/*
Theme Name: hamidashi

*/


@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@300;400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&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: 'Noto Serif JP', "游明朝", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro" ,"ＭＳ Ｐ明朝", "MS PMincho", serif;
	line-height: 1.6em;
	margin-top: 0;
	margin-right: 0;
	margin-bottom: 0;
	margin-left: 0;
	color: #111;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0;
}

em {
	font-family: 'Noto Serif JP', "游明朝", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro" ,"ＭＳ Ｐ明朝", "MS PMincho", serif;
	color: #111;
	font-size: 16px;
	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;
}

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
	text-decoration: none;
	color: #111;
}
/* 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: 'Noto Serif JP', "游明朝", "ヒラギノ明朝 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; }
 
.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_in1000 {
	max-width: 1000px;
	width: 88%;
	margin: auto;
	position: relative;
}

.sec_in1154 {
	max-width: 1154px;
	width: 88%;
	margin: auto;
	position: relative;
	overflow: hidden;
}

.sec_in1200 {
	max-width: 1200px;
	width: 88%;
	margin: auto;
	position: relative;
}

.sec_in1400 {
	max-width: 1400px;
	width: 88%;
	margin: auto;
	position: relative;
}

.overflow-h {overflow: hidden;}

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

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




.breadcrumbs {
	width: 100%;
	background: #fff;
	box-sizing: border-box;
    padding: 30px 4% 160px;
	background-image: url(images/top/top03_bg.png);
    background-size: 1920px;
    background-position: center top;
    background-repeat: no-repeat;
}

.breadcrumbs p {
	font-size: 13px;
	letter-spacing: 1px;
	color: #fff;
	line-height: 1.3;
	text-align: right;
}

.breadcrumbs span {
	font-size: 13px;
	letter-spacing: 1px;
	color: #fff;
	line-height: 1.3;
}

.breadcrumbs span a {
	font-size: 13px;
	letter-spacing: 1px;
	color: #fff;
	line-height: 1.3;
	text-decoration: underline;
}

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




.content_wrap {
	position: relative;
	
	
}







.error404 .page-title {
	font-size: 24px;
	font-weight: bold;
	color: #a40001;
	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: #a40001;
	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: #a40001;
	border: none;
	width: 13%;
	cursor: pointer;
}

.search .page-title {
	font-size: 24px;
	font-weight: bold;
	color: #a40001;
	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: #a40001;
	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: 14vh 0 18vh;
}

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

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

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


.site-main {
	background-image: url(images/top/top05_bg03.png);
	background-size: 1920px;
	background-position: center 100.02%;
	background-repeat: no-repeat;
	padding-bottom: 100px;
}

.home .site-main {background-image: none !important; padding-bottom: 0 !important;}


.page_img {background: #a40001; padding-bottom: 0;}

.page_img .sec_title01 {
	background-image: url(images/top/title_bg02.png) !important;
	margin-bottom: 0 !important;
}

.page_img .sec_title01 h2 {color: #fff !important;}
.page_img .sec_title01 P {color: #fff !important;}



@media screen and ( max-width:1366px ){ 
	.site-main {background-size: 1400px;}
	.breadcrumbs {background-size: 1400px; padding: 20px 4% 103px;}
}

@media screen and ( max-width:991px ){ 
	.site-main {background-size: 1000px;}
	.breadcrumbs {background-size: 1000px; padding: 20px 4% 63px;}
	.page_img {padding-bottom: 20px;}
}

@media screen and ( max-width:567px ){ 
	.site-main {background-size: 700px; padding-bottom: 70px;}
	.breadcrumbs {background-size: 700px; padding: 0 4% 63px; background-position: 80% top;}
	.page_img {padding-bottom: 30px;}
	
	.breadcrumbs p {font-size: 12px;}
	.breadcrumbs span {font-size: 12px;}
	.breadcrumbs span a {font-size: 12px;}
}









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

    header

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


header {
	position: relative;
	overflow-x:hidden;
	min-height: 110px;
	background: #a40001;
}
.home header {min-height: inherit !important; background: transparent;}

.error404 .page-header {background: transparent;}

@media screen and ( max-width:991px ){ 
	header {min-height: 90px;}
	.home header {min-height: inherit !important;}
}

@media screen and ( max-width:567px ){ 
	header {min-height: 90px;}
	.home header {min-height: inherit !important;}
}


.header_top {
	box-sizing: border-box;
	width: 100%;
	position: absolute;
	top: 0;
	z-index: 9999;
	transition: .3s;
}

.header_top.fixed {
	background: #111;
	position: fixed;
	height: 80px;
}

.header_logo {transition: .3s;}
.header_logo.hidden {opacity: 0;}

.h_logo {
	position: absolute;
	top: 25px;
	left: 2%;
	z-index: 9999;
	max-width: 440px;
	width: 38%;
	transition: .3s;
	box-sizing: border-box;
	display: block;
}

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

.h_logo dt {
	display: table-cell;
	width: 159px;
	vertical-align: top;
	transition: .3s;
}

.h_logo dd {
	display: table-cell;
	vertical-align: middle;
	font-size: 28px;
	color: #fff;
	font-weight: 900;
	line-height: 1.2;
	box-sizing: border-box;
	padding-left: 22px;
	transition: .3s;
}

.header_top.fixed .h_logo {top:12px; left:20px;}
.header_top.fixed .h_logo dt {width: 110px;}
.header_top.fixed .h_logo dd {font-size: 20px; padding-left: 15px;}

.h_nav_wrap {
	max-width: 760px;
	float: right;
	width: 80%;
	box-sizing: border-box;
	transition: .3s;
}
.header_top.fixed .h_nav_wrap {max-width: 680px;}

.h_nav_wrap01 {max-width: 600px; float: right; width: 100%;transition: .3s; height: 65px;}
.header_top.fixed .h_nav_wrap01 {transform: translateY(-80px); height: 0;}



.h_nav_wrap01_left {
	max-width: 340px;
	width: 56%;
	float: left;
	padding-top: 35px;
}






.h_nav_wrap nav {position: relative;}

.h_nav_wrap nav ul {overflow: hidden;}
.h_nav_wrap nav li a {
	display: block;
	float: left;
	margin-right: 5.5%;
	font-size: 19px;
	color: #fff;
	font-weight: 900;
	letter-spacing: 1px;
	line-height: 1.3;
	padding-bottom: 18px;
	padding-top: 19px;
	position: relative;
	transition: .3s;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
}

.h_nav_wrap nav li:nth-of-type(4) a {margin-right: 4%;}
.h_nav_wrap nav li:last-of-type a {margin-right: 0;}



.h_nav_wrap nav li a:hover {
	background-image: url("images/header/nav_bg.png");
	
}

.h_nav_wrap nav .h_contact a {
	padding-left: 30px;
	padding-right: 30px;
	background-image: url("images/header/h_contact_bg.png");
	background-repeat: no-repeat;
	background-position: center -61px;
	background-size: 176px;
	text-align: center;
	color: #222;
	transition: 0s !important;
	font-size: 18px;
}

.h_nav_wrap nav .h_contact a:hover {
	color: #fff;
	background-position: center 0;
	background-image: url("images/header/h_contact_bg.png");
	background-size: 176px;
}

.header_top.fixed .h_nav_wrap nav li a {font-size: 17px; margin-right: 4.5%; padding-bottom: 18px; padding-top: 18px; position: relative;bottom: 14px;}
.header_top.fixed .h_nav_wrap nav li a:hover {background-image: url("images/header/nav_bg02.png");}
.header_top.fixed .h_nav_wrap nav .h_contact a {font-size: 18px; margin-right: 0;}
.header_top.fixed .h_nav_wrap nav .h_contact a:hover {opacity: 0.8; color: #111; background-position: center -61px; background-image: url("images/header/h_contact_bg.png");}


.sp_right {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 9999;
	width: 84px;
	height: 84px;
	padding: 28px 24px;
	background: #111;
	box-sizing: border-box;
	cursor: pointer;
	transition: .3s;
}

.sp_right:hover {
	background: #222;
}

.sp_right a {
	
	
}




.main_img_wrap {
	position: relative;
	width: 100%;
	background-image: url("images/header/main_bg.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center top;
	height: 0;
	padding-bottom: calc(956 / 1920 * 100%);
}

.main_img {
	position: absolute;
	bottom: 0;
	left: 0;
	right: -44%;
	margin: auto;
	z-index: 10;
	width: 28.96%;
	max-width: 680px;
	transform: translateX(400px);
	opacity: 0;
	transition: all .6s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.main_img.show {
	transform: translateX(0);
	opacity: 1;
}



.main_text01 {
	display: block;
	position: absolute;
	top: 24%;
	left: 11%;
	width: 51.98%;
	z-index: 5;
	
	transform: scale(0);
}

.main_text01.show {
	animation: show 0.7s cubic-bezier(0.22, 1, 0.36, 1);
	transform: scale(1);
}

.main_text02 {
	display: block;
	position: absolute;
	top: 58%;
	left: 13%;
	width: 39.01%;
	z-index: 5;
	transform: translateY(200px);
	opacity: 0;
	transition: all .8s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.main_text02.show {
	transform: translateX(0);
	opacity: 1;
}



@keyframes show {
  0% {
    transform: scale(0);
  }
  60% {
    transform: scale(1.25);
  }
  80% {
    transform: scale(0.90);
  }
  100% {
    transform: scale(1);
  }
}




.header_bottom {padding-left: 3%; box-sizing: border-box;}




.c-scroll {
    width: 1px;
    height: 10rem;
    position: absolute;
    bottom: 0;
    left: 3%;
    z-index: 5000;
}

.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: 12px;
    line-height: 1;
    color: #FFFFFF;
    text-transform: uppercase;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    letter-spacing: 2px;
	font-weight: 600;
}

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

.page_top .c-scroll__line {
	background-color: #344998;
}

.c-scroll__line::before {
    content: "";
    width: 100%;
    height: 100%;
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #fff;
    -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_header

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

.sp_menu {
	padding: 36px 30px;
	background: #222;
	cursor: pointer;
	min-height: 100px;
	box-sizing: border-box;
	position: fixed;
    top: 0;
    width: 100px;
    z-index: 99999;
}

.menu-trigger {
	
}

.menu-trigger p {
	font-size:10px !important;
	font-weight: 600;
	position: relative;
	top: 20px;
	color: #fff;
	letter-spacing: 0;
	left: -2px;
}

.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 26px;
	margin: auto;
	display: block;
	cursor: pointer;
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #fff;
	border-radius: 0;
}
.menu-trigger span:nth-of-type(1) {
	top: 0;
}
.menu-trigger span:nth-of-type(2) {
	top: 8px;
}
.menu-trigger span:nth-of-type(3) {
	top: 16px;
}

.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(8px) rotate(-40deg);
	transform: translateY(8px) rotate(-40deg);
}
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-8px) rotate(40deg);
	transform: translateY(-8px) rotate(40deg);
	width: 100%;
}



.b_overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9000;
    background: rgba(0,0,0,.8);
    transition: all .2s;
    opacity: 0;
	visibility: hidden;
	width: 100vw;
	height: 100vh;
}

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




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

    sp_menu

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

.sp_menu_wrap {
	overflow: scroll;
    position: fixed;
    top: 0;
    z-index: 8000;
	margin: auto;
    color: #111;
    text-align: center;
	width: 100%;
    height: 100vh;
    /*padding: 10vh 10px 10vh;*/
	box-sizing: border-box;
	transition: .3s;
	opacity: 0;
	visibility: hidden;
	margin-right: 110px;
	background: #fff;
}

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



