/* Fonts load via a <link> in inc/head_common.php (a link tag is faster than a CSS import). */

/* ============================================================
   Stuora Bar - design tokens (colors · type · spacing)
   ============================================================ */
:root {
  /* Ink & oxblood */
  --c-ink-900:#060304; --c-ink-800:#0D0708; --c-ink-700:#160C0D;
  --c-oxblood:#220E0F; --c-oxblood-600:#2E1314; --c-burgundy:#3B1718; --c-burgundy-400:#4E2021;
  /* Warm neutrals */
  --c-mauve:#62504C; --c-taupe:#A2887F; --c-taupe-300:#B49B93; --c-champagne:#D9C8C2; --c-cream:#F0E7E2;
  /* Crimson */
  --c-crimson-900:#6E1714; --c-crimson:#91201C; --c-crimson-500:#B22A22; --c-lantern:#D6342C; --c-ruby:#A11D2A;
  /* Brass / amber */
  --c-brass-900:#7A571F; --c-brass:#C08A3C; --c-gold:#D2AE68; --c-amber:#E0A24D; --c-amber-soft:#F0C98A;
  /* Neon wordmark accent */
  --c-neon:#D63A8C; --c-neon-soft:#E87AB0;
  /* Status */
  --c-success:#7E8C5A; --c-error:#C8302B; --c-info:#8C726C;

  /* Surfaces */
  --bg-page:var(--c-ink-800); --bg-deep:var(--c-ink-900); --surface-raised:var(--c-ink-700);
  --surface-card:#150A0B; --surface-card-hover:#1E0E0F; --surface-overlay:rgba(8,4,4,0.78); --surface-velvet:var(--c-oxblood);
  /* Text */
  --text-primary:var(--c-cream); --text-secondary:var(--c-champagne); --text-muted:var(--c-taupe);
  --text-faint:#927A72; --text-on-accent:var(--c-cream); --text-gold:var(--c-gold);
  /* Accent */
  --accent:var(--c-crimson); --accent-hover:var(--c-crimson-500); --accent-press:var(--c-crimson-900);
  --accent-bright:var(--c-lantern); --accent-contrast:var(--c-cream); --gold:var(--c-gold); --gold-line:rgba(210,174,104,0.5);
  /* Borders */
  --border-subtle:rgba(217,200,194,0.10); --border-strong:rgba(217,200,194,0.20);
  --border-gold:rgba(210,174,104,0.45); --border-crimson:rgba(145,32,28,0.55);
  /* Glows */
  --glow-amber:0 0 48px -8px rgba(224,162,77,0.45); --glow-crimson:0 0 40px -6px rgba(145,32,28,0.55); --glow-neon:0 0 24px rgba(214,58,140,0.55);
  --focus-ring:0 0 0 2px var(--c-ink-900),0 0 0 4px var(--c-amber);

  /* Type */
  --font-display:'Fraunces','Playfair Display','Didot',Georgia,serif;
  --font-body:'Mulish',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-script:'Nothing You Could Do','Marck Script','Snell Roundhand',cursive;
  --fs-display-xl:clamp(3.5rem,8vw,7rem); --fs-display-lg:clamp(2.75rem,5.5vw,4.5rem);
  --fs-display-md:clamp(2rem,3.8vw,3rem); --fs-display-sm:clamp(1.6rem,2.6vw,2.1rem);
  --fs-h1:2.25rem; --fs-h2:1.75rem; --fs-h3:1.3rem; --fs-lead:1.2rem; --fs-body:1rem; --fs-sm:0.875rem; --fs-xs:0.78rem;
  --fs-eyebrow:0.72rem; --fs-script-lg:clamp(3.2rem,6.5vw,4.8rem); --fs-script-md:2.7rem;
  --fw-light:300; --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-display:600;
  --lh-tight:1.04; --lh-snug:1.22; --lh-normal:1.6; --lh-relaxed:1.75;
  --ls-display:-0.015em; --ls-tight:-0.01em; --ls-normal:0; --ls-eyebrow:0.32em; --ls-caps:0.08em;

  /* Spacing */
  --space-1:0.25rem; --space-2:0.5rem; --space-3:0.75rem; --space-4:1rem; --space-5:1.5rem;
  --space-6:2rem; --space-7:3rem; --space-8:4rem; --space-9:6rem; --space-10:8rem;
  --section-pad-y:clamp(3.5rem,9vw,8rem); --container-max:1240px; --container-narrow:760px; --gutter:clamp(1.25rem,5vw,4rem);
  --radius-xs:3px; --radius-sm:6px; --radius-md:10px; --radius-lg:14px; --radius-xl:20px; --radius-pill:999px; --radius-card:var(--radius-lg);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.5); --shadow-md:0 12px 32px -10px rgba(0,0,0,0.7);
  --shadow-lg:0 28px 70px -20px rgba(0,0,0,0.8); --shadow-card:0 20px 60px -24px rgba(0,0,0,0.85);
  --scrim-full:linear-gradient(to top,rgba(6,3,4,0.88) 0%,rgba(6,3,4,0.25) 55%,rgba(6,3,4,0.55) 100%);
  --ease-out:cubic-bezier(0.22,0.61,0.36,1); --ease-in-out:cubic-bezier(0.65,0.05,0.36,1);
  --dur-fast:160ms; --dur-base:280ms; --dur-slow:520ms; --dur-fade:800ms;
  --z-sticky:100; --z-overlay:1000; --z-modal:1100;
}

