@charset "utf-8";
/*------------------------  common.css  ------------------------*/



/*------------  reset  ------------*/
*, *::before, *::after { box-sizing: border-box; }
* { padding: 0; margin: 0; }
img, picture, video, canvas, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
form { margin: 0; padding: 0; }
li { list-style-type: none; }
img { border: none; width: 100%; vertical-align: bottom; -webkit-user-drag: none; }
a { text-decoration: none; color: #22150e; opacity: 1; transition: all .2s; }
a:hover { text-decoration: none; opacity: .7; }
button { -webkit-appearance: none; -moz-appearance: none; appearance: none; border: none; outline: none; background-color: transparent; padding: 0; }

@media screen and (max-width: 800px) {
 a:hover { opacity: 1; }
}

@media (min-width: 801px) {
 .call[href*="tel:"] { pointer-events: none; cursor: default; text-decoration: none; }
}



/*------------  body #wrap  ------------*/
body { background: #fff; font-family: 'Noto Sans JP', sans-serif; font-size: 1em; line-height: 1; color: #22150e; font-feature-settings: "palt" 1; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; letter-spacing: .02em; }
#wrap { background: url(/images/bg.jpg) center top #d5ad80; background-size: 498px 700px; }



/*------------  pc / sp  ------------*/
.pc { display: block; }
.sp { display: none; }

@media screen and (max-width: 800px) {
 .pc { display: none; }
 .sp { display: block; }
}



/*------------  header  ------------*/
#header { position: -webkit-sticky; position: sticky; top: 0; width: 100%; background: url(/images/bg_header.png) center #cd001a; background-size: 38px 10px; z-index: 100; }
#header .header-inner { position: relative; display: flex; justify-content: space-between; align-items: center; padding: 0 0 0 15px; height: 76px; border-bottom: 8px solid #fbc400; }
#header .logo { display: flex; align-items: center; width: 200px; z-index: 101; }
#header .logo .link { display: block; }
.menu-btn { display: none; pointer-events: none; }
#header .header-gnav { flex: 1; display: flex; justify-content: space-between; }
#header .header-gnav .gnav { display: flex; align-items: center; padding: 0 0 0 18px; font-weight: 800; font-size: 15px; }
#header .header-gnav .gnav .nav { position: relative; height: 100%; }
#header .header-gnav .gnav .nav .nav-link { display: flex; align-items: center; padding: 0 14px; height: 100%; color: #fff; }
#header .header-gnav .gnav .dropdown { cursor: pointer; }
#header .header-gnav .gnav .dropdown .dropdown-nav { display: none; position: absolute; top: 100%; left: 0; padding: 0 10px 10px; width: 220px; background: #fbc400; z-index: 101; }
#header .header-gnav .gnav .dropdown .dropdown-nav .bnr { padding-top: 10px; }
#header .header-gnav .gnav .dropdown .dropdown-nav .bnr .link { display: block; }
#header .header-gnav .gnav .dropdown .dropdown-nav .bnr .link:hover { opacity: .7; transition: all .2s; }
#header .header-gnav .snav { display: flex; justify-content: flex-end; align-items: center; height: 68px; }
#header .header-gnav .snav .instagram { display: flex; justify-content: center; align-items: center; padding: 0 16px 0 0; }
#header .header-gnav .snav .instagram .link { display: block; width: 42px; height: 42px; }
#header .header-gnav .snav .board { display: flex; justify-content: center; align-items: center; width: 200px; height: 100%; background: url(/images/bg.jpg) center #d5ad80; background-size: 498px 700px; }


@media screen and (max-width: 1060px) {
 #header .header-gnav .gnav { padding: 0 0 0 16px; }
 #header .header-gnav .gnav .nav .nav-link { padding: 0 12px; }
 #header .header-gnav .snav .board { display: none; }
}


@media screen and (max-width: 840px) {
 #header { background-size: 22px 6px; }
 #header .header-inner { height: 59px; padding: 0 0 0 12px; border-bottom: 5px solid #fbc400; }
 #header .logo { width: 160px; }

 .menu-btn { display: block; pointer-events: all; position: absolute; top: 0; right: 0; width: 54px; height: 54px; text-align: center; cursor: pointer; z-index: 101; }
 .menu-btn .bar { display: block; position: absolute; width: 22px; height: 2px; left: 15px; background: #fff; border-radius: 1px; }
 .menu-btn .bar:nth-of-type(1) { top: 18px; }
 .menu-btn .bar:nth-of-type(2) { top: 26px; }
 .menu-btn .bar:nth-of-type(3) { top: 34px; }
 .menu-btn.active .bar { width: 24px; left: 13px; }
 .menu-btn.active .bar:nth-of-type(1) { top: 26px; transform: rotate(45deg); }
 .menu-btn.active .bar:nth-of-type(2) { top: 26px; opacity: 0; }
 .menu-btn.active .bar:nth-of-type(3) { top: 26px; transform: rotate(-45deg); }

 body.fixed { position: fixed; width: 100%; height: 100%; }
 #header .header-gnav.active { display: block; }
 #header .header-gnav { position: fixed; top: 0; left: 0; display: none; width: 100%; height: 100dvh; background: #cd001a; z-index: 100; overflow: scroll; }
 #header .header-gnav .gnav { display: block; padding: 54px 10px 0; width: 100%; font-size: 14px; }
 #header .header-gnav .gnav .nav { padding: 0; border-bottom: 1px solid #e65668; }
 #header .header-gnav .gnav .nav:first-of-type { border-top: 1px solid #e65668; }
 #header .header-gnav .gnav .nav .nav-link { display: block; padding: 21px 8px; }
 #header .header-gnav .gnav .dropdown .dropdown-nav { display: flex; justify-content: center; flex-wrap: wrap; position: relative; padding: 2px 2px 10px; width: 100%; background: #cd001a; }
 #header .header-gnav .gnav .dropdown .dropdown-nav .bnr { flex-basis: 50%; padding: 0 5px 10px; max-width: 260px; }
 #header .header-gnav .gnav .dropdown .dropdown-nav .bnr .link:hover { opacity: 1; transition: all 0s; }
 #header .header-gnav .snav { display: block; padding: 20px 18px 25px; width: 100%; height: auto; }
 #header .header-gnav .snav .instagram { justify-content: flex-start; padding: 0; }
}


/*------------  footer  ------------*/
#footer { background: #fff; }
#footer .footer-gnav { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; padding: 16px 3%; background: #cd001a; }
#footer .footer-gnav .nav { padding: 0 14px; font-weight: 600; font-size: 15px; line-height: 1.3; }
#footer .footer-gnav .nav .nav-link { display: block; padding: 4px; color: #fff; }
#footer .footer-inner { padding: 40px 0 50px; }
#footer .logo { margin: 0 auto; width: 206px; }
#footer .logo .link { display: block; }
#footer .copyright { display: block; text-align: center; }
#footer .copyright p { padding: 14px 0 0; font-size: 13px; line-height: 1.5; }

@media screen and (max-width: 800px) {
 #footer .footer-gnav { justify-content: flex-start; padding: 16px 3%; }
 #footer .footer-gnav .nav { flex-basis: calc(100%/2); padding: 5px 2px; font-size: 14px; }
 #footer .footer-inner { padding: 25px 0 95px; }
 #footer .logo { width: 150px; }
 #footer .copyright p { padding: 10px 0 0; font-size: 12px; }
}



/*------------  app-banner  ------------*/
.app-banner { display: none; }

@media screen and (max-width: 800px) {
 .app-banner { display: block; position: fixed; bottom: 0; width: 100%; background: #fff; box-shadow: 0 0 6px rgba(0,0,0,0.15); }
 .app-banner.close { opacity: 0; visibility: hidden; transition: .2s; }
 .app-banner .banner { display: flex; margin: 0 auto; max-width: 400px; max-height: 72px; }
}