/* ============================================================
   OAK & EMBER CATERING — Candlelit Fire / Vintage Broadside
   Warm-organic Americana letterpress. Drifting embers + film grain.
   Display: DM Serif Display (+italic) · Body: Spectral
   Palette: char #2A1410 · brick #7A2E1D · gold #E0A33E · linen #F0E5D2
   ============================================================ */

:root{
  --char:#2A1410;     /* charred-wood (ink/base) */
  --brick:#7A2E1D;    /* ember */
  --gold:#E0A33E;     /* flame-gold */
  --linen:#F0E5D2;    /* paper */

  --char-2:#3C2018;
  --char-3:#1C0D0A;
  --linen-2:#E7D9C0;
  --linen-3:#DCCBAC;
  --rule:#C9B48E;            /* hairline on linen */
  --rule-ink:rgba(240,229,210,.22); /* hairline on char */
  --muted:#6E4B38;          /* warm muted on linen */
  --muted-ink:#C9A98C;      /* warm muted on char */
  --gold-soft:rgba(224,163,62,.14);
  --brick-soft:rgba(122,46,29,.10);

  --serif:'DM Serif Display',Georgia,'Times New Roman',serif;
  --body:'Spectral',Georgia,serif;

  --ease:cubic-bezier(.2,.6,.2,1);
  --gutter:24px;
  --maxw:1180px;
  --hdr-h:88px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden}
body{
  margin:0;
  background:var(--linen);
  color:var(--char);
  font-family:var(--body);
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
}
/* sitewide film grain — fixed, ambient, the ONE signature texture */
body::after{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.05;
  mix-blend-mode:multiply;
  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='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
img,svg{display:block;max-width:100%}
h1,h2,h3,h4{margin:0;font-family:var(--serif);font-weight:400;line-height:1.02;overflow-wrap:normal;word-break:normal;hyphens:none;-webkit-hyphens:none;letter-spacing:.005em}
p{margin:0}
::selection{background:var(--brick);color:var(--linen)}

a:focus-visible,button:focus-visible,summary:focus-visible,
input:focus-visible,textarea:focus-visible,select:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid var(--brick);
  outline-offset:3px;
}
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--char);color:var(--linen);padding:12px 18px;
  font-family:var(--body);
}
.skip-link:focus{left:12px;top:12px}

/* ---------- Layout shell ---------- */
.shell{width:min(var(--maxw),calc(100% - (var(--gutter)*2)));margin-inline:auto}
.flow > * + *{margin-top:1.1rem}

/* ---------- letterpress label / small-caps voice ---------- */
.smallcaps{
  font-variant:small-caps;
  letter-spacing:.08em;
}
.kicker{
  display:inline-flex;align-items:center;gap:.65em;
  font-family:var(--body);font-weight:600;
  text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;color:var(--brick);
}
.kicker::before,.kicker::after{
  content:"";width:18px;height:1px;background:var(--brick);opacity:.6;
}
.kicker.center::before,.kicker.center::after{width:30px}
.sec-no{
  font-family:var(--body);font-weight:600;letter-spacing:.18em;
  font-size:.74rem;color:var(--brick);text-transform:uppercase;
}

/* the letterpress headline treatment — subtle deboss (tuned for linen) */
.press{
  text-shadow:0 1px 0 rgba(240,229,210,.5), 0 -1px 0 rgba(28,13,10,.18);
}
/* on dark surfaces the light deboss reads as a glowy halo — flip the
   shadow so the deboss comes from the dark side, not a linen highlight */
.section.char .press,
.hero .press,
.cta-band .press,
.contact-card .press{
  text-shadow:0 1px 0 rgba(28,13,10,.55), 0 -1px 0 rgba(240,229,210,.06);
}

/* ornamental fleuron divider */
.fleuron{
  display:flex;align-items:center;justify-content:center;gap:14px;
  color:var(--brick);
}
.fleuron::before,.fleuron::after{
  content:"";height:1px;flex:1;max-width:120px;
  background:linear-gradient(90deg,transparent,var(--rule));
}
.fleuron::after{background:linear-gradient(270deg,transparent,var(--rule))}
.fleuron svg{width:22px;height:22px;opacity:.85}

