/* ------------------------------------------------------------------
   POP'S PLACE — front-porch general-store editorial
   Palette: warm cream parchment + brick + mustard gold + chalkboard green
   Type:    Fraunces display · Newsreader body · Caveat hand-lettered
   ------------------------------------------------------------------ */

:root{
  /* Color */
  --cream:       #FBF4E5;
  --cream-2:     #FDF9EE;
  --cream-deep:  #F4EBD3;
  --cream-edge:  #E8DDBE;
  --brick:       #9B2D20;
  --brick-dark:  #6F1F15;
  --brick-soft:  #C66049;
  --gold:        #D4A24C;
  --gold-deep:   #B8862C;
  --forest:      #2E4A2E;
  --forest-dark: #1F3320;
  --forest-edge: #0E1D10;
  --ink:         #2D2419;
  --ink-soft:    #5B4E3A;
  --chalk:       #F5EFE2;
  --chalk-soft:  #C8C0A8;

  /* Type */
  --font-display: 'Fraunces','Playfair Display','Georgia',serif;
  --font-body:    'Newsreader','Georgia','Times New Roman',serif;
  --font-hand:    'Caveat','Caveat Brush',cursive;

  /* Rhythm */
  --pad:    clamp(20px, 4vw, 56px);
  --maxw:   1200px;
  --radius: 14px;
  --radius-sm: 8px;

  /* Shadow */
  --shadow-1: 0 2px 0 rgba(56,38,18,.05), 0 10px 28px -14px rgba(56,38,18,.35);
  --shadow-2: 0 4px 0 rgba(56,38,18,.05), 0 22px 50px -22px rgba(56,38,18,.45);
}

/* ----- Reset --------------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  font-size:18px;
  font-weight:400;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
button{ font:inherit; cursor:pointer; }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.05; margin:0; letter-spacing:-0.01em; font-variation-settings:"SOFT" 50,"opsz" 144; }
p{ margin:0; }
ul,ol{ margin:0; padding:0; list-style:none; }

/* Universal grain — used by ::before pseudos */
.grain{
  position:absolute; inset:0; pointer-events:none; mix-blend-mode:multiply; opacity:.18;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0.12  0 0 0 0 0.08  0 0 0 0 0.04  0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ----- Notice strip -------------------------------------------------- */
.notice{
  display:flex; gap:10px; align-items:center; justify-content:center; flex-wrap:wrap;
  padding:8px 18px;
  background:var(--brick);
  color:var(--cream);
  font-family:var(--font-body);
  font-size:14px;
  letter-spacing:.02em;
}
.notice__dot{
  width:8px; height:8px; border-radius:50%;
  background:#7CC36A;
  box-shadow:0 0 0 3px rgba(124,195,106,.25);
  animation: pulse 2.6s ease-in-out infinite;
}
.notice__dot[data-state="closed"]{
  background:#E9B25E;
  box-shadow:0 0 0 3px rgba(233,178,94,.22);
}
@keyframes pulse{ 0%,100%{transform:scale(1)} 50%{transform:scale(1.25)} }

.notice__status{ font-weight:600; }
.notice__sep{ opacity:.55; }
.notice__phone{
  text-decoration:none;
  border-bottom:1px dashed rgba(251,244,229,.55);
  padding-bottom:1px;
}
.notice__phone:hover{ color:var(--gold); border-color:var(--gold); }

@media (max-width: 520px){
  .notice__sep--hide{ display:none; }
  .notice{ font-size:13px; }
}

/* ----- Top nav ------------------------------------------------------- */
.topnav{
  position:sticky; top:0; z-index:30;
  display:flex; align-items:center; gap:24px;
  padding:14px clamp(16px,3vw,32px);
  background:rgba(251,244,229,.92);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--cream-edge);
}
.topnav__brand{
  display:flex; align-items:center; gap:12px;
  text-decoration:none; color:var(--ink);
  margin-right:auto;
}
.brand__mark{
  display:grid; place-items:center;
  width:42px; height:42px;
  background:var(--brick);
  color:var(--cream);
  font-family:var(--font-display);
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
  font-weight:700;
  font-size:26px; line-height:1;
  border-radius:50%;
  box-shadow: inset 0 -3px 0 rgba(0,0,0,.18), 0 2px 0 var(--brick-dark);
  transform:rotate(-4deg);
}
.brand__mark--lg{ width:60px; height:60px; font-size:36px; }
.brand__lines{ display:flex; flex-direction:column; line-height:1; }
.brand__line1{
  font-family:var(--font-display);
  font-weight:700;
  font-size:22px;
  letter-spacing:-.01em;
  font-variation-settings:"SOFT" 70,"opsz" 144;
}
.brand__line2{
  font-family:var(--font-body);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-top:3px;
}
.topnav__nav{
  display:flex; align-items:center; gap:22px;
  font-family:var(--font-body);
  font-size:15px;
}
.topnav__nav a{
  text-decoration:none; color:var(--ink);
  position:relative;
  padding:6px 0;
  transition:color .2s;
}
.topnav__nav a:not(.topnav__cta):hover{ color:var(--brick); }
.topnav__nav a:not(.topnav__cta)::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:1px; background:var(--brick); transform:scaleX(0); transform-origin:left;
  transition:transform .25s ease;
}
.topnav__nav a:not(.topnav__cta):hover::after{ transform:scaleX(1); }
.topnav__cta{
  background:var(--ink);
  color:var(--cream) !important;
  padding:10px 18px !important;
  border-radius:999px;
  font-weight:600;
  letter-spacing:.01em;
  box-shadow: 0 2px 0 rgba(0,0,0,.15);
}
.topnav__cta:hover{ background:var(--brick); }
.topnav__toggle{
  display:none;
  flex-direction:column; gap:5px;
  padding:8px;
  background:transparent; border:0;
}
.topnav__toggle span{
  width:24px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .25s, opacity .2s;
}