/* ============================================================ base ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg-page);color-scheme:dark;color:var(--text-primary);font-family:var(--font-body);font-size:var(--fs-body);
  font-weight:var(--fw-regular);line-height:var(--lh-normal);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{display:block;max-width:100%}
::selection{background:var(--accent);color:var(--text-on-accent)}
:focus-visible{outline:2px solid var(--c-amber);outline-offset:2px;border-radius:3px}
:focus:not(:focus-visible){outline:none}
[id]{scroll-margin-top:96px}
a{color:inherit;text-decoration:none}
.st-skip{position:absolute;left:-9999px;top:0;z-index:2000;background:var(--accent);color:var(--text-on-accent);padding:0.7rem 1.1rem;border-radius:0 0 var(--radius-sm) 0;font-size:0.85rem;font-weight:var(--fw-semibold)}
.st-skip:focus{left:0}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:var(--fw-display);line-height:var(--lh-tight);letter-spacing:var(--ls-display);margin:0}
*{scrollbar-width:thin;scrollbar-color:var(--c-burgundy) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--c-burgundy);border-radius:var(--radius-pill)}
*::-webkit-scrollbar-thumb:hover{background:var(--c-crimson)}
[hidden]{display:none !important}

/* helpers */
.eyebrow{font-family:var(--font-body);font-size:var(--fs-eyebrow);font-weight:var(--fw-semibold);letter-spacing:var(--ls-eyebrow);text-transform:uppercase;color:var(--text-gold)}
.script{font-family:var(--font-script);font-weight:var(--fw-regular);line-height:1;color:var(--accent-bright)}
.rule-gold{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--gold-line),transparent)}
.rule-deco{display:flex;align-items:center;justify-content:center;gap:0.85rem}
.rule-deco::before,.rule-deco::after{content:'';height:1px;width:clamp(36px,11vw,120px);background:linear-gradient(90deg,transparent,var(--gold-line))}
.rule-deco::after{transform:scaleX(-1)}
.rule-deco i{width:7px;height:7px;flex:none;transform:rotate(45deg);border:1px solid var(--gold);position:relative}
.rule-deco i::after{content:'';position:absolute;inset:2px;background:var(--gold);opacity:0.55}
.rule-deco--left{justify-content:flex-start}
.rule-deco--left::after{display:none}
.noir-grain{position:absolute;inset:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px 180px;opacity:0.10;mix-blend-mode:overlay}
.noir-vignette{position:absolute;inset:0;pointer-events:none;background:radial-gradient(125% 105% at 50% 38%,transparent 42%,rgba(6,3,4,0.82) 100%)}
.noir-blinds{position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(8deg,rgba(6,3,4,0) 0px,rgba(6,3,4,0) 26px,rgba(6,3,4,0.28) 26px,rgba(6,3,4,0.28) 30px);opacity:0.5;mix-blend-mode:multiply}

