@charset "utf-8";

html,
body{
	font-family:var(--default-font);
	font-optical-sizing:auto;
	width:100%;
	font-size:0.95em; line-height:1.8; font-weight:var(--normal);
	color:var(--base-color);
	letter-spacing:0.06em;
	text-align:left;
	min-width:1280px;
	-webkit-text-size-adjust:100%;
  	background-color:#fff;
	overflow-wrap:break-word !important;
	word-wrap:break-word !important;
	font-feature-settings: "palt";
	scroll-behavior: smooth;
}

h1,h2,h3,h4,strong{
	font-weight:var(--bold);
}
:where(figure) {
    margin-bottom:0;
}
.eng{font-family:var(--eng-font);}
.num{font-size:1.1em;}

.size120{font-size:1.2em; line-height:1.8;}
.size110{font-size:1.1em; line-height:1.8;}
.size90{font-size:0.9em; line-height:1.8;}
.size85{font-size:0.85em; line-height:1.8;}
.size80{font-size:0.8em; line-height:1.8;}

.mt0{margin-top:0px !important;}
.mt5{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;}
.mt45{margin-top:45px !important;}
.mt50{margin-top:50px !important;}

.mb0{margin-bottom:0px !important;}
.mb5{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;}
.mb45{margin-bottom:45px !important;}
.mb50{margin-bottom:50px !important;}
.mb60{margin-bottom:60px !important;}

ul.li-mb0 > li,
ol.li-mb0 > li{margin-bottom:0px !important;}
ul.li-mb5 > li,
ol.li-mb5 > li{margin-bottom:5px !important;}
ul.li-mb10 > li,
ol.li-mb10 > li{margin-bottom:10px !important;}
ul.li-mb15 > li,
ol.li-mb15 > li{margin-bottom:15px !important;}
ul.li-mb20 > li,
ol.li-mb20 > li{margin-bottom:20px !important;}
ul.li-mb25 > li,
ol.li-mb25 > li{margin-bottom:25px !important;}
ul.li-mb30 > li,
ol.li-mb30 > li{margin-bottom:30px !important;}
ul.li-mb35 > li,
ol.li-mb35 > li{margin-bottom:35px !important;}
ul.li-mb40 > li,
ol.li-mb40 > li{margin-bottom:40px !important;}
ul.li-mb45 > li,
ol.li-mb45 > li{margin-bottom:45px !important;}
ul.li-mb50 > li,
ol.li-mb50 > li{margin-bottom:50px !important;}

ul.li-mb0 > li:last-child,
ol.li-mb0 > li:last-child,
ul.li-mb5 > li:last-child,
ol.li-mb5 > li:last-child,
ul.li-mb10 > li:last-child,
ol.li-mb10 > li:last-child,
ul.li-mb15 > li:last-child,
ol.li-mb15 > li:last-child,
ul.li-mb20 > li:last-child,
ol.li-mb20 > li:last-child,
ul.li-mb25 > li:last-child,
ol.li-mb25 > li:last-child,
ul.li-mb30 > li:last-child,
ol.li-mb30 > li:last-child,
ul.li-mb35 > li:last-child,
ol.li-mb35 > li:last-child,
ul.li-mb40 > li:last-child,
ol.li-mb40 > li:last-child,
ul.li-mb45 > li:last-child,
ol.li-mb45 > li:last-child,
ul.li-mb50 > li:last-child,
ol.li-mb50 > li:last-child{margin-bottom:0px !important;}

a{
	color:var(--link-color);
	text-decoration:none;
}
a:hover{
	text-decoration:underline;
}

a.tel-link{
	color:var(--base-color);
	text-decoration:none;
	pointer-events:none;
}
a.pdf-link::after,
a.excel-link::after,
a.word-link::after{
	font-family:var(--bootstrap);
	display:inline-block;
	width:1em; height:auto;
	margin:0 0 0 0.3em;
	position:relative;
	top:3px;
}
a.pdf-link::after{
	content:"\F63E";
	color:#AD0B00;
}
a.excel-link::after{
	content:"\F368";
	color:#016E38;
}
a.word-link::after{
	content:"\F38D";
	color:#2A5698;
}
a.website-link::after{
	content:"";
	background:url(../../img/svg/link.svg) no-repeat center center;
	background-size:contain;
	display:inline-block;
	margin:0 0 0 0.2em;
	width:18px; height:18px;
	position:relative;
	top:0.2em;
}

