/* ===========================================================
   FAME LOUNGE — Calgary
   Dark cinematic luxury · warm gold on near-black
   =========================================================== */

:root{
  --bg:        #0a0807;
  --bg-2:      #100c09;
  --panel:     #15100b;
  --ink:       #f5ecdd;
  --muted:     #b3a187;
  --faint:     #7c6e5b;
  --gold:      #d8b56a;
  --gold-hi:   #f3d79a;
  --ember:     #c8492b;
  --line:      rgba(216,181,106,.16);
  --line-soft: rgba(245,236,221,.08);

  --serif: "Bodoni Moda", Georgia, serif;
  --sans:  "Outfit", system-ui, sans-serif;
  --syne:  "Syne", var(--sans);

  --maxw: 1240px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---- atmosphere: grain + cursor glow ---- */
.grain{
  position:fixed; inset:-50%; z-index:9999; pointer-events:none;
  opacity:.045; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(6) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)} 20%{transform:translate(-4%,3%)}
  40%{transform:translate(3%,-4%)} 60%{transform:translate(-2%,2%)}
  80%{transform:translate(4%,-1%)}
}
.cursor-glow{
  position:fixed; top:0; left:0; width:520px; height:520px; z-index:1;
  margin:-260px 0 0 -260px; border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(216,181,106,.10), transparent 60%);
  transition:transform .25s var(--ease); will-change:transform;
}
@media(hover:none){ .cursor-glow{ display:none; } }

/* ---- shared type ---- */
.eyebrow,.kicker{
  font-family:var(--syne); font-weight:700; letter-spacing:.32em;
  text-transform:uppercase; font-size:.7rem; color:var(--gold);
}
.kicker{ color:var(--faint); margin-bottom:1.1rem; }
.italic{ font-style:italic; }
.gold{
  color:transparent; background:linear-gradient(100deg,var(--gold),var(--gold-hi) 55%,var(--gold));
  -webkit-background-clip:text; background-clip:text;
}
.section{ max-width:var(--maxw); margin:0 auto; padding:7rem 1.6rem; }
h2{
  font-family:var(--serif); font-weight:500; line-height:1.02;
  font-size:clamp(2.2rem,6vw,4.2rem); letter-spacing:-.01em;
}
h3{ font-family:var(--serif); font-weight:600; }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--syne); font-weight:700; font-size:.78rem;
  letter-spacing:.12em; text-transform:uppercase;
  padding:1.05em 1.8em; border-radius:999px; cursor:pointer;
  border:1px solid transparent; transition:.35s var(--ease); white-space:nowrap;
}
.btn--gold{
  background:linear-gradient(100deg,var(--gold),var(--gold-hi));
  color:#1a1206; box-shadow:0 10px 36px -12px rgba(216,181,106,.6);
}
.btn--gold:hover{ transform:translateY(-3px); box-shadow:0 18px 46px -14px rgba(216,181,106,.75); }
.btn--ghost{
  border-color:var(--line); color:var(--ink); background:rgba(255,255,255,.02);
}
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-hi); background:rgba(216,181,106,.06); }

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  gap:2rem; padding:1.4rem clamp(1.2rem,4vw,3rem);
  transition:.4s var(--ease);
}
.nav.is-stuck{
  background:rgba(10,8,7,.82); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft); padding-top:.9rem; padding-bottom:.9rem;
}
.nav__brand{ display:flex; flex-direction:column; line-height:1; }
.nav__mark{
  font-family:var(--serif); font-weight:700; font-style:italic;
  font-size:1.7rem; letter-spacing:.01em;
}
.nav__sub{
  font-family:var(--syne); font-size:.6rem; letter-spacing:.34em;
  text-transform:uppercase; color:var(--gold); margin-top:.2rem;
}
.nav__links{ display:flex; gap:2.1rem; margin-left:auto; }
.nav__links a{
  font-size:.82rem; letter-spacing:.06em; color:var(--muted);
  position:relative; padding:.3rem 0; transition:color .3s;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--gold); transition:width .35s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ width:100%; }
.nav__cta{ padding:.8em 1.3em; }
.nav__burger{
  display:none; flex-direction:column; gap:6px; background:none; border:0;
  cursor:pointer; padding:6px;
}
.nav__burger span{ width:26px; height:2px; background:var(--ink); transition:.3s var(--ease); }
.nav.is-open .nav__burger span:first-child{ transform:translateY(4px) rotate(45deg); }
.nav.is-open .nav__burger span:last-child{ transform:translateY(-4px) rotate(-45deg); }

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  overflow:hidden; padding:0 clamp(1.4rem,5vw,4rem);
}
/* full-bleed wide video, dimmed right down so the low-res softness barely reads —
   it becomes subtle moving atmosphere behind the headline */
