*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#FAF7F2;--warm:#F0E8DD;--sand:#D4C5B2;
  --mocha:#8B7355;--espresso:#5C4A32;--charcoal:#2E2A25;
  --sage:#A8B5A0;--sage-light:#D4DDD0;
  --gold:#C4A265;--gold-light:#E8D5B0;--white:#FFFDF9;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:'Noto Sans JP','Hiragino Sans',sans-serif;
  background:var(--cream);color:var(--charcoal);
  overflow-x:hidden;line-height:1.8;font-weight:300;
  -webkit-font-smoothing:antialiased;
}
a,button{-webkit-tap-highlight-color:transparent}

.loader{position:fixed;inset:0;z-index:9999;background:var(--charcoal);display:flex;align-items:center;justify-content:center;transition:opacity .8s ease,visibility .8s ease}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-text{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,4vw,2.5rem);color:var(--gold-light);letter-spacing:.3em;animation:loaderPulse 1.5s ease-in-out infinite}
@keyframes loaderPulse{0%,100%{opacity:.3}50%{opacity:1}}

header{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 2rem;transition:all .4s ease}
header.scrolled{background:rgba(250,247,242,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 20px rgba(0,0,0,.06);padding:.6rem 2rem}
nav{max-width:1200px;margin:0 auto;display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:nowrap}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:300;letter-spacing:.15em;color:var(--charcoal);text-decoration:none;transition:color .3s}
.logo span{display:block;font-family:'Noto Sans JP',sans-serif;font-size:.6rem;letter-spacing:.25em;color:var(--mocha);font-weight:300;margin-top:-2px}
header:not(.scrolled) .logo{color:var(--white)}
header:not(.scrolled) .logo span{color:var(--sand)}
header:not(.scrolled) .nav-links a{color:var(--white)}
.nav-links{display:flex;flex-direction:row;gap:2rem;list-style:none;margin:0;padding:0}
.nav-links li{list-style:none;margin:0;padding:0}
.nav-links a{text-decoration:none;color:var(--charcoal);font-size:.72rem;letter-spacing:.2em;font-weight:400;position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s ease}
.nav-links a:hover::after{width:100%}

.menu-toggle{display:none;cursor:pointer;width:28px;height:20px;position:relative;z-index:201}
.menu-toggle span{display:block;width:100%;height:1px;background:var(--charcoal);position:absolute;left:0;transition:all .3s ease}
header:not(.scrolled) .menu-toggle span{background:var(--white)}
.menu-toggle.active span{background:var(--charcoal)!important}
.menu-toggle span:nth-child(1){top:0}
.menu-toggle span:nth-child(2){top:50%;transform:translateY(-50%)}
.menu-toggle span:nth-child(3){bottom:0}
.menu-toggle.active span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

