/* ==========================================================================
   Chef Lesly · Executive Box Lunch · Fort Worth
   Production stylesheet — Dynasty Cloudflare Pages
   Last refactored: 2026-06-09 (Talos build)
   ========================================================================== */

/* =========================================================
   DESIGN TOKENS — pastel pink, locked per Don's brief
   ========================================================= */
:root{
  --pink:#b03ea0;
  --pink-soft:#f6e3f1;
  --pink-deep:#8a2c7d;
  --cream:#fbf6f3;
  --ink:#1f1419;
  --ink-muted:#5a4a55;
  --surface:#ffffff;
  --surface-2:#fbf3f7;
  --border:#ecd9e6;
  --divider:#f0e0ea;

  --font-display:'Playfair Display', Georgia, serif;
  --font-ui:'Manrope', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

  --text-xs:.78rem;
  --text-sm:.92rem;
  --text-base:1rem;
  --text-lg:1.2rem;
  --text-xl:1.45rem;
  --text-2xl:1.85rem;
  --text-3xl:2.4rem;
  --text-display:clamp(2.4rem, 5.4vw, 4.4rem);

  --space-1:.4rem;
  --space-2:.65rem;
  --space-3:1rem;
  --space-4:1.4rem;
  --space-5:1.85rem;
  --space-6:2.5rem;
  --space-7:3.5rem;
  --space-8:5rem;

  --radius-sm:.4rem;
  --radius-md:.7rem;
  --radius-lg:1rem;
  --radius-xl:1.4rem;
  --radius-full:999px;

  --shadow-sm:0 1px 2px rgba(31,20,25,.06);
  --shadow-md:0 12px 32px rgba(176,62,160,.10), 0 2px 6px rgba(31,20,25,.05);
  --shadow-lg:0 30px 70px rgba(176,62,160,.18), 0 4px 12px rgba(31,20,25,.08);

  --transition:200ms cubic-bezier(.2,.7,.2,1);
  --color-primary:var(--pink);
  --color-primary-highlight:var(--pink-soft);
  --color-text:var(--ink);
  --color-text-muted:var(--ink-muted);
  --color-surface:var(--surface);
  --color-surface-2:var(--surface-2);
  --color-border:var(--border);
  --color-divider:var(--divider);
}
[data-theme="dark"]{
  --pink:#de72cb;
  --pink-soft:#3a1d35;
  --pink-deep:#f3a3e1;
  --cream:#0f0a0d;
  --ink:#f7eaf2;
  --ink-muted:#c2adb9;
  --surface:#1a1116;
  --surface-2:#22161e;
  --border:#3a2532;
  --divider:#3a2532;

  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow-md:0 12px 32px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.35);
  --shadow-lg:0 30px 70px rgba(0,0,0,.55), 0 4px 12px rgba(0,0,0,.35);
}

/* =========================================================
   BASE
   ========================================================= */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html, body{margin:0;padding:0;overflow-x:hidden}
body{
  font-family:var(--font-ui);
  color:var(--color-text);
  background:var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--pink);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--pink-deep)}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--color-text);line-height:1.15;margin:0;letter-spacing:-.01em}
h1{font-size:var(--text-display);font-weight:700}
h2{font-size:clamp(2rem, 3.6vw, 2.9rem);font-weight:700}
h3{font-size:var(--text-xl);font-weight:600}
p{margin:0}

.shell{max-width:1180px;margin:0 auto;padding:0 var(--space-5)}
.section{padding:var(--space-8) 0}
.section-head{display:grid;gap:var(--space-3);max-width:760px;margin-bottom:var(--space-6)}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .85rem;border-radius:var(--radius-full);background:var(--pink-soft);color:var(--pink);font-size:var(--text-xs);font-weight:800;letter-spacing:.08em;text-transform:uppercase;width:fit-content}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem 1.6rem;border-radius:var(--radius-full);font-weight:800;font-size:var(--text-sm);font-family:var(--font-ui);border:1.5px solid transparent;cursor:pointer;transition:transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition);text-decoration:none;line-height:1;letter-spacing:.01em}
.btn-primary{background:var(--pink);color:#fff;border-color:var(--pink);box-shadow:var(--shadow-md)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--pink-deep);border-color:var(--pink-deep);color:#fff}
[data-theme="dark"] .btn-primary{color:#1a0f17}
[data-theme="dark"] .btn-primary:hover{color:#1a0f17}
.btn-ghost{background:transparent;color:var(--color-text);border-color:var(--color-border)}
.btn-ghost:hover{border-color:var(--pink);color:var(--pink);transform:translateY(-2px)}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none}

/* =========================================================
   NAV
   ========================================================= */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in oklab, var(--cream) 88%, transparent);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--color-border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:var(--space-4)}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--color-text)}
.brand-mark{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--pink) 0%, var(--pink-deep) 100%);color:#fff;font-family:var(--font-display);font-style:italic;font-size:1.3rem;font-weight:600;box-shadow:var(--shadow-sm)}
.brand-name{display:flex;flex-direction:column;line-height:1.05}
.brand-name small{font-family:var(--font-ui);font-weight:600;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--color-text-muted)}

.nav-links{display:flex;align-items:center;gap:var(--space-5);list-style:none;margin:0;padding:0}
.nav-links a{color:var(--color-text);font-weight:700;font-size:var(--text-sm);position:relative;padding:.5rem 0}
.nav-links a::after{content:"";position:absolute;left:50%;right:50%;bottom:0;height:2px;background:var(--pink);transition:left var(--transition), right var(--transition)}
.nav-links a:hover::after{left:0;right:0}

.nav-actions{display:flex;align-items:center;gap:var(--space-3)}
.theme-toggle{width:42px;height:42px;border-radius:50%;border:1px solid var(--color-border);background:var(--surface);color:var(--color-text);cursor:pointer;display:grid;place-items:center;transition:all var(--transition)}
.theme-toggle:hover{border-color:var(--pink);color:var(--pink)}
[data-theme="light"] .theme-toggle .icon-sun{display:block}
[data-theme="light"] .theme-toggle .icon-moon{display:none}
[data-theme="dark"] .theme-toggle .icon-sun{display:none}
[data-theme="dark"] .theme-toggle .icon-moon{display:block}
.nav-toggle{display:none;width:42px;height:42px;border-radius:50%;border:1px solid var(--color-border);background:var(--surface);cursor:pointer;color:var(--color-text)}
@media (max-width:880px){
  .nav-links,.nav-actions .btn{display:none}
  .nav-toggle{display:grid;place-items:center}
}
/* mobile drawer */
.drawer{position:fixed;top:72px;right:0;width:min(320px,100vw);height:calc(100vh - 72px);background:var(--cream);transform:translateX(100%);transition:transform var(--transition),visibility var(--transition);z-index:49;border-left:1px solid var(--color-border);padding:var(--space-6) var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);visibility:hidden;pointer-events:none;overflow-y:auto;box-shadow:-12px 0 32px rgba(0,0,0,.12)}
.drawer-backdrop{position:fixed;inset:72px 0 0 0;background:rgba(0,0,0,.4);z-index:48;opacity:0;visibility:hidden;transition:opacity var(--transition),visibility var(--transition)}
.drawer-backdrop.is-open{opacity:1;visibility:visible}
.drawer.is-open{transform:translateX(0);visibility:visible;pointer-events:auto}
.drawer a{color:var(--color-text);font-weight:700;font-size:1.1rem;padding:.6rem 0;border-bottom:1px solid var(--color-divider)}
.drawer .btn{margin-top:var(--space-4)}

/* =========================================================
   HERO
   ========================================================= */
.hero{padding:calc(var(--space-7) + 24px) 0 var(--space-8);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-25%;right:-10%;width:60vw;height:60vw;background:radial-gradient(circle, var(--pink-soft) 0%, transparent 60%);pointer-events:none;z-index:0}
.hero-grid{display:grid;gap:var(--space-7);align-items:center;position:relative;z-index:1}
@media (min-width:980px){.hero-grid{grid-template-columns:1.05fr .95fr}}
.hero-text .eyebrow{margin-bottom:var(--space-3)}
.hero-text h1{margin-bottom:var(--space-4)}
.hero-text .lede{font-size:var(--text-lg);color:var(--color-text-muted);max-width:48ch;margin-bottom:var(--space-5);line-height:1.55}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-5)}
.hero-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.hero-tags span{padding:.35rem .85rem;border-radius:var(--radius-full);background:var(--surface);border:1px solid var(--color-border);color:var(--color-text-muted);font-size:.78rem;font-weight:700}

