@charset "UTF-8";
/* CSS Document */
html {
  font-size: 62.5%; /* -> 10px; */
}
body {
	/*font-family: Crossten,"游ゴシック体","Yu Gothic",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;*/
	font-family: "Lucida Grande", "segoe UI", "ヒラギノ丸ゴ ProN W4", "Hiragino Maru Gothic ProN", Meiryo, Arial, sans-serif;
	overflow: auto;
	height: 100%;
}
img {
    width: 100%;
    height: auto;
}
ul {
	padding: 0;
	margin: 0;
	list-style: none;
}
h1, h2, h3, h4, h5, h6 {
    color: #555;
}
p {
	color: #555;
}
a:hover {
	text-decoration: none;
}
.margin-auto {
	margin: 0 auto;
}
/*--------------------------------ヘッダー--------------------------------*/
/*header {
    background-color: rgba(255,255,255,0.9);
    padding-bottom: 1.5rem;
	position: fixed;
    width: 100%;
    left: 0;
    top: 0;
    z-index: 1000;
	transition: .5s;
}*/
.header {
  	background-color: rgba(255,255,255,1);
    /*padding-bottom: 1.5rem;*/
	position: fixed;
    width: 100%;
    left: 0;
    top: 0;
    z-index: 1000;
	transition: .5s;
}
.hidden {
  /*background: none;*/
  transition: all 0.5s ease;
}
@media (max-width: 991px) {
	.header {
  	display: none;
}	
}
header .navbar {
	padding: 0;
}
header .navbar .container {
	padding: 2rem 1.5rem;
}
.main-logo {
    position: relative;
    height: auto;
    text-align: center;
    cursor: pointer;
    z-index: 0;
}
.main-logo a {
	font-size: 16px;
    color: #707070;
    text-decoration: none;
}
.main-logo img {
    height: 2rem;
}
.header-menu-box {
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.header-menu-top {
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
	
	padding: 1.5rem 0;
	    padding-top: 0;
}
.header-menu-top h1 {
	display: none;
}
.header-menu-bottom {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-around;
}
.header-menu {
	display: block;
}
.header-menu > li {
    float: left;
	padding: 1rem 1.5rem;
}
.header-menu > li > a {
    position: relative;
    display: block;
    color: #555;
    font-size: 1.3rem;
    letter-spacing: 0.2rem;
}
.hidden .header-menu > li > a {
    color: #555;
}
.header-menu > li > a:hover {
    text-decoration: none;
}
.header-phone {
	/*margin-left: 5rem;*/
	position: relative;
    margin-top: -60px;
    top: 60px;
}
.header-phone img {
	width: auto;
	height: 12rem;
}
.main-content-button p {
	margin: 0;
	font-size: 1.8rem;
	letter-spacing: 0.2rem;
	line-height: 1.2;
}
.main-content-button p span {
	font-size: 1.2rem;
}
.main-content-button a {
	width: 25rem;
	display: block;
	cursor: pointer;
	margin-bottom: 1rem;
	padding: 1.5rem;
    /*border-radius: 0.4rem;*/
	box-sizing: border-box;
	color: #fff;
	text-align: center;
	text-decoration: inherit;
	
	/*background-color: #CE3644;*/
	background: rgba(208,17,27,1);
background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );
	
	/*box-shadow: 0 0.6rem 0 rgb(174, 16, 24), 0 1.2rem 0 rgba(0,0,0,.2);
	transition: color .3s, background .3s, box-shadow .3s, transform .3s;*/
}
.main-content-button a:hover {
	/*box-shadow: 0 0.3rem 0 rgb(174, 16, 24), 0 0.6rem 0 rgba(0,0,0,.2);
	transform: translateY(0.3rem);
	animation: flash 1s both;*/
}
.main-content-button a:active {
	/*color: #ddd;
	background: #12978d;
	box-shadow: 0 0.6rem 0 rgb(174, 16, 24), 0 1.2rem 0 rgba(0,0,0,.2);
	transform: translateY(0.6rem);*/
	transition-duration: .1s;
}
@keyframes flash {
	0% { background: #F26956; }
	10% { background: #F38677; }
	100% { background: #F26956; }
}
/*トランスフォーム*/
header.transform {
    background-color: rgba(255,255,255,0.9);
    padding-bottom: 1.5rem;
	position: fixed;
    width: 100%;
    left: 0;
    top: -19.8rem;
    z-index: 1000;
}
.header-change{
    background: rgb(244, 163, 100);
    position: fixed;
    top: -7.8rem;
	left: 0;
    transition: .5s;
    width: 100%;
	z-index: 999;
	/*box-shadow: 0 0.3rem 0 rgba(0,0,0,.2);*/
	/*border-bottom: 2px solid #f4a363;*/
}
@media (max-width: 991px) {
	.header-change {
		display: none;
	}
}
.header-change.show{
    top: 0;
}
.header-change-menu {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 1.0rem 0;
}
.change-menu-box {
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-around;
}
.change-content-button p {
	margin: 0;
	/*padding: 0 1.5rem;*/
}
.change-content-button p span {
	font-size: 1.2rem;
}
.change-content-button a {
	position: relative;
    display: inline;
    color: #FFF;
    /*font-weight: bold;*/
    font-size: 1.4rem;
    letter-spacing: 0.2rem;
    transition: .3s;
    padding: 10px 20px;
	background-color: #595959;
    /*background: rgba(208,17,27,1);
    background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
    background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
    background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
    background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
    background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
    background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );*/
}
.change-content-button a:hover {
	opacity: 0.5;
	text-decoration: none;
}
/*.change-content-button a:active {
	color: #ddd;
	background: #12978d;
	box-shadow: 0 0.6rem 0 rgb(174, 16, 24), 0 1.2rem 0 rgba(0,0,0,.2);
	transform: translateY(0.6rem);
	transition-duration: .1s;
}
@keyframes flash {
	0% { background: #F26956; }
	10% { background: #F38677; }
	100% { background: #F26956; }
}*/
/*--------------------------------ヘッダー--------------------------------*/
/*--------------------------------トップページ--------------------------------*/
.hero-wrap {
    position: relative;
    width: 100%;
	top: 0;
	padding-top: 0;
	z-index: -1;
	/*max-width: 1140px;*/
    margin: 0 auto;
    /*margin-top: 102px;*/
}
.other-page .hero-wrap {
    position: relative;
    width: 100%;
    /*max-width: 1140px;*/
    top: 0;
    padding-top: 0;
    z-index: -1;
    margin: 0 auto;
    margin-top: 83px;
}
@media (max-width: 991px) {
.hero-wrap {
    position: relative;
    width: 100%;
	top: 0;
	padding-top: 5rem;
	z-index: -1;
}
	.other-page .hero-wrap {
	margin-top: 50px;
	}
}
@media (min-width: 576px) {
	.other-page .hero-wrap {
	max-width: 100%;
	}
}
@media (min-width: 768px) {
	.other-page .hero-wrap {
	max-width: 100%;
	/*margin-top: 50px;*/
	z-index: 1;	
	}
}
@media (min-width: 992px) {
	.other-page .hero-wrap {
	max-width: 960px;
	/*margin-top: 100px;*/	
	}
}
@media (min-width: 1200px) {
	.other-page .hero-wrap {
	max-width: 1140px;
	/*margin-top: 100px;*/	
	}
}
.hero-image {
    position: relative;
	width: 100%;
    /*height: calc(100vh - 102px);*/
	height: 100vh;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
	display: table;
    text-align: center;
	/*border-radius: 50px;*/
}
@media (min-width: 992px) {
.top-page .hero-image {
    height: calc(100vh - 83px);
	margin-top: 83px;
}
}
@media (max-width: 991px) {
	.hero-image {
    height: calc(100vh - 50px);
	}
}
.other-page .hero-image {
    position: relative;
	width: 100%;
    /*height: calc(100vh - 102px);*/
	height: 500px;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
	display: table;
    text-align: center;
	border-radius: 0 0 50px 50px;
}
.privacy-page .hero-image {
    position: relative;
    width: 100%;
    /* height: calc(100vh - 102px); */
    height: 0;
}
.top-page .hero-image {
    background-image: url(../images/anzu/05.jpg);
}
.concept-page .hero-image {
    background-image: url("../images/anzu/satsuei/27.jpg");
	background-position: center center;
}
.service-page .hero-image {
    background-image: url("../images/anzu/01.jpg");
	background-position: center center;
}
.company-page .hero-image {
    background-image: url("../images/anzu/satsuei/03.jpg");
	background-position: center center;
}
.recruit-page .hero-image {
    background-image: url("../images/anzu/03.jpg");
	background-position: center center;
}
.access-page .hero-image {
    background-image: url("../images/anzu/satsuei/19.jpg");
	background-position: center center;
}
@media (max-width: 991px) {
	.other-page .hero-image {
    border-radius: 0;
}
}
@media (max-width: 767px) {
	.hero-image {
    position: relative;
	width: 100%;
    height: 400px;
}
}
.hero-image .hero-text {
	display: table-cell;
    vertical-align: middle;
}
.other-page .hero-image .hero-text {
    display: table-cell;
    vertical-align: bottom;
	position: relative;
    bottom: -30px;
}
@media (max-width: 767px) {
.hero-image .hero-text {
	display: table-cell;
  vertical-align: middle;
	padding-top: 0;
}
}
.hero-image .hero-text .hero-copy {
    color: #fff;
    line-height: 2;
    letter-spacing: 0.4rem;
    display: inline-block;
    width: auto;
    margin: 0 auto;
}
.top-page .hero-image .hero-text .hero-copy {
    padding: 5rem;
    background-color: rgba(244, 163, 100, 0.8);
    border-radius: 50%;
}
.other-page .hero-image .hero-text .hero-copy {
    color: #fff;
    line-height: 2;
    letter-spacing: 0.4rem;
    width: 100%;
    margin: 0 auto;
	background-color: transparent;
}
@media (max-width: 991px) {
.hero-image .hero-text .hero-copy {
    color: #fff;
	line-height: 2;
    letter-spacing: 0.4rem;
	width: 90%;
    margin: 0 auto;
}
.top-page .hero-image .hero-text .hero-copy {
	width: auto;
}
}
@media (max-width: 767px) {
.hero-image .hero-text .hero-copy {
    color: #fff;
	line-height: 2;
    letter-spacing: 0.4rem;
	width: 80%;
    margin: 0 auto;
}
.top-page .hero-image .hero-text .hero-copy {
    padding: 2.5rem;
    width: auto;
}    
}
.hero-copy h2 {
	margin-bottom: 2rem;
    font-size: 4rem;
    /*font-family: source-han-sans-japanese, sans-serif;*/
font-weight: 900;
font-style: normal;
    display: inline-block;
}
.other-page .hero-copy h2 {
	background-color: #f4a365;
    display: inline-block;
    padding: 10px 20px;
    border-radius: 50px;
    font-size: 3.6rem;
    font-weight: normal;
	margin: 0;
	color: #fff;
}
@media (max-width: 767px) {
	.hero-copy h2 {
	margin-bottom: 2rem;
    font-size: 2.2rem;
}
}
.hero-copy h2 img {
    width: 100%;
	height: 150px;
	/*filter: drop-shadow(2px 2px 2px rgba(0,0,0,0.3));*/
}
.hero-copy img {
    width: 100%;
	height: 150px;
    margin-bottom: 15px;
	/*filter: drop-shadow(2px 2px 2px rgba(0,0,0,0.3));*/
}
@media (max-width: 767px) {
.hero-copy h2 img {
    width: 80%;
    height: auto;
}
.hero-copy img {
    width: 65%;
    height: auto;
    margin-bottom: 15px;
}    
}
.hero-copy p {
    font-size: 1.4rem;
    font-weight: normal;
    color: #fff;
	/*filter: drop-shadow(2px 1px 2px rgba(0,0,0,0.3));*/
}
@media (max-width: 767px) {
.hero-copy p {
    font-size: 1.2rem;
    font-weight: normal;
    color: #fff;
}
}
.hero-copy p span {
    font-size: 1.4rem;
    font-weight: normal;
    color: #fff;
}
/*トップ_サービス*/
#top-service.top-service-wrap {
	padding: 10rem 0;
	background-color: #fff;	
}
@media (max-width: 767px) {
	#top-service.top-service-wrap {
	padding: 0;
	background-color: #fff;	
}
	#top-service .container {
	/*margin: 5rem 0 3rem 0;*/
}
	#top-service .service-num-wrap .container {
	margin-top: 5rem;
    margin-bottom: 5rem;	
}
	#top-service .service-num-wrap:last-of-type .container {
	margin-top: 0;
    margin-bottom: 5rem;	
}
}
.contents-title-box {
	display: inline;
    /*padding: 0.1rem 0.5rem;
    background-color: #cf111b;*/
    position: relative;
    z-index: 1;
}
h2.contents-title {
	font-size: 1.6rem;
    letter-spacing: 0.4rem;
	/*margin-bottom: 0;
	margin-left: 0.5rem;
    margin-top: -0.5rem;*/
	position: relative;
	z-index: 2;
}
#top-service h2.contents-title span {
	font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
#top-service .contents-dis-box {
	padding: 10rem 20rem;
}
@media (max-width: 991px) {
	#top-service .contents-dis-box {
	padding: 5rem 10rem;
}
}
@media (max-width: 767px) {
	#top-service .contents-dis-box {
	padding: 3rem 0;
}
}
#top-service p.contents-dis {
	font-size: 1.4rem;
    letter-spacing: 0.2rem;
    text-align: left;
}
#top-service .service-num-wrap {
	padding-bottom: 80px;
}
@media (max-width: 767px) {
	#top-service .service-num-wrap {
	padding-bottom: 0;
	margin-top: 0;	
}
}
#top-service .service-num {
	padding-top: 0;
    padding-bottom: 0;
}
@media (max-width: 767px) {
#top-service .service-num {
	padding-top: 0;
    padding-bottom: 0;
}	
}
#top-service .service-01 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#top-service .service-01-bg {
	background-image: url(../images/top/service_01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    right: 0;
}
@media (max-width: 767px) {
	#top-service .service-01-bg {
    width: 100%;
    height: 250px;
    position: relative;
	top: 0;
    left: 0;
    margin-bottom: 30px;
}
}
#top-service .service-02 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#top-service .service-02-bg {
	background-image: url(../images/top/service_02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    left: 0;
}
@media (max-width: 767px) {
	#top-service .service-02-bg {
    width: 100%;
    height: 250px;
    position: relative;
	top: 0;
    left: 0;
    margin-bottom: 30px;
}
}
#top-service .text-top {
	position: relative;
	margin-bottom: 4rem;
}
#top-service .text-top h3 {
	position: relative;
	font-size: 3rem;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #333;
}
#top-service .text-top p {
    font-size: 1.6rem;
    letter-spacing: 0.2rem;
    color: #555;
    margin-top: 1rem;
}
#top-service .text-bottom {
	margin-bottom: 4rem;
}
#top-service .text-bottom p.copy {
	font-size: 1.8rem;
    letter-spacing: 0.2rem;
    color: #666;
}
#top-service .text-bottom p.dis {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
}
.content-button p {
	margin: 0;
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
	line-height: 1.2;
}
.content-button p span {
	font-size: 1.2rem;
}
.content-button a {
	width: auto;
	display: inline-block;
	cursor: pointer;
	margin-bottom: 1rem;
	padding: 1.0rem 1.5rem;
	box-sizing: border-box;
	text-align: center;
	text-decoration: inherit;
	
	border: 1px solid #666;
    position: relative;
    color: #333;
    /* min-width: 200px; */
    padding: 1.5rem 3rem;

	/*background: rgba(208,17,27,1);
background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );*/
	
	/*box-shadow: 0 0.6rem 0 rgb(174, 16, 24), 0 1.2rem 0 rgba(0,0,0,.2);
	transition: color .3s, background .3s, box-shadow .3s, transform .3s;*/
}
.content-button a:hover {
	/*box-shadow: 0 0.3rem 0 rgb(174, 16, 24), 0 0.6rem 0 rgba(0,0,0,.2);
	transform: translateY(0.3rem);
	animation: flash 1s both;*/
}
.content-button a:active {
	color: #ddd;
	background: #12978d;
	/*box-shadow: 0 0.6rem 0 rgb(174, 16, 24), 0 1.2rem 0 rgba(0,0,0,.2);
	transform: translateY(0.6rem);*/
	transition-duration: .1s;
}
@keyframes flash {
	0% { background: #F26956; }
	10% { background: #F38677; }
	100% { background: #F26956; }
}
#top-service .content-button a {
    width: auto;
    display: inline-block;
    cursor: pointer;
    margin-bottom: 1rem;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    background-color: #f4a364;
	border-radius: 30px;
	font-size: 1.4rem;
}
@media (max-width: 767px) {
	#top-service .content-button a {
		width: 100%;
	}
}
.service-dis-bg {
	background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.service-dis-bg-01 {
    background-image: url(../images/top/service_01.jpg);
}
.service-dis-bg-02 {
    background-image: url(../images/top/service_02.jpg);
}
.service-dis-bg-03 {
    background-image: url(../images/top/service_03.jpg);
}
.service-dis-bg-inner {
	padding-top: 15rem;
    padding-bottom: 15rem;
	background-color: rgba(0, 0, 0, 0.3);
}
.service-dis-bg h3 {
	font-size: 3rem;
    color: #FFF;
    letter-spacing: 0.2rem;
    font-weight: bold;
	margin-bottom: 3rem;
}
.service-dis-bg p {
	font-size: 1.6rem;
    color: #FFF;
    letter-spacing: 0.2rem;
	text-align: left;
	padding: 0 10rem;
}
/*トップ_ギャラリー*/
#top-gallery.top-gallery-wrap {
	padding: 10rem 0;
	background-color: #fff;
}
@media (max-width: 767px) {
	#top-gallery.top-gallery-wrap {
	padding: 5rem 0 3rem 0;
	background-color: #fff;
}
}
#top-gallery .contents-title-box {
	
}
#top-gallery h2.contents-title {
	font-size: 1.6rem;
    letter-spacing: 0.4rem;
	margin-bottom: 0;
}
#top-gallery h2.contents-title span {
	font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
