/* ============================================================
   SPARK SUPPER CLUB BERLIN — "Dinner Above Berlin"
   Cinematic quiet-luxury system on the SPARK brand foundation
   ============================================================ */

/* FONTS ─ SPARK brand faces ──────────────────────────────── */
@font-face{
  font-family:"GT Super Display";
  src:url("fonts/GT-Super-Display-Bold.woff2") format("woff2"),
      url("fonts/GT-Super-Display-Bold.woff") format("woff");
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Sohne";
  src:url("fonts/Sohne-Buch.otf") format("opentype");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Sohne";
  src:url("fonts/Sohne-Kraftig.otf") format("opentype");
  font-weight:500; font-style:normal; font-display:swap;
}

:root{
  /* dark cinematic palette */
  --noir:        #0B0A09;
  --noir-soft:   #131110;
  --char:        #1A1714;   /* card surface */
  --char-2:      #211D19;

  /* warm ivory light surface */
  --paper:       #F3ECDF;
  --paper-soft:  #FAF5EB;
  --paper-deep:  #EAE1D0;

  /* text */
  --ivory:       #F2EBDD;
  --ivory-dim:   rgba(242,235,221,0.60);
  --ivory-faint: rgba(242,235,221,0.40);
  --ink:         #1A1613;
  --ink-dim:     rgba(26,22,19,0.62);
  --ink-faint:   rgba(26,22,19,0.42);

  /* champagne / walnut accents */
  --champagne:   #C6A66A;
  --champagne-2: #D9BE86;
  --champagne-deep:#A8854A;
  --walnut:      #6E573C;

  /* rules */
  --rule-d:      rgba(242,235,221,0.13);
  --rule-d-soft: rgba(242,235,221,0.07);
  --rule-l:      rgba(26,22,19,0.14);
  --rule-l-soft: rgba(26,22,19,0.08);

  /* type */
  --f-display:"GT Super Display", "Instrument Serif", Georgia, serif;
  --f-serif:  "Instrument Serif", Georgia, serif;
  --f-body:   "Sohne", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --f-mono:   "JetBrains Mono", ui-monospace, monospace;

  --accent: var(--champagne);
  /* easing — Emil Kowalski strong curves */
  --ease-out: cubic-bezier(0.23,1,0.32,1);
  --ease-in-out: cubic-bezier(0.77,0,0.175,1);
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

.sc-body{
  margin:0;
  background:var(--noir);
  color:var(--ivory);
  font-family:var(--f-body);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }

/* ── SHARED PRIMITIVES ─────────────────────────────────────── */
.sc-eyebrow{
  display:inline-block;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:0.34em;
  text-transform:uppercase;
  color:var(--champagne);
  margin:0 0 22px;
}
.sc-eyebrow--dim{ color:var(--ivory-faint); }
.sc-eyebrow--on-light{ color:var(--champagne-deep); }

.sc-h1{
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(44px,8vw,96px);
  line-height:0.94;
  letter-spacing:-0.02em;
  margin:0;
  text-wrap:balance;
}
.sc-h2{
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(34px,5vw,72px);
  line-height:1.02;
  letter-spacing:-0.018em;
  margin:0;
  text-wrap:balance;
}
.sc-h3{
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(28px,3.4vw,48px);
  line-height:1.06;
  letter-spacing:-0.015em;
  margin:0;
  text-wrap:balance;
}
.sc-em{ font-family:var(--f-serif); font-style:italic; font-weight:400; color:var(--champagne); letter-spacing:0; }
.sc-h1 .sc-em,.sc-h2 .sc-em,.sc-h3 .sc-em{ font-size:1.04em; }

.sc-lede{
  font-family:var(--f-serif);
  font-style:italic;
  font-size:clamp(20px,2.2vw,30px);
  line-height:1.45;
  color:var(--ivory);
  margin:0;
}
.sc-body-copy{
  font-size:16.5px;
  line-height:1.75;
  color:var(--ivory-dim);
  margin:0 0 18px;
}
.sc-on-light{ color:var(--ink); }
.sc-on-light .sc-body-copy{ color:var(--ink-dim); }
.sc-on-light .sc-lede{ color:var(--ink); }

/* buttons — SPARK pills */
.sc-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:11px;
  height:54px; padding:0 32px;
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:0.22em; text-transform:uppercase;
  text-decoration:none; cursor:pointer;
  border:1px solid transparent; border-radius:999px;
  transition:background .28s var(--ease-out), color .28s var(--ease-out), border-color .28s var(--ease-out), transform .16s var(--ease-out);
  white-space:nowrap;
}
.sc-btn:active{ transform:scale(0.97); transition-duration:120ms; }
.sc-btn--gold{ background:var(--champagne); color:#1a1206; border-color:var(--champagne); }
.sc-btn--ghost{ background:transparent; color:var(--ivory); border:1.5px solid rgba(242,235,221,0.55); }
.sc-btn--ghost-dark{ background:transparent; color:var(--ink); border-color:var(--rule-l); }
@media (hover:hover) and (pointer:fine){
  .sc-btn--gold:hover{ background:var(--champagne-2); border-color:var(--champagne-2); }
  .sc-btn--ghost:hover{ border-color:var(--champagne); color:var(--champagne); }
  .sc-btn--ghost-dark:hover{ border-color:var(--champagne-deep); color:var(--champagne-deep); }
}
/* hero CTAs use Söhne, not mono — all three equal width */
.sc-hero__cta{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.sc-hero__cta .sc-btn{ font-family:var(--f-body); font-weight:500; width:240px; max-width:100%; padding-left:18px; padding-right:18px; }
.sc-btn--lg{ height:60px; padding:0 40px; font-size:12px; }
.sc-btn--full{ width:100%; }

.sc-link{
  font-family:var(--f-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--champagne); text-decoration:none;
  border-bottom:1px solid transparent; padding-bottom:3px; transition:border-color .25s;
}
.sc-link:hover{ border-bottom-color:var(--champagne); }

.sc-rule{ display:block; width:1px; height:38px; margin:0 auto;
  background:linear-gradient(180deg,transparent,var(--champagne)); }

.sc-wrap{ max-width:1280px; margin:0 auto; padding:0 clamp(24px,5vw,72px); }

/* ── HEADER ────────────────────────────────────────────────── */
.sc-header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
  padding:22px clamp(24px,4vw,56px);
  background:linear-gradient(180deg, rgba(11,10,9,0.62) 0%, rgba(11,10,9,0) 100%);
  transition:background .4s, padding .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.sc-header.is-scrolled{
  background:rgba(11,10,9,0.92);
  backdrop-filter:blur(18px) saturate(1.1);
  padding-top:14px; padding-bottom:14px;
  border-bottom-color:rgba(198,166,106,0.22);
}

/* brand — SPARK mark + italic serif sublabel, divider between */
.sc-header__brand{ display:flex; align-items:center; gap:16px; text-decoration:none; flex:none; }
.sc-header__mark{ display:flex; }
.sc-header__mark svg{ height:20px; width:auto; fill:var(--ivory); display:block; }
.sc-header__sublabel{
  font-family:var(--f-serif); font-style:italic; font-weight:400;
  font-size:21px; letter-spacing:0.01em; line-height:1; white-space:nowrap;
  color:var(--champagne-2);
  padding-left:18px; border-left:1px solid rgba(198,166,106,0.45);
  text-shadow:0 1px 12px rgba(0,0,0,0.45);
}

/* nav — mono, uppercase, bronze underline on hover */
.sc-header__nav{ display:flex; align-items:center; gap:clamp(20px,2.4vw,38px); }
.sc-header__nav a{
  position:relative;
  font-family:var(--f-body); font-weight:500; font-size:14px; letter-spacing:0.01em; text-transform:none;
  color:rgba(242,235,221,0.82); text-decoration:none; padding:6px 0; transition:color .25s;
}
.sc-header__nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:var(--champagne); transform:scaleX(0); transform-origin:left; transition:transform .25s;
}
.sc-header__nav a:hover{ color:var(--ivory); }
.sc-header__nav a:hover::after{ transform:scaleX(1); }

/* CTA — solid champagne block with arrow */
.sc-header__cta{
  flex:none; display:inline-flex; align-items:center; gap:9px;
  padding:12px 22px; border-radius:4px;
  background:var(--champagne); color:#1a1206;
  font-family:var(--f-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase;
  text-decoration:none; transition:background .25s, color .25s;
}
.sc-header__cta:hover{ background:var(--champagne-2); }

@media (max-width:1080px){
  .sc-header__nav{ display:none; }
  .sc-header__sublabel{ font-size:18px; padding-left:12px; }
}
@media (max-width:560px){
  .sc-header__sublabel{ display:none; }
}

/* ── HERO ──────────────────────────────────────────────────── */
.sc-hero{ position:relative; height:100vh; min-height:640px; overflow:hidden; background:#000; }
.sc-hero__slides{ position:absolute; inset:0; }
.sc-hero__slide{ position:absolute; inset:0; opacity:0; transition:opacity 1.8s ease; }
.sc-hero__slide.is-active{ opacity:1; }
.sc-hero__slide img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform:scale(1.06); transition:transform 8s ease-out; }
.sc-hero__slide.is-active img{ transform:scale(1); }
.sc-hero__slide--top img{ object-position:center top; }
.sc-hero__veil{
  position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(rgba(0,0,0,var(--hero-dim,0.12)), rgba(0,0,0,var(--hero-dim,0.12))),
    radial-gradient(ellipse 64% 52% at 50% 50%, rgba(11,10,9,0.62) 0%, rgba(11,10,9,0.30) 45%, transparent 78%),
    linear-gradient(180deg, rgba(11,10,9,0.62) 0%, rgba(11,10,9,0.28) 26%, rgba(11,10,9,0.30) 58%, rgba(11,10,9,0.90) 100%);
}
.sc-hero__inner{
  position:absolute; inset:0; z-index:3;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:96px 24px 0;
}
.sc-hero__eyebrow{
  font-family:var(--f-mono); font-size:12px; letter-spacing:0.46em; text-transform:uppercase;
  color:var(--champagne-2); margin-bottom:28px; text-shadow:0 2px 18px rgba(0,0,0,0.6);
}
.sc-hero__title{
  font-family:var(--f-display); font-weight:700; color:var(--ivory);
  font-size:clamp(48px,9.5vw,96px); line-height:0.9; letter-spacing:-0.025em;
  margin:0; text-shadow:0 8px 50px rgba(0,0,0,0.5);
}
.sc-hero__title em{ font-family:var(--f-serif); font-style:italic; font-weight:400; color:var(--champagne-2); }
.sc-hero__sub{
  max-width:60ch; margin:30px auto 0;
  font-family:var(--f-serif); font-style:italic;
  font-size:clamp(17px,1.7vw,23px); line-height:1.5; color:rgba(242,235,221,0.86);
  text-shadow:0 2px 16px rgba(0,0,0,0.5);
}
.sc-hero__facts{
  display:flex; flex-wrap:wrap; justify-content:center; gap:14px 30px; margin:26px 0 36px;
  font-family:var(--f-mono); font-size:11px; letter-spacing:0.22em; text-transform:uppercase;
  color:rgba(242,235,221,0.78);
}
.sc-hero__facts span{ display:inline-flex; align-items:center; gap:30px; }
.sc-hero__facts span::after{ content:"·"; color:var(--champagne); }
.sc-hero__facts span:last-child::after{ display:none; }
.sc-hero__cta{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }

/* JS-triggered entrance — transform-only so content is ALWAYS visible
   even if transitions are frozen (backgrounded iframe / no-JS) */
.sc-hero__eyebrow,.sc-hero__title,.sc-hero__sub,.sc-hero__facts,.sc-hero__cta{
  transform:translateY(16px);
  transition:transform 0.9s var(--ease-out);
}
.sc-hero.is-in .sc-hero__title{ transition-delay:.12s; }
.sc-hero.is-in .sc-hero__sub{ transition-delay:.24s; }
.sc-hero.is-in .sc-hero__facts{ transition-delay:.34s; }
.sc-hero.is-in .sc-hero__cta{ transition-delay:.44s; }
.sc-hero.is-in .sc-hero__eyebrow,
.sc-hero.is-in .sc-hero__title,
.sc-hero.is-in .sc-hero__sub,
.sc-hero.is-in .sc-hero__facts,
.sc-hero.is-in .sc-hero__cta{ transform:none; }
.sc-hero__scroll{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:4;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:var(--f-mono); font-size:9px; letter-spacing:0.3em; text-transform:uppercase;
  color:var(--ivory-faint);
}
.sc-hero__scroll i{ display:block; width:1px; height:36px; background:linear-gradient(180deg,var(--champagne),transparent);
  animation:scPulse 2.4s ease-in-out infinite; }
.sc-hero__dots{ position:absolute; right:clamp(24px,4vw,48px); bottom:30px; z-index:4; display:flex; flex-direction:column; gap:9px; }
.sc-hero__dots button{ width:2px; height:22px; border:0; padding:0; cursor:pointer; background:rgba(242,235,221,0.28); transition:background .3s,height .3s; }
.sc-hero__dots button.is-active{ background:var(--champagne); height:34px; }

@keyframes scPulse{ 0%,100%{ opacity:.3; transform:scaleY(.6);} 50%{ opacity:1; transform:scaleY(1);} }
@media (prefers-reduced-motion:reduce){
  .sc-hero__eyebrow,.sc-hero__title,.sc-hero__sub,.sc-hero__facts,.sc-hero__cta{ transition:none; }
  .sc-hero__slide img{ transition:none; transform:none; }
}

/* ── MYTHOS ────────────────────────────────────────────────── */
.sc-myth{
  background:var(--noir);
  display:grid; grid-template-columns:0.82fr 1.18fr; gap:clamp(36px,5vw,84px); align-items:center;
  max-width:1280px; margin:0 auto;
  padding:clamp(56px,6vw,96px) clamp(24px,5vw,72px);
}
.sc-myth__media{ margin:0; position:relative; overflow:hidden; }
.sc-myth__media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:3/4; max-height:700px; }
.sc-myth__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 60%,rgba(11,10,9,0.4)); pointer-events:none; }
.sc-myth__lede{ font-family:var(--f-serif); font-style:italic; font-size:clamp(20px,2.2vw,30px); line-height:1.4; color:var(--champagne-2); margin:22px 0 20px; }
.sc-myth__line{ list-style:none; display:flex; flex-wrap:wrap; gap:10px 14px; margin:30px 0 0; padding:0; }
.sc-myth__line li{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color:var(--ivory-dim); border:1px solid var(--rule-d); border-radius:999px; padding:10px 16px; }
@media (max-width:820px){ .sc-myth{ grid-template-columns:1fr; gap:32px; } .sc-myth__media img{ aspect-ratio:16/10; max-height:440px; } }