@media (max-width: 860px){
  .topnav__toggle{ display:flex; }
  .topnav__nav{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:var(--cream-2);
    border-bottom:1px solid var(--cream-edge);
    padding:8px 18px 18px;
    transform-origin:top;
    transform:scaleY(0);
    opacity:0;
    transition:transform .25s, opacity .2s;
  }
  .topnav__nav.is-open{ transform:scaleY(1); opacity:1; }
  .topnav__nav a{ padding:12px 4px; border-bottom:1px dashed var(--cream-edge); }
  .topnav__nav a:last-child{ border-bottom:0; margin-top:8px; text-align:center; }
  .topnav.is-open .topnav__toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .topnav.is-open .topnav__toggle span:nth-child(2){ opacity:0; }
  .topnav.is-open .topnav__toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
}

/* ----- HERO ---------------------------------------------------------- */
.hero{
  position:relative;
  overflow:hidden;
  padding: clamp(40px, 7vw, 90px) var(--pad) clamp(60px, 9vw, 110px);
  background:
    radial-gradient(1200px 600px at 20% -20%, rgba(212,162,76,.18), transparent 60%),
    radial-gradient(900px 600px at 110% 30%, rgba(155,45,32,.10), transparent 60%),
    linear-gradient(180deg, var(--cream-2) 0%, var(--cream) 60%);
  border-bottom:1px solid var(--cream-edge);
}
.hero__grain{
  position:absolute; inset:0; pointer-events:none; opacity:.5; mix-blend-mode:multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='2'/><feColorMatrix values='0 0 0 0 0.18  0 0 0 0 0.12  0 0 0 0 0.06  0 0 0 0.22 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.hero__inner{
  position:relative;
  max-width:var(--maxw); margin:0 auto;
  display:grid; gap: clamp(28px, 5vw, 64px);
  grid-template-columns: 1.05fr 0.95fr;
  align-items:center;
}
@media (max-width: 900px){ .hero__inner{ grid-template-columns:1fr; } }

.hero__eyebrow{
  display:flex; align-items:center; gap:14px;
  font-family:var(--font-body);
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:18px;
}
.eyebrow__line{ flex:0 0 36px; height:1px; background:var(--ink-soft); opacity:.5; }
.eyebrow__line:last-child{ flex:1; }