.hero-media{position:relative}
.hero-avatar{
  width:100%;
  aspect-ratio:1/1;
  max-width:520px;
  margin:0 auto;
  border-radius:var(--radius-xl);
  overflow:hidden;
  background:var(--pink-soft);
  box-shadow:var(--shadow-lg);
  position:relative;
}
.hero-avatar img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.hero-quote{
  position:absolute;
  bottom:-28px;
  left:-12px;
  right:18%;
  background:var(--surface);
  border:1px solid var(--color-border);
  border-radius:var(--radius-lg);
  padding:var(--space-4) var(--space-5);
  box-shadow:var(--shadow-md);
  font-family:var(--font-display);
  font-style:italic;
  font-size:1.05rem;
  color:var(--color-text);
  line-height:1.45;
}
.hero-quote::before{content:"\201C";position:absolute;top:-18px;left:18px;font-family:var(--font-display);color:var(--pink);font-size:4rem;line-height:1;opacity:.7}
.hero-quote cite{display:block;margin-top:.6rem;font-style:normal;font-family:var(--font-ui);font-weight:700;font-size:.78rem;color:var(--pink);letter-spacing:.06em;text-transform:uppercase}
@media (max-width:560px){
  .hero-quote{position:static;margin-top:var(--space-4);right:0;left:0}
}

/* =========================================================
   STORY
   ========================================================= */
.story{background:var(--surface);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}
.story-grid{display:grid;gap:var(--space-6);align-items:center}
@media (min-width:880px){.story-grid{grid-template-columns:1fr 1.2fr}}
.story-photo{aspect-ratio:4/5;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);background:var(--pink-soft)}
.story-photo img{width:100%;height:100%;object-fit:cover}
.story-body p{color:var(--color-text-muted);font-size:var(--text-base);margin-bottom:var(--space-3);max-width:62ch}
.story-body p:last-child{margin-bottom:0}
.story-body h2{margin-bottom:var(--space-4)}
.story-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--color-divider)}
.story-stats div{display:flex;flex-direction:column;gap:.2rem}
.story-stats strong{font-family:var(--font-display);font-size:1.6rem;color:var(--pink)}
.story-stats span{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:700;letter-spacing:.04em;text-transform:uppercase}

/* =========================================================
   MENU SHOWCASE
   ========================================================= */
.menu{background:var(--cream)}
.menu-feature{display:grid;gap:var(--space-6);align-items:start;margin-bottom:var(--space-8)}
@media (min-width:880px){.menu-feature{grid-template-columns:1.1fr 1fr}}
.menu-feature.reverse{direction:rtl}
.menu-feature.reverse > *{direction:ltr}
.menu-photo{aspect-ratio:3/2;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.menu-photo img{width:100%;height:100%;object-fit:cover}
.menu-content h3{font-size:var(--text-2xl);margin-bottom:var(--space-2)}
.menu-content > .eyebrow{margin-bottom:var(--space-3)}
.menu-content > p.lead{color:var(--color-text-muted);margin-bottom:var(--space-4);font-size:var(--text-base)}

.menu-section-head{font-family:var(--font-display);font-size:var(--text-lg);margin:var(--space-5) 0 var(--space-2);color:var(--pink)}
.menu-section-head.lg{margin-top:var(--space-6)}

.menu-list{display:flex;flex-direction:column;gap:var(--space-3);list-style:none;margin:0;padding:0}
.menu-item{display:grid;grid-template-columns:1fr auto;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-divider)}
.menu-item:last-child{border-bottom:0}
.menu-item h4{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:800;margin:0;color:var(--color-text);letter-spacing:.01em}
.menu-item p{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:.25rem;line-height:1.5}
.menu-item .price{font-family:var(--font-display);font-size:var(--text-base);color:var(--pink);font-weight:700;align-self:start;white-space:nowrap}
.menu-item .alc-only-tag{font-family:var(--font-ui);font-size:.72rem;font-weight:600;color:var(--pink);background:var(--pink-soft);padding:.15rem .5rem;border-radius:999px;letter-spacing:.02em;margin-left:.4rem;vertical-align:middle}

/* charcuterie variant — card grid */
.charc-grid{display:grid;gap:var(--space-3);grid-template-columns:repeat(2,1fr);margin-top:var(--space-5)}
@media (min-width:560px){.charc-grid{grid-template-columns:repeat(4,1fr)}}
.charc-card{padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--surface);text-align:center;transition:all var(--transition);display:flex;flex-direction:column;align-items:center;gap:.4rem;min-height:130px;justify-content:center}
.charc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--pink)}
.charc-card h4{font-family:var(--font-display);font-size:var(--text-lg);margin:0}
.charc-card .serves{display:block;font-size:var(--text-xs);color:var(--color-text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.charc-card .price{display:block;font-family:var(--font-display);font-size:var(--text-2xl);color:var(--pink);font-weight:700;line-height:1;margin-top:.2rem}
.menu-content .boardroom-note{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted)}

/* =========================================================
   ORDER
   ========================================================= */
.order{background:var(--surface);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}
.order .section-head p{color:var(--color-text-muted);font-size:var(--text-base);margin-top:var(--space-3)}

.order-wrap{display:grid;gap:var(--space-6);align-items:start}
.order-wrap > *{min-width:0}
@media (min-width:980px){.order-wrap{grid-template-columns:minmax(0,1.55fr) minmax(320px,1fr)}}
.order-panel{background:var(--surface-2);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-md);min-width:0}
@media (max-width:560px){.order-panel{padding:var(--space-4)}}
.order-rules{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-5)}
.order-rules span{padding:.4rem .85rem;border-radius:var(--radius-full);background:var(--pink-soft);color:var(--pink);font-size:.7rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.tabs{display:flex;gap:var(--space-2);padding:var(--space-1);background:var(--surface);border:1px solid var(--color-border);border-radius:var(--radius-full);width:fit-content;max-width:100%;overflow-x:auto;margin-bottom:var(--space-5)}
.tab{padding:.6rem 1.2rem;border-radius:var(--radius-full);border:none;background:transparent;color:var(--color-text-muted);font-weight:800;font-size:var(--text-sm);white-space:nowrap;transition:all var(--transition);cursor:pointer;font-family:var(--font-ui)}
.tab[aria-selected="true"]{background:var(--pink);color:#fff;box-shadow:var(--shadow-sm)}
[data-theme="dark"] .tab[aria-selected="true"]{color:#1a0f17}
.tabpanel{display:none}
.tabpanel.is-active{display:block}

.box-meta{display:grid;gap:var(--space-3);margin-bottom:var(--space-5)}
@media (min-width:560px){.box-meta{grid-template-columns:repeat(2,1fr)}}
.box-meta label.full{grid-column:1/-1}
.box-meta label{display:flex;flex-direction:column;gap:var(--space-2);font-size:var(--text-sm);font-weight:700}
.box-meta input,.box-meta select{width:100%;padding:.85rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--surface);color:var(--color-text);font:inherit;transition:border-color var(--transition),box-shadow var(--transition)}
.box-meta input:focus,.box-meta select:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px var(--pink-soft)}
.box-meta small{display:block;margin-top:.4rem;font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600}
.box-actions{margin-bottom:var(--space-4)}
.box-bulk{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);font-weight:700;width:100%}
.box-bulk > select{flex:1 1 140px;min-width:0;max-width:100%;padding:.55rem .7rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--surface);color:var(--color-text);font:inherit}
.box-rows{display:grid;gap:var(--space-2)}
.box-row{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition)}
.box-row.is-open{border-color:var(--pink);box-shadow:0 0 0 3px var(--color-primary-highlight)}
.box-summary{display:grid;grid-template-columns:auto 1fr auto auto;gap:var(--space-3);align-items:center;padding:.65rem .85rem;cursor:pointer;width:100%;border:0;background:transparent;color:inherit;text-align:left;font:inherit}
.box-summary:hover{background:rgba(176,62,160,.06)}
.box-summary .row-label{font-weight:800;font-size:var(--text-sm);color:var(--color-text-muted);min-width:54px}
.box-summary .row-summary-text{font-size:var(--text-sm);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.box-summary .row-summary-text.is-empty{color:var(--color-text-muted);font-style:italic}
.box-summary .row-status{font-size:1rem;line-height:1;width:18px;text-align:center}
.box-summary .row-status.ok{color:#3aa676}
.box-summary .row-chevron{display:inline-block;transition:transform var(--transition);font-size:.8rem;color:var(--color-text-muted)}
.box-row.is-open .row-chevron{transform:rotate(180deg)}
.box-body{display:none;padding:0 .85rem .85rem;gap:var(--space-2);grid-template-columns:1fr 1fr auto;align-items:center}
.box-row.is-open .box-body{display:grid}
@media (max-width:560px){.box-body{grid-template-columns:1fr 1fr;grid-template-areas:"sand sand" "side side" "remove remove"}.box-body .row-sand{grid-area:sand}.box-body .row-side{grid-area:side}.box-body .row-remove{grid-area:remove;justify-self:end}}
.box-body select{width:100%;padding:.7rem .8rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--surface);color:var(--color-text);font:inherit;min-width:0}
.box-add{margin-top:var(--space-3);width:100%;padding:.85rem 1rem;border:1px dashed var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-muted);font:inherit;font-weight:700;cursor:pointer;transition:border-color var(--transition),color var(--transition),background var(--transition)}
.box-add:hover{border-color:var(--pink);color:var(--pink);background:var(--color-primary-highlight)}
.box-add[disabled]{opacity:.5;cursor:not-allowed}
.row-remove{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-size:1.1rem;line-height:1;cursor:pointer;flex-shrink:0}
.row-remove:hover{color:var(--pink);border-color:var(--pink)}
.dessert-note{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--pink-soft);color:var(--pink);font-size:var(--text-sm);font-weight:700;display:flex;align-items:center;gap:.6rem}
.dessert-note::before{content:"\2728";font-size:1.15rem}
.dessert-note.inline{margin-top:var(--space-5)}

