/* ============================================================
   Single Malt Cigar Bar (Nashville) — homepage craft layer
   "Music City Speakeasy" — charcoal · whisky-amber · oxblood.
   Video-led. Builds on styles.css tokens. Bespoke per-section.
   ============================================================ */

:root{
  --whisky:#BD7A2C; --oxblood:#8A2B2B; --brass:#D9A85A; --bone:#EDE4D4;
  --ink:#070605; --leather:#3A2A1E;
  --halo: 0 0 70px -12px color-mix(in srgb,var(--primary) 45%,transparent);
}

body{ background:
  radial-gradient(120% 80% at 50% -10%, color-mix(in srgb,var(--primary) 8%,transparent), transparent 55%),
  var(--background); }
::selection{ background:var(--accent); color:var(--bone); }

/* site-wide smoke background canvas (JS-injected) — behind all content, above the body bg */
#smoke-bg{ position:fixed; inset:0; width:100vw; height:100vh; z-index:0; pointer-events:none; }
main, .site-footer{ position:relative; z-index:1; }

/* "scene" sections — a faded full-bleed atmosphere photo behind otherwise-blank sections.
   Set --scene:url(...) on the section; photo dimmed + edges faded to dark; smoke + grain stay on top, text readable. */
.section--scene{ position:relative; isolation:isolate; }
.section--scene::before, .section--scene::after{ content:""; position:absolute; top:0; bottom:0; left:50%; width:100vw; transform:translateX(-50%); z-index:-1; pointer-events:none; }
.section--scene::before{ background:var(--scene) center/cover no-repeat; opacity:.30; }
.section--scene::after{ background:
  radial-gradient(100% 120% at 50% 45%, transparent 28%, color-mix(in srgb,var(--ink) 58%,transparent) 100%),
  linear-gradient(180deg, var(--background) 0%, transparent 22%, transparent 78%, var(--background) 100%); }

/* section scaffolding */
.section{ position:relative; padding:clamp(72px,11vw,150px) 0; }
.section--tight{ padding:clamp(46px,7vw,88px) 0; }
.eyebrow{ display:inline-flex; align-items:center; gap:12px; font-family:var(--font-body);
  font-size:.72rem; font-weight:700; letter-spacing:.34em; text-transform:uppercase; color:var(--primary); margin:0 0 22px; }
.eyebrow::before{ content:""; width:30px; height:1px; background:linear-gradient(90deg,var(--primary),transparent); }
.eyebrow--c{ justify-content:center; } .eyebrow--c::after{ content:""; width:30px; height:1px; background:linear-gradient(270deg,var(--primary),transparent); }
.display{ font-family:var(--font-head); font-weight:700; line-height:1.04; letter-spacing:-.01em;
  font-size:clamp(2.5rem,5.6vw,4.8rem); margin:0 0 .35em; }
.display em{ font-style:italic; font-weight:600; color:var(--primary); }
.lead{ font-size:clamp(1.05rem,1.5vw,1.28rem); line-height:1.7; color:color-mix(in srgb,var(--foreground) 82%,transparent); max-width:62ch; }
.center{ text-align:center; margin-inline:auto; }
.text-amber{ background:linear-gradient(92deg,var(--brass),var(--primary) 60%,var(--accent));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.rule{ display:flex; align-items:center; justify-content:center; gap:16px; color:var(--primary); opacity:.7; }
.rule::before,.rule::after{ content:""; height:1px; flex:1; max-width:150px; background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--primary) 60%,transparent)); }
.rule::after{ background:linear-gradient(270deg,transparent,color-mix(in srgb,var(--primary) 60%,transparent)); }

/* ============ HEADER brand ============ */
.brand{ display:inline-flex; align-items:center; gap:12px; }
.brand__emblem{ width:40px; height:40px; flex:none; color:var(--primary); filter:drop-shadow(0 0 10px color-mix(in srgb,var(--primary) 40%,transparent)); }
.brand__word{ font-family:var(--font-head); font-weight:700; font-size:1.16rem; letter-spacing:.04em; color:var(--foreground); line-height:1; }
.brand__word small{ display:block; font-family:var(--font-body); font-size:.5rem; font-weight:600; letter-spacing:.42em; color:var(--primary); margin-top:4px; }
.site-header .container{ gap:22px; }
.nav-desktop a{ font-family:var(--font-body); font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; }
.btn--book{ background:var(--accent); color:var(--bone); font-size:.82rem; padding:11px 20px; }
.btn--book:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -10px var(--accent); color:var(--bone); }

