@charset "UTF-8";
/* base.css | 2025.11.03 改修 */


/*///////////////////////////////////
Header
///////////////////////////////////*/
#header { width: 100%; z-index: 100; position: fixed; top: 0; left: 0; transition: 0.8s ease-out;}
#header .mainbox { display: flex; align-items: center; justify-content: flex-end; height: 130px; position: relative; transition: 0.6s; }
#header .logo { line-height: 0; position: fixed; left: 50px; top: 32px; transition: 0.3s; }
#header .logo img { width: clamp(100px, calc(100px + (142px - 100px) * var(--fluid)), 142px); }
#header .logo img:nth-child(1) { display: none;}
#index #header .logo img:nth-child(1) { display: block;}
#index #header .logo img:nth-child(2) { display: none;}
/* スクロール時fixed */
#header.fixed .logo { top: 12px; left: 40px; }
#header.fixed .mainbox{ height: 80px; background: var(--c-brown); }
#header.fixed .logo img { width: 110px; }
#header.fixed .logo img:nth-child(1) { display: block;}
#header.fixed .logo img:nth-child(2) { display: none;}
@media screen and (max-width: 1100px) {
	#index #header .logo { display: block; }
	#header .logo { top: 30px; left: 40px; }
}
@media screen and (max-width: 500px) {
	#header .logo { top: 20px; left: 20px; }
	#header.fixed .logo { top: 10px; left: 20px; }
	#header.fixed .mainbox{ height: 70px;}
	#header.fixed .logo img { width: 100px; }
}



/*///////////////////////////////////
Nav
///////////////////////////////////*/
#gnav { z-index: 101; margin-right: 110px; }
#gnav .navbox {  }
#gnav ul.main { display: flex; letter-spacing: 0.1em; align-items: center;}
#gnav ul.main>li { margin-left: 1.2em; margin-bottom: 5px;}
#gnav ul.main>li a { font-size: clamp(var(--fs-lg-min), calc(var(--fs-lg-min) + (var(--fs-lg-max) - var(--fs-lg-min)) * var(--fluid)), var(--fs-lg-max)); line-height: 2.2; letter-spacing: var(--ls-xs);}
#gnav ul.main>li.insta { display: flex; justify-content: center; align-items: center; margin-bottom: 0;}
#gnav ul.main>li.insta a { width: 34px; height: 34px; display: block; position: relative; }
#gnav ul.main>li.insta a img { width: 34px; height: 34px; position: absolute; top: 0; left: 0; transition: opacity .5s;}
#gnav ul.main>li.insta a img:last-child { opacity: 0; }
#gnav ul.main>li.insta a:hover img:first-child { opacity: 0; }
#gnav ul.main>li.insta a:hover img:last-child { opacity: 1; }
#gnav ul.main>li.contact { margin-left: 0.5em; margin-bottom: 0;}
#gnav ul.main>li.contact a { padding: 0.3em 1em; border-radius: 24px; background-color: var(--c-white); border: 1px solid var(--c-base); }
#gnav ul.main>li.contact a:hover { background-color: var(--c-base); color: var(--c-white);}
#header.fixed #gnav ul.main>li a { font-size: 18px; }
#header.fixed #gnav ul.main>li a.btn.base { color: var(--c-white); }
#header.fixed #gnav ul.main>li a.btn.base span { background-image: linear-gradient(var(--c-white), var(--c-white)); }
#header.fixed #gnav ul.main>li a.btn.base span::after { background-image: url(../img/common/icon1_w.svg); }
#header.fixed #gnav ul.main>li a:hover { color: var(--c-white); }
#header.fixed #gnav ul.main>li a:hover span { background-image: linear-gradient(var(--c-white), var(--c-white)); }
#header.fixed #gnav ul.main>li a:hover span::after { background-image: url(../img/common/icon1_w.svg); }
@media screen and (max-width: 1100px) {
	#gnav { display: none;}
}
#menubtn { position: fixed; z-index: 1011; top: 42px; right: 30px; transition: top .6s;}
#menubtn a { display: block; width: 56px; height: 40px; position: relative; }
#menubtn a .line { width: 100%; height: 2px; background: var(--c-base); position: absolute; left: 50%; margin-left: -28px; transition: 0.4s cubic-bezier(0.25, 1, 0.5, 1) 0s; border-radius: 1px;}
#menubtn a #line1 { top: calc(50% - 4px); }
#menubtn a #line2 { top: calc(50% + 4px); }
#menubtn a:hover #line1 { top: calc(50% + 3px); }
#menubtn a:hover #line2 { top: calc(50% - 3px); }
#menubtn.active a { width: 80px; }
#menubtn.active a .line { background: var(--c-base); }
#menubtn.active a #line1 { -webkit-transform:translateY(15px) rotate(-30deg); transform: translateY(15px) rotate(-30deg); top: calc(50% - 15px); }
#menubtn.active a #line2 { -webkit-transform:translateY(-15px) rotate(30deg); transform: translateY(-15px) rotate(30deg); top: calc(50% + 15px); }
#menubtn.active a:hover #line1 { -webkit-transform:translateY(17px) rotate(-20deg); transform: translateY(15px) rotate(-20deg); }
#menubtn.active a:hover #line2 { -webkit-transform:translateY(-7px) rotate(20deg); transform: translateY(-15px) rotate(20deg); }
#header.fixed #menubtn { top: 20px; }
#header.fixed #menubtn a .line { background: var(--c-white); }
#index #header.fixed #menubtn a .line { background: var(--c-white); }
@media screen and (max-width: 500px){
	#menubtn { top: 20px; right: 20px;}
	#header.fixed #menubtn { top: 15px; }
}