#top-gallery .contents-dis-box {
	padding: 10rem 20rem;
    padding-bottom: 0;
}
@media (max-width: 991px) {
	#top-gallery .contents-dis-box {
	padding: 5rem 10rem;
    padding-bottom: 0;
}
}
@media (max-width: 767px) {
	#top-gallery .contents-dis-box {
	padding: 3rem 0;
    padding-bottom: 0;
}
}
#top-gallery p.contents-dis {
	font-size: 1.4rem;
    letter-spacing: 0.2rem;
    text-align: left;
}
#top-gallery .service-num-wrap {
	
}
#top-gallery .service-num {
	padding-top: 60px;
    padding-bottom: 0;
}
#top-gallery .service-01 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#top-gallery .service-01-bg {
	background-image: url(../images/top/service_01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    right: 0;
}
#top-gallery .service-02 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#top-gallery .service-02-bg {
	background-image: url(../images/top/service_02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    left: 0;
}
#top-gallery .text-top {
	position: relative;
	margin-bottom: 4rem;
}
#top-gallery .text-top h3 {
	position: relative;
	font-size: 2.6rem;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
#top-gallery .text-top p {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
#top-gallery .text-bottom {
	margin-bottom: 4rem;
}
#top-gallery .text-bottom p.copy {
	font-size: 1.8rem;
    letter-spacing: 0.2rem;
    color: #666;
}
#top-gallery .text-bottom p.dis {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
}
.gallery-bg {
	background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-image: url(../images/top/service_03.jpg);
	width: 100%;
	height: 40rem;
}
#top-gallery .content-button {
    margin-top: -2.8rem;
}
#top-gallery .content-button a {
    width: auto;
    display: inline-block;
    cursor: pointer;
    margin-bottom: 1rem;
    padding: 1.0rem 1.5rem;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    /*background-color: #cf111b;*/
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
	
	background: rgba(208,17,27,1);
background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );
}
/*トップ_お知らせ*/
#top-news.top-news-wrap {
    padding: 10rem 0;
    background-color: #fff;
}
@media (max-width: 767px) {
	#top-news.top-news-wrap {
    padding: 5rem 0 5rem 0;
}
}
#top-news h2.contents-title {
    font-size: 1.6rem;
    letter-spacing: 0.4rem;
    margin-bottom: 0.5rem;
}
#top-news h2.contents-title span {
    font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
#top-news .news-content-wrap {
    padding: 0;
    padding-bottom: 0;
}
@media (max-width: 767px) {
	#top-news .news-content-wrap {
    padding: 3rem 0;
    padding-bottom: 0;
}
}
#top-news .news-content {
    background: #fff;
    display: block;
    padding: 0;
    position: relative;
    color: #111;
    min-height: 150px;
    -webkit-align-items: center;
    align-items: center;
}
@media (max-width: 991px) {
	#top-news .news-content {
    margin-bottom: 50px;
}
}
#top-news .news-cat-tag {
	position: absolute;
    left: 0;
    top: 0;
    line-height: 100%;
}
#top-news .news-cat-tag span {
	display: inline-block;
    font-size: 75%;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 0px;
	padding: 0.75rem 1rem;
    -webkit-border-radius: 0;
    border-bottom-right-radius: 15px;
	color: #fff;
    background: rgb(118, 202, 159);
}
#top-news .news-content-text {
	text-align: left;
}
#top-news .news-content-text time {
	font-size: 1.2rem;
	font-weight: normal;
	color: #555;
}
#top-news .news-content-text p {
	font-size: 1.4rem;
    margin-top: 1rem;
    letter-spacing: 0.1rem;
    line-height: 1.8;
	overflow: hidden;
    height: 5rem;
    margin-bottom: 0;
	font-weight: normal;
}
.contact-wrap {
    padding: 5rem 0;
    background-color: #f8f8f8;
}
/*@media (max-width: 767px) {
	.contact-wrap {
    padding: 5rem 0 3rem 0;
    background-color: #fff;
}
}*/
.contact-wrap h2.contents-title {
    font-size: 1.6rem;
    letter-spacing: 0.4rem;
    margin-bottom: 0;
}
.contact-wrap h2.contents-title span {
    font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
.contact-wrap .contents-dis-box {
    /*padding: 10rem 20rem;*/
    padding-bottom: 0;
    padding-top: 3rem;
}
@media (max-width: 991px) {
	.contact-wrap .contents-dis-box {
    padding: 10rem 10rem;
    padding-bottom: 0;
    padding-top: 3rem;
}
}
.contact-wrap .contact-tel-box {
	margin-bottom: 3rem;
}
.tel-add {
	font-size: 1.6rem;
    font-weight: bold;
    letter-spacing: 0.2rem;
	/*font-family: doppio-one, sans-serif;*/
	color: #555;
}
.tel-add span {
	font-size: 3rem;
	color: #f4a364;
}
.tel-time {
	font-size: 1.4rem;
}
.contact-wrap p.contents-dis {
    font-size: 1.8rem;
    letter-spacing: 0.2rem;
    line-height: 1.8;
    text-align: left;
    margin-bottom: 3rem;
	color: #555;
}
.contact-wrap .content-button a {
    width: auto;
    display: inline-block;
    cursor: pointer;
    margin-bottom: 1rem;
    padding: 1.0rem 1.5rem;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    background-color: #f4a364;
    border-radius: 30px;
    
}
@media (max-width: 767px) {
	.contact-wrap .content-button a {
		width: auto;
	}
}
.contact-wrap .content-button a:hover {
    /*display: inline-block;
    cursor: pointer;
    margin-bottom: 1rem;
    padding: 1.0rem 1.5rem;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
    background: rgba(208,17,27,1);
    background: -moz-linear-gradient(left, rgba(252,51,51,1) 0%, rgba(208,17,27,1) 100%);
    background: -webkit-gradient(left top, right top, color-stop(0%, rgba(252,51,51,1)), color-stop(100%, rgba(208,17,27,1)));
    background: -webkit-linear-gradient(left, rgba(252,51,51,1) 0%, rgba(208,17,27,1) 100%);
    background: -o-linear-gradient(left, rgba(252,51,51,1) 0%, rgba(208,17,27,1) 100%);
    background: -ms-linear-gradient(left, rgba(252,51,51,1) 0%, rgba(208,17,27,1) 100%);
    background: linear-gradient(to right, rgba(252,51,51,1) 0%, rgba(208,17,27,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fc3333', endColorstr='#d0111b', GradientType=1 );*/
}
@media (max-width: 767px) {
	.contact-wrap .contents-dis-box {
    padding: 0;
    padding-bottom: 0;
    padding-top: 3rem;
}
}
.footer-box-wrap {
	background-color: #fff;
	padding-top: 4rem;
    padding-bottom: 8rem;
	/*background: url(../images/footer-bg-img.png) repeat;*/
}
@media (max-width: 767px) {
	.footer-box-wrap {
	padding-top: 3rem;
}
}
.footer-box-wrap .footer-box {
    /*padding: 44px 57px 108px;
    position: relative;*/
	/*display: flex;
    flex-wrap: wrap;*/
}
.footer-head-menu {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 1.5rem 0;
	border-top: 1px solid #eee;
}
.footer-head-menu h2 {
    display: none;
}
.footer-head {
    display: block;
}
.footer-head > li {
    float: left;
	padding: 1rem 1.5rem;
    padding-right: 0;
}
.footer-head > li > a {
    position: relative;
    display: block;
    color: #333;
    font-size: 1.2rem;
    letter-spacing: 0.2rem;
}
.footer-head > li > a:hover {
    text-decoration: none;
}
.header-change.show-add {
	top: -60px;
}
.footer-col {
	/*flex-basis: 0;
    flex-grow: 1;
    max-width: 100%;
	padding: 0 2rem;*/
}
@media (max-width: 767px) {
	.footer-col {
	flex-basis: auto;
    flex-grow: 1;
    max-width: 50%;
	padding: 0 2rem;
	margin-bottom: 0;	
}
}
.footer-col-title {
	font-size: 1.4rem;
	color: #fff;
	letter-spacing: 0.1rem;
	line-height: 1.8;
}
.footer-col-contact {
	background-color: #fff;
    color: #333;
    display: inline-block;
    font-size: 1.2rem;
    margin-top: 1rem;
}
@media (max-width: 767px) {
	.footer-col-contact {
    font-size: 1.6rem;
    text-align: center;
	width: 100%;
}
	.footer-oshirase, .footer-address {
	max-width: 100%;
	width: 100%;	
	}
	.footer-address {
	text-align: center;
		margin-top: 3rem;
    padding-top: 3rem;
    border-top: 2px solid #999;
	}
	.footer-oshirase ul {
		margin-bottom: 2rem;
	}
}
.footer-col-contact a {
	padding: 2rem;
    display: block;
    color: #333;
}
.footer-col-contact a {
	text-decoration: none;
}
@media (max-width: 767px) {
	.footer-col-contact a {
	padding: 2rem;
}
}
.footer-menu {
	padding: 0;
    list-style: none;
    margin: 0;
	overflow: hidden;
	text-align: right;
}
.footer-menu li {
	margin-bottom: 1rem;
	/*float: left;*/
	margin-left: 30px;
	display: inline-block;
}
.footer-menu li:first-child {
	margin-left: 0;
}
/*.footer-menu li:before {
	content: '-';
	color:#fff;
	padding-right: 0.5rem;
}*/
.footer-menu li a {
	font-size: 1.2rem;
    color: #555;
    letter-spacing: 0.2rem;
    line-height: 1.8;
}
.footer-col .content-button p {
    font-size: 1.0rem;
}
.footer-col .content-button a {
    width: 100%;
    padding: 2rem 1.5rem;
    background-color: #fff;
}
.footer-logo-wrap {
	width: 80%;
}
@media (max-width: 767px) {
	.footer-logo-wrap {
    width: 50%;
    margin: 0 auto;
}
}
.footer-logo {
    position: relative;
    height: auto;
    cursor: pointer;
    z-index: 0;
	margin: 0.5rem 0;
}
.footer-logo img {
	width: 100%;
}
.footer-logo-title {
    font-size: 1.4rem;
    color: #555;
    letter-spacing: 0.1rem;
    line-height: 1.8;
	display: flex;
  	justify-content: space-between;
}
.footer-address p.add-info {
	font-size: 1.2rem;
    color: #555;
    line-height: 1.8;
    letter-spacing: 0.1rem;
}
.copyright {
	padding: 2rem 0;
    background-color: #76ca9f;
	background-image: url("../images/anzu/footer-bg.svg");
	background-repeat: no-repeat;
    background-position: bottom;
}
.copyright p {
	color: #fff;
    margin: 0;
}
@media (max-width: 767px) {
	.copyright {
	margin-top: 0;
}
}
/*--------------------------------トップページ--------------------------------*/

/*--------------------------------小ロット対応--------------------------------*/
.hero-image.p-customer {
	background-image: url("../images/private/hero-img.jpg");
}
.hero-image.c-customer {
	background-image: url("../images/corporation/hero-img.jpg");
}
/*トップ_サービス*/
#p-customer.service-wrap, #c-customer.service-wrap {
	padding: 10rem 0;
	background-color: #fff;
	/*background: url(../images/line.png) no-repeat center center;
    background-size: cover;*/
}
@media (max-width: 991px) {
	#p-customer.service-wrap, #c-customer.service-wrap {
	padding: 0;
}
}
.contents-title-box {
	display: inline-block;
    /*padding: 0.1rem 0.5rem;
    background-color: #cf111b;*/
    position: relative;
    z-index: 1;
	margin-bottom: 50px;
}
h2.contents-title {
	font-size: 1.6rem;
    letter-spacing: 0.4rem;
	/*margin-bottom: 0;
	margin-left: 0.5rem;
    margin-top: -0.5rem;*/
	position: relative;
	z-index: 2;
	display: inline-block;
}
h2.contents-title .topics {
	width: auto;
	height: 28px;
}
.contact-wrap h2.contents-title .topics {
	width: auto;
	height: 28px;
}
@media (max-width: 767px) {
.privacy-page h2.contents-title .topics {
    width: auto;
    height: 18px;
}
.privacy-page h2.contents-title .con-img::after {
    width: 25px;
    height: 25px;
}
}
h2.contents-title .con-img::after {
	content: '';/*何も入れない*/
  	display: inline-block;/*忘れずに！*/
  	width: 36px;/*画像の幅*/
  	height: 36px;/*画像の高さ*/
  	background-image: url("../images/anzu/leaf.svg");
  	background-size: contain;
  	vertical-align: middle;
	background-repeat: no-repeat;
	margin-left: 10px;
}
@media (max-width: 767px) {
	h2.contents-title .con-img::after {
		width: 24px;/*画像の幅*/
  	height: 24px;/*画像の高さ*/
	}
	h2.contents-title .topics {
	width: auto;
	height: 20px;
}
.contact-wrap h2.contents-title .topics {
	width: auto;
	height: 20px;
}
}
.contact-wrap h2.contents-title .con-img::after {
  	width: 36px;/*画像の幅*/
  	height: 36px;/*画像の高さ*/
}
#p-customer h2.contents-title span, #c-customer h2.contents-title span {
	font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
#p-customer .contents-dis-box, #c-customer .contents-dis-box {
	padding: 10rem 20rem;
}
#p-customer p.contents-dis, #c-customer p.contents-dis {
	font-size: 1.4rem;
    letter-spacing: 0.2rem;
    text-align: left;
}
#p-customer .service-num-wrap, #c-customer .service-num-wrap {
	padding-bottom: 80px;
}
@media (max-width: 991px) {
	#p-customer .service-num-wrap, #c-customer .service-num-wrap {
	padding-bottom: 0;
}
}
#p-customer .service-num, #c-customer .service-num {
	padding-top: 60px;
    padding-bottom: 60px;
}
@media (max-width: 991px) {
#p-customer .service-num, #c-customer .service-num {
	padding: 60px 15px
}
#p-customer .service-num-wrap:nth-child(1) .service-num, #c-customer .service-num-wrap:nth-child(1) .service-num {
	padding-bottom: 0;
}
}
@media (max-width: 767px) {
#p-customer .service-num-wrap .service-num, #c-customer .service-num-wrap .service-num {
	padding: 15px 15px;
}
}
.topics-col {
    margin-bottom: 50px;
}
.topics-col h3 {
	display: block;
    padding: 10px 30px;
    background-color: #f4a365;
    color: #fff;
    font-size: 18px;
    letter-spacing: 0.2rem;
	border-radius: 30px;
    margin-bottom: 15px;
}
.sub-title-acc h3 {
    display: inline-block;
    padding: 15px 30px;
    background-color: #f4a365;
    color: #fff;
    font-size: 22px;
    letter-spacing: 0.2rem;
    border-radius: 30px;
    margin-bottom: 30px;
	width: 100%;
}
.service-page .topics-col h3 {
    margin-bottom: 30px;
}
.privacy-page .topics-col h3 {
    margin-bottom: 50px;
}
.topics-col h4 {
	display: block;
	text-align: left;
    color: #555;
    font-size: 20px;
    letter-spacing: 0.2rem;
    margin-bottom: 20px;
	position: relative;
	padding-left: 1.5em;
}
.service-page .topics-col h4::before {
  	font-family: "Font Awesome 5 Free";
    content: "\f111";
    position: absolute;
    font-size: 16px;
    left: 0;
    top: 1.5px;
    color: #f4a364;
	font-weight: 900;
}
.topics-col p {
	font-size: 1.6rem;
	line-height: 1.8;
    letter-spacing: 0.2rem;
    text-align: left;
	color: #555;
	margin-bottom: 20px;
}
.topics-col p span::before, .topics-col p span::after {
	position: relative;
  font-family: "Font Awesome 5 Free";
  display: inline-block;
  font-size: 1.0em;
  color: #f4a364;
	font-weight: 900;
}