.hero__title{
  font-family:var(--font-display);
  font-size: clamp(64px, 13vw, 168px);
  line-height:.86;
  letter-spacing:-0.035em;
  color:var(--ink);
  margin:0 0 8px;
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
}
.hero__pops{
  display:block;
  color:var(--brick);
  font-style:italic;
  font-weight:700;
  transform:translateX(-2px);
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
}
.hero__place{
  display:block;
  font-weight:800;
  color:var(--ink);
  margin-top:-0.1em;
}
.hero__sub{
  font-family:var(--font-body);
  font-size:14px; letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin: 4px 0 28px;
}
.hero__tagline{
  font-family:var(--font-hand);
  color:var(--brick);
  font-size: clamp(28px, 4vw, 42px);
  line-height:1.05;
  font-weight:600;
  margin-bottom:14px;
  transform:rotate(-1deg);
  transform-origin:left;
}
.hero__lede{
  font-size: clamp(17px, 1.4vw, 19px);
  color:var(--ink-soft);
  max-width:46ch;
  margin-bottom:28px;
}
.hero__ctas{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:34px; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 14px 22px;
  border-radius:999px;
  text-decoration:none;
  font-family:var(--font-body);
  font-weight:600;
  font-size:16px;
  letter-spacing:.01em;
  transition: transform .15s, box-shadow .2s, background .2s, color .2s;
  border:1px solid transparent;
  will-change:transform;
}
.btn__icon{ font-size:18px; }
.btn--primary{
  background:var(--brick);
  color:var(--cream);
  box-shadow: 0 2px 0 var(--brick-dark), 0 14px 26px -12px rgba(111,31,21,.5);
}
.btn--primary:hover{
  background:var(--brick-dark);
  transform:translateY(-1px);
  box-shadow: 0 3px 0 var(--brick-dark), 0 20px 30px -14px rgba(111,31,21,.6);
}
.btn--ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--ink);
}
.btn--ghost:hover{
  background:var(--ink);
  color:var(--cream);
  transform:translateY(-1px);
}

/* Hero badges */
.hero__badges{
  display:flex; gap:14px; flex-wrap:wrap;
}
.badge{
  display:flex; flex-direction:column; gap:2px;
  padding:10px 16px;
  border-radius:10px;
  background:var(--cream-2);
  border:1px solid var(--cream-edge);
  box-shadow: var(--shadow-1);
  min-width:130px;
}
.badge__big{
  font-family:var(--font-display);
  font-size:24px;
  font-weight:700;
  color:var(--brick);
  font-variation-settings:"SOFT" 100,"opsz" 144;
}
.badge__title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:16px;
  color:var(--ink);
}
.badge__sub{
  font-size:12px;
  letter-spacing:.06em;
  color:var(--ink-soft);
  text-transform:uppercase;
}
.badge--stamp{
  background:var(--gold);
  border-color:var(--gold-deep);
  transform:rotate(-3deg);
  position:relative;
}
.badge--stamp::after{
  content:""; position:absolute; inset:0;
  border:2px dashed rgba(0,0,0,.18);
  border-radius:10px;
  pointer-events:none;
}
.badge--stamp .badge__title{ color:var(--forest-dark); }
.badge--stamp .badge__sub{ color:var(--forest-dark); }

/* Hero photo */
.hero__photo{
  position:relative;
  margin:0;
  justify-self:center;
}
.hero__photoframe{
  position:relative;
  aspect-ratio: 4/5;
  width: min(440px, 100%);
  background:var(--cream-deep);
  padding:14px;
  border:1px solid var(--cream-edge);
  border-radius: 6px;
  box-shadow:
    0 1px 0 #fff inset,
    0 30px 40px -28px rgba(56,38,18,.55),
    0 0 0 1px rgba(56,38,18,.08);
  transform: rotate(2deg);
}
.hero__photoframe img{
  width:100%; height:100%; object-fit:cover;
  border-radius:2px;
  filter: saturate(1.05) contrast(1.04);
}
.hero__caption{
  position:absolute;
  bottom:-30px; left:-20px;
  display:flex; flex-direction:column;
  transform:rotate(-3deg);
  background:var(--cream-2);
  padding:8px 14px;
  box-shadow: var(--shadow-1);
  border-left:3px solid var(--brick);
}
.caption__hand{
  font-family:var(--font-hand);
  font-size:22px;
  color:var(--brick);
  line-height:1;
}
.caption__attr{
  font-size:12px;
  color:var(--ink-soft);
  letter-spacing:.08em;
}
.hero__sticker{
  position:absolute;
  top:-26px; right:-22px;
  width:120px; height:120px;
  border-radius:50%;
  background:var(--forest);
  color:var(--chalk);
  display:grid; place-items:center; align-content:center; gap:2px;
  font-family:var(--font-display);
  font-style:italic;
  font-weight:600;
  font-variation-settings:"SOFT" 100,"opsz" 144;
  font-size:22px;
  text-align:center;
  line-height:1;
  transform: rotate(14deg);
  box-shadow:
    inset 0 0 0 2px rgba(245,239,226,.4),
    inset 0 0 0 6px var(--forest),
    inset 0 0 0 7px rgba(245,239,226,.25),
    0 10px 24px -10px rgba(0,0,0,.4);
}
.hero__sticker span{ display:block; }
.hero__sticker span:nth-child(2){ color:var(--gold); font-size:30px; }

