/* ============================================================
   Southern Range Brewing Co. — stylesheet
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ink:#0d0d0f;
  --ink-2:#16161a;
  --ink-3:#1e1e24;
  --cream:#f5efe3;
  --cream-2:#ece3d2;
  --paper:#faf6ee;
  --muted:#9a958c;
  --line:rgba(245,239,227,.12);

  --amber:#f5a623;
  --amber-deep:#e08600;
  --gold:#ffce4d;

  --maxw:1240px;
  --pad:clamp(20px,5vw,64px);
  --radius:18px;
  --radius-lg:28px;

  --font-display:"Anton",system-ui,sans-serif;
  --font-cond:"Barlow Condensed",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;
  --font-script:"Pacifico",cursive;

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

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

/* scrollbar */
body::-webkit-scrollbar{width:11px}
body::-webkit-scrollbar-track{background:var(--ink)}
body::-webkit-scrollbar-thumb{background:#34343c;border-radius:20px;border:3px solid var(--ink)}

/* ---------- Shared ---------- */
.section{padding:clamp(72px,11vw,140px) var(--pad)}
.section__head{max-width:var(--maxw);margin:0 auto clamp(40px,6vw,72px);text-align:center}
.eyebrow{
  font-family:var(--font-cond);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-weight:600;
  font-size:.82rem;
  color:var(--amber);
  margin-bottom:1rem;
}
h2{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(2rem,5.2vw,3.6rem);
  line-height:1.02;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.section__lead{
  max-width:48ch;margin:1.2rem auto 0;color:var(--muted);font-size:1.06rem;
}
em{font-style:normal;color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--amber);
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-cond);
  text-transform:uppercase;letter-spacing:.08em;font-weight:700;
  font-size:1.02rem;
  padding:.92em 1.6em;border-radius:100px;
  border:2px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
  will-change:transform;
}
.btn--sm{padding:.6em 1.2em;font-size:.92rem}
.btn--lg{padding:1.1em 2.2em;font-size:1.15rem}
.btn--primary{background:var(--amber);color:var(--ink);box-shadow:0 10px 30px -10px rgba(245,166,35,.7)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px -12px rgba(245,166,35,.85);background:var(--gold)}
.btn--ghost{background:transparent;color:var(--cream);border-color:rgba(245,239,227,.35)}
.btn--ghost:hover{border-color:var(--cream);background:var(--cream);color:var(--ink);transform:translateY(-3px)}

/* ---------- Topbar ---------- */
.topbar{
  background:var(--amber);color:var(--ink);
  font-family:var(--font-cond);font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;font-size:.82rem;
  overflow:hidden;white-space:nowrap;position:relative;z-index:60;
}
.topbar__track{
  display:inline-flex;gap:1.4rem;align-items:center;padding:.5rem 0;
  animation:ticker 30s linear infinite;
}
.topbar span{display:inline-block}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  transition:background .35s var(--ease),backdrop-filter .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(13,13,15,.78);
  backdrop-filter:blur(14px) saturate(1.4);
  border-bottom-color:var(--line);
}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:.8rem var(--pad);
}
.nav__logo img{height:46px;width:auto;transition:height .35s var(--ease)}
.nav.scrolled .nav__logo img{height:38px}
.nav__links{display:flex;align-items:center;gap:1.9rem}
.nav__links a{
  font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.08em;
  font-weight:600;font-size:1rem;color:var(--cream);position:relative;
  transition:color .2s;
}
.nav__links a:not(.btn):not(.nav__shop)::after{
  content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--amber);
  transition:width .3s var(--ease);
}
.nav__links a:not(.btn):not(.nav__shop):hover::after{width:100%}
.nav__links a:hover{color:var(--gold)}
.nav__shop{color:var(--amber)!important}
.nav__cta{background:var(--amber)!important;color:var(--ink)!important;border-color:var(--amber)!important;box-shadow:0 8px 22px -10px rgba(245,166,35,.7)}
.nav__cta:hover{background:var(--gold)!important;border-color:var(--gold)!important;color:var(--ink)!important;transform:translateY(-2px)}
.nav__toggle{
  display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;
}
.nav__toggle span{width:26px;height:2.5px;background:var(--cream);border-radius:2px;transition:.3s var(--ease)}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:center;padding:clamp(90px,16vh,160px) var(--pad) 120px;
  overflow:hidden;isolation:isolate;
}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 58%;transform:scale(1.08);animation:slowzoom 20s ease-out forwards}
@keyframes slowzoom{to{transform:scale(1)}}
.hero__overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 80% at 20% 20%,rgba(13,13,15,.35),transparent 60%),
    linear-gradient(180deg,rgba(13,13,15,.55) 0%,rgba(13,13,15,.35) 35%,rgba(13,13,15,.82) 85%,var(--ink) 100%);
}
.hero__grain{
  position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;pointer-events:none;
  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='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
}
.hero__content{max-width:var(--maxw);margin:0 auto;width:100%;position:relative}
.hero__eyebrow{
  font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.3em;
  font-weight:600;color:var(--gold);margin-bottom:1.2rem;font-size:.95rem;
}
.hero__title{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(2.9rem,9vw,7.2rem);line-height:.92;letter-spacing:1px;
  text-transform:uppercase;text-shadow:0 8px 40px rgba(0,0,0,.45);
}
.hero__title span{display:block}
.hero__title--accent{color:var(--amber)}
.hero__sub{max-width:54ch;margin:1.8rem 0 0;font-size:clamp(1.02rem,1.6vw,1.22rem);color:var(--cream-2)}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.hero__scroll{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  width:26px;height:44px;border:2px solid rgba(245,239,227,.5);border-radius:20px;
  display:flex;justify-content:center;padding-top:8px;
}
.hero__scroll span{width:4px;height:9px;border-radius:4px;background:var(--amber);animation:scrolldot 1.6s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%{opacity:0;transform:translateY(14px)}}