.service-page .topics-col .service-dis-col {
	margin-bottom: 100px;
}
.service-page .topics-col .service-dis-col.gyoji {
    margin-bottom: 15px;
}
.topics-col p span::before {
  content:"\f053";/*アイコン種類*/
  padding-right: 0.5em
}
.topics-col p span::after {
  content:"\f054";/*アイコン種類*/
  padding-left: 0.5em
}
.other-page .topics-col img {
	width: 100%;
	height: auto;
}
/*------------------------#p-customer------------------------*/
#p-customer .service-01 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#p-customer .service-01-bg {
	background-image: url(../images/private/01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 60%;
    height: calc(100% + 8rem);
    position: absolute;
    right: 0;
}
@media (max-width: 991px) {
	#p-customer .service-01-bg {
	background-image: url(../images/private/01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 100%;
    height: 350px;
    position: relative;
    right: 0;
	margin: 0 auto;	
}
}
@media (min-width: 768px) and (max-width: 991px) {
	#p-customer .service-01-bg {
	max-width: 720px;
}
}
@media (max-width: 767px) {
	#p-customer .service-01-bg {
    height: 250px;
}
}
#p-customer .service-02 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#p-customer .service-02-bg {
	background-image: url(../images/private/02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 60%;
    height: calc(100% + 8rem);
    position: absolute;
    left: 0;
}
@media (max-width: 991px) {
	#p-customer .service-02-bg {
	background-image: url(../images/private/02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 100%;
    height: 350px;
    position: relative;
    right: 0;
	margin: 0 auto;	
}
}
@media (min-width: 768px) and (max-width: 991px) {
	#p-customer .service-02-bg {
	max-width: 720px;
}
}
@media (max-width: 767px) {
	#p-customer .service-02-bg {
    height: 250px;
}
}
/*------------------------#p-customer------------------------*/
/*------------------------#c-customer------------------------*/
#c-customer .service-01 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#c-customer .service-01-bg {
	background-image: url(../images/corporation/no-image.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 60%;
    height: calc(100% + 8rem);
    position: absolute;
    right: 0;
}
@media (max-width: 991px) {
	#c-customer .service-01-bg {
	background-image: url("../images/corporation/no-image.jpg");
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 100%;
    height: 350px;
    position: relative;
    right: 0;
	margin: 0 auto;	
}
}
@media (min-width: 768px) and (max-width: 991px) {
	#c-customer .service-01-bg {
	max-width: 720px;
}
}
@media (max-width: 767px) {
	#c-customer .service-01-bg {
    height: 250px;
}
}
#c-customer .service-02 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#c-customer .service-02-bg {
	background-image: url(../images/corporation/no-image.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 60%;
    height: calc(100% + 8rem);
    position: absolute;
    left: 0;
}
@media (max-width: 991px) {
	#c-customer .service-02-bg {
	background-image: url("../images/corporation/no-image.jpg");
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 100%;
    height: 350px;
    position: relative;
    right: 0;
	margin: 0 auto;	
}
}
@media (min-width: 768px) and (max-width: 991px) {
	#c-customer .service-02-bg {
	max-width: 720px;
}
}
@media (max-width: 767px) {
	#c-customer .service-02-bg {
    height: 250px;
}
}
#c-customer .service-03 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#c-customer .service-03-bg {
	background-image: url(../images/corporation/no-image.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 60%;
    height: calc(100% + 8rem);
    position: absolute;
    right: 0;
}
@media (max-width: 991px) {
	#c-customer .service-03-bg {
	background-image: url(../images/corporation/no-image.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 100%;
    height: 350px;
    position: relative;
    right: 0;
	margin: 0 auto;	
}
}
@media (min-width: 768px) and (max-width: 991px) {
	#c-customer .service-03-bg {
	max-width: 720px;
}
}
@media (max-width: 767px) {
	#c-customer .service-03-bg {
    height: 250px;
}
}
/*------------------------#c-customer------------------------*/
#p-customer .text-top, #c-customer .text-top {
	position: relative;
	margin-bottom: 2rem;
}
#p-customer .text-top h3, #c-customer .text-top h3 {
	position: relative;
    font-size: 2.0rem;
    font-weight: bold;
    letter-spacing: 0.2rem;
    color: #ffffff;
    border-bottom: 2px solid #d50e1c;
    padding-bottom: 5px;
}
@media (max-width: 767px) {
	#p-customer .text-top h3, #c-customer .text-top h3 {
    font-size: 1.8rem;
}
}
#p-customer .text-top p, #c-customer .text-top p {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
#p-customer .text-bottom, #c-customer .text-bottom {
	margin-bottom: 4rem;
}
#p-customer .text-bottom p.copy, #c-customer .text-bottom p.copy {
	font-size: 1.8rem;
    letter-spacing: 0.2rem;
    color: #c9c9c9;
}
#p-customer .text-bottom p.dis, #c-customer .text-bottom p.dis {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
	color: #e8e8e8;
}
.content-button p {
	margin: 0;
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
	line-height: 1.2;
}
.content-button p span {
	font-size: 1.2rem;
}
.content-button a {
	width: auto;
	display: inline-block;
	cursor: pointer;
	margin-bottom: 1rem;
	padding: 1.0rem 1.5rem;
	box-sizing: border-box;
	text-align: center;
	text-decoration: inherit;
	
	border: 1px solid #666;
    position: relative;
    color: #333;
    /* min-width: 200px; */
    padding: 1.5rem 3rem;
}
.content-button a:hover {
	
}
.content-button a:active {
	color: #ddd;
	background: #12978d;
	transition-duration: .1s;
}
@keyframes flash {
	0% { background: #F26956; }
	10% { background: #F38677; }
	100% { background: #F26956; }
}
#p-customer .content-button a, #c-customer .content-button a {
    width: auto;
    display: inline-block;
    cursor: pointer;
    margin-bottom: 0;
    padding: 1.0rem 1.5rem;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    /*background-color: #cf111b;*/
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
	
	background: rgba(208,17,27,1);
background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );
}
.service-dis-bg {
	background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.service-dis-bg-01 {
	background: url("../images/anzu/satsuei/14.jpg") no-repeat top center fixed;
}
.service-dis-bg-inner {
	padding-top: 15rem;
    padding-bottom: 15rem;
	background-color: rgba(0, 0, 0, 0.3);
}
.service-dis-bg h3 {
	font-size: 3rem;
    color: #FFF;
    letter-spacing: 0.2rem;
    font-weight: bold;
	margin-bottom: 3rem;
}
@media (max-width: 767px) {
	.service-dis-bg h3 {
	font-size: 1.8rem;
    color: #FFF;
    letter-spacing: 0.2rem;
    font-weight: bold;
	margin-bottom: 3rem;
}
}
.service-dis-bg p {
	font-size: 1.6rem;
    color: #FFF;
    letter-spacing: 0.2rem;
	text-align: left;
	padding: 0 10rem;
}
@media (max-width: 767px) {
	.service-dis-bg p {
	font-size: 1.4rem;
    color: #FFF;
    letter-spacing: 0.2rem;
	text-align: left;
	padding: 0;
}
}
.dis-text-box {
	padding: 3rem;
    background-color: #f8f8f8;
    box-shadow: 0 3px 8px rgba(0,0,0,0.2);
	background: url(../images/footer-bg-img.png) repeat;
}

/*サービスの流れ*/
#flow.flow-wrap {
	padding: 10rem 0;
	background-color: #fff;
}
@media (max-width: 767px) {
	#flow.flow-wrap {
	padding: 10rem 0;
	padding-bottom: 2rem;
}
}
#flow.flow-wrap > .container {
	border-top: 1px solid #dfdfdf;
    padding-top: 10rem;
    margin-top: -10rem;
}
@media (max-width: 767px) {
	#flow.flow-wrap > .container {
	border-top: none;
}
}
#flow .contents-title-box {
	
}
#top-gallery h2.contents-title {
	font-size: 1.6rem;
    letter-spacing: 0.4rem;
	margin-bottom: 0;
}
#flow h2.contents-title span {
	font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
#flow .contents-dis-box {
	padding: 10rem 20rem;
    padding-bottom: 0;
}
@media (max-width: 991px) {
#flow .contents-dis-box {
	padding: 5rem 10rem;
    padding-bottom: 0;
}
}
@media (max-width: 767px) {
#flow .contents-dis-box {
	padding: 3rem 0;
}
}
#flow p.contents-dis {
	font-size: 1.4rem;
    letter-spacing: 0.2rem;
    text-align: left;
}
#flow .service-num-wrap {
	
}
#flow .service-num {
	padding-top: 60px;
    padding-bottom: 0;
}
@media (max-width: 767px) {
	#flow .service-num {
	padding-top: 0;
    padding-bottom: 0;
}
}
#flow .service-01 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#flow .service-01-bg {
	background-image: url(../images/top/service_01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    right: 0;
}
#flow .service-02 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#flow .service-02-bg {
	background-image: url(../images/top/service_02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    left: 0;
}
#flow .text-top {
	position: relative;
	margin-bottom: 4rem;
}
#flow .text-top h3 {
	position: relative;
	font-size: 2.6rem;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
#flow .text-top p {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
#flow .text-bottom {
	margin-bottom: 4rem;
}
#flow .text-bottom p.copy {
	font-size: 1.8rem;
    letter-spacing: 0.2rem;
    color: #666;
}
#flow .text-bottom p.dis {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
}
#flow .content-button {
    margin-top: -2rem;
}
#flow .content-button a {
    width: auto;
    display: inline-block;
    cursor: pointer;
    margin-bottom: 1rem;
    padding: 1.0rem 1.5rem;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    /*background-color: #cf111b;*/
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
	
	background: rgba(208,17,27,1);
background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );
}
/*.flow-box-wrap {
	margin-bottom: 4rem;
}
.flow-box-top {
	background-color: #fff;
}
.flow-box-top h3 {
	padding: 3rem;
    font-size: 2rem;
	border: 1px solid #dfdfdf;
	margin: 0 auto;
}
.flow-box-bottom {
	background-color: #fff;
}
.flow-text-box-wrap {
    padding: 4rem;
	justify-content: space-between;
    border: 1px solid #dfdfdf;
    border-top: none;
}
.flow-text-box-col {
	padding: 5rem 0 5.5rem;
    border-bottom: 1px solid #dfdfdf;
}
.flow-text-box-col:first-of-type {
	padding-top: 0;
}
.flow-text-box-col:last-of-type {
	padding-bottom: 0;
	border-bottom: none;
}
.flow-text-box {
	justify-content: space-between;
    border-top: none;
	margin-bottom: 4rem;
}
.flow-text-box:last-of-type {
	margin-bottom: 0;
}
p.flow-text {
    text-align: left;
    line-height: 2.25;
    font-size: 1.6rem;
    padding: 0 4.5rem;
	margin-bottom: 0;
	letter-spacing: 0.1rem;
}
.flow-pic-box {
	justify-content: space-between;
    border-top: none;
	display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
	margin-bottom: 4rem;
}
p.flow-pic {
    width: 50%;
	padding: 0 1.0rem;
}
p.flow-pic img {
    width: 100%;
	height: auto;
}
.flow-dis-box-col .dis-title {
	font-size: 18px;
    margin-bottom: 1.5rem;
    letter-spacing: 0.2rem;
	font-weight: bold;
}
.flow-dis-box-col .dis-text {
	font-size: 1.6rem;
    margin-bottom: 1.5rem;
    letter-spacing: 0.1em;
}*/

.flow-box-wrap {
	margin-bottom: 0;
}
.flow-box-top {
	background-color: #fff;
}
.flow-box-wrap .accordionbox {
	width: 100%;
    margin: 0 auto;
    padding: 0;
}
.flow-box-wrap .accordionlist h3 {
	font-size: 1.8rem;
    line-height: 1.8;
    letter-spacing: 0.2rem;
    text-align: left;
    margin: 0;
    display: flex;
    align-items: center;
    font-weight: normal;
}
.flow-box-wrap .accordionlist h3 span {
	font-size: 3rem;
    font-family: doppio-one, sans-serif;
    margin-right: 20px;
}
.flow-box-wrap .accordionlist .title.active-color h3 {
	/*font-weight: bold;*/
}
.flow-box-wrap .accordionlist .title.active-color h3 span {
	color: #cf111a;
}
.service-num-wrap .flow-box-wrap:first-child dd {
	display: block;
}
.flow-box-wrap .dd-inner {
	display: block;
}
.flow-box-wrap .flow-pic-box {
    justify-content: space-between;
    border-top: none;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    margin-bottom: 4rem;
	padding: 0 3.7rem;
}
@media (max-width: 767px) {
	.flow-box-wrap .flow-pic-box {
	padding: 0;
}
}
.flow-box-bottom {
	background-color: #fff;
}
.flow-text-box-wrap {
    padding: 4rem;
	justify-content: space-between;
    border: 1px solid #dfdfdf;
    border-top: none;
}
.flow-text-box-col {
	padding: 5rem 0 5.5rem;
    border-bottom: 1px solid #dfdfdf;
}
.flow-text-box-col:first-of-type {
	padding-top: 0;
}
.flow-text-box-col:last-of-type {
	padding-bottom: 0;
	border-bottom: none;
}
.flow-text-box {
	justify-content: space-between;
    border-top: none;
	margin-bottom: 4rem;
}
.flow-text-box:last-of-type {
	margin-bottom: 0;
}
p.flow-text {
    text-align: left;
    line-height: 2.25;
    font-size: 1.6rem;
    padding: 0 4.5rem;
	margin-bottom: 0;
	letter-spacing: 0.1rem;
}
@media (max-width: 767px) {
	p.flow-text {
    text-align: left;
    line-height: 2.25;
    font-size: 1.6rem;
    padding: 0;
	margin-bottom: 0;
	letter-spacing: 0.1rem;
}
}
.flow-pic-box {
	justify-content: space-between;
    border-top: none;
	display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
	margin-bottom: 4rem;
}
p.flow-pic {
    width: 50%;
	padding: 0 1.0rem;
}
p.flow-pic img {
    width: 100%;
	height: auto;
}
.flow-dis-box-col .dis-title {
	font-size: 18px;
    margin-bottom: 1.5rem;
    letter-spacing: 0.2rem;
	font-weight: bold;
}
.flow-dis-box-col .dis-text {
	font-size: 1.6rem;
    margin-bottom: 1.5rem;
    letter-spacing: 0.1em;
}

/*FAQ*/
#faq.faq-wrap {
	padding: 10rem 0;
	background-color: #f8f8f8;
}
#faq .contents-title-box {
	
}
#faq h2.contents-title {
	font-size: 1.6rem;
    letter-spacing: 0.4rem;
	margin-bottom: 0;
}
#faq h2.contents-title span {
	font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
#faq .contents-dis-box {
	padding: 10rem 20rem;
    padding-bottom: 0;
}
@media (max-width: 991px) {
	#faq .contents-dis-box {
	padding: 5rem 10rem;
    padding-bottom: 0;
}
}
@media (max-width: 767px) {
	#faq .contents-dis-box {
	padding: 3rem 0;
    padding-bottom: 0;
}
}
#faq p.contents-dis {
	font-size: 1.4rem;
    letter-spacing: 0.2rem;
    text-align: left;
}
#faq .service-num-wrap {
	
}
#faq .service-num {
	padding-top: 60px;
    padding-bottom: 0;
}
#faq .service-01 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#faq .service-01-bg {
	background-image: url(../images/top/service_01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    right: 0;
}
#faq .service-02 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#faq .service-02-bg {
	background-image: url(../images/top/service_02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    left: 0;
}
#faq .text-top {
	position: relative;
	margin-bottom: 4rem;
}
#faq .text-top h3 {
	position: relative;
	font-size: 2.6rem;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
#faq .text-top p {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
#faq .text-bottom {
	margin-bottom: 4rem;
}
#faq .text-bottom p.copy {
	font-size: 1.8rem;
    letter-spacing: 0.2rem;
    color: #666;
}
#faq .text-bottom p.dis {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
}
#faq .content-button {
    margin-top: -2rem;
}
#faq .content-button a {
    width: auto;
    display: inline-block;
    cursor: pointer;
    margin-bottom: 1rem;
    padding: 1.0rem 1.5rem;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    /*background-color: #cf111b;*/
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
	
	background: rgba(208,17,27,1);
