@charset "utf-8";
/*-------------------------------------*/
/*	トップページ	*/
/*-------------------------------------*/
/*初期アニメーション*/
#opening {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
 background-color:#fff;
  z-index:1000;
	animation:op_back 3s both;
}
 @keyframes op_back {
0% {
	background-color: #1A3B56;
}
	 50% {
background-color: #ffffff;
}
100% {
background-color: #ffffff;
}
}
 
#opening .op_img{
  position: absolute;
top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	z-index: 1100;
	max-width: 600px;
	width: 80%;
}
#opening .op_img svg{
	width: 100%;
}
/***************************************************
 * Generated by SVG Artista on 12/1/2022, 3:19:38 AM
 * MIT license (https://opensource.org/licenses/MIT)
 * W. https://svgartista.net
 **************************************************/

@-webkit-keyframes animate-svg-stroke-1{0%{stroke-dashoffset:1634.864990234375px;stroke-dasharray:1634.864990234375px}100%{stroke-dashoffset:0;stroke-dasharray:1634.864990234375px}}@keyframes animate-svg-stroke-1{0%{stroke-dashoffset:1634.864990234375px;stroke-dasharray:1634.864990234375px}100%{stroke-dashoffset:0;stroke-dasharray:1634.864990234375px}}@-webkit-keyframes animate-svg-fill-1{0%{fill:transparent}100%{fill:rgb(0,84,135)}}@keyframes animate-svg-fill-1{0%{fill:transparent}100%{fill:rgb(0,84,135)}}.svg-elem-1{-webkit-animation:animate-svg-stroke-1 1s cubic-bezier(0.47,0,0.745,0.715) 0s both,animate-svg-fill-1 0.7s cubic-bezier(0.47,0,0.745,0.715) 0.8s both;animation:animate-svg-stroke-1 1s cubic-bezier(0.47,0,0.745,0.715) 0s both,animate-svg-fill-1 0.7s cubic-bezier(0.47,0,0.745,0.715) 0.8s both}@-webkit-keyframes animate-svg-stroke-2{0%{stroke-dashoffset:1684.3983154296875px;stroke-dasharray:1684.3983154296875px}100%{stroke-dashoffset:0;stroke-dasharray:1684.3983154296875px}}@keyframes animate-svg-stroke-2{0%{stroke-dashoffset:1684.3983154296875px;stroke-dasharray:1684.3983154296875px}100%{stroke-dashoffset:0;stroke-dasharray:1684.3983154296875px}}@-webkit-keyframes animate-svg-fill-2{0%{fill:transparent}100%{fill:rgb(0,84,135)}}@keyframes animate-svg-fill-2{0%{fill:transparent}100%{fill:rgb(0,84,135)}}.svg-elem-2{-webkit-animation:animate-svg-stroke-2 1s cubic-bezier(0.47,0,0.745,0.715) 0.12s both,animate-svg-fill-2 0.7s cubic-bezier(0.47,0,0.745,0.715) 0.9s both;animation:animate-svg-stroke-2 1s cubic-bezier(0.47,0,0.745,0.715) 0.12s both,animate-svg-fill-2 0.7s cubic-bezier(0.47,0,0.745,0.715) 0.9s both}@-webkit-keyframes animate-svg-stroke-3{0%{stroke-dashoffset:146.77940368652344px;stroke-dasharray:146.77940368652344px}100%{stroke-dashoffset:0;stroke-dasharray:146.77940368652344px}}@keyframes animate-svg-stroke-3{0%{stroke-dashoffset:146.77940368652344px;stroke-dasharray:146.77940368652344px}100%{stroke-dashoffset:0;stroke-dasharray:146.77940368652344px}}@-webkit-keyframes animate-svg-fill-3{0%{fill:transparent}100%{fill:rgb(250,160,45)}}@keyframes animate-svg-fill-3{0%{fill:transparent}100%{fill:rgb(250,160,45)}}.svg-elem-3{-webkit-animation:animate-svg-stroke-3 1s cubic-bezier(0.47,0,0.745,0.715) 0.24s both,animate-svg-fill-3 0.7s cubic-bezier(0.47,0,0.745,0.715) 1s both;animation:animate-svg-stroke-3 1s cubic-bezier(0.47,0,0.745,0.715) 0.24s both,animate-svg-fill-3 0.7s cubic-bezier(0.47,0,0.745,0.715) 1s both}@-webkit-keyframes animate-svg-stroke-4{0%{stroke-dashoffset:587.7330932617188px;stroke-dasharray:587.7330932617188px}100%{stroke-dashoffset:0;stroke-dasharray:587.7330932617188px}}@keyframes animate-svg-stroke-4{0%{stroke-dashoffset:587.7330932617188px;stroke-dasharray:587.7330932617188px}100%{stroke-dashoffset:0;stroke-dasharray:587.7330932617188px}}@-webkit-keyframes animate-svg-fill-4{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-4{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-4{-webkit-animation:animate-svg-stroke-4 1s cubic-bezier(0.47,0,0.745,0.715) 0.36s both,animate-svg-fill-4 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.1s both;animation:animate-svg-stroke-4 1s cubic-bezier(0.47,0,0.745,0.715) 0.36s both,animate-svg-fill-4 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.1s both}@-webkit-keyframes animate-svg-stroke-5{0%{stroke-dashoffset:209.0625762939453px;stroke-dasharray:209.0625762939453px}100%{stroke-dashoffset:0;stroke-dasharray:209.0625762939453px}}@keyframes animate-svg-stroke-5{0%{stroke-dashoffset:209.0625762939453px;stroke-dasharray:209.0625762939453px}100%{stroke-dashoffset:0;stroke-dasharray:209.0625762939453px}}@-webkit-keyframes animate-svg-fill-5{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-5{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-5{-webkit-animation:animate-svg-stroke-5 1s cubic-bezier(0.47,0,0.745,0.715) 0.48s both,animate-svg-fill-5 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.2000000000000002s both;animation:animate-svg-stroke-5 1s cubic-bezier(0.47,0,0.745,0.715) 0.48s both,animate-svg-fill-5 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.2000000000000002s both}@-webkit-keyframes animate-svg-stroke-6{0%{stroke-dashoffset:374.2903747558594px;stroke-dasharray:374.2903747558594px}100%{stroke-dashoffset:0;stroke-dasharray:374.2903747558594px}}@keyframes animate-svg-stroke-6{0%{stroke-dashoffset:374.2903747558594px;stroke-dasharray:374.2903747558594px}100%{stroke-dashoffset:0;stroke-dasharray:374.2903747558594px}}@-webkit-keyframes animate-svg-fill-6{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-6{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-6{-webkit-animation:animate-svg-stroke-6 1s cubic-bezier(0.47,0,0.745,0.715) 0.6s both,animate-svg-fill-6 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.3s both;animation:animate-svg-stroke-6 1s cubic-bezier(0.47,0,0.745,0.715) 0.6s both,animate-svg-fill-6 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.3s both}@-webkit-keyframes animate-svg-stroke-7{0%{stroke-dashoffset:322.8776550292969px;stroke-dasharray:322.8776550292969px}100%{stroke-dashoffset:0;stroke-dasharray:322.8776550292969px}}@keyframes animate-svg-stroke-7{0%{stroke-dashoffset:322.8776550292969px;stroke-dasharray:322.8776550292969px}100%{stroke-dashoffset:0;stroke-dasharray:322.8776550292969px}}@-webkit-keyframes animate-svg-fill-7{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-7{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-7{-webkit-animation:animate-svg-stroke-7 1s cubic-bezier(0.47,0,0.745,0.715) 0.72s both,animate-svg-fill-7 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.4000000000000001s both;animation:animate-svg-stroke-7 1s cubic-bezier(0.47,0,0.745,0.715) 0.72s both,animate-svg-fill-7 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.4000000000000001s both}@-webkit-keyframes animate-svg-stroke-8{0%{stroke-dashoffset:375.0179748535156px;stroke-dasharray:375.0179748535156px}100%{stroke-dashoffset:0;stroke-dasharray:375.0179748535156px}}@keyframes animate-svg-stroke-8{0%{stroke-dashoffset:375.0179748535156px;stroke-dasharray:375.0179748535156px}100%{stroke-dashoffset:0;stroke-dasharray:375.0179748535156px}}@-webkit-keyframes animate-svg-fill-8{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-8{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-8{-webkit-animation:animate-svg-stroke-8 1s cubic-bezier(0.47,0,0.745,0.715) 0.84s both,animate-svg-fill-8 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.5s both;animation:animate-svg-stroke-8 1s cubic-bezier(0.47,0,0.745,0.715) 0.84s both,animate-svg-fill-8 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.5s both}@-webkit-keyframes animate-svg-stroke-9{0%{stroke-dashoffset:357.91387939453125px;stroke-dasharray:357.91387939453125px}100%{stroke-dashoffset:0;stroke-dasharray:357.91387939453125px}}@keyframes animate-svg-stroke-9{0%{stroke-dashoffset:357.91387939453125px;stroke-dasharray:357.91387939453125px}100%{stroke-dashoffset:0;stroke-dasharray:357.91387939453125px}}@-webkit-keyframes animate-svg-fill-9{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-9{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-9{-webkit-animation:animate-svg-stroke-9 1s cubic-bezier(0.47,0,0.745,0.715) 0.96s both,animate-svg-fill-9 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.6s both;animation:animate-svg-stroke-9 1s cubic-bezier(0.47,0,0.745,0.715) 0.96s both,animate-svg-fill-9 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.6s both}@-webkit-keyframes animate-svg-stroke-10{0%{stroke-dashoffset:384.6487731933594px;stroke-dasharray:384.6487731933594px}100%{stroke-dashoffset:0;stroke-dasharray:384.6487731933594px}}@keyframes animate-svg-stroke-10{0%{stroke-dashoffset:384.6487731933594px;stroke-dasharray:384.6487731933594px}100%{stroke-dashoffset:0;stroke-dasharray:384.6487731933594px}}@-webkit-keyframes animate-svg-fill-10{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-10{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-10{-webkit-animation:animate-svg-stroke-10 1s cubic-bezier(0.47,0,0.745,0.715) 1.08s both,animate-svg-fill-10 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.7000000000000002s both;animation:animate-svg-stroke-10 1s cubic-bezier(0.47,0,0.745,0.715) 1.08s both,animate-svg-fill-10 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.7000000000000002s both}@-webkit-keyframes animate-svg-stroke-11{0%{stroke-dashoffset:301.93939208984375px;stroke-dasharray:301.93939208984375px}100%{stroke-dashoffset:0;stroke-dasharray:301.93939208984375px}}@keyframes animate-svg-stroke-11{0%{stroke-dashoffset:301.93939208984375px;stroke-dasharray:301.93939208984375px}100%{stroke-dashoffset:0;stroke-dasharray:301.93939208984375px}}@-webkit-keyframes animate-svg-fill-11{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-11{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-11{-webkit-animation:animate-svg-stroke-11 1s cubic-bezier(0.47,0,0.745,0.715) 1.2s both,animate-svg-fill-11 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.8s both;animation:animate-svg-stroke-11 1s cubic-bezier(0.47,0,0.745,0.715) 1.2s both,animate-svg-fill-11 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.8s both}@-webkit-keyframes animate-svg-stroke-12{0%{stroke-dashoffset:438.2740478515625px;stroke-dasharray:438.2740478515625px}100%{stroke-dashoffset:0;stroke-dasharray:438.2740478515625px}}@keyframes animate-svg-stroke-12{0%{stroke-dashoffset:438.2740478515625px;stroke-dasharray:438.2740478515625px}100%{stroke-dashoffset:0;stroke-dasharray:438.2740478515625px}}@-webkit-keyframes animate-svg-fill-12{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-12{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-12{-webkit-animation:animate-svg-stroke-12 1s cubic-bezier(0.47,0,0.745,0.715) 1.3199999999999998s both,animate-svg-fill-12 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.9000000000000001s both;animation:animate-svg-stroke-12 1s cubic-bezier(0.47,0,0.745,0.715) 1.3199999999999998s both,animate-svg-fill-12 0.7s cubic-bezier(0.47,0,0.745,0.715) 1.9000000000000001s both}@-webkit-keyframes animate-svg-stroke-13{0%{stroke-dashoffset:137.36412048339844px;stroke-dasharray:137.36412048339844px}100%{stroke-dashoffset:0;stroke-dasharray:137.36412048339844px}}@keyframes animate-svg-stroke-13{0%{stroke-dashoffset:137.36412048339844px;stroke-dasharray:137.36412048339844px}100%{stroke-dashoffset:0;stroke-dasharray:137.36412048339844px}}@-webkit-keyframes animate-svg-fill-13{0%{fill:transparent}100%{fill:rgb(199,53,61)}}@keyframes animate-svg-fill-13{0%{fill:transparent}100%{fill:rgb(199,53,61)}}.svg-elem-13{-webkit-animation:animate-svg-stroke-13 1s cubic-bezier(0.47,0,0.745,0.715) 1.44s both,animate-svg-fill-13 0.7s cubic-bezier(0.47,0,0.745,0.715) 2s both;animation:animate-svg-stroke-13 1s cubic-bezier(0.47,0,0.745,0.715) 1.44s both,animate-svg-fill-13 0.7s cubic-bezier(0.47,0,0.745,0.715) 2s both}

@media screen and (max-width: 768px) {
#opening .op_img{
	width: 70%;
}
#opening .op_img svg{
	width: 100%!important;
}	
}

/*メインビジュアル*/
#main_wrap{
	background-image: url("../images/bg_sec01.png");
	background-size: 100%;
	background-repeat: no-repeat;
	background-position: bottom center;
	width: 100%;
	padding-top: 70px;
}
#main_area{
	position: relative;
	
}
#main_img{
	margin: 0 0 0 auto;
	width: 80%;
	position: relative;
	overflow: hidden;
	max-width: 1100px;
	border-radius: 80px 0 0 0;
}
#main_img img{
	width: 100%;
	/*animation:zoomUP 7s both;*/

}
 @keyframes zoomUP {
0% {
 transform: scale(1.5);
	opacity: 0;
}
	 40% {
 transform: scale(1.5);
opacity: 1;		 
}
100% {
 transform: scale(1);
}
}
#main_wrap h2{
	position: absolute;
	z-index: 1;
	right: 0;
	bottom: 0;
}
#main_wrap h2 span{
	font-size: 6.3rem;
	font-weight: 700;
	line-height: 1;
	padding:10px;
	background: #FFFFFF;
	display: inline-block;
}
@media screen and (max-width: 1000px) {
#main_wrap{
	padding-top: 70px;
}	
	#main_wrap h2{
	font-size: 5.0rem;
}
}
@media screen and (max-width: 768px) {
	
	#main_img{
	width: 90%;
}
#main_wrap h2 {
    position: absolute;
    top: 50%;
    left: 5%;
	right: auto;
	bottom: auto;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}	
#main_wrap h2 span{
	font-size: 5.0rem;
	line-height: 1.5;
	display: inline;
}	
}
@media screen and (max-width: 550px) {
#main_wrap h2 span{
	font-size: 3.0rem;
}
}




/* トップ　sec01 */

#top #sec01{
	padding: 80px 0 200px 0;
	background-image: url("../images/index/bg_sec02.svg");
	background-repeat: no-repeat;
	background-position: bottom center;
}
@media screen and (max-width: 768px) {

}
@media screen and (max-width: 550px) {	

}
/* トップ　sec02 */

#top #sec02{
background-color: #EAF6FD;
}
#top .service_list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 30px;
  justify-content: space-between;
	margin-bottom: 40px;
}
.service_list li {
	max-width: 350px;
  width: calc(100% / 3 - 30px);
		background: #FFFFFF;
	margin-top: 90px;
	position: relative;
	padding: 40px 15px 15px 15px;
}
.service_list li:first-child {
	border-radius: 50px 0 0 0;
}
.service_list li:last-child {
	border-radius: 0 50px 0 0;
}
.service_list li::before {
	content: "";
	width: 1px;
	height: 40px;
	background: #1A3B56;
	position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.service_list li::after {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50px;
	background: #1A3B56;
	position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.service_list li .no{
	font-family: 'Crimson Text', serif;
	font-weight: 600;
	line-height: 1;
	font-size: 6.4rem;
	text-align: center;
	display: block;
	position: absolute;
    top: -90px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.service_list li h3{
	text-align: center;
	margin-bottom: 20px;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1;
}
.service_list li h3 span{
	font-family: 'Crimson Text', serif;
	display: block;
	font-size: 2.4rem;
	font-weight: 600;
	margin-bottom: 5px;
}
@media screen and (max-width: 991px) {	
.service_list li h3{
	font-size: 2.4rem;
}
.service_list li h3 span{
	font-size: 2.0rem;
}
}
@media screen and (max-width: 768px) {
#top .service_list {
flex-direction: column;
}
.service_list li {
	max-width: 350px;
  width:100%;
	margin-top: 70px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	padding: 40px 15px 15px 15px;
	border-radius: 50px 50px 0 0;
}
.service_list li:last-child,.service_list li:first-child {
	border-radius: 50px 50px 0 0;
}
.service_list li .no{
	font-size: 5.0rem;
    top: -70px;
}	
}
@media screen and (max-width: 550px) {	

}

/* トップ　sec03 */
#top #sec03{
	position: relative;
}
#top #sec03::before{
	content: "";
	width: 95%;
	height: 60%;
	background: #F9F9F9;
	border-radius: 80px 0 0 0 ;
	position: absolute;
	top: 50%;
    right: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	z-index: -1;
}
.sliderArea{
	margin: 0 auto 40px auto;
	max-width: 1170px;
}
.sliderArea .slick-slide {
margin: 0 10px;	
	
}
.sliderArea .slick-list{
overflow: inherit;

}
.sec03_box{
}
.sec03_box a{
	display: block;
	position: relative;
	box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
		background: #FFFFFF;
}
.sec03_box a .cat_label{
	position: absolute;
	right: 0;
	top: 0;
	z-index: 1;
}
.sec03_box a:hover .cat_label,.sec03_box a:hover img{
opacity: 1;
}
.sec03_box h3{
	font-size: 1.6rem;
	line-height: 1.5;
	padding: 20px 10px;
	font-weight: 600;
	color: #1A3B56;
}
.sec03_box img{
	display: block;
	width: 100%;
}
@media screen and (max-width: 768px) {
#top #sec03{
	position: relative;
	background: #F9F9F9;
}
#top #sec03::before{
	content: none;
}
}
@media screen and (max-width: 550px) {	

}
/* トップ　sec04 */
a.rec_box{
	display: block;
	background: #000000;
	position: relative;
}
a.rec_box h2{
	line-height: 1.5;
	margin-bottom: 30px;
	letter-spacing: 0.1em;
	color: #FFFFFF;
	position: absolute;
	width: 90%;
	margin: 0 auto;
	top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	text-align: center;
}
a.rec_box h2::after{
	content: url("../images/ico_arrow.svg");
	display: block;
	margin-top: 20px;

}
a.rec_box h2 span{
	display: block;
	font-weight: 600;
	font-family: 'Crimson Text', serif;
	font-size: 5.6rem;
	line-height: 1;
}
a.rec_box img{
	opacity: 0.6;
	width: 100%;
}
a.rec_box:hover img{
	opacity: 0.9;
}
@media screen and (max-width: 991px) {
a.rec_box h2 span{
	font-size: 4.4rem;
}
}
@media screen and (max-width: 768px) {

}
@media screen and (max-width: 550px) {	

}