/* ============================================================ components ============================================================ */
.btn{display:inline-flex;width:auto;align-items:center;justify-content:center;gap:0.7em;padding:0.85rem 1.6rem;font-size:0.8rem;font-family:var(--font-body);
  font-weight:var(--fw-semibold);letter-spacing:0.16em;text-transform:uppercase;line-height:1;white-space:nowrap;
  border-radius:var(--radius-pill);border:1px solid transparent;cursor:pointer;-webkit-tap-highlight-color:transparent;
  transition:background-color var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out),letter-spacing var(--dur-base) var(--ease-out),transform var(--dur-fast) var(--ease-out)}
.btn--full{display:flex;width:100%}
.btn--sm{padding:0.6rem 1.1rem;font-size:0.74rem}
.btn--md{padding:0.85rem 1.6rem;font-size:0.8rem}
.btn--lg{padding:1.05rem 2.4rem;font-size:0.86rem}
.btn--primary{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}
.btn--primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px)}
.btn--secondary{background:transparent;color:var(--text-primary);border-color:var(--border-gold)}
.btn--secondary:hover{color:var(--text-gold);border-color:var(--gold);transform:translateY(-1px)}
.btn--gold{background:var(--gold);color:var(--c-ink-900);border-color:var(--gold)}
.btn--gold:hover{background:var(--c-amber-soft);border-color:var(--c-amber-soft);transform:translateY(-1px)}
.btn:active{transform:scale(0.98)}
.btn[disabled],.btn[aria-disabled="true"]{opacity:0.4;cursor:not-allowed}
.btn .ic{display:inline-flex;font-size:1.2em}

.badge{display:inline-flex;align-items:center;gap:0.4em;padding:0.32em 0.75em;font-family:var(--font-body);font-size:var(--fs-eyebrow);
  font-weight:var(--fw-semibold);letter-spacing:var(--ls-caps);text-transform:uppercase;line-height:1;border-radius:var(--radius-pill);white-space:nowrap}
.badge--crimson{background:var(--accent);color:var(--text-on-accent);border:1px solid transparent}
.badge--gold{background:rgba(203,164,92,0.14);color:var(--text-gold);border:1px solid var(--border-gold)}
.badge--outline{background:rgba(240,231,226,0.06);color:var(--text-secondary);border:1px solid var(--border-strong)}
.badge--solid{background:var(--c-cream);color:var(--c-ink-900);border:1px solid transparent}

/* ============================================================ Header ============================================================ */
.st-app{position:relative}
.st-header{position:fixed;inset:0 0 auto 0;z-index:var(--z-sticky);display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem var(--gutter);transition:background var(--dur-base) var(--ease-out),padding var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out);border-bottom:1px solid transparent}
.st-header.is-scrolled{background:var(--surface-overlay);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding-top:0.85rem;padding-bottom:0.85rem;border-bottom:1px solid var(--border-subtle)}
.st-brand{display:inline-flex;align-items:center}
.st-logo{height:38px;width:auto;display:block;transition:height var(--dur-base) var(--ease-out)}
.st-header.is-scrolled .st-logo{height:32px}
.st-logo-foot{height:46px}
.st-lang{display:inline-flex;align-items:center;gap:0.35rem}
.st-lang-sep{color:var(--border-strong);font-size:0.7rem}
.st-lang-btn{background:none;border:0;cursor:pointer;padding:6px 5px;font-family:var(--font-body);font-size:0.72rem;font-weight:var(--fw-bold);letter-spacing:var(--ls-caps);color:var(--text-faint);transition:color var(--dur-base) var(--ease-out)}
.st-lang-btn:hover{color:var(--text-secondary)}
.st-lang-btn.is-on{color:var(--text-gold)}
.st-lang.is-compact .st-lang-btn{font-size:0.78rem}
.st-nav{display:flex;gap:2.25rem}
.st-navlink{font-size:0.82rem;letter-spacing:var(--ls-caps);text-transform:uppercase;color:var(--text-secondary);font-weight:var(--fw-semibold);transition:color var(--dur-base) var(--ease-out);position:relative}
.st-navlink::after{content:'';position:absolute;left:0;right:100%;bottom:-6px;height:1px;background:var(--gold);transition:right var(--dur-base) var(--ease-out)}
.st-navlink:hover{color:var(--text-primary)}
.st-navlink:hover::after{right:0}
.st-navlink.is-active{color:var(--text-primary)}
.st-navlink.is-active::after{right:0}
.st-header-cta{display:flex;align-items:center;gap:1rem}
.st-burger{display:none;background:none;border:0;color:var(--text-primary);cursor:pointer;padding:9px;margin:-3px}
.st-mobilemenu{display:none}