/* ============ VIDEO HERO ============ */
.hero{ min-height:100svh; display:flex; }
.hero__video, .hero__poster{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.hero__poster{ background-size:cover; background-position:center; }
.hero__scrim{ position:absolute; inset:0; z-index:-1; background:
  linear-gradient(180deg, color-mix(in srgb,var(--ink) 72%,transparent) 0%, transparent 28%, color-mix(in srgb,var(--ink) 30%,transparent) 55%, color-mix(in srgb,var(--ink) 92%,transparent) 100%),
  radial-gradient(80% 60% at 30% 80%, color-mix(in srgb,var(--accent) 18%,transparent), transparent 60%); }
.hero__inner{ position:relative; z-index:2; width:100%; }
.hero--home .hero__inner{ min-height:100svh; display:flex; flex-direction:column; justify-content:space-between; padding-top:clamp(80px,9vh,92px); padding-bottom:clamp(40px,7vh,88px); }
.hero__top{ max-width:820px; }
.hero__bottom{ max-width:600px; }
.hero__rp{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-body); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--brass); margin-bottom:14px; }
.hero__rp svg{ width:18px; height:18px; }
.hero h1{ font-family:var(--font-head); font-weight:700; letter-spacing:-.01em; font-size:clamp(2rem,5vw,3.7rem); line-height:1.02; margin:0; }
.hero h1 em{ font-style:italic; font-weight:600; color:var(--primary); }
.hero .lead{ max-width:52ch; }
.hero__cta{ margin-top:26px; display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.hero__badges{ margin-top:30px; display:flex; gap:28px; flex-wrap:wrap; align-items:center; border-top:1px solid color-mix(in srgb,var(--border) 80%,transparent); padding-top:20px; }
.hero__badge{ display:flex; flex-direction:column; gap:3px; }
.hero__badge b{ font-family:var(--font-head); font-size:1.5rem; color:var(--primary); line-height:1; display:flex; align-items:center; gap:6px; }
.hero__badge b svg{ width:18px; height:18px; }
.hero__badge span{ font-size:.7rem; letter-spacing:.13em; text-transform:uppercase; color:color-mix(in srgb,var(--foreground) 60%,transparent); }
.hero__mute{ position:absolute; top:104px; right:24px; z-index:3; width:42px; height:42px; border-radius:50%;
  border:1px solid var(--border); background:color-mix(in srgb,var(--surface) 70%,transparent); backdrop-filter:blur(6px);
  color:var(--foreground); display:grid; place-items:center; cursor:pointer; transition:border-color .3s var(--ease-premium); }
.hero__mute:hover{ border-color:var(--primary); }
.hero__mute svg{ width:18px; height:18px; }

@media (prefers-reduced-motion:reduce){ .hero__video{ display:none; } }
@media (max-width:768px){ .hero__video{ display:none; } }

/* ============ MARQUEE ============ */
.marquee{ overflow:hidden; border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:color-mix(in srgb,var(--surface) 50%,transparent); padding:16px 0; }
.marquee__track{ display:flex; gap:42px; width:max-content; animation:slide 34s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__track span{ font-family:var(--font-head); font-style:italic; font-size:1.4rem; color:color-mix(in srgb,var(--foreground) 72%,transparent); display:inline-flex; align-items:center; gap:42px; white-space:nowrap; }
.marquee__track span::after{ content:""; width:7px; height:7px; rotate:45deg; background:var(--primary); }
@keyframes slide{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marquee__track{ animation:none; } }

/* ============ split feature (humidor / bar) ============ */
.feature{ position:relative; overflow:hidden; }
.feature__wm{ position:absolute; right:-3%; top:-10%; z-index:0; font-family:var(--font-head); font-weight:700;
  font-size:26vw; line-height:.7; letter-spacing:-.03em; color:transparent; pointer-events:none; user-select:none;
  -webkit-text-stroke:1px color-mix(in srgb,var(--primary) 9%,transparent); }
.feature__grid{ position:relative; z-index:1; }
.feature__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,5vw,72px); align-items:center; }
.feature--rev .feature__media{ order:2; }
.feature__media{ position:relative; border-radius:18px; overflow:hidden; border:1px solid var(--border); box-shadow:0 40px 80px -50px #000, var(--frame, inset 0 0 0 1px color-mix(in srgb,var(--primary) 12%,transparent)); aspect-ratio:4/5; }
.feature__media video, .feature__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.feature__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%, color-mix(in srgb,var(--ink) 60%,transparent)); pointer-events:none; }
.feature__tag{ position:absolute; left:16px; bottom:16px; z-index:2; display:inline-flex; align-items:center; gap:8px; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--bone); background:color-mix(in srgb,var(--ink) 60%,transparent); border:1px solid color-mix(in srgb,var(--primary) 30%,transparent); padding:7px 13px; border-radius:var(--radius-pill); backdrop-filter:blur(5px); }
.feature__tag svg{ width:14px; height:14px; color:var(--primary); }
.feature__mute{ position:absolute; top:14px; right:14px; z-index:3; width:40px; height:40px; border-radius:50%;
  border:1px solid var(--border); background:color-mix(in srgb,var(--surface) 72%,transparent); backdrop-filter:blur(6px);
  color:var(--foreground); display:grid; place-items:center; cursor:pointer; transition:border-color .3s var(--ease-premium), background .3s var(--ease-premium); }
