/*
Theme Name: saneisyaryo
*/


@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@300;400;500;700&display=swap');

html {
 margin-top: 0px !important;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, pre,
abbr, address, cite, code,
del, dfn, img, ins, kbd, q, samp,
small, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	background: transparent;
	font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.6em;
	margin-top: 0;
	margin-right: 0;
	margin-bottom: 0;
	margin-left: 0;
	color: #333;
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 1px;
}

.single_text h1,
.single_text h2,
.single_text h3,
.single_text h4,
.single_text h5,
.single_text h6,
.single_text p,
.single_text span,
.single_text strong,
.single_text dl,
.single_text dt,
.single_text dd,
.single_text ul,
.single_text ol,
.single_text li {
	color: inherit;
	font-weight: initial;
}

em {
	font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #333;
	font-size: 15px;
	font-style: italic;	
}

body {
    line-height:1;
	-webkit-text-size-adjust: 100%;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}
nav ul {
    list-style:none;
}
/*blockquote, q {
    quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}*/
a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
	text-decoration: none;
	color: #333;
}
/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}
/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000; 
    font-style:italic;
    font-weight:bold;
}
del {
    text-decoration: line-through;
}
abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}
table {
   /* border-collapse:collapse;*/
    border-spacing:0;
}
/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}
input, select {
    vertical-align:middle;
}

/*li {
	list-style: none;	
}*/

img {
	vertical-align: bottom;
	max-width: 100%;
	height: auto;
}

/*end reset*/

/* ----------------------------------------------------
    text
---------------------------------------------------- */