/* ============================================================ Hero ============================================================ */
.st-hero{position:relative;min-height:100vh;display:flex;align-items:center}
.st-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:60% center}
.st-hero-scrim{position:absolute;inset:0;background:radial-gradient(120% 90% at 30% 50%,rgba(6,3,4,0.55),rgba(6,3,4,0.9) 90%),linear-gradient(to right,rgba(6,3,4,0.92),rgba(6,3,4,0.2))}
.st-hero-inner{position:relative;z-index:2;padding:8rem var(--gutter) 0;max-width:760px}
.st-hero-noir{z-index:1}
.st-hero-billing{display:flex;align-items:center;gap:0.9rem;flex-wrap:wrap;margin:2.25rem 0 0;font-size:0.7rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--text-muted)}
.st-hero-billing i{width:5px;height:5px;flex:none;transform:rotate(45deg);background:var(--gold);opacity:0.75;display:block}
.st-hero-eyebrow{margin:0 0 1.1rem}
.st-hero-rule{margin:0 0 1.5rem}
.st-hero-title{font-size:var(--fs-display-xl);font-weight:600;color:var(--text-primary);margin:0}
.st-hero-title em{font-style:italic;font-weight:500;color:var(--c-cream)}
.st-hero-script{font-size:var(--fs-script-md);margin:0.5rem 0 0;color:var(--accent-bright);text-shadow:var(--glow-crimson)}
.st-hero-sub{font-size:var(--fs-lead);color:var(--text-secondary);max-width:30rem;margin:1.75rem 0 2.5rem;line-height:1.6}
.st-hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.st-scrollcue{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;background:none;border:0;color:var(--text-muted);cursor:pointer;animation:cue 2.4s var(--ease-in-out) infinite}
@keyframes cue{0%,100%{transform:translate(-50%,0);opacity:.5}50%{transform:translate(-50%,8px);opacity:1}}

/* Intro */
.st-intro{text-align:center;padding:var(--section-pad-y) var(--gutter);max-width:720px;margin:0 auto}
.st-intro-lead{font-family:var(--font-display);font-size:var(--fs-display-sm);color:var(--text-primary);margin:0 0 1.25rem;font-style:italic}
.st-intro-body{font-size:var(--fs-lead);line-height:1.75;color:var(--text-muted);margin:0}

/* Generic section */
.st-section{padding:var(--section-pad-y) var(--gutter);max-width:var(--container-max);margin:0 auto}
.st-sechead{max-width:640px;margin:0 auto 3.5rem;text-align:center}
.st-sechead .rule-deco{margin:0 auto 1.25rem}
.st-sechead .eyebrow{margin:0 0 0.9rem}
.st-sectitle{font-size:var(--fs-display-md);color:var(--text-primary);margin:0;line-height:1.05}
.st-secsub{font-size:var(--fs-lead);color:var(--text-muted);margin:1rem auto 0;max-width:38rem}
.st-secbody{font-size:var(--fs-body);color:var(--text-muted);line-height:1.7;margin:1.25rem 0 2rem;max-width:30rem}

/* Cocktail cards */
.st-cardgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.st-card{background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-card);overflow:hidden;box-shadow:var(--shadow-card);transition:transform var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out)}
.st-card:hover{transform:translateY(-6px);border-color:var(--border-gold)}
.st-card-media{position:relative;aspect-ratio:4/5;overflow:hidden}
.st-card-media img,.st-card-media video{width:100%;height:100%;object-fit:cover;display:block;background:var(--bg-deep);
  transition:transform var(--dur-slow) var(--ease-out)}
