/* ============================================================
   Anyway Fruit — Catering site
   ============================================================ */
:root{
  --orange:#e89739; --orange-deep:#cf7d1d;
  --green:#69a254;  --green-deep:#4f7d3c; --green-ink:#2f5326;
  --yellow:#f6c11f; --yellow-2:#f3cf35;
  --maroon:#793338; --olive:#7b8929;
  --ink:#23201c;    --ink-soft:#5d564d; --ink-faint:#938a7d;
  --cream:#fbf7ef;  --cream-2:#f4ecdc; --cream-3:#efe6d2;
  --paper:#ffffff;
  --line:#ece4d4;
  --shadow-sm:0 6px 18px -10px rgba(35,32,28,.34);
  --shadow:0 22px 50px -24px rgba(35,32,28,.45);
  --shadow-lg:0 40px 80px -30px rgba(35,32,28,.5);
  --r:22px; --r-lg:30px;
  --maxw:1200px;
  --font-d:"Fredoka",system-ui,sans-serif;
  --font-b:"Nunito Sans",system-ui,sans-serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
html,body{margin:0;}
/* accessibility: skip link + keyboard focus ring */
.skip-link{position:absolute;left:8px;top:-60px;z-index:1000;background:var(--green-ink);color:#fff;font-family:var(--font-d);font-weight:600;font-size:15px;padding:12px 20px;border-radius:0 0 14px 14px;text-decoration:none;transition:top .18s ease;}
.skip-link:focus{top:0;outline:3px solid var(--yellow);outline-offset:2px;}
:focus-visible{outline:3px solid var(--green);outline-offset:2px;border-radius:5px;}
#main{scroll-margin-top:90px;}
body{
  font-family:var(--font-b);color:var(--ink);background:var(--cream);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* soft mango header mesh — fades into cream below the fold */
body::before{
  content:"";position:fixed;left:0;right:0;top:0;height:820px;z-index:0;pointer-events:none;
  background:
    radial-gradient(58% 80% at 4% -10%, rgba(105,162,84,.48), transparent 60%),
    radial-gradient(52% 74% at 46% -16%, rgba(246,193,31,.54), transparent 62%),
    radial-gradient(56% 78% at 98% -8%, rgba(232,151,57,.50), transparent 60%),
    radial-gradient(46% 64% at 78% -14%, rgba(121,51,56,.26), transparent 60%);
  -webkit-mask:linear-gradient(180deg, #000 0%, #000 30%, transparent 94%);
          mask:linear-gradient(180deg, #000 0%, #000 30%, transparent 94%);
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
/* keyboard focus visibility (accessibility) */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--green-deep);outline-offset:2px;border-radius:8px;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

h1,h2,h3,h4{font-family:var(--font-d);font-weight:700;letter-spacing:-.01em;margin:0;color:var(--ink);line-height:1.05;}
.eyebrow{
  font-family:var(--font-d);font-weight:600;text-transform:uppercase;
  letter-spacing:.16em;font-size:13px;color:var(--orange-deep);
  display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--orange);border-radius:2px;}
.eyebrow.center{justify-content:center;}
.eyebrow.green{color:var(--green-deep);}
.eyebrow.green::before{background:var(--green);}
.lead{font-size:19px;line-height:1.6;color:var(--ink-soft);}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--font-d);font-weight:500;font-size:17px;cursor:pointer;border:none;
  padding:15px 26px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  white-space:nowrap;
}
.btn .arr{transition:transform .18s ease;}
.btn:hover .arr{transform:translateX(4px);}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 16px 30px -14px rgba(232,151,57,.95);}
.btn-primary:hover{background:var(--orange-deep);box-shadow:0 20px 36px -14px rgba(207,125,29,.95);}
.btn-green{background:var(--green);color:#fff;box-shadow:0 16px 30px -14px rgba(105,162,84,.9);}
.btn-green:hover{background:var(--green-deep);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{background:#000;}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line);}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--green);color:var(--green-deep);}
.btn-white{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm);}
.btn-white:hover{background:var(--cream);}
.btn-lg{font-size:19px;padding:18px 32px;}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:60;background:rgba(251,247,239,.82);
  backdrop-filter:blur(14px);border-bottom:1px solid rgba(35,32,28,.07);
}

/* ---------- site-wide announcement banner ---------- */
.af-announce{position:relative;z-index:70;width:100%;}
.af-announce .afb-inner{max-width:1200px;margin:0 auto;padding:11px 24px;display:flex;align-items:center;justify-content:center;gap:16px;}
.af-announce .afb-msg{font-family:var(--font-d);font-weight:500;font-size:15px;line-height:1.4;text-align:center;}
.af-announce .afb-link{font-weight:700;text-decoration:underline;text-underline-offset:3px;white-space:nowrap;}
.af-announce .afb-x{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:24px;line-height:1;opacity:.65;padding:2px 8px;color:inherit;}
.af-announce .afb-x:hover{opacity:1;}
.af-announce.tone-info{background:var(--green-ink);color:#fff;}
.af-announce.tone-info .afb-link{color:var(--yellow-2);}
.af-announce.tone-good{background:var(--green);color:#fff;}
.af-announce.tone-good .afb-link{color:#fff;}
.af-announce.tone-alert{background:var(--maroon);color:#fff;}
.af-announce.tone-alert .afb-link{color:var(--yellow-2);}
@media (max-width:560px){
  .af-announce .afb-inner{padding:10px 40px 10px 16px;}
  .af-announce .afb-msg{font-size:13.5px;}
}
.nav-in{display:flex;align-items:center;gap:26px;height:80px;}
.nav .logo{flex:none;}
.nav .logo img{height:46px;width:auto;max-width:none;}
.nav .spacer{flex:1;}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a{font-weight:700;font-size:15.5px;color:var(--ink-soft);transition:color .15s ease;position:relative;}
.nav-links a:hover{color:var(--ink);}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;background:var(--orange);border-radius:2px;transform:scaleX(0);transition:transform .2s ease;transform-origin:left;}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-phone{display:flex;align-items:center;gap:8px;font-family:var(--font-d);font-weight:600;font-size:15.5px;color:var(--ink);white-space:nowrap;}
.nav-phone svg{width:17px;height:17px;color:var(--green);}
.nav-cta{font-size:15.5px;padding:12px 22px;}
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:8px;}
.nav-burger span{display:block;width:24px;height:2.4px;background:var(--ink);border-radius:2px;margin:5px 0;transition:.2s;}
.nav-mobile{display:none;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:30px 0 70px;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  padding:8px 8px 8px 16px;border-radius:999px;box-shadow:var(--shadow-sm);font-weight:800;font-size:14px;color:var(--ink-soft);white-space:nowrap;
}
.hero-badge .stars{color:var(--yellow);letter-spacing:1px;font-size:15px;}
.hero-badge .pill{background:var(--green);color:#fff;font-family:var(--font-d);font-weight:500;font-size:13px;padding:5px 12px;border-radius:999px;}
.hero h1{font-size:clamp(40px,5.6vw,72px);line-height:1.0;margin:24px 0 0;text-wrap:balance;}
.hero h1 .u{position:relative;color:var(--green-deep);white-space:nowrap;display:inline-block;}
.hero h1 .u svg{position:absolute;left:0;right:0;bottom:-12px;width:100%;height:14px;}
.hero p.lead{margin:24px 0 0;max-width:42ch;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px;}
.hero-trust{display:flex;align-items:center;gap:22px;margin-top:30px;flex-wrap:wrap;}
.hero-trust .t{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14.5px;color:var(--ink-soft);}
.hero-trust .t svg{width:20px;height:20px;color:var(--green);flex:none;}

/* hero visual collage */
.hero-visual{position:relative;}
.hero-visual .main{
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);
  aspect-ratio:4/5;background:var(--cream-2);transform:rotate(1.4deg);
}
.hero-visual .main img{width:100%;height:100%;object-fit:cover;}
.hero-visual .float{
  position:absolute;background:#fff;border-radius:18px;box-shadow:var(--shadow);
  padding:14px 18px;display:flex;align-items:center;gap:12px;
}
.hero-visual .float.tl{top:18px;left:-26px;transform:rotate(-3deg);}
.hero-visual .float.br{bottom:26px;right:-22px;transform:rotate(2deg);}
.hero-visual .float .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none;color:#fff;font-size:20px;}
.hero-visual .float .big{font-family:var(--font-d);font-weight:700;font-size:22px;line-height:1;white-space:nowrap;}
.hero-visual .float .small{font-size:12.5px;color:var(--ink-faint);font-weight:700;margin-top:3px;white-space:nowrap;}
.hero-blob{position:absolute;z-index:-1;border-radius:50%;filter:blur(8px);opacity:.5;}

/* ---------- marquee trust strip ---------- */
.strip{background:var(--green-ink);color:#fff;padding:20px 0;overflow:hidden;}
.strip-track{display:flex;gap:54px;align-items:center;white-space:nowrap;animation:marq 26s linear infinite;width:max-content;}
.strip-track .it{display:flex;align-items:center;gap:14px;font-family:var(--font-d);font-weight:500;font-size:21px;color:rgba(255,255,255,.92);}
.strip-track .it svg{width:22px;height:22px;color:var(--yellow);}
@keyframes marq{to{transform:translateX(-50%);}}

/* ============================================================
   SECTIONS
   ============================================================ */
section{position:relative;}
.sec{padding:96px 0;}
.sec-head{max-width:680px;}
.sec-head.center{margin:0 auto;text-align:center;}
.sec-head h2{font-size:clamp(32px,4.2vw,52px);margin-top:16px;}
.sec-head p{margin-top:18px;}

/* event types */
.events{background:var(--paper);}
.event-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px;}
.event-card{
  position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:1/1.05;
  box-shadow:var(--shadow-sm);cursor:default;
  transition:transform .25s ease, box-shadow .25s ease;
}
.event-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.event-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.event-card:hover img{transform:scale(1.06);}
.event-card .scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,15,9,.82) 0%,rgba(20,15,9,.25) 48%,rgba(20,15,9,0) 75%);}
.event-card .lab{position:absolute;left:0;right:0;bottom:0;padding:24px;color:#fff;}
.event-card .lab .n{font-family:var(--font-d);font-weight:600;font-size:25px;}
.event-card .lab .d{font-size:14.5px;color:rgba(255,255,255,.82);margin-top:5px;line-height:1.4;font-weight:600;}
.event-card .tagico{position:absolute;top:16px;left:16px;width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.92);display:grid;place-items:center;font-size:20px;box-shadow:0 6px 14px -6px rgba(0,0,0,.4);}

/* formats / what we bring */
.formats{background:var(--cream);}
.format-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:54px;}
.format-card{background:#fff;border-radius:var(--r);padding:26px;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .2s ease, box-shadow .2s ease;}
.format-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.format-card .ic{width:60px;height:60px;border-radius:18px;display:grid;place-items:center;font-size:28px;margin-bottom:18px;}
.format-card h3{font-size:22px;}
.format-card p{font-size:15px;color:var(--ink-soft);line-height:1.5;margin-top:9px;}

/* how it works */
.how{background:var(--green-ink);color:#fff;overflow:hidden;}
.how .eyebrow{color:var(--yellow-2);}
.how .eyebrow::before{background:var(--yellow);}
.how .sec-head h2{color:#fff;}
.how .sec-head p{color:rgba(255,255,255,.78);}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:56px;}
.step{position:relative;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:34px 30px;}
.step .no{font-family:var(--font-d);font-weight:700;font-size:54px;color:var(--yellow);line-height:1;opacity:.95;}
.step h3{color:#fff;font-size:24px;margin-top:14px;}
.step p{color:rgba(255,255,255,.78);font-size:16px;line-height:1.55;margin-top:12px;}
.step .arrow{position:absolute;top:46px;right:-20px;color:rgba(255,255,255,.3);z-index:2;}
.how-grid .step:last-child .arrow{display:none;}

/* why us — split */
.why{background:var(--paper);}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.why-photos{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:16px;}
.why-photos .ph{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);}
.why-photos .ph img{width:100%;height:100%;object-fit:cover;}
.why-photos .ph.tall{grid-row:span 2;}
.why-list{display:flex;flex-direction:column;gap:22px;margin-top:30px;}
.why-item{display:flex;gap:18px;align-items:flex-start;}
.why-item .ic{width:50px;height:50px;border-radius:14px;flex:none;display:grid;place-items:center;font-size:22px;color:#fff;}
.why-item h4{font-size:20px;}
.why-item p{font-size:15.5px;color:var(--ink-soft);line-height:1.5;margin-top:5px;}

/* menu preview */
.menu{background:var(--cream);}
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:50px;}
.menu-card{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s ease, box-shadow .2s ease;}
.menu-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.menu-card .pic{aspect-ratio:1/1;overflow:hidden;background:var(--cream-2);}
.menu-card .pic img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.menu-card:hover .pic img{transform:scale(1.05);}
.menu-card .cap{padding:18px 20px 22px;}
.menu-card .cap .n{font-family:var(--font-d);font-weight:600;font-size:20px;}
.menu-card .cap .d{font-size:13.5px;color:var(--ink-faint);font-weight:700;margin-top:4px;}

/* reviews */
.reviews{background:var(--paper);}
/* live truck locations widget */
.tl-widget{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.tl-card{display:flex;gap:14px;background:#fff;border:1.5px solid var(--line);border-radius:18px;padding:18px 20px;box-shadow:var(--shadow-sm);}
.tl-card.live{border-color:rgba(105,162,84,.5);}
.tl-emoji{font-size:30px;flex:none;line-height:1;}
.tl-body{flex:1;min-width:0;}
.tl-row1{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.tl-name{font-family:var(--font-d);font-weight:600;font-size:17px;color:var(--ink);}
.tl-badge{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-d);font-weight:600;font-size:12.5px;padding:4px 11px;border-radius:999px;white-space:nowrap;}
.tl-badge .d{width:8px;height:8px;border-radius:50%;}
.tl-badge.live{background:rgba(105,162,84,.16);color:var(--green-deep);}
.tl-badge.live .d{background:var(--green);animation:afpulse 2s infinite;}
.tl-badge.enroute{background:rgba(232,151,57,.16);color:#b5641f;}
.tl-badge.enroute .d{background:var(--orange);}
.tl-badge.off{background:rgba(147,138,125,.16);color:var(--ink-soft);}
.tl-badge.sched{background:rgba(105,162,84,.1);color:var(--green-deep);}
.tl-spot{font-size:15.5px;font-weight:800;color:var(--ink);margin-top:9px;line-height:1.4;display:flex;gap:7px;align-items:flex-start;}
.tl-spot .pin{flex:none;}
.tl-hours{font-size:13.5px;font-weight:800;color:var(--green-deep);margin-top:7px;display:flex;align-items:center;gap:6px;}
.tl-hours .clk{font-size:13px;}
.tl-note{font-size:13.5px;font-weight:700;color:var(--ink-soft);margin-top:6px;}
.tl-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;flex-wrap:wrap;}
.tl-upd{font-size:12.5px;font-weight:800;color:var(--ink-faint);}
.tl-dir{font-family:var(--font-d);font-weight:600;font-size:13.5px;color:var(--green-deep);display:inline-flex;align-items:center;gap:5px;white-space:nowrap;}
.tl-dir:hover{color:var(--green-ink);}
@media (max-width:680px){ .tl-widget{grid-template-columns:1fr;} }
.rev-cta{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-top:44px;}
.rev-cta .gicon{width:20px;height:20px;flex:none;}
.rev-top{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;}
.rev-score{display:flex;align-items:center;gap:18px;}
.rev-score .big{font-family:var(--font-d);font-weight:700;font-size:64px;line-height:.9;color:var(--green-deep);}
.rev-score .meta .stars{color:var(--yellow);font-size:22px;letter-spacing:2px;}
.rev-score .meta .sub{font-weight:700;color:var(--ink-soft);font-size:15px;margin-top:4px;}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px;}
.rev-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:28px;display:flex;flex-direction:column;gap:14px;}
.rev-card .stars{color:var(--yellow);font-size:17px;letter-spacing:2px;}
.rev-card .qt{font-size:16.5px;line-height:1.55;color:var(--ink);font-weight:600;}
.rev-card .by{display:flex;align-items:center;gap:12px;margin-top:auto;}
.rev-card .by .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-d);font-weight:600;color:#fff;font-size:18px;flex:none;}
.rev-card .by .nm{font-weight:800;font-size:14.5px;}
.rev-card .by .rl{font-size:12.5px;color:var(--ink-faint);font-weight:700;}

/* ============================================================
   QUOTE BUILDER
   ============================================================ */
.quote{background:var(--cream-2);position:relative;overflow:hidden;}
.quote::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(246,193,31,.3),transparent 70%);top:-160px;right:-120px;}
.quote::after{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(105,162,84,.26),transparent 70%);bottom:-160px;left:-120px;}
.quote-card{
  position:relative;z-index:2;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  display:grid;grid-template-columns:.9fr 1.1fr;overflow:hidden;
}
.quote-aside{background:var(--green-ink);color:#fff;padding:48px 44px;position:relative;display:flex;flex-direction:column;}
.quote-aside .eyebrow{color:var(--yellow-2);}
.quote-aside .eyebrow::before{background:var(--yellow);}
.quote-aside h2{color:#fff;font-size:38px;margin-top:16px;line-height:1.03;}
.quote-aside p{color:rgba(255,255,255,.82);font-size:16px;line-height:1.55;margin-top:16px;}
.quote-aside .perks{display:flex;flex-direction:column;gap:14px;margin-top:30px;}
.quote-aside .perk{display:flex;gap:12px;align-items:flex-start;font-size:15px;font-weight:700;color:rgba(255,255,255,.92);}
.quote-aside .perk svg{width:20px;height:20px;color:var(--yellow);flex:none;margin-top:1px;}
.quote-aside .aside-foot{margin-top:auto;padding-top:30px;display:flex;align-items:center;gap:12px;}
.quote-aside .aside-foot .ph{font-family:var(--font-d);font-weight:600;font-size:22px;}
.quote-aside .aside-foot .ph span{display:block;font-family:var(--font-b);font-weight:700;font-size:12.5px;color:rgba(255,255,255,.6);letter-spacing:.04em;text-transform:uppercase;}

.quote-form{padding:46px 44px;}
.qf-progress{display:flex;align-items:center;gap:8px;margin-bottom:26px;}
.qf-progress .dot{flex:1;height:6px;border-radius:999px;background:var(--cream-3);transition:background .3s ease;}
.qf-progress .dot.on{background:var(--green);}
.qf-step{display:none;}
.qf-step.active{display:block;animation:fade .35s ease;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.qf-q{font-family:var(--font-d);font-weight:600;font-size:24px;color:var(--ink);}
.qf-sub{font-size:14.5px;color:var(--ink-faint);font-weight:700;margin-top:6px;}
.qf-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;}
.qf-opt{
  border:1.5px solid var(--line);border-radius:14px;padding:16px 16px;cursor:pointer;
  display:flex;align-items:center;gap:12px;font-weight:800;font-size:15.5px;color:var(--ink);
  transition:border-color .15s ease, background .15s ease, transform .12s ease;background:#fff;text-align:left;
}
.qf-opt .em{font-size:22px;}
.qf-opt:hover{border-color:var(--green);background:var(--cream);}
.qf-opt.sel{border-color:var(--green);background:rgba(105,162,84,.1);box-shadow:inset 0 0 0 1px var(--green);}
.qf-opt.sel::after{content:"✓";margin-left:auto;color:var(--green-deep);font-weight:900;}
.qf-opt.feat{grid-column:1/-1;font-size:19px;padding:22px 20px;background:rgba(105,162,84,.1);box-shadow:inset 0 0 0 2px var(--green);}
.qf-picksec{margin-top:22px;}
.qf-picklab{font-family:var(--font-d);font-weight:600;font-size:16px;color:var(--ink);margin-bottom:11px;}
.qf-picks{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.qf-pick{border:1.5px solid var(--line);border-radius:13px;padding:13px 14px;cursor:pointer;display:flex;align-items:center;gap:10px;font-weight:800;font-size:14.5px;color:var(--ink);background:#fff;transition:border-color .15s,background .15s;}
.qf-pick .em{font-size:19px;}
.qf-pick:hover{border-color:var(--green);background:var(--cream);}
.qf-pick.sel{border-color:var(--green);background:rgba(105,162,84,.1);box-shadow:inset 0 0 0 1px var(--green);}
.qf-pick.sel::after{content:"✓";margin-left:auto;color:var(--green-deep);font-weight:900;}
@media (max-width:560px){ .qf-picks{grid-template-columns:1fr;} }
.qf-opt.feat .em{font-size:28px;}
.qf-opt.feat.sel{background:rgba(105,162,84,.16);}
.qf-field{margin-top:20px;}
.qf-field label{display:block;font-weight:800;font-size:13.5px;color:var(--ink-soft);margin-bottom:8px;letter-spacing:.01em;}
.qf-field input,.qf-field textarea,.qf-field select{
  width:100%;font-family:var(--font-b);font-size:16px;font-weight:600;color:var(--ink);
  border:1.5px solid var(--line);border-radius:13px;padding:14px 16px;background:#fff;transition:border-color .15s ease;
}
.qf-field input:focus,.qf-field textarea:focus,.qf-field select:focus{outline:none;border-color:var(--green);}
.qf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.qf-guests{margin-top:24px;}
.qf-guests .val{font-family:var(--font-d);font-weight:700;font-size:32px;color:var(--green-deep);}
.qf-guests .val span{font-size:16px;color:var(--ink-faint);font-weight:700;}
.qf-range{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:999px;background:var(--cream-3);margin-top:14px;}
.qf-range::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:var(--green);cursor:pointer;border:4px solid #fff;box-shadow:0 4px 10px -3px rgba(0,0,0,.4);}
.qf-range::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--green);cursor:pointer;border:4px solid #fff;}
.qf-nav{display:flex;align-items:center;gap:12px;margin-top:30px;}
.qf-nav .back{background:none;border:none;font-family:var(--font-d);font-weight:500;font-size:16px;color:var(--ink-faint);cursor:pointer;padding:10px;}
.qf-nav .back:hover{color:var(--ink);}
.qf-nav .spacer{flex:1;}
.qf-summary{background:var(--cream);border-radius:14px;padding:18px 20px;margin-top:22px;display:flex;flex-wrap:wrap;gap:10px;}
.qf-chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-weight:800;font-size:13.5px;color:var(--ink);display:inline-flex;gap:7px;align-items:center;}
.qf-chip b{color:var(--green-deep);}
.qf-done{text-align:center;padding:20px 0;}
.qf-done .check{width:84px;height:84px;border-radius:50%;background:var(--green);display:grid;place-items:center;margin:0 auto 22px;animation:pop .5s cubic-bezier(.2,1.5,.4,1);}
.qf-done .check svg{width:42px;height:42px;color:#fff;}
@keyframes pop{from{transform:scale(.3);opacity:0;}to{transform:scale(1);opacity:1;}}
.qf-done h3{font-size:30px;}
.qf-done p{font-size:16px;color:var(--ink-soft);margin-top:12px;line-height:1.55;}

/* ============================================================
   FINAL CTA + FOOTER
   ============================================================ */
.finale{background:var(--orange);color:#fff;text-align:center;padding:100px 0;position:relative;overflow:hidden;}
.finale h2{color:#fff;font-size:clamp(34px,5vw,60px);max-width:18ch;margin:0 auto;text-wrap:balance;}
.finale p{font-size:20px;color:rgba(255,255,255,.92);margin:20px auto 0;max-width:46ch;font-weight:600;}
.finale .cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:38px;}
.finale .blob{position:absolute;border-radius:50%;background:rgba(255,255,255,.12);}

footer.foot{background:var(--ink);color:rgba(255,255,255,.66);padding:70px 0 34px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;}
.foot .logo img{height:46px;width:auto;max-width:none;opacity:1;margin-bottom:18px;}
.foot p{font-size:15px;line-height:1.6;}
.foot h5{font-family:var(--font-d);font-weight:600;color:#fff;font-size:15px;text-transform:uppercase;letter-spacing:.1em;margin:0 0 18px;}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.foot ul a{font-size:15px;font-weight:700;color:rgba(255,255,255,.66);transition:color .15s ease;}
.foot ul a:hover{color:var(--yellow);}
.foot .contact-line{display:flex;gap:10px;font-size:15px;line-height:1.5;margin-bottom:12px;}
.foot .contact-line svg{width:18px;height:18px;color:var(--green);flex:none;margin-top:2px;}
.foot-socials{display:flex;gap:12px;margin-top:18px;}
.foot-socials a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:background .15s ease;}
.foot-socials a:hover{background:var(--green);}
.foot-socials a svg{width:19px;height:19px;color:#fff;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:26px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:13.5px;}
.staff-link{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:3px 11px;margin-left:4px;font-weight:700;white-space:nowrap;transition:background .15s,border-color .15s;}
.staff-link:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.4);}

/* ============================================================
   HOME PAGE additions
   ============================================================ */
/* what-is intro */
.intro-sec{background:var(--paper);}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.intro-photo{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:5/4;}
.intro-photo img{width:100%;height:100%;object-fit:cover;}
.intro-sec h2{font-size:clamp(30px,4vw,46px);margin-top:16px;}
.intro-sec .lead{margin-top:18px;}
.intro-stats{display:flex;gap:34px;margin-top:30px;flex-wrap:wrap;}
.intro-stats .st .n{font-family:var(--font-d);font-weight:700;font-size:38px;color:var(--green-deep);line-height:1;}
.intro-stats .st .l{font-size:13.5px;font-weight:800;color:var(--ink-faint);margin-top:6px;text-transform:uppercase;letter-spacing:.06em;}

/* offers */
.offers{background:var(--cream);}
.offer-feature{
  display:grid;grid-template-columns:1.05fr .95fr;gap:0;background:#fff;border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow);margin-top:54px;border:1px solid var(--line);
}
.offer-feature .pic{position:relative;min-height:340px;overflow:hidden;}
.offer-feature .pic img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.offer-feature:hover .pic img{transform:scale(1.05);}
.offer-feature .pic .ribbon{position:absolute;top:20px;left:20px;background:var(--orange);color:#fff;font-family:var(--font-d);font-weight:600;font-size:14px;padding:8px 16px;border-radius:999px;letter-spacing:.04em;box-shadow:0 8px 18px -8px rgba(0,0,0,.4);}
.offer-feature .body{padding:46px 44px;display:flex;flex-direction:column;justify-content:center;}
.offer-feature .body .ic{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;font-size:26px;background:rgba(232,151,57,.16);margin-bottom:18px;}
.offer-feature .body h3{font-size:32px;}
.offer-feature .body p{font-size:17px;line-height:1.6;color:var(--ink-soft);margin-top:14px;}
.offer-feature .body .go{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-d);font-weight:600;font-size:17px;color:var(--orange-deep);margin-top:24px;}
.offer-feature .body .go .arr{transition:transform .18s ease;}
.offer-feature:hover .body .go .arr{transform:translateX(5px);}

.offer-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px;}
.offer-card{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .22s ease, box-shadow .22s ease;display:flex;flex-direction:column;}
.offer-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.offer-card .pic{aspect-ratio:16/10;overflow:hidden;background:var(--cream-2);}
.offer-card .pic img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.offer-card:hover .pic img{transform:scale(1.06);}
.offer-card .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.offer-card .body .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:22px;margin-bottom:14px;}
.offer-card .body h3{font-size:23px;}
.offer-card .body p{font-size:14.5px;line-height:1.5;color:var(--ink-soft);margin-top:8px;}
.offer-card .body .go{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-d);font-weight:600;font-size:15px;color:var(--green-deep);margin-top:auto;padding-top:18px;}
.offer-card .body .go .arr{transition:transform .18s ease;}
.offer-card:hover .body .go .arr{transform:translateX(4px);}