/* double-rule frame utility */
.dframe{
  border:1px solid var(--char);
  box-shadow:0 0 0 1px var(--linen), 0 0 0 4px var(--char);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.7em;
  min-height:54px;padding:0 28px;
  font-family:var(--body);font-weight:600;
  text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;
  border:1px solid var(--char);
  background:var(--char);color:var(--linen);
  cursor:pointer;position:relative;
  transition:background .3s var(--ease),color .3s var(--ease),transform .15s var(--ease);
}
.btn:hover{background:var(--brick);border-color:var(--brick);color:var(--linen)}
.btn:active{transform:translateY(1px)}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn-gold{background:var(--gold);border-color:var(--gold);color:var(--char-3)}
.btn-gold:hover{background:var(--char);border-color:var(--char);color:var(--linen)}
.btn-ghost{background:transparent;color:var(--char)}
.btn-ghost:hover{background:var(--char);color:var(--linen)}
/* ghost button on a dark (char/ember) surface — reusable token */
.btn-ghost-on-char{background:transparent;color:var(--linen);border-color:rgba(224,163,62,.6)}
.btn-ghost-on-char:hover{background:var(--gold);border-color:var(--gold);color:var(--char-3)}
.btn-on-char{background:var(--gold);border-color:var(--gold);color:var(--char-3)}
.btn-on-char:hover{background:var(--linen);border-color:var(--linen);color:var(--char-3)}
.btn-block{width:100%}

/* drop cap */
.dropcap::first-letter{
  font-family:var(--serif);
  float:left;
  font-size:4.2em;
  line-height:.78;
  padding:.05em .12em 0 0;
  color:var(--brick);
}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}

/* =========================================================
   HEADER — sticky condensing
   ========================================================= */
.site-head{
  position:sticky;top:0;z-index:60;
  background:rgba(240,229,210,.86);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--rule);
  transition:box-shadow .3s var(--ease),background .3s var(--ease);
}
.site-head.shrink{
  background:rgba(240,229,210,.95);
  box-shadow:0 6px 24px -16px rgba(28,13,10,.5);
}
.head-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:18px;height:var(--hdr-h);
  transition:height .3s var(--ease);
}
.site-head.shrink .head-inner{height:68px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand .mark{flex:none}
.brand .mark svg{width:38px;height:38px;transition:width .3s var(--ease),height .3s var(--ease)}
.site-head.shrink .brand .mark svg{width:32px;height:32px}
.brand .wordmark{display:flex;flex-direction:column;line-height:1;min-width:0}
.brand .wordmark b{
  font-family:var(--serif);font-weight:400;font-size:1.28rem;
  letter-spacing:.01em;white-space:nowrap;
}
.brand .wordmark span{
  font-family:var(--body);font-weight:600;font-size:.6rem;
  text-transform:uppercase;letter-spacing:.34em;color:var(--brick);
  margin-top:3px;white-space:nowrap;
}
.nav-desk{display:flex;align-items:center;gap:30px}
.nav-desk a{
  font-family:var(--body);font-weight:600;font-size:.82rem;
  text-transform:uppercase;letter-spacing:.12em;color:var(--char);
  position:relative;padding:6px 0;
}
.nav-desk a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;
  background:var(--brick);transition:right .3s var(--ease);
}
.nav-desk a:hover::after,.nav-desk a[aria-current="page"]::after{right:0}
.nav-desk a[aria-current="page"]{color:var(--brick)}
.head-cta{display:flex;align-items:center;gap:14px}
.head-cta .btn{min-height:44px;padding:0 20px;font-size:.72rem}

.burger{
  display:none;width:46px;height:46px;
  border:1px solid var(--char);background:transparent;
  cursor:pointer;align-items:center;justify-content:center;flex:none;
}
.burger span{display:block;width:20px;height:2px;background:var(--char);position:relative;transition:transform .3s var(--ease),opacity .2s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--char);transition:transform .3s var(--ease)}
.burger span::before{top:-6px}.burger span::after{top:6px}
.burger[aria-expanded="true"] span{background:transparent}
.burger[aria-expanded="true"] span::before{transform:translateY(6px) rotate(45deg)}
.burger[aria-expanded="true"] span::after{transform:translateY(-6px) rotate(-45deg)}