background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );
}
@media (max-width: 767px) {
	#faq .content-button a {
		width: 100%;
	}
}
/*--------------------------------小ロット対応--------------------------------*/
/*--------------------------------弊社の強み--------------------------------*/
.hero-image.strength {
    background-image: url(../images/strength/hero-img.jpg);
}

/*トップ_ギャラリー*/
.contents-wrap {
	padding: 10rem 0;
	background-color: #fff;
}
@media (max-width: 767px) {
	#sb-site .contents-wrap {
	padding: 5rem 0;
}
	#sb-site .contents-wrap.even {
	background-color: #ececeb;
}
}
.contents-wrap h2.contents-title {
	font-size: 1.6rem;
    letter-spacing: 0.4rem;
    margin: 0;
    margin-top: 5rem;
}
@media (max-width: 767px) {
	.contents-wrap h2.contents-title {
	font-size: 1.6rem;
    letter-spacing: 0.4rem;
    margin: 0;
    margin-top: 1rem;
}
}
.contents-wrap h2.contents-title span {
	font-size: 2.6rem;
	font-family: source-han-sans-japanese, sans-serif;
    font-weight: lighter;
    font-style: normal;
}
@media (max-width: 767px) {
	.contents-wrap h2.contents-title span {
	font-size: 1.6rem;
	font-family: source-han-sans-japanese, sans-serif;
    font-weight: lighter;
    font-style: normal;
}
}
.contents-wrap .contents-dis-box {
	padding: 5rem 20rem;
    padding-bottom: 0;
}
.contents-wrap p.contents-dis {
    letter-spacing: 0.2rem;
    font-size: 3rem;
    font-family: doppio-one, sans-serif;
}
.contents-wrap .service-num-wrap {
	
}
.contents-wrap .service-num {
	padding-top: 60px;
    padding-bottom: 0;
}
.contents-wrap .service-01 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.contents-wrap .service-01-bg {
	background-image: url(../images/top/service_01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    right: 0;
}
.contents-wrap .service-02 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.contents-wrap .service-02-bg {
	background-image: url(../images/top/service_02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    left: 0;
}
.contents-wrap .text-top {
	position: relative;
	margin-bottom: 4rem;
}
.contents-wrap .text-top h3 {
	position: relative;
	font-size: 2.6rem;
	font-weight: bold;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
.contents-wrap .text-top p {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
	color: #cf111b;
}
.contents-wrap .text-bottom {
	margin-bottom: 4rem;
}
.contents-wrap .text-bottom p.copy {
	font-size: 1.8rem;
    letter-spacing: 0.2rem;
    color: #666;
}
.contents-wrap .text-bottom p.dis {
	font-size: 1.4rem;
	letter-spacing: 0.2rem;
}
.gallery-bg {
	background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    background-image: url(../images/strength/no-image.jpg);
	width: 100%;
	height: 40rem;
}
@media (max-width: 767px) {
	.gallery-bg {
	width: calc(100% - 30px);
	height: 25rem;
	margin: 0 auto;	
}
}
.contents-wrap .content-button {
    margin-top: -2rem;
}
.contents-wrap .content-button a {
    width: auto;
    display: inline-block;
    cursor: pointer;
    margin-bottom: 1rem;
    padding: 1.0rem 1.5rem;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    /*background-color: #cf111b;*/
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
	
	background: rgba(208,17,27,1);
background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );
}

.contents-text-box {
	margin-top: 5rem;
}
.contents-text-box p {
	font-size: 1.6rem;
    line-height: 2;
    letter-spacing: 0.2rem;
    text-align: left;
	margin-bottom: 3rem;
}
.contents-wrap .wrap-container {
    border-top: 1px solid #dfdfdf;
    padding-top: 10rem;
    margin-top: -10rem;
}
@media (max-width: 767px) {
	.contents-wrap .wrap-container {
    border-top: 1px solid #dfdfdf;
    padding-top: 5rem;
    margin-top: -5rem;
}
}
/*--------------------------------弊社の強み--------------------------------*/
/*--------------------------------会社情報--------------------------------*/
.other-page .contents-wrap:first-of-type {
	padding-top: 25rem;
}
@media (max-width: 991px) {
	.other-page .contents-wrap:first-of-type {
	padding-top: 10rem;
}
}
@media (max-width: 767px) {
	#sb-site .other-page .contents-wrap:first-of-type {
	padding-top: 10rem;
}
}
.other-page h2.contents-title span {
    font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
.other-page h2.contents-title {
    font-size: 1.6rem;
    letter-spacing: 0.4rem;
    margin-bottom: 0;
    margin-left: 0.5rem;
    margin-top: -0.5rem;
    position: relative;
    z-index: 2;
	color: #555;
}
@media (max-width: 767px) {
	.other-page h2.contents-title {
    margin: 0;
}
}
.other-page .gallery-bg {
	width: 80%;
    height: 50rem;
    margin: 0 auto;
}
@media (max-width: 767px) {
	.other-page .gallery-bg {
	width: 100%;
    height: 25rem;
    margin: 0 auto;
}
}
@media (max-width: 991px) {
	.other-page .gallery-bg.company-01 {
	width: 100%;
    height: 40rem;
    margin: 0 auto;
}
}
@media (max-width: 767px) {
	.other-page .gallery-bg.company-01 {
	width: 100%;
    height: 25rem;
    margin: 0 auto;
}
}
.gallery-bg.company-01{
	background-image: url(../images/company/01.jpg);
}
.other-page .contents-text-box {
	max-width: 100%;
	margin: 0 auto;
	margin-top: 5rem;
}
@media (max-width: 767px) {
	.other-page .contents-text-box {
	max-width: 90%;
	margin: 0 auto;
	margin-top: 5rem;
}
	.other-page .faq-section .contents-text-box {
	max-width: 100%;
	margin: 0 auto;
	margin-top: 5rem;
}
}
.contents-text-box .copy-text-wrap {
	margin-bottom: 4rem;
}
.contents-text-box p.copy-text {
	font-size: 2.6rem;
    font-family: source-han-sans-japanese, sans-serif;
    font-weight: lighter;
    font-style: normal;
    line-height: 2;
    letter-spacing: 0.2rem;
    text-align: center;
}
@media (max-width: 767px) {
	.contents-text-box p.copy-text {
	font-size: 1.8rem;
    font-family: source-han-sans-japanese, sans-serif;
    font-weight: lighter;
    font-style: normal;
    line-height: 2;
    letter-spacing: 0.2rem;
    text-align: center;
}
}








.table-style {
  width: 70%;	
  margin: 2rem auto;
}
.table-style th {
  color: #fff;
  padding: 1rem;
}
.table-style td {
　border: solid 1px #ccc;
}
.table-style {
margin: 0 auto;
width: 100%;
border: none;
/*border-top: solid 1px #dfdfdf;
border-bottom: solid 1px #dfdfdf;*/
border-collapse: separate;
border-spacing: 0 1rem;
/*background: #f5f5f5;*/
}
tr.gray-back {
	background-color: #fafafa;
}
.table-style th {
vertical-align: middle;
height: 5.3rem;
width: 15%;
/*border-right: solid 1px #dfdfdf;*/
margin: 0;
text-align: left;
color: #333;
font-size: 1.6rem;
font-weight: normal;
padding-left: 5rem;
padding-top: 3rem;
padding-bottom: 3rem;
}

.table-style td.data {
margin: 0;
height: 5.3rem;
width: 60%;
padding: 1rem;	
padding-left: 4rem;
padding-right: 2rem;	
border: none;
color: #666;
font-size: 1.4rem;
line-height: 2.5rem;
text-align: left;
vertical-align: middle;
/*white-space: nowrap;*/
overflow: hidden;
}

.table-style td:fst-child {
padding: 0 0 0 1rem;
vertical-align: middle;
}

.table-style td.bar {
height: 1px;
width: 100%;
border-top: solid 1px #dfdfdf;
}
@media (max-width: 767px) {
	.table-style {
  width: 100%;	
  margin: 0 auto;
}
  .last td:last-child {
    /*border-bottom: solid 1px #ccc;*/
    width: 100%;
  }
  .table-style {
    width: 100%;
    padding-left: 15px;
    padding-right: 15px;
  }
  .table-style th,
  .table-style td {
    display: block;
    width: 100%;
	border: none;
  }
.table-style td.data {
	width: 100%;
    padding: 1.0rem;
    padding-left: 1.5rem;
    height: auto;
    padding-top: 0;
    padding-bottom: 1.5rem;
}
.table-style th {
    padding-left: 0.5rem;
    line-height: 1;
	height: auto;
	font-size: 1.4rem;
}
}
/*--------------------------------会社情報--------------------------------*/
.other-page .faq-section .contents-dis-box {
    padding: 10rem 0;
	padding-top: 5rem;
    padding-bottom: 0;
}
.other-page .faq-section p.contents-dis {
    font-size: 1.4rem;
    letter-spacing: 0.2rem;
    text-align: left;
}


.accordionbox{
	width: 100%;
	/*background:#FBDBC4;*/
	margin: 10px auto 40px;
	padding: 0;
}
.accordionlist {
	border: 1px solid #DFDFDF;
	margin-bottom: 20px;
}
.accordionlist dt{
    display:block;
    background: #fff;
    padding: 30px 15px;
    border-top: 1px solid #DFDFDF;
}
.accordionlist dt:first-child{
    border-top: none !important;
}
.accordionlist dt .title{
    /*padding-left: 10px;*/
	float: left;
	display: flex;
	width: 80%;
}
.accordionlist dd{
    display: none;
	background: #fff;
	padding:30px 15px;
	border-top: 1px solid #DFDFDF;
	font-size: 1.8rem;
    line-height: 1;
    letter-spacing: 0.2rem;
    text-align: left;
    margin: 0;
    align-items: center;
    font-weight: normal;
}
.dd-inner {
	display: flex;
}
.accordionlist p {
	font-size: 1.8rem;
    line-height: 1.8;
    letter-spacing: 0.2rem;
    text-align: left;
	margin: 0;
	display: flex;
    align-items: center;
	font-weight: normal;
}
@media (max-width: 767px) {
	.accordionlist p {
		font-size: 1.6rem;
	}
}
.accordionlist p span {
	font-size: 3rem;
    font-family: doppio-one, sans-serif;
	margin-right: 20px;
}
.accordionlist p span.answer {
	color: #cf111b;
}
.accordion_icon,
.accordion_icon span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.accordion_icon {
	position: relative;
	width: 30px;
	height: auto;
	float: right;
	margin-right: 5px;
}
.accordion_icon span {
	position: absolute;
    left: 6px;
    width: 80%;
	height: 2px;
    background-color: #333;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-ms-border-radius: 4px;
	-moz-border-radius: 4px;
	-o-border-radius: 4px;
}
.accordion_icon span:nth-of-type(1) {
    top: 25px;
	transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
	-moz-transform: rotate(0deg);
	-ms-transform: rotate(0deg);
    -o-transform: rotate(0deg);
}
.accordion_icon span:nth-of-type(2) {
    top: 25px;
	transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
	-moz-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
    -o-transform: rotate(90deg);
}
/*＋、×切り替え*/
.accordion_icon.active span:nth-of-type(1) {
	top: 25px;
    transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
    -o-transform: rotate(45deg);
}
.accordion_icon.active span:nth-of-type(2) {
	top: 25px;
    transform: rotate(135deg);
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
    -o-transform: rotate(135deg);
}


.other-header.hidden .header-menu > li > a {
    color: #333;
}

/*--------------------------------技術紹介--------------------------------*/

.other-page .contents-gallery-box {
     max-width: 100%; 
    margin: 0 auto;
    margin-top: 5rem;
}

.tab {
  /*border-bottom: 3px solid #fb4343;*/
  margin-bottom: 5rem;
}
.tab li {
  color: #333;
  float: left;
  /*margin: 0 10px -1px 0;*/
  width: 50%;
  padding: 1rem 2rem;
  /*border: 0.1rem solid #fb4343;*/
  cursor: pointer;
  list-style: none;
  transition: .1s;
  font-size: 1.8rem;
  line-height: 4rem;	
}
@media (max-width: 767px) {
	.tab li {
  font-size: 1.6rem;
}
}
.tab li:before {
  transition: .1s;
}
.tab li.active {
  color: #fff;
  background: rgba(208,17,27,1);
background: -moz-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -webkit-gradient(left top, right top, color-stop(0%, rgba(208,17,27,1)), color-stop(100%, rgba(252,51,51,1)));
background: -webkit-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -o-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: -ms-linear-gradient(left, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
background: linear-gradient(to right, rgba(208,17,27,1) 0%, rgba(252,51,51,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#d0111b', endColorstr='#fc3333', GradientType=1 );
  cursor: auto;
}
 
.area ul {
  display: none;
}
.area ul.show {
  display: block;
}

.area div.tab-contents {
  display: none;
}
.area div.tab-contents.show {
  display: block;
}



.bag-example:before {
	content: '';/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  width: 2.8rem;/*画像の幅*/
  height: 2.8rem;/*画像の高さ*/
  background-image: url(../images/gallery/bag-black.png);
  background-size: contain;
  vertical-align: middle;
  margin-right: 1rem;	
}
.bag-example.active:before {
	content: '';/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  width: 2.8rem;/*画像の幅*/
  height: 2.8rem;/*画像の高さ*/
  background-image: url(../images/gallery/bag.png);
  background-size: contain;
  vertical-align: middle;
  margin-right: 1rem;	
}
@media (max-width: 767px) {
	.bag-example:before, .bag-example.active:before {
  width: 2.4rem;/*画像の幅*/
  height: 2.4rem;/*画像の高さ*/
}
}
.wallet-example:before {
	content: '';/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  width: 2.8rem;/*画像の幅*/
  height: 2.8rem;/*画像の高さ*/
  background-image: url(../images/gallery/wallet-black.png);
  background-size: contain;
  vertical-align: middle;
  margin-right: 1rem;	
}
.wallet-example.active:before {
	content: '';/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  width: 2.8rem;/*画像の幅*/
  height: 2.8rem;/*画像の高さ*/
  background-image: url(../images/gallery/wallet.png);
  background-size: contain;
  vertical-align: middle;
  margin-right: 1rem;	
}
@media (max-width: 767px) {
	.wallet-example:before, .wallet-example.active:before {
  width: 2.4rem;/*画像の幅*/
  height: 2.4rem;/*画像の高さ*/
}
}
.example-img {
	width: 100%;
}
.tab-contents {
	text-align: left;
}
.tab-text-box {
	margin-top: 3rem;
}
.tab-contents h2 {
	border-bottom: 1px solid #333;
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
}
.tab-contents p {
	font-size: 1.6rem;
	line-height: 1.8;
}
.tab-contents-inner {
	margin-bottom: 5rem;
}

/*--------------------------------お知らせ--------------------------------*/

.other-page .contents-news-box {
     max-width: 100%; 
    margin: 0 auto;
    margin-top: 5rem;
}
.news-contents-inner {
    margin-bottom: 5rem;
}
.news-text-box {
	text-align: left;
}
.news-text-box .latest-tag {
	font-size: 1.2rem;
    padding: 0.5rem 1rem;
    color: #fb4343;
    display: inline-block;
	border: 0.1rem solid #fb4343;
}
.news-text-box h2 {
	margin: 1rem 0;
    font-size: 1.8rem;
}
.news-text-box .news-date {
	margin: 1rem 0;
    font-size: 1.2rem;
}
.news-text-box .news-text {
    font-size: 1.4rem;
	line-height: 1.8;
}

/*--------------------------------お知らせ_個別記事--------------------------------*/
.single-news-title-box {
    display: block;
    position: relative;
    z-index: 1;
    text-align: left;
    margin-bottom: 2rem;
}
.single-news-title-inner-box {
	margin-bottom: 1.5rem;
}
.eye-catch.img-liquid {
	height: 35rem;
	margin-bottom: 30px;
}
@media (max-width: 767px) {
	.eye-catch.img-liquid {
	height: 25rem;
	margin-bottom: 30px;
}
}
.single-news-page h2.single-news-title {
	font-size: 2.4rem;
	font-weight: bold;
    letter-spacing: 0.4rem;
    margin-bottom: 0;
    position: relative;
    z-index: 2;
}
.single-news-date {
	font-size: 1.4rem;
}
.single-news-tag {
	background-color: #817f7c;
    color: #fff;
    padding: 5px 10px;
    display: inline-block;
}
.single-news-page .news-text-box p {
   font-size: 1.6rem;
    line-height: 2.3;
    margin-bottom: 3rem;
}
.single-news-page .news-text-box h3 {
    margin: 0 0 20px 0;
    padding: 5px 0;
    font-size: 20px;
    font-weight: 700;
    border-bottom: 2px solid #333;
	line-height: 1.8;
}










/*------------------モーダルメニュー------------------*/

@media (min-width: 992px) {
	.header-box {
  	display: none;
}	
}
.header-box {
    width: 100%;
    background-color: #FFF;
    position: fixed;
    right: auto !important;
    top: 0;
    left: 0;
    /* height: 30px !important; */
    /* width: 80px; */
    z-index: 21;
}
@media (max-width: 991px) {
.header-box {
    height: 50px;
	/*box-shadow: 0px 0.5px 3px 0px rgba(0,0,0,0.6);*/
}
}
@media (max-width: 767px) {
.header-box {
    height: 50px;
	/*box-shadow: 0px 0.5px 3px 0px rgba(0,0,0,0.6);*/
}
}
/*---------------------------------*/
.overflow {
    overflow: hidden;
    height: 100%;
}
.midnightInner {
    overflow: hidden !important;
}
*, *::after, *::before {
    box-sizing: border-box;
}
.menu {
    position: fixed;
    /*display: table;*/
    top: 0;
    left: 0;
    z-index: 20;
    width: 100%;
    height: 100%;
    -webkit-transition: all .5s;
    transition: all .5s;
    visibility: hidden;
    opacity: 0;
    background-color: rgb(255, 255, 255);
    /* background-image: url(../images/main-navi-logo.png); */
    background-repeat: no-repeat;
    background-position: 10% center;
}
.side-open .menu {
    /* cursor: url(../images/cross.svg),auto; */
    -webkit-transition: all .5s;
    transition: all .5s;
    visibility: visible;
    opacity: 1;
}
.side-open .menu {
    animation-duration: 1s;
    animation-name: slidein;
}
.menu-contents {
    /*display: table-cell;
    vertical-align: middle;*/
	width: 100%;
    height: 100%;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
}
.menu nav#nav-list li {
    /* width: 300px; */
    margin: 0 auto;
    text-align: center;
    opacity: 0;
    list-style-type: none;
    /*margin-left: 80px;*/
}
.side-open .menu nav#nav-list li {
    opacity: 1;
	margin-bottom: 30px;
}
.side-open .menu nav#nav-list li:nth-child(1) {
    -webkit-transition: opacity 1s ease .2s;
    transition: opacity 1s ease .2s;
}
.delay {
    position: relative;
    font-size: 18px;
    text-align: center;
    margin-top: 0px;
    margin-right: auto;
    margin-bottom: 0px;
    margin-left: auto;
    display: inline-block;
}
.delay:before, .delay:after {
    content: "";
    display: block;
    position: absolute;
    top: 40%;
    left: 0;
    width: 100%;
    height: 25%;
}
.delay:before {
    z-index: 1;
}
.delay:after {
    z-index: 2;
    width: 0%;
    background-color: #051630;
}
.delay a {
    z-index: 3;
    position: relative;
    display: block;
    color: #333;
}
.delay a:hover {
    text-decoration: none;
}
.menu nav#nav-list li a span {
    display: block;
    height: 60px;
    line-height: 60px;
    font-size: 40px;
    color: #f69e41;
    -webkit-transition: all .4s;
    transition: all .4s;
    font-family: yesteryear;
    font-style: normal;
    font-weight: 400;
    text-decoration: none;
    letter-spacing: 0.1em;
}
.delay-anime:after {
    transition: width 0.15s linear;
}
.menu-btn {
    position: fixed;
    top: 20px;
    right: 20px;
    /*width: 50px; */
    height: 50px;
    line-height: 50px;
    font-size: 12px;
    text-align: center;
    cursor: pointer;
    z-index: 21;
}
.menu-btn-text {
    position: fixed;
    top: 55px !important;
    right: 15px !important;
    width: 50px;
    height: 20px;
    line-height: 50px;
    font-size: 10px;
    text-align: center;
    cursor: pointer;
    z-index: 1;
}
.c-hamburger {
    display: block;
    position: relative;
    overflow: hidden;
    margin: 0;
    padding: 0;
    width: 50px;
    height: 50px;
    font-size: 0;
    text-indent: -9999px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    box-shadow: none;
    border-radius: 0;
    border: none;
    cursor: pointer;
    -webkit-transition: background 0.3s;
    transition: background 0.3s;
}
.c-hamburger--htx {
    background-color: #f4a363;
    height: 50px !important;
}
.c-hamburger--htx.is-active {
    background-color: #f4a363;
}
/*.section01 .c-hamburger--htx {
    background-color: #f59339;
}
.section01 .c-hamburger--htx.is-active {
    background-color: #f59339;
}
.section02 .c-hamburger--htx {
    background-color: #FFF;
}
.section02 .c-hamburger--htx.is-active {
    background-color: #f59339;
}*/
.button-box {
    width: 50px;
    position: fixed;
    top: 15px !important;
    right: 15px !important;
    overflow: hidden;
    height: 50px;
}
@media (max-width: 991px) {
	.button-box {
    position: fixed;
    top: 0 !important;
    right: 0 !important;
    overflow: hidden;
    height: 50px;
}
	.menu-btn-text {
    position: fixed;
    top: 40px !important;
    right: 5px !important;
    width: 50px;
    height: 20px;
    line-height: 50px;
    font-size: 10px;
    text-align: center;
    cursor: pointer;
    z-index: 1;
}
}
@media (max-width: 767px) {
	.button-box {
    position: fixed;
    top: 0 !important;
    right: 0 !important;
    overflow: hidden;
    height: 50px;
}
	.menu-btn-text {
    position: fixed;
    top: 40px !important;
    right: 0 !important;
    width: 50px;
    height: 20px;
    line-height: 50px;
    font-size: 10px;
    text-align: center;
    cursor: pointer;
    z-index: 1;
}
}
.c-hamburger span {
    display: block;
    position: absolute;
    left: 15px;
    right: 15px;
    height: 2px;
    background: #fff;
}
.c-hamburger span::before, .c-hamburger span::after {
    height: 2px;
}
.c-hamburger span::before, .c-hamburger span::after {
    background-color: #fff;
}
/*.button-box .section01 .c-hamburger--htx span {
    background-color: #fff;
}
.button-box .section01 .c-hamburger span::after, .button-box .section01 .c-hamburger span::before {
    position: absolute;
    display: block;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #FFF;
    content: "";
}
.button-box .section01 .c-hamburger.is-active span::after, .button-box .section01 .c-hamburger.is-active span::before {
    background-color: #FFF;
}
.button-box .section02 .c-hamburger--htx span {
    background-color: #f59339;
}
.button-box .section02 .c-hamburger span::after, .button-box .section02 .c-hamburger span::before {
    position: absolute;
    display: block;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #f59339;
    content: "";
}
.button-box .section02 .c-hamburger.is-active span::after, .button-box .section02 .c-hamburger.is-active span::before {
    background-color: #FFF;
}*/
.menu-btn-text span:after {
    content: attr(data-txt-open);
}
/*.menu-btn-text .section01 span {
    color: #f69e41;
}
.menu-btn-text .section02 span {
    color: #fff;
}*/
.side-open .menu-btn-text span:after {
    content: attr(data-txt-close);
    font-size: 10px;
    color: #0CF;
}
.side-open .menu-btn-text span:after {
    content: attr(data-txt-close);
    font-size: 10px;
    color: #f69e41;
}
/*.button-box .section01 .c-hamburger--htx.is-active span {
     background: 0 0; 
}
.button-box .section02 .c-hamburger--htx.is-active span {
    background: 0 0;
}*/

.header-box .main-logo {
    position: fixed;
    right: auto !important;
    top: 1.25rem !important;
    left: 1.5rem;
    height: 2.5rem !important;
	line-height: 1;
    width: auto;
    z-index: 21;
    overflow: hidden;
}
.header-box .main-logo a {
    text-decoration: none;
    display: block;
}
.header-box .main-logo img {
    width: auto;
	height: 2.5rem;
}

.slide-ul li {
	width: 300px;
    height: 200px;
    text-align: center;
}
.sub-logo {
	position: fixed;
    top: 30px !important;
    left: calc(50% - 150px);
    height: 35px !important;
    width: 300px;
    z-index: 21;
    margin: 0 auto;
}
.nav-list {
    padding: 100px 0 50px 0;
}
.nav-list ul {
    margin-bottom: 50px;
}
.slide-phone-menu, .slide-fb, .slide-hk {
    padding: 5px 0;
    text-align: center;
}
.slide-phone-menu .logo-text {
	height: 20px;
    width: auto;
    display: block;
    margin: 0 auto;
    margin-bottom: 10px;
}
.slide-phone-menu .logo-big {
	height: 60px;
    width: auto;
    display: block;
    margin: 0 auto;
    margin-bottom: 10px;
}
@media (max-width: 991px) {
	.slide-phone-menu .logo-big {
	height: 20px;
    width: auto;
    display: block;
    margin: 0 auto;
    margin-bottom: 10px;
}
}
@media (max-width: 767px) {
	.slide-phone-menu .logo-big {
	height: 30px;
    width: auto;
    display: block;
    margin: 0 auto;
    margin-bottom: 10px;
}
}
.sp-mynavi {
	width: 70%;
    margin: 0 auto;
	text-align: center;
	margin-bottom: 50px;
}
.sp-mynavi img {
	width: 100%;
    height: auto;
}
@media (max-width: 991px) {
	.sub-logo {
	/*position: fixed;
    top: 12px !important;
	right: 65px;	
    left: auto;
    height: 25px !important;
    width: 133px;
    z-index: 21;
    margin: 0 auto;*/
		
	position: relative;
    top: 16px !important;
    right: auto;
    left: auto;
    height: 18px !important;
    line-height: 1;
    width: 100%;
    display: inline-block;
    z-index: 21;
    /* margin: 0 auto; */
    text-align: center;	
	}
	.sub-logo h1 {
	color: #555;
    font-size: 18px;
	line-height: 1;
    margin: 0;	
	}
	.slide-phone-menu, .slide-fb, .slide-hk {
    display: block;
	}
}
@media (min-width: 768px) and (max-width: 991px) {
.sp-mynavi img {
    width: 60%;
    height: auto;
}
}
@media (min-width: 768px) {
	.phone-logo {
	display: none;
}
}
@media (max-width: 767px) {
	.sub-logo {
	display: none;
}
	.tab-logo {
		display: none;
	}
	.header-box .main-logo {
    position: fixed;
    right: auto !important;
    top: 12.5px !important;
    left: 15px;
    height: 25px !important;
    width: auto;
    z-index: 21;
    line-height: 1;
	overflow: hidden;	
}
	.header-box .main-logo a {
    text-decoration: none;
    overflow: hidden;
    display: block;
}
	.header-box .main-logo.phone-logo img {
    width: auto;
    height: 25px;
}
	.text-section h2 {
    font-size: 20px;
    line-height: 2;
    margin: 0;
    margin-bottom: 30px;
    /*font-family: YuMincho, '游明朝', serif;*/
    color: #5a4730;
    letter-spacing: 1rem;
    text-align: center;
}
	.side-open .header-box .main-logo {
    display: none;
}
}

.c-hamburger--htx span::before, .c-hamburger--htx span::after {
	-webkit-transition-duration: 0.3s, 0.3s;
    transition-duration: 0.3s, 0.3s;
	-webkit-transition-delay: 0.3s, 0s;
    transition-delay: 0.3s, 0s;
}
.c-hamburger--htx.is-active span::before, .c-hamburger--htx.is-active span::after {
	-webkit-transition-delay: 0.3s, 0s;
    transition-delay: 0s, 0.3s;
}
/*↓↓↓↓↓メインナビゲーションのリストが現れた時のアニメーション↓↓↓↓↓*/
.side-open .menu nav#nav-list li:nth-child(1) {
	-webkit-transition: opacity 1s ease .2s;
	transition: opacity 1s ease .2s;
}