/* sourcing band */
.sourcing{background:var(--green-ink);color:#fff;overflow:hidden;}
.sourcing .eyebrow{color:var(--yellow-2);}
.sourcing .eyebrow::before{background:var(--yellow);}
.sourcing-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.sourcing h2{color:#fff;font-size:clamp(30px,4vw,46px);margin-top:16px;}
.sourcing p{color:rgba(255,255,255,.82);font-size:17px;line-height:1.6;margin-top:18px;}
.sourcing-photos{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.sourcing-photos .ph{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:1/1;}
.sourcing-photos .ph:first-child{aspect-ratio:auto;grid-row:span 2;}
.sourcing-photos .ph img{width:100%;height:100%;object-fit:cover;}
.sourcing-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.sourcing-tags .tg{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:9px 16px;font-weight:700;font-size:14px;color:#fff;display:inline-flex;gap:8px;align-items:center;}
.sourcing-tags .tg svg{width:16px;height:16px;color:var(--yellow);}

/* locations */
.locations{background:var(--paper);}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:50px;}
.loc-card{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;}
.loc-card .pic{aspect-ratio:16/9;overflow:hidden;background:var(--cream-2);position:relative;}
.loc-card .pic img{width:100%;height:100%;object-fit:cover;}
.loc-card .pic .tag{position:absolute;top:16px;left:16px;background:#fff;color:var(--ink);font-family:var(--font-d);font-weight:600;font-size:14px;padding:7px 15px;border-radius:999px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:8px;}
.loc-card .pic .tag .dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(105,162,84,.25);}
.loc-card .body{padding:28px 28px 30px;}
.loc-card .body h3{font-size:26px;}
.loc-card .body .info{display:flex;flex-direction:column;gap:11px;margin-top:18px;}
.loc-card .body .info .row{display:flex;gap:11px;font-size:15.5px;color:var(--ink-soft);font-weight:700;line-height:1.45;}
.loc-card .body .info .row svg{width:19px;height:19px;color:var(--green);flex:none;margin-top:2px;}
.loc-card .body .btns{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap;}

@media (max-width:1000px){
  .intro-grid{grid-template-columns:1fr;gap:40px;}
  .offer-feature{grid-template-columns:1fr;}
  .offer-feature .pic{min-height:260px;}
  .offer-row{grid-template-columns:1fr;}
  .sourcing-grid{grid-template-columns:1fr;gap:40px;}
  .loc-grid{grid-template-columns:1fr;}
}

/* ============================================================
   INTERIOR PAGES (about / locations / wholesale / order)
   ============================================================ */
/* page hero */
.page-hero{background:transparent;padding:56px 0 12px;text-align:center;position:relative;}
.seo-copy{max-width:760px;margin:8px auto 0;text-align:center;font-size:16px;line-height:1.7;color:var(--ink-soft);}
.seo-copy b{color:var(--ink);font-weight:800;}
.page-hero .eyebrow{justify-content:center;}
.page-hero h1{font-size:clamp(36px,5vw,62px);margin-top:16px;text-wrap:balance;}
.page-hero h1 .o{color:var(--orange);}
.page-hero h1 .g{color:var(--green-deep);}
.page-hero p{max-width:62ch;margin:20px auto 0;font-size:19px;line-height:1.6;color:var(--ink-soft);}
.page-hero .ph-cta{margin-top:30px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.page-hero .ph-meta{margin-top:26px;display:flex;gap:22px;justify-content:center;flex-wrap:wrap;}
.page-hero .ph-meta .m{display:flex;align-items:center;gap:9px;font-weight:800;font-size:14.5px;color:var(--ink-soft);}
.page-hero .ph-meta .m svg{width:19px;height:19px;color:var(--green);}

/* active nav link */
.nav-links a.active{color:var(--ink);}
.nav-links a.active::after{transform:scaleX(1);}

/* nav dropdown (Catering) */
.nav-links .has-drop{position:relative;display:flex;align-items:center;}
.nav-links .has-drop > a{display:inline-flex;align-items:center;gap:5px;}
.nav-links .has-drop .caret{width:11px;height:11px;transition:transform .2s ease;}
.nav-links .has-drop:hover .caret,.nav-links .has-drop:focus-within .caret{transform:rotate(180deg);}
.nav-drop{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);
  background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  padding:8px;min-width:212px;display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;transition:opacity .18s ease, transform .18s ease;z-index:50;}
.nav-links .has-drop:hover .nav-drop,.nav-links .has-drop:focus-within .nav-drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-drop::before{content:"";position:absolute;bottom:100%;left:0;right:0;height:16px;}
.nav-drop a{padding:11px 14px;border-radius:9px;font-size:14.5px;font-weight:700;color:var(--ink-soft);white-space:nowrap;display:flex;align-items:center;gap:10px;transition:background .14s ease,color .14s ease;}
.nav-drop a::after{display:none;}
.nav-drop a:hover{background:var(--cream);color:var(--ink);}
.nav-drop a .di{font-size:16px;}
/* mobile nav sub-item indent */
.nav-mobile a.sub{padding-left:22px;font-size:14.5px;color:var(--ink-soft);}
.nav-mobile a.sub::before{content:"↳";margin-right:8px;color:var(--green);}

/* ---- food-truck schedule ---- */
.schedule-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:50px;}
.truck-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;}
.truck-card .thead{display:flex;align-items:center;gap:14px;padding:24px 28px;background:var(--green-ink);color:#fff;}
.truck-card .thead .tk{width:48px;height:48px;border-radius:13px;background:rgba(255,255,255,.14);display:grid;place-items:center;font-size:24px;flex:none;}
.truck-card .thead h3{color:#fff;font-size:22px;line-height:1.1;}
.truck-card .thead .loc{font-size:13px;color:rgba(255,255,255,.72);font-weight:700;margin-top:3px;}
.truck-card .thead .live{margin-left:auto;display:inline-flex;align-items:center;gap:7px;background:rgba(246,193,31,.18);color:var(--yellow-2);font-family:var(--font-d);font-weight:600;font-size:12.5px;padding:6px 12px;border-radius:999px;}
.truck-card .thead .live .d{width:8px;height:8px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 3px rgba(246,193,31,.3);}
.sched{padding:8px 28px 22px;}
.sched-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);}
.sched-row:last-child{border-bottom:none;}
.sched-row .day{font-family:var(--font-d);font-weight:600;font-size:16px;color:var(--ink);width:130px;flex:none;}
.sched-row .spot{font-size:14.5px;font-weight:700;color:var(--ink-soft);flex:1;text-align:right;line-height:1.4;}
.sched-row .spot .pin{color:var(--green-deep);}
.sched-row.closed .spot{color:var(--ink-faint);font-style:italic;font-weight:600;}
.sched-row.today{background:linear-gradient(90deg,transparent,rgba(105,162,84,.08));margin:0 -28px;padding-left:28px;padding-right:28px;border-radius:8px;}
.sched-row.today .day{color:var(--green-deep);}
.sched-row.today .day::after{content:"Today";font-family:var(--font-b);font-weight:800;font-size:10px;background:var(--green);color:#fff;padding:2px 7px;border-radius:999px;margin-left:8px;vertical-align:middle;letter-spacing:.04em;}
.edit-note{margin-top:34px;background:var(--cream-2);border:1px dashed rgba(105,162,84,.5);border-radius:16px;padding:18px 22px;display:flex;align-items:center;gap:14px;font-size:14.5px;color:var(--ink-soft);font-weight:700;line-height:1.45;}
.edit-note .ic{width:40px;height:40px;border-radius:11px;background:#fff;display:grid;place-items:center;font-size:20px;flex:none;box-shadow:var(--shadow-sm);}
.edit-note code{background:#fff;border:1px solid var(--line);border-radius:6px;padding:2px 7px;font-size:13px;color:var(--green-deep);font-weight:800;}

/* ---- maps ---- */
.map-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:50px;}
.map-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);display:flex;flex-direction:column;}
.map-card .frame{position:relative;height:280px;background:var(--cream-2);}
.map-card iframe{width:100%;height:100%;border:0;display:block;}
.map-card .badge{position:absolute;top:16px;left:16px;z-index:2;background:#fff;color:var(--ink);font-family:var(--font-d);font-weight:600;font-size:13.5px;padding:7px 14px;border-radius:999px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:8px;pointer-events:none;}
.map-card .badge .dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(105,162,84,.25);}
.map-card .badge.soon .dot{background:var(--orange);box-shadow:0 0 0 4px rgba(232,151,57,.25);}
.map-card .mbody{padding:24px 28px 28px;display:flex;flex-direction:column;flex:1;}
.map-card .mbody h3{font-size:24px;}
.map-card .mbody .info{display:flex;flex-direction:column;gap:10px;margin-top:16px;}
.map-card .mbody .info .row{display:flex;gap:11px;font-size:15px;color:var(--ink-soft);font-weight:700;line-height:1.45;}
.map-card .mbody .info .row svg{width:18px;height:18px;color:var(--green);flex:none;margin-top:2px;}
.map-card .mbody .btns{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap;}

/* ---- generic two-column form card (wholesale / order) ---- */
.form-section{background:var(--cream-2);position:relative;overflow:hidden;}
.form-section::before{content:"";position:absolute;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(246,193,31,.28),transparent 70%);top:-160px;right:-120px;}
.form-section::after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(105,162,84,.24),transparent 70%);bottom:-150px;left:-110px;}
.simple-form{padding:46px 44px;}
.simple-form .qf-field{margin-top:18px;}
.simple-form .full-actions{margin-top:28px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.form-note{font-size:13px;color:var(--ink-faint);font-weight:700;margin-top:14px;}

/* ---- order type cards ---- */
.order-types{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;}
.otype{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);display:flex;flex-direction:column;transition:transform .22s ease, box-shadow .22s ease;}
.otype:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.otype .pic{aspect-ratio:16/11;overflow:hidden;background:var(--cream-2);position:relative;}
.otype .pic img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.otype:hover .pic img{transform:scale(1.06);}
.otype .pic .fee{position:absolute;top:14px;right:14px;background:#fff;color:var(--green-deep);font-weight:800;font-size:12px;padding:6px 12px;border-radius:999px;box-shadow:var(--shadow-sm);}
.otype .body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1;}
.otype .body h3{font-size:23px;}
.otype .body p{font-size:14.5px;line-height:1.5;color:var(--ink-soft);margin-top:8px;}
.otype .body .tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px;}
.otype .body .tags span{font-size:12px;font-weight:800;color:var(--ink-soft);background:var(--cream);border:1px solid var(--line);padding:5px 11px;border-radius:999px;}
.otype .body .btn{margin-top:20px;justify-content:center;}