.hero__video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center; z-index:0;
  opacity:.32; filter:saturate(.95) contrast(1.05);
}
.hero__veil{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(10,8,7,.35) 0%, rgba(10,8,7,.1) 38%, rgba(10,8,7,.55) 80%, var(--bg) 100%),
    radial-gradient(120% 90% at 18% 60%, rgba(10,8,7,.45), transparent 60%);
}
.hero__smoke{
  position:absolute; inset:0; z-index:1; pointer-events:none; opacity:.5;
  background:radial-gradient(60% 50% at 80% 20%, rgba(216,181,106,.16), transparent 60%),
             radial-gradient(50% 40% at 15% 85%, rgba(200,73,43,.12), transparent 60%);
  animation:drift 14s ease-in-out infinite alternate;
}
@keyframes drift{ from{transform:translate3d(0,0,0)} to{transform:translate3d(-3%,-2%,0) scale(1.05)} }

.hero__inner{ position:relative; z-index:2; max-width:880px; }
.hero__title{
  font-family:var(--serif); font-weight:500; line-height:.98;
  font-size:clamp(3rem,10vw,7.2rem); letter-spacing:-.02em; margin:1.3rem 0 1.6rem;
}
.hero__title span{ display:block; }
.hero__lede{
  font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--muted);
  max-width:42ch; margin-bottom:2.2rem;
}
.hero__actions{ display:flex; gap:1rem; flex-wrap:wrap; }
.hero__meta{
  display:flex; align-items:center; gap:1.1rem; flex-wrap:wrap;
  margin-top:2.6rem; font-size:.86rem; color:var(--muted);
}
.hero__meta b{ color:var(--ink); font-weight:600; }
.hero__meta .dot{ width:5px; height:5px; border-radius:50%; background:var(--gold); }
.hero__scroll{
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
  font-family:var(--syne); font-size:.62rem; letter-spacing:.3em; text-transform:uppercase;
  color:var(--faint);
}
.hero__scroll i{ width:1px; height:40px; background:linear-gradient(var(--gold),transparent); animation:scrolln 2s var(--ease) infinite; }
@keyframes scrolln{ 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* ===========================================================
   MARQUEE
   =========================================================== */
.marquee{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--bg-2); overflow:hidden; padding:1.1rem 0;
}
.marquee__track{
  display:flex; align-items:center; gap:2.2rem; width:max-content;
  animation:scrollx 38s linear infinite;
}
.marquee__track span{
  font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--ink); white-space:nowrap;
}
.marquee__track i{ color:var(--gold); font-style:normal; font-size:.8rem; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }

/* ===========================================================
   STORY
   =========================================================== */