/* ---------- Marquee ---------- */
.marquee{
  background:var(--amber);color:var(--ink);overflow:hidden;white-space:nowrap;
  border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);
}
.marquee__track{display:inline-flex;align-items:center;gap:1.6rem;padding:.7rem 0;animation:ticker 38s linear infinite}
.marquee span{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.3rem,3vw,2.1rem);letter-spacing:1px}
.marquee i{font-style:normal;opacity:.6;font-size:1.1rem}

/* ---------- Story ---------- */
.story{background:var(--ink)}
.story__grid{
  max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(36px,6vw,80px);align-items:center;
}
.story__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 40px 80px -30px rgba(0,0,0,.8)}
.story__media img{width:100%;aspect-ratio:4/3.4;object-fit:cover;transition:transform .8s var(--ease)}
.story__media:hover img{transform:scale(1.05)}
.story__badge{
  position:absolute;bottom:22px;left:22px;background:var(--amber);color:var(--ink);
  border-radius:14px;padding:.7rem 1.1rem;text-align:center;line-height:1;
  box-shadow:0 14px 30px -10px rgba(0,0,0,.6);
}
.story__badge strong{display:block;font-family:var(--font-cond);font-weight:600;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}
.story__badge span{font-family:var(--font-display);font-size:1.9rem}
.story__text h2{margin-bottom:1.3rem}
.story__text p{color:var(--cream-2);margin-bottom:1.1rem;max-width:52ch}
.story__stats{display:flex;gap:clamp(20px,4vw,48px);margin-top:2.2rem;flex-wrap:wrap}
.stat strong{display:block;font-family:var(--font-display);font-size:clamp(2rem,4vw,2.8rem);color:var(--amber);line-height:1}
.stat span{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:.9rem}

/* ---------- Beers ---------- */
.beers{background:linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 100%)}
.seasonals{background:var(--ink-2)}
.beer-grid{
  max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,32px);
}
.beer-grid--season{grid-template-columns:repeat(3,1fr)}