/* fulfillment band */
.fulfil{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:26px;}
.fulfil .f{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 30px;display:flex;gap:18px;align-items:flex-start;box-shadow:var(--shadow-sm);}
.fulfil .f .ic{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:26px;flex:none;}
.fulfil .f h4{font-size:21px;}
.fulfil .f p{font-size:15px;color:var(--ink-soft);line-height:1.5;margin-top:6px;}

/* ---- breadcrumb ---- */
.crumb{display:flex;gap:9px;justify-content:center;align-items:center;font-family:var(--font-d);font-weight:500;font-size:14px;color:var(--ink-faint);margin-bottom:6px;}
.crumb a{color:var(--green-deep);}
.crumb a:hover{text-decoration:underline;}
.crumb .sep{opacity:.5;}

/* ---- catering menu ---- */
.cmenu-note{max-width:760px;margin:36px auto 0;background:var(--cream-2);border:1px dashed rgba(105,162,84,.5);border-radius:16px;padding:18px 24px;display:flex;align-items:center;gap:14px;font-size:15px;color:var(--ink-soft);font-weight:700;line-height:1.45;text-align:left;}
.cmenu-note .ic{width:42px;height:42px;border-radius:12px;background:#fff;display:grid;place-items:center;font-size:21px;flex:none;box-shadow:var(--shadow-sm);}
.cmenu-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:50px;}
.cmenu-cat{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease, box-shadow .2s ease;}
.cmenu-cat:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.cmenu-cat .chead{display:flex;align-items:center;gap:14px;padding:24px 28px;border-bottom:1px solid var(--line);}
.cmenu-cat .chead .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:25px;flex:none;}
.cmenu-cat .chead h3{font-size:23px;line-height:1.05;}
.cmenu-cat .chead .cd{font-size:13.5px;color:var(--ink-faint);font-weight:700;margin-top:3px;}
.cmenu-list{padding:8px 28px 24px;display:flex;flex-direction:column;}
.cmenu-list.two{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0 40px;}
.cmenu-item{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 10px;padding:14px 0;border-bottom:1px solid var(--line);}
.cmenu-item:last-child{border-bottom:none;}
/* menu sold-out + shop status (staff overrides) */
.cmenu-item.sold-out{opacity:.5;}
.cmenu-item.sold-out .nm{text-decoration:line-through;}
.soldout-tag{font-family:var(--font-d);font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--maroon);background:rgba(121,51,56,.12);padding:2px 8px;border-radius:999px;align-self:center;}
.locations .badge.open{background:rgba(105,162,84,.16) !important;color:var(--green-deep) !important;}
.locations .badge.open .dot{background:var(--green) !important;}
.locations .badge.closed{background:rgba(121,51,56,.14) !important;color:var(--maroon) !important;}
.locations .badge.closed .dot{background:var(--maroon) !important;}
.cmenu-item .nm{font-family:var(--font-d);font-weight:600;font-size:17px;color:var(--ink);white-space:nowrap;}
.cmenu-item .dots{flex:1;border-bottom:2px dotted var(--cream-3);transform:translateY(-4px);min-width:18px;}
.cmenu-item .sv{font-size:12.5px;font-weight:800;color:var(--green-deep);background:var(--cream);border:1px solid var(--line);padding:4px 11px;border-radius:999px;white-space:nowrap;flex:none;}
.cmenu-item .dd{flex-basis:100%;font-size:13.5px;color:var(--ink-soft);font-weight:600;margin-top:4px;line-height:1.4;}
.cmenu-photo{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:1/1;}
.cmenu-photo img{width:100%;height:100%;object-fit:cover;}
.cmenu-cat.feat{grid-column:1/-1;}