.story{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.story__media{ position:relative; }
.story__media img{
  width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:6px;
  filter:saturate(.92) brightness(.94);
}
.story__media::after{
  content:""; position:absolute; inset:0; border-radius:6px;
  box-shadow:inset 0 0 120px rgba(10,8,7,.7); pointer-events:none;
}
.story__badge{
  position:absolute; right:-1.2rem; bottom:1.6rem;
  background:var(--bg); border:1px solid var(--line); border-radius:6px;
  padding:1rem 1.3rem; font-family:var(--syne); font-size:.62rem; letter-spacing:.26em;
  text-transform:uppercase; color:var(--faint); line-height:1.7; text-align:right;
}
.story__badge b{ color:var(--gold); font-size:.74rem; }
.story__copy h2{ margin:.5rem 0 1.4rem; }
.story__copy p{ color:var(--muted); margin-bottom:1.1rem; max-width:48ch; }
.story__stats{
  display:flex; gap:2.4rem; margin-top:2.4rem; padding-top:2rem;
  border-top:1px solid var(--line-soft); flex-wrap:wrap;
}
.story__stats b{ display:block; font-family:var(--serif); font-size:2.4rem; color:var(--gold); line-height:1; }
.story__stats span{ font-size:.78rem; letter-spacing:.04em; color:var(--faint); }

/* ===========================================================
   EXPERIENCE
   =========================================================== */
.exp__head{ max-width:600px; margin-bottom:3.4rem; }
.exp__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.card{
  position:relative; padding:2.4rem 2rem 2.6rem; border:1px solid var(--line-soft);
  border-radius:8px; background:linear-gradient(180deg,var(--panel),var(--bg-2));
  overflow:hidden; transition:.45s var(--ease);
}
.card::before{
  content:""; position:absolute; inset:0; opacity:0; transition:opacity .45s;
  background:radial-gradient(90% 70% at 50% 0%, rgba(216,181,106,.12), transparent 60%);
}
.card:hover{ transform:translateY(-6px); border-color:var(--line); }
.card:hover::before{ opacity:1; }
.card__num{
  font-family:var(--serif); font-style:italic; font-size:1rem; color:var(--gold);
  display:block; margin-bottom:1.2rem; letter-spacing:.1em;
}
.card h3{ font-size:1.7rem; margin-bottom:.8rem; }
.card p{ color:var(--muted); font-size:.96rem; }

/* ===========================================================
   VIDEO INTERLUDE
   =========================================================== */
.interlude{
  position:relative; height:78vh; min-height:460px; display:flex; align-items:flex-end;
  overflow:hidden;
}
.interlude__video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; z-index:0;
  opacity:.34; filter:saturate(.95) contrast(1.05);
}
.interlude__veil{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, var(--bg) 0%, transparent 22%, rgba(10,8,7,.35) 55%, var(--bg) 100%),
             radial-gradient(80% 60% at 20% 90%, rgba(10,8,7,.7), transparent 60%);
}
.interlude__copy{ position:relative; z-index:2; padding:0 clamp(1.6rem,6vw,5rem) clamp(3rem,7vw,5.5rem); max-width:900px; }
.interlude__copy h2{ margin-top:.6rem; }

/* ===========================================================
   MENU
   =========================================================== */
.menu__head{ text-align:center; max-width:620px; margin:0 auto 3.4rem; }
.menu__note{ color:var(--faint); margin-top:1rem; font-size:.95rem; }
.menu__grid{ display:grid; grid-template-columns:1fr 1fr; gap:2.6rem 3.2rem; }
.dish{ display:flex; flex-direction:column; }
.dish__img{ overflow:hidden; border-radius:6px; margin-bottom:1.2rem; }
.dish__img img{
  width:100%; aspect-ratio:16/10; object-fit:cover;
  transition:transform .7s var(--ease); filter:saturate(.95);
}
.dish:hover .dish__img img{ transform:scale(1.06); }
.dish__row{ display:flex; align-items:baseline; gap:.8rem; }
.dish__row h3{ font-size:1.4rem; }
.dish__row b{ font-family:var(--serif); color:var(--gold); font-size:1.3rem; }
.dish__dots{ flex:1; border-bottom:1px dotted var(--line); transform:translateY(-4px); }
.dish p{ color:var(--muted); font-size:.92rem; margin-top:.5rem; }
.dish--feature .dish__row b{ color:var(--gold-hi); }

/* ===========================================================
   HAPPY HOUR BAND
   =========================================================== */
.band{
  position:relative; padding:5rem 1.6rem; text-align:center; overflow:hidden;
  background:
    linear-gradient(180deg,var(--bg),var(--bg-2)),
    radial-gradient(60% 120% at 50% 0%, rgba(216,181,106,.10), transparent 60%);
  border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft);
}
.band__inner{ max-width:760px; margin:0 auto; }
.band__inner h2{ margin:.6rem 0 2rem; }

/* ===========================================================
   GALLERY
   =========================================================== */
.gallery__head{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:2.4rem; flex-wrap:wrap; gap:1rem; }
.gallery__grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:1rem; }
.g{ overflow:hidden; border-radius:6px; position:relative; }
.g img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); filter:saturate(.9) brightness(.92); }
.g::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(10,8,7,.6)); opacity:0; transition:opacity .5s; }
.g:hover img{ transform:scale(1.08); }
.g:hover::after{ opacity:1; }
.g--tall{ grid-row:span 2; }
.g--wide{ grid-column:span 2; }
.gallery__ig{
  display:inline-block; margin-top:2.2rem; font-family:var(--syne); font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; font-size:.78rem; color:var(--gold);
  border-bottom:1px solid var(--line); padding-bottom:.4rem; transition:.3s;
}
.gallery__ig:hover{ color:var(--gold-hi); border-color:var(--gold); }