@media (max-width: 900px){
  .hero__photo{ order:-1; }
  .hero__sticker{ width:96px; height:96px; font-size:18px; }
}

.hero__scroll{
  display:inline-flex; gap:10px; align-items:center;
  margin-top: clamp(40px,6vw,60px);
  font-family:var(--font-body);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:12px;
  color:var(--ink-soft);
  text-decoration:none;
}
.hero__scrollarrow{
  display:inline-block;
  animation: bob 2s ease-in-out infinite;
}
@keyframes bob{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(4px)} }

/* ----- TODAY banner -------------------------------------------------- */
.today{
  position:relative;
  background:var(--ink);
  color:var(--cream);
  padding: clamp(36px,5vw,56px) var(--pad);
  overflow:hidden;
}
.today::before{
  content:""; position:absolute; inset:0;
  background:
    repeating-linear-gradient(45deg, transparent 0 22px, rgba(212,162,76,.05) 22px 23px);
  pointer-events:none;
}
.today__inner{
  position:relative;
  max-width: 900px; margin:0 auto;
  text-align:center;
}
.today__kicker{
  font-family:var(--font-body);
  font-size:12px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:10px;
}
.today__day{
  font-family:var(--font-display);
  font-size: clamp(40px, 6vw, 72px);
  font-style:italic;
  font-weight:600;
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
  color:var(--cream);
  margin-bottom:10px;
}
.today__plate{
  font-family:var(--font-body);
  font-size: clamp(18px,1.6vw,22px);
  color:var(--cream);
  max-width:62ch;
  margin: 0 auto 22px;
  opacity:.92;
}
.today__cta{ margin-bottom:16px; }
.today__fine{
  font-size:13px;
  color:var(--chalk-soft);
  letter-spacing:.02em;
}

/* ----- STORY --------------------------------------------------------- */
.section-eyebrow{
  font-family:var(--font-body);
  font-size:12px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--brick);
  margin-bottom:14px;
  display:inline-flex; align-items:center; gap:10px;
}
.section-eyebrow::before{
  content:""; width:24px; height:1px; background:currentColor; opacity:.6;
}
.section-title{
  font-family:var(--font-display);
  font-size: clamp(34px, 4.6vw, 60px);
  font-weight:600;
  color:var(--ink);
  margin-bottom:18px;
  font-variation-settings:"SOFT" 60,"opsz" 144;
}
.section-title em{
  font-style:italic;
  color:var(--brick);
  font-weight:500;
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
}
.section-lede{
  font-size: clamp(17px,1.4vw,19px);
  color:var(--ink-soft);
  max-width:60ch;
}
.section-head{ margin-bottom: clamp(28px,4vw,48px); }
.section-head--center{ text-align:center; max-width: 720px; margin-left:auto; margin-right:auto; }
.section-head--center .section-eyebrow::before{ display:none; }

.story{
  padding: clamp(56px,8vw,110px) var(--pad);
  background: var(--cream);
  position:relative;
}
.story__inner{
  max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns: 1.2fr 0.9fr;
  gap: clamp(28px,5vw,72px);
  align-items:start;
}
@media (max-width: 900px){ .story__inner{ grid-template-columns:1fr; } }
.story__copy p{
  font-size: clamp(17px,1.4vw,19px);
  margin-bottom:18px;
  color:var(--ink);
}
.story__pills{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-top:24px;
}
.story__pills li{
  padding:6px 14px;
  background:var(--cream-deep);
  border:1px solid var(--cream-edge);
  border-radius:999px;
  font-size:14px;
  letter-spacing:.04em;
  color:var(--ink);
}
.story__side{ display:flex; flex-direction:column; gap:22px; }
.story__photo{
  margin:0;
  position:relative;
  border-radius: 6px;
  overflow:hidden;
  aspect-ratio: 4/3;
  background:var(--cream-deep);
  box-shadow: var(--shadow-2);
}
.story__photo img{
  width:100%; height:100%; object-fit:cover;
  filter:saturate(1.05) contrast(1.03);
}
.story__quote{
  margin:0;
  padding: 22px 24px;
  background:var(--cream-2);
  border-left:4px solid var(--gold);
  position:relative;
  box-shadow: var(--shadow-1);
}
.story__quote p{
  font-family:var(--font-display);
  font-style:italic;
  font-size: clamp(22px, 2vw, 28px);
  line-height:1.25;
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
  color:var(--ink);
}
.story__quote cite{
  font-style:normal;
  display:block;
  margin-top:10px;
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ink-soft);
}