.mobile-overlay{display:none;position:fixed;inset:0;z-index:99;background:rgba(46,42,37,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .3s ease}
.mobile-overlay.active{opacity:1}

@media(max-width:768px){
  header{padding:.8rem 1.2rem}
  header.scrolled{padding:.6rem 1.2rem}
  .menu-toggle{display:block}
  .mobile-overlay{display:block;pointer-events:none}
  .mobile-overlay.active{pointer-events:auto}
  .nav-links{
    position:fixed;top:0;right:0;width:78%;max-width:320px;
    height:100vh;height:100dvh;background:var(--cream);
    flex-direction:column;padding:0;gap:0;z-index:200;
    transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
    box-shadow:-10px 0 40px rgba(0,0,0,.12);overflow-y:auto;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links::before{
    content:'pauhana';display:block;
    font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:300;
    letter-spacing:.15em;color:var(--sand);
    padding:4.5rem 2rem 1rem;border-bottom:1px solid var(--warm);
  }
  .nav-links li{border-bottom:1px solid var(--warm)}
  .nav-links a{
    color:var(--charcoal)!important;font-size:.88rem;
    display:flex;align-items:center;padding:1.1rem 2rem;width:100%;letter-spacing:.15em;
  }
  .nav-links a::after{display:none}
  .nav-links::after{
    content:'TEL: 0994-45-7227';display:block;
    margin-top:auto;padding:2rem;
    font-size:.72rem;letter-spacing:.1em;color:var(--mocha);text-align:center;
  }
}

.hero{height:100vh;height:100dvh;min-height:560px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,rgba(92,74,50,.85) 0%,rgba(46,42,37,.7) 50%,rgba(168,181,160,.5) 100%),linear-gradient(to bottom,rgba(0,0,0,.3),transparent 40%,transparent 60%,rgba(0,0,0,.4));z-index:1}
.hero-pattern{position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(196,162,101,.15) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(168,181,160,.1) 0%,transparent 50%);z-index:2}
.hero-texture{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,#5C4A32 0%,#3a2f1e 30%,#2E2A25 50%,#4a5a42 75%,#5C4A32 100%)}
.hero-content{position:relative;z-index:3;text-align:center;color:var(--white);animation:heroFadeIn 1.2s ease .5s both;padding:0 1.5rem}
@keyframes heroFadeIn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-sub{font-family:'Noto Sans JP',sans-serif;font-size:.65rem;letter-spacing:.5em;color:var(--gold-light);margin-bottom:1.5rem;font-weight:300}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,7vw,5.5rem);font-weight:300;letter-spacing:.08em;line-height:1.1;margin-bottom:.5rem}
.hero-jp{font-family:'Noto Serif JP',serif;font-size:clamp(.8rem,1.5vw,1rem);font-weight:200;letter-spacing:.4em;margin-bottom:2.5rem;color:var(--sand)}
.hero-line{width:40px;height:1px;background:var(--gold);margin:0 auto 2rem;animation:lineExpand 1s ease 1.2s both}
@keyframes lineExpand{from{width:0}to{width:40px}}
.hero-desc{font-size:.8rem;font-weight:200;letter-spacing:.15em;line-height:2;color:rgba(255,253,249,.75);max-width:400px;margin:0 auto}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:3;text-align:center;animation:scrollBounce 2s ease-in-out infinite}
.hero-scroll span{display:block;font-size:.6rem;letter-spacing:.3em;color:var(--sand);margin-bottom:.5rem}
.hero-scroll-line{width:1px;height:30px;background:var(--sand);margin:0 auto;opacity:.5}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

@media(max-width:768px){
  .hero-sub{font-size:.55rem;letter-spacing:.3em;margin-bottom:1.2rem}
  .hero-jp{letter-spacing:.2em;margin-bottom:2rem}
  .hero-desc{font-size:.73rem;letter-spacing:.06em;line-height:1.9;padding:0 .5rem}
  .hero-scroll{bottom:calc(1.5rem + var(--safe-bottom))}
}

section{padding:5rem 2rem}
.section-inner{max-width:1000px;margin:0 auto}
.section-label{font-family:'Cormorant Garamond',serif;font-size:clamp(.6rem,1vw,.7rem);letter-spacing:.5em;color:var(--gold);text-transform:uppercase;margin-bottom:.8rem}
.section-title{font-family:'Noto Serif JP',serif;font-size:clamp(1.3rem,3vw,2rem);font-weight:300;letter-spacing:.1em;margin-bottom:.5rem;color:var(--charcoal)}
.section-title-en{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,4vw,3rem);font-weight:300;color:var(--sand);letter-spacing:.05em;margin-bottom:2rem;opacity:.5}
.section-line{width:30px;height:1px;background:var(--gold);margin-bottom:2.5rem}
.fade-up{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

@media(max-width:768px){
  section{padding:3.2rem 1.2rem}
  .section-title-en{margin-bottom:1rem;font-size:clamp(1.3rem,5vw,1.8rem)}
  .section-line{margin-bottom:1.8rem}
}

#concept{background:var(--white)}
.concept-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.concept-visual{position:relative;aspect-ratio:3/4;background:linear-gradient(135deg,var(--warm) 0%,var(--sand) 100%);border-radius:2px;overflow:hidden}
.concept-visual::before{content:'';position:absolute;inset:20px;border:1px solid rgba(196,162,101,.3);border-radius:2px}
.concept-visual-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:4rem;opacity:.15;color:var(--espresso)}
.concept-text p{font-size:.85rem;line-height:2.2;color:var(--mocha);font-weight:300}
.concept-quote{margin-top:2rem;padding-left:1.5rem;border-left:2px solid var(--gold-light)}
.concept-quote p{font-family:'Noto Serif JP',serif;font-size:.9rem;font-style:italic;color:var(--espresso)}