/* ── SECTION SHELL ─────────────────────────────────────────── */
.sc-section{ padding:clamp(58px,6vw,96px) 0; position:relative; }
.sc-section--noir{ background:var(--noir); }
.sc-section--soft{ background:var(--noir-soft); }
.sc-section--paper{ background:var(--paper); color:var(--ink); }
.sc-section--paper .sc-h1,.sc-section--paper .sc-h2,.sc-section--paper .sc-h3{ color:var(--ink); }
.sc-section--paper .sc-em{ color:var(--champagne-deep); }
.sc-section--paper .sc-eyebrow{ color:var(--champagne-deep); }
.sc-section--paper .sc-lede{ color:var(--ink); }
.sc-section--paper .sc-body-copy{ color:var(--ink-dim); }

.sc-shead{ max-width:860px; margin:0 auto clamp(40px,5vw,64px); text-align:center; }
.sc-shead .sc-rule{ margin-bottom:24px; }
.sc-shead .sc-lede{ margin-top:22px; color:var(--ivory-dim); }
.sc-section--paper .sc-shead .sc-lede{ color:var(--ink-dim); }

/* ── MANIFESTO (What Is) ───────────────────────────────────── */
.sc-manifesto{ text-align:center; }
.sc-manifesto__statement{
  font-family:var(--f-display); font-weight:700;
  font-size:clamp(30px,4.6vw,68px); line-height:1.08; letter-spacing:-0.018em;
  max-width:20ch; margin:0 auto;
}
.sc-manifesto__statement em{ font-family:var(--f-serif); font-style:italic; font-weight:400; color:var(--champagne); }
.sc-manifesto__row{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  margin-top:clamp(40px,5vw,64px); background:var(--rule-d); border:1px solid var(--rule-d);
}
.sc-manifesto__cell{ background:var(--noir); padding:40px 28px; text-align:left; }
.sc-manifesto__cell b{ display:block; font-family:var(--f-display); font-weight:700; font-size:38px; color:var(--champagne); margin-bottom:10px; }
.sc-manifesto__cell span{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--ivory-faint); display:block; margin-bottom:6px; }
.sc-manifesto__cell p{ margin:0; font-size:14px; line-height:1.6; color:var(--ivory-dim); }
@media (max-width:880px){ .sc-manifesto__row{ grid-template-columns:repeat(2,1fr); } }