/* ----- CHALKBOARD ---------------------------------------------------- */
.board-wrap{
  background: var(--cream-deep);
  padding: clamp(56px,8vw,110px) var(--pad);
  position:relative;
}
.board-wrap__inner{
  max-width:var(--maxw); margin:0 auto;
}
.chalkboard{
  position:relative;
  margin-top: 28px;
}
.chalkboard__frame{
  background:
    linear-gradient(180deg, #5a3a1f, #3e2812);
  padding: 18px;
  border-radius: 8px;
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,.05),
    0 30px 50px -20px rgba(0,0,0,.45),
    0 4px 0 #2b1a09;
}
.chalkboard__inner{
  position:relative;
  background:
    radial-gradient(700px 400px at 20% 0%, rgba(255,255,255,.06), transparent 65%),
    radial-gradient(900px 600px at 110% 110%, rgba(255,255,255,.04), transparent 60%),
    linear-gradient(180deg, var(--forest) 0%, var(--forest-dark) 100%);
  border-radius: 4px;
  padding: clamp(28px, 4vw, 56px) clamp(24px,4vw,52px);
  color:var(--chalk);
  overflow:hidden;
}
.chalkboard__inner::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' seed='8'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:screen;
  opacity:.55;
}
.chalkboard__header{
  text-align:center;
  font-family:var(--font-hand);
  color:var(--gold);
  font-size: clamp(28px,3vw,36px);
  margin-bottom: clamp(18px,3vw,28px);
  letter-spacing:.02em;
}
.board{
  display:grid;
  gap: clamp(22px,3vw,32px) clamp(28px,4vw,48px);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.board__day{
  position:relative;
  padding: 14px 8px 18px;
  border-radius: 4px;
  transition: background .25s, transform .25s;
}
.board__day::after{
  content:""; position:absolute; left:8px; right:8px; bottom:0;
  height:1px; background: rgba(245,239,226,.18);
}
.board__day:last-child::after{ display:none; }
.board__name{
  font-family:var(--font-display);
  font-size: clamp(28px, 2.6vw, 34px);
  font-weight:600;
  color:var(--chalk);
  font-style:italic;
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
  margin-bottom:8px;
  text-shadow: 0 1px 0 rgba(255,255,255,.05);
}
.board__meat{
  font-family:var(--font-body);
  font-size: clamp(16px,1.3vw,18px);
  color:var(--chalk);
  margin-bottom:8px;
}
.board__sides{
  font-family:var(--font-hand);
  color:var(--gold);
  font-size: clamp(20px,1.7vw,24px);
  line-height:1.2;
  letter-spacing:.01em;
}
.board__day.is-today{
  background: rgba(212,162,76,.10);
  box-shadow: 0 0 0 1px rgba(212,162,76,.35), inset 0 0 28px rgba(212,162,76,.08);
}
.board__day.is-today::before{
  content:"Today";
  position:absolute;
  top:-10px; left:8px;
  background:var(--gold);
  color:var(--forest-dark);
  font-family:var(--font-body);
  font-weight:700;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding: 4px 10px;
  border-radius:999px;
  box-shadow: 0 2px 6px rgba(0,0,0,.3);
}
.chalkboard__foot{
  text-align:center;
  margin-top: clamp(20px,3vw,32px);
  color:var(--chalk-soft);
  font-family:var(--font-body);
  font-size:14px;
  letter-spacing:.06em;
}
.chalk-arrow{ color:var(--gold); margin-right:6px; }

/* ----- BASKETS / RECEIPTS ------------------------------------------- */
.baskets{
  padding: clamp(56px,8vw,110px) var(--pad);
  background: var(--cream);
}
.baskets__inner{ max-width: var(--maxw); margin:0 auto; }

.receipts{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(18px, 2.4vw, 28px);
  margin-top: clamp(28px,4vw,44px);
}
.receipt{
  --bg: var(--cream-2);
  background: var(--bg);
  padding: 22px 22px 28px;
  position:relative;
  border:1px solid var(--cream-edge);
  border-bottom: 0;
  box-shadow: var(--shadow-1);
  transition: transform .25s, box-shadow .25s;
}
.receipt::after{
  content:""; position:absolute; left:0; right:0; bottom:-12px;
  height:14px;
  background:
    radial-gradient(circle at 7px 0, var(--cream) 4.5px, var(--bg) 5px) 0 0 / 14px 14px;
}
.receipt:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-2);
}
.receipt__name{
  font-family:var(--font-display);
  font-weight:600;
  font-size:22px;
  letter-spacing:-.01em;
  color:var(--ink);
  margin-bottom:6px;
  font-variation-settings:"SOFT" 70,"opsz" 144;
}
.receipt__price{
  font-family:var(--font-body);
  font-weight:700;
  color:var(--brick);
  font-size:30px;
  letter-spacing:-.01em;
  line-height:1;
  margin-bottom:8px;
}
.receipt__line{
  font-size:13px;
  letter-spacing:.04em;
  color:var(--ink-soft);
  border-top: 1px dashed var(--cream-edge);
  padding-top:10px;
}
.receipt--star{
  --bg: #FFF7E6;
  border-color: var(--gold);
}
.receipt--star::before{
  content:"★ Favorite";
  position:absolute;
  top:-12px; left:50%; transform: translateX(-50%);
  background:var(--gold);
  color:var(--forest-dark);
  font-family:var(--font-body);
  font-weight:700;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:4px 12px;
  border-radius:999px;
  box-shadow: 0 2px 0 var(--gold-deep);
}