.alc-group{margin-top:var(--space-5)}
.alc-group:first-child{margin-top:0}
.alc-group h4{margin:0 0 var(--space-3);font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-text)}
.alc-grid{display:grid;gap:var(--space-3)}
@media (min-width:560px){.alc-grid{grid-template-columns:repeat(2,1fr)}}
.alc-item{display:grid;grid-template-columns:1fr auto;gap:var(--space-3);align-items:center;padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--surface)}
.alc-item .alc-name{font-weight:800;font-size:var(--text-sm);color:var(--color-text)}
.alc-item .alc-desc{display:block;margin-top:.25rem;font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.45;font-weight:500}
.alc-item .alc-price{display:block;margin-top:.4rem;color:var(--pink);font-weight:800;font-size:var(--text-sm)}
.alc-intro{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-4)}
.qty{display:inline-flex;align-items:center;gap:.35rem;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--surface);padding:.2rem}
.qty button{width:32px;height:32px;border-radius:50%;border:none;background:transparent;color:var(--color-text);font-size:1.1rem;font-weight:800;cursor:pointer;display:grid;place-items:center;font-family:var(--font-ui)}
.qty button:hover{background:var(--pink-soft);color:var(--pink)}
.qty button[disabled]{opacity:.35;cursor:not-allowed}
.qty span{min-width:28px;text-align:center;font-weight:800;font-size:var(--text-sm);font-variant-numeric:tabular-nums}

.cart{position:sticky;top:96px;background:var(--surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--space-3)}
@media (max-width:979px){.cart{position:relative;top:auto}}
.cart h3{font-family:var(--font-display);font-size:var(--text-xl);margin:0;color:var(--color-text)}
.cart-empty{padding:var(--space-4);border-radius:var(--radius-md);background:var(--surface-2);color:var(--color-text-muted);font-size:var(--text-sm);text-align:center}
.cart-lines{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3);max-height:280px;overflow-y:auto}
.cart-line{display:grid;grid-template-columns:1fr auto;gap:var(--space-2);font-size:var(--text-sm);padding:var(--space-3);border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--color-border)}
.cart-line .cl-name{font-weight:800;color:var(--color-text)}
.cart-line .cl-meta{color:var(--color-text-muted);font-size:var(--text-xs);margin-top:.2rem}
.cart-line .cl-amount{font-weight:800;color:var(--color-text);font-variant-numeric:tabular-nums;text-align:right}
.cart-line--comp{background:transparent;border:1px dashed var(--color-border);font-style:italic}
.cart-line--comp .cl-name,.cart-line--comp .cl-amount{font-weight:600;color:var(--color-text-muted)}
.alc-group-note{font-size:var(--text-xs);color:var(--color-text-muted);margin:.6rem 0 0;padding:.5rem .75rem;border-left:2px solid var(--color-border);font-style:italic}
.cart-totals{display:grid;gap:.4rem;padding:var(--space-3) 0;border-top:1px solid var(--color-divider);font-size:var(--text-sm)}
.cart-totals .cart-row{display:flex;justify-content:space-between;align-items:baseline;color:var(--color-text-muted)}
.cart-totals .cart-row.total{font-size:var(--text-lg);font-weight:800;color:var(--color-text);border-top:1px dashed var(--color-divider);padding-top:.6rem;margin-top:.2rem}
.cart-totals .cart-row strong{font-variant-numeric:tabular-nums;color:var(--color-text);font-weight:800}
.cart-impact{padding:var(--space-3);border-radius:var(--radius-md);background:var(--pink-soft);color:var(--pink);font-size:var(--text-sm);font-weight:700;line-height:1.45}
.cart-gate{padding:var(--space-3);border-radius:var(--radius-md);background:var(--surface-2);border:1px dashed var(--color-border);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:700;line-height:1.45}
.cart-gate.is-met{background:rgba(67,122,34,.10);border-color:rgba(67,122,34,.3);color:#2a6a1d;border-style:solid}
[data-theme="dark"] .cart-gate.is-met{color:#a8e09c;background:rgba(67,122,34,.18)}

.buyer{margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--color-divider)}
.buyer h3{font-family:var(--font-display);font-size:var(--text-xl);margin:0 0 var(--space-4);color:var(--color-text)}
.buyer-grid{display:grid;gap:var(--space-3)}
@media (min-width:640px){.buyer-grid{grid-template-columns:repeat(2,1fr)}}
.buyer-grid label{display:flex;flex-direction:column;gap:.4rem;font-size:var(--text-sm);font-weight:700}
.buyer-grid label.full{grid-column:1/-1}
.buyer-grid input,.buyer-grid select,.buyer-grid textarea{width:100%;padding:.85rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--surface);color:var(--color-text);font:inherit;transition:border-color var(--transition),box-shadow var(--transition)}
.buyer-grid input:focus,.buyer-grid select:focus,.buyer-grid textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 4px var(--pink-soft)}
.form-status{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:700;display:none}
.form-status.is-success{display:block;background:rgba(67,122,34,.12);color:#2a6a1d;border:1px solid rgba(67,122,34,.3)}
.form-status.is-error{display:block;background:rgba(192,57,43,.10);color:#9a2222;border:1px solid rgba(192,57,43,.3)}
.form-status.is-info{display:block;background:var(--pink-soft);color:var(--pink-deep);border:1px solid var(--pink)}
[data-theme="dark"] .form-status.is-success{color:#a8e09c}
[data-theme="dark"] .form-status.is-error{color:#f4a4a4}
.submit-row{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-5);align-items:center}
.submit-row .btn[disabled],.submit-row .btn[aria-busy="true"]{opacity:.55;cursor:not-allowed;transform:none;box-shadow:var(--shadow-sm)}
.submit-row small{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:700}
.spinner{width:14px;height:14px;border-radius:50%;border:2px solid currentColor;border-right-color:transparent;display:inline-block;margin-right:.5rem;vertical-align:-2px;animation:cl-spin .8s linear infinite}
@keyframes cl-spin{to{transform:rotate(360deg)}}

/* =========================================================
   COMMUNITY / GIVING
   ========================================================= */
.community{background:linear-gradient(135deg, var(--pink) 0%, var(--pink-deep) 100%);color:#fff;position:relative;overflow:hidden}
[data-theme="dark"] .community{background:linear-gradient(135deg, #4a1c42 0%, #2c0e27 100%)}
.community::before{content:"";position:absolute;top:-30%;right:-15%;width:60vw;height:60vw;background:radial-gradient(circle, rgba(255,255,255,.15) 0%, transparent 60%);pointer-events:none}
.community .shell{position:relative;z-index:1}
.community .eyebrow{background:rgba(255,255,255,.15);color:#fff;backdrop-filter:blur(8px)}
.community h2{color:#fff;margin-bottom:var(--space-4)}
.community .lede{font-size:var(--text-lg);opacity:.92;max-width:60ch;margin-bottom:var(--space-6);line-height:1.55}
.impact-grid{display:grid;gap:var(--space-4);grid-template-columns:1fr}
@media (min-width:680px){.impact-grid{grid-template-columns:repeat(3,1fr)}}
.impact-card{padding:var(--space-5);background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.20);border-radius:var(--radius-lg);backdrop-filter:blur(12px)}
.impact-card strong.big{display:block;font-family:var(--font-display);font-size:3rem;line-height:1;color:#fff;margin-bottom:.4rem}
.impact-card span.label{display:block;font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;opacity:.85;margin-bottom:var(--space-3)}
.impact-card p{font-size:var(--text-sm);opacity:.92;line-height:1.55;margin:0}

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testimonials{background:var(--surface)}
.test-grid{display:grid;gap:var(--space-5);grid-template-columns:1fr}
@media (min-width:760px){.test-grid{grid-template-columns:repeat(2,1fr)}}
.test-card{padding:var(--space-5);background:var(--surface-2);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3)}
.test-card blockquote{margin:0;font-family:var(--font-display);font-size:var(--text-lg);font-style:italic;color:var(--color-text);line-height:1.45}
.test-card blockquote::before{content:"\201C";font-family:var(--font-display);color:var(--pink);font-size:3rem;display:block;line-height:.6;margin-bottom:.5rem}
.test-card cite{display:flex;flex-direction:column;font-style:normal}
.test-card cite strong{font-family:var(--font-ui);font-weight:800;font-size:var(--text-sm);color:var(--color-text)}
.test-card cite span{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--cream);border-top:1px solid var(--color-border);padding:var(--space-7) 0 var(--space-5)}
.footer-grid{display:grid;gap:var(--space-5)}
@media (min-width:780px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr}}
.footer h4{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-3)}
.footer-brand p{color:var(--color-text-muted);font-size:var(--text-sm);max-width:42ch;line-height:1.55}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.footer a{color:var(--color-text);font-size:var(--text-sm);font-weight:600}
.footer a:hover{color:var(--pink)}
.footer-meta{color:var(--color-text-muted);font-weight:600;font-size:var(--text-sm)}
.footer-bottom{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--color-divider);display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);font-weight:600}
.heart{color:var(--pink)}

/* =========================================================
   UTIL
   ========================================================= */
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}
::selection{background:var(--pink);color:#fff}
[data-theme="dark"] ::selection{color:#1a0f17}
:focus-visible{outline:3px solid var(--pink);outline-offset:2px;border-radius:var(--radius-sm)}

/* =========================================================
   V2 · Step-based ordering · Mode chips · Variety breakdown
   Confirmation card
   ========================================================= */
.step{display:grid;grid-template-columns:48px 1fr;gap:var(--space-3);margin:var(--space-5) 0;align-items:start}
.step-num{width:36px;height:36px;border-radius:999px;background:var(--pink);color:#fff;font-weight:800;font-family:var(--font-display);font-size:1.1rem;display:grid;place-items:center;margin-top:4px;box-shadow:0 4px 12px rgba(176,62,160,.25)}
.step-body{min-width:0}
.step-title{font-family:var(--font-display);font-weight:600;font-size:clamp(1.25rem,2vw,1.55rem);margin:0 0 .25rem;color:var(--color-text)}
.step-sub{margin:0 0 var(--space-3);color:var(--color-text-muted);font-size:.95rem}
.step-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3)}
.opt{font-weight:400;color:var(--color-text-muted);font-size:.85em}

/* Mode chips */
.mode-chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-2);margin-bottom:var(--space-3)}
.mode-chip{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:var(--space-3);border:2px solid var(--color-divider);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;text-align:left;transition:all .18s ease;font:inherit}
.mode-chip:hover{border-color:var(--pink);transform:translateY(-1px)}
.mode-chip.is-active{border-color:var(--pink);background:linear-gradient(135deg, rgba(176,62,160,.08), rgba(176,62,160,.02));box-shadow:0 6px 18px rgba(176,62,160,.18)}
.mode-label{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--color-text)}
.mode-sub{font-size:.85rem;color:var(--color-text-muted)}

