@charset "utf-8";

/*----- reset -----*/
html{font-size:62.5%;height:100%;}
body{margin:0;padding:0;font-size:1.7rem;font-family:YakuHanJP,'BIZ UDPGothic','Noto Sans CJK JP','Noto Sans JP',sans-serif;line-height:1.5;color:#333;height:100%;position:relative;letter-spacing:0;overflow-wrap:break-word;word-wrap:break-word;-webkit-text-size-adjust:100%;background:#fff;width:auto;}
header,main,article,section,nav,footer{display:block;}
div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin:0;padding:0;font-size:100%;}
textarea, select{font-family:YakuHanJP,'BIZ UDPGothic','Noto Sans CJK JP','Noto Sans JP',sans-serif;}
input{font-family:YakuHanJP,'BIZ UDPGothic','Noto Sans CJK JP','Noto Sans JP',sans-serif;line-height:1.5;color:#333;position:relative;letter-spacing:0.1em;overflow-wrap:break-word;word-wrap:break-word;}
table{border-collapse:collapse;border-spacing:0;}
fieldset,img{border: 0;}
address,caption,cite,code,dfn,th,var{font-style:normal;font-weight:normal;}
em{font-style:normal;font-weight:500;}
ol,ul{list-style: none;}
caption{text-align:left;}
h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal;}
q:before,q:after{content:'';}
abbr,acronym{border:0;}
input[type="text"],input[type="submit"],input[type="email"],input[type="tel"],select{-webkit-appearance:none;appearance:none;border-radius:0;border:none;background:none;}
select::-ms-expand{display:none;}

*, *::before, *::after{box-sizing:border-box;}
/*----- reset end -----*/
:root{
	--vw-100:100vw;
	--vw-50:calc(var(--vw-100)*.5);
	/* --dd-height:70px; */
}

html{visibility:hidden;}
html.wf-active, html.wf-inactive{visibility:visible;}

#wrapper{overflow:hidden;}

.sp_size{display:none !important;}


/*----- header -----*/
#header_wrap{
    border-bottom: 1px solid #e5e5e5;
	margin:auto;
}
.header-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
	max-width: 1140px;
    padding: 0 20px;
    margin: 17px auto 0;
}
.logo {
    width: 270px;
}
.logo_link, .logo_img{
	display:block;
	width:100%;
}
#toggle{display:none;}
#menu{
	display:flex;
	align-items:center;
}
.menu_list{
	display:flex;
	padding:0;
	margin:10px 0 0;
}
.menu_item{
	list-style:none;
	margin-right:20px;
}
.menu_link{
	position:relative;
	display:block;
	padding-bottom:10px;
	color:#333;
	font-weight:bold;
	text-decoration:none;
	transition:color 0.3s;
}
/* .on .menu_link{color:#0cc;}
.menu_link::after{
	content:'';
	display:block;
	position:absolute;
	bottom:0;
	left:0;
	width:0;
	height:3px;
	background:#0cc;
	transition:width 0.3s;
}
.on .menu_link::after{width:100%;} */
.header-links {
	display: flex;
	gap: 20px;
	font-size: 1.5rem;
	font-weight: bold;
	align-items: center;
}
.header-links a {
	text-decoration: none;
	margin-top: 2px;
	color:#333 !important;
}
.header-links a:hover {
	text-decoration: underline;
}
.search a {
    display: block;
    font-weight: 400;
    padding: 7px 10px 6px 15px;
    width: 230px;
    border: 1px solid #DDDDDD;
    background: #F5F5F5 url(/img/index/icon_search.svg) no-repeat center right 15px;
    border-radius: 20px;
}
/* ===== Global Nav ===== */
.gnav {
	margin: 17px auto;
	max-width: 1140px;
	padding: 0 20px;
}
.gnav-list {
	display: grid;
	margin: 0 auto;
	grid-template-columns: repeat(3, 1fr);
    grid-gap: 30px;
	padding-left: 0;
}
.gnav-item {
	position: relative;
	flex: 1;
	list-style: none;
	margin-bottom: 0;
}
.gnav-btn {
	display: block;
	position: relative;
	width: 100%;
	padding: 10px 16px 14px;
	font-size: 2rem;
	font-weight: bold;
	background: none;
	border: 1px solid #AAA;
	border-radius: 8px;
	cursor: pointer;
	color: #333;
}
.gnav-btn::after {
    content: '';
    position: absolute;
    right: 19px;
    top: 20px;
    width: 14px;
    background: url(/img/index/icon_sankaku.svg) no-repeat center left;
    height: 14px;
}
.gnav-btn:hover {
	background: #fff5f3;
}
	.gnav-item.active .gnav-btn::after {
	transform: rotate(180deg);
}