.st-card:hover .st-card-media img,.st-card:hover .st-card-media video{transform:scale(1.06)}
.st-card-media::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(6,3,4,0) 38%,rgba(110,23,20,0.34) 100%);mix-blend-mode:multiply;transition:background var(--dur-slow) var(--ease-out)}
.st-card:hover .st-card-media::after{background:linear-gradient(180deg,rgba(145,32,28,0.16) 0%,rgba(6,3,4,0.05) 45%,rgba(110,23,20,0.52) 100%)}
.st-card-badge{position:absolute;top:0.9rem;left:0.9rem;z-index:2}
.st-card-body{padding:1.35rem 1.4rem 1.5rem}
.st-card-notes{font-size:0.7rem;letter-spacing:var(--ls-caps);text-transform:uppercase;color:var(--text-gold);margin:0 0 0.5rem}
.st-card-name{font-family:var(--font-display);font-size:1.4rem;color:var(--text-primary);margin:0 0 0.6rem;line-height:1.1}
.st-card-link{display:inline-flex;align-items:center;gap:0.4rem;background:none;border:0;padding:0;cursor:pointer;font-family:var(--font-body);font-size:0.72rem;letter-spacing:var(--ls-caps);text-transform:uppercase;color:var(--text-muted);transition:color var(--dur-base) var(--ease-out)}
.st-card-link:hover{color:var(--accent-bright)}
.st-card:hover .st-card-link{color:var(--accent-bright)}

/* Infusions feature */
.st-feature{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(2rem,6vw,6rem);max-width:var(--container-max);margin:0 auto;padding:var(--section-pad-y) var(--gutter)}
.st-feature-media{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.st-feature-media img{width:100%;height:100%;object-fit:cover}
.st-flavours{display:flex;flex-wrap:wrap;gap:0.6rem}

/* Menu */
.st-menu{background:linear-gradient(180deg,var(--bg-deep),var(--bg-page));padding-bottom:var(--section-pad-y)}
.st-mgrid{columns:3;column-gap:4rem;margin-top:3rem}
.st-mcat{break-inside:avoid;margin:0 0 2.75rem}
.st-mcat-head{display:flex;align-items:baseline;gap:1rem;margin-bottom:1.05rem}
.st-mcat-head::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--gold-line),transparent);transform:translateY(-4px)}
.st-mcat-title{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:1.3rem;color:var(--text-primary);margin:0;line-height:1.1;white-space:nowrap}
.st-mlist{list-style:none;padding:0;margin:0}
.st-mlist li{font-size:0.95rem;color:var(--text-secondary);padding:0.34rem 0;line-height:1.45}
.st-mline{font-size:0.95rem;color:var(--text-secondary);line-height:1.5;margin:0}
.st-mbites-desc{font-size:0.9rem;color:var(--text-muted);line-height:1.6;margin:0 0 0.75rem}
.st-mnote{display:flex;align-items:center;gap:0.5rem;margin:0.9rem 0 0;font-size:0.8rem;font-style:italic;color:var(--text-gold);line-height:1.4}
.st-mnote svg{flex:none}

/* Reviews */
.st-reviews{background:var(--bg-page)}
.st-rgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.st-review{margin:0;background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-card);padding:1.6rem 1.5rem;display:flex;flex-direction:column;gap:1rem;box-shadow:var(--shadow-card)}
.st-stars{color:var(--gold);display:inline-flex;gap:2px}
.st-review-q{margin:0;font-family:var(--font-display);font-style:italic;font-size:1.05rem;line-height:1.5;color:var(--text-secondary);flex:1}
.st-review-by{display:flex;flex-direction:column;gap:2px}
.st-review-name{font-weight:var(--fw-bold);font-size:0.9rem;color:var(--text-primary)}
.st-review-meta{font-size:0.75rem;color:var(--text-muted)}

/* Quote */
.st-quote{position:relative;padding:clamp(5rem,12vw,10rem) var(--gutter);text-align:center;overflow:hidden}
.st-quote-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.1)}
.st-quote-scrim{position:absolute;inset:0;background:var(--scrim-full)}
.st-quote-inner{position:relative;z-index:2;max-width:760px;margin:0 auto}
.st-quote-noir{z-index:1}
.st-quote-text{font-size:var(--fs-script-lg);color:var(--c-cream);text-shadow:0 2px 30px rgba(0,0,0,0.6);margin:0}
.st-quote-sub{font-family:var(--font-display);font-style:italic;font-size:clamp(1.3rem,2.4vw,1.9rem);color:var(--text-secondary);margin:1rem auto 1.5rem;max-width:36rem;line-height:1.4}
.st-quote-sig{font-family:var(--font-script);font-size:2.4rem;color:var(--accent-bright);margin:0}