/* Variety breakdown card */
.variety-card{background:linear-gradient(135deg, rgba(176,62,160,.06), rgba(176,62,160,.01));border:1px solid rgba(176,62,160,.18);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-3)}
.variety-head{margin-bottom:var(--space-2)}
.vh-eyebrow{display:block;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--pink);margin-bottom:4px}
.variety-head h4{font-family:var(--font-display);font-weight:600;font-size:1.15rem;margin:0;color:var(--color-text)}
.variety-list{list-style:none;padding:0;margin:0 0 var(--space-2);display:grid;gap:.4rem}
.variety-list li{display:flex;align-items:center;gap:.6rem;font-size:1rem;color:var(--color-text)}
.qty-pill{display:inline-grid;place-items:center;min-width:32px;height:32px;padding:0 10px;border-radius:999px;background:var(--pink);color:#fff;font-weight:700;font-family:var(--font-display);font-size:.95rem}
.variety-foot{margin:var(--space-2) 0 0;font-size:.9rem;color:var(--color-text-muted)}

/* Variety sides toggle */
.side-mode-toggle{border:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.side-mode-toggle legend{font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin-right:.5rem;padding:0}
.side-mode-toggle .radio{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem;color:var(--color-text);cursor:pointer}
.side-mode-toggle select{padding:.4rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--color-divider);background:var(--color-surface);font:inherit}
.side-mode-toggle select:disabled{opacity:.5;cursor:not-allowed}

/* Chef's Pick card */
.chefs-pick-card{background:linear-gradient(135deg, rgba(176,62,160,.08), rgba(176,62,160,.02));border:1px solid rgba(176,62,160,.18);border-radius:var(--radius-md);padding:var(--space-4)}
.cp-eyebrow{display:block;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--pink);margin-bottom:.4rem}
.chefs-pick-card h4{font-family:var(--font-display);font-weight:600;font-size:1.3rem;margin:0 0 .5rem;color:var(--color-text)}
.cp-desc,.cp-side,.cp-note,.cp-foot{margin:.4rem 0;color:var(--color-text);font-size:.95rem}
.cp-note{color:var(--color-text-muted);font-style:italic}
.cp-foot{font-size:.85rem;color:var(--color-text-muted)}

/* All-One grid */
.allone-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3);margin-bottom:var(--space-2)}
.allone-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:600;color:var(--color-text)}
.allone-grid select{padding:.6rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--color-divider);background:var(--color-surface);font:inherit;font-weight:400}
.allone-note{font-size:.9rem;color:var(--color-text-muted);margin:0}

/* Cart line · mode badge */
.cl-mode{display:inline-block;margin-left:.4rem;padding:2px 8px;background:rgba(176,62,160,.12);color:var(--pink);border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;vertical-align:middle}