/* トップ　news*/


@media screen and (max-width: 768px) {
#top_news .news_list {
  margin-bottom: 40px;
}
}
/*共通*/
.ttl{
	line-height: 1.5;
	margin-bottom: 30px;
	letter-spacing: 0.1em;
}
.ttl span{
	display: block;
	font-weight: 600;
	font-family: 'Crimson Text', serif;
	font-size: 5.6rem;
	line-height: 1;
}
@media screen and (max-width: 991px) {
.ttl span{
	font-size: 4.4rem;
}
}
/*-------------------------------------*/
/*	下層ページ関連	*/
/*-------------------------------------*/
a .img_wrap {
overflow: hidden;
width: 100%;
}
a:hover .img_wrap img{
	transform: scale(1.1);
transition-duration: 0.5s;
	opacity: 1;
}
#sub_wrap{
	background-image: url("../images/bg_sec01.png");
	background-size: 100%;
	background-repeat: no-repeat;
	background-position: center center;
	width: 100%;
}
#sub_ttl{
	margin: 0 0 0 auto;
	width: 80%;
	height: 700px;
	position: relative;
	overflow: hidden;
	max-width: 1100px;
	padding: 0 40px 0 0;
	display: flex;
	align-items: center;
}
#sub_ttl h2{
	font-size: 4.0rem;
	font-weight: 500;
	text-align: right;
	margin: 0 0 0 auto;
}
#sub_ttl h2 span{
	font-size: 10rem;
	font-weight: 600;
	font-family: 'Crimson Text', serif;
	text-transform: uppercase;
	display: block;
}
ul.page_link{
	text-align: center;
	margin-bottom: 80px;
}
ul.page_link  li{
	display: inline-block;
	margin-right: 40px;
}
ul.page_link  li:last-child{
	margin-right: 0;
}
ul.page_link  li a{
	font-family: 'Crimson Text', serif;
	font-size: 3.0rem;
	font-weight: 600;
	color: #1A3B56;
	position: relative;
	display: block;
}
ul.page_link  li a::before{
	content: "";
	width: 1px;
	height: 40px;
	background: #1A3B56;
	position: absolute;
    bottom: -40px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
		-webkit-transition: all 0.3s ease-out;
	-moz-transition: all 0.3s ease-out;
	-ms-transition: all 0.3s ease-out;
	transition: all 0.3s ease-out;
}
ul.page_link  li a::after{
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50px;
	background: #1A3B56;
	position: absolute;
    bottom: -40px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
		-webkit-transition: all 0.3s ease-out;
	-moz-transition: all 0.3s ease-out;
	-ms-transition: all 0.3s ease-out;
	transition: all 0.3s ease-out;
}
ul.page_link  li a:hover::before{
	height: 50px;
    bottom: -50px;
}
ul.page_link  li a:hover::after{
    bottom: -50px;
}
@media screen and (max-width: 1000px){
#sub_ttl{
	padding: 70px 40px 0 0;
	height: 400px;
}
ul.page_link  li a{
	padding: 5px;
	font-size: 2.0rem;
}	
ul.page_link  li a::before,ul.page_link  li a::after{
	content: none;
}
ul.page_link  li a::after{
	content: "\f107";
	margin-left: 10px;
    position:relative;
    z-index:1;
    font-family: FontAwesome;
	width: auto;
	height: auto;
	background: none;
    bottom: auto;
    left: auto;
    transform:none;
    -webkit-transform: none;
    -ms-transform: none;
}
ul.page_link  li a:hover::after{
    bottom: auto;
}	
ul.page_link{
	margin-bottom: 40px;
}	
}
@media screen and (max-width: 768px){
#sub_ttl{
	margin: 0 0 0 auto;
	width: 100%;
	height: 200px;
	position: relative;
}	
#sub_ttl h2{
	font-size: 2.0rem;
}
#sub_ttl h2 span{
	font-size: 6rem;
}	
}
@media screen and (max-width: 550px) {
#sub_ttl{
	height: 200px;
}	
#sub_ttl h2{
	font-size: 1.8rem;
}
#sub_ttl h2 span{
	font-size: 4rem;
}
}
/*-------------------------------------*/
/*	会社概要　*/
/*-------------------------------------*/