/* favourites mention line (fruit bowls) */
.cmenu-fav{padding:0 28px 22px;display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 10px;}
.cmenu-fav .favlab{font-family:var(--font-d);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--green-deep);}
.cmenu-fav .favlist{font-size:14.5px;font-weight:700;color:var(--ink-soft);}
/* style sub-list (fruit bowls) */
.cmenu-sublab{padding:2px 28px 0;font-family:var(--font-d);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--green-deep);}
.cmenu-item.style{display:block;}
.cmenu-item.style .nm{white-space:normal;}
.cmenu-item.style .dd{display:block;margin-top:3px;}

/* selectable + quantity (order builder) */
.cmenu-item.buyable{display:block;}
.cmenu-item.buyable .nm{white-space:normal;}
.cmenu-item.buyable .dd{display:block;margin-top:4px;}
.buy{display:flex;flex-wrap:wrap;align-items:center;gap:9px;margin-top:12px;}
.sizes{display:flex;gap:7px;flex-wrap:wrap;}
.size-chip{font-family:var(--font-d);font-weight:500;font-size:13.5px;color:var(--ink);background:var(--cream);border:1.5px solid var(--line);border-radius:999px;padding:6px 13px;cursor:pointer;transition:transform .12s ease, background .14s ease, border-color .14s ease, color .14s ease;}
.size-chip:hover{border-color:var(--green);transform:translateY(-1px);}
.size-chip.on{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 8px 16px -10px rgba(105,162,84,.8);}
.svnote{font-size:12.5px;font-weight:800;color:var(--ink-faint);}
.qty{margin-left:auto;display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;background:#fff;}
.qty .qbtn{width:34px;height:34px;border:none;background:#fff;font-size:19px;font-weight:700;color:var(--ink);cursor:pointer;display:grid;place-items:center;font-family:var(--font-d);line-height:1;transition:background .12s ease;}
.qty .qbtn:hover{background:var(--cream-2);}
.qty .qbtn:disabled{color:var(--cream-3);cursor:default;}
.qty .qn{min-width:32px;text-align:center;font-family:var(--font-d);font-weight:600;font-size:16px;color:var(--ink);}
.qty input.qn{width:42px;border:none;background:transparent;padding:4px 0;-moz-appearance:textfield;cursor:text;}
.qty input.qn::-webkit-outer-spin-button,.qty input.qn::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.qty input.qn:focus{outline:none;background:var(--cream-2);border-radius:7px;box-shadow:inset 0 0 0 1.5px var(--green);}
.cmenu-item.buyable.active{background:linear-gradient(90deg,rgba(105,162,84,.07),transparent);border-radius:12px;margin:0 -14px;padding-left:14px;padding-right:14px;}

/* sticky order bar */
.order-bar{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(160%);z-index:95;
  background:var(--ink);color:#fff;border-radius:999px;display:flex;align-items:center;gap:16px;
  padding:11px 12px 11px 24px;box-shadow:0 22px 50px -18px rgba(0,0,0,.6);transition:transform .35s cubic-bezier(.2,.9,.3,1);max-width:calc(100vw - 32px);}
.order-bar.show{transform:translateX(-50%) translateY(0);}
.order-bar .ob-info{display:flex;flex-direction:column;line-height:1.1;}
.order-bar .ob-ct{font-family:var(--font-b);font-weight:800;font-size:12px;color:rgba(255,255,255,.6);letter-spacing:.03em;}
.order-bar .ob-tot{font-family:var(--font-d);font-weight:600;font-size:20px;}
.order-bar .btn{padding:12px 20px;font-size:15px;}
.order-bar .ob-clear{background:none;border:none;color:rgba(255,255,255,.55);font-family:var(--font-d);font-weight:500;font-size:13px;cursor:pointer;padding:6px;}
.order-bar .ob-clear:hover{color:#fff;}
@media (max-width:560px){
  .order-bar{gap:10px;padding:10px 10px 10px 18px;width:calc(100vw - 24px);}
  .order-bar .ob-clear{display:none;}
  .order-bar .btn{padding:11px 16px;font-size:14px;}
}

/* ============================================================
   STANDARD QUOTE BUILDER — in-form item selector (step 2)
   ============================================================ */
.qb-list{margin-top:20px;border:1px solid var(--line);border-radius:16px;padding:6px 18px;max-height:none;}
.qb-cat{font-family:var(--font-d);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.11em;color:var(--green-deep);margin:18px 0 6px;}
.qb-cat:first-child{margin-top:8px;}
.qb-item{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 0;border-bottom:1px solid var(--line);}
.qb-item:last-child{border-bottom:none;}
.qb-item .qb-nm{font-family:var(--font-d);font-weight:600;font-size:15.5px;color:var(--ink);flex:1;min-width:130px;line-height:1.15;}
.qb-item .qb-nm .qb-note{display:block;font-family:var(--font-b);font-weight:700;font-size:11.5px;color:var(--ink-faint);margin-top:2px;}
.qb-item .qb-sizes{display:flex;gap:6px;flex-wrap:wrap;}
.qb-subtotal{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-top:18px;padding:16px 20px;background:var(--cream);border-radius:14px;}
.qb-subtotal .l{font-family:var(--font-d);font-weight:600;font-size:14px;color:var(--ink-soft);}
.qb-subtotal .l span{display:block;font-family:var(--font-b);font-weight:700;font-size:12px;color:var(--ink-faint);margin-top:2px;}
.qb-subtotal .v{font-family:var(--font-d);font-weight:700;font-size:26px;color:var(--green-deep);}
.qf-summary .qf-chip.items-chip{flex-basis:100%;align-items:flex-start;}
.qf-summary .qf-chip.items-chip b{white-space:nowrap;}
/* pickup order totals */
.qf-totals{margin-top:16px;border-top:1px solid var(--line);padding-top:16px;display:flex;flex-direction:column;gap:8px;}
.qf-totals .tline{display:flex;justify-content:space-between;gap:12px;font-size:15px;font-weight:700;color:var(--ink-soft);}
.qf-totals .tline.grand{font-family:var(--font-d);font-weight:600;font-size:21px;color:var(--ink);border-top:1px dashed var(--line);padding-top:11px;}
.qf-totals .tline.grand span:last-child{color:var(--green-deep);}
.qf-totals .tnote{font-size:12px;color:var(--ink-faint);font-weight:700;}
/* quote: per-item fruit selection step */
.qfruit{margin-top:20px;display:flex;flex-direction:column;gap:18px;}
.qfruit-group .glab{font-family:var(--font-d);font-weight:600;font-size:14.5px;color:var(--ink);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.qfruit-group .glab .ge{font-size:18px;}
/* per-line pickup pickers + same/each toggle */
.qfruit-line{padding:16px 0;border-bottom:1px solid var(--line);}
.qfruit-line:last-child{border-bottom:none;}
.qline-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:6px;}
.qline-name{font-family:var(--font-d);font-weight:600;font-size:16px;color:var(--ink);}
.qline-q{color:var(--ink-faint);}
.qline-toggle{display:inline-flex;background:var(--cream-2);border-radius:999px;padding:3px;gap:2px;}
.qlt{font-family:var(--font-d);font-weight:500;font-size:13px;border:none;background:transparent;color:var(--ink-soft);padding:6px 14px;border-radius:999px;cursor:pointer;transition:background .15s ease, color .15s ease;}
.qlt.on{background:var(--green);color:#fff;}
.qline-pickers .qfruit-group + .qfruit-group{margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);}
.fruit-min-note{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-family:var(--font-b);font-weight:800;font-size:12.5px;color:var(--green-deep);background:rgba(105,162,84,.1);border:1px solid rgba(105,162,84,.28);padding:5px 11px;border-radius:999px;}
.fruit-min-note .fmn-ic{font-size:13px;}
.fruit-defaulted-note{display:flex;align-items:center;gap:7px;margin-top:10px;font-family:var(--font-b);font-weight:800;font-size:12.5px;color:var(--orange-deep);background:rgba(232,151,57,.12);border:1px solid rgba(232,151,57,.35);padding:7px 12px;border-radius:10px;}
.chip-default{color:var(--orange-deep);font-weight:800;}
.qalloc{font-family:var(--font-d);font-weight:600;font-size:13.5px;color:var(--ink);display:inline-flex;align-items:center;gap:7px;padding:6px 14px;border-radius:999px;background:rgba(232,151,57,.16);box-shadow:inset 0 0 0 1.5px var(--orange);transition:background .2s ease, box-shadow .2s ease, color .2s ease;}
.qalloc::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 rgba(232,151,57,.5);animation:allocPulse 1.6s ease-out infinite;}
.qalloc.ok{color:var(--green-deep);background:rgba(105,162,84,.16);box-shadow:inset 0 0 0 1.5px var(--green);}
.qalloc.ok::before{background:var(--green);animation:none;box-shadow:none;}
.qalloc.over{color:#fff;background:var(--maroon);box-shadow:inset 0 0 0 1.5px var(--maroon);animation:allocShake .35s ease;}
.qalloc.over::before{background:#fff;animation:none;box-shadow:none;}
@keyframes allocPulse{0%{box-shadow:0 0 0 0 rgba(232,151,57,.5);}70%{box-shadow:0 0 0 7px rgba(232,151,57,0);}100%{box-shadow:0 0 0 0 rgba(232,151,57,0);}}
@keyframes allocShake{0%,100%{transform:translateX(0);}25%{transform:translateX(-4px);}75%{transform:translateX(4px);}}
@media (prefers-reduced-motion:reduce){.qalloc::before{animation:none;}.qalloc.over{animation:none;}}
.qcombo-ctrls{display:flex;align-items:center;gap:12px;margin-top:14px;}
.qaddcombo{font-family:var(--font-d);font-weight:500;font-size:13.5px;border:1.5px dashed var(--green);color:var(--green-deep);background:transparent;padding:8px 15px;border-radius:999px;cursor:pointer;transition:opacity .15s ease;}
.qaddcombo:disabled{opacity:.4;cursor:default;border-color:var(--line);color:var(--ink-faint);}
.qcombo-hint{font-size:12.5px;color:var(--ink-faint);font-weight:700;}
.qcombo-units{display:flex;align-items:center;gap:10px;margin:10px 0 2px;}
.qcombo-units label{font-family:var(--font-d);font-weight:600;font-size:13px;color:var(--ink-soft);}
.qcombo-units .qty{margin-left:0;}
.qcombo-remove{margin-left:auto;width:28px;height:28px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink-faint);font-size:16px;cursor:pointer;line-height:1;}
.qcombo-remove:hover{color:var(--maroon);border-color:var(--maroon);}
/* pickup disclosure */
.pickup-note{margin-top:16px;display:flex;gap:10px;align-items:flex-start;background:var(--cream-2);border:1px dashed rgba(105,162,84,.5);border-radius:13px;padding:13px 16px;font-size:13.5px;line-height:1.45;color:var(--ink-soft);font-weight:700;}
.pickup-note b{color:var(--green-deep);}
/* quote: priced toppings under fruit groups */
.qtop{margin-top:14px;padding-top:14px;border-top:1px dashed var(--line);}
.qtop .tlab{font-family:var(--font-d);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.09em;color:var(--green-deep);margin-bottom:9px;display:block;}
.qtop-btns{display:flex;flex-wrap:wrap;gap:8px;}
.top-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-b);font-weight:700;font-size:13.5px;color:var(--ink);background:var(--cream);border:1.5px solid var(--line);border-radius:999px;padding:7px 13px;cursor:pointer;transition:transform .12s ease,background .14s,border-color .14s;}
.top-btn:hover{border-color:var(--green);transform:translateY(-1px);}
.top-btn.on{background:rgba(105,162,84,.1);border-color:var(--green);}
.top-btn .tdot{width:15px;height:15px;border-radius:5px;border:2px solid var(--ink-faint);display:grid;place-items:center;flex:none;transition:.14s;}
.top-btn .tdot svg{width:9px;height:9px;color:#fff;opacity:0;transition:.14s;}
.top-btn.on .tdot{background:var(--green);border-color:var(--green);}
.top-btn.on .tdot svg{opacity:1;}
.top-btn .tp{font-family:var(--font-d);font-weight:600;color:var(--green-deep);font-size:12.5px;}
/* quote CTA band (catering page) */
.quote-cta{position:relative;z-index:2;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:54px 44px;text-align:center;}
.quote-cta .eyebrow{justify-content:center;}
.quote-cta h2{font-size:clamp(28px,3.8vw,44px);margin-top:14px;}
.quote-cta p{max-width:54ch;margin:16px auto 0;color:var(--ink-soft);font-size:18px;line-height:1.55;}
.quote-cta .cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px;}

/* FAQ accordion */
.faq{background:var(--cream);}
.faq-list{max-width:840px;margin:46px auto 0;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease;}
.faq-item[open]{box-shadow:var(--shadow);}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:16px;padding:22px 26px;font-family:var(--font-d);font-weight:600;font-size:19px;color:var(--ink);}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary .qm{margin-left:auto;flex:none;width:30px;height:30px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;transition:transform .25s ease, background .2s ease;}
.faq-item summary .qm svg{width:15px;height:15px;color:var(--green-deep);}
.faq-item[open] summary .qm{transform:rotate(45deg);background:var(--green);}
.faq-item[open] summary .qm svg{color:#fff;}
.faq-item .fa-body{padding:0 26px 24px;font-size:16.5px;line-height:1.6;color:var(--ink-soft);}
.faq-item .fa-body a{color:var(--green-deep);font-weight:700;}
@media (max-width:620px){
  .faq-item summary{font-size:17px;padding:18px 20px;}
  .faq-item .fa-body{padding:0 20px 20px;font-size:15.5px;}
}
@media (max-width:560px){
  .qb-list{padding:4px 14px;}
  .qb-item .qty{margin-left:0;}
}

/* single-fruit picker */
.fruit-pick{padding:2px 28px 24px;}
.fruit-pick .lab{font-family:var(--font-d);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-faint);margin-bottom:12px;display:block;}
.fruit-btns{display:flex;flex-wrap:wrap;gap:9px;}
.fruit-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-d);font-weight:500;font-size:14.5px;color:var(--ink);background:var(--cream);border:1.5px solid var(--line);border-radius:999px;padding:8px 15px;cursor:pointer;transition:transform .14s ease, background .14s ease, border-color .14s ease, color .14s ease;}
.fruit-btn:hover{border-color:var(--green);background:#fff;transform:translateY(-1px);}
.fruit-btn.on{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 8px 18px -10px rgba(105,162,84,.8);}
.fruit-btn .fe{font-size:16px;}

/* checkbox builder (fruit cups) */
.pick-group{padding:2px 28px 6px;}
.pick-group:last-child{padding-bottom:24px;}
.pick-group .lab{font-family:var(--font-d);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-faint);margin:14px 0 12px;display:block;}
.chk-btns{display:flex;flex-wrap:wrap;gap:9px;}
.chk-btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-d);font-weight:500;font-size:14.5px;color:var(--ink);background:var(--cream);border:1.5px solid var(--line);border-radius:10px;padding:8px 14px;cursor:pointer;transition:transform .14s ease, background .14s ease, border-color .14s ease;}
.chk-btn .box{width:17px;height:17px;border-radius:5px;border:2px solid var(--ink-faint);display:grid;place-items:center;flex:none;transition:background .14s ease, border-color .14s ease;}
.chk-btn .box svg{width:10px;height:10px;color:#fff;opacity:0;transition:opacity .14s ease;}
.chk-btn .fe{font-size:16px;}
.chk-btn:hover{border-color:var(--green);transform:translateY(-1px);}
.chk-btn.on{border-color:var(--green);background:rgba(105,162,84,.1);}
.chk-btn.on .box{background:var(--green);border-color:var(--green);}
.chk-btn.on .box svg{opacity:1;}

@media (max-width:1000px){
  .schedule-grid{grid-template-columns:1fr;}
  .map-grid{grid-template-columns:1fr;}
  .order-types{grid-template-columns:1fr;}
  .fulfil{grid-template-columns:1fr;}
  .cmenu-grid{grid-template-columns:1fr;}
  .cmenu-list.two{grid-template-columns:1fr;gap:0;}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:40px;}
  .hero-visual{max-width:440px;margin:0 auto;}
  .event-grid{grid-template-columns:repeat(2,1fr);}
  .format-grid{grid-template-columns:repeat(2,1fr);}
  .how-grid{grid-template-columns:1fr;}
  .step .arrow{display:none;}
  .why-grid{grid-template-columns:1fr;gap:40px;}
  .menu-grid{grid-template-columns:repeat(2,1fr);}
  .rev-grid{grid-template-columns:1fr;}
  .quote-card{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media (max-width:720px){
  .nav-links,.nav-phone{display:none;}
  .nav-burger{display:block;}
  .nav-mobile{display:none;flex-direction:column;gap:4px;padding:10px 28px 22px;background:var(--cream);border-bottom:1px solid var(--line);}
  .nav-mobile.open{display:flex;}
  .nav-mobile a{padding:12px 0;font-weight:800;border-bottom:1px solid var(--line);}
  .sec{padding:64px 0;}
  .event-grid{grid-template-columns:1fr;}
  .format-grid{grid-template-columns:1fr;}
  .menu-grid{grid-template-columns:1fr 1fr;}
  .qf-opts{grid-template-columns:1fr;}
  .qf-row{grid-template-columns:1fr;}
  .quote-aside,.quote-form{padding:34px 26px;}
  .foot-grid{grid-template-columns:1fr;}
  .hero-visual .float.tl{left:-8px;}
  .hero-visual .float.br{right:-6px;}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;scroll-behavior:auto;}
  .strip-track{animation:none;}
}

/* ============================================================
   LIVE STATUS · TRUCK ALERTS · ONLINE ORDERING  (added)
   ============================================================ */
/* live open/closed pill */
.af-live{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-d);font-weight:600;font-size:14px;padding:8px 16px;border-radius:999px;background:rgba(105,162,84,.14);color:var(--green-deep);white-space:nowrap;}
.af-live .d{width:9px;height:9px;border-radius:50%;background:var(--green);flex:none;}
.af-live:not(.closed) .d{animation:afpulse 2.1s infinite;}
.af-live.closed{background:rgba(147,138,125,.16);color:var(--ink-soft);}
.af-live.closed .d{background:var(--ink-faint);}
@keyframes afpulse{0%{box-shadow:0 0 0 0 rgba(105,162,84,.5);}70%{box-shadow:0 0 0 8px rgba(105,162,84,0);}100%{box-shadow:0 0 0 0 rgba(105,162,84,0);}}