.left,
.alignleft{
	float:left;
	margin:0 20px 20px 0;
}
.right,
.alignright{
	float:right;
	margin:0 0 20px 20px;
}
.aligncenter{
	margin:0 auto 20px auto !important;
	text-align:center !important;
	display:inlne-block;
}

.flex{display:flex;}
.flex-between{justify-content:space-between;}
.flex-center{justify-content:center !important;}
.flex-wrap{flex-wrap:wrap;}
.flex-reverse{flex-direction:row-reverse;}
.flex > .text-box{flex:1;}

.hissu{color:#FF0000 !important;}
.pc-block{display:block !important;}
.pc-none{display:none !important;}
.schema-data{display:none !important;}
.red{color:#dd0000 !important;}

.no-pointer{pointer-events:none;}

ul.disc-list > li{
  list-style:disc outside;
}
ol.decimal-list > li{
  list-style:decimal outside;
}
ul.disc-list > li,
ol.decimal-list > li{
  margin-left:1.25em;
}
ul.kigou-list > li{
  position:relative;
  padding-left:1.25em;
}
ul.kigou-list > li::before{
  content:"※";
  position:absolute;
  top:0; left:0;
}

/* form reset
++++++++++++++++++++++++++++++*/
input[type="text"],
input[type="number"],
input[type="tel"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="button"],
select,
textarea{
	box-sizing:border-box;
	margin:0; padding:0;
	outline:none;
	-webkit-appearance:none;
	appearance:none;
	border-radius:3px;
	outline:none;
	background:#fff;
	border:2px solid #111;
	border-radius: 10px;
	width:100%;
	font-size:1em; line-height:1.8;
	font-family: var(--default-font);
	color:var(--base-color);
}
input[type="submit"]{
	border:none;
	font-size:1em; line-height:1.8;
	font-family: var(--default-font);
	font-weight: 700;
}

input[type="text"],
input[type="number"],
input[type="tel"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
select{
	height:38px;
	text-indent:1.0em;
}
select::-ms-expand{
  display:none;
}
select:-moz-focusring{
  color:transparent;
  text-shadow:0 0 0 #828c9a;
}
textarea{
	height:200px;
	margin:0;
	padding:1em;
}
input[type="submit"],
input[type="button"]{
	display:block;
	margin:0 auto;
	width:300px; height:48px;
	/*border-color:var(--main-color);*/
	border-radius:24px;
	cursor:pointer;
	transition:0.3s;
}
input[type="submit"]:hover,
input[type="button"]:hover{
	color:#FFF;
	background-color:var(--main-color);
	border-color:var(--main-color);
	transition:0.3s;
}
input[type="submit"]:disabled{
	/*border-color:#ccc;*/
	border:none;
	color:#666;
	background:#ccc;
	cursor:not-allowed;
	transition:0.3s;
}

.select-wrapper{
	box-sizing:border-box;
	height:42px;
	overflow:hidden;
	background:#fcfcfc;
	border:2px solid #111;
	border-radius:20px;
	position:relative;
}
.select-wrapper select{
	width:110%;
	border:none;
	background:transparent;
	position:relative; z-index:2;
}
.select-wrapper::before{
	content:"";
	border-top:6px solid var(--main-color);
	border-left:6px solid transparent;
	border-right:6px solid transparent;
	position:absolute;
	top:50%; right:10px;
	transform:translateY(-50%);
}
input::placeholder{
	font-size:0.95em;
	color:#999 !important;
}

input:focus::-webkit-input-placeholder{color:transparent !important;}
input:focus::-moz-placeholder{color:transparent !important;}
input:focus::-ms-input-placeholder{color:transparent !important;}
input:focus::placeholder{color:transparent !important;}


/* initialize
++++++++++++++++++++++++++++++*/
*{margin:0; padding:0; font-style:normal;}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section{
	display: block;
}

img{border:none; display:block;}

.left{float:left; display:inline;}
.left img{margin-right:20px;}

.right{float:right; display:inline;}

.align-left{text-align:left;}
.align-right{text-align:right;}
.align-center{text-align:center;}

.clear{clear:both; display:block;}

li{list-style:none;}


/* clearfix
++++++++++++++++++++++++++++++*/
.clearfix:after{
	content:" ";
	display:block;
	clear:both;
	height:0;
	visibility:hidden;
}

.clearfix{display:inline-block;}

/* Hides from IE-mac */
* html .clearfix{height:1%;}
.clearfix{display:block;}
/* End hides from IE-mac */

/*#scrollUp{
	bottom:84px; right:10px;
	width:48px; height:48px;
	text-indent:-9999px;
	background:rgba(214,9,16,0.2);
	border-radius:100%;
	position:relative;
}
#scrollUp::before{
	content:"";
	width:48px; height:48px;
	background-image:url(../../img/arrow-up.svg);
	background-repeat:no-repeat;
	background-position:center center;
	background-size:24px auto;
	position:absolute;
	top:0; left:0;
}
a#scrollUp:hover{border:none;}
*/

/* pagenavi
++++++++++++++++++++++++++++++*/
.pagenavi-box{
  margin-top:30px;
}
.pagenavi-box > .wp-pagenavi{
  padding:0 !important;
  float:none !important;
  display:flex !important;
  flex-wrap:wrap;
	justify-content:center;
}
.pagenavi-box > .wp-pagenavi a,
.pagenavi-box > .wp-pagenavi span.pages,
.pagenavi-box > .wp-pagenavi span.extend,
.pagenavi-box > .wp-pagenavi span.current{
  padding:2px 10px !important;
	font-size:0.8rem !important;
	border-radius:0.2rem;
}

/* slick reset
++++++++++++++++++++++++++++++*/
.slick-container{
	position:relative;
	width:100%;
}
/* 同じクラス名のdivとbuttonが重なっているので注意
	divは無効化、buttonの背景に::beforeでアイコンを配置 */
.slick-container .slick-prev,
.slick-container .slick-next{
	display:block;
	font-size:0; line-height:0;
	position:absolute;
	top:50%; z-index:1;
	width:42px; height:auto;
	aspect-ratio:1/1;
	padding:0;
	margin:0;
	transform:translate(0,-50%);
	cursor:pointer;
	color:transparent;
	border:none;
	outline:none;
	background:transparent;
/* 大きさ width は適宜指定。font-size:0;のため、remで指定 */
}
.slick-container div.slick-prev,
.slick-container div.slick-next{

}
.swiper-wrapper .pager_prev,
.swiper-wrapper .pager_next{
	z-index:10;
	position: absolute;
	top:45%;
}
.swiper-wrapper .pager_prev{
	left:calc((100% - 900px) / 2);}
.swiper-wrapper .pager_prev{
	right:calc((100% - 900px) / 2);}
.swiper-wrapper .pager_prev::before,
.swiper-wrapper .pager_next::before{
	width: 43px;
    height: 43px;
	opacity: 1;
    z-index:10;
	position: absolute;
}
.swiper-wrapper .pager_prev::after{
	content:'';
	transform:translate(-110%,-48%); top:50%;
	background-image: url(../../img/index/arrow.svg);
	background-repeat: no-repeat;
	background-size: contain;
	aspect-ratio: 1/1;
	width:30px;
	height:auto;
	display: inline-block;
	z-index:100;
	position: absolute;
}
/*.slick-container button.slick-next::before{
	content:'';
	transform:translateX(-10%); top:0;
	background-image: url(../../img/index/arrow_right.png);
	background-repeat: no-repeat;
	background-size: contain;
}
	*/
.swiper-wrapper .pager_prev::before{
	content:'';
	transform:translateX(-90%); top:0;
	background-color:#fff;
	background-repeat: no-repeat;
	border-radius: 999px;
	border:1px solid #999;
	aspect-ratio: 1/1;
	width:43px; height:auto;
}
.swiper-wrapper .pager_next::before{
	content:'';
	 top:0;
	background-color:#fff;
	background-repeat: no-repeat;
	border-radius: 999px;
	border:1px solid #999;
	aspect-ratio: 1/1;
	width:43px; height:auto;
}
.swiper-wrapper .pager_next::after{
	content:'';
	transform:translate(25%,-49%) rotate(180deg); top:50%;
	background-image: url(../../img/index/arrow.svg);
	background-repeat: no-repeat;
	background-size: contain;
	aspect-ratio: 1/1;
	width:30px;
	height:auto;
	display: inline-block;
	z-index:100;
	position: absolute;
}
.slick-container div.slick-prev::before,
.slick-container div.slick-next::before{
	content:"";
	display:none;
}
.slick-slider{
	margin-bottom:0 !important;
}