/* Visit */
.st-visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.st-hours{list-style:none;padding:0;margin:2rem 0;border-top:1px solid var(--border-subtle)}
.st-hours li{display:flex;justify-content:space-between;padding:0.85rem 0;border-bottom:1px solid var(--border-subtle);font-size:1rem;color:var(--text-secondary)}
.st-hours li span:first-child{color:var(--text-muted)}
.st-hours .is-private{color:var(--text-gold)}
.st-private{display:flex;gap:0.7rem;align-items:flex-start;background:var(--surface-card);border:1px solid var(--border-gold);border-radius:var(--radius-md);padding:1rem 1.1rem;margin:0 0 2rem}
.st-private svg{flex:none;color:var(--text-gold);margin-top:2px}
.st-private p{margin:0;font-size:0.9rem;line-height:1.6;color:var(--text-secondary)}
.st-visit-cta{display:flex;gap:0.8rem;flex-wrap:wrap;margin-top:0.5rem}
.st-contact{display:flex;flex-direction:column;gap:0.9rem;margin-bottom:2rem}
.st-contact a{display:flex;align-items:center;gap:0.8rem;color:var(--text-secondary);font-size:0.98rem;transition:color var(--dur-base) var(--ease-out)}
.st-contact a:hover{color:var(--text-primary)}
.st-ci{display:inline-flex;color:var(--text-gold)}
.st-addr-link{align-items:flex-start !important}
.st-addr{display:flex;flex-direction:column;gap:0.15rem}
.st-entrance{font-size:0.82rem;color:var(--text-gold);font-style:italic}
.st-visit-media{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.st-visit-media img{width:100%;height:100%;object-fit:cover}

/* Map */
.st-map{max-width:var(--container-max);margin:0 auto;padding:0 var(--gutter) var(--section-pad-y)}
.st-map-frame{position:relative;border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border-gold);box-shadow:var(--shadow-lg);aspect-ratio:21/9;background:var(--surface-card)}
.st-map-embed{width:100%;height:100%;border:0;display:block;filter:invert(0.92) hue-rotate(180deg) saturate(0.78) brightness(0.92) contrast(1.05)}
.st-map-scrim{position:absolute;inset:0;pointer-events:none;background:radial-gradient(60% 60% at 50% 45%,transparent,rgba(6,3,4,0.35))}
.st-map-pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:0.35rem;pointer-events:none}
.st-map-dot{width:40px;height:40px;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--c-cream);box-shadow:var(--glow-crimson)}
.st-map-label{font-family:var(--font-script);font-size:1.9rem;color:var(--c-cream);line-height:1;text-shadow:0 2px 12px rgba(0,0,0,0.8)}
/* FAQ accordion (homepage) */
.st-faq-list{max-width:46rem;margin:0 auto;display:flex;flex-direction:column;gap:0.5rem}
.st-faq-item{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface-card)}
.st-faq-q{display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;padding:1.05rem 1.25rem;font-family:var(--font-display);font-size:1.08rem;color:var(--text-primary);list-style:none}
.st-faq-q::-webkit-details-marker{display:none}
.st-faq-mark{position:relative;flex:none;width:14px;height:14px}
.st-faq-mark::before,.st-faq-mark::after{content:"";position:absolute;background:var(--text-gold);transition:transform var(--dur-base) var(--ease-out)}
.st-faq-mark::before{top:6px;left:0;width:14px;height:2px}
.st-faq-mark::after{top:0;left:6px;width:2px;height:14px}
.st-faq-item[open] .st-faq-mark::after{transform:scaleY(0)}
.st-faq-a{padding:0 1.25rem 1.15rem;color:var(--text-secondary);line-height:1.65}
.st-faq-a p{margin:0}
/* Occasion page - included list */
.occ-incl{max-width:40rem;margin:0 auto;list-style:none;padding:0;display:flex;flex-direction:column;gap:0.7rem}
.occ-incl li{display:flex;align-items:flex-start;gap:0.7rem;color:var(--text-secondary);line-height:1.5}
.occ-incl .ev-tick{flex:none;margin-top:2px}
@media (prefers-reduced-motion:reduce){.st-faq-mark::before,.st-faq-mark::after{transition:none}}
.st-map-bar{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;flex-wrap:wrap;margin-top:1.25rem}
.st-map-note{display:flex;align-items:center;gap:0.55rem;margin:0;font-size:0.92rem;font-style:italic;color:var(--text-muted);line-height:1.4}
.st-map-note svg{flex:none;color:var(--text-gold)}
.st-map-actions{display:flex;gap:0.8rem;flex-wrap:wrap}