/* mobile drawer */
.mobile-nav{
  position:fixed;inset:0;z-index:55;
  background:var(--char);color:var(--linen);
  transform:translateY(-100%);
  transition:transform .42s var(--ease);
  display:flex;flex-direction:column;
  padding:calc(var(--hdr-h) + 20px) var(--gutter) 40px;
  visibility:hidden;
}
.mobile-nav.open{transform:none;visibility:visible}
.mobile-nav a{
  font-family:var(--serif);font-size:clamp(1.8rem,7vw,2.6rem);
  padding:.45rem 0;border-bottom:1px solid var(--rule-ink);color:var(--linen);
}
.mobile-nav a:last-of-type{border-bottom:none}
.mobile-nav .m-foot{margin-top:auto;color:var(--muted-ink);font-size:.9rem}
.mobile-nav .m-foot a{font-family:var(--body);font-size:1rem;border:none;padding:0;color:var(--gold)}
body.menu-lock{overflow:hidden}

/* =========================================================
   HERO — POSTER / MENU BROADSIDE (centered, formal)
   ========================================================= */
.hero{
  position:relative;
  background:
    radial-gradient(120% 80% at 50% 120%, rgba(122,46,29,.55), transparent 60%),
    linear-gradient(180deg,var(--char-3),var(--char) 55%, var(--char-2));
  color:var(--linen);
  overflow:hidden;
  isolation:isolate;
}
/* ember grain glowing up from the bottom edge */
.hero .ember-layer{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  opacity:var(--ember,.5);
  transition:opacity .6s linear;
}
.hero .ember-grain{
  position:absolute;left:0;right:0;bottom:0;height:62%;
  background:
    radial-gradient(80% 120% at 50% 130%, rgba(224,163,62,.40), transparent 62%);
  mix-blend-mode:screen;
}
.hero .ember-noise{position:absolute;inset:0;width:100%;height:100%}
.hero .sparks{position:absolute;inset:0;z-index:1;pointer-events:none}
.spark{
  position:absolute;bottom:-12px;width:3px;height:3px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 6px 1px rgba(224,163,62,.8);
  opacity:0;
  animation:rise var(--dur,9s) ease-in infinite;
  animation-delay:var(--del,0s);
}
@keyframes rise{
  0%{transform:translateY(0) translateX(0);opacity:0}
  12%{opacity:.9}
  70%{opacity:.7}
  100%{transform:translateY(-78vh) translateX(var(--drift,14px));opacity:0}
}

.hero-broadside{
  position:relative;z-index:2;
  text-align:center;
  padding:clamp(56px,9vw,104px) clamp(22px,5vw,72px);
  margin:clamp(28px,5vw,60px) auto;
  /* leave ~18px each side beyond the gutter so the 5px gold ring
     never gets clipped by overflow-x:hidden on small screens */
  width:min(880px,calc(100% - (var(--gutter)*2) - 16px));
  border:1px solid rgba(224,163,62,.55);
  box-shadow:0 0 0 1px var(--char-3), 0 0 0 5px rgba(224,163,62,.5),
             0 40px 90px -50px rgba(0,0,0,.8);
  background:
    linear-gradient(180deg, rgba(28,13,10,.30), rgba(28,13,10,.10));
}
.hero-broadside .estd{
  font-family:var(--body);font-weight:600;text-transform:uppercase;
  letter-spacing:.4em;font-size:.74rem;color:var(--gold);
  margin-bottom:1.4rem;
}
.hero-broadside .estd span{opacity:.55;margin:0 .5em}
.hero-broadside h1{
  font-size:clamp(2.3rem,9vw,5.6rem);
  line-height:.96;color:var(--linen);
  text-shadow:0 2px 30px rgba(224,163,62,.18);
  /* never break "Wood-Fired" mid-word on the smallest phones */
  hyphens:none;-webkit-hyphens:none;
}
.hero-broadside h1 em{font-style:italic;color:var(--gold)}
.hero-broadside .sub{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(1.05rem,3.2vw,1.55rem);
  color:var(--linen);opacity:.92;
  margin-top:1.1rem;
}
.hero-broadside .lede{
  max-width:46ch;margin:1.5rem auto 0;
  color:var(--muted-ink);font-size:1.02rem;
}
.hero-rule{
  display:flex;align-items:center;justify-content:center;gap:16px;
  margin:1.8rem auto 0;color:var(--gold);
}
.hero-rule::before,.hero-rule::after{
  content:"";height:1px;width:min(120px,22vw);
  background:linear-gradient(90deg,transparent,rgba(224,163,62,.7));
}
.hero-rule::after{background:linear-gradient(270deg,transparent,rgba(224,163,62,.7))}
.hero-cta{
  display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:2.2rem;
}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:8px 26px;justify-content:center;
  margin-top:2.2rem;color:var(--muted-ink);
  font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;font-weight:600;
}
.hero-meta span{display:inline-flex;align-items:center;gap:.55em}
.hero-meta i{width:5px;height:5px;border-radius:50%;background:var(--gold);font-style:normal}