/* ── SPLIT (Residence) ─────────────────────────────────────── */
.sc-split{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:clamp(40px,5vw,88px); align-items:center; }
.sc-split--rev{ grid-template-columns:0.95fr 1.05fr; }
.sc-split--rev .sc-split__media{ order:-1; }
.sc-split__copy h3{ margin-bottom:24px; }
.sc-split__media{ position:relative; }
.sc-split__media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/5; }
.sc-split__cap{
  position:absolute; left:18px; bottom:18px;
  font-family:var(--f-mono); font-size:10px; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--ivory); background:rgba(11,10,9,0.7); border:1px solid var(--rule-d);
  padding:8px 14px; backdrop-filter:blur(6px);
}
.sc-feat-list{ list-style:none; margin:30px 0 36px; padding:0; display:grid; gap:0; }
.sc-feat-list li{
  display:grid; grid-template-columns:34px 1fr; align-items:baseline; gap:16px;
  padding:16px 0; border-bottom:1px solid var(--rule-d);
}
.sc-section--paper .sc-feat-list li{ border-bottom-color:var(--rule-l); }
.sc-feat-list li span{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.14em; color:var(--champagne); }
.sc-feat-list li strong{ font-family:var(--f-display); font-weight:700; font-size:19px; letter-spacing:-0.01em; }
.sc-feat-list li em{ display:block; font-style:normal; font-size:13.5px; color:var(--ivory-dim); margin-top:3px; }
.sc-section--paper .sc-feat-list li em{ color:var(--ink-dim); }
@media (max-width:860px){ .sc-split,.sc-split--rev{ grid-template-columns:1fr; } .sc-split--rev .sc-split__media{ order:0; } .sc-split__media img{ aspect-ratio:16/11; } }

/* ── PRIVATE HOSTING ───────────────────────────────────────── */
.sc-host{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:clamp(40px,5vw,80px); align-items:center; }
.sc-host__media{ position:relative; margin:0; overflow:hidden; border-radius:4px; }
.sc-host__media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:5/6; }
.sc-host__badge{ position:absolute; left:18px; bottom:18px; font-family:var(--f-mono); font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color:var(--ivory); background:rgba(11,10,9,0.7); border:1px solid var(--rule-d); padding:8px 14px; backdrop-filter:blur(6px); }
.sc-host__copy h2{ margin:14px 0 18px; }
.sc-host__copy .sc-lede{ margin-bottom:18px; }
.sc-host__features{ list-style:none; margin:28px 0 32px; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:12px 24px; }
.sc-host__features li{ position:relative; padding-left:22px; font-size:14.5px; color:var(--ivory-dim); }
.sc-host__features li::before{ content:""; position:absolute; left:0; top:7px; width:6px; height:6px; border:1px solid var(--champagne); transform:rotate(45deg); }
.sc-host__cta{ display:flex; gap:14px; flex-wrap:wrap; }
@media (max-width:860px){ .sc-host{ grid-template-columns:1fr; } .sc-host__media img{ aspect-ratio:16/11; } }

