/* =========================================================
   bijou — nail salon  |  design system
   warm-peach editorial (NORA lineage) × jewel refinement
   ========================================================= */

/* ---------- fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@400;500;600;700&family=Noto+Sans+JP:wght@200;300;400;500;700&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Jost:wght@300;400;500&display=swap');

/* ---------- tokens ---------- */
:root{
  /* base surfaces */
  --ivory:#FBF7F1;
  --cream:#F4EBDF;
  --blush:#F9EAE0;
  --peach:#F3D9C7;
  --sand:#EADFCF;
  --line:#E4D7C6;
  --line-soft:#EFE6D9;

  /* ink / text */
  --ink:#2A231F;
  --ink-2:#5F544B;
  --ink-3:#8C7F72;

  /* accents */
  --coral:#CB6B4E;
  --coral-deep:#B0522E;
  --rose:#E1A98F;
  --gold:#BE9F72;

  /* dark surfaces */
  --dark:#241B16;
  --dark-2:#30251E;
  --on-dark:#F3E9DD;
  --on-dark-2:#C3B2A2;

  /* type families */
  --serif:"Shippori Mincho B1", serif;
  --latin:"Cormorant Garamond", serif;
  --sans:"Noto Sans JP", sans-serif;
  --geo:"Jost", sans-serif;

  /* metrics */
  --maxw:1280px;
  --gut:clamp(20px,5vw,64px);
  --header-h:84px;

  /* motion */
  --ease:cubic-bezier(.16,1,.3,1);
  --spring:cubic-bezier(.34,1.3,.5,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--ivory);
  line-height:1.9;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-break:strict;
  word-break:normal;
  overflow-wrap:anywhere;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none}
::selection{background:var(--peach);color:var(--ink)}

/* line-start kinsoku helper */
.kin{line-break:strict}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(84px,12vw,168px)}
.section--tight{padding-block:clamp(60px,8vw,108px)}

/* ---------- type utilities ---------- */
.eyebrow{
  font-family:var(--geo);
  font-weight:400;
  font-size:12px;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--coral);
  display:inline-flex;align-items:center;gap:.9em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.7}
.eyebrow.is-center{justify-content:center}
.eyebrow.is-center::after{content:"";width:26px;height:1px;background:currentColor;opacity:.7}

.h-lg{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(28px,4.4vw,52px);
  line-height:1.42;
  letter-spacing:.04em;
  color:var(--ink);
  word-break:keep-all;
  text-wrap:pretty;
}
.h-md{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(23px,3vw,34px);
  line-height:1.5;
  letter-spacing:.05em;
  word-break:keep-all;
}
.latin-title{
  font-family:var(--latin);
  font-weight:500;
  font-style:italic;
  letter-spacing:.02em;
  color:var(--coral);
}
.lead{
  font-size:clamp(15px,1.5vw,17px);
  line-height:2.15;
  color:var(--ink-2);
  font-weight:300;
}
.text-center{text-align:center}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--coral); --fg:#fff;
  display:inline-flex;align-items:center;gap:.85em;
  padding:16px 34px;
  border-radius:100px;
  background:var(--bg);color:var(--fg);
  font-family:var(--geo);font-weight:400;font-size:13px;
  letter-spacing:.22em;text-transform:uppercase;
  position:relative;overflow:hidden;
  transition:transform .5s var(--spring), box-shadow .5s var(--ease), background .4s var(--ease);
  box-shadow:0 10px 26px -12px rgba(176,82,46,.55);
}
.btn .btn-ar{transition:transform .5s var(--ease)}
.btn:hover{transform:translateY(-3px);background:var(--coral-deep);box-shadow:0 16px 34px -12px rgba(176,82,46,.6)}
.btn:hover .btn-ar{transform:translateX(4px)}
.btn:focus-visible{outline:2px solid var(--coral-deep);outline-offset:3px}
.btn--ghost{
  --bg:transparent;--fg:var(--ink);
  border:1px solid var(--line);box-shadow:none;
}
.btn--ghost:hover{background:var(--ink);--fg:#fff;border-color:var(--ink);box-shadow:none}
.btn--onDark{--bg:transparent;--fg:var(--on-dark);border:1px solid rgba(243,233,221,.3);box-shadow:none}
.btn--onDark:hover{--bg:var(--coral);--fg:#fff;border-color:var(--coral)}

/* text link with animated underline + arrow */
.tlink{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--geo);font-size:13px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);position:relative;padding-bottom:4px;
}
.tlink::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--coral);transform:scaleX(0);transform-origin:right;
  transition:transform .5s var(--ease)}