@media screen and (max-width: 768px) {

}
@media screen and (max-width: 550px) {

}
/*-------------------------------------*/
/*	事業内容　*/
/*-------------------------------------*/
#service dl{
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 100px;
}
#service dl:last-of-type{
	margin-bottom: 0;
}
#service dl:nth-of-type(even){
flex-direction: row-reverse;
}
#service dl dt{
	width: 60%;
}
#service dl dd{
	width: 40%;
}
#service dl:nth-of-type(odd) dt img{
	border-radius: 0 80px 0 0 ;
	overflow: hidden;
	width: 100%;
}
#service dl:nth-of-type(even) dt img{
	border-radius: 80px 0 0 0 ;
	overflow: hidden;
	width: 100%;
}
#service dl dd .inner{
	width: 80%;
	max-width: 400px;
	margin: 0 auto;
}
#service dl dd .no{
	font-size: 14rem;
	color: #EAF6FD;
	text-align: center;
	display: block;
	font-family: 'Crimson Text', serif;
	font-weight: 600;
	line-height: 1;
	margin-bottom: 20px;
}
#service dl dd h2{
	font-size: 3rem;
	text-align: center;
	margin-bottom: 40px;
	font-weight: 600;
}
#service dl dd h2 span{
	font-size: 2rem;
	display: block;
	font-family: 'Crimson Text', serif;
	font-weight: 600;
	margin-top: 10px;
}
@media screen and (max-width: 991px) {
#service dl dd .no{
	font-size: 9rem;
}
#service dl dt{
	width: 50%;
}
#service dl dd{
	width: 50%;
}	
}
@media screen and (max-width: 768px) {
#service dl{
margin-bottom: 40px;
}	
#service dl,#service dl:nth-of-type(even){
flex-direction:column;
}	
#service dl dt{
	width: 100%;
}
#service dl dd{
	width: 100%;
	padding: 40px;
}
#service dl:nth-of-type(odd) dt img,#service dl:nth-of-type(even) dt img{
	border-radius: 0 0 0 0 ;
	overflow: hidden;
	width: 100%;
}	
#service dl dd .inner{
	width: 80%;
	max-width: 400px;
	margin: 0 auto;
}
#service dl dd h2{
	font-size: 2.4rem;
}
#service dl dd h2 span{
	font-size: 1.8rem;
}	
}
@media screen and (max-width: 550px) {
#service dl dd .inner{
	width: 85%;
}
}
/*-------------------------------------*/
/*	スタッフ紹介　*/
/*-------------------------------------*/
dl.staff_read{
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 100px;
}
dl.staff_read dt{
	width: 60%;
}
dl.staff_read dd{
	width: 40%;
}
dl.staff_read img{
	border-radius: 0 80px 0 0 ;
	overflow: hidden;
	width: 100%;
}
dl.staff_read dd .inner{
	width: 80%;
	max-width: 400px;
	margin: 0 auto;
}
dl.staff_read dd h2{
	font-size: 3rem;
	text-align: center;
	margin-bottom: 40px;
	font-weight: 600;
}