/* =========================================================
   SECTIONS
   ========================================================= */
.section{padding:clamp(64px,9vw,128px) 0;position:relative}
.section.char{background:var(--char);color:var(--linen)}
.section.char h1,.section.char h2,.section.char h3{color:var(--linen)}
.sec-head{max-width:640px;margin-bottom:clamp(36px,5vw,60px)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h1,.sec-head h2{
  font-size:clamp(2.1rem,6vw,3.6rem);line-height:1;margin-top:.5rem;
}
.sec-head h1 em,.sec-head h2 em{font-style:italic;color:var(--brick)}
.section.char .sec-head h1 em,.section.char .sec-head h2 em{color:var(--gold)}
.sec-head p{margin-top:1.1rem;color:var(--muted);font-size:1.05rem}
.section.char .sec-head p{color:var(--muted-ink)}

/* ---------- intro / promise strip ---------- */
.promise{
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,5vw,72px);
  align-items:center;
}
.promise > *{min-width:0}
.promise .lead{
  font-family:var(--serif);font-size:clamp(1.5rem,3.6vw,2.3rem);
  line-height:1.18;color:var(--char);
}
.promise .lead em{font-style:italic;color:var(--brick)}
.promise .body p{color:var(--muted)}
.promise .body p + p{margin-top:1rem}
.signoff{
  margin-top:1.6rem;display:flex;align-items:center;gap:14px;
}
.signoff .sig{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--brick)}
.signoff .who{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:600}

/* ---------- pillars (3 wood-fire values) ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.section.char .pillars{background:var(--rule-ink);border-color:var(--rule-ink)}
.pillar{
  background:var(--linen);padding:clamp(28px,4vw,42px);min-width:0;
  position:relative;
}
.section.char .pillar{background:var(--char)}
.pillar .ic{width:46px;height:46px;color:var(--brick);margin-bottom:1.4rem}
.section.char .pillar .ic{color:var(--gold)}
.pillar h3{font-size:1.5rem;line-height:1.05}
.pillar p{margin-top:.7rem;color:var(--muted);font-size:.98rem}
.section.char .pillar p{color:var(--muted-ink)}
.pillar .n{position:absolute;top:18px;right:22px;font-family:var(--serif);font-size:1.1rem;color:var(--rule)}

/* ---------- featured menu preview (broadside card) ---------- */
.menu-preview{
  background:var(--linen-2);
  padding:clamp(32px,5vw,64px);
  position:relative;
}
.menu-card{
  max-width:760px;margin-inline:auto;
  background:var(--linen);
  border:1px solid var(--char);
  box-shadow:0 0 0 1px var(--linen), 0 0 0 4px var(--char),
             0 40px 80px -60px rgba(28,13,10,.6);
  padding:clamp(30px,5vw,56px);
}
.menu-card .mc-head{text-align:center;margin-bottom:1.8rem}
.menu-card .mc-head .top{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--brick);font-weight:600}
.menu-card .mc-head h3{font-size:clamp(1.8rem,5vw,2.6rem);margin:.5rem 0 .2rem}
.menu-card .mc-head .when{font-family:var(--serif);font-style:italic;color:var(--muted)}
.menu-rows{display:flex;flex-direction:column;gap:.2rem}
.mrow{
  display:grid;grid-template-columns:1fr auto;align-items:baseline;
  gap:6px;padding:.7rem 0;border-bottom:1px dotted var(--rule);
}
.mrow:last-child{border-bottom:none}
.mrow .nm{min-width:0}
.mrow .nm b{
  font-family:var(--serif);font-size:1.18rem;font-weight:400;
  font-variant:small-caps;letter-spacing:.04em;
}
.mrow .nm small{display:block;color:var(--muted);font-size:.88rem;font-style:italic;margin-top:1px}
.mrow .pr{font-family:var(--serif);color:var(--brick);font-size:1.12rem;white-space:nowrap}
.menu-card .mc-foot{text-align:center;margin-top:1.8rem}

/* =========================================================
   MENUS PAGE — seasonal tabs
   ========================================================= */