.baskets__note{
  text-align:center;
  margin-top: clamp(28px,4vw,44px);
  font-size:14px;
  color:var(--ink-soft);
}
.baskets__note a{
  color:var(--brick);
  border-bottom:1px dashed currentColor;
  text-decoration:none;
}

/* ----- FRIDAY NIGHT -------------------------------------------------- */
.friday{
  position:relative;
  background:
    radial-gradient(900px 600px at 90% -10%, rgba(212,162,76,.16), transparent 60%),
    linear-gradient(180deg, #1f1208 0%, #2D1B0B 100%);
  color:var(--cream);
  padding: clamp(56px,8vw,110px) var(--pad);
  overflow:hidden;
}
.friday::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='7'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.05 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:screen;
}
.friday__inner{ position:relative; max-width:var(--maxw); margin:0 auto; }
.friday__head{ max-width: 720px; margin-bottom: clamp(36px,5vw,56px); }
.friday__eyebrow{ color:var(--gold); }
.friday__eyebrow::before{ background: currentColor; }
.friday__title{ color:var(--cream); }
.friday__title em{ color:var(--gold); }
.friday__lede{ color: #DDD2B7; }

.friday__grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: clamp(16px, 2vw, 24px);
}
@media (max-width: 1000px){
  .friday__grid{ grid-template-columns: 1fr 1fr; }
  .ticket--big{ grid-column: span 2; }
}
@media (max-width: 580px){
  .friday__grid{ grid-template-columns: 1fr; }
  .ticket--big{ grid-column: auto; }
}