@media(max-width:768px){
  .concept-grid{grid-template-columns:1fr;gap:1.5rem}
  .concept-visual{aspect-ratio:16/9;max-height:200px}
  .concept-visual::before{inset:10px}
  .concept-visual-icon{font-size:2.5rem}
  .concept-text p{font-size:.8rem;line-height:2}
  .concept-quote{margin-top:1.2rem;padding-left:1rem}
  .concept-quote p{font-size:.8rem;line-height:1.8}
}

#menu{background:var(--cream)}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1rem}
.menu-card{background:var(--white);padding:2.2rem 1.8rem;border-radius:3px;position:relative;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}
.menu-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.menu-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--gold-light),var(--gold),var(--gold-light));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.menu-card:hover::before{transform:scaleX(1)}
.menu-card h4{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;letter-spacing:.1em;margin-bottom:.2rem;color:var(--espresso)}
.menu-card .jp-name{font-size:.68rem;color:var(--mocha);letter-spacing:.2em;margin-bottom:1rem}
.menu-card .price{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:400;color:var(--gold);margin-bottom:.6rem}
.menu-card .price span{font-size:.72rem;color:var(--mocha)}
.menu-card .desc{font-size:.78rem;color:var(--mocha);line-height:1.8;font-weight:300}
.menu-note{text-align:center;margin-top:2rem;font-size:.72rem;color:var(--mocha);letter-spacing:.05em}

@media(max-width:768px){
  .menu-grid{grid-template-columns:1fr;gap:0}
  .menu-card{padding:1.1rem 1.2rem;border-radius:0;display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto auto;gap:0 1rem;align-items:center;border-bottom:1px solid var(--warm)}
  .menu-card:first-child{border-radius:6px 6px 0 0}
  .menu-card:last-child{border-radius:0 0 6px 6px;border-bottom:none}
  .menu-card::before{display:none}
  .menu-card:hover{transform:none;box-shadow:none}
  .menu-card h4{grid-column:1;grid-row:1;font-size:1.05rem;margin-bottom:0}
  .menu-card .jp-name{grid-column:1;grid-row:2;margin-bottom:0;font-size:.6rem}
  .menu-card .price{grid-column:2;grid-row:1/3;text-align:right;margin-bottom:0;font-size:1.2rem;align-self:center}
  .menu-card .price span{font-size:.6rem}
  .menu-card .desc{grid-column:1/-1;grid-row:3;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed var(--warm);font-size:.7rem;line-height:1.7}
  .menu-note{font-size:.68rem;margin-top:1.2rem}
}

#stylist{background:var(--charcoal);color:var(--cream);position:relative;overflow:hidden}
#stylist::before{content:'';position:absolute;top:0;right:0;width:300px;height:300px;background:radial-gradient(circle,rgba(196,162,101,.08),transparent 70%)}
#stylist .section-title{color:var(--cream)}
.stylist-card{display:grid;grid-template-columns:200px 1fr;gap:3rem;align-items:start;margin-top:1rem}
.stylist-photo{aspect-ratio:3/4;background:linear-gradient(135deg,var(--espresso),var(--mocha));border-radius:2px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.stylist-info h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:300;letter-spacing:.1em;margin-bottom:.2rem}
.stylist-info .role{font-size:.65rem;letter-spacing:.3em;color:var(--gold);margin-bottom:1.5rem}
.stylist-info p{font-size:.82rem;line-height:2.2;color:var(--sand);font-weight:200}
.stylist-skills{display:flex;gap:.6rem;margin-top:1.5rem;flex-wrap:wrap}
.stylist-skills span{font-size:.63rem;letter-spacing:.12em;padding:.35rem .9rem;border:1px solid rgba(196,162,101,.3);border-radius:20px;color:var(--gold-light)}

