:root{
  --bg:#FAF7F2;
  --bg-warm:#F3EDE3;
  --ink:#2C1810;
  --ink-soft:#4a3628;
  --ink-mute:#7a6a5c;
  --black:#111111;
  --gold:#C9A84C;
  --gold-soft:#b69136;
  --line:rgba(44,24,16,0.14);
  --line-soft:rgba(44,24,16,0.08);
  --serif:"Noto Serif JP",serif;
  --sans:"Noto Sans JP",system-ui,sans-serif;
  --latin:"Cormorant Garamond",serif;
  --display:"Playfair Display",serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:300;-webkit-font-smoothing:antialiased}
body{line-height:1.9;letter-spacing:.04em;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;letter-spacing:inherit}

/* ---------- layout ---------- */
.wrap{max-width:1320px;margin:0 auto;padding:0 64px}
@media (max-width:800px){ .wrap{padding:0 24px} }

/* ---------- typographic primitives ---------- */
.latin{font-family:var(--latin);letter-spacing:.22em;font-weight:300}
.latin-tiny{font-family:var(--latin);font-size:11px;letter-spacing:.42em;font-weight:400;text-transform:uppercase}
.serif{font-family:var(--serif);font-weight:400}
.vrl{writing-mode:vertical-rl;text-orientation:mixed}

.gold-rule{display:inline-block;width:40px;height:1px;background:var(--gold);vertical-align:middle}
.gold-rule.long{width:72px}
.gold-dot{display:inline-block;width:4px;height:4px;background:var(--gold);border-radius:50%;vertical-align:middle}