.side-open .menu nav#nav-list li:nth-child(2) {
	-webkit-transition: opacity 1s ease .25s;
	transition: opacity 1s ease .25s;
}

.side-open .menu nav#nav-list li:nth-child(3) {
	-webkit-transition: opacity 1s ease .3s;
	transition: opacity 1s ease .3s;
}

.side-open .menu nav#nav-list li:nth-child(4) {
	-webkit-transition: opacity 1s ease .35s;
	transition: opacity 1s ease .35s;
}

.side-open .menu nav#nav-list li:nth-child(5) {
	-webkit-transition: opacity 1s ease .4s;
	transition: opacity 1s ease .4s;
}

.side-open .menu nav#nav-list li:nth-child(6) {
	-webkit-transition: opacity 1s ease .45s;
	transition: opacity 1s ease .45s;
}

.side-open .menu nav#nav-list li:nth-child(7) {
	-webkit-transition: opacity 1s ease .5s;
	transition: opacity 1s ease .5s;
}

.side-open .menu nav#nav-list li:nth-child(8) {
	-webkit-transition: opacity 1s ease .55s;
	transition: opacity 1s ease .55s;
}
.sp-mynavi {
	opacity: 0;
}
.side-open .sp-mynavi {
	opacity: 1;
	-webkit-transition: opacity 1s ease 0.5s;
	transition: opacity 1s ease 0.5s;
}
.slide-phone-menu {
	opacity: 0;
}
.side-open .slide-phone-menu {
	opacity: 1;
	-webkit-transition: opacity 1s ease 0.55s;
	transition: opacity 1s ease 0.55s;
}

/*------------------/モーダルメニュー------------------*/

@media (min-width: 992px) {
.header-box {
	display: none;
}
}

@media (max-width: 991px) {
.sub-logo img {
	height: 26px;
}
.footer-box-wrap-head {
	display: none;
}
}

@media (min-width: 768px) {
	.phone-footer-col {
		display: none;
	}
}













.shutter {
    position: fixed;
    top: 0;
    left: 0;
    width: 200vw;
    height: 100vh;
    background-color: #cf111a;
    z-index: 999999;
    pointer-events: none;
    transition: transform 1.8s ease-in-out;
}

.shutter-a {
    transform: translateX(100vw);
}
.shutter-a.moved {
    transform: translateX(-200vw);
}

.shutter-b {
    transform: translateX(-200vw);
}
.shutter-b.moved {
    transform: translateX(100vw);
}



.block-revealer__element {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  pointer-events: none;
  opacity: 0;
}

/*_______________________*/
.motion-txt {
  display: inline-block;
  position: relative;
  overflow: hidden;
  padding:10px;
}


.motion-txt:before {
  content: '';
  position: absolute;
  z-index: 2;
  opacity: 1;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  background-color: #797875;
  transform: translate3d(-101%, 0, 0);
}
.js-scroll.show .motion-txt:before {
  transition-property: transform, opacity;
  transition-duration: 0.5s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(0, 0, 0);
}
.js-scroll.done .motion-txt:before {
  transition-property: transform;
  transition-duration: 0.5s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(103%, 0, 0);
}


.motion-txt:after {
  content: '';
  position: absolute;
  z-index: 1;	
  opacity: 1;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  background-color: #d1111c;
  transform: translate3d(-101%, 0, 0);
}
.js-scroll.show .motion-txt:after {
  transition-property: transform, opacity;
  transition-duration: 0.5s;
  transition-delay: .1s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(0, 0, 0);
}
.js-scroll.done .motion-txt:after {
  transition-property: transform;
  transition-duration: 0.5s;
  transition-delay: .1s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(103%, 0, 0);
}
.motion-txt .motion-inner {
  display: inline-block;
  opacity: 0;
}
.js-scroll.done .motion-txt .motion-inner {
  opacity: 1;
}

.motion-img {
    display: block;
    position: relative;
    overflow: hidden;
    padding: 0;
    height: 100%;
}


.motion-img:before {
  content: '';
  position: absolute;
  opacity: 1;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  background-color: #fff;
  /*transform: translate3d(-101%, 0, 0);*/
}
.js-scroll.show .motion-img:before {
  transition-property: transform, opacity;
  transition-duration: 0.5s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(0, 0, 0);
}
.js-scroll.done .motion-img:before {
  transition-property: transform;
  transition-duration: 0.5s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(103%, 0, 0);
}



.motion-img:after {
  content: '';
  position: absolute;
  opacity: 1;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  background-color: #ADADAD;
  transform: translate3d(-101%, 0, 0);
}
.js-scroll.show .motion-img:after {
  transition-property: transform, opacity;
  transition-duration: 1.0s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(0, 0, 0);
}
.js-scroll.done .motion-img:after {
  transition-property: transform;
  transition-duration: 1.0s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  transform: translate3d(103%, 0, 0);
}
/*.motion-img .motion-inner {
  display: inline-block;
  opacity: 0;
}
.js-scroll.done .motion-img .motion-inner {
  opacity: 1;
}*/