.feature__mute:hover{ border-color:var(--primary); background:color-mix(in srgb,var(--surface) 88%,transparent); }
.feature__mute svg{ width:17px; height:17px; }
.feature__stats{ display:flex; gap:30px; flex-wrap:wrap; margin-top:26px; }
.feature__stats .s b{ font-family:var(--font-head); font-size:2rem; color:var(--primary); display:block; line-height:1; }
.feature__stats .s span{ font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:color-mix(in srgb,var(--foreground) 60%,transparent); }

/* ============ ORIGINS explorer (signature) ============ */
.origins{ position:relative; }
.origins__panel{ display:grid; grid-template-columns:.85fr 1.15fr; gap:0; border:1px solid var(--border); border-radius:22px; overflow:hidden; background:var(--surface); box-shadow:0 40px 80px -55px #000; }
.origins__tabs{ display:flex; flex-direction:column; border-right:1px solid var(--border); }
.origin-tab{ text-align:left; background:transparent; border:0; border-bottom:1px solid var(--border); color:var(--foreground); font:inherit; cursor:pointer; padding:14px 22px; display:flex; align-items:center; gap:16px; transition:background .35s var(--ease-premium), color .35s var(--ease-premium); }
.origin-tab:last-child{ border-bottom:0; }
.origin-tab svg{ width:30px; height:22px; flex:none; border-radius:3px; }
.origin-tab b{ font-family:var(--font-head); font-size:1.18rem; font-weight:600; display:block; }
.origin-tab small{ font-size:.76rem; color:color-mix(in srgb,var(--foreground) 58%,transparent); letter-spacing:.04em; }
.origin-tab:hover{ background:color-mix(in srgb,var(--muted) 60%,transparent); }
.origin-tab.is-on{ background:color-mix(in srgb,var(--accent) 16%,transparent); color:var(--bone); box-shadow:inset 3px 0 0 var(--primary); }
.origins__view{ padding:clamp(30px,4vw,52px); display:flex; flex-direction:column; justify-content:center; gap:16px; background:radial-gradient(120% 90% at 85% 0%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 55%); }
.origins__view .flag{ width:48px; height:34px; border-radius:5px; box-shadow:0 6px 16px -6px #000; }
.origins__view h3{ font-family:var(--font-head); font-size:clamp(1.7rem,3vw,2.4rem); margin:0; }
.origins__view p{ margin:0; color:color-mix(in srgb,var(--foreground) 82%,transparent); }
.origins__profile{ display:flex; gap:10px; flex-wrap:wrap; margin-top:4px; }
.origins__profile span{ font-size:.78rem; letter-spacing:.04em; color:var(--primary); border:1px solid color-mix(in srgb,var(--primary) 35%,transparent); border-radius:var(--radius-pill); padding:5px 13px; }
.origins__pair{ font-size:.95rem; border-left:2px solid var(--accent); padding-left:14px; color:color-mix(in srgb,var(--foreground) 80%,transparent); }
.origins__fade{ transition:opacity .3s var(--ease-premium); } .is-swapping .origins__fade{ opacity:0; }

/* ============ MEMBERSHIPS ============ */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch; }
.tier{ position:relative; background:linear-gradient(180deg, color-mix(in srgb,var(--surface) 96%,transparent), var(--surface)); border:1px solid var(--border); border-radius:18px; padding:32px 28px; display:flex; flex-direction:column; gap:14px; transition:transform .5s var(--ease-premium), border-color .5s var(--ease-premium), box-shadow .5s var(--ease-premium); }
.tier:hover{ transform:translateY(-4px); border-color:color-mix(in srgb,var(--primary) 45%,transparent); box-shadow:0 30px 60px -34px #000, var(--halo); }
.tier::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--primary) 65%,transparent),transparent); }
.tier--featured{ border-color:color-mix(in srgb,var(--accent) 60%,transparent); background:linear-gradient(180deg, color-mix(in srgb,var(--accent) 10%,transparent), var(--surface)); }
.tier__flag{ position:absolute; top:-12px; left:50%; translate:-50% 0; background:var(--accent); color:var(--bone); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; padding:5px 14px; border-radius:var(--radius-pill); }
.tier h3{ font-family:var(--font-head); font-size:1.5rem; font-weight:600; margin:0; }
.tier__price{ font-family:var(--font-head); font-size:2.6rem; color:var(--primary); line-height:1; }
.tier__price small{ font-family:var(--font-body); font-size:.8rem; color:color-mix(in srgb,var(--foreground) 55%,transparent); letter-spacing:.04em; display:block; margin-top:6px; }
.tier ul{ list-style:none; margin:6px 0 0; padding:0; display:grid; gap:10px; flex:1; }
.tier li{ display:flex; gap:10px; align-items:flex-start; font-size:.92rem; color:color-mix(in srgb,var(--foreground) 80%,transparent); }
.tier li svg{ width:16px; height:16px; color:var(--primary); flex:none; margin-top:3px; }
.tier .btn{ margin-top:6px; justify-content:center; }