dl.staff_box{
	display: flex;
	justify-content: space-between;
	margin-bottom: 100px;
}
dl.staff_box:last-of-type{
	margin-bottom:0;
}
dl.staff_box dt{
	width: 30%;
	text-align: center;
}
dl.staff_box dt img{
	border-radius: 50px 0 0 0 ;
	overflow: hidden;
}
dl.staff_box dd{
	width: 70%;
	display: flex;
	align-items: center;
	background: #EAF6FD;
	padding: 20px 0;
}
dl.staff_box dd .inner{
	width: 90%;
	max-width: 500px;
	margin: 0 auto;
}
dl.staff_box dd h2{
	font-size: 3rem;
	margin-bottom: 20px;
	font-weight: 600;
	border-bottom: 1px solid #1A3B56;
	padding-bottom: 10px;
	line-height: 1.5;
}
dl.staff_box dd h2 span{
	font-size: 1.4rem;
	margin-right: 10px;

}
@media screen and (max-width: 991px) {

dl.staff_read dt{
	width: 50%;
}
dl.staff_read dd{
	width: 50%;
}
dl.staff_box dt{
	width: 40%;
}
dl.staff_box dd{
	width: 60%;
}
dl.staff_box dd h2{
	font-size: 2.4rem;
}	
}
@media screen and (max-width: 768px) {	
dl.staff_read{
flex-direction:column;
	margin-bottom: 40px;
}	
dl.staff_read dt{
	width: 100%;
}
dl.staff_read dd{
	width: 100%;
	padding: 40px 0;
	
}
dl.staff_read dt img{
	border-radius: 0 0 0 0 ;
	overflow: hidden;
	width: 100%;
}	
dl.staff_read dd .inner{
	width: 80%;
	max-width: 400px;
	margin: 0 auto;
}
dl.staff_read dd h2{
	font-size: 2.4rem;
}
dl.staff_box{
	flex-direction: column;
	margin-bottom: 40px;
}
dl.staff_box dt{
	width: 100%;
}
dl.staff_box dt img{
	border-radius: 0 0 0 0 ;
	overflow: hidden;
	max-width: 300px;
}
dl.staff_box dd{
	width: 100%;
	display: block;
	padding: 40px 0;
	background: none;
}
dl.staff_box dd .inner{
	width: 80%;
	max-width: 500px;
	margin: 0 auto;
}	
}
@media screen and (max-width: 550px) {
dl.staff_read dd .inner{
	width: 90%;
}
}
/*-------------------------------------*/
/*	施工事例	*/
/*-------------------------------------*/
#tab{
	margin-top: -90px;
	padding-top: 90px;
}
ul.tab_container {
	width: 100%;
	border-bottom: 1px solid #1A3B56;
	margin-bottom: 40px;
	display: flex;
}
ul.tab_container li {
  width: calc(100%/6);
	margin-right: 5px;
}
ul.tab_container li:last-child {
	margin-right: 0;
}
ul.tab_container li a{
	width: 100%;
	display: block;
	  padding:15px 0;
  background-color: #FFFFFF;
  text-align: center;
  color: #1A3B56;
  transition: all 0.2s ease;
	border-right: 1px solid #1A3B56;
	border-left: 1px solid #1A3B56;
	border-top:  1px solid #1A3B56;
	border-radius: 10px 10px 0 0;
}
ul.tab_container li a:hover{
  background-color: #EAF6FD;
}
ul.tab_container li a.current{
    background: #1A3B56;
	color: #FFFFFF;
}
.thm{
	display: block;
	position: relative;
	margin: 0 auto;
}
.thm .zoom_mark{
	position: absolute;
	bottom: 5px;
	right: 5px;
	display: block;
	background:rgba(0,0,0,0.55);
	padding: 5px;
}
ul.b-a{
	display: flex;
	justify-content: space-between;
}
ul.b-a li{
	position: relative;
	width: 45%;
	text-align: center;
}
ul.b-a li .ico_ba{
	position: absolute;
	left: 10px;
	top: -20px;
}
ul.b-a li:first-child::before{
	content: "";
	width: 0;
height: 0;
border-style: solid;
border-width: 20px 0 20px 15px;
border-color: transparent transparent transparent #1a3b56;
    position: absolute;
    top: 50%;
    right: -50px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
@media screen and (max-width: 1000px) {
#tab{
	margin-top: -70px;
	padding-top: 70px;
}	
}
@media screen and (max-width: 768px) {
ul.tab_container li {
  width: calc(100%/5);
	margin-right: 2px;
}
ul.tab_container li a{
	font-size: 1.2rem;

}	
	ul.b-a{
	flex-direction: column;
}
ul.b-a li{
	width: 100%;
}
ul.b-a li:first-child{
	margin-bottom: 50px;
}
ul.b-a li:first-child::before{
	content: "";
width: 0;
height: 0;
border-style: solid;
border-width: 15px 20px 0 20px;
border-color: #1a3b56 transparent transparent transparent;
    right: auto;
	 top: auto;
    left: 50%;
	bottom: -35px;
    transform: translate(-50%, 0);
    -webkit-transform: translate(-50%,0%);
    -ms-transform: translate(-50%, 0%);
}	
}
@media screen and (max-width: 550px) {
ul.b-a li .ico_ba{
	position: absolute;
	left: -10px;
	top: -10px;
}
}
/*-------------------------------------*/
/*	一覧ページナビ	*/
/*-------------------------------------*/
/*	ページナビ関連	*/
.wp-pagenavi {
	clear: both;
	margin: 40px auto auto;
	text-align: center;
}
.wp-pagenavi a{
	text-decoration: none!important;
	padding: 0.9em 1em!important;
	margin: 3px;
	display: inline-block;
	color:#1A3B56!important;
	background:#F9F9F9;
	border: none!important;
	-webkit-transition: all 0.3s ease-out;
	-moz-transition: all 0.3s ease-out;
	-ms-transition: all 0.3s ease-out;
	transition: all 0.3s ease-out;
	font-weight: 600;
}
.wp-pagenavi span{
	color:#1A3B56;
	vertical-align: baseline;
}
.wp-pagenavi span.current {
	text-decoration: none!important;
	padding: 0.9em 1em!important;
	margin: 3px;
	display: inline-block;
	border: none!important;
	color:#FFFFFF;
	background:#1A3B56;
	font-size: 1.6rem;
	font-weight: 600;
}
.wp-pagenavi span.current {
    border-color: #1A3B56!important;
}
.wp-pagenavi a:hover{
	border: none!important;
	color: #1A3B56!important;
	text-decoration: none!important;
	background:#EAF6FD;
}
.wp-pagenavi a:hover span{
	color:#FFFFFF;
}
.wp-pagenavi span {
    border: none!important;
}