.season-tabs{
  display:flex;flex-wrap:wrap;gap:0;justify-content:center;
  border:1px solid var(--char);max-width:640px;margin:0 auto clamp(36px,5vw,56px);
}
.season-tabs button{
  flex:1 1 25%;min-width:120px;
  padding:16px 10px;background:transparent;border:none;cursor:pointer;
  font-family:var(--body);font-weight:600;text-transform:uppercase;
  letter-spacing:.16em;font-size:.78rem;color:var(--char);
  border-right:1px solid var(--char);
  transition:background .25s var(--ease),color .25s var(--ease);
  position:relative;
}
.season-tabs button:last-child{border-right:none}
.season-tabs button .szn{display:block;font-family:var(--serif);font-size:1.4rem;letter-spacing:.01em;text-transform:none;margin-bottom:2px}
.season-tabs button[aria-selected="true"]{background:var(--char);color:var(--linen)}
.season-tabs button[aria-selected="true"] .szn{color:var(--gold)}
.season-tabs button:hover:not([aria-selected="true"]){background:var(--gold-soft)}

.season-panel{display:none}
.season-panel.active{display:block;animation:fadeUp .5s var(--ease)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.season-intro{text-align:center;max-width:600px;margin:0 auto clamp(32px,5vw,52px)}
.season-intro h2{font-size:clamp(2rem,6vw,3.2rem)}
.season-intro h2 em{font-style:italic;color:var(--brick)}
.season-intro p{margin-top:1rem;color:var(--muted)}

.menu-cols{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);
  max-width:920px;margin-inline:auto;
}
.menu-cols > *{min-width:0}
.menu-group h3{
  font-size:1.5rem;text-align:center;color:var(--brick);
  padding-bottom:.6rem;margin-bottom:1rem;
  border-bottom:2px solid var(--char);position:relative;
}
.menu-group h3 span{
  font-family:var(--body);display:block;font-size:.66rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--muted);margin-top:4px;font-weight:600;
}

/* =========================================================
   GALLERY / EVENTS — dish swatches + lightbox
   ========================================================= */
.event-types{
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,28px);
}
.event-types > *{min-width:0}
.etype{
  border:1px solid var(--rule);background:var(--linen);padding:clamp(24px,3vw,34px);
  position:relative;overflow:hidden;
}
.etype h3{font-size:1.7rem}
.etype .lead-num{font-family:var(--serif);color:var(--rule);font-size:2.4rem;line-height:1;margin-bottom:.5rem}
.etype p{margin-top:.6rem;color:var(--muted);font-size:.96rem}
.etype ul{margin:1rem 0 0;padding:0;list-style:none}
.etype li{padding-left:18px;position:relative;font-size:.94rem;color:var(--muted);margin-top:.35rem}
.etype li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;background:var(--gold);transform:rotate(45deg)}

.gallery{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
.gallery > *{min-width:0}
.gitem{
  position:relative;aspect-ratio:1/1;border:1px solid var(--char);
  cursor:pointer;overflow:hidden;background:var(--char);
  padding:0;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.gitem:hover,.gitem:focus-visible{transform:translateY(-3px);box-shadow:0 18px 36px -22px rgba(28,13,10,.7)}
.gitem svg{width:100%;height:100%}
.gitem .cap{
  position:absolute;left:0;right:0;bottom:0;
  padding:14px 14px 12px;
  background:linear-gradient(0deg,rgba(28,13,10,.92),transparent);
  color:var(--linen);text-align:left;
}
.gitem .cap b{font-family:var(--serif);font-size:1.05rem;font-weight:400;display:block;line-height:1.1}
.gitem .cap small{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.gitem.tall{grid-row:span 2;aspect-ratio:auto}
.gitem.wide{grid-column:span 2;aspect-ratio:2/1}

/* lightbox */
.lightbox{
  position:fixed;inset:0;z-index:120;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,48px);
  background:rgba(20,9,7,.9);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;
}
.lightbox.open{opacity:1;visibility:visible}
.lb-frame{
  width:min(640px,100%);background:var(--linen);
  border:1px solid var(--gold);
  box-shadow:0 0 0 4px var(--char-3), 0 40px 90px -40px rgba(0,0,0,.8);
  transform:translateY(14px) scale(.98);transition:transform .35s var(--ease);
}
.lightbox.open .lb-frame{transform:none}
.lb-swatch{aspect-ratio:16/10;background:var(--char);border-bottom:1px solid var(--gold)}
.lb-swatch svg{width:100%;height:100%}
.lb-body{padding:clamp(22px,4vw,34px);text-align:center}
.lb-body .top{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--brick);font-weight:600}
.lb-body h3{font-size:clamp(1.6rem,5vw,2.3rem);margin:.4rem 0}
.lb-body p{color:var(--muted);max-width:46ch;margin:.6rem auto 0}
.lb-close{
  position:absolute;top:clamp(14px,3vw,28px);right:clamp(14px,3vw,28px);
  width:50px;height:50px;border:1px solid var(--gold);background:rgba(28,13,10,.6);
  color:var(--linen);cursor:pointer;font-size:1.3rem;line-height:1;
  display:flex;align-items:center;justify-content:center;
}
.lb-close:hover{background:var(--brick);border-color:var(--brick)}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;border:1px solid var(--gold);background:rgba(28,13,10,.55);
  color:var(--linen);cursor:pointer;font-size:1.4rem;
  display:flex;align-items:center;justify-content:center;
}
.lb-nav:hover{background:var(--brick);border-color:var(--brick)}
.lb-prev{left:clamp(8px,2vw,24px)}
.lb-next{right:clamp(8px,2vw,24px)}