/*#top-service .service-01-bg.show {
    background-image: url(../images/top/service_01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    right: 0;
	opacity: 0;
}
#top-service .service-01-bg.done {
	opacity: 1;
}*/
#top-dis {
    padding: 50px 0;
    padding-bottom: 0;
}
.other-page #top-dis {
	margin-top: 100px;
    background-color: #fafafa;
}
@media (max-width: 991px) {
	.other-page #top-dis {
	margin-top: 0;
	}
}
.service-page #top-dis, .recruit-page #top-dis, .company-page #top-dis, .access-page #top-dis, .news-page #top-dis {
	margin-top: 50px;
    background-color: #fff;
}
.news-page #top-dis {
    margin-bottom: 100px;
	padding-top: 50px;
}
@media (max-width: 991px) and (min-width: 768px) {
	.news-page #top-dis {
	padding-top: 100px;
}
}
.single-page-wrap {
	margin-top: 80px;
    overflow: hidden;
}
@media (max-width: 991px) and (min-width: 768px) {
	.single-page-wrap {
	margin-top: 0;
    overflow: hidden;
}
}
@media (max-width: 767px) {
	.single-page-wrap {
	margin-top: 0;
    overflow: hidden;
}
}
.single-page #top-dis, .privacy-page #top-dis {
    margin-top: 50px;
	padding-bottom: 100px;
    background-color: #fff;
}
.single-page #top-dis {
    margin-top: 50px;
    padding: 0;
    padding-bottom: 100px;
    background-color: #fff;
}
@media (max-width: 991px) {
	.service-page #top-dis, .recruit-page #top-dis, .company-page #top-dis, .privacy-page #top-dis, .access-page #top-dis, .news-page #top-dis {
	margin-top: 0;
    background-color: #fff;
}
	.single-page #top-dis {
    margin-top: 50px;
    background-color: #fff;
}
	.service-page #top-dis {
		padding-bottom: 0;
	}
	.other-page.service-page .topics-col {
    margin-bottom: 0;
    padding: 0;
	}
}
@media (max-width: 991px) and (min-width: 768px) {
	.single-page #top-dis {
	margin-top: 0;
    padding-top: 100px;
}
}
.service-dis-bg {
	display: table;
    background-color: transparent;
    width: 100%;
    height: 500px;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}
.service-dis-bg-inner {
    padding-top: 15rem;
    padding-bottom: 15rem;
    background-color: transparent;
}
.header-obi {
	padding: 5px;
}
.header-obi h1 {
	font-size: 10px;
}
.main-logo img {
    height: 3.7rem;
    width: auto;
}
.change-content-button a {
    position: relative;
    display: inline;
    color: #fff;
    /* font-weight: bold; */
    font-size: 1.3rem;
    letter-spacing: 0.2rem;
    transition: .3s;
    padding: 1rem 1.5rem;
     background-color: transparent; 
}
.header-change-menu .main-logo img {
	    height: 2.5rem;
    width: auto;
}
.ser-div img {
    width: 100%;
    height: auto;
    /*border-radius: 50px;*/
	/*border: 4px dotted #f4a363;*/
}
.text-bottom p {
	font-size: 1.8rem;
}
.flex-div {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.com-flex {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: left;
    position: relative;
    padding: 0 50px;
}
@media (max-width: 991px) {
	.com-flex-right {
    padding-right: 0;
}
	.com-flex-left {
    padding-left: 0;
}
}
.contents-title-box p {
    font-size: 1.6rem;
    letter-spacing: 0.2rem;
    color: #555;
    margin-top: 1rem;
}
figure.img-liquid {
	width: 100%;
	height: 250px;
	/*border-radius: 30px;*/
	margin-bottom: 15px;
}
@media (max-width: 1199px) {
	figure.img-liquid {
	height: 200px;
}
}
.more-buttom {
	text-align: right;
    margin-top: 30px;
}
.more-buttom p {
	font-size: 14px;
    border-radius: 30px;
    border: 2px solid #c2c2c2;
    display: inline-block;
    margin: 0;
}
.more-buttom a::after {
	content: '●';
    margin-left: 10px;
    color: #f4a364;
}
.more-buttom a {
	color: #8a8a8a;
	text-decoration: none;
	display: block;
    padding: 10px 20px;
}
.footer-right-logo {
	padding-top: 30px;
    text-align: right;
}
.footer-right-logo img {
    width: auto;
    height: 50px;
    display: inline-block;
}
.news-content-wrap .content-button p {
	margin: 0;
}
.news-content-wrap .content-button a {
    width: auto;
    display: inline-block;
    cursor: pointer;
    margin-bottom: 0;
    box-sizing: border-box;
    text-align: center;
    text-decoration: inherit;
    border: none;
    position: relative;
    color: #FFF;
    padding: 2rem 4rem;
    background-color: #f4a364;
    border-radius: 30px;
	font-size: 1.4rem;
}
.news-arc-margin {
	margin-top: 50px;
}
@media (max-width: 991px) {
.news-arc-margin {
    margin-top: 50px;
}
}


/*CEOメッセージ*/
#ceo-message.top-service-wrap {
	padding: 10rem 0;
	background-color: #fff;	
}
@media (max-width: 767px) {
	#ceo-message.top-service-wrap {
	padding: 50px 0;
	background-color: #fff;	
}
	#ceo-message .container {
	/*margin: 5rem 0 3rem 0;*/
}
	#ceo-message .service-num-wrap .container {
	margin-top: 2rem;
}
}
.contents-title-box {
	display: inline-block;
    position: relative;
    z-index: 1;
}
.contact-wrap .contents-title-box {
	margin-bottom: 20px;
}
.other-page .contents-title-box {
    display: block;
    position: relative;
    z-index: 1;
}
.other-page.service-page .contents-title-box {
    margin-bottom: 50px;
}
.other-page.service-page .contact-wrap .contents-title-box {
    margin-bottom: 10px;
}
#ceo-message h2.contents-title span {
	font-size: 4rem;
    font-family: doppio-one, sans-serif;
}
#ceo-message .contents-dis-box {
	padding: 10rem 20rem;
}
@media (max-width: 991px) {
	#ceo-message .contents-dis-box {
	padding: 5rem 10rem;
}
}
@media (max-width: 767px) {
	#ceo-message .contents-dis-box {
	padding: 3rem 0;
}
}
#ceo-message p.contents-dis {
	font-size: 1.4rem;
    letter-spacing: 0.2rem;
    text-align: left;
}
#ceo-message .service-num-wrap {
	/*padding-bottom: 80px;*/
}
@media (max-width: 767px) {
	#ceo-message .service-num-wrap {
	padding-bottom: 0;
}
}
#ceo-message .service-num {
	padding-top: 0;
    padding-bottom: 0;
}
@media (max-width: 767px) {
#ceo-message .service-num {
	padding-top: 0;
    padding-bottom: 0;
}	
}
#ceo-message .service-01 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#ceo-message .service-01-bg {
	background-image: url(../images/top/service_01.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    right: 0;
}
@media (max-width: 767px) {
	#ceo-message .service-01-bg {
    width: 100%;
    height: 250px;
    position: relative;
	top: 0;
    left: 0;
    margin-bottom: 30px;
}
}
#ceo-message .service-02 {
	position: relative;
	display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#ceo-message .service-02-bg {
	background-image: url(../images/top/service_02.jpg);
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    width: 50%;
    height: calc(100% + 4rem);
    position: absolute;
    left: 0;
}
@media (max-width: 767px) {
	#ceo-message .service-02-bg {
    width: 100%;
    height: 250px;
    position: relative;
	top: 0;
    left: 0;
    margin-bottom: 30px;
}
}
#ceo-message .img-liquid {
	height: 500px;
	border-radius: 50px;
}
#ceo-message .text-top {
	position: relative;
	/*margin-bottom: 2rem;*/
}
#ceo-message .text-top h3 {
	position: relative;
    font-size: 2.6rem;
    font-weight: normal;
    letter-spacing: 0.2rem;
    color: #777;
    line-height: 1.6;
}
#ceo-message .text-top p {
    font-size: 1.6rem;
    letter-spacing: 0.2rem;
    color: #555;
    margin-top: 1rem;
}
#ceo-message .text-bottom {
	/*margin-bottom: 4rem;*/
}
#ceo-message .text-bottom p {
    font-size: 1.6rem;
    line-height: 1.8;
    letter-spacing: 0.15rem;
    color: #555;
	margin-bottom: 0;
}
.table-archive-col {
	margin-bottom: 100px;
}

.cbp_tmtimeline {
    position: relative;
    margin: 30px 0px 0px;
    padding: 0px;
    list-style: none;
}
.cbp_tmtimeline::before {
    content: "";
    position: absolute;
    top: 0px;
    bottom: 40px;
    width: 10px;
    left: 35%;
    margin-left: -10px;
    background: rgb(177, 229, 203);
}
.cbp_tmtimeline-ex::before {
    bottom: 0;
}
.cbp_tmtimeline > li {
    position: relative;
}
.cbp_tmtimeline > li .cbp_tmtime {
    display: block;
    width: 25%;
    padding-right: 0;
    position: absolute;
}
.cbp_tmtimeline > li:nth-child(2n+1) .cbp_tmtime span:last-child {
    color: rgb(144, 209, 129);
}
.cbp_tmtimeline > li .cbp_tmtime span:last-child {
    font-size: 2.9em;
    color: rgb(119, 191, 155);
}
.cbp_tmtimeline > li .cbp_tmtime span {
    display: block;
    text-align: right;
}
/*.cbp_tmtimeline > li .cbp_tmtime span:first-child {
    font-size: 0.9em;
    color: rgb(189, 208, 219);
}*/
.cbp_tmtimeline > li .cbp_tmicon {
    width: 40px;
    height: 40px;
    font-family: ecoico;
    speak: none;
    font-style: normal;
    font-weight: normal;
    text-transform: none;
    font-size: 1.4em;
    line-height: 40px;
    -webkit-font-smoothing: antialiased;
    position: absolute;
    color: rgb(255, 255, 255);
    box-shadow: rgb(177, 229, 203) 0px 0px 0px 8px;
    text-align: center;
    left: 35%;
    top: 0px;
    font-variant: normal;
    background: rgb(108, 183, 145);
    border-radius: 50%;
    margin: 0px 0px 0px -25px;
}
.cbp_tmicon-phone::before {
    font-family: "Font Awesome 5 Free";
    content: "\f0f4";
	font-weight:900;
}
.cbp_tmicon-home::before {
    font-family: "Font Awesome 5 Free";
    content: "\f015";
	font-weight:900;
}
.cbp_tmicon-anzu::before {
    font-family: "Font Awesome 5 Free";
    content: "\f52b";
	font-weight:900;
}
.cbp_tmtimeline > li .cbp_tmlabel {
    color: rgb(255, 255, 255);
    font-size: 1.2em;
    font-weight: 300;
    line-height: 1.4;
    position: relative;
    margin: 0px 0px 15px 45%;
    background: rgb(118, 202, 159);
    padding: 2em;
    border-radius: 0;
	top: -15px;
	width: 40%;
}
.cbp_tmtimeline > li:nth-child(2n+1) .cbp_tmlabel {
    background: rgb(133, 202, 118);
}
.cbp_tmtimeline > li .cbp_tmlabel h2 {
    margin-top: 0px;
    padding: 0;
    /*border-bottom: 1px solid rgba(255, 255, 255, 0.4);*/
	text-align: left;
    font-weight: bold;
	color: #fff;
}
.cbp_tmtimeline > li:nth-child(2n+1) .cbp_tmlabel::after {
    border-right-color: rgb(133, 202, 118);
}
.cbp_tmtimeline > li .cbp_tmlabel::after {
    right: 100%;
    content: " ";
    height: 0px;
    width: 0px;
    position: absolute;
    pointer-events: none;
    top: 25px;
    border-style: solid;
    border-color: transparent rgb(118, 202, 159) transparent transparent;
    border-image: initial;
    border-width: 10px;
}
.cbp_tmicon-screen:before {
    font-family: "Font Awesome 5 Free";
    content: "\f004";
	font-weight:900;
}
.cbp_tmicon-earth:before {
    font-family: "Font Awesome 5 Free";
    content: "\f004";
	font-weight:900;
}
.cbp_tmicon-eat:before {
    font-family: "Font Awesome 5 Free";
    content: "\f2e7";
	font-weight:900;
}
.cbp_tmicon-bath:before {
    font-family: "Font Awesome 5 Free";
    content: "\f2cd";
	font-weight:900;
}
.cbp_tmicon-bed:before {
    font-family: "Font Awesome 5 Free";
    content: "\f236";
	font-weight:900;
}
.cbp_tmicon-wakeup:before {
    font-family: "Font Awesome 5 Free";
    content: "\f1ae";
	font-weight:900;
}
.cbp_tmicon-work:before {
    font-family: "Font Awesome 5 Free";
    content: "\f0b1";
	font-weight:900;
}
.cbp_tmtimeline p {
	color: #fff;
}
.privacy-dis {
	    font-size: 1.6rem;
    line-height: 1.8;
    letter-spacing: 0.2rem;
    text-align: left;
    color: #555;
	margin-bottom: 100px;
}
.topics-col p.privacy-point {
	position: relative;
	padding-left: 1.5em;
}
.topics-col p.privacy-point::before {
	font-family: "Font Awesome 5 Free";
    content: "\f111";
	font-weight:900;
    position: absolute;
    font-size: 16px;
    left: 0;
    top: 0;
    color: #f4a364;
}
.map-sec .googlemap iframe {
	width: 100%;
}
.table-style-access {
    margin: 0 auto;
    width: 100%;
    border: none;
    border-collapse: separate;
    border-spacing: 0 1rem;
}
.table-style-access th {
    color: #333;
    font-size: 1.6rem;
    font-weight: normal;
}
.table-style-access td.data {
    padding-left: 4rem;
    font-size: 1.4rem;
    line-height: 2.5rem;
    text-align: left;
}
.padding-lr-15 {
	padding-right: 15px;
    padding-left: 15px;
}
.contact-table table {
    margin-top: 10rem;
    margin-bottom: 5rem;
	width: 100%;
}
.contact-table table th {
    padding-left: 0;
    border: none;
    font-size: 1.6rem;
    line-height: 1;
    width: 250px;
    vertical-align: middle;
    font-weight: normal;
    text-align: left;
	color: #555;
}
.contact-table table td {
    /*width: 60%;*/
	font-size: 16px;
    padding: 0;
    vertical-align: middle;
	text-align: left;
}
.contact-table table tr {
    margin-bottom: 20px;
    display: block;
    vertical-align: middle;
}
.contact-table table th i {
    font-size: 1rem;
    color: #ffffff;
    background-color: #fc7879;
    padding: 4px 5px;
    margin-left: 10px;
    font-style: normal;
}
.contact-table td span {
    position: relative;
	margin-left: 0;
}
.contact-table td input {
    outline: none;
    display: block;
    width: 100%;
    border: 0;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-sizing: border-box;
    padding: 10px;
    color: rgba(0, 0, 0, 0.6);
    font-family: inherit;
    font-size: inherit;
    font-weight: 500;
    line-height: inherit;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
    font-size: 16px;
}
.contact-table td input[type=text], .contact-table td input[type=tel], .contact-table td input[type=email] {
	-webkit-border-radius: 0;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
	-webkit-appearance: none;
}
.contact-table td textarea {
    width: 100%;
    border: 1px solid #ccc;
    display: block;
	line-height: 1.8;
    -webkit-border-radius: 0;
    -webkit-appearance: none;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}