/* Confirmation card */
.confirm-card{background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--radius-md);padding:var(--space-5);box-shadow:0 12px 36px rgba(0,0,0,.08);max-width:720px;margin:0 auto}
.confirm-inner{text-align:center}
.confirm-check{width:64px;height:64px;border-radius:999px;background:linear-gradient(135deg, #2da44e, #1a7f37);color:#fff;font-size:2rem;display:grid;place-items:center;margin:0 auto var(--space-3);box-shadow:0 8px 24px rgba(45,164,78,.3)}
.confirm-title{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,3vw,2rem);margin:0 0 .5rem;color:var(--color-text)}
.confirm-id{margin:0 0 var(--space-4);color:var(--color-text-muted);font-size:.95rem}
.confirm-id strong{color:var(--pink);font-family:var(--font-display);letter-spacing:.04em}
.confirm-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3);margin:var(--space-4) 0;padding:var(--space-3);background:linear-gradient(135deg, rgba(176,62,160,.04), rgba(176,62,160,.01));border-radius:var(--radius-sm)}
.confirm-summary>div{display:flex;flex-direction:column;gap:.2rem}
.confirm-summary span{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}
.confirm-summary strong{font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--color-text)}
.confirm-breakdown{margin:var(--space-4) 0;padding:var(--space-3);background:var(--color-bg);border-radius:var(--radius-sm);text-align:left}
.confirm-breakdown h4{font-family:var(--font-display);font-weight:600;font-size:1rem;margin:0 0 var(--space-2);color:var(--color-text)}
.confirm-breakdown p{margin:var(--space-2) 0 0;font-size:.85rem;color:var(--color-text-muted)}
.confirm-next{margin:var(--space-3) 0;color:var(--color-text);font-size:.95rem;line-height:1.55}
.confirm-next a{color:var(--pink);font-weight:600;text-decoration:underline}
.btn.ghost{background:transparent;border:2px solid var(--pink);color:var(--pink);padding:.7rem 1.4rem;border-radius:var(--radius-sm);font-weight:700;cursor:pointer;font:inherit;transition:all .18s}
.btn.ghost:hover{background:var(--pink);color:#fff}

/* Step grid responsiveness */
@media (max-width: 640px){
  .step{grid-template-columns:36px 1fr;gap:var(--space-2)}
  .step-num{width:32px;height:32px;font-size:1rem}
  .mode-chips{grid-template-columns:1fr 1fr}
  .confirm-summary{grid-template-columns:1fr 1fr}
}

/* =========================================================
   V2 polish · mobile fixes
   ========================================================= */
/* Step 1 inputs full-width, label as block */
.step-grid label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;font-weight:700;color:var(--color-text)}
.step-grid input,.step-grid select{width:100%;padding:.7rem .85rem;border-radius:var(--radius-sm);border:1px solid var(--color-divider);background:var(--color-surface);color:var(--color-text);font:inherit;font-weight:500;transition:border-color .18s,box-shadow .18s}
.step-grid input:focus,.step-grid select:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(176,62,160,.18)}
.step-grid small{font-size:.78rem;color:var(--color-text-muted);font-weight:400}

/* À la carte items — give text more breathing room on narrow screens */
@media (max-width: 540px){
  .alc-item{grid-template-columns:1fr;gap:var(--space-2);padding:var(--space-3)}
  .alc-item .qty{justify-self:start;margin-top:.5rem}
  .alc-item .alc-name{font-size:1rem}
  .alc-item .alc-desc{font-size:.85rem}
}

/* Cart line metadata — let text wrap and not get clipped */
.cart-line .cl-meta{word-wrap:break-word;overflow-wrap:anywhere;line-height:1.45}

/* Mode chips stay 2-up on small phones */
@media (max-width: 480px){
  .mode-chips{grid-template-columns:1fr 1fr}
  .mode-chip{padding:var(--space-2)}
  .mode-label{font-size:.95rem}
  .mode-sub{font-size:.78rem}
}


/* =====================================================
   Order builder · à la carte groups now collapsible
   ===================================================== */
details.alc-group{border-top:1px solid var(--color-border)}
details.alc-group:first-child{border-top:none;margin-top:0}
details.alc-group>summary.alc-summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) 0;margin-bottom:var(--space-2);user-select:none}
details.alc-group>summary.alc-summary::-webkit-details-marker{display:none}
details.alc-group>summary.alc-summary h4{margin:0}
details.alc-group>summary.alc-summary::after{content:"\25BE";margin-left:auto;color:var(--color-text-muted);transition:transform var(--transition)}
details.alc-group[open]>summary.alc-summary::after{transform:rotate(180deg)}
details.alc-group>summary.alc-summary:hover h4{color:var(--pink)}


/* À la carte group count badge — secondary confirmation signal */
.alc-count{
  display:inline-flex;
  align-items:center;
  margin-left:var(--space-2);
  padding:.12rem .55rem;
  border-radius:var(--radius-full);
  background:var(--pink-soft);
  color:var(--pink-deep);
  font-family:var(--font-ui);
  font-size:var(--text-xs);
  font-weight:700;
  line-height:1.5;
  letter-spacing:.01em;
  white-space:nowrap;
}
.alc-count[hidden]{display:none}


/* =========================================================
   À la carte sandwiches — lighter post-$250 block
   Sits below the main Step 3 charcuterie/sides/dessert.
   Secondary hierarchy: smaller heading, muted, locked < $250.
   ========================================================= */
.order-subtle-divider{
  border:0;
  border-top:1px dashed var(--color-border);
  margin:var(--space-5) 0 var(--space-4);
  opacity:.7;
}
.order-ala-carte.note-block{
  margin-top:var(--space-4);
  padding:var(--space-4);
  border:1px dashed var(--color-border);
  border-radius:var(--radius-lg);
  background:color-mix(in srgb, var(--surface) 70%, transparent);
}
.order-ala-carte .eyebrow-small{
  display:inline-block;
  margin:0 0 .35rem;
  padding:.1rem .55rem;
  font-family:var(--font-ui);
  font-size:var(--text-xs);
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--pink-deep);
  background:var(--pink-soft);
  border-radius:var(--radius-full);
}
.order-ala-carte h4{
  margin:.15rem 0 .35rem;
  font-family:var(--font-display);
  font-size:var(--text-base);
  font-weight:700;
  color:var(--color-text);
  letter-spacing:.005em;
}
.order-ala-carte .muted{
  margin:0 0 var(--space-3);
  color:var(--color-text-muted);
  font-size:var(--text-sm);
  line-height:1.5;
}
.ala-carte-sand-grid{
  display:grid;
  gap:var(--space-2);
}
@media (min-width:560px){
  .ala-carte-sand-grid{grid-template-columns:repeat(2,1fr)}
}
.ala-carte-sand-item{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:var(--space-3);
  padding:.55rem .75rem;
  border:1px solid var(--color-border);
  border-radius:var(--radius-md);
  background:var(--surface);
  transition:opacity .15s ease, background .15s ease;
}
.ala-carte-sand-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.ala-carte-sand-name{
  font-family:var(--font-ui);
  font-weight:700;
  font-size:var(--text-sm);
  color:var(--color-text);
  line-height:1.3;
}
.ala-carte-sand-price{
  font-family:var(--font-ui);
  font-weight:700;
  font-size:var(--text-xs);
  color:var(--pink);
  letter-spacing:.01em;
}
.ala-carte-helper{
  margin:var(--space-3) 0 0;
  font-size:var(--text-xs);
  color:var(--color-text-muted);
  font-style:italic;
}
.ala-carte-helper[hidden]{display:none}

/* Locked state — block is visible but disabled below $250 */
.order-ala-carte.is-locked{
  opacity:.78;
}
.order-ala-carte.is-locked .ala-carte-sand-item{
  background:color-mix(in srgb, var(--surface) 60%, transparent);
}
.order-ala-carte.is-locked .ala-carte-sand-qty button{
  cursor:not-allowed;
  opacity:.5;
}

/* =========================================================
   FAQ — accordion between Order and Giving
   ========================================================= */
.faq.section{background:transparent}
.faq .section-head{margin-bottom:var(--space-5)}
.faq-list{
  display:grid;
  gap:var(--space-2);
  max-width:780px;
  margin:0 auto;
}
.faq-item{
  border:1px solid var(--color-border);
  border-radius:var(--radius-lg);
  background:var(--surface);
  overflow:hidden;
  transition:border-color .15s ease, background .15s ease;
}
.faq-item[open]{
  border-color:color-mix(in srgb, var(--pink) 40%, var(--color-border));
}
.faq-item > summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-3);
  padding:var(--space-4) var(--space-4);
  min-height:48px;
  font-family:var(--font-ui);
  font-weight:700;
  color:var(--color-text);
}
.faq-item > summary::-webkit-details-marker{display:none}
.faq-item > summary:hover{background:color-mix(in srgb, var(--pink-soft) 35%, var(--surface))}
.faq-item > summary:focus-visible{outline:2px solid var(--pink);outline-offset:2px}
.faq-q{
  font-size:var(--text-base);
  line-height:1.35;
  flex:1 1 auto;
}
.faq-chev{
  flex:0 0 auto;
  width:28px;
  height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:var(--radius-full);
  background:var(--pink-soft);
  color:var(--pink-deep);
  font-size:1.1rem;
  font-weight:800;
  line-height:1;
  position:relative;
}
.faq-chev::before,
.faq-chev::after{
  content:"";
  position:absolute;
  background:currentColor;
  border-radius:2px;
  transition:transform .2s ease, opacity .2s ease;
}
.faq-chev::before{width:12px;height:2px}
.faq-chev::after{width:2px;height:12px}
.faq-item[open] .faq-chev::after{transform:scaleY(0);opacity:0}
.faq-a{
  padding:0 var(--space-4) var(--space-4);
  color:var(--color-text-muted);
  font-size:var(--text-sm);
  line-height:1.6;
}
.faq-a p{margin:0}