/* Mega Menu Dropdown */
.gnav-dropdown {
	position: absolute;
	top:calc(100% + 10px);
	left: 0;
	width: 100%;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: all 0.3s ease;
	z-index: 100;
	background:#FFF3F8;
	padding:10px 20px 20px;
	border-radius:8px;
	box-shadow:0 0 5px rgba(0,0,0,0.1);
}
.gnav-btn.is-open + .gnav-dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}
.gnav-dropdown a {
	display: block;
	font-size:1.7rem;
	color:#2444BB;
	margin-top:10px;
}


/*----- search -----*/
.modal_open{
	display:block;
	width:50px;
	height:50px;
	border-radius:10px;
	cursor:pointer;
	text-decoration:none;
	transition:opacity 0.3s;
}
.modal_txt{
	display:block;
	position:relative;
	height:100%;
	background:url(/img/common/search.svg) no-repeat center/30px;
	border-radius:10px;
	font-size:0;
}
.modal_content{
	position:fixed;
	display:none;
	z-index:5000;
	text-align:center;
	width:526px;
}
.search_box{
	position:relative;
	width:100%;
	background:#fff;
}
.search_txt{
	display:block;
	width:100%;
	padding:20px 60px 19px 20px;
	background:none;
	border:none;
	box-sizing:border-box;
	font-size:1.8rem;
}
.search_txt::placeholder{color:#aaa;}
.search_btn{
	display:block;
	position:absolute;
	top:0;
	right:0;
	font-size:0;
	width:60px;
	height:69px;
	background:url(/img/common/search.svg) no-repeat center/30px;
	border:none;
	cursor:pointer;
}
#s_overlay{
	display: none;
	position:fixed;
	z-index:3000;
	top:0;
	left:0;
	width:100%;
	height:120%;
	background-color:rgba(0,0,0,0.85);
}


/*----- footer -----*/
#return{
	position:relative;
	z-index:1000;
}
.return_btn{
	display:block;
	position:fixed;
	right:20px;
	bottom:20px;
	width:60px;
	height:60px;
	background:#000;
	border-radius:10px;
	text-decoration:none;
	transition:background 0.3s;
}
.return_btn::after{
	content:'';
	display:block;
	position:absolute;
	top:8px;
	right:0;
	bottom:0;
	left:0;
	margin:auto;
	width:13px;
	height:13px;
	border-top:1px solid #fff;
	border-right:1px solid #fff;
	transform:rotate(-45deg);
}
.return_txt{display:none;}


/*----- main -----*/
a, a:visited{
	color:#2444BB;
	text-decoration:underline;
}
a[target="_blank"]{
	padding-left:20px;
	background:url(/img/common/popup.svg) no-repeat center left;
}
a.non[target="_blank"]{
	padding-left:0;
	background:none;
}
a[href$=".doc"], a[href$=".docx"]{
	padding-left:20px;
	background:url(/img/common/icon_word.svg) no-repeat center left;
}
a[href$=".xls"], a[href$=".xlsx"]{
	padding-left:20px;
	background:url(/img/common/icon_excel.svg) no-repeat center left;
}
a[href$=".pdf"]{
	padding-left:20px;
	background:url(/img/common/icon_pdf.svg) no-repeat center left;
}
a.none[href$=".pdf"]{
	padding-left:0;
	background:none;
}
[href^="tel:"]{
	color:#333 !important;
	pointer-events:none;
}

img{
	display:block;
	max-width:100%;
	width:auto;
	height:auto;
	-webkit-backface-visibility:hidden;
	backface-visibility:hidden;
}
a img{pointer-events:none;}


#index_wrap {
	max-width: 1140px;
	margin: auto;
	padding: 0 20px;
}
.important-notice-section {
	margin-bottom: 79px;
}
.index_slide {
    margin: 0 auto 32px;
}
.important-notice {
	background: #FFECEC;
	padding: 27px 34px 21px;
	border-left: 6px solid #D21E00;
	border-radius: 4px;
}
.important-notice h2 {
    font-size: 2.2rem;
    font-weight: bold;
    margin-bottom: 10px;
}
.important-notice ul li{
	color: #D21E00;
	text-decoration: underline;
	margin-bottom: 11px;
}