/* ── EVENING JOURNEY (timeline) ────────────────────────────── */
.sc-journey{ max-width:980px; margin:0 auto; }
.sc-journey__tag{ font-family:var(--f-serif); font-style:italic; font-size:clamp(17px,2vw,23px); color:var(--champagne-deep); text-align:center; margin:0 0 20px; }
.sc-jrow{
  display:grid; grid-template-columns:140px 1fr; gap:clamp(20px,4vw,56px);
  padding:16px 0; border-top:1px solid var(--rule-l);
  align-items:baseline;
}
.sc-jrow:last-child{ border-bottom:1px solid var(--rule-l); }
.sc-jtime{ font-family:var(--f-mono); font-size:clamp(20px,2.4vw,30px); letter-spacing:0.02em; color:var(--champagne-deep); }
.sc-jbody h4{ font-family:var(--f-display); font-weight:700; font-size:clamp(19px,2.1vw,27px); letter-spacing:-0.015em; margin:0 0 5px; }
.sc-jbody p{ margin:0; font-size:14px; line-height:1.5; color:var(--ink-dim); max-width:58ch; }
.sc-jbody h4 em{ font-family:var(--f-serif); font-style:italic; color:var(--champagne-deep); font-weight:400; }
@media (max-width:680px){ .sc-jrow{ grid-template-columns:1fr; gap:8px; } }
.sc-journeys .sc-journey{ display:none; }
.sc-journeys .sc-journey.is-active{ display:block; }
.sc-section--paper .sc-mtoggle{ background:#fff; border-color:var(--rule-l); }
.sc-section--paper .sc-mtoggle button{ color:var(--ink-dim); }
.sc-section--paper .sc-mtoggle button.is-active{ color:#1a1206; }
#sc-jtoggle{ margin-bottom:clamp(36px,4vw,52px); }
.sc-jtoggle{ width:100%; max-width:780px; }
.sc-jtoggle button{ flex:1 1 0; display:flex; flex-direction:column; align-items:center; gap:4px; padding:13px 12px; text-align:center; }
.sc-jtoggle button b{ font-family:var(--f-mono); font-weight:400; font-size:11px; letter-spacing:0.16em; text-transform:uppercase; }
.sc-jtoggle button small{ font-family:var(--f-mono); font-size:9px; letter-spacing:0.1em; opacity:0.65; }
.sc-jtoggle button.is-active small{ opacity:0.9; }
@media (max-width:560px){ .sc-jtoggle button b{ font-size:9.5px; letter-spacing:0.08em; } .sc-jtoggle button small{ font-size:8px; } }

/* ── MENUS ─────────────────────────────────────────────────── */
.sc-menus{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--rule-d); border:1px solid var(--rule-d); }
.sc-menu{ background:var(--char); padding:44px 30px 36px; display:flex; flex-direction:column; min-height:440px; }
.sc-menu--feat{ background:linear-gradient(180deg, rgba(198,166,106,0.12), rgba(198,166,106,0.02) 60%, transparent), var(--char); }
.sc-menu__top{ display:flex; align-items:baseline; justify-content:space-between; padding-bottom:18px; margin-bottom:22px; border-bottom:1px solid var(--rule-d); }
.sc-menu__tag{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--champagne); }
.sc-menu__price{ font-family:var(--f-serif); font-style:italic; font-size:30px; color:var(--champagne); }
.sc-menu h4{ font-family:var(--f-display); font-weight:700; font-size:26px; letter-spacing:-0.01em; margin:0 0 6px; }
.sc-menu h4 em{ font-family:var(--f-serif); font-style:italic; font-weight:400; color:var(--champagne); }
.sc-menu__courses{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--ivory-faint); margin:0 0 22px; }
.sc-menu ul{ list-style:none; margin:0 0 26px; padding:0; display:grid; gap:13px; }
.sc-menu li{ font-size:14.5px; line-height:1.4; color:var(--ivory-dim); padding-left:16px; position:relative; }
.sc-menu li::before{ content:""; position:absolute; left:0; top:9px; width:5px; height:5px; border:1px solid var(--champagne); transform:rotate(45deg); }
.sc-menu li strong{ color:var(--ivory); font-weight:500; }
.sc-menu__foot{ margin-top:auto; }
@media (max-width:980px){ .sc-menus{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .sc-menus{ grid-template-columns:1fr; } }

/* ── MENU · 5 CHAPTERS ─────────────────────────────────────── */
.sc-menu-price{ font-family:var(--f-display); font-weight:700; font-size:clamp(30px,3.6vw,48px); color:var(--champagne); margin:20px 0 0; line-height:1; }
.sc-menu-price span{ font-family:var(--f-serif); font-style:italic; font-size:0.46em; color:var(--ivory-dim); letter-spacing:0.01em; }

.sc-mtoggle{ display:flex; gap:6px; justify-content:center; align-items:center; width:max-content; max-width:100%; margin:0 auto clamp(40px,5vw,60px); padding:6px; border:1px solid var(--rule-d); border-radius:999px; background:var(--char); }
.sc-mtoggle button{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ivory-dim); background:transparent; border:0; border-radius:999px; padding:12px 26px; cursor:pointer; transition:background .25s var(--ease-out), color .25s var(--ease-out); white-space:nowrap; }
.sc-mtoggle button.is-active{ background:var(--champagne); color:#1a1206; }

.sc-chapters{ max-width:920px; margin:0 auto; }
.sc-ch{ display:grid; grid-template-columns:96px 1fr; gap:clamp(20px,4vw,52px); padding:18px 0; border-top:1px solid var(--rule-d); align-items:baseline; }
.sc-ch:last-child{ border-bottom:1px solid var(--rule-d); }
.sc-ch__num{ font-family:var(--f-serif); font-style:italic; font-size:clamp(36px,4.4vw,58px); color:var(--champagne); line-height:1; }
.sc-ch__name{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.3em; text-transform:uppercase; color:var(--ivory-faint); display:block; margin-bottom:9px; }
.sc-ch__title{ font-family:var(--f-display); font-weight:700; font-size:clamp(21px,2.5vw,32px); letter-spacing:-0.012em; margin:0 0 11px; }
.sc-ch__dish{ margin:0; font-size:15.5px; line-height:1.65; color:var(--ivory-dim); }
.sc-ch__dish strong{ color:var(--ivory); font-weight:500; }
.sc-chapters[data-variant="premium"] .sc-ch__dish--veg{ display:none; }
.sc-chapters[data-variant="vegetarian"] .sc-ch__dish--premium{ display:none; }
@media (max-width:600px){ .sc-ch{ grid-template-columns:1fr; gap:6px; } }

.sc-menu-cta{ text-align:center; margin:clamp(40px,5vw,60px) 0 0; }

.sc-addons{ max-width:920px; margin:clamp(48px,6vw,72px) auto 0; padding-top:clamp(36px,4vw,48px); border-top:1px solid var(--rule-d); }
.sc-addons__h{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.28em; text-transform:uppercase; color:var(--champagne); margin:0 0 24px; text-align:center; }
.sc-addons__grid{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:0 52px; }
.sc-addons__grid li{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; padding:15px 0; border-bottom:1px solid var(--rule-d-soft); }
.sc-addons__grid li span{ font-size:15.5px; color:var(--ivory); }
.sc-addons__grid li em{ font-family:var(--f-serif); font-style:italic; font-size:20px; color:var(--champagne); white-space:nowrap; }
@media (max-width:600px){ .sc-addons__grid{ grid-template-columns:1fr; gap:0; } }

/* ── GALLERY ───────────────────────────────────────────────── */
.sc-gallery{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:200px; gap:6px; }
.sc-gtile{ position:relative; overflow:hidden; background:var(--char); margin:0; }
.sc-gtile img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1.4s cubic-bezier(.2,0,.2,1); filter:saturate(.96); }
.sc-gtile::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(11,10,9,0.6)); opacity:0; transition:opacity .4s var(--ease-out); }
.sc-gtile figcaption{ position:absolute; left:16px; bottom:16px; z-index:2; opacity:0; transform:translateY(6px); transition:opacity .35s var(--ease-out), transform .35s var(--ease-out); }
@media (hover:hover) and (pointer:fine){
  .sc-gtile:hover img{ transform:scale(1.06); }
  .sc-gtile:hover::after{ opacity:1; }
  .sc-gtile:hover figcaption{ opacity:1; transform:translateY(0); }
}
.sc-gtile figcaption span{ font-family:var(--f-mono); font-size:9px; letter-spacing:0.26em; text-transform:uppercase; color:var(--champagne-2); background:rgba(11,10,9,0.7); border:1px solid rgba(198,166,106,0.35); padding:6px 11px; }
.sc-g-a{ grid-column:span 3; grid-row:span 2; }
.sc-g-b{ grid-column:span 3; }
.sc-g-c{ grid-column:span 2; }
.sc-g-d{ grid-column:span 2; }
.sc-g-e{ grid-column:span 2; grid-row:span 2; }
.sc-g-f{ grid-column:span 2; }
.sc-g-g{ grid-column:span 2; }
@media (max-width:860px){ .sc-gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; } .sc-g-a,.sc-g-b,.sc-g-c,.sc-g-d,.sc-g-e,.sc-g-f,.sc-g-g{ grid-column:span 1; grid-row:span 1; } .sc-g-a{ grid-column:span 2; grid-row:span 2; } }