/* ============ EVENTS ============ */
.events__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.evt{ position:relative; border:1px solid var(--border); border-radius:16px; overflow:hidden; background:var(--surface); display:flex; flex-direction:column; min-height:230px; transition:border-color .4s var(--ease-premium), transform .4s var(--ease-premium); }
.evt:hover{ transform:translateY(-3px); border-color:color-mix(in srgb,var(--primary) 45%,transparent); }
.evt__top{ padding:22px 22px 0; display:flex; justify-content:space-between; align-items:flex-start; gap:10px; }
.evt__ico{ width:34px; height:34px; color:var(--primary); }
.evt__price{ font-family:var(--font-head); font-size:1.5rem; color:var(--primary); }
.evt h3{ font-family:var(--font-head); font-size:1.3rem; margin:14px 22px 0; }
.evt p{ margin:6px 22px 0; font-size:.86rem; color:color-mix(in srgb,var(--foreground) 66%,transparent); flex:1; }
.evt a.evt__book{ margin:16px 22px 22px; font-family:var(--font-body); font-weight:600; font-size:.84rem; color:var(--primary); display:inline-flex; align-items:center; gap:8px; transition:gap .35s var(--ease-premium); }
.evt a.evt__book:hover{ gap:12px; } .evt__book svg{ width:14px; height:14px; }

/* ============ RATING / reviews band ============ */
.rating-band{ text-align:center; }
.stars{ display:inline-flex; gap:6px; color:var(--primary); margin-bottom:14px; } .stars svg{ width:26px; height:26px; }
.rating-band .num{ font-family:var(--font-head); font-size:clamp(3rem,6vw,4.6rem); color:var(--foreground); line-height:1; }
.rating-band .num em{ color:var(--primary); font-style:normal; }

/* ============ VISIT / map ============ */
.visit__grid{ display:grid; grid-template-columns:1fr 1fr; gap:0; border:1px solid var(--border); border-radius:20px; overflow:hidden; }
.visit__info{ padding:clamp(32px,4vw,52px); display:flex; flex-direction:column; gap:18px; }
.visit__row{ display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:start; }
.visit__row svg{ width:24px; height:24px; color:var(--primary); margin-top:2px; }
.visit__row h4{ font-family:var(--font-head); font-size:1.1rem; margin:0 0 3px; }
.visit__row p, .visit__row a{ margin:0; font-size:.92rem; color:color-mix(in srgb,var(--foreground) 76%,transparent); line-height:1.6; }
.visit__map{ min-height:340px; position:relative; }
.visit__map iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; filter:grayscale(.3) invert(.9) hue-rotate(180deg) contrast(.9); }

