/* ==========================================================================
   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-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}
}