/* Footer */
.st-footer{padding:var(--space-8) var(--gutter) var(--space-6);max-width:var(--container-max);margin:0 auto}
.st-footer-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.st-footer-tag{font-size:2.2rem;color:var(--accent-bright);margin:0}
.st-footer-bottom{display:flex;gap:2rem;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:1.5rem 0;font-size:0.86rem;color:var(--text-muted)}
.st-footer-ig{display:inline-flex;align-items:center;gap:0.5rem;color:var(--text-secondary)}
.st-footer-fine{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:0.75rem;color:var(--text-faint);margin:0.5rem 0 0}

/* Reserve drawer */
.rd-veil{position:fixed;inset:0;z-index:var(--z-overlay);background:rgba(6,3,4,0.6);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity var(--dur-base) var(--ease-out)}
.rd-veil.is-open{opacity:1;pointer-events:auto}
.rd-drawer{position:fixed;top:0;right:0;bottom:0;z-index:var(--z-modal);width:min(420px,92vw);background:var(--surface-raised);border-left:1px solid var(--border-gold);box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform var(--dur-slow) var(--ease-out);overflow-y:auto}
.rd-drawer.is-open{transform:translateX(0)}
.rd-head{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 0.5rem}
.rd-head .eyebrow{margin:0}
.rd-close{background:none;border:0;color:var(--text-muted);cursor:pointer;padding:6px;transition:color var(--dur-base)}
.rd-close:hover{color:var(--text-primary)}
.rd-body{padding:1rem 1.75rem 2rem}
.rd-title{font-family:var(--font-display);font-size:1.7rem;color:var(--text-primary);margin:0.5rem 0 0.4rem;line-height:1.1}
.rd-lead{font-size:0.92rem;color:var(--text-muted);line-height:1.6;margin:0 0 1.75rem}
.rd-field{display:block;margin-bottom:1.5rem}
.rd-field>span{display:block;font-size:0.72rem;letter-spacing:var(--ls-caps);text-transform:uppercase;color:var(--text-gold);margin-bottom:0.6rem}
.rd-field input{width:100%;padding:0.85rem 1rem;background:var(--surface-card);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:1rem;transition:border-color var(--dur-base)}
.rd-field input:focus{outline:none;border-color:var(--gold)}
.rd-field input::placeholder{color:var(--text-faint)}
.rd-field input[type="date"]{color-scheme:dark}
.rd-field input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(0.7) sepia(1) saturate(4) hue-rotate(5deg);opacity:0.85;cursor:pointer}
.rd-field input[type="date"]:hover::-webkit-calendar-picker-indicator{opacity:1}
.rd-chips{display:flex;flex-wrap:wrap;gap:0.5rem}
.rd-chip{padding:0.55rem 0.9rem;background:var(--surface-card);border:1px solid var(--border-strong);border-radius:var(--radius-pill);color:var(--text-secondary);font-family:var(--font-body);font-size:0.85rem;cursor:pointer;transition:all var(--dur-fast) var(--ease-out)}
.rd-chip:hover{border-color:var(--border-gold)}
.rd-chip.is-on{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}
.rd-stepper{display:flex;align-items:center;justify-content:space-between;background:var(--surface-card);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:0.4rem 0.6rem}
.rd-stepper strong{font-family:var(--font-body);font-weight:600;color:var(--text-primary);font-size:0.95rem}
.rd-stepper button{width:38px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface-raised);color:var(--text-primary);font-size:1.2rem;cursor:pointer;transition:all var(--dur-fast)}
.rd-stepper button:hover{border-color:var(--gold);color:var(--gold)}
.rd-summary{display:flex;justify-content:space-between;padding:1rem 0;margin-bottom:1rem;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);font-size:0.88rem;color:var(--text-secondary)}
.rd-summary span{display:inline-flex;align-items:center;gap:0.5rem}
.rd-back{display:block;margin:1rem auto 0;background:none;border:0;color:var(--text-muted);font-size:0.85rem;cursor:pointer}
.rd-back:hover{color:var(--text-primary)}
.rd-done{text-align:center;padding-top:2rem}
.rd-check{width:64px;height:64px;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--c-cream);background:var(--accent);box-shadow:var(--glow-crimson)}
.rd-sig{font-size:2.2rem;color:var(--accent-bright);margin:0 0 1.75rem}
.rd-hint{display:flex;align-items:center;gap:0.5rem;font-size:0.78rem;font-style:italic;color:var(--text-gold);margin:0 0 1.25rem;line-height:1.4}
.rd-hint svg{flex:none}