#footer_wrap {
    position: relative;
}
.footer_img {
    display: block;
    width: 100%;
    height: 260px;
    object-fit: cover;
    object-position: center;
}
.footer_img2{
	margin: auto;
}
.footer_pagetop {
    position: absolute;
	right: 20px;
	width: 120px;
    cursor: pointer;
}
.copy_txt {
    font-size: 1.1rem;
    color: #fff;
	padding: 16px 0 18px;
    display: block;
}
.copyright {
    text-align: center;
    background: #006DBF;
}

.footer_pagetop {
    position: fixed;
    right: 20px;
    bottom: 20px;
    width: 120px;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
    z-index: 100;
}

.footer_pagetop.is-show {
    opacity: 1;
    visibility: visible;
}





@media (hover:hover){

.menu_link:hover{color:#0cc;}
.menu_link:hover::after{width:100%;}
.modal_open:hover{opacity:0.5;}
.return_btn:hover{background:#666;}
a:hover{text-decoration:none;}

}


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

/*----- header -----*/



/*----- footer -----*/

}


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

#wrapper.fixed{
	position:fixed;
	top:0;
	right:0;
	bottom:0;
	left:0;
}

.pc_size{display:none !important;}
.sp_size{display:block !important;}


/*----- header -----*/
#toggle{display:block;}
.toggle_btn{
	position:relative;
	display:flex;
	align-items:center;
	justify-content:center;
	width:60px;
	height:60px;
	font-size:0;
	text-decoration:none;
}
.toggle_txt{
	position:relative;
	display:block;
	width:60px;
	height:60px;
	background:#000;
}
.toggle_btn::before, .toggle_btn::after, .toggle_txt::before{
	content:'';
	display:block;
	position:absolute;
	z-index:10;
	left:0;
	right:0;
	margin:auto;
	width:18px;
	height:2px;
	background:#fff;
	transition:all 0.3s;
}
.toggle_btn::before{top:19px;}
.toggle_btn::after{top:33px;}
.toggle_txt::before{top:20px;}
.toggle_btn.open::before{
	top:26px;
	transform:rotate(135deg);
}
.toggle_btn.open::after{
	top:26px;
	transform:rotate(-135deg);
}
.open .toggle_txt::before{
	opacity:0;
	visibility:hidden;
}
#menu_box{
	display:block;
	position:fixed;
	z-index:50;
	top:80px;
	right:0;
	bottom:0;
	left:0;
	width:100%;
	height:100%;
	overflow:auto;
	-webkit-overflow-scrolling:touch;
}
.menu_dis{display:none !important;}
#menu{
	display:block;
	height:100%;
	background:#000;
}
.menu_list{
	display:block;
	margin:0 auto 30px;
}
.menu_item{
	margin:0;
	border-bottom:1px solid #fff;
}
.menu_link{
	padding:10px 20px;
	color:#fff;
	font-size:1.4rem;
}
.menu_link::after{
	top:0;
	right:20px;
	left:auto;
	margin:auto;
	width:8px !important;
	height:8px;
	background:none;
	border-top:2px solid #fff;
	border-right:2px solid #fff;
	transform:rotate(45deg) !important;
}

/*----- search -----*/
#search{
	position:relative;
	z-index:200;
	left:0;
	right:0;
	margin:0 auto;
	width:calc(100% - 60px);
}
.modal_open{display:none;}
.modal_content{
	position:relative;
	display:block;
	width:100%;
	border-radius:10px;
	overflow:hidden;
}
.search_txt{
	padding:11px 56px 12px 15px;
	font-size:1.6rem;
}
.search_btn{
	width:56px;
	height:47px;
}


/*----- footer -----*/


/*----- main -----*/
[href^="tel:"]{
	text-decoration:underline;
	pointer-events:auto;
}

}


/*----- print -----*/
@media print{
	:root{--vw-100:1200px;}
	body{
		width:1200px;
		transform:scale(1);
		-moz-transform:scale(1);
		-webkit-transform:scale(1);
		transform-origin:0 0;
		zoom:.91;
		margin:auto
	}
	@media all and (-ms-high-contrast:none){
		body{width:1200px}
	}
	@media (-ms-high-contrast:none),(-ms-high-contrast:active){
		body{width:1200px}
	}
	@media all and (-webkit-min-device-pixel-ratio:0) and (min-resolution:.001dpcm){
		body{
			width:1200px;
			transform:scale(.8);
			-moz-transform:scale(.8);
			-webkit-transform:scale(.8);
			transform-origin:0 0;
			margin:auto
		}
	}
}
/*----- print end -----*/