.beer-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--ink-3);border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s;
  will-change:transform;
}
.beer-card:hover{transform:translateY(-8px);border-color:transparent;box-shadow:0 30px 60px -24px rgba(0,0,0,.85)}
.beer-card__media{
  position:relative;aspect-ratio:1/1;overflow:hidden;
  background:var(--c2);
}
.beer-card__media::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 50%,rgba(13,13,15,.5) 100%);
}
.beer-card__media img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s var(--ease);
}
.beer-card:hover .beer-card__media img{transform:scale(1.06)}
.beer-card:hover{box-shadow:0 32px 64px -26px color-mix(in srgb,var(--c1) 55%,#000)}

.beer-card__body{padding:22px 22px 26px;flex:1;display:flex;flex-direction:column}
.beer-card__top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.beer-card__top h3{font-family:var(--font-cond);font-weight:700;text-transform:uppercase;font-size:1.4rem;letter-spacing:.02em;line-height:1.05}
.abv{
  flex-shrink:0;font-family:var(--font-cond);font-weight:700;font-size:.8rem;letter-spacing:.05em;
  background:var(--amber);color:var(--ink);padding:.2em .6em;border-radius:7px;
}
.beer-card__style{color:var(--amber);font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.12em;font-size:.84rem;font-weight:600;margin:.4rem 0 .7rem}
.beer-card__notes{color:var(--muted);font-size:.96rem;line-height:1.55}

.ribbon{
  position:absolute;top:14px;left:14px;z-index:3;
  background:var(--ink);color:var(--gold);font-family:var(--font-cond);font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;
  padding:.35em .8em;border-radius:100px;border:1px solid var(--line);
}

/* ---------- Beer Quiz ---------- */
.quiz{background:var(--ink)}
.quiz__card{
  max-width:720px;margin:0 auto;background:var(--ink-3);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:clamp(26px,4vw,48px);
  box-shadow:0 40px 80px -40px rgba(0,0,0,.85);position:relative;overflow:hidden;
}
.quiz__card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:5px;
  background:linear-gradient(90deg,#2456a6,#0b6e3b,#f5a623,#d81e7a,#9b2fae);
}
.quiz__screen{text-align:center}
.quiz__screen.is-hidden{display:none}
.quiz__emoji{font-size:3rem;margin-bottom:.6rem}
.quiz__screen h3{font-family:var(--font-cond);font-weight:700;text-transform:uppercase;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:.02em;margin-bottom:.6rem;line-height:1.1}
.quiz__screen>p{color:var(--muted);margin-bottom:1.6rem;font-size:1.05rem}

/* progress */
.quiz__progress{height:7px;border-radius:20px;background:var(--ink);overflow:hidden;margin-bottom:1.1rem}
.quiz__progress span{display:block;height:100%;width:0;background:var(--amber);border-radius:20px;transition:width .4s var(--ease)}
.quiz__count{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.18em;font-size:.8rem;color:var(--amber);margin-bottom:.5rem}
.quiz__q{margin-bottom:1.4rem!important;color:var(--cream)}

.quiz__options{display:grid;gap:.7rem}
.quiz__opt{
  width:100%;text-align:left;cursor:pointer;
  background:var(--ink-2);border:1.5px solid var(--line);border-radius:14px;
  color:var(--cream);font-family:var(--font-body);font-size:1.02rem;font-weight:500;
  padding:1rem 1.2rem;display:flex;align-items:center;gap:.8rem;
  transition:border-color .2s,background .2s,transform .15s var(--ease);
}
.quiz__opt:hover{border-color:var(--amber);background:#23232a;transform:translateX(4px)}
.quiz__opt .quiz__dot{flex:0 0 auto;width:22px;height:22px;border-radius:50%;border:2px solid var(--muted);transition:.2s}
.quiz__opt:hover .quiz__dot{border-color:var(--amber);background:var(--amber)}
.quiz__back{background:none;border:0;color:var(--muted);cursor:pointer;margin-top:1.2rem;font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.08em;font-size:.9rem}
.quiz__back:hover{color:var(--cream)}
.quiz__back.is-hidden{display:none}

/* result */
.quiz__result-label{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.2em;color:var(--amber);font-size:.9rem;margin-bottom:1rem}
.quiz__result-media{width:230px;height:230px;margin:0 auto 1.2rem;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 24px 48px -22px rgba(0,0,0,.8)}
.quiz__result-media img{width:100%;height:100%;object-fit:cover;display:block}
#quizResultName{font-family:var(--font-display);font-weight:400;font-size:clamp(1.8rem,4vw,2.6rem);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.3rem}
.quiz__result-style{color:var(--amber);font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.12em;font-size:.9rem;margin-bottom:1rem}
.quiz__result-blurb{color:var(--cream-2);font-size:1.06rem;max-width:46ch;margin:0 auto 1.8rem}
.quiz__result-actions{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}
.quiz__fb{background:#1877f2;color:#fff;border-color:#1877f2}
.quiz__fb:hover{background:#0f63d6;border-color:#0f63d6;color:#fff;transform:translateY(-3px)}

/* ---------- More to Drink ---------- */
.more{background:linear-gradient(180deg,var(--ink-2) 0%,var(--ink) 100%)}
.more__grid{
  max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,24px);align-items:stretch;
}
.more-card{
  background:var(--ink-3);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem 1.5rem;display:flex;flex-direction:column;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.more-card:hover{transform:translateY(-6px);border-color:var(--amber);box-shadow:0 26px 52px -28px rgba(0,0,0,.8)}
.more-card__icon{font-size:2.2rem;line-height:1;margin-bottom:.8rem}
.more-card h3{font-family:var(--font-cond);font-weight:700;text-transform:uppercase;letter-spacing:.03em;font-size:1.45rem;margin-bottom:.7rem}
.more-card__list{color:var(--cream-2);font-size:.98rem;line-height:1.55}
.more-card__note{margin-top:auto;padding-top:1rem;color:var(--muted);font-size:.92rem}
.more-card__note strong{color:var(--gold)}
.more-card--feature{border-color:rgba(245,166,35,.4);background:linear-gradient(180deg,rgba(245,166,35,.08),var(--ink-3) 60%)}
.more__foot{max-width:var(--maxw);margin:clamp(28px,4vw,42px) auto 0;text-align:center;color:var(--muted);font-size:1rem;font-style:italic}
@media (max-width:880px){.more__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.more__grid{grid-template-columns:1fr}}

/* ---------- Gallery ---------- */
.gallery{background:var(--ink)}
.gallery__grid{
  max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:clamp(12px,1.4vw,18px);
  grid-auto-flow:dense;
}
.gtile{position:relative;overflow:hidden;border-radius:var(--radius);margin:0;border:1px solid var(--line)}
.gtile img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.gtile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(13,13,15,.78));opacity:.9;transition:opacity .4s}
.gtile figcaption{
  position:absolute;left:16px;bottom:14px;z-index:2;
  font-family:var(--font-cond);font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  font-size:1.05rem;color:var(--cream);text-shadow:0 2px 12px rgba(0,0,0,.6);
  transform:translateY(4px);transition:transform .4s var(--ease),color .3s;
}
.gtile:hover img{transform:scale(1.08)}
.gtile:hover figcaption{transform:translateY(0);color:var(--gold)}
.gtile--tall{grid-row:span 2}
.gtile--wide{grid-column:span 2}
@media (max-width:760px){
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .gtile--wide{grid-column:span 2}
  .gtile--tall{grid-row:span 2}
}

/* ---------- Visit ---------- */
.visit{background:linear-gradient(180deg,var(--ink-2) 0%,var(--ink) 100%)}
.visit__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,72px);align-items:center}
.visit__info h2{margin:.6rem 0 1.1rem}
.visit__info>p{color:var(--cream-2);max-width:46ch;margin-bottom:1.8rem}
.hours{background:var(--ink-3);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.6rem;margin-bottom:1.6rem}
.hours h3{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.12em;font-size:1rem;color:var(--amber);margin-bottom:.8rem}
.hours ul{list-style:none}
.hours li{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--line);font-family:var(--font-cond);font-size:1.08rem;letter-spacing:.01em}
.hours li:last-child{border-bottom:0}
.hours li span{color:var(--cream-2)}
.hours li em{color:var(--gold)}
.visit__contact{display:flex;gap:2.4rem;margin-bottom:1.6rem}
.visit__contact h4{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.12em;font-size:.82rem;color:var(--muted);margin-bottom:.3rem}
.visit__contact p{font-size:1.05rem;color:var(--cream)}
.visit__contact a:hover{color:var(--amber)}
.perks{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.8rem}
.perks span{background:var(--ink-3);border:1px solid var(--line);border-radius:100px;padding:.45em 1em;font-family:var(--font-cond);font-size:.95rem;letter-spacing:.03em}
.visit__map{display:grid;gap:18px}
.visit__photo{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:var(--radius);box-shadow:0 30px 60px -28px rgba(0,0,0,.8)}
.visit__map iframe{width:100%;height:260px;border:0;border-radius:var(--radius);display:block}
.mapfacade{
  position:relative;height:260px;border-radius:var(--radius);cursor:pointer;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;
  background:linear-gradient(150deg,var(--ink-3),var(--ink-2));border:1px solid var(--line);
  text-align:center;padding:1rem;transition:border-color .3s,transform .3s var(--ease);
}
.mapfacade::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background-image:
    linear-gradient(rgba(245,166,35,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(245,166,35,.08) 1px,transparent 1px);
  background-size:26px 26px;
}
.mapfacade:hover{border-color:var(--amber)}
.mapfacade>*{position:relative;z-index:1}
.mapfacade__pin{font-size:2.4rem}
.mapfacade__txt{font-family:var(--font-cond);font-weight:600;font-size:1.1rem;color:var(--cream);letter-spacing:.02em}
.mapfacade__hint{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;color:var(--amber)}