/* closed state for existing map/loc badges */
.map-card .badge.closed{color:var(--ink-soft);}
.map-card .badge.closed .dot{background:var(--ink-faint);box-shadow:0 0 0 4px rgba(147,138,125,.22);}
.loc-card .pic .tag.closed .dot{background:var(--ink-faint);box-shadow:0 0 0 4px rgba(147,138,125,.22);}
/* truck schedule live badge — open (default yellow) vs closed */
.truck-card .thead .live.off{background:rgba(255,255,255,.12);color:rgba(255,255,255,.72);}
.truck-card .thead .live.off .d{background:#d8c7ab;box-shadow:none;}

/* ---- online ordering band (order page) ---- */
.order-online{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:40px 40px 34px;position:relative;overflow:hidden;}
.order-online .oo-head{text-align:center;max-width:600px;margin:0 auto;}
.order-online .oo-head .af-live{margin-bottom:16px;}
.order-online .oo-head h2{font-size:clamp(28px,3.4vw,40px);}
.order-online .oo-head p{font-size:16.5px;line-height:1.6;color:var(--ink-soft);margin:12px auto 0;max-width:52ch;}
.oo-apps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px;}
.oo-event{display:flex;align-items:center;gap:18px;margin-top:28px;background:linear-gradient(120deg,var(--green-ink),var(--green-deep));border-radius:18px;padding:26px 30px;color:#fff;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease;}
.oo-event:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.oo-event .ooe-em{font-size:46px;flex:none;line-height:1;}
.oo-event .ooe-tx{flex:1;min-width:0;}
.oo-event .ooe-t{display:block;font-family:var(--font-d);font-weight:600;font-size:26px;color:#fff;}
.oo-event .ooe-s{display:block;font-size:15.5px;line-height:1.5;color:rgba(255,255,255,.85);margin-top:5px;}
.oo-event .arr{flex:none;font-size:26px;color:var(--yellow);}
@media (max-width:560px){ .oo-event{padding:22px 22px;gap:14px;} .oo-event .ooe-em{font-size:36px;} .oo-event .ooe-t{font-size:22px;} }
.oo-apps.oo-apps--compact{grid-template-columns:repeat(2,1fr);max-width:560px;margin-left:auto;margin-right:auto;}
.oo-app{display:flex;align-items:center;gap:13px;background:var(--cream);border:1.5px solid var(--line);border-radius:16px;padding:16px 18px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;}
.oo-app:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:var(--green);}
.oo-app .oo-logo{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-family:var(--font-d);font-weight:700;font-size:13px;flex:none;letter-spacing:-.02em;}
.oo-app .t{font-family:var(--font-d);font-weight:600;font-size:16px;color:var(--ink);line-height:1.05;}
.oo-app .s{font-size:12.5px;font-weight:700;color:var(--ink-faint);margin-top:3px;}
.oo-app .arr{margin-left:auto;color:var(--ink-faint);font-weight:800;transition:transform .18s ease;}
.oo-app:hover .arr{transform:translateX(4px);color:var(--green-deep);}
.oo-app.call,.oo-app[data-order-link="pickup"]{background:var(--green-ink);border-color:var(--green-ink);}
.oo-app.call .t,.oo-app[data-order-link="pickup"] .t{color:#fff;}
.oo-app.call .s,.oo-app[data-order-link="pickup"] .s{color:rgba(255,255,255,.7);}
.oo-app.call .oo-logo,.oo-app[data-order-link="pickup"] .oo-logo{background:rgba(255,255,255,.14);color:#fff;}
.oo-app.call .arr,.oo-app[data-order-link="pickup"] .arr{color:rgba(255,255,255,.7);}

/* ---- truck location alerts signup ---- */
.truck-signup{background:var(--green-ink);border-radius:var(--r-lg);padding:48px 50px;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;position:relative;overflow:hidden;box-shadow:var(--shadow);}
.truck-signup::before{content:"";position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(246,193,31,.22),transparent 70%);top:-150px;right:-90px;pointer-events:none;}
.ts-copy{position:relative;z-index:1;}
.ts-copy .eyebrow{color:#bfe6a8;}
.ts-copy .eyebrow::before{background:#bfe6a8;}
.ts-copy h2{color:#fff;font-size:clamp(26px,3.2vw,38px);margin-top:14px;text-wrap:balance;}
.ts-copy p{color:rgba(255,255,255,.82);font-size:16px;line-height:1.6;margin-top:14px;max-width:46ch;}
.ts-perks{display:flex;flex-wrap:wrap;gap:9px 18px;margin-top:20px;}
.ts-perks .pk{display:flex;align-items:center;gap:8px;font-weight:800;font-size:13.5px;color:rgba(255,255,255,.9);}
.ts-perks .pk svg{width:17px;height:17px;color:var(--yellow);flex:none;}
.ts-form{position:relative;z-index:1;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:var(--r);padding:26px;}
.ts-toggle{display:flex;gap:8px;background:rgba(0,0,0,.18);border-radius:999px;padding:5px;}
.ts-toggle button{flex:1;font-family:var(--font-d);font-weight:600;font-size:14.5px;color:rgba(255,255,255,.78);background:transparent;border:none;cursor:pointer;padding:11px 14px;border-radius:999px;transition:background .18s ease,color .18s ease;}
.ts-toggle button.on{background:#fff;color:var(--green-ink);}
.ts-input{display:flex;gap:10px;margin-top:14px;}
.ts-input input{flex:1;min-width:0;font-family:var(--font-b);font-size:16px;font-weight:600;color:var(--ink);border:none;border-radius:13px;padding:15px 17px;background:#fff;}
.ts-input input:focus{outline:none;box-shadow:0 0 0 3px rgba(246,193,31,.5);}
.ts-input .btn{flex:none;}
.ts-note{margin-top:13px;font-size:12.5px;color:rgba(255,255,255,.6);line-height:1.5;}
.ts-note a{color:var(--yellow-2);font-weight:800;}
.ts-done{position:relative;z-index:1;text-align:center;padding:12px 6px;}
.ts-done .check{width:60px;height:60px;border-radius:50%;background:var(--yellow);display:grid;place-items:center;margin:0 auto 16px;}
.ts-done .check svg{width:30px;height:30px;color:var(--green-ink);}
.ts-done h3{color:#fff;font-size:24px;}
.ts-done p{color:rgba(255,255,255,.85);font-size:15.5px;line-height:1.55;margin-top:8px;}

@media (max-width:860px){
  .oo-apps{grid-template-columns:1fr 1fr;}
  .truck-signup{grid-template-columns:1fr;gap:30px;padding:36px 30px;}
}
@media (max-width:560px){
  .oo-apps{grid-template-columns:1fr;}
  .ts-input{flex-direction:column;}
  .ts-input .btn{justify-content:center;}
}

/* ============================================================
   CUSTOMER ACCOUNTS  (added)
   ============================================================ */
/* nav chip */
.acct-chip{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-d);font-weight:600;font-size:15px;color:var(--ink) !important;padding:8px 16px 8px 11px;border-radius:999px;box-shadow:inset 0 0 0 1.5px var(--line);transition:box-shadow .15s ease,background .15s ease;white-space:nowrap;}
.acct-chip::after{display:none !important;}
.acct-chip svg{width:18px;height:18px;color:var(--green);}
.acct-chip:hover{box-shadow:inset 0 0 0 1.5px var(--green);background:var(--cream);}
.acct-chip .av{width:26px;height:26px;border-radius:50%;background:var(--green);color:#fff;font-family:var(--font-d);font-weight:600;font-size:14px;display:grid;place-items:center;flex:none;}
.acct-chip.in{box-shadow:inset 0 0 0 1.5px rgba(105,162,84,.4);background:rgba(105,162,84,.08);}

/* page hero */
.acct-hero{padding:54px 0 8px;text-align:center;position:relative;z-index:1;}
.acct-hero .eyebrow{justify-content:center;}
.acct-hero h1{font-size:clamp(34px,4.6vw,54px);margin-top:14px;text-wrap:balance;}
.acct-hero p{font-size:18px;color:var(--ink-soft);max-width:54ch;margin:14px auto 0;line-height:1.55;}

.acct-sec{padding:40px 0 96px;position:relative;z-index:1;}

/* ---- auth card (logged out) ---- */
.acct-card{position:relative;z-index:2;max-width:1000px;margin:0 auto;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);display:grid;grid-template-columns:.92fr 1.08fr;overflow:hidden;}
.acct-aside{background:var(--green-ink);color:#fff;padding:44px 40px;display:flex;flex-direction:column;position:relative;overflow:hidden;}
.acct-aside::before{content:"";position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(246,193,31,.22),transparent 70%);top:-130px;right:-90px;}
.acct-aside .eyebrow{color:var(--yellow-2);position:relative;z-index:1;}
.acct-aside .eyebrow::before{background:var(--yellow);}
.acct-aside h2{color:#fff;font-size:30px;margin-top:14px;line-height:1.06;position:relative;z-index:1;}
.acct-perks{display:flex;flex-direction:column;gap:18px;margin-top:30px;position:relative;z-index:1;}
.acct-perk{display:flex;gap:14px;align-items:flex-start;}
.acct-perk .pic{width:42px;height:42px;border-radius:13px;background:rgba(255,255,255,.12);display:grid;place-items:center;font-size:21px;flex:none;}
.acct-perk .t{font-family:var(--font-d);font-weight:600;font-size:16.5px;color:#fff;line-height:1.1;}
.acct-perk .s{font-size:13.5px;color:rgba(255,255,255,.74);line-height:1.5;margin-top:4px;}
.acct-aside .aside-foot{margin-top:auto;padding-top:28px;font-size:13px;color:rgba(255,255,255,.62);line-height:1.5;position:relative;z-index:1;}

.acct-form{padding:42px 44px;}
.acct-tabs{display:flex;gap:8px;background:var(--cream-2);border-radius:999px;padding:5px;margin-bottom:28px;}
.acct-tabs button{flex:1;font-family:var(--font-d);font-weight:500;font-size:16px;color:var(--ink-soft);background:transparent;border:none;cursor:pointer;padding:12px;border-radius:999px;transition:background .18s ease,color .18s ease,box-shadow .18s ease;}
.acct-tabs button.on{background:#fff;color:var(--green-deep);box-shadow:var(--shadow-sm);}
.acct-pane{display:none;animation:fade .35s ease;}
.acct-pane.on{display:block;}
.acct-pane h3{font-size:23px;}
.acct-pane .hint{font-size:14px;color:var(--ink-faint);font-weight:700;margin-top:5px;margin-bottom:4px;}
.acct-staff-link{display:block;text-align:center;margin-top:18px;font-family:var(--font-d);font-weight:500;font-size:14px;color:var(--ink-soft);text-decoration:none;padding:11px;border-top:1px solid var(--line);}
.acct-staff-link:hover{color:var(--green-deep);}
.acct-consent{display:flex;gap:11px;align-items:flex-start;margin-top:18px;cursor:pointer;}
.acct-consent input{width:20px;height:20px;margin-top:2px;accent-color:var(--green);flex:none;cursor:pointer;}
.acct-consent span{font-size:13px;color:var(--ink-soft);line-height:1.5;}
.acct-consent a{color:var(--green-deep);font-weight:800;}
.acct-opts{display:flex;flex-direction:column;gap:11px;margin-top:16px;}
.acct-opt{display:flex;gap:11px;align-items:center;font-size:14px;color:var(--ink-soft);font-weight:700;cursor:pointer;}
.acct-opt input{width:19px;height:19px;accent-color:var(--green);flex:none;cursor:pointer;}
.acct-err{background:rgba(216,69,90,.1);color:#b03247;border-radius:12px;padding:12px 15px;font-size:13.5px;font-weight:800;margin-top:16px;display:none;}
.acct-err.show{display:block;}
.acct-form .btn{width:100%;justify-content:center;margin-top:22px;}
.acct-form .full{width:100%;}

/* ---- dashboard (logged in) ---- */
.dash{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:24px;}
.dash-head{background:#fff;border-radius:var(--r);box-shadow:var(--shadow-sm);padding:30px 34px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.dash-head .big-av{width:64px;height:64px;border-radius:50%;background:var(--green);color:#fff;font-family:var(--font-d);font-weight:600;font-size:30px;display:grid;place-items:center;flex:none;}
.dash-head .who h2{font-size:26px;}
.dash-head .who p{font-size:14.5px;color:var(--ink-faint);font-weight:700;margin-top:4px;}
.dash-head .signout{margin-left:auto;background:none;border:none;cursor:pointer;font-family:var(--font-d);font-weight:500;font-size:15px;color:var(--ink-faint);padding:10px 16px;border-radius:999px;box-shadow:inset 0 0 0 1.5px var(--line);transition:box-shadow .15s ease,color .15s;}
.dash-head .signout:hover{color:var(--maroon);box-shadow:inset 0 0 0 1.5px var(--maroon);}
.dash-cols{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;}
.dash-card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow-sm);padding:28px 30px;}
.dash-card h3{font-size:19px;display:flex;align-items:center;gap:9px;}
.dash-card h3 .ic{font-size:21px;}

/* favourites driven by order history */
.picks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:10px;margin-top:18px;}
.pick-item{display:flex;align-items:center;gap:13px;border:1.5px solid var(--line);border-radius:14px;padding:12px 15px;cursor:pointer;color:var(--ink);background:#fff;transition:border-color .15s,background .15s;text-align:left;}
.pick-item:hover{border-color:var(--green);background:var(--cream);}
.pick-item .em{font-size:23px;flex:none;}
.pick-item .pi-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;}
.pick-item .pi-name{font-family:var(--font-d);font-weight:600;font-size:15.5px;color:var(--ink);line-height:1.05;}
.pick-item .pi-bar{height:6px;border-radius:999px;background:var(--cream-2);overflow:hidden;}
.pick-item .pi-bar span{display:block;height:100%;border-radius:999px;background:var(--green);}
.pick-item .pi-count{font-family:var(--font-d);font-weight:600;font-size:14px;color:var(--ink-faint);flex:none;}
.pick-item .heart{color:var(--line);font-size:18px;flex:none;transition:color .15s,transform .15s;}
.pick-item.pinned{border-color:var(--maroon);background:rgba(121,51,56,.05);}
.pick-item.pinned .pi-bar span{background:var(--maroon);}
.pick-item.pinned .heart{color:var(--maroon);transform:scale(1.12);}
.picks-empty{margin-top:18px;border:1.5px dashed var(--line);border-radius:14px;padding:26px 20px;text-align:center;font-weight:700;font-size:14.5px;color:var(--ink-faint);line-height:1.5;}
.picks-demo{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);}
.picks-demo .pd-label{font-size:13px;font-weight:800;color:var(--ink-faint);}
.pd-select{font-family:var(--font-b);font-weight:700;font-size:14px;color:var(--ink);border:1.5px solid var(--line);border-radius:11px;padding:9px 12px;background:#fff;cursor:pointer;}
.pd-select:focus{outline:none;border-color:var(--green);}
.picks-demo .btn{padding:10px 18px;font-size:14px;}
.pd-done{font-size:13px;font-weight:800;color:var(--green-deep);opacity:0;transition:opacity .2s;}
.pd-done.show{opacity:1;}

/* profile fields in dashboard */
.dash-card .qf-field:first-of-type{margin-top:16px;}
.dash-saved{font-size:13px;font-weight:800;color:var(--green-deep);margin-top:14px;opacity:0;transition:opacity .2s;}
.dash-saved.show{opacity:1;}

@media (max-width:860px){
  .acct-card{grid-template-columns:1fr;}
  .acct-aside{padding:36px 30px;}
}
@media (max-width:560px){
  .acct-chip .tx{display:none;}
  .acct-chip{padding:8px;}
}

/* ---- partnership / affiliation ---- */
.partner-verified{display:flex;align-items:center;gap:14px;background:rgba(105,162,84,.1);border:1.5px solid rgba(105,162,84,.4);border-radius:14px;padding:16px 18px;margin-top:18px;}
.pv-badge{width:44px;height:44px;border-radius:50%;background:var(--green);display:grid;place-items:center;flex:none;}
.pv-badge svg{width:23px;height:23px;color:#fff;}
.pv-tx{flex:1;min-width:0;}
.pv-name{font-family:var(--font-d);font-weight:600;font-size:17px;color:var(--green-ink);line-height:1.1;}
.pv-perk{font-size:15.5px;font-weight:800;color:var(--maroon);margin-top:4px;}
.pv-sub{font-size:13px;font-weight:700;color:var(--ink-faint);margin-top:5px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.pv-status{font-family:var(--font-d);font-weight:600;font-size:12px;padding:2px 9px;border-radius:999px;}
.pv-status.ok{background:rgba(105,162,84,.18);color:var(--green-deep);}
.pv-status.soon{background:rgba(232,151,57,.2);color:#b5641f;}
.pv-status.off{background:rgba(147,138,125,.2);color:var(--ink-soft);}
.partner-verified.inactive{background:var(--cream);border-color:var(--line);}
.partner-verified.inactive .pv-badge,.partner-verified .pv-badge.muted{background:var(--ink-faint);}
.pv-unlink{background:none;border:none;cursor:pointer;font-family:var(--font-d);font-weight:500;font-size:14px;color:var(--ink-faint);padding:8px 14px;border-radius:999px;box-shadow:inset 0 0 0 1.5px var(--line);transition:color .15s,box-shadow .15s;flex:none;align-self:flex-start;}
.pv-unlink:hover{color:var(--maroon);box-shadow:inset 0 0 0 1.5px var(--maroon);}
.pv-side{display:flex;flex-direction:column;gap:9px;align-items:flex-end;flex:none;}
.pv-redeem{background:var(--green);color:#fff;border:none;cursor:pointer;font-family:var(--font-d);font-weight:600;font-size:14.5px;padding:11px 20px;border-radius:999px;transition:background .15s;white-space:nowrap;}
.pv-redeem:hover{background:var(--green-deep);}
.pv-used{font-size:12.5px;font-weight:800;color:var(--ink-faint);text-align:right;max-width:150px;line-height:1.4;}

/* staff-confirm redemption modal */
.af-modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:24px;background:rgba(35,32,28,.55);backdrop-filter:blur(4px);opacity:0;transition:opacity .22s ease;}
.af-modal.show{opacity:1;}
.af-modal-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:34px 32px 26px;max-width:380px;width:100%;text-align:center;transform:translateY(12px) scale(.97);transition:transform .28s cubic-bezier(.2,1.3,.4,1);}
.af-modal.show .af-modal-card{transform:none;}
.afm-eyebrow{font-family:var(--font-d);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--ink-faint);}
.afm-org{font-family:var(--font-d);font-weight:600;font-size:22px;color:var(--green-ink);margin-top:10px;}
.afm-perk{font-size:18px;font-weight:800;color:var(--maroon);margin-top:6px;}
.afm-member{font-size:13.5px;font-weight:700;color:var(--ink-soft);margin-top:14px;}
.afm-limit{font-size:12.5px;font-weight:800;color:var(--ink-faint);margin-top:4px;}
.af-modal-card .btn{width:100%;justify-content:center;margin-top:20px;}
.afm-cancel{width:100%;background:none;border:none;cursor:pointer;font-family:var(--font-d);font-weight:500;font-size:14px;color:var(--ink-faint);padding:10px;margin-top:8px;border-radius:10px;}
.afm-cancel:hover{color:var(--maroon);}
.pv-unlink:hover{color:var(--maroon);box-shadow:inset 0 0 0 1.5px var(--maroon);}

/* ---- birthday banner ---- */
.bday-banner{display:flex;align-items:center;gap:16px;background:linear-gradient(100deg,var(--maroon),#9a4148);color:#fff;border-radius:var(--r);padding:20px 26px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;}
.bday-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(40% 120% at 90% 0%, rgba(246,193,31,.28), transparent 60%);pointer-events:none;}
.bday-banner .cake{font-size:34px;flex:none;position:relative;z-index:1;}
.bday-banner .bd-tx{position:relative;z-index:1;display:flex;flex-direction:column;gap:3px;}
.bday-banner .bd-tx b{font-family:var(--font-d);font-weight:600;font-size:19px;}
.bday-banner .bd-tx span{font-size:14.5px;color:rgba(255,255,255,.86);font-weight:700;line-height:1.45;}