/* =========================================================
   TESTIMONIAL CAROUSEL
   ========================================================= */
.tcar{position:relative;max-width:780px;margin-inline:auto;overflow:hidden}
.tcar .rail{display:flex;transition:transform .6s var(--ease)}
.tcar .slide{flex:0 0 100%;min-width:0;padding:0 clamp(4px,3vw,40px);text-align:center}
.tcar .stars{color:var(--gold);letter-spacing:.3em;font-size:1.1rem;margin-bottom:1rem}
.tcar blockquote{
  margin:0;font-family:var(--serif);font-size:clamp(1.4rem,4vw,2.1rem);
  line-height:1.25;color:var(--linen);
}
.section.char .tcar blockquote{color:var(--linen)}
.tcar blockquote em{font-style:italic;color:var(--gold)}
.tcar .who{margin-top:1.4rem;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--muted-ink)}
.tcar .who b{color:var(--gold);font-weight:600}
.tcar-ctrl{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:2rem}
.tcar-ctrl button{
  width:48px;height:48px;border:1px solid var(--rule-ink);background:transparent;color:var(--linen);
  cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;
  transition:background .25s var(--ease),border-color .25s;
}
.tcar-ctrl button:hover{background:var(--gold);border-color:var(--gold);color:var(--char-3)}
.tcar-pause{font-size:.7rem;letter-spacing:.04em}
.tcar-pause .ico-play{display:none}
.tcar-pause .ico-pause{display:inline}
.tcar.is-paused .tcar-pause .ico-play{display:inline}
.tcar.is-paused .tcar-pause .ico-pause{display:none}
.tcar-dots{display:flex;gap:9px;align-items:center}
.tcar-dots button{
  width:9px;height:9px;padding:0;border-radius:50%;border:1px solid var(--muted-ink);
  background:transparent;cursor:pointer;transition:background .25s,border-color .25s;
}
.tcar-dots button[aria-current="true"]{background:var(--gold);border-color:var(--gold)}

/* =========================================================
   FAQ
   ========================================================= */
.faq{max-width:780px;margin-inline:auto}
.faq details{border-bottom:1px solid var(--rule);padding:0}
.faq details:first-child{border-top:1px solid var(--rule)}
.faq summary{
  list-style:none;cursor:pointer;padding:1.4rem 48px 1.4rem 0;position:relative;
  font-family:var(--serif);font-size:clamp(1.15rem,3vw,1.5rem);line-height:1.2;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-family:var(--serif);font-size:1.7rem;color:var(--brick);transition:transform .3s var(--ease);
}
.faq details[open] summary::after{content:"–"}
.faq .faq-a{padding:0 48px 1.5rem 0;color:var(--muted)}

/* =========================================================
   STORY / TIMELINE
   ========================================================= */
.story-lead{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center;
}
.story-lead > *{min-width:0}
.story-portrait{
  border:1px solid var(--char);
  box-shadow:0 0 0 1px var(--linen),0 0 0 4px var(--char);
  background:var(--char);aspect-ratio:4/5;
}
.story-portrait svg{width:100%;height:100%}