/* ── AVAILABILITY CALENDAR ─────────────────────────────────── */
.sc-cal{ max-width:1080px; margin:0 auto; display:grid; grid-template-columns:1fr 360px; gap:clamp(28px,4vw,56px); align-items:start; }
.sc-cal__grid{ display:flex; flex-direction:column; gap:26px; }
.sc-cal__mgroup{ }
.sc-cal__mlabel{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.26em; text-transform:uppercase; color:var(--champagne); margin:0 0 14px; padding-bottom:10px; border-bottom:1px solid var(--rule-d); }
.sc-cal__mgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.sc-night{
  text-align:left; background:var(--char); border:1px solid var(--rule-d); border-radius:6px;
  padding:24px 26px; cursor:pointer; color:var(--ivory); font-family:var(--f-body);
  transition:border-color .25s var(--ease-out), background .25s var(--ease-out), transform .25s var(--ease-out); position:relative; overflow:hidden;
}
.sc-night:active:not(.is-sold){ transform:scale(0.98); }
@media (hover:hover) and (pointer:fine){ .sc-night:hover:not(.is-sold){ border-color:var(--champagne); transform:translateY(-2px); } }
.sc-night__date{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:14px; }
.sc-night__day{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--champagne); }
.sc-night__num{ font-family:var(--f-display); font-weight:700; font-size:32px; letter-spacing:-0.01em; }
.sc-night__mon{ font-family:var(--f-mono); font-size:11px; color:var(--ivory-dim); }
.sc-night__seats{ display:flex; align-items:center; gap:10px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.06em; color:var(--ivory-dim); }
.sc-night__bar{ flex:1; height:3px; background:var(--rule-d); border-radius:2px; overflow:hidden; }
.sc-night__bar i{ display:block; height:100%; background:var(--champagne); }
.sc-night.is-low .sc-night__bar i{ background:#C97B4A; }
.sc-night.is-sold{ cursor:not-allowed; opacity:0.5; }
.sc-night.is-sold .sc-night__seats{ color:#9c5b48; }
.sc-night__badge{ position:absolute; top:0; right:0; font-family:var(--f-mono); font-size:8.5px; letter-spacing:0.2em; text-transform:uppercase; padding:5px 10px; }
.sc-night.is-sold .sc-night__badge{ background:rgba(156,91,72,0.18); color:#c98; }
.sc-night.is-low .sc-night__badge{ background:rgba(201,123,74,0.18); color:#E0A06A; }
.sc-cal__aside{ background:var(--char); border:1px solid var(--rule-d); border-radius:8px; padding:34px 32px; position:sticky; top:96px; }
.sc-cal__aside h4{ font-family:var(--f-display); font-weight:700; font-size:24px; margin:0 0 8px; }
.sc-cal__aside p{ font-size:14px; line-height:1.6; color:var(--ivory-dim); margin:0 0 22px; }
.sc-cal__legend{ display:grid; gap:12px; margin:0 0 26px; }
.sc-cal__legend div{ display:flex; align-items:center; gap:11px; font-family:var(--f-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ivory-dim); }
.sc-cal__legend i{ width:22px; height:3px; border-radius:2px; }
.sc-cal__weeks{ display:flex; gap:8px; margin-bottom:26px; flex-wrap:wrap; }
.sc-cal__weekbtn{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; padding:8px 14px; border-radius:999px; border:1px solid var(--rule-d); background:transparent; color:var(--ivory-dim); cursor:pointer; transition:background .25s var(--ease-out), color .25s var(--ease-out), border-color .25s var(--ease-out); }
.sc-cal__weekbtn.is-active{ background:var(--champagne); color:#1a1206; border-color:var(--champagne); }
@media (max-width:860px){ .sc-cal{ grid-template-columns:1fr; } .sc-cal__aside{ position:static; } .sc-cal__mgrid{ grid-template-columns:1fr 1fr; } }
@media (max-width:1100px) and (min-width:861px){ .sc-cal__mgrid{ grid-template-columns:repeat(3,1fr); } }

/* ── PRIVATE EVENTS ────────────────────────────────────────── */
.sc-priv{ display:grid; grid-template-columns:repeat(3,1fr); gap:4px; }
.sc-pcard{ background:var(--paper-soft); border:1px solid var(--rule-l); padding:44px 34px; display:flex; flex-direction:column; }
.sc-pcard__n{ font-family:var(--f-serif); font-style:italic; font-size:46px; color:var(--champagne-deep); line-height:1; margin-bottom:24px; }
.sc-pcard h4{ font-family:var(--f-display); font-weight:700; font-size:24px; letter-spacing:-0.01em; margin:0 0 12px; color:var(--ink); }
.sc-pcard p{ font-size:15px; line-height:1.65; color:var(--ink-dim); margin:0; }
.sc-priv__band{ margin-top:48px; display:flex; flex-wrap:wrap; gap:24px 56px; align-items:center; justify-content:space-between;
  padding:36px clamp(28px,4vw,56px); background:var(--ink); color:var(--ivory); border-radius:8px; }
.sc-priv__band p{ margin:0; font-family:var(--f-serif); font-style:italic; font-size:clamp(20px,2.4vw,30px); max-width:24ch; }
.sc-priv__band p em{ color:var(--champagne-2); }
@media (max-width:860px){ .sc-priv{ grid-template-columns:1fr; } }

/* ── FAQ ───────────────────────────────────────────────────── */
.sc-faq{ max-width:860px; margin:0 auto; }
.sc-faq__item{ border-bottom:1px solid var(--rule-d); }
.sc-faq__q{ width:100%; background:none; border:0; cursor:pointer; text-align:left;
  display:flex; align-items:center; justify-content:space-between; gap:24px; padding:28px 0;
  font-family:var(--f-display); font-weight:700; font-size:clamp(19px,2vw,26px); letter-spacing:-0.01em; color:var(--ivory); }
.sc-faq__q i{ flex:none; width:22px; height:22px; position:relative; transition:transform .35s; }
.sc-faq__q i::before,.sc-faq__q i::after{ content:""; position:absolute; background:var(--champagne); }
.sc-faq__q i::before{ left:0; top:50%; width:100%; height:1.5px; transform:translateY(-50%); }
.sc-faq__q i::after{ top:0; left:50%; height:100%; width:1.5px; transform:translateX(-50%); transition:opacity .35s; }
.sc-faq__item.is-open .sc-faq__q i{ transform:rotate(180deg); }
.sc-faq__item.is-open .sc-faq__q i::after{ opacity:0; }
.sc-faq__a{ max-height:0; overflow:hidden; transition:max-height .4s ease; }
.sc-faq__a p{ margin:0 0 28px; font-size:15.5px; line-height:1.75; color:var(--ivory-dim); max-width:64ch; }

/* ── FINAL CTA ─────────────────────────────────────────────── */
.sc-final{ position:relative; min-height:78vh; display:flex; align-items:center; justify-content:center; text-align:center; overflow:hidden; }
.sc-final img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center top; }
.sc-final__veil{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(11,10,9,0.55),rgba(11,10,9,0.75)); }
.sc-final__inner{ position:relative; z-index:2; padding:80px 24px; }
.sc-final__count{ font-family:var(--f-mono); font-size:12px; letter-spacing:0.4em; text-transform:uppercase; color:var(--champagne-2); margin-bottom:26px; }
.sc-final h2{ color:var(--ivory); margin:0 auto 18px; max-width:18ch; }
.sc-final p{ font-family:var(--f-serif); font-style:italic; font-size:clamp(18px,2vw,24px); color:rgba(242,235,221,0.86); margin:0 auto 38px; max-width:46ch; }

/* ── FOOTER ────────────────────────────────────────────────── */
.sc-foot{ background:var(--noir); border-top:1px solid var(--rule-d); padding:clamp(56px,7vw,90px) 0 40px; }
.sc-foot__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px; align-items:start; }
.sc-foot__brand{ display:flex; align-items:center; gap:16px; text-decoration:none; }
.sc-foot__mark svg{ height:22px; width:auto; fill:var(--ivory); display:block; }
.sc-foot__sub{ font-family:var(--f-serif); font-style:italic; font-size:21px; color:var(--champagne); padding-left:18px; border-left:1px solid rgba(198,166,106,0.45); line-height:1; white-space:nowrap; }
.sc-foot__contact h5{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--ivory-faint); margin:0 0 14px; }
.sc-foot__contact p{ font-family:var(--f-mono); font-size:12px; line-height:1.95; color:var(--ivory-dim); margin:0; }
.sc-foot__legal{ text-align:right; }
.sc-foot__links{ display:flex; flex-direction:column; align-items:flex-end; gap:9px; margin-bottom:16px; }
.sc-foot__links a, .sc-foot__imprint{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ivory-dim); text-decoration:none; transition:color .2s; }
.sc-foot__links a:hover, .sc-foot__imprint:hover{ color:var(--champagne); }
.sc-foot__imprint{ display:inline-block; margin-bottom:18px; }
.sc-foot__copy{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ivory-faint); line-height:1.85; margin:0; }
@media (max-width:860px){ .sc-foot__top{ grid-template-columns:1fr; gap:34px; } .sc-foot__legal{ text-align:left; } .sc-foot__links{ justify-content:flex-start; } }
@media (max-width:560px){ .sc-foot__sub{ font-size:18px; } }
.sc-foot__brand p{ font-family:var(--f-serif); font-style:italic; font-size:16px; color:var(--champagne); margin:0 0 8px; }
.sc-foot__brand small{ font-size:13px; color:var(--ivory-dim); line-height:1.6; }
.sc-foot__col h5{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--ivory-faint); margin:0 0 18px; }
.sc-foot__col a,.sc-foot__col p{ display:block; font-size:14px; color:var(--ivory-dim); text-decoration:none; margin:0 0 10px; line-height:1.55; transition:color .2s; }
.sc-foot__col a:hover{ color:var(--champagne); }
.sc-foot__bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; padding-top:28px;
  font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ivory-faint); }
@media (max-width:860px){ .sc-foot__top{ grid-template-columns:1fr 1fr; } }