.extend{
	padding: 0 10px 0 10px;
}
@media screen and (max-width: 768px){
.previouspostslink,.nextpostslink{
	font-size: 86%;
}
}
/*-------------------------------------*/
/*	新着情報　*/
/*-------------------------------------*/
/*一覧*/
.news_list {
  padding: 0;
}
#news .news_list {
  margin-bottom: 40px;
}
.news_list .item {
  display: flex;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  text-decoration: none;
  border-bottom: 1px dotted #999;
  padding: 20px 0;
}
.news_list .item:first-child {
 border-top: 1px dotted #999;
}
.news_list .item .date {
  margin: 0;
  min-width: 100px;
  padding: 0 15px 0 0;
}
.news_list .item .category {
  margin: 0;
  min-width: 110px;
  padding: 0 15px 0 0;
}
.news_list .item .title {
  margin: 0;
  width: 100%;
}
.news_list .item .title a{
	color:#1A3B56;
}
.news_list .item .title a:hover {
  opacity: 0.7;
	text-decoration: underline;
}
/* カテゴリーラベル */
.cat_label{
	display: inline-block;
	background: #1A3B56;
	color: #FFFFFF;
	font-size: 1.4rem;
	padding: 0.5em 0.5em;
	line-height: 1;
	border: 1px solid #1A3B56;
}
.cat_label:hover{
	display: inline-block;
	background: #fff;
	color: #1A3B56!important;
}
.news_list .cat_label{
	width: 100%;
	text-align: center;
	font-size: 1.2rem;
}
@media screen and (max-width: 767px) {
  .archive_cat li {
    margin-bottom: 20px;
  }
  .archive_cat li:last-child {
    margin-bottom: 0;
  }
  .news_list .item {
    flex-wrap: wrap;
  }
  .news_list .item .date {
    min-width: 100px;
  }
  .news_list .item .title {
    margin-top: 10px;
  }
}