/* ============ DRINKS menu frame ============ */
.menu-frame{ margin:0; border:1px solid var(--border); border-radius:16px; overflow:hidden; background:var(--surface); box-shadow:0 40px 80px -50px #000, var(--frame, inset 0 0 0 1px color-mix(in srgb,var(--primary) 12%,transparent)); max-width:460px; margin-inline:auto; }
.menu-frame img{ width:100%; height:auto; display:block; }
.menu-frame figcaption{ padding:12px 16px; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:color-mix(in srgb,var(--foreground) 58%,transparent); border-top:1px solid var(--border); text-align:center; }

/* ============ FORM (contact) ============ */
.field{ margin-bottom:20px; }
.field label{ display:flex; flex-direction:column; gap:10px; font-family:var(--font-body); font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:color-mix(in srgb,var(--foreground) 66%,transparent); }
.field input, .field textarea{ width:100%; background:color-mix(in srgb,var(--muted) 70%,transparent); border:1px solid var(--border); border-radius:12px; padding:16px 18px; color:var(--foreground); font-family:var(--font-body); font-size:1rem; line-height:1.6; transition:border-color .3s var(--ease-premium), background .3s var(--ease-premium); }
.field input::placeholder, .field textarea::placeholder{ color:color-mix(in srgb,var(--foreground) 38%,transparent); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--primary); background:color-mix(in srgb,var(--surface) 92%,transparent); }
.field textarea{ resize:vertical; min-height:150px; vertical-align:top; }
form[data-form] .btn{ margin-top:6px; }

/* ============ FAQ ============ */
.faq__grid{ display:grid; grid-template-columns:.7fr 1.3fr; gap:clamp(32px,5vw,64px); align-items:start; }
.faq details{ border-bottom:1px solid var(--border); }
.faq summary{ list-style:none; cursor:pointer; padding:22px 44px 22px 0; position:relative; font-family:var(--font-head); font-size:1.24rem; font-weight:600; transition:color .3s var(--ease-premium); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary:hover{ color:var(--primary); }
.faq summary::after{ content:"+"; position:absolute; right:6px; top:50%; translate:0 -50%; font-size:1.4rem; color:var(--primary); transition:transform .4s var(--ease-premium); }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ margin:0; padding:0 0 22px; font-size:.95rem; color:color-mix(in srgb,var(--foreground) 76%,transparent); max-width:64ch; }

/* ============ CTA ============ */
.cta{ position:relative; text-align:center; border:1px solid var(--border); border-radius:26px; overflow:hidden; padding:clamp(48px,7vw,92px) clamp(24px,5vw,60px);
  background:radial-gradient(90% 140% at 50% 0%, color-mix(in srgb,var(--accent) 18%,transparent), transparent 55%), var(--surface); }
.cta .display{ max-width:20ch; margin-inline:auto; }

/* ============ FOOTER ============ */
.site-footer{ background:var(--ink); padding-top:72px; }
.foot__top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:36px; padding-bottom:46px; border-bottom:1px solid var(--border); }
.foot__brand p{ font-size:.9rem; color:color-mix(in srgb,var(--foreground) 64%,transparent); max-width:34ch; margin:16px 0; }
.foot__social{ display:flex; gap:12px; }
.foot__social a{ width:38px; height:38px; border:1px solid var(--border); border-radius:50%; display:grid; place-items:center; color:var(--foreground); transition:border-color .3s,color .3s; }
.foot__social a:hover{ border-color:var(--primary); color:var(--primary); } .foot__social svg{ width:17px; height:17px; }
.foot__col h4{ font-family:var(--font-body); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--primary); margin:0 0 16px; }
.foot__col a, .foot__col p{ display:block; font-size:.92rem; color:color-mix(in srgb,var(--foreground) 70%,transparent); margin:0 0 10px; }
.foot__col a:hover{ color:var(--primary); }
.foot__bottom{ display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; padding:24px 0 40px; align-items:center; }
.foot__bottom small{ font-size:.78rem; color:color-mix(in srgb,var(--foreground) 50%,transparent); }
.age{ border:1px solid var(--border); border-radius:var(--radius-pill); padding:5px 14px; font-size:.72rem; letter-spacing:.1em; color:var(--primary); }

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .feature__grid,.origins__panel,.visit__grid,.faq__grid{ grid-template-columns:1fr; }
  .feature--rev .feature__media{ order:0; }
  .origins__tabs{ flex-direction:row; overflow-x:auto; border-right:0; border-bottom:1px solid var(--border); }
  .origin-tab{ border-bottom:0; border-right:1px solid var(--border); min-width:180px; }
  .tiers{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; }
  .events__grid{ grid-template-columns:1fr 1fr; }
  .foot__top{ grid-template-columns:1fr 1fr; }
  .feature__media{ aspect-ratio:16/10; }
}
@media (max-width:600px){
  .hero h1{ font-size:clamp(2.6rem,11vw,3.6rem); }
  .events__grid{ grid-template-columns:1fr; } .foot__top{ grid-template-columns:1fr; }
  .hero__badges{ gap:18px; }
}