/* ── BOOKING ENGINE (modal) ────────────────────────────────── */
.sc-booking{ position:fixed; inset:0; z-index:120; display:none; align-items:center; justify-content:center; padding:24px; }
.sc-booking.is-open{ display:flex; }
.sc-booking__backdrop{ position:absolute; inset:0; background:rgba(6,5,5,0.80); backdrop-filter:blur(8px); }
.sc-booking__panel{
  position:relative; width:min(580px,100%); max-height:90vh;
  background:var(--noir-soft); border:1px solid var(--rule-d); border-radius:14px;
  display:flex; flex-direction:column; overflow:hidden;
  transform:translateY(16px); transition:transform .45s cubic-bezier(.22,1,.36,1);
  box-shadow:0 40px 110px rgba(0,0,0,0.6);
}
.sc-booking.is-open .sc-booking__panel{ transform:none; }
.sc-booking__head{ padding:24px clamp(26px,4vw,40px) 18px; border-bottom:1px solid var(--rule-d); }
.sc-booking__head-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.sc-booking__brand{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.3em; text-transform:uppercase; color:var(--champagne); }
.sc-booking__close{ width:38px; height:38px; border-radius:999px; border:1px solid var(--rule-d); background:transparent; color:var(--ivory); cursor:pointer; font-size:18px; line-height:1; transition:border-color 200ms var(--ease-out), color 200ms var(--ease-out), transform 160ms var(--ease-out); }
.sc-booking__close:active{ transform:scale(0.92); }
@media (hover:hover) and (pointer:fine){ .sc-booking__close:hover{ border-color:var(--champagne); color:var(--champagne); } }
.sc-steps{ display:flex; gap:6px; }
.sc-steps__seg{ flex:1; height:3px; background:var(--rule-d); border-radius:2px; overflow:hidden; }
.sc-steps__seg i{ display:block; height:100%; width:0; background:var(--champagne); transition:width .4s; }
.sc-steps__seg.is-done i,.sc-steps__seg.is-active i{ width:100%; }
.sc-booking__body{ flex:1; overflow-y:auto; padding:clamp(26px,4vw,40px); }
.sc-step{ display:none; }
.sc-step.is-active{ display:block; }
.sc-step__label{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.26em; text-transform:uppercase; color:var(--ivory-faint); margin:0 0 8px; }
.sc-step__title{ font-family:var(--f-display); font-weight:700; font-size:clamp(26px,3.4vw,38px); letter-spacing:-0.015em; margin:0 0 26px; }
.sc-step__title em{ font-family:var(--f-serif); font-style:italic; font-weight:400; color:var(--champagne); }

.sc-opt{ display:flex; flex-direction:column; gap:12px; }
.sc-opt__item{
  display:flex; align-items:center; gap:18px; padding:20px 22px; text-align:left; color:var(--ivory);
  border:1px solid var(--rule-d); border-radius:8px; cursor:pointer; background:var(--char);
  transition:border-color .2s, background .2s;
}
.sc-opt__item:hover{ border-color:rgba(198,166,106,0.5); }
.sc-opt__item.is-sel{ border-color:var(--champagne); background:linear-gradient(180deg,rgba(198,166,106,0.14),rgba(26,23,20,0.6)); }
.sc-opt__mark{ flex:none; width:20px; height:20px; border-radius:50%; border:1px solid var(--rule-d); position:relative; transition:.2s; }
.sc-opt__item.is-sel .sc-opt__mark{ border-color:var(--champagne); }
.sc-opt__item.is-sel .sc-opt__mark::after{ content:""; position:absolute; inset:4px; border-radius:50%; background:var(--champagne); }
.sc-opt__main{ flex:1; }
.sc-opt__main b{ display:block; font-family:var(--f-display); font-weight:700; font-size:18px; letter-spacing:-0.01em; color:var(--ivory); }
.sc-opt__main span{ display:block; font-size:13px; color:var(--ivory-dim); margin-top:3px; }
.sc-opt__price{ font-family:var(--f-serif); font-style:italic; font-size:19px; color:var(--champagne); white-space:nowrap; }
.sc-opt__item--check .sc-opt__mark{ border-radius:5px; }
.sc-opt__item--check.is-sel .sc-opt__mark::after{ border-radius:2px; inset:4px; }

/* night picker inside booking */
.sc-bnights{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.sc-bnight{ text-align:left; padding:16px 18px; border:1px solid var(--rule-d); border-radius:8px; background:var(--char); cursor:pointer; color:var(--ivory); transition:.2s; }
.sc-bnight:hover:not(:disabled){ border-color:rgba(198,166,106,0.5); }
.sc-bnight.is-sel{ border-color:var(--champagne); background:linear-gradient(180deg,rgba(198,166,106,0.1),transparent); }
.sc-bnight:disabled{ opacity:.4; cursor:not-allowed; }
.sc-bnight b{ display:block; font-family:var(--f-display); font-weight:700; font-size:22px; }
.sc-bnight small{ font-family:var(--f-mono); font-size:9.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ivory-dim); }

/* join/reserve mode cards */
.sc-mode{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:24px; }
.sc-modecard{ position:relative; text-align:left; background:var(--char); border:1px solid var(--rule-d); border-radius:10px; padding:18px 20px; cursor:pointer; color:var(--ivory); display:flex; flex-direction:column; gap:5px; transition:border-color .2s, background .2s; }
.sc-modecard:hover{ border-color:rgba(198,166,106,0.5); }
.sc-modecard.is-sel{ border-color:var(--champagne); background:linear-gradient(180deg,rgba(198,166,106,0.14),rgba(26,23,20,0.6)); }
.sc-modecard__t{ font-family:var(--f-display); font-weight:700; font-size:18px; letter-spacing:-0.01em; color:var(--ivory); }
.sc-modecard__d{ font-size:12.5px; line-height:1.45; color:var(--ivory-dim); }
.sc-modecard__badge{ position:absolute; top:0; right:0; font-family:var(--f-mono); font-size:8px; letter-spacing:0.18em; text-transform:uppercase; color:#1a1206; background:var(--champagne); padding:4px 9px; border-radius:0 10px 0 8px; }
@media (max-width:520px){ .sc-mode{ grid-template-columns:1fr; } }

/* guest stepper */
.sc-guests{ display:flex; align-items:center; justify-content:center; gap:30px; padding:30px 0; }
.sc-guests button{ width:58px; height:58px; border-radius:50%; border:1px solid var(--rule-d); background:transparent; color:var(--ivory); font-size:24px; cursor:pointer; transition:.2s; }
.sc-guests button:hover{ border-color:var(--champagne); color:var(--champagne); }
.sc-guests button:disabled{ opacity:.3; cursor:not-allowed; }
.sc-guests__n{ font-family:var(--f-display); font-weight:700; font-size:64px; min-width:90px; text-align:center; letter-spacing:-0.02em; }
.sc-guests__lbl{ text-align:center; font-family:var(--f-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--ivory-dim); }

/* checkout / payment */
.sc-field{ margin-bottom:16px; }
.sc-field label{ display:block; font-family:var(--f-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--ivory-faint); margin-bottom:8px; }
.sc-field input{ width:100%; height:50px; padding:0 16px; background:var(--char); border:1px solid var(--rule-d); border-radius:6px; color:var(--ivory); font-family:var(--f-body); font-size:15px; transition:border-color .2s; }
.sc-field input:focus{ outline:none; border-color:var(--champagne); }
.sc-field textarea{ width:100%; padding:12px 16px; background:var(--char); border:1px solid var(--rule-d); border-radius:6px; color:var(--ivory); font-family:var(--f-body); font-size:15px; line-height:1.5; resize:vertical; }
.sc-field textarea:focus{ outline:none; border-color:var(--champagne); }
.sc-charcount{ display:block; text-align:right; font-family:var(--f-mono); font-size:9px; letter-spacing:0.1em; color:var(--ivory-faint); margin-top:6px; }
.sc-field--row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.sc-pay{ display:flex; gap:10px; margin-bottom:22px; }
.sc-pay button{ flex:1; height:48px; border-radius:6px; border:1px solid var(--rule-d); background:var(--char); color:var(--ivory); font-family:var(--f-mono); font-size:11px; letter-spacing:0.1em; cursor:pointer; transition:border-color .2s var(--ease-out), color .2s var(--ease-out), transform .16s var(--ease-out); display:flex; align-items:center; justify-content:center; gap:6px; }
.sc-pay button:active{ transform:scale(0.97); }
.sc-pay button.is-sel{ border-color:var(--champagne); color:var(--champagne); }

/* summary */
.sc-sum{ background:var(--char); border:1px solid var(--rule-d); border-radius:8px; padding:22px 24px; margin-bottom:8px; }
.sc-sum__row{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; padding:9px 0; border-bottom:1px solid var(--rule-d-soft); font-size:14px; }
.sc-sum__row:last-of-type{ border-bottom:0; }
.sc-sum__row span{ color:var(--ivory-dim); }
.sc-sum__row b{ font-weight:500; color:var(--ivory); font-family:var(--f-body); }
.sc-sum__total{ display:flex; align-items:baseline; justify-content:space-between; margin-top:14px; padding-top:16px; border-top:1px solid var(--rule-d); }
.sc-sum__total span{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--ivory-dim); }
.sc-sum__total b{ font-family:var(--f-display); font-weight:700; font-size:34px; color:var(--champagne); }