@media (max-width:560px){
  .faq-item > summary{padding:.9rem 1rem}
  .faq-q{font-size:var(--text-sm)}
  .faq-a{padding:0 1rem 1rem;font-size:var(--text-sm)}
}


/* =========================================================
   Cart gate — stacked unlock callout when $250 minimum is met
   ========================================================= */
.cart-gate.is-met{display:flex;flex-direction:column;gap:.4rem}
.cart-gate .gate-line{display:block;line-height:1.45}
.cart-gate .gate-line-primary{font-weight:700}
.cart-gate .gate-line-unlock{
  font-family:var(--font-ui);
  font-size:var(--text-xs);
  font-weight:600;
  color:var(--pink-deep);
  letter-spacing:.005em;
  opacity:.95;
}


/* =========================================================
   Step 3 inline progress hint
   ========================================================= */
.step-progress{
  margin:.25rem 0 var(--space-3);
  padding:.5rem .75rem;
  border-radius:var(--radius-md);
  font-family:var(--font-ui);
  font-size:var(--text-sm);
  line-height:1.4;
  display:none;
}
.step-progress:not(:empty){display:block}
.step-progress strong{font-weight:700}
.step-progress.is-under{
  background:color-mix(in srgb, var(--pink-soft) 60%, transparent);
  color:var(--pink-deep);
  border:1px solid color-mix(in srgb, var(--pink) 25%, transparent);
}
.step-progress.is-met{
  background:color-mix(in srgb, #d9efd9 60%, transparent);
  color:#1f5b2a;
  border:1px solid color-mix(in srgb, #1f5b2a 18%, transparent);
}


/* =========================================================
   Cart restore banner (shown above the order form when a
   meaningful draft is found in localStorage)
   ========================================================= */
.order-restore{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-3);
  padding:var(--space-3) var(--space-4);
  margin-bottom:var(--space-3);
  background:color-mix(in srgb, var(--pink-soft) 70%, var(--surface));
  border:1px solid color-mix(in srgb, var(--pink) 35%, transparent);
  border-radius:var(--radius-lg);
}
.order-restore[hidden]{display:none}
.order-restore-body{flex:1 1 260px;min-width:0}
.order-restore-title{
  margin:0 0 .15rem;
  font-family:var(--font-ui);
  font-weight:700;
  font-size:var(--text-base);
  color:var(--color-text);
}
.order-restore-summary{
  margin:0;
  font-family:var(--font-ui);
  font-size:var(--text-sm);
  color:var(--color-text-muted);
  line-height:1.4;
}
.order-restore-summary strong{color:var(--color-text);font-weight:700}
.order-restore-actions{
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-2);
  flex:0 0 auto;
}
.order-restore-actions .btn{padding:.55rem 1rem;font-size:var(--text-sm)}
@media (max-width:560px){
  .order-restore{flex-direction:column;align-items:stretch}
  .order-restore-actions{justify-content:stretch}
  .order-restore-actions .btn{flex:1 1 0}
}