/* Responsive */
@media (max-width:1100px){.st-mgrid{columns:2}}
@media (max-width:940px){
  .st-cardgrid{grid-template-columns:repeat(2,1fr)}
  .st-rgrid{grid-template-columns:repeat(2,1fr)}
  .st-feature,.st-visit-grid{grid-template-columns:1fr}
  .st-feature-media,.st-visit-media{aspect-ratio:16/10}
  .st-nav{display:none}
  .st-header-cta>.st-lang{display:none}
  .st-burger{display:inline-flex}
  .st-mobilemenu{display:flex;flex-direction:column;gap:0.5rem;position:absolute;top:100%;left:0;right:0;background:var(--surface-overlay);backdrop-filter:blur(14px);padding:1rem var(--gutter) 1.5rem;border-bottom:1px solid var(--border-subtle)}
  .st-mobilemenu a{color:var(--text-secondary);padding:0.6rem 0;text-transform:uppercase;letter-spacing:var(--ls-caps);font-size:0.85rem}
  .st-mobilemenu-foot{margin-top:0.5rem;padding-top:0.9rem;border-top:1px solid var(--border-subtle)}
}
@media (max-width:620px){
  .st-mgrid{columns:1}
  .st-cardgrid{grid-template-columns:1fr}
  .st-rgrid{grid-template-columns:1fr}
  .st-hero-cta{flex-direction:column;align-items:stretch}
  .st-hero-inner{padding-top:7rem}
  .st-visit-cta{flex-direction:column;align-items:stretch}
  .rd-drawer{width:100vw;border-left:0}
  .st-map-frame{aspect-ratio:4/3}
  .st-map-bar{flex-direction:column;align-items:stretch}
  .st-map-actions{width:100%}
  .st-map-actions>*{flex:1}
  .st-footer-bottom{flex-direction:column;align-items:flex-start;gap:0.75rem}
}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.001ms !important;transition-duration:0.001ms !important}}

/* cross-page: Private events link (used on home nav + visit) */
.st-navlink--events{color:var(--text-gold)}
.st-navlink--events::after{background:var(--gold)}
.st-mobilemenu-events{color:var(--text-gold) !important;font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:var(--ls-caps);font-size:0.85rem;padding:0.6rem 0}
.st-private-link{color:var(--text-gold);font-weight:var(--fw-semibold);white-space:nowrap;border-bottom:1px solid var(--gold-line);transition:border-color var(--dur-base)}
.st-private-link:hover{border-color:var(--gold)}
.st-walkin{display:flex;align-items:center;gap:0.5rem;color:var(--text-secondary);font-size:0.92rem;margin:0 0 1.75rem;line-height:1.4}
.st-walkin svg{color:var(--text-gold);flex:none}
.st-menu-private{margin-top:3rem;display:flex;flex-direction:column;align-items:center;gap:1.1rem;text-align:center}
.st-menu-private-note{display:flex;align-items:center;gap:0.5rem;margin:0;font-size:0.92rem;font-style:italic;color:var(--text-gold);line-height:1.4;max-width:34rem}
.st-menu-private-note svg{flex:none}