/*詳細*/
.single_ttl{
	margin-bottom: 20px;
	line-height: 1.5;
	font-size: 2.8rem;
	text-align:left;
	letter-spacing: 0.1em;
	padding: 0.5em 0 0.5em 0;
	font-weight: 700;
	border-bottom: 1px solid #b3b3b3;
	position: relative;
}
.single_ttl::before{
	content: "";
	width: 10%;
	height: 1px;
	background: #1A3B56;
	position: absolute;
	left: 0;
	bottom: -1px;
}
.thumb{
	display: block;
	margin: 0 auto 40px auto;
	text-align: center;
}
.single .day{
color: #004098;
	margin-bottom: 30px;
	font-size: 1.6rem;
	letter-spacing: 0.1em;
}
.single_info{
	padding-top: 70px;
}
.cat_label{

}
.post-navigation {
    overflow: hidden;
    padding: 12px 0;
	font-size: 1.4rem;
}
 
.prev a {
    position: relative;
    float: left;
    width: 50%;
}
 
.next a {
    position: relative;
    float: right;
    width: 50%;
    text-align: right;
}
@media screen and (max-width: 768px){
.single .day{
color: #004098;
	margin-bottom: 20px;
	font-size: 103%;
	letter-spacing: 0.1em;
}
.single_info{
	padding-top: 50px;
}
}
/*-------------------------------------*/
/*	フォーム	*/
/*-------------------------------------*/
.form_area h4{
	margin-top: 40px;
	font-weight: 700;
	margin-bottom: 10px;
	line-height: 1.5;
	font-size: 1.8rem;
}
.submit_btn_wrap{
	position:relative;
	width:200px;
	margin:0 auto;
}
ul.submit2_btn_wrap{
	position:relative;
	width:50%;
	margin:0 auto;
	text-align: center;
}
ul.submit2_btn_wrap li{
	display: inline-block;
	width:200px;
	margin-left: 5px;
}
.submit_btn{
	width: 100%;
	padding: 0.7em 1.5em;
	display:inline-block;
	-webkit-transition: all 0.3s ease-out;
	-moz-transition: all 0.3s ease-out;
	-ms-transition: all 0.3s ease-out;
	transition: all 0.3s ease-out;
	font-size:1.6rem;
	text-align:center;
	border: 1px solid #1A3B56;
 background: #1A3B56;
	color: #fff;
	border-radius: 50px;
}
.submit_btn:hover{
	 background: #fff;
	text-decoration:none;
	color:#1A3B56;
}
.back_btn{
		width: 100%;
	height: 35px;
	position:relative;
	display:inline-block;
	border:1px solid #AAAAAA;
	font-size:88%;
	text-align:center;
	background:#AAAAAA;
	color:#FFFFFF;
	-webkit-transition: all 0.3s ease-out;
	-moz-transition: all 0.3s ease-out;
	-ms-transition: all 0.3s ease-out;
	transition: all 0.3s ease-out;
	-webkit-box-sizing : border-box ;
	-moz-box-sizing : border-box ;
	box-sizing : border-box ;
	line-height: 35px;
}