.section-label{display:flex;align-items:center;gap:18px;font-family:var(--latin);font-size:11px;letter-spacing:.5em;color:var(--ink-soft);text-transform:uppercase}
.section-label .num{color:var(--gold);font-weight:500}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:40;padding:18px 48px;display:flex;align-items:center;transition:background .4s ease,color .3s ease,border-color .3s ease;border-bottom:1px solid transparent}
.nav.on-dark{color:#f5efe2}
.nav.scrolled{background:rgba(250,247,242,.92);backdrop-filter:blur(14px);color:var(--ink);border-bottom-color:var(--line-soft)}
.nav.scrolled.on-dark{color:var(--ink)}
.nav .brand{display:flex;align-items:center;flex:0 0 auto}
.nav .brand .en{font-family:var(--latin);font-size:10px;letter-spacing:.45em;opacity:.7}
.nav .brand-logo{height:48px;width:auto;display:block}
.nav:not(.scrolled) .brand-logo{filter:invert(1) sepia(1) brightness(.5) saturate(15) hue-rotate(-15deg) brightness(1.09)}
.nav.scrolled .brand-logo{filter:none}
.nav ul{flex:1;display:flex;justify-content:center;gap:32px;list-style:none;font-family:var(--serif);font-size:14px;letter-spacing:.18em;font-weight:300}
.nav ul a{position:relative;padding:10px 2px;opacity:.85}
.nav ul a:hover{opacity:1}
.nav .cta-mini{font-family:var(--serif);font-size:12px;letter-spacing:.34em;padding:10px 22px;border:1px solid currentColor;opacity:.9}
.nav .cta-mini:hover{background:var(--gold);color:#fff;border-color:var(--gold)}

/* hamburger button */
.nav-burger{display:none;position:relative;width:44px;height:44px;background:transparent;border:0;padding:0;cursor:pointer;z-index:120;-webkit-tap-highlight-color:transparent}
.nav-burger span{position:absolute;left:10px;width:24px;height:1.5px;background:currentColor;transition:transform .3s ease,opacity .25s ease,top .3s ease,background .3s ease}
.nav-burger span:nth-child(1){top:16px}
.nav-burger span:nth-child(2){top:22px}
.nav-burger span:nth-child(3){top:28px}
.nav-burger.open span{background:#efe6d3}
.nav-burger.open span:nth-child(1){top:22px;transform:rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){top:22px;transform:rotate(-45deg)}

/* mobile overlay */
.nav-overlay{position:fixed;inset:0;z-index:100;background:var(--ink);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease}
.nav-overlay::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 500px at 50% 30%,rgba(201,168,76,.08),transparent 60%);pointer-events:none}
.nav-overlay.open{opacity:1;visibility:visible}
.nav-overlay__inner{position:relative;text-align:center;padding:80px 24px 40px;max-width:480px;width:100%;display:flex;flex-direction:column;align-items:center;gap:48px}
.nav-overlay__list{list-style:none;display:flex;flex-direction:column;gap:32px;margin:0;padding:0}
.nav-overlay__list li{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.nav-overlay.open .nav-overlay__list li{opacity:1;transform:translateY(0)}
.nav-overlay.open .nav-overlay__list li:nth-child(1){transition-delay:.15s}
.nav-overlay.open .nav-overlay__list li:nth-child(2){transition-delay:.20s}
.nav-overlay.open .nav-overlay__list li:nth-child(3){transition-delay:.25s}
.nav-overlay.open .nav-overlay__list li:nth-child(4){transition-delay:.30s}
.nav-overlay.open .nav-overlay__list li:nth-child(5){transition-delay:.35s}
.nav-overlay__list a{display:flex;flex-direction:column;align-items:center;gap:6px;color:#efe6d3;padding:8px 0}
.nav-overlay__list .jp{font-family:var(--serif);font-size:18px;letter-spacing:.3em;font-weight:300}
.nav-overlay__list .en{font-family:var(--latin);font-size:10px;letter-spacing:.45em;color:var(--gold);text-transform:uppercase}
.nav-overlay__cta{display:inline-flex;flex-direction:column;align-items:center;gap:4px;padding:18px 44px;border:1px solid var(--gold);color:var(--gold);font-family:var(--serif);font-size:13px;letter-spacing:.4em;opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease,background .3s ease}
.nav-overlay.open .nav-overlay__cta{opacity:1;transform:translateY(0);transition-delay:.42s}
.nav-overlay__cta:hover{background:rgba(201,168,76,.1)}
.nav-overlay__cta .en{font-family:var(--latin);font-size:9px;letter-spacing:.5em;opacity:.7}
.nav-overlay__contact{display:flex;flex-direction:column;align-items:center;gap:6px;padding-top:24px;border-top:1px solid rgba(239,230,211,.15);width:100%;max-width:280px;font-family:var(--serif);letter-spacing:.18em;color:rgba(239,230,211,.75);opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.nav-overlay.open .nav-overlay__contact{opacity:1;transform:translateY(0);transition-delay:.5s}
.nav-overlay__contact a{color:#efe6d3;font-size:18px;letter-spacing:.16em}
.nav-overlay__contact span{font-size:11px;letter-spacing:.18em;color:rgba(239,230,211,.55)}

@media (max-width:900px){
  .nav{padding:16px 24px}
  .nav ul,.nav .cta-mini{display:none}
  .nav-burger{display:block;color:var(--ink)}
  .nav.on-dark .nav-burger{color:#efe6d3}
  .nav.scrolled .nav-burger{color:var(--ink)}
  .nav.menu-open{background:transparent !important;border-bottom-color:transparent !important;backdrop-filter:none !important;z-index:110}
  .nav.menu-open .brand{color:#efe6d3}
  .nav.menu-open .nav-burger{color:#efe6d3}
}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;color:#efe6d3;background:var(--black);overflow:hidden}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;transform:scale(1.05) translateX(2%);z-index:0}
.hero .backdrop{position:absolute;inset:0;z-index:1;background:
    radial-gradient(1200px 600px at 70% 40%, rgba(201,168,76,.10), transparent 60%),
    radial-gradient(900px 700px at 20% 80%, rgba(255,230,180,.05), transparent 60%),
    linear-gradient(180deg,#0c0806 0%,#1a0f09 55%,#0c0806 100%);
}
.hero.has-photo .backdrop{background:linear-gradient(180deg,rgba(8,5,3,.42) 0%,rgba(16,10,6,.32) 50%,rgba(8,5,3,.45) 100%)}
.hero .grain{position:absolute;inset:0;z-index:1;opacity:.25;mix-blend-mode:soft-light;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.78  0 0 0 0 0.66  0 0 0 0 0.30  0 0 0 0.35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}
.hero .vignette{position:absolute;inset:0;z-index:1;background:radial-gradient(1200px 800px at 50% 50%, transparent 40%, rgba(0,0,0,.6) 100%)}

.hero .content{position:relative;z-index:2;min-height:100vh;display:grid;grid-template-columns:220px 1fr 220px;align-items:center;padding:120px 64px}
.hero .side{font-family:var(--latin);font-size:10px;letter-spacing:.55em;color:rgba(239,230,211,.55);text-transform:uppercase;display:flex;flex-direction:column;gap:18px;justify-content:space-between;min-height:60vh}
.hero .side.right{align-items:flex-end;text-align:right}
.hero .side .vline{width:1px;flex:1;background:linear-gradient(180deg,transparent,rgba(201,168,76,.35) 30%,rgba(201,168,76,.35) 70%,transparent);margin:0 auto}

.hero .center{text-align:center;display:flex;flex-direction:column;align-items:center;gap:28px}
.hero .kicker{font-family:var(--latin);font-size:12px;letter-spacing:.6em;color:var(--gold);text-transform:uppercase;display:flex;align-items:center;gap:16px}
.hero .kicker .line{width:32px;height:1px;background:var(--gold);opacity:.7}

.hero .catchcopy{font-family:var(--serif);font-weight:300;font-size:clamp(44px,5.2vw,78px);letter-spacing:.22em;line-height:1.7;color:#fff;padding:44px 0;position:relative}
.hero .catchcopy::before,.hero .catchcopy::after{content:"";position:absolute;left:50%;transform:translateX(-50%);width:64px;height:1px;background:var(--gold)}
.hero .catchcopy::before{top:0}
.hero .catchcopy::after{bottom:0}
.hero .catchcopy .accent{color:var(--gold)}

.hero .catchcopy.vertical{display:flex;justify-content:center;gap:.5em;writing-mode:vertical-rl;text-orientation:upright;padding:44px 0;letter-spacing:.35em}

.hero .subtitle{font-family:var(--latin);font-size:14px;letter-spacing:.58em;color:rgba(239,230,211,.85);text-transform:uppercase}
.hero .established{margin-top:18px;font-family:var(--latin);font-size:10px;letter-spacing:.5em;color:rgba(201,168,76,.7);text-transform:uppercase}

.hero .scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:14px;font-family:var(--latin);font-size:10px;letter-spacing:.5em;color:rgba(239,230,211,.55);text-transform:uppercase;z-index:2}
.hero .scroll .bar{width:1px;height:56px;background:linear-gradient(180deg,rgba(201,168,76,.7),transparent);animation:scrollbar 2.6s ease-in-out infinite}
@keyframes scrollbar{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(.2);transform-origin:bottom}}

@media (max-width:900px){
  .hero .content{grid-template-columns:1fr;padding:140px 24px 120px;gap:60px}
  .hero .side{display:none}
  .hero .catchcopy{font-size:36px;letter-spacing:.22em;line-height:2.1}
}

/* ---------- intro ---------- */
.intro{padding:180px 0;position:relative}
.intro .grid{display:grid;grid-template-columns:1fr 1fr;gap:120px;align-items:start}
.intro .col-label{display:flex;flex-direction:column;gap:80px;padding-top:20px}
.intro .vertical-title{writing-mode:vertical-rl;text-orientation:mixed;font-family:var(--serif);font-size:28px;letter-spacing:.4em;line-height:2.2;color:var(--ink);margin-left:auto;min-height:320px}
.intro .lead{font-family:var(--serif);font-size:32px;line-height:2;letter-spacing:.18em;color:var(--ink);font-weight:400;margin-bottom:56px}
.intro .lead .accent{color:var(--gold)}
.intro p.body{font-size:14px;line-height:2.3;letter-spacing:.14em;color:var(--ink-soft);margin-bottom:28px;max-width:520px}

.intro .lineage{margin-top:72px;padding:40px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.intro .lineage .gen{display:flex;flex-direction:column;gap:8px}
.intro .lineage .era{font-family:var(--latin);font-size:10px;letter-spacing:.4em;color:var(--gold);text-transform:uppercase}
.intro .lineage .name{font-family:var(--serif);font-size:15px;letter-spacing:.2em}
.intro .lineage .role{font-size:11px;letter-spacing:.16em;color:var(--ink-mute)}

.intro__gallery{margin-top:88px;position:relative}
.intro__gallery-hero .intro__gallery-frame{aspect-ratio:16/7;overflow:hidden}
.intro__gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.intro__gallery-frame{overflow:hidden}
.intro__gallery-cell .intro__gallery-frame{aspect-ratio:4/3}
.intro__gallery-img{width:100%;height:120%;object-fit:cover;display:block;transform-origin:center top;will-change:transform}
@supports (animation-timeline:scroll()){
  .intro__gallery-img{animation:intro-parallax linear both;animation-timeline:scroll(root);animation-range:cover 0% cover 100%}
  @keyframes intro-parallax{from{transform:translateY(0)}to{transform:translateY(-16.5%)}}
}
.intro__gallery-caption{display:block;margin-top:14px;font-family:var(--latin);font-size:10px;letter-spacing:.44em;color:var(--ink-mute);text-transform:uppercase}

@media (max-width:900px){
  .intro{padding:110px 0}
  .intro .grid{grid-template-columns:1fr;gap:48px}
  .intro .vertical-title{writing-mode:horizontal-tb;font-size:22px;min-height:auto}
  .intro .lead{font-size:22px}
  .intro .lineage{grid-template-columns:repeat(2,1fr);gap:32px}
  .intro__gallery-hero .intro__gallery-frame{aspect-ratio:4/3}
  .intro__gallery-grid{grid-template-columns:1fr;gap:12px}
}

/* ---------- menu ---------- */
.menu{padding:180px 0;background:var(--bg-warm);position:relative}
.menu .head{display:flex;flex-direction:column;align-items:center;gap:28px;margin-bottom:100px;text-align:center}
.menu .head h2{font-family:var(--serif);font-weight:400;font-size:38px;letter-spacing:.4em;line-height:1.6}
.menu .head p{max-width:520px;font-size:13px;line-height:2.2;letter-spacing:.14em;color:var(--ink-soft)}

.menu-single{max-width:780px;margin:0 auto;text-align:center}
.menu-single__label{margin-bottom:56px}
.menu-single__title{font-family:var(--serif);font-size:32px;letter-spacing:.44em;font-weight:400;margin-top:16px;color:var(--ink)}
.menu-single__body p{font-size:14.5px;line-height:2.6;letter-spacing:.12em;color:var(--ink-soft);margin-bottom:36px;text-align:left}
.menu-single__conclusion{color:var(--ink)!important;font-family:var(--serif);font-weight:400;font-size:15px!important;border-top:1px solid var(--line);padding-top:40px}

@media (max-width:900px){
  .menu{padding:110px 0}
  .menu .head h2{font-size:26px;letter-spacing:.3em}
  .menu-single__title{font-size:24px;letter-spacing:.3em}
  .menu-single__body p{font-size:13.5px}
}

/* ---------- pricing ---------- */
.pricing{padding:180px 0;background:var(--ink);color:#efe6d3}
.pricing .head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:80px}
.pricing .head .label{color:rgba(239,230,211,.7)}
.pricing .head h2{font-family:var(--serif);font-size:36px;letter-spacing:.34em;font-weight:300;line-height:1.4}
.pricing .head h2 .accent{color:var(--gold)}
.pricing .head .note{max-width:320px;font-size:12px;line-height:2.1;letter-spacing:.12em;color:rgba(239,230,211,.6);text-align:right}

.price-table{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(201,168,76,.25);border-bottom:1px solid rgba(201,168,76,.25)}
.price-table .row{padding:56px 44px;display:flex;flex-direction:column;gap:18px;position:relative}
.price-table .row + .row{border-left:1px solid rgba(239,230,211,.1)}
.price-table .row:hover{background:rgba(201,168,76,.06)}
.price-table .duration{font-family:var(--latin);font-size:11px;letter-spacing:.5em;color:var(--gold);text-transform:uppercase}
.price-table .minutes{font-family:var(--serif);font-weight:300;font-size:56px;line-height:1;letter-spacing:.1em;display:flex;align-items:baseline;gap:6px}
.price-table .minutes small{font-size:14px;letter-spacing:.3em;color:rgba(239,230,211,.6)}
.price-table .jp{font-family:var(--serif);font-size:15px;letter-spacing:.26em}
.price-table .price-tiers{margin-top:20px;display:flex;flex-direction:column;gap:14px;border-top:1px solid rgba(201,168,76,.2);padding-top:20px}
.price-table .price-tier{display:flex;align-items:baseline;justify-content:space-between}
.price-table .price-tier .tier-label{font-size:11px;letter-spacing:.22em;color:rgba(239,230,211,.5)}
.price-table .price{display:flex;align-items:baseline;gap:4px;font-family:var(--serif)}
.price-table .price .yen{font-size:12px;letter-spacing:.1em;color:rgba(239,230,211,.6)}
.price-table .price .amt{font-size:26px;letter-spacing:.05em;color:#fff}
.price-table .price-tier.special .tier-label{color:var(--gold)}
.price-table .price-tier.special .price .yen{color:rgba(201,168,76,.7)}
.price-table .price-tier.special .price .amt{color:var(--gold)}
.price-table .desc{font-size:12px;line-height:2;letter-spacing:.1em;color:rgba(239,230,211,.6);margin-top:14px}

.pricing .footnote-special{margin-top:48px;padding:18px 0;border-top:double 3px rgba(201,168,76,.5);border-bottom:double 3px rgba(201,168,76,.5);color:var(--gold);font-size:12px;letter-spacing:.18em;text-align:center}
.pricing .footnote-note{margin-top:20px;font-size:11px;letter-spacing:.14em;color:rgba(239,230,211,.4);text-align:center}

.pricing__rooms{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:56px}
.pricing__room{position:relative;overflow:hidden}
.pricing__room-img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block}
.pricing__room-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.65));color:#efe6d3;font-family:var(--serif);font-size:13px;letter-spacing:.18em;padding:32px 20px 16px;display:block}

@media (max-width:900px){
  .pricing{padding:110px 0}
  .pricing .head{flex-direction:column;align-items:flex-start}
  .pricing .head .note{text-align:left}
  .price-table{grid-template-columns:1fr}
  .price-table .row + .row{border-left:0;border-top:1px solid rgba(239,230,211,.1)}
  .pricing__rooms{grid-template-columns:1fr;gap:12px}
}

/* ---------- history ---------- */
.history{padding:180px 0;background:var(--black);color:#efe6d3}
.history .section-label{color:rgba(239,230,211,.6)}
.history__head{margin-bottom:96px}
.history__head h2{font-family:var(--serif);font-size:36px;letter-spacing:.36em;font-weight:400;margin-top:24px;line-height:1.6}
.history__timeline{max-width:1000px}
.history__entry{display:flex;align-items:stretch;gap:72px;padding-bottom:96px}
.history__entry+.history__entry{border-top:1px solid rgba(239,230,211,.12);padding-top:96px}
.history__entry:last-child{padding-bottom:0}
.history__entry--even{flex-direction:row-reverse}
.history__photo-wrap{flex:0 0 260px}
.history__photo{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:grayscale(1) contrast(1.05)}
.history__content{flex:1;display:flex;flex-direction:column;justify-content:center}
.history__char{height:72px;width:auto;display:block;opacity:.9;margin-bottom:24px;align-self:flex-start;filter:invert(1) sepia(1) brightness(.5) saturate(15) hue-rotate(-15deg) brightness(1.09)}
.history__date{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:18px}
.history__year-num{font-family:var(--latin);font-size:24px;letter-spacing:.14em;color:var(--gold);font-weight:300;line-height:1}
.history__era{font-family:var(--sans);font-size:11px;color:rgba(239,230,211,.5);letter-spacing:.2em;position:relative;padding-left:16px}
.history__era::before{content:"";position:absolute;left:0;top:50%;width:10px;height:1px;background:var(--gold);opacity:.55}
.history__gen{font-family:var(--sans);font-size:14px;letter-spacing:.18em;color:var(--gold);display:block;margin-bottom:12px}
.history__name{font-family:var(--serif);font-size:28px;letter-spacing:.32em;font-weight:400;line-height:1.5;margin-bottom:6px}
.history__en{font-family:var(--latin);font-size:11px;letter-spacing:.3em;color:rgba(239,230,211,.6);display:block;margin-bottom:20px}
.history__desc{font-size:14px;line-height:2.4;letter-spacing:.12em;color:rgba(239,230,211,.75);max-width:480px}
@media (max-width:900px){
  .history{padding:110px 0}
  .history__entry{flex-direction:column!important;gap:0;padding-bottom:64px}
  .history__entry+.history__entry{padding-top:64px}
  .history__photo-wrap{flex:none;width:100%;height:280px}
  .history__content{padding-top:32px}
  .history__char{height:56px;margin-bottom:18px}
  .history__year-num{font-size:18px}
  .history__name{font-size:22px;letter-spacing:.24em}
}

/* ---------- access ---------- */
.access{padding:180px 0;position:relative}
.access .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:96px;align-items:stretch}
.access .info h2{font-family:var(--serif);font-size:34px;letter-spacing:.32em;font-weight:400;margin:18px 0 48px}
.access dl{display:grid;grid-template-columns:120px 1fr;gap:20px 24px;border-top:1px solid var(--line);padding-top:32px}
.access dt{font-family:var(--latin);font-size:10px;letter-spacing:.4em;color:var(--gold);text-transform:uppercase;padding-top:6px}
.access dd{font-family:var(--serif);font-size:15px;line-height:2;letter-spacing:.16em;color:var(--ink);border-bottom:1px solid var(--line-soft);padding-bottom:20px}
.access dd small{display:block;font-family:var(--sans);font-size:12px;color:var(--ink-mute);letter-spacing:.12em;margin-top:4px}

.access .map{position:relative;min-height:480px;overflow:hidden;border:1px solid var(--line)}
.access .map iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

@media (max-width:900px){
  .access{padding:110px 0}
  .access .grid{grid-template-columns:1fr;gap:40px}
  .access .map{min-height:320px}
}

/* ---------- trust ---------- */
.trust{background:#0c0806;overflow:hidden;position:relative}
.trust::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 1000px 280px at 50% 115%,rgba(201,168,76,.16),transparent 55%);pointer-events:none}
.trust__items{display:flex;align-items:stretch;position:relative;z-index:1}
.trust__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:96px 40px;gap:0}
.trust__item--hero{background:rgba(201,168,76,.035);padding:112px 48px}
.trust__stat{display:flex;align-items:baseline;justify-content:center;gap:6px;margin-bottom:28px}
.trust__num{font-family:var(--display);font-size:clamp(68px,8vw,104px);font-weight:400;letter-spacing:-.01em;line-height:1;color:rgba(239,230,211,.7)}
.trust__unit{font-family:var(--serif);font-size:clamp(22px,2.4vw,32px);font-weight:300;letter-spacing:.08em;color:rgba(239,230,211,.45);padding-bottom:.1em}
.trust__item--hero .trust__num{font-size:clamp(100px,13vw,158px);color:var(--gold);text-shadow:0 0 48px rgba(201,168,76,.45),0 0 120px rgba(201,168,76,.15)}
.trust__item--hero .trust__unit{font-size:clamp(34px,3.8vw,52px);color:rgba(201,168,76,.65)}
.trust__rule{display:none}
.trust__title{font-family:var(--serif);font-size:clamp(14px,1.6vw,18px);letter-spacing:.28em;line-height:2;color:rgba(239,230,211,.55)}
.trust__item--hero .trust__title{font-size:clamp(16px,1.8vw,20px);color:rgba(239,230,211,.8);letter-spacing:.3em}
.trust__sub{display:inline-block;font-family:var(--serif);font-size:11px;letter-spacing:.4em;color:rgba(201,168,76,.85);border:1px solid rgba(201,168,76,.3);padding:5px 14px;margin-top:20px}
.trust__divider{width:1px;flex-shrink:0;align-self:stretch;background:linear-gradient(to bottom,transparent,rgba(239,230,211,.12) 25%,rgba(239,230,211,.12) 75%,transparent)}
@media (max-width:900px){
  .trust__items{flex-direction:column}
  .trust__divider{width:100%;height:1px;background:linear-gradient(to right,transparent,rgba(239,230,211,.12) 25%,rgba(239,230,211,.12) 75%,transparent)}
  .trust__item,.trust__item--hero{padding:64px 28px}
  .trust__item--hero .trust__num{font-size:clamp(88px,22vw,130px)}
}

/* ---------- voices ---------- */
.voices{padding:180px 0;background:var(--bg)}
.voices__head{margin-bottom:80px}
.voices__head h2{font-family:var(--serif);font-size:36px;letter-spacing:.36em;font-weight:400;margin-top:24px}
.voices__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line)}
.voices__card{background:var(--bg);padding:48px 40px;display:flex;flex-direction:column;gap:16px}
.voices__mark{font-family:var(--latin);font-size:56px;line-height:.9;color:var(--gold);opacity:.55;font-weight:300;margin-bottom:4px}
.voices__text{font-family:var(--serif);font-size:14px;line-height:2.5;letter-spacing:.14em;color:var(--ink-soft);flex:1}
.voices__meta{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--line);margin-top:auto}
.voices__stars{color:var(--gold);font-size:11px;letter-spacing:.2em}
.voices__source{font-family:var(--latin);font-size:9px;letter-spacing:.38em;color:var(--ink-mute);text-transform:uppercase}

.voices__google{text-align:center;max-width:560px;margin:0 auto;padding:72px 48px;background:rgba(255,255,255,.55);border:1px solid var(--line)}
.voices__stars-row{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:32px}
.voices__google-text{font-family:var(--serif);font-size:15px;letter-spacing:.2em;line-height:2.2;color:var(--ink-soft);margin-bottom:44px}
.voices__google-btn{display:inline-flex;align-items:center;gap:16px;padding:18px 44px;border:1px solid var(--gold);color:var(--ink);font-family:var(--serif);font-size:13px;letter-spacing:.28em;text-decoration:none;transition:background .3s,color .3s}
.voices__google-btn:hover{background:var(--gold);color:#fff}
.voices__google-btn-arrow{font-size:16px;color:var(--gold);transition:color .3s,transform .3s}
.voices__google-btn:hover .voices__google-btn-arrow{color:#fff;transform:translateX(4px)}

@media (max-width:900px){
  .voices{padding:110px 0}
  .voices__google{padding:48px 28px}
  .voices__google-text{font-size:14px;letter-spacing:.14em}
  .voices__google-btn{padding:16px 28px;font-size:12px}
}

/* ---------- faq ---------- */
.faq{padding:140px 0;background:var(--bg-warm)}
.faq__head{margin-bottom:64px}
.faq__head h2{font-family:var(--serif);font-size:36px;letter-spacing:.36em;font-weight:400;margin-top:24px}
.faq__list{max-width:760px;margin:0 auto}
.faq__item{border-bottom:1px solid var(--line);padding:36px 0}
.faq__item:first-child{border-top:1px solid var(--line)}
.faq__q{font-family:var(--serif);font-size:15px;letter-spacing:.2em;color:var(--ink);margin-bottom:16px;padding-left:20px;position:relative}
.faq__q::before{content:"Q";position:absolute;left:0;top:0;font-family:var(--latin);font-size:12px;letter-spacing:.2em;color:var(--gold);font-weight:500}
.faq__a{font-size:14px;line-height:2.2;letter-spacing:.1em;color:var(--ink-soft);padding-left:20px;white-space:pre-line}
.faq__link{display:inline-block;margin-top:10px;font-family:var(--serif);font-size:13px;letter-spacing:.16em;color:var(--ink);border-bottom:1px solid rgba(201,168,76,.5);text-decoration:none;transition:color .3s,border-color .3s}
.faq__link:hover{color:var(--gold);border-bottom-color:var(--gold)}

/* ---------- first-visit (EN) ---------- */
.first-visit{padding:140px 0;background:var(--bg-warm)}
.first-visit__label{margin-bottom:16px}
.first-visit__title{font-family:var(--serif);font-size:clamp(28px,3.4vw,42px);letter-spacing:.28em;font-weight:400;color:var(--ink);margin:24px 0 64px;line-height:1.7}
.first-visit__highlights{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:760px;margin:0 auto 72px;border:1px solid var(--line)}
.first-visit__highlight{display:flex;align-items:center;gap:16px;padding:22px 28px;border-bottom:1px solid var(--line);font-family:var(--serif);font-size:14px;letter-spacing:.14em;color:var(--ink-soft)}
.first-visit__highlight:nth-child(odd){border-right:1px solid var(--line)}
.first-visit__highlight:nth-last-child(-n+2){border-bottom:none}
.first-visit__check{color:var(--gold);font-size:14px;flex-shrink:0}
.first-visit__faq{margin-top:0}

@media (max-width:900px){
  .faq{padding:90px 0}
  .faq__head h2{font-size:28px}
  .faq__q{font-size:14px}
  .faq__a{font-size:13.5px}
  .first-visit{padding:90px 0}
  .first-visit__title{margin-bottom:48px}
  .first-visit__highlights{grid-template-columns:1fr}
  .first-visit__highlight{border-right:none!important}
  .first-visit__highlight:nth-last-child(-n+2){border-bottom:1px solid var(--line)}
  .first-visit__highlight:last-child{border-bottom:none}
}

/* ---------- cta ---------- */
.cta{padding:160px 0;background:var(--ink);color:#efe6d3;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:
  radial-gradient(800px 400px at 50% 100%, rgba(201,168,76,.12), transparent 60%);
  pointer-events:none}
.cta .inner{text-align:center;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:32px}
.cta .kana{font-family:var(--serif);font-size:clamp(30px,3.4vw,46px);letter-spacing:.4em;line-height:1.8;font-weight:300}
.cta .kana .accent{color:var(--gold)}
.cta .desc{max-width:520px;font-size:13px;line-height:2.2;letter-spacing:.14em;color:rgba(239,230,211,.7)}
.cta .buttons{display:flex;gap:16px;margin-top:20px;flex-wrap:wrap;justify-content:center}

.btn-gold{display:inline-flex;align-items:center;gap:18px;padding:22px 44px;background:var(--gold);color:#1a0f09;font-family:var(--serif);font-size:13px;letter-spacing:.4em;font-weight:500;transition:background .3s ease,letter-spacing .3s ease,gap .3s ease;border:1px solid var(--gold)}
.btn-gold:hover{background:var(--gold-soft);gap:26px;letter-spacing:.42em}
.btn-gold .en{font-family:var(--latin);font-size:10px;letter-spacing:.4em;opacity:.75}
.btn-gold .arrow{width:24px;height:1px;background:currentColor;position:relative}
.btn-gold .arrow::after{content:"";position:absolute;right:0;top:-3px;width:8px;height:1px;background:currentColor;transform:rotate(30deg);transform-origin:right}

.btn-ghost{display:inline-flex;align-items:center;gap:18px;padding:22px 40px;background:transparent;color:#efe6d3;border:1px solid rgba(239,230,211,.35);font-family:var(--serif);font-size:13px;letter-spacing:.4em;transition:border-color .3s ease,background .3s ease}
.btn-ghost:hover{border-color:var(--gold);background:rgba(201,168,76,.08)}

.cta .reservation-note{margin-top:36px}
.cta .reservation-note a{display:inline-flex;align-items:center;gap:10px;font-family:var(--serif);font-size:12px;letter-spacing:.18em;color:rgba(239,230,211,.6);padding:8px 4px;border-bottom:1px solid rgba(239,230,211,.15);transition:color .3s ease,border-color .3s ease}
.cta .reservation-note a:hover{color:var(--gold);border-bottom-color:var(--gold)}
.cta .reservation-note .arrow{font-family:var(--latin);font-size:13px;color:var(--gold);transition:transform .3s ease}
.cta .reservation-note a:hover .arrow{transform:translateX(4px)}

/* ---------- footer ---------- */
.footer{background:#0c0806;color:rgba(239,230,211,.6);padding:80px 0 40px}
.footer .grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px}
.footer h4{font-family:var(--latin);font-size:10px;letter-spacing:.5em;color:var(--gold);text-transform:uppercase;margin-bottom:22px;font-weight:500}
.footer .brand-block{display:flex;flex-direction:column;gap:16px}
.footer-logo{align-self:flex-start;width:160px;height:auto;display:block;filter:invert(1) sepia(.15) brightness(.92);opacity:.88}
.footer .brand-block .name{font-family:var(--serif);font-size:17px;letter-spacing:.32em;color:#efe6d3}
.footer .brand-block .en{font-family:var(--latin);font-size:10px;letter-spacing:.5em;opacity:.6}
.footer .brand-block p{font-size:12px;line-height:2;letter-spacing:.12em}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:14px;font-size:12px;letter-spacing:.16em}
.footer .bottom{border-top:1px solid rgba(239,230,211,.12);padding-top:28px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.footer .bottom__copy{display:flex;flex-direction:column;gap:6px;font-family:var(--latin);font-size:10px;letter-spacing:.4em;text-transform:uppercase;opacity:.55}
.footer .bottom__links{display:flex;gap:24px}
.footer .bottom__links a{font-family:var(--sans);font-size:11px;letter-spacing:.18em;color:rgba(239,230,211,.6);transition:color .3s ease}
.footer .bottom__links a:hover{color:var(--gold)}

@media (max-width:900px){
  .footer .grid{grid-template-columns:1fr 1fr;gap:36px}
  .footer .bottom{flex-direction:column;gap:12px}
}
@media (max-width:600px){
  .footer .grid{grid-template-columns:1fr;gap:32px}
  .footer .bottom__links{flex-direction:column;gap:12px}
  .cta .buttons{flex-direction:column;align-items:center}
  .btn-gold,.btn-ghost{width:100%;justify-content:center;text-align:center;font-size:11px;letter-spacing:.2em;padding:18px 24px}
  .trust__item,.trust__item--hero{padding:48px 20px}
}

/* ---------- tweaks panel ---------- */
.tweaks{position:fixed;bottom:24px;right:24px;z-index:90;width:300px;background:rgba(17,17,17,.96);color:#efe6d3;padding:22px;font-family:var(--sans);font-size:12px;letter-spacing:.08em;border:1px solid rgba(201,168,76,.3);backdrop-filter:blur(14px);display:none}
.tweaks.open{display:block}
.tweaks h5{font-family:var(--latin);font-size:11px;letter-spacing:.42em;color:var(--gold);text-transform:uppercase;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}
.tweaks h5 button{color:rgba(239,230,211,.6);font-size:16px;line-height:1}
.tweaks .row{margin-bottom:14px}
.tweaks label{display:block;color:rgba(239,230,211,.7);font-size:10px;letter-spacing:.2em;margin-bottom:6px;text-transform:uppercase}
.tweaks .seg{display:flex;border:1px solid rgba(239,230,211,.2)}
.tweaks .seg button{flex:1;padding:8px;font-size:10px;letter-spacing:.2em;color:rgba(239,230,211,.7);text-transform:uppercase}
.tweaks .seg button.active{background:var(--gold);color:#111}
.tweaks .check{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-top:1px solid rgba(239,230,211,.08);font-size:11px;color:rgba(239,230,211,.85)}
.tweaks .check input{accent-color:var(--gold)}

/* ---------- hero-en ---------- */
.hero-en .hero-en__content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:2;padding:100px 24px 0}
.hero-en__kicker{display:flex;align-items:center;gap:20px;font-family:var(--latin);font-size:10px;letter-spacing:.55em;color:rgba(201,168,76,.75);text-transform:uppercase;margin-bottom:36px}
.hero-en__kicker .line{flex:1;max-width:60px;height:1px;background:rgba(201,168,76,.35)}
.hero-en__headline{font-family:var(--display);font-size:clamp(48px,7.5vw,110px);font-weight:400;line-height:1.15;letter-spacing:-.01em;color:#efe6d3;margin-bottom:32px;text-align:center}
.hero-en__shiatsu{display:block;letter-spacing:.18em;color:var(--gold);font-size:clamp(56px,9vw,130px);line-height:1.05}
.hero-en__sub{font-family:var(--latin);font-size:clamp(14px,1.6vw,19px);letter-spacing:.3em;color:rgba(239,230,211,.55);line-height:2;margin-bottom:20px}
.hero-en__note{font-family:var(--serif);font-size:clamp(11px,1.2vw,13px);letter-spacing:.2em;color:rgba(201,168,76,.65);line-height:2;margin-bottom:52px}
.hero-en__actions{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.hero-en__tel{font-family:var(--latin);font-size:14px;letter-spacing:.25em;color:rgba(239,230,211,.55);border-bottom:1px solid rgba(239,230,211,.2);padding-bottom:4px;transition:color .3s,border-color .3s}
.hero-en__tel:hover{color:var(--gold);border-color:var(--gold)}
@media(max-width:900px){
  .hero-en .hero-en__content{padding:88px 20px 0}
  .hero-en__kicker{gap:12px;font-size:9px}
  .hero-en__kicker .line{max-width:32px}
  .hero-en__headline{font-size:clamp(36px,11vw,64px)}
  .hero-en__shiatsu{font-size:clamp(44px,14vw,80px);letter-spacing:.12em}
  .hero-en__sub{font-size:13px;letter-spacing:.2em}
  .hero-en__note{display:none}
  .hero-en__actions{flex-direction:column;gap:16px;width:100%}
  .hero-en__actions .btn-gold,.hero-en__actions .btn-ghost{width:100%;justify-content:center}
  .hero-en__tel{font-size:13px}
}

/* ---------- celebrities ---------- */
.celebrities{background:#0c0806;overflow:hidden;position:relative}
.celebrities::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 1200px 400px at 50% 120%,rgba(201,168,76,.12),transparent 55%);pointer-events:none}
.celebrities__header{padding:120px 64px 80px;text-align:center;position:relative;z-index:1}
.celebrities__eyebrow{font-family:var(--latin);font-size:10px;letter-spacing:.65em;color:var(--gold);text-transform:uppercase;margin-bottom:32px}
.celebrities__title{font-family:var(--serif);font-size:clamp(28px,3.5vw,44px);font-weight:300;letter-spacing:.2em;line-height:1.7;color:rgba(239,230,211,.75)}
.celebrities__grid{display:grid;grid-template-columns:1fr 1fr;position:relative;z-index:1}
.celebrities__card{padding:80px 72px 96px;border-top:1px solid rgba(239,230,211,.07);position:relative}
.celebrities__card:first-child{border-right:1px solid rgba(239,230,211,.07)}
.celebrities__card::before{content:"";position:absolute;top:0;left:72px;width:40px;height:2px;background:var(--gold);opacity:.5}
.celebrities__role{font-family:var(--latin);font-size:9px;letter-spacing:.7em;color:var(--gold);text-transform:uppercase;margin-bottom:20px}
.celebrities__name{font-family:var(--display);font-size:clamp(40px,5.5vw,76px);font-weight:400;line-height:1.05;color:rgba(239,230,211,.85);margin-bottom:20px;display:flex;flex-direction:column}
.celebrities__date{font-family:var(--latin);font-size:11px;letter-spacing:.4em;color:rgba(239,230,211,.28);margin-bottom:36px}
.celebrities__desc{font-family:var(--serif);font-size:14px;line-height:2.6;letter-spacing:.15em;color:rgba(239,230,211,.45);max-width:440px}
.celebrities__bridge{border-top:1px solid rgba(201,168,76,.14);background:rgba(201,168,76,.03);padding:72px 64px;position:relative;z-index:1}
.celebrities__bridge-inner{display:flex;align-items:center;gap:64px;max-width:900px;margin:0 auto}
.celebrities__bridge-num{font-family:var(--display);font-size:clamp(64px,8vw,100px);font-weight:400;color:var(--gold);flex-shrink:0;line-height:1;text-shadow:0 0 40px rgba(201,168,76,.3)}
.celebrities__bridge-text{font-family:var(--serif);font-size:clamp(13px,1.5vw,16px);line-height:2.4;letter-spacing:.2em;color:rgba(239,230,211,.5)}
.celebrities__bridge-text strong{color:rgba(239,230,211,.78);font-weight:400}
@media(max-width:900px){
  .celebrities__header{padding:80px 28px 56px}
  .celebrities__grid{grid-template-columns:1fr}
  .celebrities__card{padding:56px 28px 64px}
  .celebrities__card:first-child{border-right:none;border-bottom:1px solid rgba(239,230,211,.07)}
  .celebrities__card::before{left:28px}
  .celebrities__bridge{padding:56px 28px}
  .celebrities__bridge-inner{flex-direction:column;gap:32px;text-align:center}
}

/* ---------- origin ---------- */
.origin{padding:180px 0;background:var(--bg)}
.origin__label{margin-bottom:40px}
.origin__head{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-bottom:64px}
.origin__headline{font-family:var(--display);font-size:clamp(40px,5vw,68px);font-weight:400;line-height:1.1;letter-spacing:-.01em;color:var(--ink)}
.origin__lead{font-family:var(--serif);font-size:clamp(14px,1.5vw,17px);line-height:2.4;letter-spacing:.16em;color:var(--ink-soft);padding-top:12px}
.origin__body{font-family:var(--serif);font-size:14px;line-height:2.8;letter-spacing:.16em;color:var(--ink-mute);max-width:860px;margin-bottom:96px;padding-top:0;border-top:1px solid var(--line);padding-top:48px}
.origin__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.origin__stat{background:var(--bg);padding:48px 36px;display:flex;flex-direction:column;gap:12px}
.origin__stat-num{font-family:var(--display);font-size:clamp(36px,4vw,52px);font-weight:400;color:var(--ink);letter-spacing:-.01em;line-height:1}
.origin__stat-title{font-family:var(--latin);font-size:9px;letter-spacing:.55em;text-transform:uppercase;color:var(--gold)}
.origin__stat-desc{font-family:var(--serif);font-size:12px;line-height:2.2;letter-spacing:.12em;color:var(--ink-mute);margin-top:8px}
@media(max-width:900px){
  .origin{padding:110px 0}
  .origin__head{grid-template-columns:1fr;gap:40px}
  .origin__stats{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .origin__stats{grid-template-columns:1fr}
}

/* ---------- nav lang switch ---------- */
.nav__lang-item{list-style:none}
.nav__lang{display:flex!important;flex-direction:column!important;align-items:center!important;font-family:var(--latin)!important;border:1px solid rgba(239,230,211,.55)!important;padding:5px 14px!important;transition:all .3s!important;background:rgba(239,230,211,.06)!important;text-decoration:none!important;line-height:1!important;gap:3px!important}
.nav__lang-sub{font-size:8px!important;letter-spacing:.22em!important;text-transform:uppercase!important;color:rgba(239,230,211,.55)!important;transition:color .3s!important}
.nav__lang-text{font-size:11px!important;letter-spacing:.18em!important;text-transform:uppercase!important;color:rgba(239,230,211,.9)!important;font-weight:500!important;transition:color .3s!important}
.nav__lang:hover{border-color:var(--gold)!important;background:rgba(201,168,76,.1)!important}
.nav__lang:hover .nav__lang-sub,.nav__lang:hover .nav__lang-text{color:var(--gold)!important}
.nav.scrolled .nav__lang{border-color:rgba(44,24,16,.3)!important;background:transparent!important}
.nav.scrolled .nav__lang .nav__lang-sub{color:rgba(44,24,16,.4)!important}
.nav.scrolled .nav__lang .nav__lang-text{color:var(--ink-soft)!important}
.nav.scrolled .nav__lang:hover{border-color:var(--gold-soft)!important;background:rgba(201,168,76,.06)!important}
.nav.scrolled .nav__lang:hover .nav__lang-sub,.nav.scrolled .nav__lang:hover .nav__lang-text{color:var(--gold-soft)!important}
/* overlay lang section */
.nav-overlay__lang{margin:28px 0 0;padding:20px 0 0;border-top:1px solid rgba(239,230,211,.12);text-align:center}
.nav-overlay__lang-label{display:block;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(239,230,211,.45);margin-bottom:12px;font-family:var(--latin)}
.nav-overlay__lang-btn{display:inline-block;font-family:var(--latin);font-size:13px;letter-spacing:.15em;color:rgba(239,230,211,.85);border:1px solid rgba(239,230,211,.4);padding:9px 28px;transition:all .3s}
.nav-overlay__lang-btn:hover{color:var(--gold);border-color:var(--gold);background:rgba(201,168,76,.08)}

/* ---------- fade in ---------- */
.reveal{opacity:0;transform:translateY(12px);transition:opacity 1.1s ease,transform 1.1s ease}
.reveal.visible{opacity:1;transform:none}