/* Delivery date picker — fresh-window hint under the date select */
.delivery-window-note {
  display: block;
  margin-top: 6px;
  font-size: 13px;
  color: var(--ink-3, #6b7280);
  line-height: 1.4;
}
.delivery-window-note strong {
  color: var(--ink-1, #111);
  font-weight: 600;
}

/* =========================================================
   PRINT RECEIPT
   - Hidden on screen by default
   - Confirm card gets a side-by-side action row for the print + new-order buttons
   - @media print: show only the receipt, suppress everything else, black on white
   ========================================================= */

#print-receipt {
  display: none;
}

.confirm-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.confirm-actions .btn { flex: 0 1 auto; }

@media print {
  /* Hide every layer except the receipt itself.
     Use display:none so non-receipt content doesn't reserve page space
     (visibility:hidden was causing 12 blank trailing pages). */
  body > *:not(#print-receipt) { display: none !important; }

  /* Reset page chrome */
  html, body {
    background: #fff !important;
    color: #111 !important;
    margin: 0 !important;
    padding: 0 !important;
    height: auto !important;
    overflow: visible !important;
  }

  /* Show the receipt as the sole page content */
  #print-receipt {
    display: block !important;
    position: static !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    background: #fff !important;
    color: #111 !important;
    font-family: Georgia, 'Times New Roman', serif !important;
  }

  .receipt-wrap {
    box-sizing: border-box;
    width: 100%;
    max-width: 7.5in;
    margin: 0 auto;
    padding: 0.5in 0.6in;
    font-size: 11pt;
    line-height: 1.5;
  }

  .receipt-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    border-bottom: 2px solid #111;
    padding-bottom: 12px;
    margin-bottom: 18px;
  }
  .receipt-logo {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 24pt;
    font-weight: 700;
    letter-spacing: 0.5px;
    color: #111;
  }
  .receipt-tag {
    font-size: 9.5pt;
    color: #444;
    margin-top: 2px;
    font-style: italic;
  }
  .receipt-meta {
    font-size: 10pt;
    text-align: right;
    color: #222;
  }
  .receipt-meta div { margin-bottom: 3px; }
  .receipt-meta strong { display: inline-block; min-width: 56px; }

  .receipt-block { margin: 14px 0; page-break-inside: avoid; }
  .receipt-h {
    font-size: 11pt;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #111;
    border-bottom: 1px solid #999;
    padding-bottom: 4px;
    margin: 0 0 8px 0;
  }

  .receipt-kv {
    width: 100%;
    border-collapse: collapse;
  }
  .receipt-kv th {
    text-align: left;
    font-weight: 600;
    width: 32%;
    padding: 3px 8px 3px 0;
    color: #333;
    font-size: 10pt;
    vertical-align: top;
  }
  .receipt-kv td {
    padding: 3px 0;
    color: #111;
    font-size: 10.5pt;
  }

  .receipt-items {
    width: 100%;
    border-collapse: collapse;
    margin-top: 4px;
  }
  .receipt-items thead th {
    text-align: left;
    font-size: 9pt;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 6px 4px;
    border-bottom: 1.5px solid #111;
    color: #111;
  }
  .receipt-items tbody td {
    padding: 8px 4px;
    border-bottom: 1px dotted #bbb;
    vertical-align: top;
    font-size: 10.5pt;
  }
  .receipt-items td:first-child {
    width: 36px;
    font-weight: 700;
  }
  .r-num {
    text-align: right;
    white-space: nowrap;
  }
  .r-name { font-weight: 600; }
  .r-sub  { font-size: 9pt; color: #555; margin-top: 2px; font-style: italic; }

  .receipt-totals {
    margin-top: 18px;
    border-top: 2px solid #111;
    padding-top: 10px;
  }
  .receipt-money th { text-align: left; font-weight: 500; padding: 3px 0; color: #333; }
  .receipt-money td { text-align: right; font-weight: 600; padding: 3px 0; color: #111; }
  .receipt-money .r-total th,
  .receipt-money .r-total td {
    font-size: 12pt;
    font-weight: 700;
    padding: 6px 0;
    border-top: 1px solid #888;
    border-bottom: 1px solid #888;
    color: #111;
  }

  .receipt-footer {
    margin-top: 28px;
    padding-top: 12px;
    border-top: 1px solid #999;
    font-size: 9.5pt;
    color: #444;
    line-height: 1.55;
  }
  .receipt-footer p { margin: 4px 0; }
  .receipt-fineprint { font-size: 8.5pt; color: #666; margin-top: 8px !important; }

  /* Prevent any link decoration ink waste */
  #print-receipt a { color: #111 !important; text-decoration: none !important; }

  @page {
    size: letter;
    margin: 0.4in;
  }
}


/* ============================================================
   VEGGIE PLATTER v2 — inline expand inside menu
   ============================================================ */

/* Menu collapse behavior (sandwiches + sides) */
.menu-list.js-collapse[data-collapsed="true"] > .menu-item:nth-child(n+4) {
  display: none;
}
.menu-more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 8px 0 18px;
  background: transparent;
  border: 1px solid rgba(204,123,140,.35);
  color: var(--brand-pink, #cc7b8c);
  padding: 8px 16px;
  border-radius: 999px;
  font: 600 13px/1 'Inter', system-ui, sans-serif;
  letter-spacing: .02em;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.menu-more:hover { background: rgba(204,123,140,.08); }
.menu-more .chev { display: inline-block; transition: transform .2s ease; font-size: 11px; }
.menu-more[aria-expanded="true"] .chev { transform: rotate(180deg); }

/* Veggie row — single menu-item, full-width clickable toggle */
#veggie-row { margin-bottom: 0; }
.veg-item { padding: 0; border: none; }
.veg-toggle {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  border-top: 1px solid rgba(0,0,0,.08);
  padding: 18px 0;
  cursor: pointer;
  font: inherit;
  color: inherit;
}
.veg-toggle:hover { background: rgba(0,0,0,.015); }
.veg-toggle h4 { margin: 0 0 4px; font: 600 17px/1.3 'Playfair Display', Georgia, serif; }
.veg-toggle p { margin: 0; color: rgba(0,0,0,.62); font-size: 14px; line-height: 1.45; max-width: 56ch; }
.veg-toggle-meta { display: inline-flex; align-items: center; gap: 10px; flex-shrink: 0; }
.veg-toggle-meta .price { font: 600 16px/1 'Inter', sans-serif; }
.veg-toggle-meta .chev { display: inline-block; transition: transform .2s ease; color: var(--brand-pink, #cc7b8c); font-size: 14px; }
.veg-toggle[aria-expanded="true"] .chev { transform: rotate(180deg); }
.veg-toggle[aria-expanded="true"] { background: rgba(0,0,0,.02); }


/* ============================================================
   Chef Lesly Chalkboard — Veggie Platter expanded state
   Green slate, chalk-on-board treatment. No gray utility boxes.
   ============================================================ */
.veg-panel {
  /* Deep black chalkboard — match the masthead artwork board */
  --chalk: #f5efe2;
  --chalk-soft: rgba(245,239,226,.78);
  --chalk-faint: rgba(245,239,226,.55);
  --chalk-line: rgba(245,239,226,.22);
  --chalk-pink: #f3b5c3;     /* warm chalk-pink accent (echoes brand-pink) */
  --chalk-mint: #b6e6c2;     /* asparagus accent */
  --board: #0a0a0a;          /* deep black slate */
  --board-deep: #000;

  position: relative;
  background-color: var(--board);
  color: var(--chalk);
  border-radius: 16px;
  margin: 0 -8px 22px;
  overflow: hidden;
  box-shadow:
    0 22px 60px rgba(0,0,0,.35),
    inset 0 0 0 1px rgba(245,239,226,.05),
    inset 0 0 80px rgba(0,0,0,.55);

  background-image:
    /* corner vignettes for slate depth */
    radial-gradient(ellipse 70% 40% at 20% 0%, rgba(245,239,226,.05), transparent 60%),
    radial-gradient(ellipse 60% 50% at 85% 100%, rgba(0,0,0,.55), transparent 65%),
    radial-gradient(ellipse 50% 60% at 10% 100%, rgba(0,0,0,.40), transparent 60%),
    /* faint horizontal chalk-streak grain */
    repeating-linear-gradient(2deg, rgba(245,239,226,.012) 0 2px, transparent 2px 6px),
    /* soft board gradient */
    linear-gradient(180deg, #141414 0%, #0a0a0a 45%, #050505 100%);
}
.veg-panel::before {
  /* wooden frame edge highlight */
  content: "";
  position: absolute; inset: 0;
  border-radius: 16px;
  pointer-events: none;
  box-shadow:
    inset 0 0 0 1px rgba(245,239,226,.12),
    inset 0 0 0 6px rgba(0,0,0,.18);
}
.veg-panel::after {
  /* chalk dust at the bottom edge */
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 38px;
  pointer-events: none;
  background:
    radial-gradient(ellipse 60% 100% at 30% 100%, rgba(245,239,226,.10), transparent 70%),
    radial-gradient(ellipse 40% 100% at 75% 100%, rgba(245,239,226,.06), transparent 70%);
  filter: blur(2px);
}
.veg-panel[hidden] { display: none !important; }
.veg-panel-inner { position: relative; padding: 0 30px 28px; }

/* Masthead — blend into chalkboard */
.veg-mast {
  position: relative;
  margin: 0 -30px 4px;
  background: #000;
  overflow: hidden;
}
.veg-mast img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 300px;
  object-fit: cover;
  opacity: .95;
}
.veg-mast-fade {
  position: absolute; left: 0; right: 0; bottom: -1px;
  height: 90px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(10,10,10,0) 0%, rgba(10,10,10,.55) 55%, var(--board) 100%);
}

/* Lede + chalk label */
.veg-lede {
  font: 400 15.5px/1.6 'Manrope', system-ui, sans-serif;
  color: var(--chalk-soft);
  margin: 18px 0 22px;
  max-width: 60ch;
  letter-spacing: .005em;
}
.veg-chalk-label {
  display: inline-block;
  font: 600 13px/1 'Caveat', 'Playfair Display', cursive;
  font-style: italic;
  color: var(--chalk-pink);
  letter-spacing: .04em;
  margin-right: 10px;
  transform: translateY(-2px);
  font-size: 18px;
}

/* Section labels in chalk handwriting */
.veg-section-label {
  display: block;
  font: 600 22px/1.1 'Caveat', cursive;
  color: var(--chalk);
  margin: 0 0 10px;
  letter-spacing: .01em;
}

/* Platter option cards — chalkboard tiles, no gray fills */
.veg-opts {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 0 0 22px;
}
.veg-opt {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 16px 14px 14px;
  background: rgba(245,239,226,.03);
  border: 1.5px dashed rgba(245,239,226,.28);
  border-radius: 10px;
  color: var(--chalk);
  cursor: pointer;
  font: inherit;
  text-align: left;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.veg-opt:hover {
  background: rgba(245,239,226,.06);
  border-color: rgba(245,239,226,.45);
  transform: translateY(-1px);
}
.veg-opt.is-active {
  background: rgba(243,181,195,.10);
  border: 1.5px solid var(--chalk-pink);
  box-shadow:
    0 0 0 1px rgba(243,181,195,.30),
    0 8px 24px rgba(243,181,195,.10);
}
.veg-opt.is-active::before {
  /* hand-drawn underline accent */
  content: "";
  position: absolute;
  left: 14px; right: 14px; bottom: 6px;
  height: 2px;
  background: linear-gradient(90deg, transparent 0, var(--chalk-pink) 20%, var(--chalk-pink) 80%, transparent 100%);
  opacity: .55;
  border-radius: 2px;
}
.veg-opt-name {
  font: 700 22px/1.05 'Caveat', cursive;
  color: var(--chalk);
  letter-spacing: .005em;
}
.veg-opt-sub {
  font: 400 12px/1.35 'Manrope', sans-serif;
  color: var(--chalk-faint);
}
.veg-opt-price {
  font: 600 17px/1 'Playfair Display', serif;
  margin-top: 6px;
  color: var(--chalk);
}

/* Chosen-5 note and side picker — chalk frames, never gray cards */
.veg-chosen-note,
.veg-pick {
  position: relative;
  background: transparent;
  border: none;
  border-top: 1px dashed var(--chalk-line);
  border-bottom: 1px dashed var(--chalk-line);
  border-radius: 0;
  padding: 16px 4px 18px;
  margin: 0 0 18px;
  font: 400 14px/1.55 'Manrope', sans-serif;
  color: var(--chalk-soft);
}
.veg-pick[hidden] { display: none !important; }
.veg-chosen-note[hidden] { display: none !important; }

.veg-chosen-note::before {
  content: "Lesly's pick";
  display: block;
  font: 600 22px/1 'Caveat', cursive;
  color: var(--chalk-pink);
  margin-bottom: 6px;
}

.veg-pick-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin: 0 0 12px;
}
.veg-pick-label {
  font: 700 24px/1 'Caveat', cursive;
  letter-spacing: .01em;
  color: var(--chalk);
  text-transform: none;
}
.veg-counter {
  font: 600 14px/1 'Caveat', cursive;
  color: var(--chalk-pink);
  font-size: 18px;
}

.veg-sides-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px 18px;
  margin: 4px 0 8px;
}
.veg-side {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 4px;
  background: transparent;
  border: none;
  border-radius: 0;
  cursor: pointer;
  font: 500 18px/1.2 'Caveat', cursive;
  color: var(--chalk);
  transition: color .15s ease, transform .12s ease;
}
.veg-side:hover { color: var(--chalk-pink); transform: translateX(2px); }
.veg-side input[type="checkbox"] {
  appearance: none;
  width: 18px; height: 18px;
  border: 1.5px solid var(--chalk-soft);
  border-radius: 3px;
  background: transparent;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
}
.veg-side input[type="checkbox"]:checked {
  background: var(--chalk-pink);
  border-color: var(--chalk-pink);
}
.veg-side input[type="checkbox"]:checked::after {
  content: "✓";
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -55%);
  color: var(--board-deep);
  font: 700 14px/1 'Manrope', sans-serif;
}
.veg-side.is-checked { color: var(--chalk); }
.veg-side.is-checked .veg-side-name { text-decoration: underline; text-decoration-color: var(--chalk-pink); text-decoration-thickness: 1.5px; text-underline-offset: 3px; }
.veg-side.is-disabled { opacity: .35; cursor: not-allowed; }
.veg-side.is-disabled input { pointer-events: none; }
.veg-side-name { flex: 1; }

.veg-included {
  margin: 10px 0 0;
  font: 400 14px/1.4 'Caveat', cursive;
  color: var(--chalk-faint);
  font-style: italic;
  font-size: 16px;
}

/* Premium add-ons — chalk callout, mint accent. Multiple options, each +$1.50 */
.veg-toggle-tiers {
  font: 500 14px/1.2 'Caveat', cursive;
  color: var(--chalk-mint, #b6e6c2);
  letter-spacing: 0.2px;
}
.veg-premiums {
  margin: 4px 0 20px;
  padding: 14px 16px;
  background: rgba(182,230,194,.05);
  border: 1.5px dashed rgba(182,230,194,.32);
  border-radius: 10px;
}
.veg-premiums-label {
  display: block;
  font: 600 13px/1 'Manrope', sans-serif;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--chalk-mint, #b6e6c2);
  margin-bottom: 10px;
}
.veg-premium-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
@media (min-width: 640px) {
  .veg-premium-list { grid-template-columns: 1fr 1fr; }
}
.veg-premium {
  display: grid;
  grid-template-columns: 22px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: transparent;
  border: 1px solid rgba(182,230,194,.22);
  border-radius: 8px;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease;
}
.veg-premium:hover { background: rgba(182,230,194,.08); border-color: rgba(182,230,194,.45); }
.veg-premium.is-checked { background: rgba(182,230,194,.12); border-color: var(--chalk-mint, #b6e6c2); }
.veg-premium input[type="checkbox"] {
  appearance: none;
  width: 18px; height: 18px;
  border: 1.5px solid var(--chalk-mint, #b6e6c2);
  border-radius: 3px;
  background: transparent;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
}
.veg-premium input[type="checkbox"]:checked {
  background: var(--chalk-mint, #b6e6c2);
  border-color: var(--chalk-mint, #b6e6c2);
}
.veg-premium input[type="checkbox"]:checked::after {
  content: "✓";
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -55%);
  color: var(--board-deep, #14201a);
  font: 700 14px/1 'Manrope', sans-serif;
}
.veg-premium-name {
  font: 600 16px/1.2 'Caveat', cursive;
  color: var(--chalk, #f3efe6);
}
.veg-premium-tag {
  font: 700 12px/1 'Manrope', sans-serif;
  color: var(--chalk-mint, #b6e6c2);
  white-space: nowrap;
}

/* CTA row — qty, subtotal, add button */
.veg-cta-row {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  padding: 18px 0 0;
  border-top: 1px dashed var(--chalk-line);
  margin-top: 4px;
}
.veg-qty {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
}
.veg-qty span {
  font: 500 16px/1 'Caveat', cursive;
  letter-spacing: .02em;
  color: var(--chalk-faint);
  text-transform: none;
}
.veg-qty input {
  width: 80px;
  padding: 10px 12px;
  background: rgba(245,239,226,.04);
  border: 1.5px dashed rgba(245,239,226,.32);
  border-radius: 8px;
  color: var(--chalk);
  font: 700 18px/1 'Playfair Display', serif;
  text-align: center;
}
.veg-qty input:focus {
  outline: none;
  border-color: var(--chalk-pink);
  background: rgba(245,239,226,.07);
}
.veg-total {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  margin-left: auto;
  text-align: right;
}
.veg-total span {
  font: 500 16px/1 'Caveat', cursive;
  letter-spacing: .02em;
  color: var(--chalk-faint);
  text-transform: none;
}
.veg-total strong {
  font: 700 30px/1 'Playfair Display', serif;
  color: var(--chalk);
}

.veg-add {
  padding: 14px 26px;
  background: var(--chalk-pink);
  color: var(--board-deep);
  border: none;
  border-radius: 999px;
  font: 700 15px/1 'Manrope', sans-serif;
  letter-spacing: .03em;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(243,181,195,.22);
  transition: background .15s ease, transform .15s ease, box-shadow .15s ease;
}
.veg-add:hover {
  background: #e89bad;
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(243,181,195,.32);
}
.veg-add:disabled {
  background: rgba(245,239,226,.10);
  color: rgba(245,239,226,.35);
  cursor: not-allowed;
  box-shadow: none;
}

.veg-feedback {
  margin: 14px 0 0;
  padding: 12px 16px;
  background: rgba(182,230,194,.10);
  border: 1.5px dashed rgba(182,230,194,.45);
  border-radius: 10px;
  color: var(--chalk-mint);
  font: 600 16px/1.4 'Caveat', cursive;
  font-size: 18px;
}
.veg-feedback[hidden] { display: none !important; }

/* Toggle row chevron color when expanded */
.veg-toggle[aria-expanded="true"] .chev { color: #4f7a5e; }

/* Mobile */
@media (max-width: 720px) {
  .veg-panel-inner { padding: 0 18px 22px; }
  .veg-mast { margin: 0 -18px 4px; }
  .veg-mast img { max-height: 200px; }
  .veg-opts { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .veg-sides-grid { grid-template-columns: 1fr; gap: 4px 0; }
  .veg-opt-name { font-size: 20px; }
  .veg-cta-row { gap: 12px; }
  .veg-total { margin-left: 0; text-align: left; }
  .veg-total strong { font-size: 26px; }
  .veg-add { flex: 1 1 100%; padding: 14px 22px; }
  .veg-lede { margin-top: 16px; }
}

/* ===== Charcuterie collapsed section (homepage, below testimonials) ===== */
.charcuterie { background: var(--surface); }
.charc-collapse {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--bg, #fff);
  overflow: hidden;
  transition: box-shadow var(--transition), border-color var(--transition);
}
.charc-collapse[open] {
  box-shadow: var(--shadow-md);
  border-color: var(--pink);
}
.charc-summary {
  list-style: none;
  cursor: pointer;
  padding: var(--space-5) var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.charc-summary::-webkit-details-marker { display: none; }
.charc-summary:hover { background: color-mix(in srgb, var(--pink-soft) 35%, transparent); }
.charc-summary:focus-visible { outline: 2px solid var(--pink); outline-offset: 2px; }
.charc-summary-head { display: flex; flex-direction: column; gap: .25rem; }
.charc-summary-head .eyebrow { color: var(--color-text-muted); }
.charc-summary-head h2 { margin: 0; }
.charc-summary-lede { margin: .25rem 0 0; color: var(--color-text-muted); font-size: var(--text-base); }
.charc-chev {
  width: 14px; height: 14px;
  border-right: 2px solid var(--color-text);
  border-bottom: 2px solid var(--color-text);
  transform: rotate(45deg);
  transition: transform var(--transition);
  flex: 0 0 auto;
}
.charc-collapse[open] .charc-chev { transform: rotate(-135deg); }
.charc-body { padding: 0 var(--space-6) var(--space-6); }
@media (max-width: 560px) {
  .charc-summary { padding: var(--space-4); }
  .charc-body { padding: 0 var(--space-4) var(--space-4); }
}

/* ===== Belt-and-suspenders: force charcuterie body hidden when not open ===== */
.charc-collapse:not([open]) > .charc-body {
  display: none !important;
}
.charc-collapse[open] > .charc-body {
  display: block;
}