.back_btn:hover{
	color:#AAAAAA;
	background:#FFFFFF;
	text-decoration:none;
}
/*-------------------------------------*/
/*	フォーム関連	*/
input::-webkit-input-placeholder{
	color: #989898;
}
input:-ms-input-placeholder{
	color: #989898;
}
input::-ms-input-placeholder{
	color: #989898;
}
input::placeholder{
	color: #989898;
}

.must{
	margin:0 10px 0 0;
	padding:0.2em 1em;
	display:inline-block;
	color:#ffffff;
	font-size:1.2rem;
	font-weight: 300;
	background: #E5006A;
}

.privacy_box {
    border: 1px solid #000000;
	margin-bottom: 20px;
}

.privacy_inner {
    width: auto;
    height: 200px;
    overflow-y: scroll;
    padding: 22px;
	font-size: 100%;
}

.consent_check_wrap{
	padding: 20px;
	margin-bottom: 40px;
	text-align: center;
	background: #F9F9F9;
}
.consent_check_wrap p a{
	text-decoration: underline;
}
.form_area :focus {
  outline: solid 2px #3e4f69;
}

.form_area input[type="text"],
.form_area input[type="email"],
.form_area input[type="tel"],
.form_area textarea, .form_area radio, .form_area select {
	border: 1px solid #AAAAAA;
	font-family: inherit;
	font-size:1.6rem;
	padding: 0.7em;
	margin:0;
	background: #F9F9F9;
	border-radius: 0;
	-webkit-box-sizing : border-box ;
	-moz-box-sizing : border-box ;
	box-sizing : border-box ;
	max-width:100%;
}
.form_area input[type="text"],
.form_area input[type="email"],
.form_area input[type="tel"],
.form_area textarea, .form_area radio, .form_area select {
	margin-bottom: 0;
}