/* ---------- Schedule (This Week) ---------- */
.schedule{background:linear-gradient(180deg,var(--ink-2) 0%,var(--ink) 100%)}
.schedule__grid{
  max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(5,1fr);gap:clamp(14px,1.6vw,20px);align-items:start;
}
.day{
  background:var(--ink-3);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;height:100%;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.day:hover{transform:translateY(-6px);border-color:var(--amber);box-shadow:0 24px 50px -26px rgba(0,0,0,.8)}
.day__head{
  display:flex;align-items:baseline;justify-content:space-between;
  padding:.9rem 1.1rem;background:rgba(245,166,35,.1);border-bottom:1px solid var(--line);
}
.day__name{font-family:var(--font-display);text-transform:uppercase;font-size:1.5rem;color:var(--cream)}
.day__date{font-family:var(--font-cond);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--amber);font-size:.9rem}
.day__list{list-style:none;padding:.5rem .7rem .9rem;display:flex;flex-direction:column;gap:.5rem}
.ev{display:flex;flex-direction:column;gap:.18rem;padding:.7rem .65rem;border-radius:12px;background:var(--ink-2);border-left:3px solid var(--amber)}
.ev--music{border-left-color:#d81e7a}
.ev--food{border-left-color:#f5a623}
.ev--market{border-left-color:#199a7c}
.ev--tap{border-left-color:#2456a6}
.ev__tag{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:700;color:var(--muted)}
.ev--music .ev__tag{color:#ff5aa6}
.ev--food .ev__tag{color:var(--gold)}
.ev--market .ev__tag{color:#3fd9b4}
.ev--tap .ev__tag{color:#6f9fe0}
.ev__name{font-weight:600;font-size:.98rem;line-height:1.25;color:var(--cream)}
.ev__time{font-family:var(--font-cond);font-size:.9rem;color:var(--muted);letter-spacing:.02em}
.schedule__cta{max-width:var(--maxw);margin:clamp(34px,5vw,52px) auto 0;text-align:center}

@media (max-width:980px){
  .schedule__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .schedule__grid{grid-template-columns:1fr}
}

/* ---------- Events ---------- */
.events{position:relative;padding:clamp(90px,16vw,180px) var(--pad);overflow:hidden;isolation:isolate;text-align:center}
.events__bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;transform:scale(1.05)}
.events__overlay{position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(13,13,15,.7),rgba(13,13,15,.55) 50%,rgba(13,13,15,.9))}
.events__content{max-width:680px;margin:0 auto}
.events__content h2{margin:.5rem 0 1.1rem}
.events__content p{color:var(--cream-2);font-size:1.1rem;margin-bottom:2rem}

/* ---------- Shop / Ship CTA ---------- */
.shopcta{
  position:relative;color:var(--ink);padding:clamp(60px,9vw,110px) var(--pad);overflow:hidden;
  background:radial-gradient(120% 140% at 0% 0%,var(--gold) 0%,var(--amber) 45%,var(--amber-deep) 100%);
}
.shopcta::before{
  content:"";position:absolute;inset:0;opacity:.12;mix-blend-mode:multiply;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.shopcta__inner{max-width:var(--maxw);margin:0 auto;position:relative}
.shopcta__text{max-width:760px}
.shopcta__eyebrow{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.26em;font-weight:700;font-size:.85rem;color:#5a3d00;margin-bottom:1rem}
.shopcta h2{color:var(--ink);font-size:clamp(2.1rem,5.4vw,3.8rem)}
.shopcta__lead{font-size:clamp(1.05rem,1.6vw,1.22rem);margin-top:1.1rem;max-width:56ch;color:#3a2a08;font-weight:500}
.shipbenefits{
  list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:2.2rem 0;
}
.shipbenefits li{
  background:rgba(13,13,15,.07);border:1.5px solid rgba(13,13,15,.16);border-radius:14px;
  padding:1rem .9rem;text-align:center;
}
.shipbenefits strong{display:block;font-family:var(--font-display);font-size:1.7rem;line-height:1;color:var(--ink)}
.shipbenefits span{display:block;margin-top:.4rem;font-family:var(--font-cond);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;color:#4a350a}
.shopcta__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}
.shopcta__buy{background:var(--ink);color:var(--gold);box-shadow:0 16px 34px -12px rgba(0,0,0,.55)}
.shopcta__buy:hover{background:var(--ink-2);color:var(--gold);transform:translateY(-3px) scale(1.02);box-shadow:0 22px 44px -14px rgba(0,0,0,.7)}
.shopcta__merch{background:transparent;color:var(--ink);border-color:rgba(13,13,15,.5)}
.shopcta__merch:hover{background:var(--ink);color:var(--cream);transform:translateY(-3px)}
.shopcta__fine{margin-top:1.4rem;font-size:.86rem;color:#5a3d00;font-weight:600}
@media (max-width:680px){
  .shipbenefits{grid-template-columns:repeat(2,1fr)}
  .shopcta__buy,.shopcta__merch{width:100%}
}

/* ---------- Footer ---------- */
.footer{background:var(--ink);border-top:1px solid var(--line);padding:clamp(54px,7vw,80px) var(--pad) 0}
.footer__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,48px)}
.footer__brand img{height:64px;margin-bottom:1rem}
.footer__brand p{color:var(--muted);max-width:30ch;margin-bottom:1.2rem}
.footer__social{display:flex;gap:1rem}
.footer__social a{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.08em;font-size:.9rem;color:var(--cream);position:relative}
.footer__social a:hover{color:var(--amber)}
.footer__col h4{font-family:var(--font-cond);text-transform:uppercase;letter-spacing:.14em;font-size:.85rem;color:var(--amber);margin-bottom:1rem}
.footer__col a,.footer__col p{display:block;color:var(--muted);margin-bottom:.6rem;font-size:.98rem}
.footer__col a:hover{color:var(--cream)}
.footer__bar{
  max-width:var(--maxw);margin:clamp(40px,5vw,60px) auto 0;padding:1.6rem 0;
  border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  color:var(--muted);font-size:.86rem;
}
.footer__legal{color:#6f6a61}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__media img{animation:none;transform:none}
  .topbar__track,.marquee__track{animation:none}
  *{scroll-behavior:auto}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .story__grid,.visit__grid{grid-template-columns:1fr}
  .story__media{order:-1}
  .beer-grid,.beer-grid--season{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav__toggle{display:flex}
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);
    flex-direction:column;align-items:flex-start;gap:1.4rem;
    background:rgba(13,13,15,.97);backdrop-filter:blur(16px);
    padding:6rem 2rem 2rem;transform:translateX(100%);
    transition:transform .4s var(--ease);box-shadow:-30px 0 60px rgba(0,0,0,.5);
  }
  .nav__links.open{transform:translateX(0)}
  .nav__links a{font-size:1.3rem}
  .nav__cta{margin-top:.5rem}
}
@media (max-width:560px){
  .beer-grid,.beer-grid--season,.footer__inner{grid-template-columns:1fr}
  .visit__contact{flex-direction:column;gap:1rem}
  .footer__bar{flex-direction:column}
  .shopcta__inner{flex-direction:column;align-items:flex-start}
}