.sp_menu_box {
	box-sizing: border-box;
	width: 100%;
	padding-top: 11vh;
	padding-bottom: 18vh;
	background: #111;
}

.sp_menu_in {
	max-width: 350px;
	width: 90%;
	margin: auto;
}

.sp_menu_in h2 {
	text-align: center;
	margin-bottom: 80px;
}
.sp_menu_in h2 a {color: #fff; font-size: 20px; font-weight: 900;}
.sp_menu_in h2 a img {padding-bottom: 10px;}
.sp_menu_in ul {margin-bottom: 50px; overflow: hidden;}
.sp_menu_in li {
	margin-bottom: 45px;
	width: 100%;
	text-align: left;
}
.sp_menu_in li a {
	font-size: 32px;
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1.3;
	color: #fff;
}

.sp_menu_in li a img {
	padding-right: 8px;
	position: relative;
	bottom: 3px;
}

.sp_menu_in li a:hover {
	color: #a40001;
}

.sp_menu_info p {
	font-size: 15px;
	line-height: 2em;
	text-align: center;
	margin-bottom: 40px;
	color: #fff;
}

.sp_menu_tel a {font-size: 32px; line-height: 1; letter-spacing: 0; color: #a40001; padding-bottom: 12px; font-weight: 900;}
.sp_menu_tel a span {padding-right: 8px; font-size: 0.7em; color: #a40001; font-weight: 900;}

.sp_copy {
	text-align: center;
	font-size: 12px;
	letter-spacing: 2px;
	line-height: 1.3;
	color: #fff;
}



.sp_sns_wrap {margin-bottom: 50px;}
.sp_sns_wrap p {text-align: center;}
.sp_sns_wrap p a:nth-of-type(1) {margin-right: 30px;}









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

    top

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

.top01 {
	padding: 110px 0 0;
	position: relative;
	background-image: url("images/top/top01_bg02.png"), url("images/top/top01_bg04.png"), url("images/top/top01_bg01.jpg");
	background-repeat: no-repeat, no-repeat, no-repeat;
	background-position: 0 34% , right 70%, center top;
	background-size: 483px, 614px, cover;
	overflow-x: hidden;
	overflow-y: hidden;
}

.top01_in01 {
	max-width: 1460px;
	width: 88%;
	position: relative;
	margin: auto;
	padding-bottom: 10px;
}

.sec_title01 {
	padding: 100px 0 25px;
	box-sizing: border-box;
	background-image: url("images/top/title_bg01.png");
	background-size: contain;
	background-position: center center;
	background-repeat: no-repeat;
	margin-bottom: 20px;
	
}

.top01_in01 .sec_title01 {
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}

.top01_in01.show .sec_title01 {
	transform: translateY(0);
	opacity: 1;
}

.top01_in03 .sec_title01 {
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}
.top01_in03.show .sec_title01 {
	transform: translateY(0);
	opacity: 1;
}

.sec_title01 h2 {
	text-align: center;
	color: #a40001;
	font-size: 46px;
	line-height: 1.2;
	font-weight: 900;
	letter-spacing: 0;
	padding-bottom: 16px;
}

.sec_title01 p {
	text-align: center;
	font-size: 18px;
	color: #111;
	line-height: 1.2;
	letter-spacing: 0;
	font-weight: 700;
}

.top01_in01_title {
	float: left;
	width: 30%;
	position: relative;
	max-width: 360px;
	margin-right: 3%;
}

.top01_in01_title .sec_title01 {max-width: 230px; margin-bottom: 0;}

.top01_in01_title::before {
	display: block;
	content: "";
	width: 60px;
	height: 1px;
	background: #a40001;
	position: absolute;
	top: 60%;
	right: 0;
}

.top01_in01_text {
	float: left;
	width: 67%;
	padding-top: 60px;
}

.top01_in01_text h3 {
	font-size: 60px;
	font-weight: 900;
	color: #111;
	line-height: 1.2;
	letter-spacing: 0;
	transform: translateX(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top01_in02 .top01_in01_text h3 {transform: translateX(-200px);}

.top01_in01.show .top01_in01_text h3 {
	transform: translateY(0);
	opacity: 1;
}

.top01_in02 .top01_in01_title {
	float: right;
	margin-right: 0;
	margin-left: 3%;
	max-width: 300px;
}

.top01_in02 .top01_in01_text {
	float: right;
	max-width: 730px;
}

.top01_in02 .top01_in01_title .sec_title01 {float: right;}

.top01_in02 .top01_in01_title::before {
	right: auto;
	left: 0;
}

.top01_in03 {padding-bottom: 100px; padding-top: 30px;}

.top01_in03_in {
	max-width: 1630px;
	width: 90%;
	margin: auto; 
}

.top01_in03_box {
	float: left;
	width: 19.2%;
	margin: 0 0.4%;
	box-sizing: border-box;
	padding: 48px 26px 20px;
	min-height: 424px;
	background-color: #fff;
	background-image: url("images/top/top01_bg03.png");
	background-size: 129px;
	background-position: -50px -30px;
	background-repeat: no-repeat;
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top01_in03_box:nth-of-type(2) {transition-delay: .6s;}
.top01_in03_box:nth-of-type(3) {transition-delay: .7s;}
.top01_in03_box:nth-of-type(4) {transition-delay: .8s;}
.top01_in03_box:nth-of-type(5) {transition-delay: .9s;}

.top01_in03.show .top01_in03_box {
	transform: translateY(0);
	opacity: 1;
}

.top01_in03_box:nth-of-type(even) {
	margin-top: 50px;
}

.top01_in03_box_no {
	font-size: 60px;
	color: #a40001;
	line-height: 1.1;
	font-weight: 900;
	text-align: center;
	padding-bottom: 20px;
}

.top01_in03_box_no span {
	font-size: 16px;
	color: #a40001;
	line-height: 1.1;
	font-weight: 700;
	display: block;
}

.top01_in03_box h3 {
	font-size: 36px;
	font-weight: 900;
	line-height: 1.3;
	padding-bottom: 15px;
}

.top01_in03_box p {
	font-size: 17px;
	font-weight: 700;
	line-height: 1.7;
	
}

.top01_in04 {
	max-width: 1000px;
	width: 88%;
	margin: auto;
}

.top01_in04_text {
	float: right;
	width: 62.4%;
	padding-top: 20px;
}

.top01_in04_img {
	float: left;
	width: 34%;
	max-width: 290px;
	transform: translateY(200px);
	opacity: 0;
	transition: all .8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .8s;
}

.top01_in04.show .top01_in04_img {
	transform: translateY(0);
	opacity: 1;
}

.sec_title02 {
	padding: 60px 0 35px 30px;
	box-sizing: border-box;
	background-image: url("images/top/title_bg01.png");
	background-size: contain;
	background-position: left center;
	background-repeat: no-repeat;
	margin-bottom: 20px;
}

.top01_in04_text .sec_title02 {
	transform: translateX(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}

.top01_in04.show .top01_in04_text .sec_title02 {
	transform: translateY(0);
	opacity: 1;
}

.sec_title02 h2 {
	color: #a40001;
	font-size: 46px;
	line-height: 1.2;
	font-weight: 900;
}

.sec_title02 h2 span {
	font-size: 18px;
	color: #111;
	line-height: 1.2;
	font-weight: 700;
	padding-left: 30px;
	position: relative;
	bottom: 10px;
}

.top01_in04_text p {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.9;
	letter-spacing: 1px;
	padding-bottom: 30px;
	padding-left: 30px;
	transform: translateX(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top01_in04.show .top01_in04_text p {
	transform: translateY(0);
	opacity: 1;
}

.top01_in04_text h4 {
	font-size: 29px;
	font-weight: 700;
	line-height: 1.2;
	padding-left: 30px;
	letter-spacing: 1px;
	transform: translateX(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .6s;
}
.top01_in04.show .top01_in04_text h4 {
	transform: translateY(0);
	opacity: 1;
}

.top01_in04_text h4 span {
	font-size: 0.65em;
	font-weight: 700;
	padding-right: 10px;
}

.top01_bottom_bg {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	width: 1920px;
	margin: auto;
	z-index: 10;
}


.top02 {
	background-color: #a40001;
	background-image: url("images/top/top02_bg01.png");
	background-size: 320px;
	background-position: left top;
	background-repeat: no-repeat;
	padding-bottom: 30px;
}

.top02_in {
	max-width: 1410px;
	width: 88%;
	margin: auto;
}

.top02 .sec_title01 {background-image: url(images/top/title_bg02.png); margin-bottom: 30px;}
.top02 .sec_title01 h2 {color: #fff;}
.top02 .sec_title01 p {color: #fff;}

.top02 .sec_title01 {
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}

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


.top02_title02 {
	display: block;
	font-size: 36px;
	font-weight: 900;
	text-align: center;
	margin-bottom: 20px;
	color: #fff;
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top02.show .top02_title02 {
	transform: translateY(0);
	opacity: 1;
}

.top02_text {
	display: block;
	font-size: 16px;
	font-weight: 700;
	text-align: center;
	margin-bottom: 40px;
	color: #fff;
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .6s;
}
.top02.show .top02_text {
	transform: translateY(0);
	opacity: 1;
}

.top02_in02 {margin-bottom: 40px;}

.top02_box {
	float: left;
	max-width: 347px;
	width: 25%;
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top02_box:nth-of-type(2) {transition-delay: .6s;}
.top02_box:nth-of-type(3) {transition-delay: .7s;}
.top02_box:nth-of-type(4) {transition-delay: .8s;}

.top02_in02.show .top02_box {
	transform: translateY(0);
	opacity: 1;
}

.top02_b_text {
	display: block;
	font-size: 36px;
	font-weight: 900;
	text-align: center;
	margin-bottom: 20px;
	color: #fff;
	line-height: 1.4;
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top02_b_text.show {
	transform: translateY(0);
	opacity: 1;
}

.top03 {
	padding: 180px 0 180px;
	background-color: #000;
	background-image: url("images/top/top03_bg.png"), url("images/top/top04_bg.png");
	background-size: 1920px, 1920px;
	background-position: center top, center bottom;
	background-repeat: no-repeat, no-repeat;
	overflow-x: hidden;
	overflow-y: hidden;
}

.top03_in01 {
	max-width: 1280px;
	width: 88%;
	margin: 0 auto 60px;
}

.top03_in01_img {
	float: left;
	max-width: 573px;
	width: 48%;
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}
.top03_in01.show .top03_in01_img {
	transform: translateX(0);
    opacity: 1;
}

.top03_in01_text {
	float: right;
	max-width: 560px;
	width: 48%;
	padding-top: 30px;
}
.top03_in01_text .sec_title02 {
	background-image: url("images/top/title_bg03.png");
	transform: translateX(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}

.top03_in01.show .top03_in01_text .sec_title02 {
	transform: translateX(0);
    opacity: 1;
}

.top03_in01_text .sec_title02 h2 {color: #fff;}
.top03_in01_text .sec_title02 h2 span {color: #aaa;}

.top03_in01_text h3 {
	font-size: 60px;
	font-weight: 900;
	line-height: 1.2;
	padding-bottom: 40px;
	color: #fff;
	box-sizing: border-box;
	display: block;
	padding-left: 30px;
	transform: translateX(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .6s;
}
.top03_in01.show .top03_in01_text h3 {
	transform: translateX(0);
    opacity: 1;
}

.top03_in01_text p {
	font-size: 16px;
	font-weight: 700;
	color: #fff;
	line-height: 1.7;
	box-sizing: border-box;
	display: block;
	padding-left: 30px;
	letter-spacing: 1px;
	transform: translateX(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .7s;
}
.top03_in01.show .top03_in01_text p {
	transform: translateX(0);
    opacity: 1;
}

.sec_title03 {
	width: 88%;
	margin: 0 auto 40px;
}
.sec_title03 p {
	display: block;
	text-align: center;
	color: #fff;
	font-weight: 900;
	padding: 40px 0 22px;
	box-sizing: border-box;
	font-size: 20px;
	line-height: 1.3;
	background-image: url("images/top/title_bg03.png");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 114px;
	
}

.sec_title03 p span {
	font-size: 47px;
	color: #fff;
	font-weight: 900;
	padding-left: 6px;
	position: relative;
	top: 8px;
}

.sec_title03 h2 {
	font-size: 44px;
	color: #fff;
	font-weight: 900;
	line-height: 1.3;
	text-align: center;
}

.top03 .sec_title03 {
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}

.top03 .sec_title03.show {
	transform: translateY(0);
    opacity: 1;
}

.top03_in02 {margin-bottom: 120px;}

.top03_in02_img {
	float: left;
	width: 43.28%;
	transform: translateX(-200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top03_in03 .top03_in02_img {transform: translateX(200px);}

.top03_in02.show .top03_in02_img {
	transform: translateX(0);
    opacity: 1;
}

.top03_in02_text {
	float: right;
	width: 47%;
	padding-top: 30px;
	margin-right: 3%;
}

.top03_in02_text h3 {
	margin-bottom: 30px;
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .6s;
}
.top03_in02.show .top03_in02_text h3 {
	transform: translateY(0);
    opacity: 1;
}
.top03_in02_text p {
	font-size: 16px;
	font-weight: 700;
	color: #fff;
	line-height: 1.7;
	box-sizing: border-box;
	display: block;
	padding-left: 24px;
	letter-spacing: 1px;
	margin-bottom: 40px;
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .7s;
}
.top03_in02.show .top03_in02_text p {
	transform: translateY(0);
    opacity: 1;
}

.top03_in02_text ul {
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .8s;
}
.top03_in02.show .top03_in02_text ul {
	transform: translateY(0);
    opacity: 1;
}

.top03_in02_text li {
	font-size: 22px;
	font-weight: 700;
	color: #fff;
	line-height: 1.4;
	box-sizing: border-box;
	display: block;
	padding: 6px 0 6px 54px;
	background-image: url("images/top/top03_icon01.png");
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 44px;
	margin-bottom: 8px;
}

.top03_in02_b_text {
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .9s;
}
.top03_in02.show .top03_in02_b_text {
	transform: translateY(0);
    opacity: 1;
}

.top03_in02_b_text h4 {
	padding-top: 40px;
	font-size: 32px;
	font-weight: 900;
	color: #fff;
	line-height: 1.4;
	display: block;
	text-align: center;
}

.top03_in03 {
	max-width: 1540px;
	width: 88%;
	margin: auto;
}

.top03_in03 .top03_in02_img {
	float: right;
	max-width: 806px;
	width: 48%;
	padding-top: 30px;
}

.top03_in03 .top03_in02_text {
	float: left;
	max-width: 640px;
	width: 48%;
}

.top03_in03 .top03_in02_text ul {margin-bottom: 30px;}

.top03_in03_text_bottom {
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .9s;
}

.top03_in02.show .top03_in03_text_bottom {
	transform: translateY(0);
    opacity: 1;
}

.top03_in03_text_bottom h4 {
	font-size: 26px;
	font-weight: 700;
	color: #fff;
	line-height: 1.3;
	display: block;
	margin-bottom: 5px;
}

.top03_in03_text_bottom h4 span {
	font-size: 1em;
	font-weight: 700;
	color: #a40001;
	padding-right: 4px;
}

.top03_in03_text_bottom dl {
	display: table;
	width: 100%;
	box-sizing: border-box;
	background: #fff;
	padding: 6px;
	margin-bottom: 10px;
}

.top03_in03_text_bottom dt {
	display: table-cell;
	width: 120px;
	box-sizing: border-box;
	text-align: center;
	background: #a40001;
	font-size: 20px;
	font-weight: 700;
	color: #fff;
	line-height: 1.1;
	padding: 7px;
	vertical-align: top;
}

.top03_in03_text_bottom dd {
	display: table-cell;
	box-sizing: border-box;
	padding-left: 20px;
	padding-right: 10px;
	font-size: 23px;
	color: #111;
	font-weight: 700;
	line-height: 1.3;
	vertical-align: middle;
}

.top03_in03_text_bottom dd span {
	font-size: 0.8em;
	color: #111;
	font-weight: 700;
}

.top03_in03_text_bottom dd img {
	padding: 0 10px;
	position: relative;
	bottom: 6px;
}


.top04 {background: #fff; padding: 0 0 40px; overflow-x: hidden;}

.top04 .sec_title01 {
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}
.top04.show .sec_title01 {
	transform: translateY(0);
    opacity: 1;
}

.overview01_in {
	margin-bottom: 70px;
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top04.show .overview01_in {
	transform: translateY(0);
    opacity: 1;
}

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

.overview01_in dt {
	display: table-cell;
	width: 24%;
	box-sizing: border-box;
	border-top: solid 1px #a40001;
	padding: 20px;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 1px;
	vertical-align: top;
	color: #111;
	line-height: 1.4;
}

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

.overview01_in dd span {
	border-top: solid 1px #ddd;
	padding: 20px;
	font-size: 18px;
	letter-spacing: 1px;
	width: 100%;
	display: block;
	box-sizing: border-box;
	color: #111;
	line-height: 1.4;
}

.overview01_in dl:last-of-type dt {
	border-bottom: solid 1px #a40001;
}

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

.overview02_in iframe {filter: grayscale(0.5);}



@media screen and ( max-width:991px ){
	.overview01_in dt {font-size: 15px; letter-spacing: 1px;}
	.overview01_in dd span {font-size: 15px; letter-spacing: 1px;}
}

@media screen and ( max-width:767px ){
	.overview01 {padding: 0 0 70px;}
	.overview01_in dt {width: 25%;font-size: 16px; padding: 15px;}
	.overview01_in dd {width: 75%;padding-left: 0;}
	.overview01_in dd span {font-size: 16px; padding: 15px;}
}

@media screen and ( max-width:567px ){
	.overview01_in dt {width: 90px;font-size: 15px;padding: 12px;}
	.overview01_in dd {padding-left: 0;	}	
	.overview01_in dd span {font-size: 15px;padding: 12px;}
	.overview01 {padding: 0 0 60px;}
}

@media screen and ( max-width:450px ){
	.overview01_in dt {padding: 12px 0;}
	.overview01_in dd span {padding: 12px 0 12px 10px;}
}

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




.top04_in01 {padding-bottom: 80px;}
.top04_in01 h3 {
	font-size: 30px;
	font-weight: 700;
	line-height: 1.3;
	text-align: center;
	display: block;
	margin-bottom: 25px;
	transform: translateY(200px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}

.top04_in01.show h3 {
	transform: translateY(0);
    opacity: 1;
}

.top04_in01_in p {
	display: block;
	max-width: 280px;
	width: 23.8%;
	margin: 0 0.6% 12px;
	float: left;
	transform: translateY(150px);
    opacity: 0;
    transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top04_in01_in p:nth-of-type(2) {transition-delay: .6s;}
.top04_in01_in p:nth-of-type(3) {transition-delay: .7s;}
.top04_in01_in p:nth-of-type(4) {transition-delay: .8s;}
.top04_in01_in p:nth-of-type(5) {transition-delay: .9s;}
.top04_in01_in p:nth-of-type(6) {transition-delay: 1s;}
.top04_in01_in p:nth-of-type(7) {transition-delay: 1.1s;}
.top04_in01_in p:nth-of-type(8) {transition-delay: 1.2s;}
.top04_in01_in p:nth-of-type(9) {transition-delay: 1.3s;}
.top04_in01_in p:nth-of-type(10) {transition-delay: 1.4s;}
.top04_in01_in p:nth-of-type(11) {transition-delay: 1.5s;}
.top04_in01_in p:nth-of-type(12) {transition-delay: 1.6s;}

.top04_in01.show .top04_in01_in p {
	transform: translateY(0);
    opacity: 1;
}




/*ここからトップのニュースブロック*/




.top04_left {
	float: left;
    width: 20%;
    max-width: 320px;
    box-sizing: border-box;
}

.top04_right {
	float: right;
    width: 75%;
}

.news_wrap {
	margin-bottom: 10px;
}

.news_wrap dl {
	display: table;
	width: 100%;
	border-bottom: solid 1px #ccc;
	padding: 24px 20px;
	overflow-x: hidden;
	box-sizing: border-box;
}

.news_wrap dt {
	display: table-cell;
	width: 130px;
	box-sizing: border-box;
	font-size: 17px;
	font-weight: 600;
	letter-spacing: 1px;
	line-height: 1.3;
	color: #a40001;
	transform: translateX(150px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.news_wrap dl:nth-of-type(2) dt {transition-delay: .6s;}
.news_wrap dl:nth-of-type(3) dt {transition-delay: .7s;}
.news_wrap dl:nth-of-type(4) dt {transition-delay: .8s;}
.news_wrap dl:nth-of-type(5) dt {transition-delay: .9s;}
.news_wrap dl:nth-of-type(6) dt {transition-delay: 1s;}
.news_wrap dl:nth-of-type(7) dt {transition-delay: 1.1s;}
.news_wrap dl:nth-of-type(8) dt {transition-delay: 1.2s;}
.news_wrap dl:nth-of-type(9) dt {transition-delay: 1.3s;}
.news_wrap dl:nth-of-type(10) dt {transition-delay: 1.4s;}
.news_wrap dl:nth-of-type(11) dt {transition-delay: 1.5s;}
.news_wrap dl:nth-of-type(12) dt {transition-delay: 1.6s;}

.top04_in02.show .news_wrap dt {transform: translateX(0); opacity: 1;}



.news_wrap dd {
	display: table-cell;
	box-sizing: border-box;
	transform: translateX(150px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.news_wrap dl:nth-of-type(2) dd {transition-delay: .6s;}
.news_wrap dl:nth-of-type(3) dd {transition-delay: .7s;}
.news_wrap dl:nth-of-type(4) dd {transition-delay: .8s;}
.news_wrap dl:nth-of-type(5) dd {transition-delay: .9s;}
.news_wrap dl:nth-of-type(6) dd {transition-delay: 1s;}
.news_wrap dl:nth-of-type(7) dd {transition-delay: 1.1s;}
.news_wrap dl:nth-of-type(8) dd {transition-delay: 1.2s;}
.news_wrap dl:nth-of-type(9) dd {transition-delay: 1.3s;}
.news_wrap dl:nth-of-type(10) dd {transition-delay: 1.4s;}
.news_wrap dl:nth-of-type(11) dd {transition-delay: 1.5s;}
.news_wrap dl:nth-of-type(12) dd {transition-delay: 1.6s;}

.top04_in02.show .news_wrap dd {transform: translateX(0); opacity: 1;}

.news_wrap dd a {
	font-size: 17px;
	letter-spacing: 1px;
	line-height: 1.3;
	font-weight: 600;
}

.news_wrap dd a:hover {
	text-decoration: underline;
	color: #a40001;
}

.top04 .btn02 {
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: 1s;
}
.top04.show .btn02 {transform: translateY(0); opacity: 1;}

.btn01 {padding-top: 20px;}
.btn01 a {
	display: block;
	width: 100%;
	max-width: 240px;
	float: right;
	box-sizing: border-box;
	border: solid 1px #111;
	text-align: center;
	color: #111;
	padding: 12px 20px 10px;
	line-height: 1.2;
	font-weight: 700;
	letter-spacing: 1px;
	border-radius: 30px;
	transition: .3s;
	font-size: 18px;
	position: relative;
}

.btn01 a i {font-size: 20px; color: #111; float: right; transition: .3s;}
.btn01 a:hover {background: #111; color: #fff;}
.btn01 a:hover i {color: #fff;}


@media screen and ( max-width:1366px ){
	.top04 {padding: 10px 0 50px;}
	.news_wrap dt span {font-size: 11px; width: 90px; letter-spacing: 1px;}
	.news_wrap dt {font-size: 16px; width: 100px;}
	.news_wrap dd {padding-left: 20px;}
	.news_wrap dd a {font-size: 16px;}
}

@media screen and ( max-width:991px ){
	.top04_left {float: none; width: 100%; margin-bottom: 20px; margin: auto;}
	.top04_right {float: none; width: 100%;}
	.btn02 a {float: none; margin: auto;}
	.top04 {padding: 10px 0 20px; background-size: 400px;}
	.btn01 a {float: none; margin: auto;}
}

@media screen and ( max-width:767px ){
	.news_wrap {margin-bottom: 10px;}
	.news_wrap dt {display: block; width: 100%; margin-bottom: 8px;}
	.news_wrap dd {display: block; width: 100%; padding-left: 0; line-height: 1.3;}
	.news_wrap dt {font-size: 15px;}
	.news_wrap dt span {font-size: 10px; width: 80px; margin-right: 13px;}
}




/*ここまでトップのニュースブロック*/











.top05 {
	padding: 160px 0 240px;
	background-color: #000;
	background-image: url("images/top/top05_bg02.png"), url("images/top/top05_bg03.png"), url("images/top/top05_bg01.png");
	background-size: 1920px, 1920px, 614px;
	background-position: center top, center bottom, right 35%;
	background-repeat: no-repeat, no-repeat, no-repeat;
	overflow-x: hidden;
}

.top05_in01 {padding-bottom: 60px;}

.top05_in01 .sec_title01, .top05_in02 .sec_title01 {background-image: url("images/top/title_bg05.png"); background-size: 180px;}
.top05_in01 .sec_title01 h2, .top05_in02 .sec_title01  h2 {color: #fff;}
.top05_in01 .sec_title01 p, .top05_in02 .sec_title01 p {color: #fff;}

.top05_in01 .top01_in01_text p {
	color: #fff;
	font-weight: 500;
	letter-spacing: 1px;
	padding-bottom: 20px;
	transform: translateX(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}
.top01_in01.show .top01_in01_text p {
	transform: translateY(0);
    opacity: 1;
}

.top05_in01 .top01_in01_text {padding-top: 100px;}

.btn02 {padding-top: 0;}
.btn02 a {
	color: #fff;
	border: solid 1px #fff;
	font-size: 16px;
	max-width: 280px;
	float: none;
}

.btn02 a i {color: #fff; float: none; padding-right: 10px;}

.btn02 a:hover {color: #111; background: #fff; padding: 12px 20px 12px;}
.btn02 a:hover i {color: #111;}

.top05_in02 {padding-bottom: 60px;}

.top05_in02 .sec_title01 {
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .4s;
}
.top05_in02.show .sec_title01 {
	transform: translateY(0);
    opacity: 1;
}

.top05_in02_text {
	font-size: 17px;
	color: #fff;
	font-weight: 700;
	text-align: center;
	display: block;
	margin-bottom: 20px;
	line-height: 1.4;
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}
.top05_in02.show .top05_in02_text {
	transform: translateY(0);
    opacity: 1;
}

.top05_in02_info {
	box-sizing: border-box;
	max-width: 500px;
	width: 90%;
	margin: auto;
	border: solid 1px #fff;
	padding: 20px;
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .6s;
}
.top05_in02.show .top05_in02_info {
	transform: translateY(0);
    opacity: 1;
}

.top05_in02_info p {
	font-size: 16px;
	color: #fff;
	font-weight: 700;
	text-align: center;
	display: block;
	line-height: 1.4;
	margin-bottom: 6px;
}

.top05_in02_info h3 {text-align: center;}

.top05_in02_info h3 a {
	font-size: 40px;
	line-height: 1;
	font-weight: 900;
	color: #fff;
	text-align: center;
}

.top05_in02_info h3 a span {
	font-size: 0.6em;
	font-weight: 900;
	color: #fff;
	padding-right: 8px;
}

.top05_in03_title {
	font-size: 26px;
	color: #fff;
	text-align: center;
	display: block;
	margin-bottom: 25px;
	line-height: 1.3;
	font-weight: 700;
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .5s;
}

.top05_in03.show .top05_in03_title {
	transform: translateY(0);
    opacity: 1;
}

.b_contact_wrap {
	transform: translateY(200px);
	opacity: 0;
	transition: all .7s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition-delay: .6s;
}

.top05_in03.show .b_contact_wrap {
	transform: translateY(0);
    opacity: 1;
}








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

.b_contact_wrap dl dt {
	display:table-cell;
	width:26%;
	box-sizing:border-box;
	vertical-align:top;
	font-weight: 500;
	font-size: 18px;
	padding-top: 5px;
	color: #fff;
}

.b_contact_wrap dl dt p {font-size: 18px; color: #fff; font-weight: 700;}

.b_contact_wrap 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;
}


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

.b_contact_wrap .required02 {
	display:block;
	padding-left: 31%;
	font-size:12px;
	color:#888;
    margin-bottom: -30px;
    margin-top: 10px;
	letter-spacing: 0;
	text-align: left;
}
.b_contact_wrap .required02 {
	padding-left: 0;
	margin-bottom: 3px;
}
.required2 {
    color: #fff;
    background-color: #aaa;
    font-size: 12px;
    padding: 1px 7px;
	margin: 0 10px 0 0;
	letter-spacing: 1px;
}

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

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

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

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

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

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

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

.b_contact_wrap input[type="submit"] {
	max-width:400px;
	width: 80%;
	margin: 30px auto 0;
	box-sizing:border-box;
	display:block;
	text-align:center;
	background-color:#a40001;
	color:#fff;
    padding: 18px 0;
	font-size: 20px;
	letter-spacing: 1px;
	cursor: pointer;
	border: none;
	border-radius: 40px;
	-webkit-appearance: none;
	transition: .3s;
	font-family: 'Noto Serif JP', "游明朝", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro" ,"ＭＳ Ｐ明朝", "MS PMincho", serif;
}

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

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

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


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


@media screen and ( max-width:991px ){
	.b_contact_wrap dl dt p {font-size: 16px;}
	.b_contact_wrap .required {padding: 1px 4px 2px;}
}

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

}

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

}

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


.grecaptcha-badge { visibility: hidden; }










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

    footer

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


footer {
	box-sizing: border-box;
	padding: 0;
	position: relative;
	background: #a40001;
}


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

.footer_left {
	max-width: 500px;
	width: 64%;
	float: left;
}

.footer_right {
	max-width: 200px;
	width: 30%;
	float: right;
	overflow: hidden;
	padding-top: 60px;
}

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

.footer_left h2 a {
	font-size: 28px;
	color: #fff;
	font-weight: 900;
	line-height: 83px;
}

.footer_left h2 a img {
	padding-right: 15px;
}

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

.footer_left p {
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 1px;
	line-height: 1.7;
	color: #fff;
	padding-bottom: 20px;
}

.footer_left p a {
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 1px;
	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: 200px;
	width: 33%;
}*/

/*.f_nav_right {
	float: right;
	max-width: 200px;
	width: 33%;
}*/

.f_nav h3 {
	font-size: 20px;
	font-weight: 400;
	color: #35457f;
	line-height: 1.3;
	margin-bottom: 20px;
	letter-spacing: 2px;
}

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



.f_nav li a {
	font-size: 18px;
	font-weight: 500;
	letter-spacing: 1px;
	line-height: 1.3;
	color: #fff;
	display: block;
	position: relative;
}

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

.f_nav li a img {padding-right: 7px;}



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



.f_sns a:nth-of-type(1) {padding-right: 20px;}

.footer_bottom {
	width: 100%;
	box-sizing: border-box;
	padding: 0 25px 35px;
	background: #a40001;
}

.f_copy {
	font-size: 12px;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 1px;
	color: #ccc;
	text-align: center;
	
}


.page_top a {
	display: block;
	position: fixed;
	right: 1.5%;
	bottom: -200px;
	z-index: 100;
	transition: .3s;
}

.page_top a:hover {opacity:0.8;}

.page_top.visible a {
	bottom: 20px;
} 




@media screen and ( max-width:1366px ){
	.footer_right {max-width: 140px;}
	.footer_left h3 {font-size: 18px; margin-bottom: 10px;}
	.footer_left p {font-size: 15px; letter-spacing: 0; line-height: 1.5;}
	.footer_left p a {font-size: 15px; letter-spacing: 0; line-height: 1.5;}
	.f_nav li a {letter-spacing: 1px; font-size: 16px;}
	.f_nav li a i {width: 18px; height: 18px; font-size: 13px; position: relative; bottom: 1px;}
	
	.footer_left h2 a {font-size: 22px; line-height: 62px;}
	.footer_left h2 a img {width: 120px;}
	
	.page_top a img { width: 88px;}
	.f_sns a img {width: 34px;}
	.f_sns a:nth-of-type(2) img {width: 30px; position: relative; bottom: 2px;}
}

@media screen and ( max-width:1199px ){
	.page_top .c-scroll {top: 0; position: static;}
}

@media screen and ( max-width:991px ){
	footer {padding-top: 30px;}
	.footer_left {float: none; width: 100%; margin: 0 auto 40px; max-width: 360px; text-align: center;}
	.footer_right {float: none; width: 100%; margin: 0 auto; max-width: 100px; padding-top: 0;}
	.footer_right_bottom {float: none; margin: auto;}
	
	.f_copy {font-size: 11px; letter-spacing: 1px;}

	.footer_left h2 img {width: 100%;}
	.f_nav h3 {font-size: 17px;}

	.footer_in {padding-bottom: 20px;}
	.page_top {right: 4%;}
}

@media screen and ( max-width:767px ){
	.footer_in {padding-bottom: 0;}
	
}

@media screen and ( max-width:567px ){
	.f_nav {width: 100%; margin: 0 auto 20px; min-height: inherit; max-width: 360px; float: none;}
	.footer01 {padding: 50px 0;}
	.f_nav li a {font-size: 16px;}
	.f-scroll {right: 1.5rem;}
	.f_info {width: 100%; margin: 0 auto 30px; float: none;}
	.f_btn01 {padding-top: 10px;}
	.footer03_in h3 {width: 48%; margin: 0 1% 10px; max-width: inherit;}
	.footer03_in h3 img {width: 100%;}

}

@media screen and ( max-width:450px ){
	.f_copy {font-size: 10px;}

	.footer_left h2 a img {width: 100px;}
	.footer_left h2 a {font-size: 19px; line-height: 52px;}
	.footer_left p {padding-bottom: 40px;}
	.sp_copy {font-size: 10px; letter-spacing: 1px;}
	
	.f_nav {max-width: 130px;}
	.f_nav_left {width: 100%; float: none;}
	.footer_right {width: 100%; float: none; padding-bottom: 30px;}
	
	
	.page_top a {right: 3%; top: auto;}
	.page_top.visible a {bottom: 30px;}
	.page_top a img {width: 70px;}
}












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

    news

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

.blog_pages {
	text-align: center;
	min-height: 26px;
	margin-bottom: 30px;
}

.blog_pages .page-numbers {
    border: solid 1px #a40001;
    padding: 4px 8px 4px;
    font-size: 12px;
    margin-right: 1px;
    color: #a40001;
	box-sizing: border-box;
}

.blog_pages .prev {
	padding: 4px 6px 4px;
}

.blog_pages .next {
	padding: 4px 6px 4px;
}

.blog_pages .current {
    border: solid 1px #a40001;
    padding: 4px 8px 4px;
    font-size: 12px;
    margin-right: 1px;
    color: #fff;
	background: #a40001;
	box-sizing: border-box;
}

a.page-numbers:hover {
	color: #fff;
	background: #a40001;
}

.blog_pages span,
.blog_pages a {
	font-family: 'Lato', sans-serif;
}


.news01 {padding: 0 0 80px;}






.single_wrap {
	padding: 30px 0 80px;
}

.single_wrap header {background: transparent !important;}

.single_img {
	padding-top: 0;
	margin-bottom: 30px;
	text-align: center;
}

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

.single_title {
	font-size: 28px;
	letter-spacing: 1px;
	display: block;
	line-height: 1.3;
	padding-bottom: 10px;
	margin-bottom: 20px;
	border-bottom: solid 1px #333;
}

.post-navigation {
	padding: 30px 0 10px;
}

.nav-links {
	overflow: hidden;
	width: 100%;
	box-sizing: border-box;
	padding: 20px 0;
}

.nav-links a {
	font-size: 12px;
	letter-spacing: 0;
}

.nav-links a:nth-of-type(1) {
	display: block;
	width: 50%;
	float: left;
	border-right: solid 1px #ccc;
	box-sizing: border-box;
	padding: 20px 10px 20px 0;
}

.nav-links a:nth-of-type(2) {
	display: block;
	width: 50%;
	float: right;
	text-align: right;
	box-sizing: border-box;
	padding: 20px 0 20px 10px;
}

.nav-links a:hover {
	color: #00a897;
}

.nav-links a span {
	font-size: 13px;
}

.nav-links a:hover span {
	color: #a40001;
}

.entry-content {
	padding-bottom: 30px;
	border-bottom: solid 5px #eee;
}

.cat-links {
	margin-bottom: 10px;
}

.cat-links a {
	display: inline-block;
    box-sizing: border-box;
    font-size: 12px;
    color: #a40001;
    letter-spacing: 1px;
    padding: 4px 10px;
    text-align: center;
    line-height: 1;
    width: 108px;
    border: solid 1px #a40001;
}

.single .entry-title {
	font-size: 28px;
	color: #a40001;
	padding-top: 10px;
	letter-spacing: 1px;
	font-weight: 700;
	margin-bottom: 15px;
}
.entry-date {padding-bottom: 10px;}

.byline {
	display: none;
	
}

.entry-date a {
	cursor:default;
}

.comments-link {
	display: none;
}

.edit-link {
	display: none;
}

.single .post-thumbnail {
	margin-bottom: 25px;
}

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

.single .entry-content {
	padding: 30px 0 20px;
	margin-top: 30px;
	border-top: solid 1px #ccc;
	clear: both;
	margin-bottom: 30px;
}

.single .entry-content p {
	font-size: 17px;
	line-height: 1.7;
	letter-spacing: 1px;
}

.entry-date {
	color: #888;
	float: right;
}

.wp-block-table tbody {
	border-top: solid 1px #eee;
    border-left: solid 1px #eee;
}

.single .btn01 a {width: 100%; margin: auto; float: none;}


@media screen and ( max-width:1366px ){
	.single .page_img_wrap {padding-top: 110px;}
	.news01 {padding: 0 0 50px;}
}

@media screen and ( max-width:991px ){
	.single .page_img_wrap {padding-top: 90px;}
	.single_wrap {padding-top: 40px;}
	.news01 {padding: 20px 0 20px;}
}

@media screen and ( max-width:767px ){
	.single .post-thumbnail img {height: 400px;}
	.single .breadcrumbs_wrap {margin-top: 66px;}
	.single .page_img_wrap {padding-top: 70px;}
	.single_wrap {padding-top: 20px;}
}

@media screen and ( max-width:567px ){
	.page-id-27 .news_list {margin-bottom: 30px;}
	.single .post-thumbnail img {height: 300px;}
	.single .entry-title {font-size: 23px; letter-spacing: 1px;}
	.single .entry-content {margin-top: 20px;}
	
	.news01 {padding: 10px 0 0;}
}

@media screen and ( max-width:500px ){
	.post-navigation {padding: 0;}
	.single .entry-content p {font-size: 15px;}
}

@media screen and ( max-width:450px ){
	.single_wrap {padding: 20px 0 20px;}
	.single .post-thumbnail img {height: 250px;}
	.single .entry-title {font-size: 22px; letter-spacing: 0;line-height: 1.4;}
	.nav-links a span {font-size: 12px;}
	.single .post-thumbnail {margin-bottom: 10px;}
	.entry-date {font-size: 13px;}
}















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

    メディアクエリ

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


.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;}
.max850 {display: none !important;}
.min851 {display: block !important;}
.max767 {display: none !important;}
.min768 {display: block !important;}
.max567 {display: none !important;}
.min568 {display: block !important;}
.max450 {display: none !important;}
.min451 {display: block !important;}




@media screen and ( min-width:1921px ){
	.top01_bottom_bg {width: 100%;}
	.top03 {background-size: contain, contain;}
	.top05 {background-size: contain, contain;}
}

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

}

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

@media screen and ( max-width:1680px ){
	.top01 {padding-top: 60px;}
}


@media screen and ( max-width:1536px ){
	
	.h_nav_wrap {max-width: 700px;}
	.h_nav_wrap nav li a {font-size: 17px;}
	.h_logo dt {width: 140px;}
	.h_logo dd {font-size: 24px;}

	.sp_right {width: 70px; height: 70px; padding: 22px 20px;}
	
	
	.c-scroll {height: 8.5rem;}
	.c-scroll a span {font-size: 10px;}
	.c-scroll__line {height: 4.5rem;}
	
	.top01_in03_box {min-height: 370px; padding: 28px 20px 16px;}
	.top01_in03_box_no {font-size: 46px;}
	.top01_in03_box_no span {font-size: 14px;}
	.top01_in03_box h3 {font-size: 30px;}
	.top01_in03_box p {font-size: 16px;}
	
	.top02_title02 {font-size: 32px;}
	.top02_b_text {font-size: 32px;}
	.top02_in02 {max-width: 1080px; margin: 0 auto 40px;}
	
	.top03_in01 {max-width: 1140px;}
	.top03_in01_img {max-width: 480px;}
}

@media screen and ( max-width:1366px ){
	.max1366 {display: block !important;}
	.min1367 {display: none !important;}

	
	.h_nav_wrap {max-width: 660px;}
	.header_top.fixed .h_nav_wrap {max-width: 640px;}

	.h_nav_wrap nav li a {font-size: 16px; margin-right: 5%;}
	.header_top.fixed .h_nav_wrap nav li a {font-size: 16px; margin-right: 4.5%;}
	
	
	.sp_menu {padding-top: 30px; min-height: 90px; width: 90px;}
	
	.menu-trigger p {font-size: 10px !important;}
	
	.sec_title01 {padding: 80px 0 25px;}
	.sec_title01 h2 {font-size: 40px; padding-bottom: 12px;}
	.sec_title01 p {font-size: 16px;}
	
	.top01_in01_title {max-width: 330px;}
	.top01_in01_text {padding-top: 50px;}
	.top01_in01_text h3 {font-size: 50px;}
	.top01_in02 .top01_in01_text {max-width: 600px;}
	
	.top01_in03_box {min-height: 340px;}
	.top01_in03_box_no {font-size: 40px; padding-bottom: 10px;}
	.top01_in03_box_no span {font-size: 13px;}
	.top01_in03_box h3 {font-size: 27px;}
	.top01_in03_box p {line-height: 1.5;}
	
	.top01_in04_img {max-width: 250px; width: 30%;}
	.top01_in04 {max-width: 900px;}
	.top01_in04_text {width: 67%;}
	.top01_bottom_bg {width: 1400px;}
	
	.sec_title02 {padding: 40px 0 20px 30px; margin-bottom: 10px;}
	.top01_in04_text p {font-size: 17px; padding-bottom: 20px;}
	.top01_in04_text h4 {font-size: 26px;}
	
	.top02 {background-size: 260px;}
	.top02_b_text {font-size: 29px;}
	
	.top03 {background-size: 1400px, 1400px; padding: 140px 0 140px; background-position: center top, center 100.01%;}
	
	.sec_title03 p {font-size: 16px; padding: 20px 0 12px; background-size: 74px;}
	.sec_title03 p span {font-size: 38px; top: 6px;}
	.sec_title03 h2 {font-size: 38px;}
	
	.top03_in02_text {width: 49%; padding-top: 20px; margin-right: 4%;}
	.top03_in02_text h3 {max-width: 540px;}
	.top03_in02_text p  {margin-bottom: 30px; padding-left: 0;}
	.top03_in02_text p br {display: none;}
	.top03_in02_text li {font-size: 19px;}
	.top03_in02_b_text h4 {font-size: 28px;}
	.top03_in02_img {padding-top: 50px;}
	
	.top03_in03 .top03_in02_text h3 {max-width: 420px;}
	.top03_in03_text_bottom h4 {font-size: 22px;}
	.top03_in03_text_bottom dt {width: 100px; font-size: 18px;}
	.top03_in03_text_bottom dd {padding-left: 13px; font-size: 20px;}
	.top03_in03_text_bottom dd img {width: 10px;}
	
	.top04_in01 h3 {font-size: 26px;}
	
	.btn01 a {font-size: 16px;}
	
	.top05 {background-size: 1400px, 1400px, 380px; background-position: center top, center 100.01%, right 35%;}
	.top05_in01 .sec_title01, .top05_in02 .sec_title01 {background-size: 120px;}
}

@media screen and ( max-width:1279px ){
	.max1279 {display: block !important;}
	.min1280 {display: none !important;}
	
}

@media screen and ( max-width:1199px ){
	.max1199 {display: block !important;}
	.min1200 {display: none !important;}
	
	.h_logo dt {width: 110px;}
	.h_logo dd {font-size: 20px;}
	
	.top01_in01_title::before {width: 45px;}
	.sec_title01 {padding: 60px 0 20px;}
	.sec_title01 h2 {font-size: 35px; padding-bottom: 12px;}
	.sec_title01 p {font-size: 15px;}
	.top01_in01_title .sec_title01 {max-width: 170px;}
	.top01_in01_title {max-width: 250px;}
	.top01_in02 .top01_in01_title {max-width: 210px;}
	.top01_in01_text {padding-top: 35px;}
	.top01_in01_text h3 {font-size: 45px;}
	.top01_in02 .top01_in01_text {max-width: 540px;}
	
	.top01_in03_box h3 {font-size: 24px;}
	
	.top03_in01_text h3 {font-size: 52px;}
	
	.top03_in01_img {width: 42%;}
	.top03_in01_text {width: 54%;}
	
	.top05_in01 .top01_in01_text {padding-top: 50px;}
}

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

@media screen and ( max-width:991px ){
	.max991 {display: block !important;}
	.min992 {display: none !important;}
	
	.h_logo {width: 70%; top: 14px; left: 15px;}
	.header_top.fixed .h_logo {left: 15px; top: 14px;}
	.h_nav_wrap {width: 28%;}
	.h_logo dt {width: 100px;}
	.h_logo dd {font-size: 18px; padding-left: 15px;}
	.header_top.fixed {position: absolute; background: transparent;}
	.header_top.fixed .h_logo dt {width: 100px;}
	.header_top.fixed .h_logo dd {font-size: 18px; padding-left: 15px;}
	
	.top01 {padding-top: 40px; background-size: 300px, 400px, cover;}
	.top01_in01_title {float: none !important; width: 100% !important; margin: 0 auto !important;}
	.top01_in01_title::before {display: none;}
	.top01_in01_text {float: none !important; max-width: 420px; width: 100% !important; margin: auto; padding-top: 0 !important;}
	.top01_in01_text h3 {text-align: center;}
	.top01_in02 .top01_in01_title .sec_title01 {float: none;}
	
	.top01_in01_title .sec_title01 {margin: auto;}
	.top01_in02 .top01_in01_text {margin: auto;}
	.top01_in01 {padding-bottom: 30px;}
	.sec_title01 {padding: 40px 0 10px; margin-bottom: 30px !important;}
	.top01_in01 .sec_title01 {margin-bottom: 10px !important;}
	.top01_in01_text h3 br {display: none;}
	
	.top01_in03_box {background-size: 80px; background-position: -30px -20px; width: 31.3%; margin: 0 1% 20px; min-height: 320px;}
	.top01_in03_box:nth-of-type(even) {margin-top: 0;}
	
	.top01_in03 {padding-bottom: 60px;}
	.top01_in04_text p {line-height: 1.6;}
	.top01_bottom_bg {width: 1000px; left: auto;}
	
	.sec_title02 h2 {font-size: 36px;}
	.sec_title02 h2 span {font-size: 16px; padding-left: 20px; bottom: 5px;}
	
	
	.top02 {background-size: 200px; padding-top: 30px;}
	.top02_title02 {font-size: 28px;}
	.top02_b_text {font-size: 24px;}
	.top02_text {font-size: 15px;}
	
	.top03 {background-size: 1000px, 1000px;}
	
	.top03_in01_text h3 {font-size: 48px; padding-bottom: 30px;}
	
	.top03_in02_img {float: none; width: 96%; padding-top: 10px;}
	.top03_in02_text {float: none; width: 88%; margin: auto; max-width: 640px; padding-top: 30px;}
	.top03_in03 .top03_in02_img {float: none; width: 88%; margin: 0 auto;max-width: 560px; padding-top: 0;} 
	.top03_in03 .top03_in02_text {float: none; width: 88%; margin: 0 auto;}
	.top03_in02 {margin-bottom: 70px;}
	.top03_in03 .top03_in02_text h3 {margin: 0 auto 35px;}
	
	.top04 .sec_title01 {margin-bottom: 20px !important;}
	.top04 .top04_in02 .sec_title01 {margin-bottom: 0 !important;}
	.top04_in01 {padding-bottom: 30px;}
	
	.top05 {background-size: 1000px, 1000px, 280px; padding: 100px 0 130px;}
	
	.top05_in01 .top01_in01_text {max-width: 650px;}
	.top05_in01 .top01_in01_text p {padding: 25px 0 35px;}
	.top05_in01 {width: 100%;}
	
}

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

@media screen and ( max-width:767px ){
	.max767 {display: block !important;}
	.min768 {display: none !important;}

	.main_img_wrap {padding-bottom: 0; height: 680px;}
	.main_img {right: 0; width: 250px;}
	.main_text01 {left: 0; right: 0; margin: auto; width: 86%; max-width: 400px; top: 120px;}
	.main_text02 {z-index: 100; top: 240px; left: 0; right: 0; margin: auto; width: 72%; max-width: 330px;}
	
	.top01 {background-position: 0 26%, right 74%, center top; background-size: 200px, 300px, cover;}
	.top01_in03_box {width: 46%; margin: 0 2% 20px; min-height: 290px;}
	
	.top01_in04_text {float: none; width: 100%; margin: 0 auto 30px; padding-top: 0;}
	.top01_in04_img {float: none; width: 100%; margin: 0 auto;}
	
	.top01_in04_text p {padding-left: 0;}
	.top01_in04_text h4 {padding-left: 0; text-align: right;}
	
	.top02_box {width: 50%; margin: 0 auto 20px;}
	
	.top03 {padding: 100px 0 100px;}
	.top03_in01_img {float: none; width: 90%; margin: 0 auto; max-width: 300px;}
	.top03_in01_text  {float: none; width: 100%; margin: 0 auto;}
	.top03_in01_text h3 {font-size: 41px; padding-bottom: 25px; padding-left: 0;}
	.top03_in01_text p {padding-left: 0;}
	
	.sec_title03 {margin-bottom: 30px;}
	.sec_title03 h2 {font-size: 30px;}
	.sec_title03 p {font-size: 14px; padding: 16px 0 9px; background-size: 58px;}
	.sec_title03 p span {font-size: 30px; top: 4px; padding-left: 4px;}
	
	.top04_in01_in p {width: 31.3%; margin: 0 1% 12px;}
	.top05_in02_info p {font-size: 15px;}
	.top05_in02_info h3 a {font-size: 30px;}
	
}

@media screen and ( max-width:567px ){	
	.max567 {display: block !important;}
	.min568 {display: none !important;}
	
	.sp_menu_in {max-width: 280px;}
	.sp_menu_in li a {font-size: 25px;}
	.sp_menu_tel a {font-size: 26px;}
	
	.top01 {background-position: 0 19%, right 96%, center top; background-size: 160px, 220px, cover;}
	
	.top01_in01_text h3 {font-size: 38px;}
	.top01_in01_text {max-width: 350px;}
	.top01_in02 .top01_in01_text {max-width: 460px;}
	
	.sec_title01 h2 {font-size: 28px;}
	.sec_title01 p {font-size: 14px;}
	
	.top01_in03_box_no {font-size: 34px;}
	.top01_in03_box_no span {font-size: 12px;}
	
	.sec_title02 {padding-left: 0; background-position: center center;}
	.sec_title02 h2 {font-size: 28px; text-align: center; }
	.sec_title02 h2 span {font-size: 14px; padding-left: 0; bottom: 0; display: block; text-align: center; padding-top: 10px;}
	
	.top02_title02 {text-align: left; font-size: 26px;}
	.top02_text {text-align: left;}
	.top02_b_text {text-align: left; font-size: 22px;}
	.top02_b_text br {display: none;}
	.top02_in02 {margin-bottom: 20px;}
	
	.top03 {background-size: 700px, 700px; background-position: center top, center 100.01%;}
	
	.top03_in02_text li {font-size: 17px; background-size: 34px; padding: 6px 0 6px 42px; margin-bottom: 2px;}
	.top03_in02_b_text {width: 88%; margin: auto;}
	.top03_in02_b_text h4 {font-size: 22px; text-align: left; padding-top: 30px;}
	.top03_in02_text p {font-size: 15px;}
	
	.top03_in03 {margin-bottom: 20px;}
	.top03_in03 .top03_in02_img {width: 92%;}
	.top03_in03 .top03_in02_text {width: 100%;}
	.top03_in03_text_bottom dt {font-size: 17px;}
	.top03_in03_text_bottom dd {font-size: 18px;}
	
	.top04_in01 h3 {font-size: 20px;}
	.top04_in01_in p {width: 47%; margin: 0 1.5% 10px;}
	
	.top05 {background-size: 700px, 700px, 180px; padding: 70px 0 80px;}
	.top05_in02 {padding-top: 20px;}
	.top05_in01 .sec_title01, .top05_in02 .sec_title01 {background-size: 100px;}
	.top05_in02_text {font-size: 16px;}
	.top05_in03_title {font-size: 22px;}
	.top05_in01 .top01_in01_text p {font-size: 15px;}
}

@media screen and ( max-width:500px ){
	.h_logo dt {width:80px;}
	.h_logo dd {font-size: 16px;}
	.header_top.fixed .h_logo dt {width:80px;}
	.header_top.fixed .h_logo dd {font-size: 16px;}
	
	.top01_in03_box {float: none; width: 100%; margin: 0 auto 20px; min-height: inherit; padding-bottom: 25px;}
	.top01_in03_box h3 {font-size: 28px;}
	.top01_in03 {padding-top: 0; padding-bottom: 20px;}
	
	.top01_in04_img {max-width: 200px;}
	.top01_bottom_bg {left: 0; width: 600px;}
	
	.top02 {background-position: left -2%;}
	
	.top03_in03_text_bottom dt {display: table; width: 100%; margin: 0 auto;}
	.top03_in03_text_bottom dd {display: table; width: 100%; margin: 0 auto; padding: 10px;}
	
	.top04_in01 h3 {text-align: left;}
	
	.top05_in02_info {padding: 16px 10px;}
	.top05_in02_info h3 a {font-size: 25px;}
}

@media screen and ( max-width:450px ){
	.max450 {display: block !important;}
	.min451 {display: none !important;}

	.main_text01 {width: 86%; top: 150px;}
	.main_text02 {top: 260px;width: 72%;}
	
	.top01_in01_text h3 {text-align: left; font-size: 34px;}
	
	.sec_title03 h2 {font-size: 27px;}
	.top03_in01_text h3 {font-size: 39px;}
	.top03_in01_img {max-width: 240px;}
}

@media screen and ( max-width:360px ){
	.main_text01 {top: 110px;}
	.h_logo dt {width:80px;}
	.h_logo dd {font-size: 16px;}
}

@media screen and ( max-width:325px ){	
	.main_text01 {top: 120px;}
	.h_logo dt {width:70px;}
	.h_logo dd {font-size: 15px;}
	
}

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





