.contact-table td input[type=checkbox] {
    display: inline-block;
    width: auto;
    margin-right: 1rem;
}
td .wpcf7-acceptance label {
	display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
}
td .wpcf7-acceptance label span {
	font-size: 1.4rem;
}
.contact-table td span.check-dis {
    font-size: 1.6rem;
	color: #555;
}
.contact-button p {
	/*display: block;
    padding: 10px 30px;
    background-color: #f4a365;
    color: #fff;
    font-size: 18px;
    letter-spacing: 0.2rem;
    border-radius: 30px;*/
}
.wpcf7-form p input.wpcf7-submit {
    display: block;
    padding: 10px 30px;
    background-color: #f4a365;
    color: #fff;
    font-size: 18px;
    letter-spacing: 0.2rem;
    border-radius: 30px;
	border: none;
    width: 100%;
    -webkit-transition: 0.2s ease-in-out;
    -moz-transition: 0.2s ease-in-out;
    -o-transition: 0.2s ease-in-out;
    transition: 0.2s ease-in-out;
	cursor: pointer;
}
.wpcf7-form p input.wpcf7-submit:hover {
	background-color: #76ca9f;
	color: #fff;
}
div.wpcf7-validation-errors, div.wpcf7-acceptance-missing {
    border: none !important;
	color: #f00;
    font-size: 16px;
    font-weight: normal;
    display: block;
    margin: 0 !important;
}
span.wpcf7-not-valid-tip {
    color: #f00;
    font-weight: normal;
    display: block;
	font-size: 14px !important;
    margin-top: 5px;
}
div.wpcf7-mail-sent-ok {
    border: none !important;
	font-size: 16px;
    margin: 0;
    color: #37b005;
}
.news-page .news-content {
    background: #fff;
    display: block;
    padding: 0;
    position: relative;
    color: #111;
    min-height: 150px;
    -webkit-align-items: center;
    align-items: center;
	margin-bottom: 50px;
}
.news-page .news-cat-tag {
    position: absolute;
    left: 0;
    top: 0;
    line-height: 100%;
}
.news-page .news-cat-tag span {
    display: inline-block;
    font-size: 75%;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: 0px;
    padding: 0.75rem 1rem;
    -webkit-border-radius: 0;
    border-bottom-right-radius: 15px;
    color: #fff;
    background: rgb(118, 202, 159);
}
.news-page .news-content-text {
    text-align: left;
}
.news-page .news-content-text time {
    font-size: 1.2rem;
    font-weight: bold;
}
.news-page .news-content-text p {
    font-size: 1.4rem;
    margin-top: 1rem;
    letter-spacing: 0.1rem;
    line-height: 1.8;
    overflow: hidden;
    height: 5rem;
    margin-bottom: 0;
    font-weight: bold;
}
.single-page figure.img-liquid {
    width: 100%;
    height: 500px;
    /*border-top-left-radius: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 30px;
    border-bottom-left-radius: 30px;*/
    margin-bottom: 30px;
	/*border: 5px solid #f4a363;*/
}
@media (max-width: 1199px) {
	.single-page figure.img-liquid {
    width: 100%;
    height: 400px;
}
}
.single-page .news-content h1 {
    /*margin-bottom: 10px;
    padding-bottom: 1.5rem;*/
    color: #555;
    letter-spacing: 0.2rem;
    font-weight: bold;
    /*border-bottom: 2px solid #fff;*/
	font-size: 26px;
}
@media (max-width: 1199px) {
	.single-page .news-content h1 {
	font-size: 24px;
}
}
@media (max-width: 767px) {
	.single-page .news-content h1 {
	font-size: 20px;
}
}
.single-title-box {
	/*border-top-left-radius: 30px;
    border-top-right-radius: 30px;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;*/
	padding: 0;
	margin-bottom: 30px;
    /*margin-bottom: 0;
    border: 2px solid #f4a364;
    background-color: #f4a364;*/
}
.single-time {
	margin-bottom: 20px;
}
.single-time time {
	color: #555;
    font-size: 1.2rem;
}
.single-page .news-content-text p {
	font-size: 1.6rem;
    letter-spacing: 0.2rem;
	line-height: 1.8;
	margin-bottom: 30px;
	text-align: left;
}
@media (max-width: 767px) {
	.single-page .news-content-text p {
	margin-bottom: 30px;
}
}
@media (max-width: 991px) {
	.access-page .table-style td.data {
    width: 50%;
	}
	.access-page .table-style th {
    width: 20%;
	}
	#ceo-message .text-top h3 {
    position: relative;
    font-size: 2rem;
    font-weight: normal;
    letter-spacing: 0.2rem;
    color: #777;
    line-height: 1.6;
    text-align: left;
	}
	#ceo-message .text-top {
    position: relative;
    margin-bottom: 2rem;
	}
	#ceo-message .text-bottom p {
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0.2rem;
    color: #555;
    text-align: left;
	}
	.service-num-wrap .ser-div {
		padding: 0;
	}
	.service-num-wrap .flex-div {
		-webkit-align-items: center;
    	align-items: center;
	}
	.ser-div img {
    width: 100%;
    height: auto;
    /*border-radius: 20px;*/
	}
	.news-content figure.img-liquid {
    width: 100%;
    height: 250px;
    /*border-radius: 20px;*/
    margin-bottom: 15px;
	}
	.single-page .news-content figure.img-liquid {
    width: 100%;
    height: 400px;
   /* border-top-left-radius: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 30px;
    border-bottom-left-radius: 30px;*/
    margin-bottom: 30px;
    /*border: 5px solid #f4a363;*/
	}
	.footer-box-wrap .footer-address {
		display: none;
	}
	.footer-box-pc {
		display: none;
	}
	.footer-menu {
		text-align: center;
		border-top: 1px solid #e2e2e2;
	}
	.footer-menu li {
    margin: 0 auto;
    display: inline-block;
    width: 50%;
	float: left;
	}
	.footer-menu li:nth-child(odd) {
    border-bottom: 1px solid #e2e2e2;
	border-right: 1px solid #e2e2e2;
	}
	.footer-menu li:nth-child(even) {
    border-bottom: 1px solid #e2e2e2;
	}
	.footer-box-wrap {
    padding-top: 0;
    padding-bottom: 0;
	}
	.phone-address {
		padding: 50px 0;
	}
	.phone-address p {
		font-size: 14px;
		color: #555;
	}
	.phone-menu {
		padding: 0;
	}
	.footer-menu li a {
    color: #555;
    padding: 20px 0;
    display: block;
	transition: all 0.5s ease;	
	}
	.footer-menu li a:hover {
    background-color: #B4B4B4;
	color: #fafafa;
	}
	.footer-center-logo {
    text-align: center;
    margin-bottom: 10px;
	}
	.footer-center-logo img {
    width: auto;
    height: 50px;
    display: inline-block;
	}
	.service-dis-bg {
    height: 500px;
	}
	.service-dis-bg-01 {
    background-attachment: scroll;
	}
	#ceo-message .text-bottom {
    margin-bottom: 0;
	}
	#ceo-message .img-liquid {
    height: 300px;
    border-radius: 30px;
	}
	.concept-page .contents-wrap .service-num {
    padding-top: 0;
    padding-bottom: 0;
	}
	.other-page .contents-title-box {
    margin-bottom: 30px;
	}
	.table-style th {
    padding-left: 1.5rem;
	padding-bottom: 1rem;
	padding-top: 1.5rem;	
	}
}
@media (min-width: 992px) {
	.footer-box-phone {
		display: none;
	}
}
@media (min-width: 768px) {
	.phone-dis {
		display: none;
	}
}
@media (max-width: 767px) {
	.cbp_tmtimeline > li .cbp_tmlabel::after {
    top: 10px;
	}
	.recruit-page #top-dis .container {
    padding-right: 15px;
    padding-left: 15px;
	}
	.cbp_tmtimeline > li .cbp_tmlabel h2 {
    margin-top: 0px;
	margin-bottom: 0;	
    padding: 0;
    /* border-bottom: 1px solid rgba(255, 255, 255, 0.4); */
    text-align: left;
    font-weight: bold;
    color: #fff;
    font-size: 1.6rem;
	}
	.cbp_tmtimeline > li .cbp_tmtime span:last-child {
    font-size: 1.8em;
    color: rgb(119, 191, 155);
	}
	.cbp_tmtimeline > li .cbp_tmtime {
    display: block;
    width: auto;
    padding-right: 0;
    position: absolute;
    }
	.cbp_tmtimeline {
    position: relative;
    margin: 15px 0px 0px;
    padding: 0px;
    list-style: none;
	}
	.cbp_tmtimeline > li .cbp_tmlabel {
    color: rgb(255, 255, 255);
    font-size: 1.2em;
    font-weight: 300;
    line-height: 1.4;
    position: relative;
    margin: 0px 0px 15px 45%;
    background: rgb(118, 202, 159);
    padding: 1em;
    border-radius: 0;
    top: 0;
    width: auto;
	}
	.other-page.company-page .topics-col {
    margin-bottom: 50px;
    padding: 0 15px;
    }
	.pc-dis {
		display: none;
	}
	#top-dis {
    padding: 50px 0;
	}
	#top-dis .container {
    /*padding-right: 0;
    padding-left: 0;*/
	}
	.company-page #top-dis .container {
    padding-right: 15px;
    padding-left: 15px;
	}
	.service-dis-bg {
    height: 300px;
	}
	.service-num-wrap .ser-div {
    padding: 0 30px;
	margin-bottom: 20px;	
	}
	.com-flex {
     justify-content: center;
	}
	.com-flex-right {
     padding-right: 30px;
	 padding-left: 30px;	
	}
	.com-flex-left {
     padding-right: 30px;
	 padding-left: 30px;	
	}
	.com-flex-inner {
	text-align: center;
	width: 100%;	
	}
	.contact-wrap {
    padding: 3rem 1.5rem;
	}
	#top-news .news-cat-tag {
    position: absolute;
    left: 15px;
    top: 0;
	}
	#top-news .news-content {
    padding-left: 15px;
    padding-right: 15px;
	}
	#top-news .news-content-text p {
    overflow: initial;
    height: auto;
	}
	.more-buttom {
    display: none;
	}
	.contents-title-box {
    margin-bottom: 0;
	}
	.contents-title-box {
    margin-bottom: 0;
    }
	.top-page .contents-title-box {
    margin-bottom: 3rem
	}
	.news-content-wrap .content-button a {
	width: 100%;	
	}
	#top-service .text-top {
    position: relative;
    margin-bottom: 3rem;
	}
	.text-bottom p {
    font-size: 1.6rem;
	}
	.topics-col h3 {
    text-align: center;
	}
	.contact-wrap p.contents-dis {
    font-size: 1.6rem;
	}
	.content-button p {
    font-size: 1.6rem;
	}
	.footer-menu li a {
    color: #555;
    font-size: 1.4rem;
	}
	#top-news .news-cat-tag span {
    display: inline-block;
    font-size: 125%;
	}
	.other-page .hero-wrap {
    max-width: 100%;
    margin-top: 50px;
    z-index: 1;
	}
	.other-page .hero-image {
    height: 300px;
	}
	.other-page .hero-copy h2 {
    font-size: 2.4rem;
	}
	.other-page .hero-image .hero-text {
    bottom: -25px;
	}
	.other-page #top-dis {
    padding-top: 100px;
    margin-top: 0;
	}
	.other-page .topics-col {
    margin-bottom: 0;
    padding: 0 50px;
	}
	.other-page.contact-page .topics-col {
    margin-bottom: 0;
    padding: 0;
	}
	.contact-table table th {
    padding-left: 0;
    border: none;
    font-size: 1.6rem;
    line-height: 1;
    width: 100%;
    vertical-align: middle;
    font-weight: normal;
    text-align: left;
    color: #555;
    display: inline-block;
    /* clear: left; */
    margin-bottom: 20px;
	}
	.contact-table table td {
    font-size: 16px;
    padding: 0;
    text-align: left;
    line-height: 1;
    display: flex;
    align-items: center;
	}
	.recruit-page .table-archive-col {
		margin-bottom: 0;
	}
	.company-page .table-style {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
	}
	.access-page .table-archive-col .container {
    padding-right: 30px;
    padding-left: 30px;
	}
	.access-page .table-style {
    padding-left: 0;
    padding-right: 0;
	}
	.other-page.access-page .topics-col {
    margin-bottom: 0;
    padding: 0;
	}
	.access-page .table-style th {
    width: 100%;
	}
	.access-page .table-style td.data {
    width: 100%;
	}
	#route .table-style-access th {
    display: block;
    width: 100%;
	}
	#route .table-style-access td.data {
    display: block;
    width: 100%;
    padding-left: 0;
	}
	.other-page.privacy-page .topics-col {
    margin-bottom: 0;
    padding: 0;
	}
	.privacy-page .topics-col h3 {
    display: block;
    padding: 10px 5px;
    background-color: #f4a365;
    color: #fff;
    font-size: 16px;
    letter-spacing: 0.2rem;
    border-radius: 30px;
    margin-bottom: 15px;
	}
	.single-page .news-content figure.img-liquid {
    height: 250px;
	}
}
span.big-text {
	font-size: 1.8rem;
    font-weight: bold;
    line-height: 2;
    text-decoration: underline;
    color: #f4a364;
}
.other-page.contact-page #top-dis {
    margin-top: 50px;
	margin-bottom: 100px;
    background-color: #fff;
}
@media (max-width: 991px) {
.other-page.contact-page #top-dis {
    margin-top: 0;
}	
}
.contact-box {
    padding: 2rem 0;
}
.contact-wrap .contents-dis-box {
    background-color: #f4a363;
    padding: 3rem 1.5rem;
}
.contact-wrap .green .contents-dis-box {
    background-color: #76ca9f;
    padding: 3rem 1.5rem;
}
.contact-wrap p.contents-dis {
    color: #fff;
}
.contact-wrap .content-button a {
    color: #555;
    background-color: #fff;
}
.contact-wrap .contact-tel-box {
    margin-bottom: 0;
}
.contact-box {
    padding: 2rem 0;
	padding-bottom: 0;
	background-color: #fff;
	border-radius: 3rem;
    overflow: hidden;
}
.green .contact-box {
	
}
.service-num-wrap {
	margin-top: 0;
}
.tel-add span {
    font-size: 4rem;
    color: #f4a364;
}
.contact-wrap {
    /*background: linear-gradient(-45deg, #fbf4f2, #f7e6d9, #e2e1dd, #eaf6f3);
    background-size: 400% 400%;
    animation: Gradient 15s ease infinite;*/
	background-color: #f3f0f0;
	
	background-image: radial-gradient(rgba(102, 24, 0, 0.1) 14%, transparent 15%), radial-gradient(rgba(102, 28, 0, 0.1) 14%, transparent 15%);
    background-position: 0 0, 10px 10px;
    background-size: 20px 20px;
}
@keyframes Gradient {
	0% {
		background-position: 0% 50%
	}
	50% {
		background-position: 100% 50%
	}
	100% {
		background-position: 0% 50%
	}
}
@media (max-width: 991px) {
.contact-wrap p.contents-dis {
    font-size: 1.4rem;
}
}
@media (max-width: 767px) {
.contact-wrap .col-md-6:first-of-type .contact-box {
    margin-bottom: 3rem;
}
}
.top-dis-img {
	margin-bottom: 5rem;
}
@media (max-width: 767px) {
.top-dis-img {
    margin-bottom: 3rem;
}
}
@media (min-width: 992px) {
#top-service .service-num-wrap .container {
    width: 100%;
	max-width: 100%;
    padding-right: 0;
    padding-left: 0;
    margin-right: auto;
    margin-left: auto;
}
#top-service .service-01 .ser-div {
    padding-right: 0;
}
#top-service .service-02 .ser-div {
    padding-left: 0;
}
#top-service .service-num-wrap {
    padding-bottom: 0;
}
.com-flex {
    padding: 0 100px;
}
}
.facility-img-box {
	margin-bottom: 30px;
}
.facility-col {
	margin-bottom: 10rem;
}
.facility-col figcaption {
	padding: 10px;
	font-size: 14px;
}
.facility-col .img-liquid {
	height: 350px;
}
@media (max-width: 1199px) {
.facility-col .img-liquid {
	height: 300px;
}	
}
@media (max-width: 991px) {
.facility-col .img-liquid {
	height: 220px;
}	
}
@media (max-width: 767px) {
.facility-col .img-liquid {
	height: 250px;
}	
}
/*アニメーション*/
.sa {
  opacity: 0;
  transition: all .5s ease;
}
 
.sa.show {
  opacity: 1;
  transform: none;
}
 
.sa--lr {
  transform: translate(-100px, 0);
}
 
.sa--rl {
  transform: translate(100px, 0);
}
 
.sa--up {
  transform: translate(0, 100px);
}
 
.sa--down {
  transform: translate(0, -100px);
}
 
.sa--scaleUp {
  transform: scale(.5);
}
 
.sa--scaleDown {
  transform: scale(1.5);
}
 
.sa--rotateL {
  transform: rotate(180deg);
}
 
.sa--rotateR {
  transform: rotate(-180deg);
}

/*-------------------------------*/
.button {
  display: inline-block;
  padding: .75rem 1.25rem;
  border-radius: 10rem;
  color: #fff;
  text-transform: uppercase;
  font-size: 1rem;
  letter-spacing: .15rem;
  transition: all .3s;
  position: relative;
  overflow: hidden;
  z-index: 1;
}
.button:after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #f4a264;
  border-radius: 10rem;
  z-index: -2;
}
.button:before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0%;
  height: 100%;
  background-color: #76ca9f;
  transition: all .3s;
  border-radius: 10rem;
  z-index: -1;
}
.button:hover {
  color: #fff;
}
.button:hover:before {
  width: 100%;
}
figure.img-liquid a {
    transition: 0.5s;
}
figure.img-liquid a:hover {
    background-color: rgba(244, 162, 100, 0.5);
    /*border-radius: 30px;*/
}

/*WordPress_管理画面表示時のマージン*/
.margin-top-32 {
	margin-top: 32px;
}
@media (max-width: 767px) {
.margin-top-46 {
	margin-top: 46px;
}
}