/* ===========================================================
   VISIT
   =========================================================== */
.visit{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.visit__copy h2{ margin:.4rem 0 2rem; }
.visit__list{ list-style:none; border-top:1px solid var(--line-soft); }
.visit__list li{
  display:flex; justify-content:space-between; align-items:baseline; gap:1rem;
  padding:1.15rem 0; border-bottom:1px solid var(--line-soft);
}
.visit__list span{ font-family:var(--syne); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--faint); }
.visit__list b{ font-weight:500; font-size:1.02rem; text-align:right; }
.visit__list a:hover{ color:var(--gold-hi); }
.visit__actions{ display:flex; gap:1rem; margin-top:2rem; flex-wrap:wrap; }
.visit__map{ border-radius:8px; overflow:hidden; border:1px solid var(--line); height:440px; }
.visit__map iframe{ width:100%; height:100%; border:0; filter:grayscale(1) invert(.9) contrast(.9) hue-rotate(180deg); }

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{ background:var(--bg-2); border-top:1px solid var(--line); padding:4rem clamp(1.4rem,5vw,3rem) 2rem; }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.4rem; padding-bottom:3rem; border-bottom:1px solid var(--line-soft); }
.footer__brand p{ color:var(--faint); font-size:.9rem; margin-top:1rem; }
.footer__nav{ display:flex; flex-direction:column; gap:.7rem; }
.footer__nav a, .footer__contact a, .footer__contact span{ color:var(--muted); font-size:.92rem; transition:color .3s; }
.footer__nav a:hover, .footer__contact a:hover{ color:var(--gold); }
.footer__contact{ display:flex; flex-direction:column; gap:.7rem; }
.footer__bar{
  max-width:var(--maxw); margin:1.6rem auto 0; display:flex; justify-content:space-between;
  gap:1rem; flex-wrap:wrap; font-size:.78rem; color:var(--faint);
}

/* ===========================================================
   REVEAL ANIMATIONS
   =========================================================== */
.reveal,.reveal-up{ opacity:0; }
.reveal{ transform:translateY(14px); }
.reveal-up{ transform:translateY(34px); }
.reveal.in,.reveal-up.in{
  opacity:1; transform:none;
  transition:opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal[data-d="1"],.reveal-up[data-d="1"]{ transition-delay:.12s; }
.reveal[data-d="2"],.reveal-up[data-d="2"]{ transition-delay:.24s; }
.reveal[data-d="3"]{ transition-delay:.36s; }
.reveal[data-d="4"]{ transition-delay:.48s; }
.reveal[data-d="5"]{ transition-delay:.6s; }
.reveal[data-d="6"]{ transition-delay:.72s; }

@media(prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; }
  .reveal,.reveal-up{ opacity:1; transform:none; }
}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:980px){
  .nav__links{ display:none; }
  .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
  /* give the top bar a solid backdrop when the menu is open so the logo/X read cleanly */
  .nav.is-open{ background:var(--bg); }
  .nav__links.is-open{
    display:flex; position:fixed; inset:0; flex-direction:column;
    align-items:center; justify-content:center; gap:1.9rem; margin:0;
    z-index:95;
    /* explicit solid colour guarantees an opaque paint even if the gradient fails */
    background-color:#0a0807;
    background-image:radial-gradient(80% 50% at 50% 18%, rgba(216,181,106,.10), transparent 60%);
    /* force its own compositor layer so it never renders behind the video layers */
    transform:translateZ(0); will-change:transform; isolation:isolate;
    backface-visibility:hidden;
  }
  .nav__links.is-open a{
    font-family:var(--serif); font-style:italic; font-size:1.9rem; color:var(--ink);
  }
  .nav__links.is-open a::after{ display:none; }
  .story, .visit{ grid-template-columns:1fr; }
  .story__media{ max-width:460px; }
  .exp__grid{ grid-template-columns:1fr; }
  .menu__grid{ grid-template-columns:1fr; gap:2.4rem; }
  .footer__top{ grid-template-columns:1fr 1fr; }
}
@media(max-width:620px){
  .section{ padding:4.5rem 1.4rem; }
  .gallery__grid{ grid-template-columns:1fr 1fr; grid-auto-rows:150px; }
  .g--wide{ grid-column:span 2; }
  .story__stats{ gap:1.4rem; }
  .footer__top{ grid-template-columns:1fr; }
  .hero__meta{ font-size:.78rem; }
}