.ticket{
  position:relative;
  background: #fbf4e5;
  color:var(--ink);
  padding: 24px 22px;
  border-radius: 6px;
  display:flex; flex-direction:column; gap:8px;
  box-shadow: 0 18px 30px -16px rgba(0,0,0,.5);
}
.ticket::before, .ticket::after{
  content:""; position:absolute;
  width:18px; height:18px; border-radius:50%;
  background: #1f1208;
}
.ticket::before{ left:-9px; top:50%; transform:translateY(-50%); }
.ticket::after{ right:-9px; top:50%; transform:translateY(-50%); }
.ticket__tag{
  font-family:var(--font-body);
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--brick);
  font-weight:700;
}
.ticket__name{
  font-family:var(--font-display);
  font-size: clamp(24px,2.2vw,30px);
  font-weight:600;
  color:var(--ink);
  margin:0;
  font-variation-settings:"SOFT" 60,"opsz" 144;
}
.ticket__desc{
  font-size:15px;
  color:var(--ink-soft);
  flex:1;
}
.ticket__price{
  font-family:var(--font-display);
  font-weight:700;
  font-size: clamp(28px,2.6vw,36px);
  color:var(--brick);
  line-height:1;
  margin-top: 4px;
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
}
.ticket--big{
  background:
    linear-gradient(180deg, #fff7e2 0%, #f7e9c0 100%);
  border: 1px solid var(--gold);
}
.ticket--big .ticket__name{ font-size: clamp(28px,2.6vw,40px); }
.ticket--wings .ticket__flavors{
  margin-top:6px;
  display:flex; flex-wrap:wrap; gap:6px;
}
.ticket--wings .ticket__flavors li{
  padding: 4px 10px;
  background: var(--cream-deep);
  border:1px solid var(--cream-edge);
  border-radius:999px;
  font-size:12px;
  letter-spacing:.05em;
  color:var(--ink);
}

/* ----- FAVORITES / MOSAIC ------------------------------------------- */
.favorites{
  padding: clamp(56px,8vw,110px) var(--pad);
  background: var(--cream);
}
.favorites__inner{ max-width:var(--maxw); margin:0 auto; }
.grid--mosaic{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 16px;
  margin-top: clamp(28px,4vw,44px);
}
.card{
  position:relative;
  margin:0;
  overflow:hidden;
  border-radius: var(--radius);
  background: var(--cream-deep);
  box-shadow: var(--shadow-1);
  transition: transform .3s, box-shadow .3s;
}
.card img{
  width:100%; height:100%; object-fit:cover;
  transition: transform .8s ease;
  filter: saturate(1.05) contrast(1.03);
}
.card:hover img{ transform: scale(1.06); }
.card:hover{ box-shadow: var(--shadow-2); transform: translateY(-2px); }
.card figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding: 18px 18px 16px;
  background: linear-gradient(180deg, transparent 0%, rgba(20,12,4,.85) 70%);
  color:var(--cream);
}
.card figcaption h3{
  font-family:var(--font-display);
  font-size: 22px;
  font-weight:600;
  margin:0 0 4px;
  font-variation-settings:"SOFT" 100,"opsz" 144,"WONK" 1;
}
.card figcaption p{
  font-size:13px;
  color: #E8DEC6;
  letter-spacing:.02em;
}
.card--tall{ grid-column: span 2; grid-row: span 2; }
.card--wide{ grid-column: span 2; }

@media (max-width: 760px){
  .grid--mosaic{
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 200px;
  }
  .card--tall{ grid-column: span 2; grid-row: span 1; }
  .card--wide{ grid-column: span 2; }
}

.tags{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top: clamp(28px,4vw,44px);
  justify-content:center;
}
.tags li{
  padding: 7px 14px;
  background: var(--cream-2);
  border: 1px solid var(--cream-edge);
  border-radius: 999px;
  font-size:14px;
  color:var(--ink);
  letter-spacing:.02em;
}

/* ----- VISIT --------------------------------------------------------- */
.visit{
  padding: clamp(56px,8vw,110px) var(--pad);
  background: var(--cream-deep);
}
.visit__inner{ max-width: var(--maxw); margin:0 auto; }
.visit__grid{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(28px,4vw,48px);
  margin-top: clamp(28px,4vw,44px);
}
@media (max-width: 900px){ .visit__grid{ grid-template-columns:1fr; } }