@media(max-width:768px){
  .stylist-card{grid-template-columns:1fr;gap:1.2rem;text-align:center}
  .stylist-photo{width:120px;height:155px;margin:0 auto;aspect-ratio:auto}
  .stylist-info h3{font-size:1.25rem}
  .stylist-info .role{margin-bottom:1rem;font-size:.6rem}
  .stylist-info p{font-size:.78rem;line-height:1.9;text-align:left}
  .stylist-skills{justify-content:center;gap:.5rem}
  .stylist-skills span{font-size:.58rem;padding:.28rem .65rem}
}

.coupon-section{background:linear-gradient(135deg,var(--warm) 0%,var(--cream) 100%);text-align:center}
.coupon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1.5rem}
.coupon-card{background:var(--white);padding:2rem 1.5rem;border-radius:3px;border:1px dashed var(--gold-light);position:relative}
.coupon-card .coupon-tag{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--white);font-size:.58rem;letter-spacing:.2em;padding:.2rem .7rem;border-radius:10px;white-space:nowrap}
.coupon-card h4{font-size:.82rem;font-weight:400;margin-top:.6rem;margin-bottom:.5rem;letter-spacing:.05em;line-height:1.6}
.coupon-card .original-price{font-size:.72rem;color:var(--sand);text-decoration:line-through}
.coupon-card .coupon-price{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--gold);font-weight:600}
.coupon-card .coupon-price small{font-size:.7rem;color:var(--mocha);font-weight:300}

@media(max-width:768px){
  .coupon-grid{grid-template-columns:1fr;gap:.8rem}
  .coupon-card{display:flex;align-items:center;justify-content:space-between;text-align:left;padding:1.2rem 1.2rem 1.2rem 1rem;gap:.8rem}
  .coupon-card .coupon-tag{left:auto;right:1rem;top:-8px;transform:none;font-size:.52rem;padding:.15rem .6rem}
  .coupon-card h4{font-size:.78rem;margin:0;line-height:1.5;flex:1}
  .coupon-card .original-price{display:none}
  .coupon-card .price-area{text-align:right;flex-shrink:0}
  .coupon-card .coupon-price{font-size:1.4rem;white-space:nowrap}
  .coupon-card .coupon-price small{font-size:.6rem}
}

#salon{background:var(--white)}
.info-table{margin-top:1rem}
.info-row{display:grid;grid-template-columns:110px 1fr;gap:1.5rem;padding:1.2rem 0;border-bottom:1px solid var(--warm);font-size:.82rem}
.info-row dt{font-weight:500;letter-spacing:.1em;color:var(--espresso);font-size:.73rem}
.info-row dd{color:var(--mocha);font-weight:300}
.info-row dd a{color:var(--mocha);text-decoration:none;border-bottom:1px solid var(--gold-light);padding-bottom:1px}
.map-container{margin-top:2.5rem;aspect-ratio:16/7;background:var(--warm);border-radius:3px;overflow:hidden;position:relative}
.map-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.5rem;color:var(--mocha)}
.map-placeholder svg{width:32px;height:32px;opacity:.4}
.map-placeholder>span{font-size:.72rem;letter-spacing:.12em}
.map-link{display:inline-block;margin-top:.8rem;font-size:.72rem;color:var(--gold);text-decoration:none;letter-spacing:.1em;padding:.5rem 1.2rem;border:1px solid var(--gold-light);border-radius:20px;transition:all .3s ease}
.map-link:hover{background:var(--gold);color:var(--white)}

@media(max-width:768px){
  .info-row{grid-template-columns:1fr;gap:.2rem;padding:.9rem 0}
  .info-row dt{font-size:.62rem;color:var(--gold);letter-spacing:.18em;font-weight:400}
  .info-row dd{font-size:.82rem}
  .map-container{aspect-ratio:4/3;margin-top:1.5rem}
  .map-link{padding:.6rem 1.5rem;font-size:.72rem}
}