/* footer nav of booking */
.sc-booking__foot{ padding:20px clamp(26px,4vw,40px); border-top:1px solid var(--rule-d); display:flex; align-items:center; gap:14px; background:var(--noir-soft); }
.sc-booking__foot .sc-foot-meta{ flex:1; }
.sc-booking__foot .sc-foot-meta span{ display:block; font-family:var(--f-mono); font-size:9px; letter-spacing:0.18em; text-transform:uppercase; color:var(--ivory-faint); }
.sc-booking__foot .sc-foot-meta b{ font-family:var(--f-display); font-weight:700; font-size:22px; color:var(--champagne); }
.sc-back{ background:none; border:0; color:var(--ivory-dim); font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; cursor:pointer; padding:10px 6px; transition:color .2s; }
.sc-back:hover{ color:var(--ivory); }
.sc-back:disabled{ opacity:0; pointer-events:none; }

/* confirmation */
.sc-confirm{ text-align:center; padding:20px 0; }
.sc-confirm__seal{ width:84px; height:84px; border-radius:50%; border:1px solid var(--champagne); display:flex; align-items:center; justify-content:center; margin:0 auto 26px; color:var(--champagne); }
.sc-confirm__seal svg{ width:34px; height:34px; }
.sc-confirm h3{ font-family:var(--f-display); font-weight:700; font-size:32px; letter-spacing:-0.015em; margin:0 0 12px; }
.sc-confirm h3 em{ font-family:var(--f-serif); font-style:italic; color:var(--champagne); font-weight:400; }
.sc-confirm > p{ font-size:15px; line-height:1.7; color:var(--ivory-dim); max-width:42ch; margin:0 auto 28px; }
.sc-ticket{ text-align:left; background:var(--char); border:1px solid var(--rule-d); border-radius:10px; overflow:hidden; margin-bottom:24px; }
.sc-ticket__top{ padding:22px 26px; display:flex; align-items:center; justify-content:space-between; background:linear-gradient(180deg,rgba(198,166,106,0.12),transparent); border-bottom:1px dashed var(--rule-d); }
.sc-ticket__top b{ font-family:var(--f-display); font-weight:700; font-size:18px; }
.sc-ticket__top span{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.16em; color:var(--champagne); text-transform:uppercase; }
.sc-ticket__rows{ padding:18px 26px 22px; display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.sc-ticket__rows div span{ display:block; font-family:var(--f-mono); font-size:9px; letter-spacing:0.18em; text-transform:uppercase; color:var(--ivory-faint); margin-bottom:4px; }
.sc-ticket__rows div b{ font-family:var(--f-body); font-weight:500; font-size:15px; color:var(--ivory); }
.sc-confirm__actions{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }

@media (max-width:560px){
  .sc-booking{ padding:0; }
  .sc-booking__panel{ width:100%; max-height:100vh; height:100%; border-radius:0; border:0; }
  .sc-bnights{ grid-template-columns:1fr; }
  .sc-ticket__rows{ grid-template-columns:1fr; }
}

/* tweaks-host friendliness */
#sc-tweaks-root{ position:fixed; z-index:200; }

/* ── THE TABLE (one table above Berlin) ────────────────────── */.sc-table{ display:grid; grid-template-columns:1fr 1.02fr; gap:clamp(40px,5vw,84px); align-items:center; }
.sc-table__copy h2{ margin:14px 0 24px; }
.sc-table__points{ list-style:none; margin:32px 0 36px; padding:0; display:grid; gap:0; }
.sc-table__points li{ display:grid; grid-template-columns:48px 1fr; gap:18px; align-items:baseline; padding:18px 0; border-top:1px solid var(--rule-d); }
.sc-table__points li:last-child{ border-bottom:1px solid var(--rule-d); }
.sc-table__points span{ font-family:var(--f-serif); font-style:italic; font-size:28px; color:var(--champagne); line-height:1; }
.sc-table__points b{ display:block; font-family:var(--f-display); font-weight:700; font-size:18px; letter-spacing:-0.01em; color:var(--ivory); margin-bottom:4px; }
.sc-table__points em{ font-style:normal; font-size:14px; color:var(--ivory-dim); line-height:1.55; }
.sc-table__media{ position:relative; margin:0; overflow:hidden; border-radius:4px; }
.sc-table__media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/5; transition:transform 1.3s cubic-bezier(.2,0,.2,1); }
.sc-table__media:hover img{ transform:scale(1.05); }
.sc-table__reveal{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; background:linear-gradient(180deg,rgba(11,10,9,0.12),rgba(11,10,9,0.58)); opacity:0; transition:opacity .5s; }
.sc-table__media:hover .sc-table__reveal{ opacity:1; }
.sc-table__reveal span{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.3em; text-transform:uppercase; color:var(--ivory); background:rgba(11,10,9,0.45); padding:9px 18px; border:1px solid rgba(242,235,221,0.32); }
.sc-table__quote{ margin:clamp(54px,7vw,92px) auto 0; max-width:18ch; text-align:center; font-family:var(--f-display); font-weight:700; font-size:clamp(30px,4.2vw,58px); line-height:1.08; letter-spacing:-0.018em; color:var(--ivory); }
.sc-table__quote .sc-em{ color:var(--champagne); }
@media (max-width:860px){ .sc-table{ grid-template-columns:1fr; } .sc-table__media img{ aspect-ratio:16/11; } }

/* ── THE EVENING · public experience cards ─────────────────── */
.sc-exp-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.sc-expcard{ display:flex; flex-direction:column; gap:10px; background:var(--char); border:1px solid var(--rule-d); border-radius:12px; padding:34px 30px 30px; }
.sc-expcard--feat{ background:linear-gradient(180deg, rgba(198,166,106,0.12), rgba(198,166,106,0.02) 55%, transparent), var(--char); border-color:rgba(198,166,106,0.4); }
.sc-expcard__time{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--champagne); }
.sc-expcard__name{ font-family:var(--f-display); font-weight:700; font-size:clamp(24px,2.5vw,30px); letter-spacing:-0.015em; margin:0; }
.sc-expcard__blurb{ font-size:15px; color:var(--ivory-dim); margin:0; min-height:2.6em; }
.sc-expcard__from{ font-family:var(--f-serif); font-style:italic; font-size:22px; color:var(--champagne); margin:6px 0 16px; }
.sc-expcard__from em{ font-style:normal; font-family:var(--f-mono); font-size:9px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ivory-faint); }
.sc-expcard .sc-btn{ margin-top:auto; font-family:var(--f-body); font-weight:500; }
@media (max-width:820px){ .sc-exp-cards{ grid-template-columns:1fr; } }

/* ── BOOKING · guest input (typable) ───────────────────────── */
input.sc-guests__n{ width:130px; background:transparent; border:none; text-align:center; color:var(--ivory);
  font-family:var(--f-display); font-weight:700; font-size:64px; letter-spacing:-0.02em; -moz-appearance:textfield; padding:0; }
input.sc-guests__n:focus{ outline:none; color:var(--champagne); }
input.sc-guests__n::-webkit-outer-spin-button, input.sc-guests__n::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }

/* ── BOOKING · view-menu trigger ───────────────────────────── */
.sc-viewmenu{ margin-top:16px; background:none; border:0; cursor:pointer;
  font-family:var(--f-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--champagne);
  border-bottom:1px solid transparent; padding:4px 0; transition:border-color .2s; }
.sc-viewmenu:hover{ border-bottom-color:var(--champagne); }
.sc-moreenh{ width:100%; background:none; border:0; border-top:1px solid var(--rule-d); cursor:pointer; text-align:left; padding:15px 2px 2px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--champagne); margin-top:6px; }
#sc-book-enh:not(.show-more) .sc-enh-more{ display:none; }

/* ── BOOKING · house policies ──────────────────────────────── */
.sc-policies{ display:flex; flex-direction:column; gap:12px; }
.sc-policy{ display:flex; gap:14px; align-items:flex-start; padding:16px 18px; border:1px solid var(--rule-d); border-radius:8px; background:var(--char); cursor:pointer; transition:border-color .2s; }
.sc-policy:hover{ border-color:rgba(198,166,106,0.45); }
.sc-policy input{ position:absolute; opacity:0; width:0; height:0; }
.sc-policy__box{ flex:none; width:22px; height:22px; border:1px solid var(--rule-d); border-radius:5px; margin-top:2px; position:relative; transition:.2s; }
.sc-policy input:checked + .sc-policy__box{ border-color:var(--champagne); background:var(--champagne); }
.sc-policy input:checked + .sc-policy__box::after{ content:""; position:absolute; left:7px; top:3px; width:5px; height:10px; border:solid #1a1206; border-width:0 2px 2px 0; transform:rotate(45deg); }
.sc-policy__txt{ font-size:13.5px; line-height:1.55; color:var(--ivory-dim); }
.sc-policy__txt b{ display:block; font-family:var(--f-display); font-weight:700; font-size:16px; color:var(--ivory); letter-spacing:-0.01em; margin-bottom:3px; }

/* ── MENU detail popup ─────────────────────────────────────── */
.sc-menupop{ position:fixed; inset:0; z-index:140; display:none; align-items:center; justify-content:center; padding:24px; }
.sc-menupop.is-open{ display:flex; }
.sc-menupop__backdrop{ position:absolute; inset:0; background:rgba(6,5,5,0.82); backdrop-filter:blur(8px); }
.sc-menupop__panel{ position:relative; width:min(620px,100%); max-height:88vh; overflow-y:auto; background:var(--noir-soft); border:1px solid var(--rule-d); border-radius:14px; padding:clamp(30px,4vw,48px); box-shadow:0 40px 110px rgba(0,0,0,0.6); }
.sc-menupop__close{ position:absolute; top:18px; right:18px; width:38px; height:38px; border-radius:999px; border:1px solid var(--rule-d); background:transparent; color:var(--ivory); cursor:pointer; font-size:18px; transition:.2s; }
.sc-menupop__close:hover{ border-color:var(--champagne); color:var(--champagne); }
.sc-mp__head{ text-align:center; margin-bottom:28px; }
.sc-mp__title{ font-family:var(--f-display); font-weight:700; font-size:clamp(26px,3vw,38px); letter-spacing:-0.015em; margin:8px 0 0; }
.sc-mp__list{ display:flex; flex-direction:column; }
.sc-mp__row{ display:grid; grid-template-columns:54px 1fr; gap:20px; padding:20px 0; border-top:1px solid var(--rule-d); align-items:baseline; }
.sc-mp__row:first-child{ border-top:0; }
.sc-mp__num{ font-family:var(--f-serif); font-style:italic; font-size:30px; color:var(--champagne); line-height:1; }
.sc-mp__name{ display:block; font-family:var(--f-mono); font-size:9px; letter-spacing:0.28em; text-transform:uppercase; color:var(--ivory-faint); margin-bottom:7px; }
.sc-mp__dt{ font-family:var(--f-display); font-weight:700; font-size:19px; letter-spacing:-0.01em; margin:0 0 8px; }
.sc-mp__dish{ margin:0; font-size:14.5px; line-height:1.6; color:var(--ivory-dim); }
.sc-mp__dish--veg{ margin-top:6px; color:var(--ivory-faint); }
.sc-mp__dish--veg em{ font-style:normal; font-family:var(--f-mono); font-size:9px; letter-spacing:0.16em; text-transform:uppercase; color:var(--champagne); }

/* ── BOOKING · configurator additions ──────────────────────── */
.sc-step__note{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--champagne); margin:-16px 0 24px; }

/* date step month labels */
.sc-bmonth{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--champagne); margin:0 0 12px; padding-bottom:8px; border-bottom:1px solid var(--rule-d); }
.sc-bmonth ~ .sc-bmonth{ margin-top:8px; }
.sc-bnights + .sc-bmonth{ margin-top:26px; }

/* slot cards */
.sc-slots{ display:flex; flex-direction:column; gap:12px; }
.sc-slotcard{ text-align:left; background:var(--char); border:1px solid var(--rule-d); border-radius:10px; padding:22px 24px; cursor:pointer; color:var(--ivory); display:flex; flex-direction:column; gap:6px; transition:border-color .2s, background .2s; }
.sc-slotcard:hover{ border-color:rgba(198,166,106,0.5); }
.sc-slotcard.is-sel{ border-color:var(--champagne); background:linear-gradient(180deg,rgba(198,166,106,0.1),transparent); }
.sc-slotcard__time{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color:var(--champagne); }
.sc-slotcard__name{ font-family:var(--f-display); font-weight:700; font-size:23px; letter-spacing:-0.01em; }
.sc-slotcard__blurb{ font-size:13.5px; color:var(--ivory-dim); }
.sc-slotcard__from{ font-family:var(--f-serif); font-style:italic; font-size:18px; color:var(--champagne); margin-top:4px; }
.sc-slotcard__from em{ font-style:normal; font-family:var(--f-mono); font-size:9px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ivory-faint); }

/* experience options (with included list) */
.sc-exps{ display:flex; flex-direction:column; gap:12px; }
.sc-exp{ text-align:left; display:flex; align-items:flex-start; gap:16px; background:var(--char); border:1px solid var(--rule-d); border-radius:10px; padding:22px 24px; cursor:pointer; color:var(--ivory); transition:border-color .2s, background .2s; }
.sc-exp:hover{ border-color:rgba(198,166,106,0.5); }
.sc-exp.is-sel{ border-color:var(--champagne); background:linear-gradient(180deg,rgba(198,166,106,0.1),transparent); }
.sc-exp .sc-opt__mark{ margin-top:3px; }
.sc-exp.is-sel .sc-opt__mark{ border-color:var(--champagne); }
.sc-exp.is-sel .sc-opt__mark::after{ content:""; position:absolute; inset:4px; border-radius:50%; background:var(--champagne); }
.sc-exp__main{ flex:1; }
.sc-exp__main b{ display:block; font-family:var(--f-display); font-weight:700; font-size:19px; letter-spacing:-0.01em; margin-bottom:8px; }
.sc-exp__main ul{ list-style:none; margin:0; padding:0; display:grid; gap:5px; }
.sc-exp__main li{ font-size:13.5px; color:var(--ivory-dim); padding-left:15px; position:relative; }
.sc-exp__main li::before{ content:""; position:absolute; left:0; top:8px; width:4px; height:4px; border:1px solid var(--champagne); transform:rotate(45deg); }
.sc-exp__price{ font-family:var(--f-serif); font-style:italic; font-size:21px; color:var(--champagne); white-space:nowrap; }

.sc-opt__price em{ font-style:normal; font-family:var(--f-mono); font-size:8.5px; letter-spacing:0.1em; color:var(--ivory-faint); }

/* review rule + payment note */
.sc-sum__rule{ height:1px; background:var(--rule-d); margin:10px 0; }
.sc-pay__note{ font-family:var(--f-mono); font-size:9.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ivory-faint); margin:18px 0 0; line-height:1.6; }