.hours{
  background:var(--cream-2);
  padding: clamp(24px,3vw,36px);
  border-radius: var(--radius);
  border: 1px solid var(--cream-edge);
  box-shadow: var(--shadow-1);
}
.hours__title{
  font-family:var(--font-display);
  font-size: 28px;
  margin-bottom:16px;
  font-variation-settings:"SOFT" 70,"opsz" 144;
}
.hours__table{
  width:100%; border-collapse: collapse;
  margin-bottom: 22px;
}
.hours__table th, .hours__table td{
  text-align:left;
  padding: 10px 0;
  border-bottom: 1px dashed var(--cream-edge);
  font-weight:400;
  font-size:16px;
}
.hours__table th{
  font-family:var(--font-display);
  font-weight:600;
  font-size:18px;
  color:var(--ink);
  font-variation-settings:"SOFT" 60,"opsz" 144;
}
.hours__table td{
  text-align:right;
  color:var(--ink-soft);
}
.hours__table tr:last-child th, .hours__table tr:last-child td{ border-bottom:0; }
.hours__table tr.is-today th, .hours__table tr.is-today td{
  color: var(--brick);
  font-weight:600;
}
.hours__table tr.is-today th::after{
  content:"· today";
  font-family:var(--font-hand);
  color:var(--brick);
  font-size:18px;
  margin-left:8px;
}
.visit__contact li{
  display:flex; justify-content:space-between; gap:18px;
  padding: 8px 0;
  border-top: 1px solid var(--cream-edge);
  align-items:baseline;
}
.contact__label{
  font-family:var(--font-body);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.visit__contact a{
  text-decoration:none;
  color:var(--ink);
  border-bottom: 1px dashed var(--cream-edge);
  text-align:right;
}
.visit__contact a:hover{ color: var(--brick); border-color:var(--brick); }

.map{
  border-radius: var(--radius);
  overflow:hidden;
  min-height: 360px;
  box-shadow: var(--shadow-2);
  background:#eee;
  border: 1px solid var(--cream-edge);
}
.map iframe{
  width:100%; height:100%; min-height:360px;
  border:0; display:block;
}

.amenities{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
  margin-top: clamp(28px,4vw,44px);
}
.amenities li{
  display:flex; align-items:center; gap:10px;
  padding: 12px 14px;
  background: var(--cream-2);
  border:1px solid var(--cream-edge);
  border-radius: 8px;
  font-size:14px;
  color:var(--ink);
}
.amen__ico{ font-size:18px; }

/* ----- FOOTER -------------------------------------------------------- */
.foot{
  background: var(--ink);
  color: var(--cream);
  padding: clamp(48px,6vw,80px) var(--pad) 24px;
}
.foot__inner{
  max-width: var(--maxw); margin: 0 auto;
  display:grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(28px,4vw,48px);
  align-items:start;
}
@media (max-width: 760px){ .foot__inner{ grid-template-columns: 1fr; } }
.foot__brand{ display:flex; gap:14px; align-items:center; }
.foot__name{
  font-family:var(--font-display);
  font-size: 28px;
  font-weight:700;
  letter-spacing:-.01em;
  font-variation-settings:"SOFT" 70,"opsz" 144;
}
.foot__sub{
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color: var(--chalk-soft);
}
.foot__cols{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 20px;
}
.foot__label{
  font-family:var(--font-body);
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color: var(--gold);
  margin-bottom:6px;
}
.foot__col a{
  color: var(--cream);
  text-decoration: none;
  border-bottom: 1px dashed rgba(245,239,226,.25);
  padding-bottom:1px;
}
.foot__col a:hover{ color: var(--gold); border-color: var(--gold); }
.foot__col p{ color: #D9CFB4; font-size:14px; line-height:1.6; }

.foot__fine{
  margin-top: clamp(36px,5vw,60px);
  padding-top: 20px;
  border-top: 1px solid rgba(245,239,226,.12);
  font-size:12px;
  letter-spacing:.04em;
  color: var(--chalk-soft);
  text-align:center;
  max-width: 760px;
  margin-left:auto; margin-right:auto;
  line-height:1.7;
}

/* ----- Reveal animations -------------------------------------------- */
.reveal{
  opacity:0;
  transform: translateY(20px);
  transition: opacity .8s ease, transform .8s ease;
}
.reveal.in{
  opacity:1; transform: translateY(0);
}

/* Hero load stagger */
.hero__copy > *{
  opacity:0;
  transform: translateY(14px);
  animation: rise .8s ease forwards;
}
.hero__copy > *:nth-child(1){ animation-delay: .05s; }
.hero__copy > *:nth-child(2){ animation-delay: .15s; }
.hero__copy > *:nth-child(3){ animation-delay: .25s; }
.hero__copy > *:nth-child(4){ animation-delay: .35s; }
.hero__copy > *:nth-child(5){ animation-delay: .45s; }
.hero__copy > *:nth-child(6){ animation-delay: .55s; }
.hero__copy > *:nth-child(7){ animation-delay: .65s; }
.hero__photo{ opacity:0; animation: rise .9s .3s ease forwards; }
@keyframes rise{
  from{ opacity:0; transform: translateY(14px); }
  to{   opacity:1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  html{ scroll-behavior:auto; }
}