.timeline{max-width:760px;margin-inline:auto;position:relative;padding-left:30px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:var(--rule)}
.tl-item{position:relative;padding-bottom:clamp(28px,4vw,44px)}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{
  content:"";position:absolute;left:-30px;top:6px;width:14px;height:14px;
  border-radius:50%;background:var(--brick);box-shadow:0 0 0 4px var(--linen),0 0 0 5px var(--rule);
}
.tl-item .yr{font-family:var(--serif);color:var(--brick);font-size:1.6rem;line-height:1}
.tl-item h3{font-size:1.4rem;margin:.3rem 0 .5rem}
.tl-item p{color:var(--muted);font-size:1rem}

.stat-band{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule-ink);
  border-top:1px solid var(--rule-ink);border-bottom:1px solid var(--rule-ink);
}
.stat-band > *{min-width:0}
.stat{background:var(--char);padding:clamp(28px,4vw,44px) clamp(18px,3vw,28px);text-align:center}
.stat .num{font-family:var(--serif);font-size:clamp(2.4rem,6vw,3.6rem);color:var(--gold);line-height:1}
.stat .lbl{margin-top:.5rem;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-ink);font-weight:600}

/* values list on story */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,40px)}
.values > *{min-width:0}
.value{display:flex;gap:18px}
.value .vic{flex:none;width:42px;height:42px;color:var(--brick)}
.section.char .value .vic{color:var(--gold)}
.value h3{font-size:1.3rem}
.value p{margin-top:.4rem;color:var(--muted);font-size:.96rem}
.section.char .value p{color:var(--muted-ink)}

/* =========================================================
   INQUIRE / CONTACT
   ========================================================= */
.inquire-grid{
  display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(32px,5vw,72px);align-items:start;
}
.inquire-grid > *{min-width:0}
.contact-card{
  background:var(--char);color:var(--linen);padding:clamp(28px,4vw,44px);
  position:relative;
}
.contact-card h3{color:var(--linen);font-size:1.7rem}
.contact-list{margin-top:1.8rem;display:flex;flex-direction:column;gap:1.3rem}
.cl-row{display:flex;gap:14px;align-items:flex-start}
.cl-row .cic{flex:none;width:24px;height:24px;color:var(--gold);margin-top:3px}
.cl-row .lbl{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-ink);font-weight:600}
.cl-row .val{font-size:1.05rem;color:var(--linen)}
.cl-row .val a:hover{color:var(--gold)}
.hours-table{margin-top:1.8rem;border-top:1px solid var(--rule-ink);padding-top:1.2rem}
.hours-table .hr{display:flex;justify-content:space-between;padding:.4rem 0;font-size:.95rem}
.hours-table .hr span:first-child{color:var(--muted-ink)}

.form-wrap{
  background:var(--linen);
  /* plain hairline frame — keep the double-ring deboss reserved for the
     broadside + menu-card so the signature frame stays special */
  border:1px solid var(--rule);
  box-shadow:0 30px 60px -50px rgba(28,13,10,.5);
  padding:clamp(28px,4vw,48px);
}
.form-wrap h3{font-size:1.8rem}
.form-wrap .fw-sub{color:var(--muted);margin-top:.4rem}
.field{margin-top:1.3rem}
.field label{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--char);margin-bottom:.5rem}
.field label .req{color:var(--brick)}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--body);font-size:1rem;color:var(--char);
  background:var(--linen-2);border:1px solid var(--rule);
  padding:14px 16px;transition:border-color .2s var(--ease),background .2s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);opacity:.6}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--brick);background:var(--linen);
}
.field textarea{resize:vertical;min-height:120px}
.field .err{display:none;margin-top:.45rem;font-size:.82rem;color:var(--brick);font-weight:600}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--brick);background:rgba(122,46,29,.06)}
.field.invalid .err{display:block}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field-row > *{min-width:0}
.form-actions{margin-top:1.8rem}
.form-note{margin-top:1rem;font-size:.82rem;color:var(--muted);text-align:center}

.form-success{
  display:none;text-align:center;padding:clamp(30px,5vw,52px);
}
.form-success.show{display:block;animation:fadeUp .5s var(--ease)}
.form-success .seal{width:84px;height:84px;margin:0 auto 1.4rem;color:var(--brick)}
.form-success h3{font-size:clamp(1.8rem,5vw,2.6rem)}
.form-success p{color:var(--muted);max-width:44ch;margin:1rem auto 0}
.form-success .ref{
  margin-top:1.6rem;display:inline-block;font-family:var(--body);font-weight:600;
  letter-spacing:.14em;font-size:.8rem;text-transform:uppercase;color:var(--brick);
  border:1px solid var(--brick);padding:10px 18px;
}