.serif {
	font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝","ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.sans-serif {
	font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.lato {
	font-family: 'Lato', sans-serif;
}



.tc {text-align: center !important;}
.tr {text-align: right !important;}
.tl {text-align: left !important;}

.bold {font-weight:bold;}
 
.font10{font-size:10px !important;}
.font11{font-size:11px !important;}
.font12{font-size:12px !important;}
.font13{font-size:13px !important;}
.font14{font-size:14px !important;}
.font15{font-size:15px !important;}
.font16{font-size:16px !important;}
.font17{font-size:17px !important;}
.font18{font-size:18px !important;}
.font19{font-size:19px !important;}
.font20{font-size:20px !important;}
.font21{font-size:21px !important;}
.font22{font-size:22px !important;}
.font23{font-size:23px !important;}
.font24{font-size:24px !important;}
.font25{font-size:25px !important;}
.font26{font-size:26px !important;}
.font27{font-size:27px !important;}
.font28{font-size:28px !important;}
.font29{font-size:29px !important;}
.font30{font-size:30px !important;}
.font32{font-size:32px !important;}
.font34{font-size:34px !important;}
.font36{font-size:36px !important;}
.font40{font-size:40px !important;}
 
/* ----------------------------------------------------
    float
---------------------------------------------------- */
.fr {float: right !important;}
.fl {float: left !important;}
 
.clear {clear: both;}
 
.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
 
.clearfix {
  min-height: 1px;
}
 
* html .clearfix {
  height: 1px;
  /*¥*//*/
  height: auto;
  overflow: hidden;
  /**/
}
 

/* ----------------------------------------------------
    margin
---------------------------------------------------- */
 
.mt00 { margin-top:  0px !important; }
.mt05 { margin-top:  5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt50 { margin-top: 50px !important; }
.mt60 { margin-top: 60px !important; }
.mt80 { margin-top: 80px !important; }
 
.mr00 { margin-right:  0px !important; }
.mr05 { margin-right:  5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
.mr35 { margin-right: 35px !important; }
.mr40 { margin-right: 40px !important; }
.mr50 { margin-right: 50px !important; }
.mr60 { margin-right: 60px !important; }
.mr65 { margin-right: 65px !important; }
.mr6_5 { margin-right: 6.5% !important; }
 
.mb00 { margin-bottom:  0px !important; }
.mb05 { margin-bottom:  5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb35 { margin-bottom: 35px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb50 { margin-bottom: 50px !important; }
.mb55 { margin-bottom: 55px !important; }
.mb60 { margin-bottom: 60px !important; }
.mb70 { margin-bottom: 70px !important; }
.mb76 { margin-bottom: 76px !important; }
.mb80 { margin-bottom: 80px !important; }
.mb90 { margin-bottom: 90px !important; }
.mb100 { margin-bottom: 100px !important; }
 
.ml00 { margin-left:  0px !important; }
.ml05 { margin-left:  5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.ml35 { margin-left: 35px !important; }
.ml40 { margin-left: 40px !important; }
 
/* ----------------------------------------------------
    padding
---------------------------------------------------- */
 
.pt00 { padding-top:  0px !important; }
.pt05 { padding-top:  5px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt80 { padding-top: 80px !important; }
 
.pr00 { padding-right:  0px !important; }
.pr05 { padding-right:  5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }
.pr25 { padding-right: 25px !important; }
.pr30 { padding-right: 30px !important; }
.pr35 { padding-right: 35px !important; }
.pr40 { padding-right: 40px !important; }
 
.pb00 { padding-bottom:  0px !important; }
.pb05 { padding-bottom:  5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
 
.pl00 { padding-left:  0px !important; }
.pl05 { padding-left:  5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }
.pl25 { padding-left: 25px !important; }
.pl30 { padding-left: 30px !important; }
.pl35 { padding-left: 35px !important; }
.pl40 { padding-left: 40px !important; }






/* ----------------------------------------------------

    common

---------------------------------------------------- */


/* IE10以前でのみ有効 */
html {
height: 100%\9;
overflow: hidden\9;
}
body {
height: 100%\9;
overflow: scroll\9;
}
/* IE10以降でのみ有効 */
@media all and (-ms-high-contrast: none) {
	html {
		height: 100%;
		overflow: hidden;
	}
	body {
		height: 100%;
		overflow-y: scroll;
		overflow-x: hidden;
	}
}

.sec_in960 {
	max-width: 960px;
	width: 94%;
	margin: auto;
}

.sec_in1000 {
	max-width: 1000px;
	width: 90%;
	margin: auto;

}

.sec_in1200 {
	max-width: 1200px;
	width: 90%;
	margin: auto;

}

.sec_in800 {
	max-width: 800px;
	width: 90%;
	margin: auto;

}

.sec_in880 {
	max-width: 880px;
	width: 90%;
	margin: auto;

}

.sec_in1360 {
	max-width: 1360px;
	width: 90%;
	margin: auto;
}



.overflow-h {overflow: hidden;}


.object-fit-img {
  object-fit: contain;
  font-family: 'object-fit: contain;';
}

body {
	overflow-x: hidden;
	transition: .3s;
}

.content_wrap {
	transition: .3s;
	overflow: hidden;
}


.b_overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2000;
    background: #fff;
    transition: all .2s;
    opacity: 0;
	visibility: hidden;
	width: 100vw;
	height: 100vh;
}

.overflow-h .b_overlay {
	opacity: 1;
	visibility: visible;
}








.error404 .page-title {
	font-size: 24px;
	font-weight: bold;
	color: #224eb2;
	text-align: center;
	margin-bottom: 30px;
}

.error404 .page-content {
	text-align: center;
}

.error404 .page-content p {
	margin-bottom: 20px;
}

.error404 input[type="search"] {
	font-size: 16px;
	box-sizing: border-box;
	padding: 10px;
	border: solid 1px #ccc;
	width: 86%;
}

.error404 input[type="submit"] {
	box-sizing: border-box;
	padding: 9px;
	font-size: 16px;
	text-align: center;
	color: #fff;
	background: #224eb2;
	border: none;
	width: 13%;
	cursor: pointer;
}

.error404 .b_contact::after {width: 100%;}

.search .page-content p {
	margin-bottom: 20px;
}

.search input[type="search"] {
	font-size: 16px;
	box-sizing: border-box;
	padding: 10px;
	border: solid 1px #ccc;
	width: 86%;
}

.search input[type="submit"] {
	box-sizing: border-box;
	padding: 9px;
	font-size: 16px;
	text-align: center;
	color: #fff;
	background: #d94c17;
	border: none;
	width: 13%;
	cursor: pointer;
}

.search .page-title {
	font-size: 24px;
	font-weight: bold;
	color: #d94c17;
	text-align: center;
	margin-bottom: 30px;
}

.search article {
	padding-bottom: 30px;
	margin-bottom: 30px;
	border-bottom: solid 1px #ddd;
}

.search article .entry-title a {
	display: block;
	font-size: 20px;
	font-weight: bold;
	color: #d94c17;
	margin-bottom: 10px;
}

.search article .entry-meta {display: none;}

.search article .entry-summary p {
	color: #999;
}

.search .post-thumbnail {
	display: block;
	padding-bottom: 20px;
}

.page_wrap01 {
	padding: 10vh 0 15vh;
}

.page-template-default .site-content {
	padding: 90px 0;
}

.page-template-default .entry-header {
	display: none;
}

.page-template-default .edit-link {
	display: none;
}












.breadcrumbs {
	width: 92%;
	margin: auto;
	box-sizing: border-box;
	padding: 30px 0;
}

.breadcrumbs p {
	font-size: 14px;
	letter-spacing: 2px;
	color: #aaa;
	line-height: 1.3;

}

.breadcrumbs span {
	font-size: 14px;
	letter-spacing: 2px;
	color: #aaa;
	line-height: 1.3;
}

.breadcrumbs span a {
	font-size: 14px;
	letter-spacing: 2px;
	color: #aaa;
	line-height: 1.3;
	text-decoration: underline;
}

.breadcrumbs span a:hover {
	text-decoration: none;
	color: #ce4b1b;
}


@media screen and ( max-width:991px ){
	.breadcrumbs p {font-size: 12px; letter-spacing: 1px;}
	.breadcrumbs span {font-size: 12px; letter-spacing: 1px;}
	.breadcrumbs span a {font-size: 12px; letter-spacing: 1px;}
	.breadcrumbs {width: 91%;}
}

@media screen and ( max-width:567px ){
	.breadcrumbs {padding: 20px 0;}
}




.page_main {
	position: relative;
	top: 0;
	width: 100%;
}

.page_main_img img {
	object-fit: cover;
	width: 100%;
	height: 560px;
}

.page_main_filter {
	position: absolute;
	top: 0;
	left: 0;
	max-width: 747px;
	width: 70%;
	z-index: 10;
}

.page_main_filter img {
	object-fit: cover;
	width: 100%;
	height: 560px;
}

.page_main_text {
	position: absolute;
	top: 45%;
	left: 8%;
	z-index: 100;
}


.grecaptcha-badge { 
   visibility: hidden; 
}


/* ----------------------------------------------------

    header

---------------------------------------------------- */

header {
	position: relative;
}

.h_logo a {
	display: block;
	
	padding-top: 23px;
	position: absolute;
	top: 0;
	left: 2.5%;
	z-index: 9000;
	transition: .3s;
}

.h_logo a.zindex {z-index: 8000;}

.h_logo a img {transition: .3s;}

.h_logo a.fixed {
	width: 200px;
	height: 100px;
	padding-top: 32px;
}

.h_logo a.fixed img {
	width: 110px;
}



/*　メニューボタン（ブロック）ここから　*/

.h_menu {
	width: 100px;
	height: 100px;
	box-sizing: border-box;
	cursor: pointer;
	position: fixed;
	top: 0;
	right: 0;
	background: #224eb2;
	z-index: 99999;
	text-align: center;
	
}

.h_menu:hover {background: #0b3ba8;}

.h_menu_in {
	width: 36px;
	height: 36px;
	position: absolute;
	top: 32px;
	left: 0;
	right: 0;
	margin: auto;
}

.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 100%;
    height: 100%;
	
	box-sizing: border-box;
}
.menu-trigger span {
	position: absolute;
	left: 0;
    right: 0;
    margin: auto;
	width: 36px;
	height: 1px;
	background-color: #fff;
	border-radius: 0;
}
.menu-trigger span:nth-of-type(1) {
	top: 6px;
	transform: translateY(-3px);
	transition: .2s;
}
.menu-trigger span:nth-of-type(2) {
	top: 12px;
}
.menu-trigger span:nth-of-type(3) {
	bottom: 17px;
	transform: translateY(3px);
	transition: .2s;
}

.h_menu:hover .menu-trigger span:nth-of-type(1) {
	transform: translateY(0);
}

.h_menu:hover .menu-trigger span:nth-of-type(3) {
	transform: translateY(0);
}

.menu-trigger.active {
	transition: .3s;
}

.h_menu .menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(6px) rotate(-45deg);
	transform: translateY(6px) rotate(-45deg);
	width: 36px;
}
.h_menu .menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}
.h_menu .menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-5px) rotate(45deg);
	transform: translateY(-5px) rotate(45deg);
	width: 36px;
}

.menu-trigger p {
	text-align: center;
    font-size: 11px;
    color: #fff;
    letter-spacing: 0.5px;
	position: absolute;
	bottom: -8px;
	width: 36px;
	left: 0;
	right: 0;
	margin: auto;
}


@media screen and ( max-width:1366px ){	
	.h_menu {width: 80px; height: 80px;}
	.h_menu_in {top: 24px; width: 30px; height: 30px;}
	.menu-trigger span {width: 30px;}
	.menu-trigger p {font-size: 10px; width: 30px; letter-spacing: 0;}
	.menu-trigger span:nth-of-type(2) {top: 11px;}
	.menu-trigger span:nth-of-type(3) {bottom: 13px;}
	.h_menu .menu-trigger.active span:nth-of-type(1) {width: 30px; -webkit-transform: translateY(5px) rotate(-45deg); transform: translateY(5px) rotate(-45deg);}
	.h_menu .menu-trigger.active span:nth-of-type(3) {width: 30px;}

}

@media screen and ( max-width:991px ){
	.h_menu {background: #222;}
	.h_menu:hover {background: #333;}
}

@media screen and ( max-width:767px ){	
	.h_menu {width: 66px;height: 66px;}
	.h_menu_in {top: 16px;}
	
}



/*　メニューボタン（ブロック）ここまで　*/






.header_top {
	z-index: 8000;
	height: 100px;
	width: 100%;
	box-sizing: border-box;
	position: absolute;
	top: 0;
	left: 0;
	border-bottom: solid 1px rgba(255,255,255,0.4);
}

.header_top nav {
	float: right;
	padding-right: 100px;
	padding-top: 38px;
	position: relative;
}

.header_top nav ul {
	
}

.header_top nav li {
	float: left;
	padding-right: 50px;
}

.header_top nav li a {
	font-size: 17px;
	padding: 10px 0 37px;
	letter-spacing: 2px;
	line-height: 1.2;
	color: #fff;
	transition: .3s;
}

.header_top nav li a span {
	font-size: 0.7em;
	display: block;
	text-align: center;
	color: #fff;
	font-weight: 500;
	padding-top: 5px;
	transition: .3s;
}

.header_top nav li a:hover {
	color: #f3bc29;
}

.header_top nav li a:hover span {
	color: #f3bc29;
}




ul.child {
	position: absolute;
	top: 100px;
	left: 25%;
    z-index: 9999;
	transition: .3s;
	opacity: 0;
	overflow: hidden;
	background: rgba(255,255,255,0.8);
	backdrop-filter: blur(15px);
	padding: 12px 15px 5px;
	box-sizing: border-box;
	visibility: hidden;
	max-width: 500px;
}

ul.child li {
	float: left;
	
	padding-right: 0;
	width: 42%;
	margin: 0 4%;
}


ul.child li a {
    padding: 10px 0 10px !important;
    display: block;
    color: #333;  
    text-align: center;
    box-sizing: border-box;
    transition: .3s;
	font-size: 15px;
	line-height: 1.3;
	letter-spacing: 0;
	font-weight: 400;
	margin-right: 0 !important;
}

ul.child li a:hover {
	color:#d6a217;
}

ul.child li a img {
	padding-bottom: 5px;
	transition: .3s;
}

ul.child li a:hover img {opacity: 0.6;}

nav > ul > li > .nav_li:hover + ul.child {
	display: block;
	transition: .3s;
	opacity: 1;
	/*transform: scale(1) translate(0, 0);*/
	visibility: visible;
}

ul.child:hover {
	display: block;
	transition: .3s;
	opacity: 1;
	/*transform: scale(1) translate(0, 0);*/
	visibility: visible;
}





.header_main {
	position: relative;
	height: 0;
	padding-top: calc(880 / 1920 * 100%);
}


.main_img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}


.h_main_text_bg {
	max-width: 587px;
	width: 40%;
	position: absolute;
	bottom: 27%;
	left: 7%;
	z-index: 1;
	transform: translateX(300px);
	opacity: 0;
	transition: all 1.2s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .1.2s;
}
.h_main_text_bg.show {
	opacity: 1;
	transform: translateX(0);
}

.h_main_text {
	position: absolute;
	bottom: 16%;
	left: 14%;
	z-index: 10;
	box-sizing: border-box;
	/*padding: 260px 0 0 140px;
	background-image: url("images/header/h_text_bg.png");
	background-repeat: no-repeat;
	background-size: 587px;
	background-position: left top;*/
}

.h_main_text h2 {
	margin-bottom: 10px;
	display: block;
	overflow: hidden;
	position: relative;
	font-size: 35px;
	color: #f3bc29;
	line-height: 1;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1.2s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .9s;
}

.h_main_text h2 span {
	font-size: 45px;
	color: #f3bc29;
}

.h_main_text.show .h_main_text01  {
	opacity: 1;
	transform: translateY(0);
}



.h_main_text h3 {
	font-size: 18px;
	letter-spacing: 1px;
	line-height: 1.7;
	color: #fff;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1.2s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: 1s;
}

.h_main_text.show .h_main_text03 {
	transform: translateY(0);
	opacity: 1;
}



.c-scroll {
    width: 1px;
    height: 10rem;
    position: absolute;
    bottom: 0;
    right: 2%;
    z-index: 3000;
}

.c-scroll a {
    display: block;
    height: 100%;
    position: relative;
    -webkit-transition: all 0.4s ease;
    -o-transition: all 0.4s ease;
    transition: all 0.4s ease;
    text-decoration: none;
}

.c-scroll a span {
    display: block;
    font-size: 11px;
	font-weight: 600;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    letter-spacing: 2px;
}

.c-scroll__line {
    width: 1px;
    height: 5.5rem;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    background-color: rgba(255, 255, 255, 0.3);
    z-index: 3500;
}

.c-scroll__line::before {
    content: "";
    width: 100%;
    height: 100%;
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: 0;
    background-color: white;
    -webkit-animation-name: lineInOut;
    animation-name: lineInOut;
    -webkit-animation-duration: 2s;
    animation-duration: 2s;
    -webkit-transform: scaleY(0);
    -ms-transform: scaleY(0);
    transform: scaleY(0);
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
}

@-webkit-keyframes lineInOut {
  0% {
    opacity: 0;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  5% {
    opacity: 1;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  59% {
    opacity: 1;
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  60% {
    opacity: 1;
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: bottom;
            transform-origin: bottom;
  }
  100% {
    opacity: 1;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: bottom;
            transform-origin: bottom;
  }
}

@keyframes lineInOut {
  0% {
    opacity: 0;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  5% {
    opacity: 1;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  59% {
    opacity: 1;
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
  60% {
    opacity: 1;
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: bottom;
            transform-origin: bottom;
  }
  100% {
    opacity: 1;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: bottom;
            transform-origin: bottom;
  }
}

@keyframes lineInOut2 {
  0% {
    opacity: 0;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: left;
            transform-origin: left;
  }
  5% {
    opacity: 1;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: left;
            transform-origin: left;
  }
  59% {
    opacity: 1;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: left;
            transform-origin: left;
  }
  60% {
    opacity: 1;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    opacity: 1;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: right;
            transform-origin: right;
  }
}





.sp_menu_wrap {
	overflow: scroll;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 8500;
    width: 100%;
    background: #fff;
    height: 100vh;
    transition: all .3s;
	box-sizing: border-box;
	opacity: 0;
	visibility: hidden;
}

.sp_menu_wrap.open {
	opacity: 1;
	visibility: visible;
}

.sp_menu_left {
	float: left;
	width: 50%;
}

.sp_menu_left img {
	object-fit: cover;
	width: 100%;
	height: 100vh;
}

#metaslider_17 .slides img {
	object-fit: cover;
	width: 100%;
	height: 100vh;
}

.sp_menu {
	float: right;
	width: 50%;
	padding-top: 18vh;
	box-sizing: border-box;
}

.sp_menu_in {
	max-width: 340px;
	width: 80%;
	margin: auto;
}

.sp_menu_in h2 {
	font-size: 34px;
	letter-spacing: 5px;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 60px;
	text-align: center;
	color: #111;
}

.sp_menu01 {
	margin-bottom: 60px;
}

.sp_menu01 li {
	margin-bottom: 40px;
	list-style: none;
	text-align: center;
}

.sp_menu01 li a {
	font-size: 22px;
	letter-spacing: 4px;
	font-weight: 400;
	color: #224eb2;
	padding: 0 4px 0 6px;
	display: inline-block;
	position: relative;
	transition: .3s;
}

.sp_menu01 li a:hover {
	color: #e6b532;
}

.sp_menu01 li a span {
	display: block;
	font-size: 14px;
	letter-spacing: 2px;
}



.sp_copy {
	font-size: 12px;
	letter-spacing: 1px;
	text-align: center;
	color: #1F3058;
}












/* ----------------------------------------------------

    top

---------------------------------------------------- */


.top01 {
	margin: 100px 0 140px;
	position: relative;
	min-height: 760px;
}

.top01_img {
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	z-index: 1;
	transition: all .8s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .4s;
}

.top03 .top01_img {left: auto; right: 0;}

.top01.show .top01_img {
	width: 45.83%;
}

.top01_img img {
	object-fit: cover;
	width: 100%;
	height: 600px;
}

.top01_in {
	max-width: 520px;
	width: 44%;
	float: right;
	padding-top: 10px;
}
.top03 .top01_in {float: left;}

.top03_in {
	max-width: 600px;
	width: 48%;
}

.top01_in h4 {
	font-size: 17px;
	letter-spacing: 2px;
	color: #224eb2;
	line-height: 1;
	margin-bottom: 130px;
	position: relative;
	box-sizing: border-box;
	padding-left: 50px;
	display: block;
}

.top01_in h4::before {
	display: block;
	content: "";
	width: 40px;
	height: 1px;
	background: #224eb2;
	position: absolute;
	left: 0;
	top: 49%;
}

.top03_in h4 {color: #e6b532;}
.top03_in h4::before {background: #e6b532;}



.top01_in h2 {
	font-size: 40px;
	letter-spacing: 3px;
	line-height: 1.4;
	margin-bottom: 50px;
	color: #224eb2;
}

.top01_in p {
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 2px;
	line-height: 1.8;
	color: #333;
}

.top01_bg {
	width: 0;
	height: 610px;
	background: #d3dcf0;
	position: absolute;
	bottom: 60px;
	right: 0;
	z-index: -1;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .8s;
}

.top03 .top01_bg {
	right: auto;
	left: 0;
	height: 520px;
}

.top01.show .top01_bg {
	width: 61%;
}

.bnr01 {
	max-width: 540px;
	width: 90%;
	position: absolute;
	bottom: 0;
	right: 50%;
	z-index: 100;
	box-shadow: 10px 10px 30px rgba(0,0,0,0.3);
	transform: translateY(150px);
	opacity: 0;
	transition: all 1.2s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: 1.2s;
}

.top01.show .bnr01 {
	transform: translateY(0);
	opacity: 1;
}

.bnr01 a {display: block;}

.bnr01 dl {
	display: table;
	width: 100%;
}

.bnr01 dt {
	display: table-cell;
	width: 200px;
	transition: .3s;
	overflow: hidden;
}

.bnr01 dt img {
	object-fit: cover;
	width: 100%;
	height: 200px;
	transition: .3s;
}

.bnr01 dd {
	display: table-cell;
	box-sizing: border-box;
	text-align: center;
	vertical-align: middle;
	background: #fff;
	padding-top: 20px;
	transition: .3s;
}

.bnr01 dd p {
	font-size: 14px;
	letter-spacing: 1px;
	color: #fff;
	line-height: 1;
	margin-bottom: 18px;
	transition: .3s;
	font-weight: 500;
	display: inline-block;
	box-sizing: border-box;
	padding: 4px 15px;
	background: #224eb2;
	border-radius: 20px;
}

.bnr01 dd h3 {
	font-size: 26px;
	letter-spacing: 3px;
	line-height: 1;
	color: #224eb2;
	margin-bottom: 35px;
	transition: .3s;
}

.bnr01 dd h4 {
	font-size: 12px;
	color: #224eb2;
	line-height: 1;
	letter-spacing: 2px;
	transition: .3s;
}

.bnr01 dd h4 img {
	padding-left: 4px;
	position: relative;
	bottom: 2px;
	transition: .3s;
}

.bnr01 a:hover dt img {
	transform: scale(1.1);
	filter: brightness(0.5);
}

.bnr01 a:hover dd {
	background: #224eb2;
}

.bnr01 a:hover dd p {background: #fff; color: #224eb2;}
.bnr01 a:hover dd h3 {color: #fff;}
.bnr01 a:hover dd h4 {color: #fff;}
.bnr01 a:hover dd h4 img {filter: brightness(10);}


.top03_bnr_wrap {
	position: absolute;
	bottom: 0;
	max-width: 1040px;
	width: 100%;
	z-index: 100;
}

.top03_bnr_wrap .bnr01 {
	position: static;
	float: left;
	width: 48%;
}

.top03_bnr_wrap .bnr01:nth-of-type(2) {float: right;}

.top03_bnr_wrap .bnr01 dd {background: #e6b532;}
.top03_bnr_wrap .bnr01 dd p {
	color: #fff;
	background: transparent;
	padding: 0;
	font-size: 27px;
	font-weight: 500;
	line-height: 1;
}
.top03_bnr_wrap .bnr01 a:hover dd p {background: transparent; color: #fff;}
.top03_bnr_wrap .bnr01 dd h3 {color: #fff;}
.top03_bnr_wrap .bnr01 dd h4 {color: #fff;}

.top03 {min-height: 680px;}

.top03 .sec_in1200 {overflow: visible;}
.top03_in {padding-top: 10px;}
.top03_in .bnr01 {position: static;}
.top03_in .bnr01 dd h4 {margin-bottom: 0;}

.top03_in_text {margin-bottom: 80px; color: #222 !important;}
.top03_bg {background: #f5f5f5;}



.sec_title01 {
	margin-bottom: 80px;
	text-align: center;
}

.sec_title01 p {
	font-size: 17px;
	color: #e6b532;
	line-height: 1;
	margin-bottom: 20px;
	font-weight: 500;
}

.sec_title01 h2 {
	font-size: 34px;
	letter-spacing: 4px;
	line-height: 1.3;
	color: #224eb2;
}

.btn01 a {
	display: block;
	max-width: 280px;
	width: 100%;
	background: #224eb2;
	box-sizing: border-box;
	padding: 20px 20px;
	font-size: 19px;
	line-height: 1.1;
	letter-spacing: 2px;
	color: #fff;
	text-align: center;
	font-weight: 400;
	transition: .3s;
}

.btn01 a img {
	float: right;
	position: relative;
	top: 5px;
}

.btn01 a:hover {
	background: #e6b532;
}




.top02 {padding-bottom: 130px;}

.top02_left {
	float: left;
	max-width: 620px;
	width: 46%;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .3s;
	position: relative;
}
.top02.show .top02_left {
	transform: translateY(0);
	opacity: 1;
}

.top02_left img {
	object-fit: cover;
	width: 100%;
	height: 436px;
}


.top02_icon {
	width: 156px;
	height: 156px;
	position: absolute;
	top: -40px;
	left: -40px;
	z-index: 100;
}

.top02_icon01 {
	width: 100% !important;
	height: 100% !important;
	display: block;
	animation: rotateAnimation 18s linear infinite;
}


@keyframes rotateAnimation {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}



.top02_right {
	float: right;
	max-width: 650px;
	width: 48%;
	box-sizing: border-box;
	padding: 80px 0 0 70px;
	position: relative;
	overflow: hidden;
}

.top02_right_in {
	max-width: 530px;
}

.top02_right_in h3 {
	font-size: 24px;
	letter-spacing: 2px;
	line-height: 1.7;
	display: block;
	margin-bottom: 60px;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .4s;
}
.top02.show .top02_right_in h3 {
	transform: translateY(0);
	opacity: 1;
}

.top02_right_in h3 span {
	letter-spacing: 2px;
	font-size: 1em;
	color: #224eb2;
}

.top02_right_in .btn01 {
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .5s;
}

.top02.show .top02_right_in .btn01 {
	transform: translateY(0);
	opacity: 1;
}

.top02_bg_text {
	position: absolute;
	top: 10px;
	left: 0;
	z-index: -1;
}

.top02_bg_text span {
	display: inline-block;
	font-size: 140px;
	color: #e8ecf5;
	font-weight: 900;
	font-style: italic;
	letter-spacing: 0;
	line-height: 1;
	transform: translateX(300px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .5s;
}

.top02_bg_text span:nth-of-type(2) {transition-delay: .6s;}
.top02_bg_text span:nth-of-type(3) {transition-delay: .7s;}
.top02_bg_text span:nth-of-type(4) {transition-delay: .8s;}
.top02_bg_text span:nth-of-type(5) {transition-delay: .9s;}
.top02_bg_text span:nth-of-type(6) {transition-delay: 1s;}
.top02_bg_text span:nth-of-type(7) {transition-delay: 1.1s;}

.top02.show .top02_bg_text span {
	transform: translateX(0);
	opacity: 1;
}












.b_contact {
	padding: 90px 0;
	position: relative;
	overflow-x: hidden;
}

.b_contact::before {
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	background: #fff;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	transition: all 1.2s cubic-bezier(0.6, 0.2, 0.1, 1) 0s;
	transition-delay: .7s;
}

.b_contact.show::before {
	transform: translateX(120%);
}

.b_contact::after {
	display: block;
	content: "";
	background-image: url("images/top/b_contact_bg.jpg");
	background-repeat: no-repeat;
	background-position: left top;
	background-size: cover;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -10;
	width: 100%;
	height: 100%;
}



.b_contact_in {
	max-width: 1080px;
	width: 90%;
	margin: auto;
}

.sec_title02 {
	margin-bottom: 40px;
	text-align: center;
}

.sec_title02 p {
	font-size: 17px;
	color: #e6b532;
	line-height: 1;
	margin-bottom: 15px;
}

.sec_title02 h2 {
	font-size: 32px;
	letter-spacing: 4px;
	line-height: 1.3;
	color: #fff;
}

.b_contact_text {
	font-size: 17px;
	line-height: 1.8;
	text-align: center;
	margin-bottom: 40px;
	color: #fff;
}

.b_contact_left a {
	display: block;
	max-width: 520px;
	width: 100%;
	margin: 0 auto;
	box-sizing: border-box;
	text-align: center;
	padding: 18px 10px 16px;
	background: #fff;
	border: solid 1px #224eb2;
	transform: translateY(200px);
	opacity: 0;
	transition: all 1s;
	transition-delay: .5s;
}

.b_contact.show .b_contact_left a {
	transform: translateY(0);
	opacity: 1;
}

.b_contact_left a h3 {
	font-size: 16px;
	line-height: 1.3;
	color: #224eb2;
}

.b_contact_left a h4 {
	font-size: 32px;
	line-height: 1.3;
	color: #224eb2;
	font-weight: 500;
}

.b_contact_left a h4 span {
	font-size: 0.8em;
	color: #224eb2;
	margin-right: 5px;
	font-weight: 500;
}

.b_contact_left a p {
	font-size: 13px;
	letter-spacing: 0;
}






/* ----------------------------------------------------

    footer

---------------------------------------------------- */



footer {
	box-sizing: border-box;
	padding: 100px 0 0;
	background: #333;
	position: relative;
	
}


.footer_in {
	width: 88%;
	margin: auto;
	overflow: hidden;
	padding-bottom: 60px;
}

.footer_left {
	max-width: 400px;
	width: 32%;
	float: left;
}

.footer_right {
	max-width: 500px;
	width: 64%;
	float: right;
	overflow: hidden;
}

.footer_left h2 {
	margin-bottom: 25px;
}

.footer_left h3 {
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 2px;
	line-height: 1.2;
	color: #fff;
	margin-bottom: 6px;
}

.footer_left p {
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 2px;
	line-height: 1.7;
	color: #fff;
}

.footer_left p a {
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 2px;
	line-height: 1.7;
	color: #fff;
}

.footer_left p a:hover {
	text-decoration: underline;
}

.f_nav {
	margin-bottom: 30px;
	overflow: hidden;
}

.f_nav_left {
	float: left;
	max-width: 326px;
	width: 50%;
}

.f_nav_right {
	float: right;
	max-width: 200px;
	width: 48%;
}

.f_nav h3 {
	font-size: 20px;
	font-weight: 500;
	color: #6393fd;
	line-height: 1.3;
	margin-bottom: 20px;
}

.f_nav li {
	list-style: none;
	margin-bottom: 20px;
}



.f_nav li a {
	font-size: 17px;
	font-weight: 400;
	letter-spacing: 3px;
	line-height: 1.3;
	color: #6393fd;
}

.f_nav li a:hover {
	color: #e6b532;
	text-decoration: underline;
}

.f_nav li a i {
	display: inline-block;
	text-align: center;
	color: #6393fd;
	font-size: 18px;
	box-sizing: border-box;
	margin-right: 10px;
	line-height: 1;
	padding: 1px 0 0 2px;
}

.footer_right_bottom {
	float: right;
	width: 100%;
}

.pagetop {padding-top: 50px;}

.pagetop a {
	display: block;
	width: 80px;
	height: 80px;
	position: relative;
	text-align: center;
	float: right;
	box-sizing: border-box;
	transition: .2s;
}

.pagetop a img {

}


.pagetop a:hover {
	transform: translateY(-10px);
}


.footer_bottom {
	width: 100%;
	box-sizing: border-box;
	padding: 25px;
	border-top: solid 1px #6393fd;
}

.f_copy {
	font-size: 12px;
	line-height: 1.4;
	letter-spacing: 2px;
	color: #6393fd;
	text-align: center;
}













/* ----------------------------------------------------

    recruit

---------------------------------------------------- */


.recruit01 {padding: 20px 0 100px;}



.table01_wrap dl {
	display: table;
	width: 100%;
}

.table01_wrap dt {
	display: table-cell;
	width: 24%;
	box-sizing: border-box;
	border-top: solid 1px #224eb2;
	padding: 20px;
	font-size: 16px;
	letter-spacing: 2px;
	vertical-align: top;
}

.table01_wrap dd {
	display: table-cell;
	width: 75%;
	padding-left: 1%;
	vertical-align: middle;
}

.table01_wrap dd span {
	border-top: solid 1px #ddd;
	padding: 20px;
	font-size: 16px;
	letter-spacing: 2px;
	width: 100%;
	display: inline-block;
	box-sizing: border-box;
	color: #555;
}

.table01_wrap dd span a {
	font-size: 16px;
	letter-spacing: 2px;
}

.table01_wrap dd span a:hover {
	color: #dccd59;
}

.table01_wrap dl:last-of-type dt {
	border-bottom: solid 1px #224eb2;
}

.table01_wrap dl:last-of-type dd span {
	border-bottom: solid 1px #ddd;
}

.recruit01_b_text {padding-top: 70px;}
.recruit01_b_text h4 {
	font-size: 20px;
	letter-spacing: 2px;
	line-height: 1.7;
	text-align: center;
}

.recruit02 {padding-bottom: 110px;}




@media screen and ( max-width:991px ){
	.table01_wrap dt {font-size: 15px; letter-spacing: 1px;}
	.table01_wrap dd span {font-size: 15px; letter-spacing: 1px;}
	
	.recruit01 {padding: 30px 0 70px;}
	.recruit01_b_text h4 {font-size: 18px;}

}

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

	.table01_wrap dt {width: 25%;font-size: 14px;}
	.table01_wrap dd {width: 75%;padding-left: 0;}
	.table01_wrap dd span {font-size: 14px;}
	
	.recruit01_b_text h4 {font-size: 17px; letter-spacing: 1px;}
	.recruit01_b_text {padding-top: 50px;}
}

@media screen and ( max-width:567px ){
	
	.table01_wrap dt {width: 100px;font-size: 14px;padding: 15px 7px;}
	.table01_wrap dd {width: auto;padding-left: 0;	}	
	.table01_wrap dd span {font-size: 14px;padding: 15px;}

	.recruit01_b_text h4 {font-size: 16px; text-align: left;}
	.recruit01_b_text {padding-top: 40px;}
}

@media screen and ( max-width:450px ){
	.table01_wrap dd span a {font-size: 13px;letter-spacing: 0;}

}

@media screen and ( max-width:360px ){
	.table01_wrap dt {width: 32%;}	
	.table01_wrap dd {width: 68%;}
}





.recruit02 dl {
	display:table;
	width:100%;
	padding: 10px 0;
	margin-bottom: 10px;
}

.recruit02 dl dt {
	display:table-cell;
	width:26%;
	box-sizing:border-box;
	vertical-align:top;
	font-weight: 500;
	font-size: 15px;
	padding-top: 5px;
}

.recruit02 dl dt p {font-size: 16px;}

.recruit02 dl dd {
	display:table-cell;
	width:74%;
	box-sizing:border-box;
}

.input_dummy {
	width:500px;
	height:36px;
	box-sizing:border-box;
	background-color:#fff;
}

.textarea_dummy {
	width:500px;
	height:165px;
	box-sizing:border-box;
	background-color:#fff;
}

#zip {
    width: 200px;
}

.recruit02 .recruit02_in p {
	margin-bottom: 0;
}

.recruit02 .recruit02_in .required {
	color:#fff;
	background-color:#aa1d2f;
	margin: 0 10px 0 0;
	letter-spacing: 1px;
	font-size: 11px;
	padding: 2px 5px 2px;
}

.recruit02 .recruit02_in .required02 {
	display:block;
	padding-left: 31%;
	font-size:12px;
	color:#999;
    margin-bottom: -30px;
    margin-top: 10px;
	letter-spacing: 0;
	text-align: left;
}
.recruit02 .recruit02_in .required02 {
	padding-left: 0;
	margin-bottom: 3px;
}
.required2 {
    color: #fff;
    background-color: #aaa;
    font-size: 11px;
    padding: 2px 5px;
	margin: 0 10px 0 0;
	letter-spacing: 1px;
}

.yuubin .required02 {
    padding-left: 3%;
    display: inline;
}

.recruit02 input[type="text"] {
	font-size: 16px;
    padding: 14px;
	width: 100%;
	background: #fff;
	box-sizing: border-box;
	border: solid 1px #ccc;
}

.recruit02 input[type="email"] {
	font-size: 16px;
    padding: 14px;
	width: 100%;
	border: solid 1px #ccc;
	background: #fff;
	box-sizing: border-box;
}

.recruit02 input[type="tel"] {
	font-size: 16px;
    padding: 14px;
	width: 100%;
	border: solid 1px #ccc;
	background: #fff;
	box-sizing: border-box;
}

.recruit02 input[type="radio"] {
	margin-top: 0;
}

.recruit02 input[type="number"] {
	font-size: 16px;
    padding: 14px;
	width: 100px;
	border: solid 1px #ccc;
	background: #fff;
	box-sizing: border-box;
	margin: 0 5px 5px;
}

.recruit02 textarea {
	font-size: 16px;
    padding: 14px;
    width: 100%;
	border: solid 1px #ccc;
	background: #fff;
	box-sizing: border-box;
}

.recruit02 input[type="submit"] {
	max-width:400px;
	width: 80%;
	margin: 30px auto 0;
	box-sizing:border-box;
	display:block;
	text-align:center;
	background-color:#9e2224;
	color:#fff;
    padding: 18px 0;
	font-size: 17px;
	letter-spacing: 1px;
	cursor: pointer;
	border: none;
	border-radius: 40px;
	-webkit-appearance: none;
	transition: .3s;
}

.recruit02 input[type="submit"]:hover {
	background-color:#dccd59;
	transition: .3s;
	color: #222;
}

.wpcf7-list-item {
	margin-left: 0;
	margin-right: 3em;
}

.wpcf7-list-item span {
	font-size: 15px;
}


#zip_txt {
    font-size: 12px;
    padding-left: 7px;
    color: #999;
    line-height: 1.3em;
	letter-spacing: 0;
}



@media screen and ( max-width:767px ){
	.recruit02 dl {display: block;width: 100%;}
	.recruit02 dl dt {display: block;width: 100%;font-size: 14px;}
	.recruit02 dl dd {display: block;width: 100%;padding: 10px 0;}
	.wpcf7-list-item {display: block;width: 100%;margin-bottom: 4px;margin-right: 0;}
	.recruit02_in p.tc {text-align: left !important;}
	.recruit02 input[type="submit"] {font-size: 15px;}
}

@media screen and ( max-width:567px ){
	.recruit02 {padding-bottom: 60px;}
	.recruit02_in {padding-bottom: 10px;}
	.recruit02 dl dt p {font-size: 15px;}
	.recruit02 input[type="number"] {width: 70px; padding: 14px 8px;}
	.recruit03_text {font-size: 15px; letter-spacing: 1px; text-align: left; margin-bottom: 20px;}
}

@media screen and ( max-width:450px ){
	.recruit02 {padding-bottom: 70px;}
	.recruit02 dl {margin-bottom: 0;}
	
}








/* ----------------------------------------------------

    message

---------------------------------------------------- */

.message02 {min-height: 640px; margin-bottom: 110px;}
.message02 .top01_img img {height: 560px;}
.message02 .top01_bg {height: 540px; bottom: 0;}
.message02 .top01_in {padding-top: 170px;}

.message03 {min-height: 640px; margin-bottom: 110px;}
.message03 .top01_img img {height: 560px;}
.message03 .top01_bg {height: 540px; bottom: 0;}
.message03 .top01_in {padding-top: 170px; max-width: 550px;}

.message04 {margin-bottom: 100px; min-height: 670px;}
.message04 .top01_in {padding-top: 150px; max-width: 600px;}
.message04 .top01_bg {height: 570px; bottom: 0;}


.top01_in p span {font-weight: 600; font-size: 1em; color: #e6b020;}
.top01_in_box {
	box-sizing: border-box;
	padding: 25px 30px;
	background: #fff;
	margin: 15px 0;
}

.top01_in_box h3 {
	font-size: 22px;
	line-height: 1.2;
	color: #224eb2;
	display: block;
	margin-bottom: 10px;
}

.top01_in_box dl {
	display: table;
	width: 100%;
	margin-bottom: 7px;
}

.top01_in_box dt {
	display: table-cell;
	width: 1em;
	color: #224eb2;
	font-size: 20px;
	line-height: 1;
	vertical-align: top;
	position: relative;
    top: 1px;
}

.top01_in_box dd {
	display: table-cell;
	font-size: 17px;
	line-height: 1.3;
	vertical-align: top;
	box-sizing: border-box;
	padding-left: 5px;
}


.message05 {padding: 0 0 130px;}

.message05_title {
	display: block;
	font-size: 40px;
	text-align: center;
	color: #224eb2;
	line-height: 1.3;
	letter-spacing: 3px;
	margin-bottom: 30px;
}

.message05_text {
	font-size: 20px;
	line-height: 1.7;
	letter-spacing: 2px;
	display: block;
	margin-bottom: 50px;
	text-align: center;
}

.message05_in p {
	text-align: center;
	font-size: 16px;
	margin-bottom: 15px;
	display: block;
}

.message05 .bnr01 {position: static; margin: auto;}
.message05.show .bnr01 {
	transform: translateY(0);
    opacity: 1;
}

.message05 .bnr01 dd {background: #e6b532;}
.message05 .bnr01 dd p {
	color: #e6b532;
	background: #fff;
}

.message05 .bnr01 dd h3 {color: #fff;}
.message05 .bnr01 dd h4 {color: #fff;}






/* ----------------------------------------------------

    service

---------------------------------------------------- */

.service01 {padding-bottom: 120px;}

.service01_box {
	max-width: 1460px;
	width: 88%;
	margin: auto;
	position: relative;
}

.service01_img {
	object-fit: cover;
	width: 100%;
	height: 541px;
	object-position: left top;
}

.service01_img_bg {
	position: absolute;
	top: 0;
	right: 0;
	object-fit: cover;
	height: 541px;
	z-index: 1;
}

.service01_box_in {
	max-width: 1200px;
	width: 88%;
	margin: auto;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	box-sizing: border-box;
	padding-top: 120px;
}

.service01_box_in h2 {
	font-size: 50px;
	letter-spacing: 3px;
	line-height: 1.4;
	color: #f3bc29;
	display: block;
	margin-bottom: 100px;
	text-align: right;
}

.service01_box_in p {
	font-size: 17px;
	letter-spacing: 1px;
	line-height: 1.7;
	color: #fff;
	display: block;
	text-align: right;
	max-width: 590px;
	float: right;
}


.service_wrap {width: 100%; margin-bottom: 120px;}

.service_img {
	float: left;
	width: 48%;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .4s;
}

.service_wrap02 .service_img {float: right;}

.service_wrap.show .service_img {
	transform: translateY(0);
	opacity: 1;
}

.service_img img {
	object-fit: cover;
	width: 100%;
	height: 560px;
}

.service05 .service_img img {height: 440px;}
.service06 .service_img img {height: 440px;}

.service_text {
	float: right;
	width: 52%;
	box-sizing: border-box;
	padding-top: 40px;
}

.service_wrap02 .service_text {float: left;}

.service_text_in {
	max-width: 586px;
	width: 88%;
	margin: auto;
}

.service_text_in h2 {
	font-size: 40px;
	letter-spacing: 2px;
	line-height: 1.3;
	color: #224eb2;
	display: block;
	padding-bottom: 20px;
	margin-bottom: 20px;
	overflow: visible;
	box-sizing: border-box;
	position: relative;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .5s;
}

.service_wrap.show .service_text_in h2 {
	transform: translateY(0);
	opacity: 1;
}

.service_text_in h2::before {
	display: block;
	content: "";
	width: 0%;
	height: 1px;
	background: #224eb2;
	position: absolute;
	right: 0;
	bottom: 0;
	transition: all .8s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: 1s;
}

.service_wrap02 .service_text_in h2::before {right: auto; left: 0;}

.service_wrap.show .service_text_in h2::before {
	width: 150%;
}

.service_text_in h2::after {
	display: block;
	content: "";
	position: absolute;
    bottom: -6px;
    left: -50%;
    width: 13px;
    height: 13px;
    background: #224eb2;
    z-index: 20;
    border-radius: 50%;
    opacity: 0;
    transition: all .5s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: 1.7s;
}

.service_wrap02 .service_text_in h2::after {left: auto; right: -50%;}

.service_wrap.show .service_text_in h2::after {
	opacity: 1;
}

.service_text_in h2 span {
	display: inline-block;
	color: rgba(34,78,178,0.15);
	font-size: 150px;
	font-weight: 300;
	font-style: italic;
	line-height: 1;
	letter-spacing: 0;
	position: absolute;
	right: 0;
	bottom: -17px;
	transform: translateX(-70px);
	opacity: 0;
	transition: 1.2s;
	transition-delay: 1s !important;
}
.service_wrap.show .service_text_in h2 span {
	transform: translateX(0);
	opacity: 1;
}

.service_text_in p {
	font-size: 17px;
	letter-spacing: 1px;
	line-height: 1.7;
	display: block;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
}

.service_text01 {transition-delay: .6s !important;}
.service_text02 {transition-delay: .8s !important;}

.service_wrap.show .service_text_in p {
	transform: translateY(0);
	opacity: 1;
}

.service_text_in_box {
	border: solid 1px #224eb2;
	transform: translateY(50px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .7s;
}

.service_wrap.show .service_text_in_box {
	transform: translateY(0);
	opacity: 1;
}

.service07 {padding-bottom: 120px;}

.service07_dl01 {
	display: table;
	width: 100%;
	margin-bottom: 50px;
}

.service07_dl01 > dt {
	display: table-cell;
	width: 540px;
	box-sizing: border-box;
	vertical-align: top;
	padding: 60px 0 55px;
	position: relative;
	padding-right: 80px;
}

.service07_dl01 > dt img {
	position: absolute;
	top: 0;
	left: 15%;
	z-index: -1;
	transform: translateX(-100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .8s;
}

.service07.show .service07_dl01 > dt img {
	transform: translateX(0);
	opacity: 1;
}

.service07_dl01 > dt::before {
	display: block;
	content: "";
	width: 0;
	height: 1px;
	background: #224eb2;
	position: absolute;
	top: 110px;
	left: 88%;
	z-index: 1;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: 1.3s;
}

.service07.show .service07_dl01 > dt::before {
	width: 70px;
}

.service07_dl01 > dd {
	display: table-cell;
	box-sizing: border-box;
	vertical-align: top;
	padding-left: 4%;
	padding-top: 90px;
}

.service07_dl01 > dt p {
	font-size: 95px;
	color: #224eb2;
	line-height: 1;
	font-weight: 900;
	font-style: italic;
	letter-spacing: 0;
	margin-bottom: 20px;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .3s;
}

.service07.show .service07_dl01 > dt p {
	transform: translateY(0);
	opacity: 1;
}

.service07_dl01 > dt h2 {
	font-size: 20px;
	letter-spacing: 2px;
	line-height: 1.3;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .4s;
}
.service07.show .service07_dl01 > dt h2 {
	transform: translateY(0);
	opacity: 1;
}

.service07_in_box {
	margin-bottom: 40px;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .7s;
}
.service07_in_box:nth-of-type(2) {transition-delay: .8s;}
.service07_in_box:nth-of-type(3) {transition-delay: .9s;}

.service07.show .service07_in_box {
	transform: translateY(0);
	opacity: 1;
}


.service07_in_box dl {
	display: table;
	width: 100%;
	margin-bottom: 15px;
}

.service07_in_box dt {
	display: table-cell;
	width: 50px;
	font-size: 30px;
	padding: 3px 0;
	line-height: 1;
	letter-spacing: 0;
	font-weight: 500;
	color: #224eb2;
	border-right: solid 1px #224eb2;
	vertical-align: top;
}

.service07_in_box dd {
	display: table-cell;
	box-sizing: border-box;
	padding-left: 18px;
	font-size: 30px;
	letter-spacing: 3px;
	line-height: 1.3;
	color: #224eb2;
}

.service07_in_box p {
	font-size: 17px;
	letter-spacing: 2px;
	line-height: 1.5;
}

.service07_bottom {
	box-sizing: border-box;
	max-width: 940px;
	width: 100%;
	margin: auto;
	border: solid 2px #224eb2;
	padding: 40px 30px;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: 1.2s;
}

.service07.show .service07_bottom {
	transform: translateY(0);
	opacity: 1;
}

.service07_bottom p {
	text-align: center;
	font-size: 24px;
	line-height: 1.6;
	letter-spacing: 2px;
}

.highlight {
	margin: 0 4px;
    text-decoration: underline;
    text-decoration-thickness: 0.5em;
    text-decoration-color: #fcdb80;
    text-underline-offset: -0.2em;
    text-decoration-skip-ink: none;
    font-weight: 500;
    font-size: 1em;
}






/* ----------------------------------------------------

    company

---------------------------------------------------- */

.company01 {padding: 40px 0 30px;}

.mvv_box {
	display: table;
	width: 100%;
	margin-bottom: 50px;
}

.mvv_title {
	float: left;
	width: 44%;
	max-width: 520px;
	box-sizing: border-box;
	vertical-align: top;
	padding: 60px 0 55px;
	position: relative;
	padding-right: 80px;
}

.mvv_box02 .mvv_title {float: right; padding-left: 80px; padding-right: 0;}

.mvv_title img {
	position: absolute;
	top: 0;
	left: 15%;
	z-index: -1;
	transform: translateX(-100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .8s;
}

.mvv_box02 .mvv_title img {left: 25%;}

.mvv_box.show .mvv_title img {
	transform: translateX(0);
	opacity: 1;
}
.company03.show .mvv_title img {
	transform: translateY(0);
	opacity: 1;
}

.mvv_title::before {
	display: block;
	content: "";
	width: 0;
	height: 1px;
	background: #224eb2;
	position: absolute;
	top: 110px;
	left: 88%;
	z-index: 1;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: 1.3s;
}

.mvv_box02 .mvv_title::before {right: 88%; left: auto;}

.mvv_box.show .mvv_title::before {
	width: 70px;
}

.mvv_text {
	float: right;
	width: 54%;
	box-sizing: border-box;
	vertical-align: top;
	padding-top: 70px;
}

.mvv_box02 .mvv_text {float: left;}

.mvv_title p {
	font-size: 95px;
	color: #224eb2;
	line-height: 1;
	font-weight: 900;
	font-style: italic;
	letter-spacing: 0;
	margin-bottom: 20px;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .3s;
}

.mvv_box.show .mvv_title p {
	transform: translateY(0);
	opacity: 1;
}
.company03.show .mvv_title p {
	transform: translateY(0);
	opacity: 1;
}

.mvv_title h2 {
	font-size: 20px;
	letter-spacing: 2px;
	line-height: 1.3;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .4s;
}
.mvv_box.show .mvv_title h2 {
	transform: translateY(0);
	opacity: 1;
}
.company03.show .mvv_title h2 {
	transform: translateY(0);
	opacity: 1;
}

.mvv_box02 .mvv_title h2 {padding-left: 20px;}

.mvv_text h3 {
	font-size: 56px;
	font-weight: 300;
	letter-spacing: 4px;
	line-height: 1.3;
	color: #224eb2;
	display: block;
	margin-bottom: 20px;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .6s;
}
.mvv_box.show .mvv_text h3 {
	transform: translateY(0);
	opacity: 1;
}

.mvv_box02 .mvv_text h3 {font-size: 34px; letter-spacing: 2px;}

.mvv_text p {
	font-size: 17px;
	letter-spacing: 2px;
	line-height: 1.7;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .7s;
}

.mvv_box.show .mvv_text p {
	transform: translateY(0);
	opacity: 1;
}



.company03 {padding: 60px 0 80px;}

.company03_in {
	max-width: 1560px;
	width: 88%;
	margin: auto;
}

.company03_in .mvv_title {
	float: none; 
	max-width: 340px;
	width: 100%;
	margin: 0 auto 50px;
	padding-right: 0;
}

.company03_in .mvv_title::before {display: none;}

.company03_in .mvv_title h2 {text-align: center;}

.value_box {
	float: left;
	width: 23%;
	margin: 0 1% 35px;
	box-sizing: border-box;
	padding: 30px 40px 10px;
	min-height: 380px;
	border: solid 1px #224eb2;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.6, 0.2, 0.1, 1);
	transition-delay: .5s;
}
.value_box:nth-of-type(2) {transition-delay: .6s;}
.value_box:nth-of-type(3) {transition-delay: .7s;}
.value_box:nth-of-type(4) {transition-delay: .8s;}
.value_box:nth-of-type(5) {transition-delay: .9s;}
.value_box:nth-of-type(6) {transition-delay: 1s;}
.value_box:nth-of-type(7) {transition-delay: 1.1s;}
.value_box:nth-of-type(8) {transition-delay: 1.2s;}

.company03.show .value_box {
	transform: translateY(0);
	opacity: 1;
}

.value_box h4 {
	font-size: 20px;
	font-weight: 600;
	font-style: italic;
	color: #224eb2;
	line-height: 1;
	letter-spacing: 0;
	text-align: center;
	display: block;
	margin-bottom: 20px;
}

.value_box h4 span {
	font-size: 1.8em;
	font-weight: 500;
	font-style: italic;
	color: #224eb2;
	line-height: 1;
	letter-spacing: 0;
	padding-left: 5px;
	position: relative;
	top: 4px;
}

.value_box h3 {
	font-size: 28px;
	color: #224eb2;
	line-height: 1.4;
	display: block;
	text-align: center;
	max-width: 240px;
	margin: 0 auto 20px;
}

.value_box p {
	font-size: 16px;
	line-height: 1.6;
}

.company04 {
	padding: 90px 0;
	background: #f5f5f5;
}

.company05 {
	padding: 90px 0;
}

.company05_in iframe {filter: grayscale(0.3);}






/* ----------------------------------------------------

    メディアクエリ

---------------------------------------------------- */


.max1366 {display: none !important;}
.min1367 {display: block !important;}
.max1279 {display: none !important;}
.min1280 {display: block !important;}
.max1199 {display: none !important;}
.min1200 {display: block !important;}
.max991 {display: none !important;}
.min992 {display: block !important;}
.max767 {display: none !important;}
.min768 {display: block !important;}
.max567 {display: none !important;}
.min568 {display: block !important;}
.max428 {display: none !important;}
.min429 {display: block !important;}
.max360 {display: none !important;}
.min361 {display: block !important;}


@media screen and ( min-width:1921px ){
	
}


@media screen and ( max-width:1680px ){
	.service_wrap.show .service_text_in h2::before {width: 140%;}
	.service_text_in h2::after {left: -40%}
	.service_wrap02 .service_text_in h2::after {right: -40%;}
	.service_text_in h2 span {font-size: 120px; bottom: -13px;}
	.service_img img {height: 520px;}
	.service_text_in p {font-size: 16px;}
}

@media screen and ( max-width:1536px ){
	.h_main_text h2 {font-size: 28px;}
	.h_main_text h3 {font-size: 15px;}
	.h_main_text_bg {max-width: 430px; bottom: 24%;}
	.h_main_text {bottom: 10%;}
	
	.top01_in h4 {margin-bottom: 110px;}
	.top01_in h2 {font-size: 31px; letter-spacing: 2px;}
	.top01_in p {font-size: 16px; letter-spacing: 1px;}
	.top01_in {max-width: 480px;}
	.top01 .sec_in1200 {max-width: 1100px; width: 80%;}
	
	.page_main_img img {height: 480px;}
	.page_main_filter img {height: 480px;}
	.page_main_text {top: 39%;}
	
	.value_box h4 {font-size: 17px;}
	.value_box {padding: 25px 30px 10px;}
	.value_box h3 {font-size: 26px;}
}

@media screen and ( max-width:1366px ){
	.max1366 {display: block !important;}
	.min1367 {display: none !important;}
	
	.footer_left {width: 36%;}
	.footer_right {width: 62%;}
	.footer_left h3 {font-size: 18px; margin-bottom: 10px;}
	.footer_left p {font-size: 13px; letter-spacing: 1px; line-height: 1.5;}
	.f_nav li a {letter-spacing: 1px; font-size: 14px;}
	.f_nav li a i {width: 18px; height: 18px; font-size: 13px; position: relative; bottom: 1px;}
	
	.header_top {height: 80px;}
	.h_logo a {max-width: 160px; padding-top: 18px;}
	.header_top nav li a {font-size: 15px; padding-bottom: 27px;}
	.header_top nav {padding-top: 28px; padding-right: 80px;}
	ul.child {top: 80px; padding: 7px 6px 5px;}
	ul.child li a img {width: 120px;}
	ul.child li a {font-size: 13px !important;}
	
	.h_main_text h2 {font-size: 24px; margin-bottom: 0;}
	.h_main_text h3 {font-size: 14px;}
	.h_main_text_bg {max-width: 360px; bottom: 21%; left: 4%;}
	.h_main_text {bottom: 7%; left: 12%;}
	
	.top01_img img {height: 540px;}
	.top01 .bnr01 {bottom: 40px;}
	
	.top02_right_in h3 {font-size: 20px; letter-spacing: 1px;}
	.top02_right_in h3 span {letter-spacing: 1px;}
	.btn01 a {font-size: 17px;}
	.top02_bg_text span {font-size: 100px;}
	.top02_right {padding: 60px 0 0 60px;}
	.top02_left img {height: 360px;}
	.top02_icon {width: 120px; height: 120px; top: -30px; left: -30px;}
	
	
	.page_main_img img {height: 440px;}
	.page_main_filter img {height: 440px;}
	.page_main_text {top: 39%;}
	
	
	.message02 .top01_img img {height: 430px;}
	.message03 .top01_img img {height: 430px;}
	.message02 {min-height: 540px;}
	.message03 {min-height: 510px;}
	.message04 {min-height: 620px;}
	.message02 .top01_in {padding-top: 120px;}
	.message03 .top01_in {padding-top: 120px; width: 48%;}
	.message04 .top01_in {padding-top: 100px; width: 48%;}
	.message02 .top01_bg {height: 480px;}
	.message03 .top01_bg {height: 460px;}
	.message04 .top01_bg {height: 560px;}
	.message02 .top01_in h2,.message03 .top01_in h2,.message04 .top01_in h2 {margin-bottom: 30px;}
	.message03 .sec_in1360 {max-width: 1000px;}
	.message04 .sec_in1360 {max-width: 1000px;}
	.message02 .top01_in p, .message03 .top01_in p, .message04 .top01_in p {line-height: 1.6;}
	
	.message05 {padding-bottom: 100px;}
	.message05_title {font-size: 32px; letter-spacing: 2px;}
	.message05_text {font-size: 18px;}
	
	.sec_title01 {margin-bottom: 60px;}
	
	.service01_img {height: 440px;}
	.service01_img_bg {height: 440px;}
	.service01_box_in {padding-top: 60px;}
	.service01_box_in h2 {font-size: 40px; letter-spacing: 2px;}
	.service01_box_in p {font-size: 16px; max-width: 550px;}
	
	.service_wrap.show .service_text_in h2::before {width: 124%;}
	.service_text_in h2::after {left: -24%}
	.service_wrap02 .service_text_in h2::after {right: -24%;}
	.service_text_in h2 span {font-size: 110px; bottom: -10px;}
	.service_text_in h2 {font-size: 34px;}
	
	.service07_in {margin-bottom: 40px;}
	.service07_dl01 {max-width: 950px; margin: auto;}
	.service07_dl01 > dt {width: 430px;}
	.service07_dl01 > dt p {font-size: 75px;}
	.service07_dl01 > dt h2 {font-size: 18px; letter-spacing: 1px;}
	.service07_dl01 > dt img {left: 5%;}
	.service07_in_box {margin-bottom: 30px;}
	.service07_in_box dl {margin-bottom: 6px;}
	.service07_in_box dd {font-size: 28px; letter-spacing: 1px;}
	.service07_in_box dt {width: 44px; font-size: 28px;}
	.service07_in_box p {font-size: 16px; letter-spacing: 1px;}
	
	.mvv_title {width: 40%; max-width: 440px; padding: 40px 0;}
	.mvv_title p {font-size: 80px;}
	.mvv_title h2 {font-size: 17px; letter-spacing: 1px;}
	.mvv_text h3 {font-size: 44px;}
	.mvv_box02 .mvv_text h3 {font-size: 28px;}
	.company03_in .mvv_title p {text-align: center;}
	.mvv_title img {width: 160px; left: 25%;}
	.mvv_title::before {top: 85px;}
	.mvv_text {padding-top: 54px;}
	.company03 {padding: 20px 0 70px;}
	.mvv_text p {font-size: 16px; letter-spacing: 1px;}
	.company01 .sec_in1360, .company02 .sec_in1360 {width: 84%;}
}

@media screen and ( max-width:1280px ){
	.max1279 {display: block !important;}
	.min1280 {display: none !important;}
	
	.value_box h3 {font-size: 23px; line-height: 1.3;}
	.value_box h3 br {display: none;}
	.value_box:nth-of-type(1) h3 br {display: block;}
	.value_box {padding: 25px 20px 10px; margin: 0 1% 25px;}
	.value_box p {font-size: 15px; line-height: 1.5;}

}

@media screen and ( max-width:1200px ){
	.max1199 {display: block !important;}
	.min1200 {display: none !important;}
	
	.top01_in h4 {margin-bottom: 110px;}
	.top01_in h2 {margin-bottom: 40px;}
	.top01_in p {line-height: 1.6;}
	.bnr01 {max-width: 500px;}
	.bnr01 dd p {font-size: 12px;}
	.bnr01 dd h3 {font-size: 22px;}
	.bnr01 dd h4 {font-size: 10px; letter-spacing: 1px;}
	.top03_bnr_wrap {width: 90%;}
	
	.company01 {padding-bottom: 0;}
	.mvv_title p {font-size: 70px;}
	.mvv_box.show .mvv_title::before {width: 60px;}
	.mvv_title img {width: 150px; left: 15%;}
	.company03 .mvv_title img {left: 25%;}
	.mvv_text h3 {font-size: 38px;}
	.mvv_box02 .mvv_text h3 {font-size: 24px;}
	.mvv_title h2 {font-size: 16px;}
	.mvv_box02 .mvv_title h2 {padding-left: 10px;}
	
}

@media screen and ( max-width:991px ){
	.max991 {display: block !important;}
	.min992 {display: none !important;}
	
	.sp_menu {float: none; width: 100%;}
	.sp_menu_in h2 {margin-bottom: 8vh;}
	
	.footer_left {float: none; width: 100%; margin: 0 auto 60px; max-width: 330px; text-align: center;}
	.footer_right {float: none; width: 100%; margin: 0 auto;}
	.footer_right_bottom {float: none; margin: auto;}
	.f_copy {font-size: 11px; letter-spacing: 1px;}
	
	.header_main {padding-top: calc(1920 / 1920 * 100%); overflow: hidden;}
	.h_main_text_bg {width: 70%; left: 0; right: 0; bottom: 41%; margin: auto; max-width: 460px;}
	.h_main_text {bottom: 4%; left: 0; max-width: 405px; right: 0; margin: auto;}
	
	.top01_img {position: static; width: 100% !important;}
	.bnr01 {position: static; width: 86%; margin: auto;}

	.bnr01 dt {width: 160px;}
	.bnr01 dt img {height: 160px;}
	.bnr01 dd {padding-top: 10px;}
	.bnr01 dd p {font-size: 12px;}
	.bnr01 dd h3 {font-size: 22px; letter-spacing: 3px;}
	.top01 {background: #d3dcf0; margin: 0; padding-bottom: 80px;}
	.top01_in {width: 100%; float: none; max-width: 100%; padding-top: 70px;}
	.top01_bg {display: none;}
	.top01_in h4 {margin-bottom: 20px; font-size: 15px;}
	.top01_in h2 {margin-bottom: 25px;}
	.top01_img img {height: 480px;}
	.top01 .sec_in1200 {margin-bottom: 40px;}
	.top03 .top01_in {float: none;}
	.top03_bnr_wrap {position: static; width: 100%;}
	.top03_in_text {margin-bottom: 40px;}
	.top03 {background: #f5f5f5;}
	
	.top02 {padding: 60px 0 80px;}
	.top02_right_in h3 {font-size: 18px; margin-bottom: 40px;}
	.top02_bg_text span {font-size: 80px;}
	.top02_right {padding: 50px 0 0 40px;}
	.top02_left img {height: 310px;}
	
	.b_contact {padding: 60px 0;}
	.b_contact_text {font-size: 16px; margin-bottom: 30px;}
	.sec_title02 {margin-bottom: 30px;}
	.sec_title02 h2 {font-size: 26px; letter-spacing: 2px;}
	.sec_title02 p {font-size: 15px;}
	.b_contact_left a {max-width: 400px;}
	.b_contact_left a h4 {font-size: 27px;}
	.b_contact_left a p {font-size: 12px;}
	
	.f_nav {max-width: 260px; margin: auto;}
	.f_nav h3 {font-size: 16px;}
	.f_nav li a i {margin-right: 2px;}
	.f_nav_right {width: 112px;}
	
	.pagetop a {width: 60px; height: 60px;}
	
	.page_main_filter {width: 100%;}
	.page_main_text {top: 32%;}
	
	.sec_title01 {margin-bottom: 50px;}
	.sec_title01 p {font-size: 15px; margin-bottom: 15px;}
	.sec_title01 h2 {font-size: 30px;}
	
	.message02 .top01_in {padding-top: 60px;}
	.message03 .top01_in {width: 100%; padding-top: 60px; max-width: 100%;}
	.message04 .top01_in {width: 100%; padding-top: 60px; max-width: 100%;}
	.message02 {padding-bottom: 60px;}
	.message03 {padding-bottom: 60px;}
	.message04 {padding-bottom: 60px;}
	.message02 .sec_in1200 {margin-bottom: 0;}
	
	.message05 {padding: 60px 0 70px;}
	.message03 .sec_in1360 {width: 80%;}
	.message04 .sec_in1360 {width: 80%;}
	
	.service01 {padding-bottom: 70px;}
	.service01_img {height: 400px;}
	.service01_img_bg {height: 400px;}
	.service01_box_in {padding-top: 50px;}
	.service01_box_in h2 {font-size: 32px; letter-spacing: 1px; margin-bottom: 140px;}
	.service01_box_in p {font-size: 15px; max-width: 520px;}
	
	.service_wrap {margin-bottom: 0;background: #f5f5f5;}
	.service_img {float: none; width: 100%; margin: 0 auto;}
	.service_text {float: none; width: 100%; padding: 60px 0;}
	.service_img img {height: 440px;}
	.service_wrap.show .service_text_in h2::before {display: none;}
	.service_text_in {max-width: 650px;}
	.service_text_in h2::after {display: none;}
	.service_text_in h2 {padding-bottom: 0;}
	.service_text_in h2 span {font-size: 80px;}
	
	.service07 {padding: 50px 0 70px;}
	.service07_dl01 > dt {width: 290px; padding: 30px 0 35px;}
	.service07_dl01 > dt p {font-size: 55px; margin-bottom: 10px;}
	.service07_dl01 > dt h2 {font-size: 16px; letter-spacing: 1px;}
	.service07_dl01 > dt img {left: 5%; width: 110px;}
	.service07_dl01 > dt::before {top: 60px; left: 91%;}
	.service07.show .service07_dl01 > dt::before {width: 40px;}
	.service07_dl01 > dd {padding-top: 44px;}
	.service07_dl01 {max-width: 730px;}
	.service07_in_box p {font-size: 15px;}
	.service07_bottom {padding: 30px;}
	.service07_bottom p {font-size: 18px; letter-spacing: 1px; display: block; max-width: 640px; margin: auto;}
	
	.mvv_title {float: none; width: 100%; margin: 0 auto 30px; text-align: center; padding: 20px 0;}
	.mvv_text {float: none; width: 100%; padding-top: 10px;}
	.mvv_title p {margin-bottom: 10px;}
	.mvv_title::before {display: none;}
	.mvv_title img {left: 0 !important; right: 0 !important; margin: auto; width: 120px;}
	.mvv_box02 .mvv_title {float: none; padding-left: 0; }
	.mvv_text h3 {font-size: 30px; letter-spacing: 2px;}
	
	.value_box {width: 31.3%; margin: 0 1% 20px; min-height: 330px;}
	.value_box h4 {font-size: 15px;}
	
	.company05 {padding: 70px 0;}
}

@media screen and ( max-width:767px ){
	.max767 {display: block !important;}
	.min768 {display: none !important;}
	
	.top01_img img {height: 360px;}
	
	.top03_bnr_wrap .bnr01 {float: none !important; width: 100%; margin: 0 auto 20px;}
	
	.top02_left {float: none; width: 100%; margin: 0 auto 10px;}
	.top02_right {float: none; width: 100%; margin: 0 auto; padding: 40px 30px 0; max-width: 100%;}
	.top02_right_in {max-width: 100%;}
	.top02_right_in h3 {margin-bottom: 30px;}
	.top02_icon {left: 20px;}
	
	.message01 {padding-top: 20px;}
	.message02 .top01_img img {height: 360px;}
	.message03 .top01_img img {height: 360px;}
	.message04 .top01_img img {height: 360px;}
	
	.service01 {padding-top: 20px;}
	.service01_img {height: 600px;}
	.service01_img_bg {height: 600px;}
	.service01_box_in {padding-top: 50px;}
	.service01_box_in h2 {font-size: 28px; letter-spacing: 1px; margin-bottom: 360px;}
	.service01_box_in p {font-size: 14px; max-width: 500px;}
	
	.service_img img {height: 380px !important;}
	.service_text {padding: 50px 0;}
	
	.service07_dl01 > dt {display: block; width: 100%; max-width: 270px; margin: 0 auto 30px;}
	.service07_dl01 > dd {display: block; width: 100%; padding: 0; max-width: 340px; margin: auto;}
	.service07_dl01 > dt::before {display: none;}
	.service07_in_box dd {font-size: 25px; padding-left: 10px;}
	.service07_in_box dt {width: 38px;font-size: 25px;}
	
	.company01 {padding: 10px 0 30px;}
	.mvv_title {margin: 0 auto 20px;}
	.mvv_title p {font-size: 50px; }
	.mvv_title h2 {font-size: 14px;}
	.mvv_title img {width: 90px;}
	.mvv_text h3 {font-size: 26px; letter-spacing: 1px;}
	.mvv_box02 .mvv_text h3 {font-size: 22px; letter-spacing: 1px;}
	.mvv_text p {font-size: 15px;}
	
	.value_box {width: 46%; margin: 0 2% 20px; min-height: 300px;}
	.company04 {padding: 60px 0;}
	
	.company05 {padding: 50px 0;}
	.company05_in iframe {height: 340px;}
}

@media screen and ( max-width:567px ){
	.max567 {display: block !important;}
	.min568 {display: none !important;}
	
	.main_img .max991 {display: none !important;}
	.header_main {padding-top: calc(2400 / 1580 * 100%);}
	.h_main_text_bg {width: 80%; bottom: 38%;}
	.h_main_text h2 {font-size: 20px;}
	.h_main_text h2 span {font-size: 27px;}
	.h_main_text h3 {font-size: 13px; letter-spacing: 0;}
	.h_main_text {max-width: 314px; width: 96%; }
	.h_main_text h3 br {display: none;}
	
	.top01_img img {height: 260px;}
	.top01_in h2 {font-size: 26px; letter-spacing: 2px;}
	
	.bnr01 dt img {height: 120px;}
	.bnr01 dt {width: 120px;}
	.bnr01 dd {padding-top: 0;}
	.bnr01 dd h3 {margin-bottom: 15px;}
	.bnr01 dd p {font-size: 11px; margin-bottom: 10px;}
	.top01 .sec_in1200 {width: 86%;}
	.top01_in p {font-size: 16px;}
	.top01_in h4 {font-size: 13px;}
	.top01_in h2 {font-size: 25px;}
	
	.top01 {padding-bottom: 60px;}
	.top01_in h4::before {width: 30px;}
	.top01_in h4 {padding-left: 40px;}
	.top01_in {padding-top: 50px;}
	.bnr01 dd h3 {font-size: 19px; letter-spacing: 0;}
	.top03_bnr_wrap .bnr01 dd p {font-size: 20px; margin-bottom: 8px;}
	
	.top02 {padding: 60px 0;}
	.top02_right_in .btn01 a {margin: auto;}
	.top02_bg_text span {font-size: 60px;}
	
	.b_contact_in {max-width: 380px;}
	.b_contact_text {font-size: 15px; text-align: left;}
	.b_contact::after {background-position: 40% top;}
	
	footer {padding-top: 70px;}
	.pagetop {padding-top: 10px;}
	.footer_in {padding-bottom: 40px;}
	.f_copy {font-size: 10px; letter-spacing: 0;}
	
	.page_main_text {width: 50%; top: 24%;}
	
	.sec_title01 {margin-bottom: 30px;}
	.sec_title01 p {font-size: 13px; margin-bottom: 12px;}
	.sec_title01 h2 {font-size: 26px; letter-spacing: 2px;}
	
	.message02 .top01_in {padding-top: 40px;}
	.message03 .top01_in {padding-top: 40px;}
	.message04 .top01_in {padding-top: 40px;}
	.message02 {padding-bottom: 40px;}
	.message03 {padding-bottom: 40px;}
	.message04 {padding-bottom: 40px;}
	.message02 .top01_in h2, .message03 .top01_in h2, .message04 .top01_in h2 {margin-bottom: 20px;}
	.message02 .top01_img img {height: 260px;}
	.message03 .top01_img img {height: 260px;}
	.message04 .top01_img img {height: 260px;}
	.message02 .top01_in p, .message03 .top01_in p, .message04 .top01_in p {font-size: 15px;}
	.top01_in_box {padding: 20px 20px 15px;}
	.top01_in_box h3 {font-size: 18px;}
	.top01_in_box dt {font-size: 17px;}
	.top01_in_box dd {font-size: 15px;}
	.message05_title {font-size: 24px; letter-spacing: 1px; margin-bottom: 15px;}
	.message05_text {font-size: 15px; letter-spacing: 1px; text-align: left; margin-bottom: 20px;}
	.message05_in p {font-size: 15px; font-weight: 500; letter-spacing: 0; margin-bottom: 10px;}
	.message05 {padding: 40px 0 50px;}
	.message05 .sec_in1000 {width: 80%;}
	.message05 .bnr01 {width: 100%;}
	
	
	.service01_img {height: 400px;}
	.service01_img_bg {height: 400px;}
	.service01_box_in {padding-top: 30px;}
	.service01_box_in h2 {font-size: 28px; letter-spacing: 1px; margin-bottom: 160px; text-shadow: 0 0 20px #224eb2, 0 0 20px #224eb2,0 0 20px #224eb2,0 0 20px #224eb2;}
	.service01_box_in p {font-size: 14px; text-align: left; line-height: 1.6;}
	
	.service_img img {height: 320px !important;}
	.service_text {padding: 40px 0;}
	.service_text_in h2 {font-size: 30px; letter-spacing: 1px;}
	.service_text_in h2 span {font-size: 60px;}
	.service_text_in p {font-size: 15px;}
	
	.service07 {padding: 50px 0;}
	.service07_in {margin-bottom: 20px;}
	.service07_bottom {padding: 20px;}
	.service07_bottom p {font-size: 16px; text-align: left;}
	.service07_dl01 > dt {max-width: 210px;}
	.service07_dl01 > dt p {font-size: 45px;}
	
	.company01 {padding: 30px 0 30px;}
	.mvv_box {margin-bottom: 30px;}
	.mvv_box02 .mvv_title h2 {padding-left: 0;}
	
	.company03 {padding: 20px 0 30px;}
	.value_box {padding: 20px 15px 10px; min-height: 340px;}
	.value_box h3 {font-size: 21px; margin-bottom: 10px;}
	
	.company05 {padding: 40px 0 30px;}
	.company05_in iframe {height: 310px;}
}

@media screen and ( max-width:450px ){
	.max428 {display: block !important;}
	.min429 {display: none !important;}
	
	.sp_menu {padding-top: 17vh; padding-bottom: 20vh;}
	.sp_menu01 {margin-bottom: 10vh;}
	.sp_menu01 li {margin-bottom: 5vh;}
	
	.f_copy {font-size: 10px;}
	.footer_left h2 img {width: 160px;}
	.footer_left h3 {font-size: 16px; letter-spacing: 1px;}
	
	.h_logo a {left: 4.5%; max-width: 140px;}
	
	.top02_left img {height: 250px;}
	.top02_right_in h3 {font-size: 17px;}
	.top02_right {padding: 40px 15px 0;}
	.top02_bg_text {left: -10px;}
	.top02_icon {width: 100px; height: 100px; top: -20px;}
	
	.b_contact {padding: 50px 0;}
	.b_contact_in {width: 86%;}
	.b_contact_left a p {font-size: 11px;}
	.b_contact_left a {padding: 8px 8px 12px;}
	.b_contact::after {filter: brightness(0.8);}
	
	.page_main_text {width: 60%; top: 42%;}
	.page_main_filter img {object-position: 90%;}
	
	.service01_img {height: 300px;}
	.service01_img_bg {height: 300px;}
	.service01_box_in {padding-top: 20px;}
	.service01_box_in h2 {font-size: 22px; letter-spacing: 0; margin-bottom: 76px;}
	.service01_box_in p {line-height: 1.4;}
	
	.service_img img {height: 230px !important;}
	.service_text_in h2 {font-size: 27px;}
	.service07_in_box dd {font-size: 23px; padding-left: 10px;}
	.service07_in_box dt {width: 34px;font-size: 23px;}
	.service07_dl01 > dd {max-width: 310px;}
	
	.value_box {float: none; width: 100%; margin: 0 auto 20px; min-height: auto; padding: 24px;}
	.value_box h3 {font-size: 25px; max-width: 210px; margin-bottom: 20px;}
	.value_box h3 br {display: block;}
	
	.company04 {padding: 50px 0;}
}

@media screen and ( max-width: 360px ){
	.max360 {display: block !important;}
	.min361 {display: none !important;}
	
	.top02_left img {height: 220px;}
	
	.service01_box_in h2 br {display: none;}
	.service01_box_in p {font-size: 13px;}
}

@media screen and ( max-width: 325px ){
	.top01_img img {height: 220px;}
}
