/*///////////////////////////////////
Leadbox・Menubtn
///////////////////////////////////*/
#widenav { position: fixed; display: flex; flex-direction: column; justify-content: space-between; align-items: center; transition: 0.4s; width: 100vw; height:100vh; height:100svh; padding: 40px 6%; background:var(--c-mustard); box-sizing: border-box; top: 0; left: 0; z-index: 102; opacity: 0; pointer-events: none; transform: scale(1.1); }
#widenav.is-open { pointer-events: auto; opacity: 1;transform: scale(1);}
#widenav .navbox { line-height: 1; display: flex; align-items: center; justify-content: center; padding: 2em 0 0; box-sizing: border-box; flex: 1; flex-direction: column; }
#widenav .nav-copy { width: clamp(250px, calc(260px + (480px - 250px) * var(--fluid)), 480px); margin-bottom: 2em; }
#widenav ul.main { display: flex; align-items: center; }
#widenav ul.main>li { margin-right: 1.1em; }
#widenav ul.main>li a { position: relative; transition: 0.5s; font-size: clamp(var(--fs-xl-min), calc(var(--fs-xl-min) + (var(--fs-xl-max) - var(--fs-xl-min)) * var(--fluid)), var(--fs-xl-max));}
#widenav ul.main>li a:hover { opacity: 0.3;}
#widenav ul.main>li:last-child { margin-right: 0; }
#widenav ul.contactbox { display: flex; justify-content: center; align-items: center;}
#widenav ul.contactbox>li.insta { display: flex; justify-content: center;  align-items: center; margin-bottom: 0;}
#widenav ul.contactbox>li.insta a { width: 44px; height: 44px; display: block; position: relative; }
#widenav ul.contactbox>li.insta a img { width: 44px; height: 44px; position: absolute; top: 0; left: 0; transition: opacity .5s;}
#widenav ul.contactbox>li.insta a img:last-child { opacity: 0; }
#widenav ul.contactbox>li.insta a:hover img:first-child { opacity: 0; }
#widenav ul.contactbox>li.insta a:hover img:last-child { opacity: 1; }
#widenav ul.contactbox>li.contact { margin-left: 0.5em; margin-bottom: 0; font-size: clamp(var(--fs-lg-min), calc(var(--fs-lg-min) + (var(--fs-lg-max) - var(--fs-lg-min)) * var(--fluid)), var(--fs-lg-max));}
#widenav ul.contactbox>li.contact a { padding: 0.3em 1em; border-radius: 24px; background-color: var(--c-white); border: 1px solid var(--c-base); }
#widenav ul.contactbox>li.contact a:hover { background-color: var(--c-base); color: var(--c-white);}
#widenav .nav-logo { text-align: center; margin-top: 20px;}
#widenav .nav-logo img { width: 142px; }
@media screen and (max-width: 767px){
	#widenav .navbox { }
	#widenav ul.main { display: flex; align-items: center; flex-direction: column; }
	#widenav ul.main>li { margin-right: 0; padding: 0.5em 0; }
	#widenav ul.contactbox>li.insta a,
	#widenav ul.contactbox>li.insta a img { width: 38px; height: 38px; }
}


/*///////////////////////////////////
Mainv.under
///////////////////////////////////*/
#mainv.under { position: relative; width: 100%; height: clamp(250px, calc(180px + 20vw), 600px); display: flex; justify-content: center; align-items: flex-end; background-color: var(--c-mustard-l); }
#mainv .title-page { margin-bottom: clamp(25px, calc(10px + 3.5vw), 100px) }