.map-frame{
  margin:clamp(40px,6vw,72px) 0 0;border:1px solid var(--char);
  box-shadow:0 0 0 1px var(--linen),0 0 0 4px var(--char);
  background:var(--linen-2);overflow:hidden;
}
.map-frame .map-svg{
  display:block;width:100%;height:clamp(260px,34vw,380px);
}
.map-frame .map-cap{
  display:flex;align-items:center;gap:12px;
  padding:16px clamp(18px,3vw,26px);
  border-top:1px solid var(--rule);background:var(--linen);
  font-size:.92rem;color:var(--muted);line-height:1.45;
}
.map-frame .map-cap b{font-family:var(--serif);font-weight:400;color:var(--char);font-size:1.05rem;letter-spacing:.01em}
.map-frame .map-pin{flex:none;width:22px;height:22px;color:var(--brick)}
.map-frame .map-pin svg{width:100%;height:100%}

/* =========================================================
   CTA BAND (heats up)
   ========================================================= */
.cta-band{
  position:relative;overflow:hidden;isolation:isolate;
  background:
    radial-gradient(120% 120% at 50% 130%, rgba(224,163,62,.30), transparent 55%),
    linear-gradient(180deg,var(--char-2),var(--char-3));
  color:var(--linen);text-align:center;
  padding:clamp(64px,9vw,120px) 0;
}
.cta-band .ember-noise{position:absolute;inset:0;z-index:-1;opacity:.5}
.cta-band h2{font-size:clamp(2.3rem,7vw,4.2rem);line-height:1;color:var(--linen)}
.cta-band h2 em{font-style:italic;color:var(--gold)}
.cta-band p{max-width:50ch;margin:1.3rem auto 0;color:var(--muted-ink);font-size:1.08rem}
.cta-band .cta-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:2.2rem}

/* =========================================================
   FOOTER
   ========================================================= */
.site-foot{background:var(--char-3);color:var(--linen);padding:clamp(56px,7vw,88px) 0 36px}
.foot-top{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,48px);
}
.foot-top > *{min-width:0}
.foot-brand .mark{margin-bottom:1.2rem}
.foot-brand .mark svg{width:44px;height:44px}
.foot-brand .nm{font-family:var(--serif);font-size:1.6rem;line-height:1}
.foot-brand .nm span{display:block;font-family:var(--body);font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-top:6px;font-weight:600}
.foot-brand p{margin-top:1.2rem;color:var(--muted-ink);font-size:.95rem;max-width:32ch}
.foot-col h4{font-family:var(--body);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:1.2rem}
.foot-col a,.foot-col p{display:block;color:var(--muted-ink);font-size:.96rem;margin-bottom:.7rem}
.foot-col a:hover{color:var(--linen)}
.foot-bottom{
  margin-top:clamp(40px,5vw,64px);padding-top:24px;border-top:1px solid var(--rule-ink);
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;
  color:var(--muted-ink);font-size:.84rem;
}
.foot-bottom a{color:var(--gold)}
.foot-bottom a:hover{text-decoration:underline}
.made-moblank{font-weight:600}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:920px){
  .nav-desk,.head-cta .btn{display:none}
  .burger{display:flex}
  .head-cta{gap:0}
  .promise,.story-lead,.inquire-grid,.menu-cols{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gitem.wide{grid-column:span 2}
  .gitem.tall{grid-row:span 1;aspect-ratio:1/1}
}
@media (max-width:760px){
  body{font-size:17px}
  .pillars{grid-template-columns:1fr}
  .event-types{grid-template-columns:1fr}
  .stat-band{grid-template-columns:repeat(2,1fr)}
  .values{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .season-tabs button{flex:1 1 50%;min-width:0}
  .season-tabs button:nth-child(2){border-right:none}
}
@media (max-width:480px){
  .gallery{grid-template-columns:1fr}
  .gitem.wide{grid-column:span 1;aspect-ratio:1/1}
  .stat-band{grid-template-columns:1fr}
  .lb-nav{width:42px;height:42px}
}

/* =========================================================
   REDUCED MOTION — freeze embers, keep grain
   ========================================================= */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;
  }
  .spark{animation:none;opacity:.55}
  .hero .ember-layer{opacity:.5 !important;transition:none}
  .reveal{opacity:1;transform:none}
}