.tlink .a{transition:transform .45s var(--ease)}
.tlink:hover::after{transform:scaleX(1);transform-origin:left}
.tlink:hover .a{transform:translateX(5px)}

/* ---------- scroll progress ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--rose),var(--coral));transition:width .1s linear}

/* =========================================================
   splash
   ========================================================= */
.splash{position:fixed;inset:0;z-index:200;background:var(--ivory);
  display:grid;place-items:center;transition:opacity .8s var(--ease),visibility .8s}
.splash.is-done{opacity:0;visibility:hidden}
.splash-mark{font-family:var(--geo);font-weight:300;font-size:clamp(40px,9vw,86px);
  letter-spacing:.34em;color:var(--ink);position:relative;
  opacity:0;transform:translateY(8px);animation:splashIn 1.1s var(--ease) .15s forwards}
.splash-mark::before{content:"";position:absolute;left:-.42em;top:12%;
  width:2px;height:76%;background:linear-gradient(var(--gold),var(--coral));
  transform:scaleY(0);transform-origin:top;animation:splashBar 1s var(--ease) .5s forwards}
.splash-dot{position:absolute;left:-.44em;top:6%;width:9px;height:9px;border-radius:50%;
  background:var(--gold);opacity:0;animation:splashDot .5s var(--ease) 1.1s forwards}
@keyframes splashIn{to{opacity:1;transform:none}}
@keyframes splashBar{to{transform:scaleY(1)}}
@keyframes splashDot{to{opacity:1}}

/* =========================================================
   header
   ========================================================= */
.header{position:fixed;top:0;left:0;width:100%;z-index:100;
  height:var(--header-h);display:flex;align-items:center;
  transition:background .5s var(--ease),height .5s var(--ease),box-shadow .5s var(--ease),border-color .5s}
.header .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.header.is-solid{background:rgba(251,247,241,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  height:66px;border-bottom:1px solid var(--line-soft);box-shadow:0 6px 24px -18px rgba(42,35,31,.5)}

.brand{display:inline-flex;align-items:baseline;gap:.6em;position:relative}
.brand-mark{font-family:var(--geo);font-weight:300;font-size:26px;letter-spacing:.3em;
  color:var(--ink);position:relative;transition:color .5s var(--ease)}
.brand-mark::before{content:"";position:absolute;left:-.34em;top:14%;width:1.5px;height:72%;
  background:linear-gradient(var(--gold),var(--coral))}
.brand-dot{position:absolute;left:-.38em;top:2px;width:5px;height:5px;border-radius:50%;background:var(--gold)}
.brand-sub{font-family:var(--geo);font-size:9.5px;letter-spacing:.36em;text-transform:uppercase;
  color:var(--ink-3);transition:color .5s var(--ease)}
.header.is-hero .brand-mark,.header.is-hero .brand-sub{color:#fff}
.header.is-hero .brand-mark::before{background:linear-gradient(var(--gold),var(--rose))}

.nav{display:flex;align-items:center;gap:clamp(18px,2vw,34px)}
.nav-list{display:flex;gap:clamp(16px,1.8vw,30px)}
.nav-list a{font-family:var(--geo);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-2);position:relative;padding:6px 0;transition:color .4s}
.nav-list a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--coral);
  transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease)}