.cta-section{background:var(--charcoal);text-align:center;color:var(--cream);padding:5rem 2rem}
.cta-section h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,4vw,2.8rem);font-weight:300;letter-spacing:.1em;margin-bottom:1rem}
.cta-section>p{font-size:.8rem;color:var(--sand);font-weight:200;letter-spacing:.1em;margin-bottom:2rem}
.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2.5rem;font-size:.75rem;letter-spacing:.18em;text-decoration:none;border-radius:2px;transition:all .3s ease;font-family:'Noto Sans JP',sans-serif}
.btn-primary{background:var(--gold);color:var(--white);border:1px solid var(--gold)}
.btn-primary:hover,.btn-primary:active{background:transparent;color:var(--gold)}
.btn-outline{background:transparent;color:var(--cream);border:1px solid var(--sand)}
.btn-outline:hover,.btn-outline:active{background:var(--cream);color:var(--charcoal)}

@media(max-width:768px){
  .cta-section{padding:3rem 1.2rem}
  .cta-section>p{font-size:.72rem}
  .cta-buttons{flex-direction:column;gap:.7rem}
  .btn{justify-content:center;padding:.8rem 1.5rem;font-size:.72rem;width:100%}
}

.mobile-bottom-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;
  background:rgba(46,42,37,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  padding:.55rem .8rem;padding-bottom:calc(.55rem + var(--safe-bottom));
  box-shadow:0 -2px 20px rgba(0,0,0,.15);
}
.bar-inner{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;max-width:400px;margin:0 auto}
.mobile-bottom-bar a{
  display:flex;align-items:center;justify-content:center;gap:.35rem;
  text-decoration:none;padding:.65rem .5rem;border-radius:3px;
  font-size:.68rem;letter-spacing:.1em;font-weight:400;transition:opacity .2s;
}
.mobile-bottom-bar a:active{opacity:.7}
.bar-tel{background:var(--gold);color:var(--white)}
.bar-reserve{background:transparent;color:var(--cream);border:1px solid var(--sand)}
.mobile-bottom-bar svg{flex-shrink:0}

@media(max-width:768px){
  .mobile-bottom-bar{display:block}
  body{padding-bottom:calc(56px + var(--safe-bottom))}
  footer{padding-bottom:calc(4.5rem + var(--safe-bottom))}
  .float-deco{display:none!important}
}

footer{background:var(--charcoal);border-top:1px solid rgba(255,255,255,.06);padding:3rem 2rem 2rem;text-align:center}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:300;letter-spacing:.15em;color:var(--cream);margin-bottom:.3rem}
.footer-logo span{display:block;font-family:'Noto Sans JP',sans-serif;font-size:.55rem;letter-spacing:.25em;color:var(--mocha);font-weight:300}
.footer-sns{display:flex;gap:1.2rem;justify-content:center;margin:1.5rem 0}
.footer-sns a{width:42px;height:42px;border:1px solid rgba(255,253,249,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--sand);text-decoration:none;font-size:.65rem;letter-spacing:.05em;transition:all .3s ease}
.footer-sns a:hover,.footer-sns a:active{border-color:var(--gold);color:var(--gold)}
.footer-copy{font-size:.58rem;color:var(--mocha);letter-spacing:.1em;margin-top:1rem}
@media(max-width:768px){footer{padding:2.5rem 1.2rem 2rem}}

.float-deco{position:fixed;bottom:2rem;right:2rem;z-index:50}
.float-deco a{width:56px;height:56px;background:var(--gold);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 20px rgba(196,162,101,.4);transition:transform .3s ease,box-shadow .3s ease}
.float-deco a:hover{transform:scale(1.08);box-shadow:0 6px 30px rgba(196,162,101,.5)}

@media print{
  header,.hero-scroll,.float-deco,.mobile-bottom-bar,.loader{display:none!important}
  .hero{height:auto;min-height:auto;padding:2rem}
  section{padding:1.5rem;break-inside:avoid}
  .fade-up{opacity:1!important;transform:none!important}
}