.single-page .contents-title-box {
    margin-bottom: 20px;
}

.widget_recent_entries {
	display: block;
    width: 100%;
}
.widget_recent_entries h2 {
	background-color: #f4a364;
    color: #fff;
    font-size: 16px;
	padding: 5px 10px;
    border-radius: 15px;
    margin-bottom: 15px;
}
.widget_recent_entries ul {
    padding-left: 10px;
}
.widget_recent_entries li {
    font-size: 14px;
	margin-bottom: 10px;
}
.widget_recent_entries li a {
    color: #555;
}
.single-page-wrap .instagram-section {
	margin-top: 50px;
}
@media (max-width: 991px) {
	.single-page-wrap .instagram-section {
	margin-top: 0;
	margin-bottom: 50px;	
}
}
.news-content-text h1 {
	font-size: 16px;
}

/* cms-pagination */
.cms-pagination {
    width: 100%;
    overflow: hidden;
    margin-top: 40px;
}

.cms-pagination ul {
    position: relative;
    float: left;
    left: 50%;
    margin-bottom: 12px;
}

.cms-pagination ul li {
    position: relative;
    float: left;
    left: -50%;
    width: 34px;
    height: 38px;
    display: table;
    margin: 0 2px;
    display: none;
}

.cms-pagination ul li.pagination-no-num {
    width: 50px;
    display: table;
}
@media (max-width: 1023px) {
.cms-pagination ul li.pagination-no-num {
    width: 75px;
    display: table;
}	
}
.cms-pagination ul li.pagination-no-num span {
    background: #eee;
    border: 1px solid #ddd;
    color: #ccc;
}

.cms-pagination ul li.pagination-sp span {
	background: #f4a364;
	border: none;
}

.cms-pagination ul li a,
.cms-pagination ul li span {
    width: 100%;
    height: 100%;
    display: table-cell;
    vertical-align: middle;
    text-align: center;
    position: relative;
    border: 1px solid #999;
    background: #fff;
}

.cms-pagination ul li a:before,
.cms-pagination ul li span:before {
    position: absolute;
    display: block;
    content: '';
    width: 96%;
    height: 2px;
    /*background: #ccc;*/
    bottom: -3px;
    left: 2%;
}

.cms-pagination ul li span {
    background: #555;
    border: 1px solid #555;
    color: #fff;
}

.pagination-txt {
    clear: both;
    text-align: center;
    margin-bottom: 40px;
}

.pagination-txt span {
    color: #999;
}

.cms-pagination ul li a {
	color: #555;
}

@media print,screen and (min-width: 1024px) {
    .cms-pagination ul li {
        width: 44px;
        height: 44px;
        margin: 0 3px;
        display: table;
    }
    .cms-pagination ul li a {
        -webkit-transition: background 0.3s ease;
        -moz-transition: background 0.3s ease;
        transition: background 0.3s ease;
    }
    .cms-pagination ul li a:hover {
        background: #ccc;
        -webkit-transition: background 0.3s ease;
        -moz-transition: background 0.3s ease;
        transition: background 0.3s ease;
    }
    .cms-pagination ul li.pagination-no-num {
        width: 60px;
    }
	.cms-pagination ul li.pagination-no-num.next, .cms-pagination ul li.pagination-no-num.prev {
        width: 75px;
    }
    .pagination-txt {
        margin-bottom: 60px;
    }
}


/*-----------------------------*/
.single-page-wrap .post-navigation {
    overflow: hidden;
    padding: 12px 0;
    /*border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;*/
	margin-top: 100px;
}
 
.single-page-wrap .prev {
    float: left;
}
 
.single-page-wrap .next {
    float: right;
}

.single-page-wrap .prev a {
    position: relative;
    /*float: left;*/
    width: 100%;
	color: #fff;
    background-color: #f4a363;
    padding: 10px 15px;
	padding-left: 30px;
    font-size: 12px;
}
.single-page-wrap .prev a::before {
    font-family: "Font Awesome 5 Free";
    content: "\f104";
    position: absolute;
    font-size: 16px;
    top: 5px;
    left: 15px;
    color: #fff;
    font-weight: 900;
}
.single-page-wrap .next a {
    position: relative;
    /*float: right;*/
    width: 100%;
    text-align: right;
	color: #fff;
    background-color: #f4a363;
    padding: 10px 15px;
	padding-right: 30px;
    font-size: 12px;
}
.single-page-wrap .next a::after {
    font-family: "Font Awesome 5 Free";
    content: "\f105";
    position: absolute;
    font-size: 16px;
    top: 5px;
    right: 15px;
    color: #fff;
    font-weight: 900;
}
.news-content-text h2 {
	text-align: left;
    font-size: 22px;
    letter-spacing: 0.1rem;
    margin-bottom: 20px;
    padding-bottom: 8px;
    border-bottom: 3px solid #f4a264;
}
.news-content-text h3 {
	text-align: left;
    font-size: 18px;
    letter-spacing: 0.1rem;
    margin-bottom: 20px;
	position: relative;
    padding-left: 1.5em;
}
.news-content-text h3:before {
	font-family: "Font Awesome 5 Free";
    content: "\f111";
    font-weight: 900;
    position: absolute;
    font-size: 18px;
    left: 0;
    top: 0;
    color: #f4a364;
}
@media (max-width: 767px) {
	.news-content-text h2 {
	text-align: left;
    font-size: 18px;
}
	.news-content-text h3 {
	text-align: left;
    font-size: 16px;
    letter-spacing: 0.1rem;
    margin-bottom: 20px;
	position: relative;
    padding-left: 1.5em;
}
	.news-content-text h3:before {
	font-family: "Font Awesome 5 Free";
    content: "\f111";
    font-weight: 900;
    position: absolute;
    font-size: 16px;
    left: 0;
    top: 0;
    color: #f4a364;
}
}
.topics-col p.capacity {
	display: inline-block;
    background-color: #555;
    color: #fff;
    border-radius: 20px;
    padding: 0 15px;
	font-size: 14px;
}
.topics-col p.holiday {
	text-align: center;
	font-size: 14px;
}
.h3-col-mb {
	margin-bottom: 50px;
}
.h3-col-mb h3 {
	margin-bottom: 20px;
}
.h3-col-mb a {
	font-size: 14px;
    text-decoration: underline;
    margin-bottom: 20px;
    display: block;
	color: #76ca9f;
}
.h3-col-mb p {
	font-size: 14px;
}
.kyubo {
	font-size: 18px;
    line-height: 1.8;
    border: 3px solid #f4a363;
    display: inline-block;
    padding: 20px;
    margin-bottom: 30px;
}
.kaiga {
	position: relative;
}
.kaiga-box .name {
	margin: 15px 0;
	text-align: center;
	font-size: 1.6rem;
}
.kaiga-box .comment {
	text-align: center;
	font-size: 1.2rem;
}
.kaiga:before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: inset 0 0 0px 8px rgba(255,255,255,0.6);
}
.kaiga.bImg {
      border:10px solid #ccc;
      border-image: url("../images/anzu/kaiga_waku_01.jpg") 15 repeat;
      -webkit-border-image: url("../images/anzu/kaiga_waku_01.jpg") 15 repeat;
    }
.kaiga.bImg::before {
      box-shadow: none;  
    }
.kaiga.shadow {
      box-shadow: 1px 3px 8px rgba(20,20,20,0.3);
    }
.kaiga.shadow::before {
      box-shadow: inset 1px 1px 6px 0px rgba(0,0,0,0.4),
                  -1px -1px 2px rgba(40,40,40,0.2),
                  1px 1px 2px rgba(255,255,255,1);  
    }
.kaiga.bWidth {
      border-width: 16px;
    }
.kaiga-box .name-tag {
	display: inline-block;
    padding: 5px 15px;
    margin-top: 30px;
    border: 1px solid #666;
}
.service-page .topics-col .gyoji-photo .service-dis-col {
    margin-bottom: 0;
}
.season .season-inner {
	margin-bottom: 50px;
	justify-content: center;
}
.season .season-inner:last-of-type {
	margin-bottom: 0;
}
.topics-col .season h4 {
    display: inline-block;
}
.topics-col .season .season-inner p {
    text-align: center;
}
@media (max-width: 991px) {
	.fall .season-inner:last-of-type .gyoji-photo:last-of-type {
		margin-top: 30px;
	}
}	
.spring {
    background-color: #ffe6e6;
    border-radius: 30px;
    padding: 30px;
    margin-bottom: 50px;
}
.summer {
    background-color: #e6ffe7;
    border-radius: 30px;
    padding: 30px;
    margin-bottom: 50px;
}
.fall {
    background-color: #fff6e6;
    border-radius: 30px;
    padding: 30px;
    margin-bottom: 50px;
}
.winter {
    background-color: #f1f5fd;
    border-radius: 30px;
    padding: 30px;
    margin-bottom: 50px;
}
@media (max-width: 767px) {
	.spring, .summer, .fall, .winter {
		padding: 30px 15px;
	}
}
.topics-col .season h4 {
    display: inline-block;
    padding-left: 1.5em;
    padding-right: 1.5em;
}
.service-page .topics-col .season h4::after {
  	font-family: "Font Awesome 5 Free";
    content: "\f111";
    position: absolute;
    font-size: 16px;
    right: 0;
    top: 1.5px;
    color: #f4a364;
	font-weight: 900;
}
.news-content img {
	width: auto;
    height: auto;
    max-width: 100%;
	padding-right: 15px;
}
.news-content img:last-of-type {
	padding-right: 0;
}

/*20221028_追加*/
/*-------------------------------------------------------*/
.message-col .com-flex-inner {
	margin-bottom: 80px;
}
.message-col .com-flex-inner:last-of-type {
	margin-bottom: 0;
}
.message-text-wrap {
	position: relative;
}
/*.message-text-wrap::before, .message-text-wrap::after {
	content: '';
	width: 15px;
	height: 100%;
	position: absolute;
}

.message-text-wrap::before {
	border-left: solid 1px #ddd;
	border-top: solid 1px #ddd;
	border-bottom: solid 1px #ddd;
	top: 0;
	left: 0;
}

.message-text-wrap::after {
	border-right: solid 1px #ddd;
	border-top: solid 1px #ddd;
	border-bottom: solid 1px #ddd;
	top: 0;
	right: 0;
}*/
#ceo-message .text-top h3 {
    color: #f4a364;
    line-height: 1;
    margin-bottom: 30px;
    padding: 10px;
    border: 2px solid #f4a364;
    font-size: 2.2rem;
}
/*.message-text-wrap {
    padding: 20px 50px;
}*/
#ceo-message .text-bottom li {
    font-size: 1.6rem;
    line-height: 1.8;
    letter-spacing: 0.15rem;
    color: #555;
	display: flex;
    justify-content: flex-start;
    align-items: center;
	margin-bottom: 25px;
    padding-bottom: 25px;
    border-bottom: 1px solid #eee;
}
@media screen and (max-width: 767px) {
#ceo-message .text-bottom li {
    flex-direction: column;
}	
}
#ceo-message .text-bottom li:last-of-type {
	margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}
#ceo-message .text-bottom li span.number {
	font-family: 'Abril Fatface', cursive;
	font-size: 100px;
	width: 100px;
    display: block;
	color: #dad4d0;
	line-height: 1;
	text-align: center;
	margin-right: 30px;
}
@media screen and (max-width: 767px) {
#ceo-message .text-bottom li span.number {
	width: 100%;
	color: #f5c7a9;
	margin-right: 0;
	margin-bottom: 15px;
    font-size: 50px;
}	
}
#ceo-message .text-bottom li span.mess-text {
	width: calc(100% - 130px);
	display: block;
	text-align: left;
}
@media screen and (max-width: 767px) {
#ceo-message .text-bottom li span.mess-text {
	width: 100%;
}	
}
@media screen and (max-width: 767px) {
.message-col {
	padding: 0 30px;
}
.message-text-wrap {
    padding: 15px;
}
#ceo-message .text-top {
    position: relative;
    margin-bottom: 1.5rem;
}
#ceo-message .text-top h3 {
    line-height: 1;
}
#ceo-message .text-bottom p {
    font-size: 1.4rem;
    line-height: 1.8;
	letter-spacing: 0;
}
}
@media screen and (max-width: 767px) {
	.other-page h2.contents-title {
		font-size: 2.2rem;
	}
	h2.contents-title .topics {
    width: auto;
    height: 28px;
	}
	h2.contents-title .con-img::after {
    width: 28px;
    height: 28px;
	}
	.sub-title-acc h3 {
	    font-size: 18px;	
	}
}


/*-------管理画面用_マージン-------*/
@media (min-width: 783px) {
.margin-top-32 {
margin-top: 32px;
}
.modal-menu-box.margin-top-32 {
    position: relative;
    margin: 0;
    margin-left: 10px;
}
.modal-menu-box.margin-top-32 .modal-btn {
    top: 32px;
}
.slide-text-wrap.wpadminbar-32 {
    height: calc(100vh - 32px);
}
.hero-news .hero-news-bar .left-tag.wpadminbar-32 {
    bottom: 32px;
}
.swiper-container.wpadminbar-32 {
    height: calc(100vh - 32px);
}
.hero-wrap.margin-top-32 {
    height: calc(100vh - 32px);
}
}
@media (max-width: 782px) {
.margin-top-46 {
	margin-top: 46px;
}
.modal-menu-box.margin-top-46 {
	margin-top: 0;
}
#header.margin-top-46 {
	position: absolute;	
}
#wpadminbar {
    position: fixed !important;
    top: 0;
    left: 0;
}
}
/*-------管理画面用_マージン-------*/
/*ローディング*/
.c-loader-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #5bbee5;
  z-index: 9999;
  display: grid;
  place-items: center;
  pointer-events: none;
}

.c-loader-container {
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -50px;
  margin-top: -10px;
  text-align: center;
  font-family: Arial;
  font-weight: bold;
}

.c-loader-container span {
  display: block;
  background: #000;
  width: 100px;
  height: 5px;
  margin-top: 5px;
  animation: load 2s infinite;
  border-radius: 5px;
}

.c-loader-container span:nth-child(2) {
  animation-delay: 100ms;
}

.c-loader-container span:nth-child(3) {
  animation-delay: 200ms;
}

@keyframes load {
  50% {
    width: 5px;
    margin-right: 95px;
    opacity: 0.1;
  }
}

/* メインコンテンツ */
.main {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh;
  background: linear-gradient(
    to bottom,
    hsl(180, 80%, 40%),
    hsl(240, 80%, 60%),
    hsl(300, 80%, 40%)
  );
  background-size: 400% 400%;
  animation: AnimationName 10s ease infinite;
}

@keyframes AnimationName {
  0% {
    background-position: 50% 0%;
  }
  50% {
    background-position: 50% 100%;
  }
  100% {
    background-position: 50% 0%;
  }
}

/*--------20240521_追加--------*/
.contact-wrap .content-button a {
 transition:1s all;
}
.contact-wrap .content-button a:hover {
    transform:scale(1.2,1.2);
    transition:1s all;
}
@media screen and (min-width: 992px) {
#top-service .service-num-wrap {
    padding-bottom: 0;
    overflow: hidden;
}
#top-service .service-01 .ser-div {
    padding-right: 0;
    padding-left: 0;
}
#top-service .service-02 .ser-div {
    padding-left: 0;
    padding-right: 0;
}
}
#manual {
    background-color: #468f7f;
    background-image: radial-gradient(rgba(102, 24, 0, 0.1) 14%, transparent 15%), radial-gradient(rgba(102, 28, 0, 0.1) 14%, transparent 15%);
    background-position: 0 0, 10px 10px;
    background-size: 20px 20px;
}
#manual h2.contents-title .con-img::after {
    background-image: url(../images/anzu/leaf_white.svg);
}




#manual .service-num {
    padding-top: 0;
}
#manual .sa.show {
    padding: 0 30px;
}
#manual .h3-col-wrap {
    border-radius: 15px;
    border: 5px solid #f4a364;
    margin-bottom: 0;
    padding: 30px;
    background-color: #FFF;
}
#manual .h3-col-wrap h3 {
    font-size: 22px;
    margin-bottom: 20px;
}
#manual .h3-col-wrap a {
    display: inline-block;
    margin-bottom: 0;
    background-color: #f4a364;
    color: #FFF;
    text-decoration: none;
    padding: 10px 30px;
    border-radius: 5px;
    font-size: 16px;
}
.other-page #manual h2.contents-title {
    color: #FFF;
}
#manual .contents-title-box .description {
    color: #FFF;
    margin-top: 30px;
}
@media screen and (min-width: 992px) {
#manual br {
    display: none;
}
}
@media screen and (max-width: 991px) {
#manual .sa.show:first-child {
    margin-bottom: 30px;
}
}