.nav-list a:hover{color:var(--ink)}
.nav-list a:hover::after{transform:scaleX(1);transform-origin:left}
.header.is-hero .nav-list a{color:rgba(255,255,255,.82)}
.header.is-hero .nav-list a:hover{color:#fff}
.nav-list a[aria-current]{color:var(--coral)}
.nav-list a[aria-current]::after{transform:scaleX(1);transform-origin:left}

.nav-cta{display:inline-flex;align-items:center;gap:.6em;padding:11px 22px;border-radius:100px;
  background:var(--coral);color:#fff;font-family:var(--geo);font-size:11.5px;letter-spacing:.2em;
  text-transform:uppercase;transition:transform .5s var(--spring),background .4s}
.nav-cta:hover{transform:translateY(-2px);background:var(--coral-deep)}
.nav-tel{font-family:var(--geo);font-size:12px;letter-spacing:.14em;color:var(--ink-2);display:inline-flex;align-items:center;gap:.5em}
.header.is-hero .nav-tel{color:rgba(255,255,255,.85)}

.burger{display:none;width:40px;height:40px;position:relative;z-index:101}
.burger span{position:absolute;left:9px;width:22px;height:1.5px;background:var(--ink);transition:.4s var(--ease)}
.burger span:nth-child(1){top:15px}.burger span:nth-child(2){top:24px}
.header.is-hero .burger span{background:#fff}
body.nav-open .burger span{background:var(--ink)}
body.nav-open .header .brand-mark,body.nav-open .header .brand-sub{color:var(--ink)}
body.nav-open .header .brand-mark::before{background:linear-gradient(var(--gold),var(--coral))}
body.nav-open .burger span:nth-child(1){top:20px;transform:rotate(45deg)}
body.nav-open .burger span:nth-child(2){top:20px;transform:rotate(-45deg)}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:99;background:var(--ivory);
  display:flex;flex-direction:column;justify-content:center;padding:var(--gut);
  clip-path:circle(0% at calc(100% - 40px) 40px);transition:clip-path .7s var(--ease);visibility:hidden}
body.nav-open .drawer{clip-path:circle(150% at calc(100% - 40px) 40px);visibility:visible}
.drawer-list{display:flex;flex-direction:column;gap:6px}
.drawer-list a{font-family:var(--serif);font-size:26px;letter-spacing:.06em;color:var(--ink);
  padding:10px 0;display:flex;align-items:baseline;gap:14px;
  opacity:0;transform:translateY(16px);transition:.6s var(--ease)}
.drawer-list a .en{font-family:var(--latin);font-style:italic;font-size:14px;color:var(--coral)}
body.nav-open .drawer-list a{opacity:1;transform:none}
body.nav-open .drawer-list a:nth-child(1){transition-delay:.15s}
body.nav-open .drawer-list a:nth-child(2){transition-delay:.2s}
body.nav-open .drawer-list a:nth-child(3){transition-delay:.25s}
body.nav-open .drawer-list a:nth-child(4){transition-delay:.3s}
body.nav-open .drawer-list a:nth-child(5){transition-delay:.35s}
body.nav-open .drawer-list a:nth-child(6){transition-delay:.4s}
body.nav-open .drawer-list a:nth-child(7){transition-delay:.45s}
.drawer-foot{margin-top:44px;display:flex;flex-direction:column;gap:14px;
  opacity:0;transition:.6s var(--ease) .5s}
body.nav-open .drawer-foot{opacity:1}

/* =========================================================
   hero
   ========================================================= */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden;display:flex;align-items:flex-end}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.6s var(--ease)}