/*///////////////////////////////////
Pankuzu
///////////////////////////////////*/

#pankuzu { line-height: 1.4; padding-top:18px; text-align: center;}
#pankuzu.min { text-align: center; float: none;}
#pankuzu ol { margin: 0 25px; font-size: 0; }
#pankuzu ol li { display:inline; font-size: 1.4rem; }
#pankuzu ol li img { width: 13px; vertical-align: 0px; margin-right: 5px; }
#pankuzu ol li:before { content:""; border-right: 1px solid var(--c-base); border-top: 1px solid var(--c-base); width: 4px; height: 4px; display: inline-block; margin: 0 8px 0 5px; transform: rotate(45deg); vertical-align: 2px; font-size: 0; }
#pankuzu ol li:first-child:before { display: none; }
#pankuzu ol li a:hover { text-decoration: underline; }
@media screen and (max-width: 767px) { 
	#pankuzu{ display: none; }
	#pankuzu ol { margin: 0 6%; }
}



/*///////////////////////////////////
Content
///////////////////////////////////*/

#main { margin-top: 0; }
@media screen and (max-width: 767px) { 
}



/*///////////////////////////////////
Cntside
///////////////////////////////////*/

#side {  }



/*///////////////////////////////////
Footer
///////////////////////////////////*/

#footer {  }
/* sec_insta */
#footer #sec_insta { text-align: center;}
#footer #sec_insta .txt1 { font-size: var(--fs-xl); margin-top: 0.3em; }
@media screen and (max-width: 500px){
	#footer #sec_insta { padding: 80px 0;}
}

/* footerinfo */
#footer .fcontactbox{ background: var(--c-mustard); padding: 70px 0; color: var(--c-white); }
#footer .fcontactbox .txt1 { font-size: var(--fs-xl);text-align: center;}
#footer .fcontactbox .btnbox { margin-top: 0.5em;}
#footer .fcontactbox .btnbox>li.tel .btn span::after { display: none;}
#footer .fcontactbox .btnbox>li.tel { position: relative; padding-right: calc(3em - 10px);}
#footer .fcontactbox .btnbox>li.tel::after { content: "・"; position: absolute; top: 20%; right: 0; font-size: 30px; line-height: 1; }
	#footer .fcontactbox .btnbox>li p { line-height: 1.65; }
@media screen and (max-width: 1100px){
}
@media screen and (max-width: 767px){
	#footer .fcontactbox .btnbox { flex-direction: column; }
	#footer .fcontactbox .btnbox>li.tel::after { display: none;}
	#footer .fcontactbox .btnbox>li.tel { padding-right: 0; margin-bottom: 0.6em;}
}
/* fnav */
#footer .finfobox{ background: var(--c-brown); padding: 40px 0; color: var(--c-white); }
#footer .finfobox .insec { display: flex; justify-content: space-between; align-items: center; }
#footer .finfobox .logo-nav { display: flex; gap: 1.5em; align-items: center; flex: 1; }
#footer .finfobox .logo-nav .logo { width: clamp(100px, calc(100px + (142px - 100px) * var(--fluid)), 142px); }
#footer .finfobox .logo-nav .fnav { display: flex; gap: 1em; }
#footer .finfobox .logo-nav .fnav>li a { font-size: var(--fs); }
#footer .finfobox .logo-nav .fnav>li a:hover { color: var(--c-white); }
#footer .finfobox .logo-nav .fnav>li a:hover span { background-image: linear-gradient(var(--c-white), var(--c-white)); }
#footer .finfobox .logo-nav .fnav>li a:hover span::after { background-image: url(../img/common/icon1_w.svg); }
#footer .finfobox .info { font-size: var(--fs-xs); line-height: var(--lh-xs); }
@media screen and (max-width: 1100px){
	#footer .finfobox .insec { flex-direction: column;}	
	#footer .finfobox .info { text-align: center; margin-top: 1.5em;}
}
@media screen and (max-width: 500px){
	#footer .finfobox .insec { }	
	#footer .finfobox .logo-nav { flex-direction: column-reverse; }
	#footer .finfobox .logo-nav .logo { margin-top: 0.8em; }
	#footer .finfobox .info { text-align: center; margin-top: 1em;}
}

/* fnav */
#footer .cr { padding: 1em 0; font-size: var(--fs-xs); }
#footer .cr .list { display: flex; justify-content: center; gap: 0 1em;}