.form_area input[type="text"].text_fomr_01,.form_area input[type="email"].text_fomr_01,.form_area input[type="tel"].text_fomr_01 { width:70%; }
.form_area input[type="text"].text_fomr_02,.form_area input[type="email"].text_fomr_02,.form_area input[type="tel"].text_fomr_02{ width:50%; }
.form_area input[type="text"].text_fomr_03,.form_area input[type="email"].text_fomr_03,.form_area input[type="tel"].text_fomr_03{ width:40%; margin:0 0 0 5px }
.form_area input[type="text"].text_fomr_04,.form_area input[type="email"].text_fomr_04,.form_area input[type="tel"].text_fomr_04{ width:100%;}
.form_area textarea.form_txtarea_01{ width:100%;}

.form_area input[type="checkbox"] {
    height: 15px;
    width: 15px;
   margin: 5px;
    vertical-align: middle;
}
.form_area input[type="radio"] {
    vertical-align: middle;
	margin: 0 3px 0 0;
}
.form_area label {
	margin-right: 20px;
	font-weight: normal!important;
	font-size: 1.8rem;
	 padding: 5px;
}
span.wpcf7-list-item {
    display: inline-block;
    margin: 0 0 0 0.5em!important;
}
@media screen and (max-width: 768px){
	.tel_list{
	display: block;
}
.tel_list div{
margin-right: 0;	
}
	.privacy_inner {
    padding: 10px;
}
		.privacy_inner p{
    font-size: 1.2rem!important;
}
	.submit_btn_wrap{
		width:80%;
		margin: 0 auto;
	}
	.submit_btn{
		width:100%;
	}
	ul.submit2_btn_wrap li{
		margin-bottom: 20px;
	}
	input[type="text"].text_fomr_01,input[type="email"].text_fomr_01,input[type="tel"].text_fomr_01{ width:100%!important; }
	input[type="text"].text_fomr_02,input[type="email"].text_fomr_02,input[type="tel"].text_fomr_02{ width:100%!important; }
	ul.input_list li{
		margin-bottom: 20px;
	}
	ul.input_list li:last-child{
		margin-bottom: 0;
	}
	label {
	font-size: 1.6rem;
}
	}