.hero-slide.is-active{opacity:1}
.hero-slide::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(30,20,16,.32) 0%,rgba(30,20,16,.05) 34%,rgba(30,20,16,.14) 62%,rgba(30,20,16,.62) 100%)}
.hero-slide .bg{position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.06);transition:transform 7s ease-out}
.hero-slide.is-active .bg{transform:scale(1)}
/* placeholder warm tones until photos arrive */
.ph1{background:#e7c4ad url("../images/hero-1.jpg") center/cover no-repeat}
.ph2{background:#dcae9a url("../images/hero-2.jpg") center/cover no-repeat}
.ph3{background:#e9d3c4 url("../images/hero-3.jpg") center/cover no-repeat}

.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(56px,9vh,120px)}
.hero-eyebrow{color:#fff;opacity:.9}
.hero-eyebrow::before{background:var(--rose)}
.hero h1{font-family:var(--serif);font-weight:600;color:#fff;
  font-size:clamp(38px,7vw,88px);line-height:1.32;letter-spacing:.06em;
  margin-top:22px;text-shadow:0 2px 30px rgba(20,12,8,.3);word-break:keep-all}
.hero-sub{color:rgba(255,255,255,.9);max-width:34em;margin-top:24px;font-size:clamp(14px,1.4vw,16px);line-height:2.1}
.hero-cta{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap}
.hero-cta .btn--onDark{border-color:rgba(255,255,255,.45);color:#fff}
.hero-dots{position:absolute;right:var(--gut);bottom:clamp(56px,9vh,120px);z-index:3;display:flex;flex-direction:column;gap:12px}
.hero-dots button{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);transition:.4s}
.hero-dots button.is-active{background:#fff;transform:scale(1.3)}
.hero-index{position:absolute;left:var(--gut);bottom:clamp(56px,9vh,120px);z-index:3;
  font-family:var(--geo);font-size:12px;letter-spacing:.2em;color:rgba(255,255,255,.85)}
.hero-index b{font-weight:400;color:#fff}

/* =========================================================
   reveal
   ========================================================= */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.1s}
.reveal[data-d="2"]{transition-delay:.2s}
.reveal[data-d="3"]{transition-delay:.3s}
.reveal[data-d="4"]{transition-delay:.4s}
.reveal-line{overflow:hidden;display:block}
.reveal-line>span{display:block;transform:translateY(105%);transition:transform 1s var(--ease)}
.in .reveal-line>span{transform:none}

/* =========================================================
   concept (intro)
   ========================================================= */
.concept{background:var(--ivory)}
.concept-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,96px);align-items:center}
.concept-figure{position:relative;aspect-ratio:4/5;border-radius:2px;overflow:hidden;background:linear-gradient(135deg,#f1d9c8,#e7c0a9)}
.concept-figure .bg{position:absolute;inset:0;background:#eccdba url("../images/concept.jpg") center/cover no-repeat}
.concept-figure figcaption{position:absolute;left:20px;bottom:18px;z-index:2;color:#fff;
  font-family:var(--latin);font-style:italic;font-size:15px;letter-spacing:.04em;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.concept-figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(20,12,8,.4))}
.concept-quote{font-family:var(--serif);font-weight:500;font-size:clamp(21px,2.5vw,30px);
  line-height:1.9;letter-spacing:.05em;color:var(--ink);margin:26px 0 28px}
.concept-quote em{font-style:normal;color:var(--coral)}
.gold-rule{width:44px;height:1px;background:var(--gold);margin:30px 0}

/* =========================================================
   gallery teaser
   ========================================================= */
.gallery{background:var(--cream)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:clamp(36px,5vw,64px)}
.sec-head .txt{max-width:40em}
.sec-head h2{margin-top:16px}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.4vw,18px)}
.gal-item{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:2px;background:var(--sand)}
.gal-item .bg{position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform 1.1s var(--ease)}
.gal-item:hover .bg{transform:scale(1.07)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(20,12,8,.34));
  opacity:0;transition:opacity .5s}
.gal-item:hover::after{opacity:1}
.gal-item .tag{position:absolute;left:12px;bottom:12px;z-index:2;color:#fff;
  font-family:var(--geo);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  opacity:0;transform:translateY(8px);transition:.5s var(--ease)}
.gal-item:hover .tag{opacity:1;transform:none}
.gal-item.tall{grid-row:span 2;aspect-ratio:3/5}
.gal-c1{background:linear-gradient(150deg,#f4ddcd,#e8bfa8)}
.gal-c2{background:linear-gradient(150deg,#efd6c9,#dcae9c)}
.gal-c3{background:linear-gradient(150deg,#f6e3d6,#eccbb6)}
.gal-c4{background:linear-gradient(150deg,#eccbb8,#d99f88)}
.gal-c5{background:linear-gradient(150deg,#f1d7c6,#e3b7a0)}
.gal-more{margin-top:clamp(30px,4vw,48px);text-align:center}

/* =========================================================
   menu teaser
   ========================================================= */
.menu{background:var(--ivory)}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(2px,.2vw,4px);border:1px solid var(--line);background:var(--line)}
.menu-cell{background:var(--ivory);padding:clamp(28px,3.4vw,52px);position:relative;transition:background .5s var(--ease)}
.menu-cell:hover{background:var(--blush)}
.menu-num{font-family:var(--latin);font-style:italic;font-size:15px;color:var(--gold)}
.menu-cell h3{font-family:var(--serif);font-weight:600;font-size:clamp(19px,2vw,25px);letter-spacing:.05em;margin:10px 0 12px}
.menu-cell p{color:var(--ink-2);font-size:14.5px;line-height:2;max-width:24em}
.menu-price{margin-top:20px;font-family:var(--geo);font-size:13px;letter-spacing:.08em;color:var(--coral)}
.menu-price b{font-weight:500;font-size:17px}
.menu-note{margin-top:26px;color:var(--ink-3);font-size:12.5px;letter-spacing:.04em}

/* =========================================================
   care (dark blush band)
   ========================================================= */
.care{position:relative;background:linear-gradient(135deg,#31241d,#241b16);color:var(--on-dark);overflow:hidden}
.care::before{content:"";position:absolute;right:-8%;top:-20%;width:52%;height:140%;
  background:radial-gradient(circle,rgba(203,107,78,.22),transparent 62%);pointer-events:none}
.care-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,6vw,90px);align-items:center;position:relative;z-index:1}
.care-figure{aspect-ratio:1/1;border-radius:2px;overflow:hidden;background:#3a2b22 url("../images/care.jpg") center/cover no-repeat}
.care .eyebrow{color:var(--rose)}
.care h2{color:#fff;margin:16px 0 22px}
.care p{color:var(--on-dark-2);max-width:32em}
.care .accent-line{font-family:var(--serif);color:#fff;font-size:clamp(18px,2vw,23px);letter-spacing:.06em;margin-top:26px;line-height:1.8}

/* =========================================================
   salon teaser
   ========================================================= */
.salon{background:var(--cream)}
.salon-lead{max-width:44em}
.salon-media{display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:auto auto;gap:clamp(12px,1.5vw,20px);margin-top:clamp(34px,4vw,58px)}
.salon-media figure{position:relative;overflow:hidden;border-radius:2px;background:var(--sand)}
.salon-media .m1{grid-row:span 2;aspect-ratio:4/5;background:linear-gradient(140deg,#efd8c8,#e0b7a1)}
.salon-media .m2{aspect-ratio:16/10;background:linear-gradient(140deg,#f4e2d5,#e7c6b2)}
.salon-media .m3{aspect-ratio:16/10;background:linear-gradient(140deg,#ecccb9,#dcae98)}
.salon-media .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1.1s var(--ease)}
.salon-media figure:hover .bg{transform:scale(1.06)}

/* =========================================================
   reserve CTA (dark)
   ========================================================= */
.reserve{position:relative;background:var(--dark);color:var(--on-dark);text-align:center;overflow:hidden}
.reserve::before{content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 120%,rgba(203,107,78,.28),transparent 60%)}
.reserve-inner{position:relative;z-index:1;max-width:640px;margin-inline:auto}
.reserve .latin-title{display:block;font-size:clamp(16px,2vw,20px);margin-bottom:12px}
.reserve h2{color:#fff;font-size:clamp(26px,3.6vw,44px);line-height:1.5}
.reserve p{color:var(--on-dark-2);margin:22px auto 0;max-width:30em}
.reserve-actions{margin-top:40px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.reserve-ways{margin-top:34px;display:flex;gap:28px;justify-content:center;flex-wrap:wrap;
  font-family:var(--geo);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--on-dark-2)}
.reserve-ways span{display:inline-flex;align-items:center;gap:.6em}

/* =========================================================
   access teaser
   ========================================================= */
.access{background:var(--ivory)}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center}
.access-map{aspect-ratio:5/4;border-radius:2px;overflow:hidden;background:#e7ddcd;position:relative}
.access-map .bg{position:absolute;inset:0;background:#e7ddcd url("../images/map.jpg") center/cover no-repeat;filter:saturate(.9)}
.access-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.15) saturate(.92) contrast(.98)}
.info-table{margin-top:26px;border-top:1px solid var(--line)}
.info-table div{display:grid;grid-template-columns:120px 1fr;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.info-table dt{font-family:var(--geo);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);padding-top:3px}
.info-table dd{color:var(--ink);font-size:15px;line-height:1.8}

/* =========================================================
   footer
   ========================================================= */
.footer{background:var(--dark-2);color:var(--on-dark);padding-block:clamp(60px,7vw,96px) 40px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:52px;border-bottom:1px solid rgba(243,233,221,.14)}
.footer-brand .brand-mark{color:#fff;font-size:34px}
.footer-brand .brand-mark::before{background:linear-gradient(var(--gold),var(--rose))}
.footer-brand p{color:var(--on-dark-2);margin-top:22px;max-width:24em;font-size:14px;line-height:2}
.footer h4{font-family:var(--geo);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--rose);margin-bottom:20px}
.footer-col a,.footer-col p{display:block;color:var(--on-dark-2);font-size:13.5px;line-height:2.3;transition:color .35s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:28px;flex-wrap:wrap}
.footer-bottom small{color:var(--on-dark-2);font-family:var(--geo);font-size:11px;letter-spacing:.14em}
.footer-sns{display:flex;gap:18px}
.footer-sns a{color:var(--on-dark-2);font-family:var(--geo);font-size:11px;letter-spacing:.16em;text-transform:uppercase;transition:color .35s}
.footer-sns a:hover{color:#fff}

/* =========================================================
   mobile fixed reserve bar
   ========================================================= */
.mbar{position:fixed;left:0;bottom:0;width:100%;z-index:90;display:none;
  grid-template-columns:1fr 1fr;background:rgba(36,27,22,.96);backdrop-filter:blur(8px);
  transform:translateY(110%);transition:transform .5s var(--ease)}
.mbar.show{transform:none}
.mbar a{display:flex;align-items:center;justify-content:center;gap:.5em;padding:16px 8px;
  font-family:var(--geo);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#fff}
.mbar a.tel{background:transparent;border-right:1px solid rgba(255,255,255,.15)}
.mbar a.rsv{background:var(--coral)}

/* =========================================================
   mobile vertical hero
   ========================================================= */
@media (max-width:680px){
  .ph1{background-image:url("../images/hero-1-sp.jpg");background-size:cover;background-position:center}
  .ph2{background-image:url("../images/hero-2-sp.jpg");background-size:cover;background-position:center}
  .ph3{background-image:url("../images/hero-3-sp.jpg");background-size:cover;background-position:center}
}

/* =========================================================
   logo integration (supplied bijou mark)
   ========================================================= */
.brand{align-items:center}
.brand-mark{
  display:inline-block;vertical-align:middle;
  width:98px;height:28px;letter-spacing:0;
  background:url("../images/logo-word.png") left center/contain no-repeat;
  text-indent:-9999px;overflow:hidden;color:transparent;
}
.brand-mark::before,.brand-dot{display:none!important}
.header.is-solid .brand-mark{background-image:url("../images/logo-word.png")}
.header.is-hero .brand-mark{background-image:url("../images/logo-word-cream.png")}
body.nav-open .header .brand-mark{background-image:url("../images/logo-word.png")}
.footer-brand .brand-mark{display:block;width:54px;height:90px;margin-bottom:14px;
  background:url("../images/logo-full-cream.png") left center/contain no-repeat}
.splash-mark{
  width:150px;height:230px;letter-spacing:0;
  background:url("../images/logo-full.png") center/contain no-repeat;
  text-indent:-9999px;overflow:hidden;color:transparent;
}
.splash-mark::before,.splash-dot{display:none!important}

/* =========================================================
   sub-page: header solid, subhero
   ========================================================= */
.page-sub .header{background:rgba(251,247,241,.9);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  height:66px;border-bottom:1px solid var(--line-soft)}
.page-sub{padding-top:0}

.subhero{position:relative;padding-top:calc(66px + clamp(56px,9vw,110px));
  padding-bottom:clamp(46px,7vw,86px);background:var(--cream);overflow:hidden}
.subhero::after{content:"";position:absolute;right:-6%;top:-30%;width:44%;height:150%;
  background:radial-gradient(circle,rgba(203,107,78,.12),transparent 60%);pointer-events:none}
.subhero .wrap{position:relative;z-index:2}
.ghost-word{position:absolute;right:var(--gut);top:38%;z-index:1;font-family:var(--latin);font-style:italic;
  font-size:clamp(90px,17vw,230px);line-height:.8;color:#fff;opacity:.5;pointer-events:none;letter-spacing:-.02em;
  mix-blend-mode:soft-light}
.subhero h1{font-family:var(--serif);font-weight:600;font-size:clamp(32px,5.6vw,64px);
  line-height:1.3;letter-spacing:.05em;color:var(--ink);margin-top:16px;word-break:keep-all}
.subhero .sub-lead{max-width:36em;margin-top:22px;color:var(--ink-2);font-size:clamp(14px,1.4vw,16px);line-height:2.1}
.breadcrumb{display:flex;gap:.7em;font-family:var(--geo);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:4px}
.breadcrumb a:hover{color:var(--coral)}
.breadcrumb span{color:var(--line)}

/* section eyebrow head (left) */
.head-l{margin-bottom:clamp(30px,4vw,54px)}
.head-l h2{margin-top:14px}
.head-l .lead{margin-top:16px;max-width:42em}

/* =========================================================
   article prose (concept / care)
   ========================================================= */
.article{max-width:760px;margin-inline:auto}
.article p{color:var(--ink-2);font-size:clamp(15px,1.5vw,16.5px);line-height:2.2;margin-bottom:1.7em}
.article .drop{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:clamp(19px,2.2vw,26px);
  line-height:1.9;letter-spacing:.04em;margin-bottom:1.4em}
.pullquote{font-family:var(--serif);font-weight:500;color:var(--coral);
  font-size:clamp(21px,3vw,34px);line-height:1.8;letter-spacing:.05em;text-align:center;
  margin:clamp(40px,6vw,80px) 0;position:relative}
.pullquote::before,.pullquote::after{content:"";display:block;width:40px;height:1px;background:var(--gold);margin:24px auto}
.article-figure{aspect-ratio:16/9;border-radius:2px;overflow:hidden;margin:clamp(36px,5vw,64px) 0;
  background:linear-gradient(135deg,#f1d9c8,#e3b49c)}

/* two column editorial */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,90px);align-items:center}
.split.rev .split-fig{order:2}
.split-fig{aspect-ratio:4/5;border-radius:2px;overflow:hidden;background:linear-gradient(140deg,#efd8c8,#e0b7a1)}
.split-fig.wide{aspect-ratio:5/4}
.split-fig .bg{position:absolute;inset:0;background-size:cover;background-position:center}

/* =========================================================
   gallery page: filter + big grid
   ========================================================= */
.filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(30px,4vw,50px)}
.filter button{padding:9px 20px;border-radius:100px;border:1px solid var(--line);
  font-family:var(--geo);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);
  transition:.4s var(--ease)}
.filter button:hover{border-color:var(--coral);color:var(--coral)}
.filter button.is-on{background:var(--ink);color:#fff;border-color:var(--ink)}
.mgrid{columns:4;column-gap:clamp(10px,1.4vw,18px)}
.mgrid .cell{break-inside:avoid;margin-bottom:clamp(10px,1.4vw,18px);position:relative;overflow:hidden;border-radius:2px}
.mgrid .bg{width:100%;display:block;transition:transform 1.1s var(--ease)}
.mgrid .cell:hover .bg{transform:scale(1.06)}
.mgrid .cell::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(20,12,8,.34));opacity:0;transition:.5s}
.mgrid .cell:hover::after{opacity:1}
.mgrid .cell .tag{position:absolute;left:12px;bottom:12px;z-index:2;color:#fff;font-family:var(--geo);
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:0;transform:translateY(8px);transition:.5s var(--ease)}
.mgrid .cell:hover .tag{opacity:1;transform:none}

/* =========================================================
   menu page: price list
   ========================================================= */
.price-block{margin-bottom:clamp(40px,5vw,72px)}
.price-block h3{font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.2vw,26px);letter-spacing:.05em;
  padding-bottom:16px;border-bottom:1px solid var(--ink);display:flex;align-items:baseline;gap:14px}
.price-block h3 .en{font-family:var(--latin);font-style:italic;font-size:15px;color:var(--coral)}
.price-row{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:baseline;
  padding:20px 0;border-bottom:1px solid var(--line)}
.price-row .name{font-size:16px;color:var(--ink)}
.price-row .desc{display:block;color:var(--ink-3);font-size:13px;margin-top:6px;line-height:1.8}
.price-row .yen{font-family:var(--geo);font-size:15px;letter-spacing:.04em;color:var(--coral);white-space:nowrap}
.price-row .yen b{font-weight:500;font-size:20px}

/* =========================================================
   flow steps
   ========================================================= */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,30px);counter-reset:st}
.flow.three{grid-template-columns:repeat(3,1fr)}
.flow .step{position:relative;padding-top:34px}
.flow .step::before{counter-increment:st;content:"0" counter(st);position:absolute;top:0;left:0;
  font-family:var(--latin);font-style:italic;font-size:24px;color:var(--gold)}
.flow .step h4{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:.04em;margin-bottom:10px}
.flow .step p{color:var(--ink-2);font-size:14px;line-height:1.95}
.flow .step::after{content:"";position:absolute;top:12px;right:-15px;width:20px;height:1px;background:var(--line)}
.flow .step:last-child::after{display:none}

/* =========================================================
   reserve page: channels + form
   ========================================================= */
.ways{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.8vw,22px)}
.way{padding:clamp(28px,3vw,42px);border:1px solid var(--line);border-radius:2px;text-align:center;
  transition:.5s var(--ease);background:var(--ivory)}
.way:hover{background:var(--blush);transform:translateY(-4px);box-shadow:0 20px 40px -26px rgba(42,35,31,.4)}
.way .k{font-family:var(--latin);font-style:italic;color:var(--coral);font-size:16px;margin-bottom:8px}
.way h3{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:.04em;margin-bottom:12px}
.way p{color:var(--ink-2);font-size:13.5px;line-height:1.9;margin-bottom:18px}
.form{max-width:640px;margin:0 auto}
.form .fld{margin-bottom:22px}
.form label{display:block;font-family:var(--geo);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:8px}
.form input,.form select,.form textarea{width:100%;padding:14px 16px;border:1px solid var(--line);
  border-radius:2px;background:var(--ivory);font-family:var(--sans);font-size:15px;color:var(--ink);transition:border .3s}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--coral)}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form .note{color:var(--ink-3);font-size:12.5px;margin-top:8px;line-height:1.8}

/* =========================================================
   staff
   ========================================================= */
.staff{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,4vw,56px)}
.staff .card{}
.staff .por{aspect-ratio:4/5;border-radius:2px;overflow:hidden;margin-bottom:20px;
  background:linear-gradient(140deg,#efd8c8,#dcae98)}
.staff .role{font-family:var(--latin);font-style:italic;color:var(--coral);font-size:15px}
.staff h3{font-family:var(--serif);font-weight:600;font-size:22px;letter-spacing:.05em;margin:6px 0 12px}
.staff p{color:var(--ink-2);font-size:14px;line-height:2}

/* =========================================================
   company table
   ========================================================= */
.company{max-width:760px}
.company .row{display:grid;grid-template-columns:180px 1fr;gap:20px;padding:18px 0;border-bottom:1px solid var(--line)}
.company .row:first-child{border-top:1px solid var(--line)}
.company dt{font-family:var(--geo);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);padding-top:3px}
.company dd{color:var(--ink);font-size:15px;line-height:1.9}

/* =========================================================
   responsive
   ========================================================= */
@media (max-width:1024px){
  .gal-grid{grid-template-columns:repeat(3,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .mgrid{columns:3}
  .flow{grid-template-columns:repeat(2,1fr);gap:30px 24px}
  .flow .step::after{display:none}
}
@media (max-width:860px){
  :root{--header-h:64px}
  .nav-list,.nav-tel{display:none}
  .burger{display:block}
  .header .nav-cta{display:none}
  .concept-grid,.care-grid,.access-grid{grid-template-columns:1fr;gap:34px}
  .care-figure{aspect-ratio:16/11}
  .menu-grid{grid-template-columns:1fr}
  .salon-media{grid-template-columns:1fr 1fr}
  .salon-media .m1{grid-row:auto;aspect-ratio:1/1}
  .sec-head{flex-direction:column;align-items:flex-start}
  .mbar{display:grid}
  body{padding-bottom:0}
  .split,.split.rev{grid-template-columns:1fr;gap:30px}
  .split.rev .split-fig{order:0}
  .mgrid{columns:2}
  .ways{grid-template-columns:1fr;gap:12px}
  .staff{grid-template-columns:1fr;gap:34px}
  .company .row{grid-template-columns:130px 1fr;gap:14px}
  .ghost-word{font-size:clamp(70px,20vw,120px);top:auto;bottom:8%}
}
@media (max-width:640px){
  .hero-index{display:none}
  .hero-dots{flex-direction:row;left:var(--gut);right:auto;bottom:26px;gap:9px}
  .hero-inner{padding-bottom:76px}
}
@media (max-width:560px){
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .gal-item.tall{grid-row:auto;aspect-ratio:3/4}
  .concept-quote{font-size:19px;line-height:1.85}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%;justify-content:center}
  .reserve-ways{gap:14px 22px}
  .info-table div{grid-template-columns:96px 1fr;gap:10px}
  .reserve-actions{flex-direction:column;align-items:stretch}
  .reserve-actions .btn{justify-content:center}
  .flow{grid-template-columns:1fr;gap:26px}
  .form .row2{grid-template-columns:1fr;gap:22px}
  .price-row{grid-template-columns:1fr;gap:8px}
  .price-block h3{font-size:20px}
}
