/* ════════════════════════════════════════
   DESIGN TOKENS
════════════════════════════════════════ */
:root {
  --g900: #1a4500;
  --g700: #2a7d00;
  --g600: #3a9e10;
  --g400: #6abf3a;
  --g100: #edf7e3;
  --g50:  #f6fbf1;
  --o600: #c44e0a;
  --o400: #e8651a;
  --o100: #fdf0e8;
  --cream: #faf6ef;
  --warm:  #f3ede3;
  --sand:  #e8e0d2;
  --ink:   #1a1209;
  --ink70: #4a4033;
  --ink40: #8c7e6e;
  --ink20: #c4b9a8;
  --white: #ffffff;
  --card:  #ffffff;
  --border: rgba(26,18,9,0.08);
  --border-strong: rgba(26,18,9,0.15);

  --r-sm: 10px;
  --r:    16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --r-2xl:40px;

  --sh-xs: 0 1px 4px rgba(26,18,9,.06);
  --sh-sm: 0 4px 16px rgba(26,18,9,.07);
  --sh-md: 0 8px 32px rgba(26,18,9,.09);
  --sh-lg: 0 20px 60px rgba(26,18,9,.12);
  --sh-xl: 0 32px 80px rgba(26,18,9,.16);
  --sh-g:  0 16px 48px rgba(42,125,0,.22);

  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --ease-out: cubic-bezier(.22,1,.36,1);
}

/* ════════════════════════════════════════
   RESET & BASE
════════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px }
body {
  background: var(--cream);
  color: var(--ink);
  font-family: "DM Sans", sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { display:block; max-width:100% }
a { text-decoration:none; color:inherit }
button { font-family:inherit; cursor:pointer }

::-webkit-scrollbar { width:3px }
::-webkit-scrollbar-track { background:var(--warm) }
::-webkit-scrollbar-thumb { background:var(--g700); border-radius:4px }
::selection { background:var(--g700); color:#fff }

/* ════════════════════════════════════════
   TRIAL BOOKING SECTION
════════════════════════════════════════ */
.trial-section {
  background: linear-gradient(160deg, var(--g50) 0%, var(--cream) 60%);
  position: relative; overflow: hidden;
}
.trial-section::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(42,125,0,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(42,125,0,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 0%, transparent 100%);
}

.trial-inner {
  display: grid; grid-template-columns: 1fr 1.15fr; gap: 72px; align-items: start;
  position: relative; z-index: 1;
}

.trial-info {}
.trial-info h2 { font-size: clamp(30px,3.8vw,48px); margin-bottom: 14px }
.trial-info p { color: var(--ink40); font-size: 15px; line-height: 1.9; margin-bottom: 28px }

.trial-price-badge {
  display: inline-flex; align-items: center; gap: 14px;
  background: linear-gradient(135deg, #e8651a 0%, #c44e0a 100%);
  color: #fff;
  padding: 16px 28px; border-radius: var(--r-lg);
  margin-bottom: 32px;
  box-shadow: 0 8px 32px rgba(196,78,10,.38), 0 2px 8px rgba(196,78,10,.18);
  position: relative; overflow: hidden;
}
.trial-price-badge::before {
  content: ""; position: absolute; top: -30%; right: -10%;
  width: 90px; height: 90px; border-radius: 50%;
  background: rgba(255,255,255,.12); pointer-events: none;
}
.trial-price-badge::after {
  content: ""; position: absolute; bottom: -25%; left: -5%;
  width: 60px; height: 60px; border-radius: 50%;
  background: rgba(255,255,255,.08); pointer-events: none;
}
.trial-price-badge .amt {
  font-family: "Playfair Display", serif; font-size: 52px; font-weight: 900; line-height: 1;
  text-shadow: 0 2px 8px rgba(0,0,0,.15);
}
.trial-price-badge .amt-label {
  font-family: "Space Grotesk", sans-serif; font-size: 14px; font-weight: 700;
  line-height: 1.4;
}

.trial-features { display: grid; gap: 11px }

.trial-limit-banner {
  display: flex; align-items: center; gap: 14px;
  background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);
  border: 2px solid #f59e0b;
  border-radius: var(--r);
  padding: 14px 18px;
  margin-bottom: 20px;
}
.tlb-icon {
  font-size: 28px; flex-shrink: 0; line-height: 1;
}
.tlb-content { flex: 1 }
.tlb-title {
  font-family: "Space Grotesk", sans-serif;
  font-size: 15px; font-weight: 800;
  color: #92400e; line-height: 1.2; margin-bottom: 3px;
}
.tlb-desc {
  font-family: "Space Grotesk", sans-serif;
  font-size: 12px; color: #b45309; line-height: 1.5;
}
.tlb-dots {
  display: flex; gap: 6px; flex-shrink: 0;
}
.tlb-dot {
  width: 12px; height: 12px; border-radius: 50%;
  background: #f59e0b; border: 2px solid #d97706;
}
.trial-feat {
  display: flex; align-items: center; gap: 12px;
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r); padding: 13px 16px;
  font-size: 14px; font-weight: 500; color: var(--ink70);
  box-shadow: var(--sh-xs); transition: all .22s;
}
.trial-feat:hover { border-color: rgba(42,125,0,.25); transform: translateX(4px); background: var(--g50) }
.trial-feat .tf-icon { font-size: 18px; flex-shrink: 0 }

.trial-form-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-2xl); padding: 38px 36px 36px;
  box-shadow: var(--sh-xl); position: relative; overflow: hidden;
}
.trial-form-card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--g700), var(--g600), var(--o400));
}
.trial-form-card h3 {
  font-size: 22px; margin-bottom: 4px; color: var(--ink);
}
.trial-form-card .tfc-sub {
  font-size: 13px; color: var(--ink40); margin-bottom: 26px;
}

.form-group { margin-bottom: 18px }
.form-group label {
  display: block; font-family: "Space Grotesk", sans-serif;
  font-size: 12px; font-weight: 600; letter-spacing: .06em;
  text-transform: uppercase; color: var(--ink70); margin-bottom: 7px;
}
.form-group label .req { color: var(--o400) }
.form-control {
  width: 100%; padding: 12px 16px;
  background: var(--warm); border: 1.5px solid var(--border);
  border-radius: var(--r); font-family: "DM Sans", sans-serif;
  font-size: 15px; color: var(--ink); outline: none;
  transition: all .22s; appearance: none; -webkit-appearance: none;
}
.form-control:focus {
  border-color: var(--g700); background: var(--g50);
  box-shadow: 0 0 0 3px rgba(42,125,0,.1);
}
.form-control.error {
  border-color: var(--o600); background: var(--o100);
  box-shadow: 0 0 0 3px rgba(196,78,10,.1);
}
.form-control::placeholder { color: var(--ink20) }
select.form-control { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238c7e6e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px; cursor: pointer }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px }

/* Meal Combo Selector */
.meal-combo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.meal-combo-opt {
  position: relative; cursor: pointer;
}
.meal-combo-opt .mco-radio { position: absolute; opacity: 0; width: 0; height: 0 }
.meal-combo-opt .mco-inner {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 12px 8px 10px; border-radius: var(--r);
  background: var(--warm); border: 1.5px solid var(--border);
  text-align: center; transition: all .22s;
}
.meal-combo-opt.meal-combo-wide { grid-column: span 3 }
.meal-combo-opt.meal-combo-wide .mco-inner,
.meal-combo-opt.meal-combo-wide .mco-inner-wide {
  flex-direction: row; justify-content: space-between; align-items: center;
  padding: 12px 16px; text-align: left; gap: 10px;
}
.mco-emoji { font-size: 22px; display: block; margin-bottom: 2px }
.meal-combo-opt.meal-combo-wide .mco-emoji { font-size: 18px; margin-bottom: 0; flex-shrink: 0 }
.mco-title {
  font-family: "Space Grotesk", sans-serif; font-size: 13px;
  font-weight: 700; color: var(--ink); line-height: 1.2;
  display: flex; align-items: center; gap: 5px; flex-wrap: wrap;
}
.mco-time { font-size: 10px; color: var(--ink40); margin-top: 1px; font-family: "Space Grotesk", sans-serif }
.mco-price {
  font-family: "Playfair Display", serif; font-size: 15px;
  font-weight: 900; color: var(--g700); margin-top: 4px;
}
.meal-combo-opt.meal-combo-wide .mco-price { margin-top: 0; flex-shrink: 0; font-size: 17px }
.mco-popular {
  background: var(--o100); color: var(--o600);
  font-size: 9px; font-weight: 700; padding: 2px 7px;
  border-radius: 100px; font-family: "Space Grotesk", sans-serif;
  letter-spacing: .04em; text-transform: uppercase;
}
.mco-best {
  background: var(--g50); color: var(--g700);
  font-size: 9px; font-weight: 700; padding: 2px 7px;
  border-radius: 100px; font-family: "Space Grotesk", sans-serif;
  letter-spacing: .04em; text-transform: uppercase;
}
.meal-combo-opt .mco-radio:checked + .mco-inner,
.meal-combo-opt.selected .mco-inner {
  background: var(--g50); border-color: var(--g700);
  box-shadow: 0 0 0 2px rgba(42,125,0,.15);
}
.meal-combo-all .mco-radio:checked + .mco-inner,
.meal-combo-all.selected .mco-inner {
  background: linear-gradient(135deg, rgba(42,125,0,.06), var(--g50));
  border-color: var(--g700);
}
.meal-combo-opt .mco-inner:hover { border-color: rgba(42,125,0,.3); background: var(--g50) }
@media (max-width: 480px) {
  .meal-combo-grid { grid-template-columns: repeat(3, 1fr) }
  .mco-title { font-size: 11px }
  .mco-price { font-size: 13px }
}

.field-hint { font-size: 11px; color: var(--ink40); margin-top: 5px; line-height: 1.5 }

/* ── PERSON COUNTER ── */
.person-counter-wrap {
  display: flex; align-items: center; gap: 0;
  background: var(--warm); border: 1.5px solid var(--border);
  border-radius: var(--r); overflow: hidden; width: 100%;
}
.pc-btn {
  width: 48px; height: 48px; flex-shrink: 0;
  background: var(--white); border: none; cursor: pointer;
  font-size: 20px; font-weight: 300; color: var(--ink70);
  display: flex; align-items: center; justify-content: center;
  transition: all .18s; font-family: inherit;
}
.pc-btn:hover { background: var(--g50); color: var(--g700) }
.pc-btn:active { transform: scale(.92) }
.pc-btn:disabled { opacity: .35; cursor: not-allowed }
.pc-divider { width: 1px; height: 30px; background: var(--border); flex-shrink: 0 }
.pc-display {
  flex: 1; text-align: center;
  font-family: "Playfair Display", serif; font-size: 22px;
  font-weight: 900; color: var(--ink); line-height: 1;
}
.pc-display-sub {
  font-family: "Space Grotesk", sans-serif;
  font-size: 10px; color: var(--ink40); font-weight: 500;
  display: block; margin-top: 2px; letter-spacing: .04em;
  text-transform: uppercase;
}

.price-preview {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--g50); border: 1px solid rgba(42,125,0,.18);
  border-radius: var(--r); padding: 10px 14px; margin-top: 8px;
  font-family: "Space Grotesk", sans-serif;
}
.price-preview-label { font-size: 12px; color: var(--ink40); font-weight: 500 }
.price-preview-amt {
  font-family: "Playfair Display", serif;
  font-size: 20px; font-weight: 900; color: var(--g700);
  transition: all .2s;
}
.price-preview-note { font-size: 10px; color: var(--ink40); margin-top: 1px; display: block }
.field-err { font-size: 11px; color: var(--o600); margin-top: 5px; display: none }
.field-err.show { display: block }

.trial-submit {
  width: 100%; padding: 16px; margin-top: 8px;
  background: var(--g700); color: #fff; border: none; border-radius: 100px;
  font-family: "Space Grotesk", sans-serif; font-size: 16px; font-weight: 700;
  cursor: pointer; box-shadow: 0 6px 24px rgba(42,125,0,.3);
  transition: all .28s var(--ease-spring); display: flex; align-items: center;
  justify-content: center; gap: 10px;
}
.trial-submit:hover { background: var(--g900); transform: translateY(-2px); box-shadow: var(--sh-g) }
.trial-submit:active { transform: scale(.97) }
.trial-submit:disabled { opacity: .65; cursor: not-allowed; transform: none }

.trial-submit .ts-loader {
  width: 16px; height: 16px; border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff; border-radius: 50%;
  animation: spin .7s linear infinite; display: none;
}
.trial-submit.loading .ts-txt { display: none }
.trial-submit.loading .ts-loader { display: block }
@keyframes spin { to { transform: rotate(360deg) } }

/* Success state */
.trial-success {
  display: none; text-align: center; padding: 20px 0;
}
.trial-success.show { display: block }
.ts-check {
  width: 72px; height: 72px; border-radius: 50%;
  background: linear-gradient(135deg, var(--g700), var(--g600));
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; margin: 0 auto 20px;
  box-shadow: var(--sh-g);
  animation: popIn .5s var(--ease-spring) both;
}
@keyframes popIn { from { transform: scale(0); opacity: 0 } to { transform: scale(1); opacity: 1 } }
.ts-title { font-family: "Playfair Display", serif; font-size: 26px; margin-bottom: 10px }
.ts-msg { color: var(--ink40); font-size: 14px; line-height: 1.8; margin-bottom: 24px }
.ts-wa-btn {
  display: inline-flex; align-items: center; gap: 9px;
  background: #25d366; color: #fff; padding: 14px 28px;
  border-radius: 100px; font-family: "Space Grotesk", sans-serif;
  font-size: 15px; font-weight: 700; cursor: pointer; border: none;
  box-shadow: 0 6px 20px rgba(37,211,102,.3); transition: all .25s;
}
.ts-wa-btn:hover { background: #1fb857; transform: translateY(-2px) }

.date-notice {
  background: var(--o100); border: 1px solid rgba(196,78,10,.2);
  border-radius: var(--r); padding: 11px 14px;
  font-size: 12px; color: var(--o600); margin-top: 6px;
  display: flex; align-items: flex-start; gap: 8px; line-height: 1.5;
}
.date-notice .dn-icon { flex-shrink: 0; font-size: 14px }

.area-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--g50); border: 1px solid rgba(42,125,0,.2);
  color: var(--g700); font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: 100px; margin-top: 7px;
  font-family: "Space Grotesk", sans-serif;
}
.area-badge::before { content: "✓"; font-weight: 800 }

/* Responsive */
@media (max-width: 860px) {
  .trial-inner { grid-template-columns: 1fr; gap: 40px }
  .trial-form-card { padding: 28px 20px 24px }
  .form-row { grid-template-columns: 1fr }
}
@media (max-width: 480px) {
  .trial-price-badge .amt { font-size: 34px }
  .meal-selector { grid-template-columns: repeat(3,1fr) }
}

/* ── MAP LOCATION PICKER ── */
.map-picker-wrap {
  border-radius: var(--r);
  border: 1.5px solid var(--border); margin-top: 7px;
  box-shadow: var(--sh-xs); position: relative;
}
#deliveryMap {
  height: 260px; width: 100%; display: block;
}
.map-search-box {
  position: absolute; top: 10px; left: 10px; right: 10px; z-index: 1001;
  display: flex; gap: 6px;
}
.map-search-input {
  flex: 1; padding: 9px 14px;
  background: rgba(255,255,255,.96); backdrop-filter: blur(8px);
  border: 1.5px solid var(--border); border-radius: 100px;
  font-family: "DM Sans", sans-serif; font-size: 13px; color: var(--ink);
  outline: none; box-shadow: var(--sh-sm);
  transition: border-color .2s;
}
.map-search-input:focus { border-color: var(--g700) }
.map-search-btn {
  padding: 9px 16px; border-radius: 100px;
  background: var(--g700); color: #fff; border: none;
  font-size: 13px; font-weight: 600; cursor: pointer;
  white-space: nowrap; box-shadow: var(--sh-sm);
  font-family: "Space Grotesk", sans-serif;
  transition: background .2s;
}
.map-search-btn:hover { background: var(--g900) }
.map-locate-btn {
  position: absolute; bottom: 10px; right: 10px; z-index: 999;
  width: 36px; height: 36px; border-radius: 50%;
  background: #fff; border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; box-shadow: var(--sh-sm); font-size: 16px;
  transition: all .2s;
}
.map-locate-btn:hover { background: var(--g50); border-color: var(--g700) }
.map-hint {
  font-size: 11px; color: var(--ink40); margin-top: 6px;
  display: flex; align-items: center; gap: 5px;
}
.map-coords-badge {
  display: none; align-items: center; gap: 6px;
  background: var(--g50); border: 1px solid rgba(42,125,0,.2);
  color: var(--g700); font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: 100px; margin-top: 6px;
  font-family: "Space Grotesk", sans-serif;
}
.map-coords-badge.show { display: inline-flex }
.payment-advance-notice {
  display: flex; align-items: flex-start; gap: 10px;
  background: var(--o100); border: 1px solid rgba(232,101,26,.25);
  border-radius: var(--r); padding: 12px 14px; margin-bottom: 18px;
  font-size: 13px; color: var(--ink70); line-height: 1.5;
}
.payment-advance-notice .pan-icon { font-size: 18px; flex-shrink: 0 }
.payment-advance-notice strong { color: var(--o600) }

/* ════════════════════════════════════════
   LAYOUT
════════════════════════════════════════ */
.wrap { max-width:1140px; margin:0 auto; padding:0 28px }
.section { padding:100px 0 }
.s-head { text-align:center; margin-bottom:72px }
.s-head h2 { font-size:clamp(32px,4.2vw,52px); margin-bottom:14px; letter-spacing:-.02em }
.s-head p { font-size:16px; color:var(--ink40); max-width:500px; margin:0 auto; line-height:1.8 }

/* ════════════════════════════════════════
   TYPOGRAPHY
════════════════════════════════════════ */
h1,h2,h3,h4 { font-family:"Playfair Display",serif; line-height:1.1; letter-spacing:-.02em }
.eyebrow {
  display:inline-flex; align-items:center; gap:7px;
  font-family:"Space Grotesk",sans-serif;
  font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--g700);
  background:var(--g50); border:1px solid rgba(42,125,0,.2);
  padding:5px 13px; border-radius:100px;
  margin-bottom:18px;
}
.eyebrow::before { content:""; width:6px; height:6px; border-radius:50%; background:var(--g700); flex-shrink:0 }

/* ════════════════════════════════════════
   BUTTONS
════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:"Space Grotesk",sans-serif; font-weight:600;
  border:none; cursor:pointer; border-radius:100px;
  transition:all .28s var(--ease-spring);
  white-space:nowrap; position:relative; overflow:hidden;
}
.btn::after {
  content:""; position:absolute; inset:0; border-radius:100px;
  background:rgba(255,255,255,0); transition:background .2s;
}
.btn:hover::after { background:rgba(255,255,255,.08) }
.btn:active { transform:scale(.97) }

.btn-g {
  background:var(--g700); color:#fff; font-size:15px; padding:14px 30px;
  box-shadow:0 4px 20px rgba(42,125,0,.28);
}
.btn-g:hover { background:var(--g900); transform:translateY(-2px); box-shadow:var(--sh-g) }

.btn-o {
  background:var(--o400); color:#fff; font-size:15px; padding:14px 30px;
  box-shadow:0 4px 20px rgba(232,101,26,.25);
}
.btn-o:hover { background:var(--o600); transform:translateY(-2px) }

.btn-outline {
  background:transparent; color:var(--ink); font-size:14px; padding:13px 26px;
  border:1.5px solid var(--border-strong); font-weight:500;
}
.btn-outline:hover { border-color:var(--g700); color:var(--g700); background:var(--g50) }

.btn-white {
  background:#fff; color:var(--g700); font-size:15px; padding:14px 30px;
  box-shadow:var(--sh-md);
}
.btn-white:hover { transform:translateY(-2px); box-shadow:var(--sh-lg) }

.btn-lg { font-size:17px !important; padding:17px 38px !important }

/* ════════════════════════════════════════
   HEADER
════════════════════════════════════════ */
#header {
  position:fixed; top:0; left:0; right:0; z-index:500;
  transition:all .35s var(--ease-out);
}
.header-pill {
  margin:12px auto; max-width:1100px; padding:0 20px;
}
.header-inner {
  background:rgba(250,246,239,.9);
  backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
  border:1px solid var(--border);
  border-radius:100px;
  padding:10px 10px 10px 20px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  box-shadow:var(--sh-sm);
  transition:all .35s var(--ease-out);
}
#header.scrolled .header-inner {
  background:rgba(250,246,239,.97);
  box-shadow:var(--sh-md);
}
.logo { display:flex; align-items:center; gap:10px }
.logo-mark {
  width:44px; height:44px; border-radius:10px;
  overflow:hidden; flex-shrink:0;
  box-shadow:0 4px 14px rgba(42,125,0,.22);
}
.logo-mark img {
  width:100%; height:100%; object-fit:cover; object-position:center 30%;
  display:block;
}
.logo-text-wrap { display:flex; flex-direction:column; gap:5px }
.logo-name { font-family:"Playfair Display",serif; font-size:16px; font-weight:700; color:var(--ink); line-height:1; margin-bottom:6px }
.logo-tagline { font-family:"Space Grotesk",sans-serif; font-size:9px; color:var(--ink40); letter-spacing:.14em; text-transform:uppercase; line-height:1; margin-top:0 }

nav { display:flex; align-items:center; gap:2px }
nav a {
  color:var(--ink70); font-family:"Space Grotesk",sans-serif; font-size:13px; font-weight:500;
  padding:7px 13px; border-radius:100px; transition:all .18s;
}
nav a:hover { color:var(--ink); background:var(--warm) }

.nav-cta { display:flex; align-items:center; gap:8px }

.hamburger {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  width:38px; height:38px; align-items:center; justify-content:center;
  border-radius:10px; border:1px solid var(--border); background:var(--warm);
  transition:all .2s;
}
.hamburger span { width:18px; height:1.5px; background:var(--ink); border-radius:2px; transition:all .3s; display:block }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(4.5px,4.5px) }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0) }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(4.5px,-4.5px) }

.mnav {
  display:none; position:fixed; inset:0; z-index:490;
  background:var(--cream); flex-direction:column; align-items:center; justify-content:flex-start; gap:2px;
  padding:80px 24px 32px; overflow-y:auto;
}
.mnav.open { display:flex }
.mnav-x {
  position:absolute; top:18px; right:18px;
  width:38px; height:38px; border-radius:50%; border:1px solid var(--border);
  background:var(--warm); display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:16px; color:var(--ink70); transition:all .2s;
}
.mnav a {
  font-family:"Space Grotesk",sans-serif; font-size:16px; font-weight:600;
  color:var(--ink); padding:12px 24px; border-radius:12px; width:100%; max-width:320px;
  text-align:center; transition:all .2s; opacity:0; animation:slideUp .4s var(--ease-out) forwards;
}
.mnav a:hover { background:var(--warm); color:var(--g700) }
.mnav a:nth-child(2) { animation-delay:.04s }
.mnav a:nth-child(3) { animation-delay:.08s }
.mnav a:nth-child(4) { animation-delay:.12s }
.mnav a:nth-child(5) { animation-delay:.16s }
.mnav a:nth-child(6) { animation-delay:.20s }
.mnav-line { width:100%; max-width:320px; height:1px; background:var(--border); margin:10px 0; opacity:0; animation:slideUp .4s .22s forwards }
.mnav-btns { display:flex; flex-direction:column; gap:10px; width:100%; max-width:320px; opacity:0; animation:slideUp .4s .26s forwards }

/* ════════════════════════════════════════
   HERO
════════════════════════════════════════ */
.hero {
  min-height:100vh; display:flex; align-items:center;
  padding:130px 0 90px; position:relative; overflow:hidden;
}
.hero-ambient {
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 65% 50% at 68% 30%, rgba(42,125,0,.07) 0%, transparent 60%),
    radial-gradient(ellipse 45% 40% at 15% 75%, rgba(232,101,26,.05) 0%, transparent 60%),
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(42,125,0,.04) 0%, transparent 50%);
}
.hero-grid-bg {
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:
    linear-gradient(rgba(26,18,9,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26,18,9,.04) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 0%, transparent 100%);
}
.hero-inner {
  display:grid; grid-template-columns:1.05fr .95fr; gap:72px; align-items:center;
  position:relative; z-index:2;
}

.hero-badge { display:flex; align-items:center; gap:8px; margin-bottom:24px; flex-wrap:wrap }
.hero-stars {
  display:inline-flex; align-items:center; gap:6px;
  background:#fff; border:1px solid var(--border); border-radius:100px;
  padding:5px 13px; font-size:12px; font-weight:600; color:var(--ink);
  box-shadow:var(--sh-xs);
}
.hero-stars .s { color:#f59e0b; font-size:11px; letter-spacing:1px }
.hero-since {
  display:inline-flex; align-items:center; gap:5px;
  background:var(--g50); border:1px solid rgba(42,125,0,.2); border-radius:100px;
  padding:5px 12px; font-size:12px; font-weight:600; color:var(--g700);
  font-family:"Space Grotesk",sans-serif;
}

.hero h1 {
  font-size:clamp(44px,5.8vw,76px); font-weight:900;
  line-height:1.02; margin-bottom:10px;
}
.hero h1 .accent { color:var(--g700); font-style:italic; display:block }
.hero-sub {
  font-size:17px; color:var(--ink40); max-width:420px;
  line-height:1.8; margin-bottom:38px; font-weight:400;
}
.hero-actions { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:56px }

.hero-stats { display:flex; align-items:center; gap:0 }
.h-stat { padding:0 28px; text-align:center }
.h-stat:first-child { padding-left:0 }
.h-stat-num {
  font-family:"Playfair Display",serif; font-size:32px; font-weight:900;
  color:var(--ink); line-height:1;
}
.h-stat-num b { color:var(--g700) }
.h-stat-label { font-size:11px; color:var(--ink40); margin-top:4px; font-family:"Space Grotesk",sans-serif; letter-spacing:.04em }
.h-stat-sep { width:1px; height:40px; background:var(--border); flex-shrink:0 }

.hero-card {
  background:var(--white); border-radius:var(--r-2xl);
  border:1px solid var(--border); overflow:visible;
  box-shadow:var(--sh-xl); position:relative;
}
.hc-img {
  border-radius:var(--r-xl) var(--r-xl) 0 0; overflow:hidden; position:relative;
}
.hc-img img {
  width:100%; height:280px; object-fit:cover; object-position:center 38%;
  transition:transform .7s var(--ease-out); display:block;
}
.hero-card:hover .hc-img img { transform:scale(1.05) }
.hc-img-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(10,20,5,.5) 0%, rgba(10,20,5,.15) 40%, transparent 70%);
}
.hc-img-tag {
  position:absolute; bottom:16px; left:16px;
  background:rgba(255,255,255,.15); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.25);
  color:#fff; font-size:12px; font-weight:600; padding:7px 14px;
  border-radius:100px; display:flex; align-items:center; gap:6px;
  font-family:"Space Grotesk",sans-serif; letter-spacing:.04em;
}
.hc-body { padding:22px 24px 24px }
.hc-rating {
  display:flex; align-items:center; gap:10px;
  background:var(--g50); border:1px solid rgba(42,125,0,.15);
  border-radius:14px; padding:12px 16px; margin-bottom:14px;
}
.hc-stars { color:#f59e0b; font-size:15px; letter-spacing:1px }
.hc-rating strong { font-size:13px; color:var(--ink); display:block; line-height:1.2 }
.hc-rating small { font-size:11px; color:var(--ink40) }
.hc-chips { display:flex; gap:7px; flex-wrap:wrap }
.chip {
  background:var(--warm); color:var(--ink70);
  font-size:11px; font-weight:600; padding:6px 13px;
  border-radius:100px; border:1px solid var(--border);
  font-family:"Space Grotesk",sans-serif; letter-spacing:.03em;
  transition:all .2s;
}
.chip:hover { background:var(--g50); color:var(--g700); border-color:rgba(42,125,0,.25) }

.fbadge {
  position:absolute; background:var(--white); border:1px solid var(--border);
  border-radius:var(--r); padding:10px 15px; font-size:12px; font-weight:600;
  font-family:"Space Grotesk",sans-serif;
  box-shadow:var(--sh-md); display:flex; align-items:center; gap:8px;
  white-space:nowrap; z-index:10; color:var(--ink);
  animation:bobble 4s ease-in-out infinite;
}
.fb-tl { top:-18px; left:-18px; animation-delay:0s }
.fb-br { bottom:-18px; right:-18px; animation-delay:-2s }
.fb-dot { width:8px; height:8px; border-radius:50%; background:#22c55e; flex-shrink:0; box-shadow:0 0 0 3px rgba(34,197,94,.2) }
@keyframes bobble { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

/* ════════════════════════════════════════
   TICKER
════════════════════════════════════════ */
.ticker {
  background:var(--g700); padding:14px 0; overflow:hidden;
  position:relative;
}
.ticker::before,.ticker::after {
  content:""; position:absolute; top:0; bottom:0; width:80px; z-index:2; pointer-events:none;
}
.ticker::before { left:0; background:linear-gradient(to right,var(--g700),transparent) }
.ticker::after { right:0; background:linear-gradient(to left,var(--g700),transparent) }
.ticker-inner {
  display:flex; gap:0; animation:tick 25s linear infinite; width:max-content;
}
.ticker-item {
  display:flex; align-items:center; gap:8px;
  padding:0 32px; font-size:13px; font-weight:500;
  font-family:"Space Grotesk",sans-serif; color:rgba(255,255,255,.8);
  white-space:nowrap;
}
.ticker-item strong { color:#fff }
.ticker-sep { color:rgba(255,255,255,.3); font-size:18px }
@keyframes tick { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ════════════════════════════════════════
   ABOUT
════════════════════════════════════════ */
.about-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:80px; align-items:center }

.about-visual { position:relative }
.about-card-main {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:44px 40px 40px;
  box-shadow:var(--sh-lg); position:relative; overflow:hidden;
  text-align:center;
}
.about-card-main::before {
  content:""; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--g700),var(--g600),var(--o400));
}
.about-monogram {
  width:130px; height:130px; border-radius:20px; margin:0 auto 18px;
  overflow:hidden; background:var(--warm);
  box-shadow:0 8px 32px rgba(42,125,0,.18);
}
.about-monogram img {
  width:100%; height:100%; object-fit:cover; object-position:center 30%;
  display:block;
}
.about-pill {
  display:inline-block; background:var(--o400); color:#fff;
  font-size:11px; font-weight:700; padding:5px 14px; border-radius:100px;
  margin-bottom:14px; font-family:"Space Grotesk",sans-serif; letter-spacing:.06em;
}
.about-card-main > p { font-size:14px; color:var(--ink40); line-height:1.85 }
.feat-list { margin-top:26px; display:grid; gap:9px; text-align:left }
.feat-row {
  display:flex; align-items:center; gap:12px;
  background:var(--warm); border:1px solid var(--border);
  border-radius:12px; padding:12px 14px; font-size:14px;
  transition:all .22s;
}
.feat-row:hover { background:var(--g50); border-color:rgba(42,125,0,.2); transform:translateX(4px) }
.feat-row .ic { font-size:17px; flex-shrink:0 }
.feat-row strong { display:block; font-size:13px; color:var(--ink); font-weight:600 }
.feat-row span { font-size:11px; color:var(--ink40) }

.about-float {
  position:absolute; background:var(--white); border:1px solid var(--border);
  border-radius:var(--r); padding:12px 16px; box-shadow:var(--sh-md);
  font-family:"Space Grotesk",sans-serif; animation:bobble 5s ease-in-out infinite;
}
.about-float-tl { top:-20px; right:-20px; animation-delay:0s }
.about-float-br { bottom:-20px; left:-20px; animation-delay:-2.5s }
.about-float .af-val { font-size:22px; font-weight:700; color:var(--g700); line-height:1 }
.about-float .af-lbl { font-size:10px; color:var(--ink40); letter-spacing:.06em; text-transform:uppercase }

.about-text h2 { font-size:clamp(30px,3.5vw,46px); margin-bottom:20px }
.about-text p { color:var(--ink40); font-size:15px; line-height:1.9; margin-bottom:22px }
.about-text strong { color:var(--ink); font-weight:600 }

/* ════════════════════════════════════════
   MENU
════════════════════════════════════════ */

.day-card.today {
  background: var(--g50);
  border: 2px solid var(--g700);
  box-shadow: 0 4px 16px rgba(42,125,0,.15);
}
.day-card.today .day-name { color: var(--g700); font-weight: 800; }
.today-tag {
  background: var(--g700); color: #fff;
  font-size: 9px; font-weight: 700; padding: 2px 7px;
  border-radius: 100px; letter-spacing: .05em;
  text-transform: uppercase; font-family: 'Space Grotesk', sans-serif;
  vertical-align: middle; margin-left: 5px;
}
.day-included {
  font-size: 10px; color: var(--ink40); margin-top: 4px;
  font-family: 'Space Grotesk', sans-serif; font-style: italic;
}

.menu-tabs-wrap { display:flex; justify-content:center; margin-bottom:36px }
.menu-tabs {
  display:flex; gap:4px;
  background:var(--white); border:1px solid var(--border);
  border-radius:100px; padding:5px; box-shadow:var(--sh-xs);
}
.menu-tab {
  padding:10px 24px; border-radius:100px; font-size:14px; font-weight:600;
  border:none; background:transparent; color:var(--ink40); cursor:pointer;
  font-family:"Space Grotesk",sans-serif; transition:all .22s;
}
.menu-tab.on { background:var(--g700); color:#fff; box-shadow:0 4px 14px rgba(42,125,0,.3) }
.menu-tab:not(.on):hover { color:var(--ink); background:var(--warm) }

.menu-grid {
  display:grid; grid-template-columns:repeat(7,1fr); gap:12px;
}
.day-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r); padding:18px 12px; text-align:center;
  box-shadow:var(--sh-xs); transition:all .25s var(--ease-spring);
  cursor:default;
}
.day-card:hover {
  border-color:var(--g700); transform:translateY(-6px);
  box-shadow:0 16px 40px rgba(42,125,0,.15);
}
.day-name {
  font-family:"Space Grotesk",sans-serif; font-size:10px; font-weight:700;
  color:var(--g700); text-transform:uppercase; letter-spacing:.12em; margin-bottom:12px;
}
.day-food { font-size:12px; color:var(--ink70); line-height:1.5; padding:5px 0; border-bottom:1px solid var(--border) }
.day-food:last-child { border-bottom:none; color:var(--ink40); font-size:11px; margin-top:6px }

/* ════════════════════════════════════════
   PLANS
════════════════════════════════════════ */
.plans-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; align-items:stretch;
}
.plan {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r-xl); padding:36px 30px 30px;
  display:flex; flex-direction:column;
  box-shadow:var(--sh-sm);
  transition:all .3s var(--ease-out); position:relative; overflow:hidden;
}
.plan:hover { transform:translateY(-8px); box-shadow:var(--sh-xl); border-color:rgba(42,125,0,.3) }
.plan.featured {
  background:linear-gradient(160deg,rgba(42,125,0,.06) 0%,#fff 55%);
  border-color:rgba(42,125,0,.35);
  box-shadow:var(--sh-lg);
}
.plan-ribbon {
  position:absolute; top:0; right:0;
  background:var(--g700); color:#fff; font-size:9px; font-weight:700;
  padding:8px 18px 7px; font-family:"Space Grotesk",sans-serif; letter-spacing:.12em;
  border-radius:0 var(--r-xl) 0 14px;
}
.plan-icon { font-size:30px; margin-bottom:14px }
.plan-name {
  font-family:"Playfair Display",serif; font-size:22px; font-weight:700;
  margin-bottom:5px; color:var(--ink);
}
.plan-desc { font-size:13px; color:var(--ink40); margin-bottom:24px }
.plan-price {
  display:flex; align-items:baseline; gap:5px; flex-wrap:wrap; margin-bottom:24px;
}
.plan-amt { font-family:"Playfair Display",serif; font-size:46px; font-weight:900; color:var(--ink); line-height:1 }
.plan-per { font-size:13px; color:var(--ink40) }
.plan-was { font-size:14px; color:var(--ink20); text-decoration:line-through; margin-left:4px }
.plan-save {
  background:var(--o100); color:var(--o600); font-size:10px; font-weight:700;
  padding:3px 9px; border-radius:100px; font-family:"Space Grotesk",sans-serif;
  margin-left:2px; letter-spacing:.04em;
}
.plan-feats { list-style:none; flex:1; display:grid; gap:9px; margin-bottom:28px }
.plan-feats li {
  display:flex; align-items:flex-start; gap:9px;
  font-size:14px; color:var(--ink70); line-height:1.5;
}
.plan-feats li::before {
  content:"✓"; color:var(--g700); font-weight:800; font-size:12px;
  margin-top:2px; flex-shrink:0;
  width:18px; height:18px; background:var(--g50); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(42,125,0,.2);
}

.trial-bar {
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  flex-wrap:wrap; margin-top:48px;
  background:linear-gradient(135deg,var(--g50),var(--cream));
  border:1.5px dashed rgba(42,125,0,.3);
  border-radius:var(--r-lg); padding:28px 32px;
}
.trial-bar-left strong { display:block; font-size:16px; color:var(--ink); margin-bottom:4px; font-family:"Space Grotesk",sans-serif; font-weight:700 }
.trial-bar-left span { font-size:14px; color:var(--ink40) }

/* ════════════════════════════════════════
   WHY US
════════════════════════════════════════ */
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.why-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:32px 28px;
  box-shadow:var(--sh-xs); transition:all .28s var(--ease-out);
  position:relative; overflow:hidden;
}
.why-card::before {
  content:""; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--g700),var(--g600));
  transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease-out);
}
.why-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); border-color:rgba(42,125,0,.2) }
.why-card:hover::before { transform:scaleX(1) }
.why-card.full { grid-column:1/-1; display:flex; gap:32px; align-items:center }
.why-icon-wrap {
  width:60px; height:60px; border-radius:16px; flex-shrink:0;
  background:var(--g50); border:1px solid rgba(42,125,0,.15);
  display:flex; align-items:center; justify-content:center; font-size:26px;
  margin-bottom:18px; transition:all .25s;
}
.why-card:hover .why-icon-wrap { background:var(--g100); transform:scale(1.08) }
.why-card.full .why-icon-wrap { margin-bottom:0 }
.why-card h3 {
  font-family:"Space Grotesk",sans-serif; font-size:17px; font-weight:700;
  color:var(--ink); margin-bottom:8px;
}
.why-card p { font-size:14px; color:var(--ink40); line-height:1.8 }

/* ════════════════════════════════════════
   PROMISE BAND
════════════════════════════════════════ */
.promise {
  margin:0; padding:80px 0; position:relative; overflow:hidden;
  background:linear-gradient(135deg,var(--g900) 0%,var(--g700) 60%,var(--g600) 100%);
}
.promise::before {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle 300px at 20% 50%,rgba(255,255,255,.05) 0%,transparent 70%),
    radial-gradient(circle 200px at 80% 20%,rgba(255,255,255,.04) 0%,transparent 60%);
}
.promise-inner { position:relative; z-index:1; text-align:center }
.promise .eyebrow {
  background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.2);
  color:rgba(255,255,255,.9); justify-content:center; margin-bottom:20px;
}
.promise .eyebrow::before { background:rgba(255,255,255,.8) }
.promise h2 { font-size:clamp(26px,3.5vw,42px); color:#fff; margin-bottom:10px }
.promise p { color:rgba(255,255,255,.7); max-width:520px; margin:0 auto 40px; font-size:16px; line-height:1.8 }
.promise-badges { display:flex; justify-content:center; gap:12px; flex-wrap:wrap }
.pbadge {
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(10px); color:#fff;
  border-radius:100px; padding:11px 20px; font-size:13px; font-weight:500;
  font-family:"Space Grotesk",sans-serif;
  display:flex; align-items:center; gap:7px;
  transition:all .22s;
}
.pbadge:hover { background:rgba(255,255,255,.18); transform:translateY(-2px) }

/* ════════════════════════════════════════
   TESTIMONIALS
════════════════════════════════════════ */
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.review-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:30px 28px;
  box-shadow:var(--sh-xs); transition:all .28s var(--ease-out);
  display:flex; flex-direction:column;
}
.review-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); border-color:rgba(42,125,0,.2) }
.rv-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px }
.rv-stars { color:#f59e0b; font-size:14px; letter-spacing:2px }
.rv-source {
  font-size:10px; color:var(--ink40); font-family:"Space Grotesk",sans-serif;
  letter-spacing:.06em; text-transform:uppercase;
  background:var(--warm); padding:3px 9px; border-radius:100px;
}
.rv-quote { font-size:38px; color:var(--g700); font-family:"Playfair Display",serif; line-height:.8; margin-bottom:10px }
.rv-text { font-size:14px; color:var(--ink70); line-height:1.85; font-style:italic; flex:1; margin-bottom:20px }
.rv-author { display:flex; align-items:center; gap:12px; padding-top:18px; border-top:1px solid var(--border) }
.rv-avatar {
  width:40px; height:40px; border-radius:50%; flex-shrink:0;
  background:var(--g50); border:2px solid rgba(42,125,0,.15);
  display:flex; align-items:center; justify-content:center; font-size:18px;
}
.rv-name { font-family:"Space Grotesk",sans-serif; font-size:14px; font-weight:700; color:var(--ink) }
.rv-meta { font-size:11px; color:var(--ink40) }

/* ════════════════════════════════════════
   FAQ
════════════════════════════════════════ */
.faq-wrap { max-width:740px; margin:0 auto }
.faq-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-sm);
}
.faq-item { border-bottom:1px solid var(--border) }
.faq-item:last-child { border-bottom:none }
.faq-q {
  width:100%; background:none; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 28px; gap:20px; text-align:left;
  font-size:15px; font-weight:600; color:var(--ink);
  font-family:"Space Grotesk",sans-serif;
  transition:background .2s;
}
.faq-q:hover { background:var(--warm) }
.faq-item.open .faq-q { background:var(--g50); color:var(--g700) }
.faq-icon-btn {
  width:28px; height:28px; border-radius:50%; flex-shrink:0;
  background:var(--warm); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-weight:300; color:var(--ink40);
  transition:all .3s var(--ease-spring);
}
.faq-item.open .faq-icon-btn {
  background:var(--g700); color:#fff; border-color:var(--g700);
  transform:rotate(45deg);
}
.faq-a {
  font-size:14px; color:var(--ink40); line-height:1.85;
  max-height:0; overflow:hidden; padding:0 28px;
  transition:max-height .38s var(--ease-out), padding .38s var(--ease-out);
}
.faq-item.open .faq-a { max-height:300px; padding:0 28px 22px }

/* ════════════════════════════════════════
   LOCATION
════════════════════════════════════════ */
.loc-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-lg);
}

.loc-info { display:grid; grid-template-columns:repeat(4,1fr); gap:0 }
.loc-cell {
  padding:28px 24px; border-right:1px solid var(--border);
  transition:background .2s;
}
.loc-cell:last-child { border-right:none }
.loc-cell:hover { background:var(--warm) }
.loc-icon-wrap { font-size:20px; margin-bottom:10px }
.loc-lbl {
  font-size:10px; color:var(--ink40); text-transform:uppercase;
  letter-spacing:.1em; font-family:"Space Grotesk",sans-serif;
  font-weight:700; margin-bottom:6px;
}
.loc-val { font-size:13px; color:var(--ink); line-height:1.7 }
.loc-val a { color:var(--g700); font-weight:600 }

/* ════════════════════════════════════════
   CTA FINAL
════════════════════════════════════════ */
.cta-final {
  text-align:center; padding:110px 28px;
  position:relative; overflow:hidden;
  background:var(--warm);
}
.cta-final::before {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 70% at 50% 50%,rgba(42,125,0,.07) 0%,transparent 70%),
    radial-gradient(ellipse 50% 40% at 20% 80%,rgba(232,101,26,.04) 0%,transparent 60%);
}
.cta-final > * { position:relative; z-index:1 }
.cta-final .eyebrow { justify-content:center }
.cta-final h2 { font-size:clamp(32px,5vw,60px); margin-bottom:16px }
.cta-final p { font-size:18px; color:var(--ink40); max-width:480px; margin:0 auto 44px; line-height:1.8 }
.cta-actions { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap }

/* ════════════════════════════════════════
   FOOTER
════════════════════════════════════════ */
footer {
  background:var(--ink); color:rgba(255,255,255,.6);
  padding:60px 0 0;
}
.footer-top {
  display:grid; grid-template-columns:1.8fr 1fr 1fr; gap:60px;
  padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.08);
}
.ft-brand p { font-size:13px; line-height:1.9; max-width:270px; margin-top:16px }
.ft-logo { display:flex; align-items:center; gap:10px }
.ft-logo-mark {
  width:44px; height:44px; border-radius:10px;
  overflow:hidden; flex-shrink:0;
}
.ft-logo-mark img {
  width:100%; height:100%; object-fit:cover; object-position:center 30%;
  display:block;
}
.ft-logo-name { font-family:"Playfair Display",serif; font-size:16px; font-weight:700; color:#fff }
.ft-logo-sub { font-size:9px; color:rgba(255,255,255,.35); letter-spacing:.14em; text-transform:uppercase; font-family:"Space Grotesk",sans-serif }
.ft-social { display:flex; gap:10px; margin-top:20px }
.ft-social a { color:rgba(255,255,255,.4); font-size:13px; transition:color .2s }
.ft-social a:hover { color:var(--g400) }
.ft-col h5 {
  font-size:10px; text-transform:uppercase; letter-spacing:.14em;
  color:rgba(255,255,255,.3); font-family:"Space Grotesk",sans-serif;
  font-weight:700; margin-bottom:18px;
}
.ft-col ul { list-style:none; display:grid; gap:12px }
.ft-col a { font-size:14px; color:rgba(255,255,255,.55); transition:color .2s }
.ft-col a:hover { color:#fff }
.footer-bottom {
  padding:20px 0; display:flex; align-items:center;
  justify-content:space-between; font-size:12px; flex-wrap:wrap; gap:12px;
}
.footer-bottom a { color:var(--g400) }

/* ════════════════════════════════════════
   MOBILE STICKY CTA
════════════════════════════════════════ */
.mob-cta {
  display:none; position:fixed; bottom:0; left:0; right:0; z-index:400;
  background:rgba(250,246,239,.95); backdrop-filter:blur(20px);
  border-top:1px solid var(--border); padding:10px 14px; gap:10px;
  box-shadow:0 -8px 30px rgba(26,18,9,.1);
}
.mob-cta a {
  flex:1; display:flex; align-items:center; justify-content:center; gap:8px;
  padding:13px; border-radius:14px; font-weight:700; font-size:14px;
  font-family:"Space Grotesk",sans-serif; transition:all .2s;
}
.mob-call { background:var(--warm); color:var(--ink); border:1px solid var(--border) }
.mob-call:hover { background:var(--sand) }
.mob-wa { background:var(--g700); color:#fff; box-shadow:0 4px 14px rgba(42,125,0,.3) }
.mob-wa:hover { background:var(--g900) }

/* ════════════════════════════════════════
   MEAL TIMINGS
════════════════════════════════════════ */
.timings-section {
  background: var(--cream);
  padding: 80px 0;
}
.timings-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 16px;
}
.timing-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 36px 28px;
  text-align: center;
  box-shadow: var(--sh-sm);
  position: relative;
  overflow: hidden;
  transition: all .28s var(--ease-out);
}
.timing-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--g700), var(--g400));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s var(--ease-out);
}
.timing-card:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); border-color: rgba(42,125,0,.2) }
.timing-card:hover::before { transform: scaleX(1) }
.timing-emoji { font-size: 42px; margin-bottom: 16px; display: block }
.timing-name {
  font-family: "Playfair Display", serif;
  font-size: 22px; font-weight: 700;
  color: var(--ink); margin-bottom: 8px;
}
.timing-time {
  font-family: "Space Grotesk", sans-serif;
  font-size: 28px; font-weight: 700;
  color: var(--g700); margin-bottom: 6px;
  letter-spacing: -.01em;
}
.timing-sub { font-size: 13px; color: var(--ink40); margin-bottom: 20px; line-height: 1.6 }
.timing-price {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--g50); border: 1px solid rgba(42,125,0,.2);
  border-radius: 100px; padding: 8px 20px;
  font-family: "Space Grotesk", sans-serif;
  font-size: 15px; font-weight: 700; color: var(--g700);
}
.timing-price-was {
  font-size: 12px; color: var(--ink40); text-decoration: line-through; font-weight: 400;
}
@media(max-width:980px) {
  .timings-grid { grid-template-columns: 1fr; gap: 14px }
}
.reveal {
  opacity:0; transform:translateY(32px);
  transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);
  will-change:opacity,transform;
}
.reveal.in { opacity:1; transform:translateY(0); will-change:auto }
.reveal-l { opacity:0; transform:translateX(-32px); transition:opacity .7s var(--ease-out),transform .7s var(--ease-out) }
.reveal-l.in { opacity:1; transform:translateX(0) }
.reveal-r { opacity:0; transform:translateX(32px); transition:opacity .7s var(--ease-out),transform .7s var(--ease-out) }
.reveal-r.in { opacity:1; transform:translateX(0) }

@keyframes slideUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media(max-width:980px){
  .hero-inner { grid-template-columns:1fr; gap:40px }
  .hero-visual { order:-1 }
  .hc-img img { height:230px }
  .fb-tl,.fb-br { display:none }
  .hc-body { padding:14px 16px 16px }
  .about-grid { grid-template-columns:1fr; gap:48px }
  .about-float-tl,.about-float-br { display:none }
  .plans-grid { grid-template-columns:1fr !important; gap:16px }
  .why-grid { grid-template-columns:1fr 1fr; gap:16px }
  .why-card.full { flex-direction:column; gap:16px; grid-column:1/-1 }
  .reviews-grid { grid-template-columns:1fr; gap:16px }
  .loc-info { grid-template-columns:1fr 1fr }
  .loc-cell:nth-child(2) { border-right:none }
  .loc-cell:nth-child(3) { border-top:1px solid var(--border) }
  .loc-cell:nth-child(4) { border-top:1px solid var(--border); border-right:none }
  .footer-top { grid-template-columns:1fr; gap:36px }
  nav,.nav-call,.nav-plan { display:none }
  .hamburger { display:flex }
  .mob-cta { display:flex }
  .hero { padding:110px 0 70px }
  .hero h1 { font-size:clamp(38px,9vw,54px) }
  .section { padding:72px 0 }
  .s-head { margin-bottom:48px }
  .trial-bar { flex-direction:column; align-items:flex-start }
  .header-pill { padding:0 12px }
  .promise { padding:60px 0 }
  .loc-info { padding-bottom:0 }
}
@media(max-width:640px){
  .section { padding:56px 0 }
  .wrap { padding:0 16px }
  .menu-grid { grid-template-columns:repeat(2,1fr); gap:10px }
  .hero-stats { gap:0 }
  .h-stat { padding:0 16px }
  .h-stat:first-child { padding-left:0 }
  .hero-actions { flex-direction:column; align-items:stretch }
  .hero-actions .btn { width:100%; justify-content:center }
  .menu-tabs { width:100%; border-radius:var(--r) }
  .menu-tab { flex:1; padding:10px 6px; font-size:12px }
  .cta-actions { flex-direction:column; align-items:center }
  .cta-actions .btn { width:100%; max-width:340px }
  .footer-bottom { flex-direction:column; text-align:center }
  .why-grid { grid-template-columns:1fr }
  .loc-info { grid-template-columns:1fr }
  .loc-cell { border-right:none !important; border-top:1px solid var(--border) }
  .loc-cell:first-child { border-top:none }
  .hc-img img { height:200px }
  .s-head { margin-bottom:36px }
  .promise-badges { gap:8px }
  .pbadge { font-size:12px; padding:9px 14px }
  .faq-q { padding:17px 20px; font-size:14px }
  .faq-item.open .faq-a { padding:0 20px 18px }
  .mob-cta a { font-size:13px }
  .hero-badge { gap:6px }
  .h-stat-num { font-size:26px }
}

/* ════════════════════════════════════════
   ADDITIONAL RESPONSIVE FIXES
════════════════════════════════════════ */

/* ── 480px and below (very small phones) ── */
@media(max-width:480px){
  .wrap { padding:0 14px }
  .section { padding:48px 0 }
  .s-head { margin-bottom:30px }
  .s-head h2 { font-size:clamp(26px,8vw,36px) }
  .s-head p { font-size:14px }

  /* Hero */
  .hero { padding:100px 0 60px }
  .hero h1 { font-size:clamp(34px,10vw,46px) }
  .hero-sub { font-size:15px; margin-bottom:28px }
  .hero-actions { gap:10px; margin-bottom:36px }
  .hero-stats { flex-wrap:wrap; justify-content:center }
  .h-stat { padding:10px 14px; min-width:80px }
  .h-stat-num { font-size:22px }
  .h-stat-sep { display:none }

  /* Hero Card */
  .hc-img img { height:180px }
  .hc-body { padding:12px }
  .hc-chips { gap:5px }
  .chip { font-size:10px; padding:5px 10px }

  /* About */
  .about-card-main { padding:28px 20px 24px }
  .about-monogram { width:80px; height:80px; font-size:28px }
  .feat-row { padding:10px 12px; font-size:13px }

  /* Menu */
  .menu-grid { grid-template-columns:repeat(2,1fr); gap:8px }
  .day-card { padding:14px 8px }
  .day-food { font-size:11px }
  .menu-tabs { gap:2px }
  .menu-tab { padding:9px 4px; font-size:11px; letter-spacing:0 }

  /* Plans */
  .plan { padding:28px 20px 22px }
  .plan-amt { font-size:38px }
  .plan-feats li { font-size:13px }

  /* Trial bar */
  .trial-bar { padding:20px 18px }
  .trial-bar-left strong { font-size:15px }

  /* Why */
  .why-card { padding:24px 20px }
  .why-icon-wrap { width:52px; height:52px; font-size:22px }
  .why-card h3 { font-size:15px }
  .why-card p { font-size:13px }

  /* Promise */
  .promise { padding:48px 0 }
  .promise h2 { font-size:clamp(22px,7vw,34px) }
  .promise p { font-size:14px }
  .pbadge { font-size:11px; padding:8px 12px; gap:5px }

  /* Reviews */
  .review-card { padding:22px 18px }
  .rv-text { font-size:13px }

  /* FAQ */
  .faq-q { padding:15px 16px; font-size:13px; gap:12px }
  .faq-item.open .faq-a { padding:0 16px 16px }
  .faq-a { font-size:13px; padding:0 16px }
  .faq-icon-btn { width:24px; height:24px; font-size:16px }

  /* Location */
  .loc-map { height:220px }
  .loc-cell { padding:20px 16px }
  .loc-val { font-size:12px }

  /* CTA Final */
  .cta-final { padding:72px 16px }
  .cta-final h2 { font-size:clamp(26px,8vw,40px) }
  .cta-final p { font-size:15px; margin-bottom:32px }
  .cta-actions .btn { font-size:14px; padding:14px 20px }

  /* Footer */
  footer { padding:44px 0 0 }
  .footer-top { gap:28px; padding-bottom:32px }
  .ft-brand p { font-size:12px }
  .ft-col h5 { font-size:9px }
  .ft-col a { font-size:13px }

  /* Mobile sticky CTA */
  .mob-cta { padding:8px 10px; gap:8px }
  .mob-cta a { font-size:12px; padding:11px 8px; border-radius:12px }

  /* Timing cards */
  .timing-card { padding:28px 20px }
  .timing-emoji { font-size:36px }
  .timing-name { font-size:20px }
  .timing-time { font-size:24px }

  /* Eyebrow pills */
  .eyebrow { font-size:10px; padding:4px 11px }

  /* Header */
  .header-pill { padding:0 10px }
  .logo-name { font-size:14px }
  .logo-tagline { font-size:8px }
  .logo-mark { width:38px; height:38px; }
}

/* ── Tablet portrait (641px–980px) better grid handling ── */
@media(min-width:641px) and (max-width:980px){
  .hero-inner { grid-template-columns:1fr; max-width:600px; margin:0 auto }
  .hero-visual { width:100%; max-width:520px; margin:0 auto }
  .about-grid { max-width:600px; margin:0 auto }
  .plans-grid { grid-template-columns:1fr 1fr !important; gap:16px }
  .plans-grid .plan.featured { grid-column:1/-1; max-width:460px; margin:0 auto; width:100% }
  .reviews-grid { grid-template-columns:1fr 1fr; gap:16px }
  .why-grid { grid-template-columns:1fr 1fr }
  .timings-grid { grid-template-columns:1fr 1fr 1fr }
  .menu-grid { grid-template-columns:repeat(4,1fr); gap:10px }
}

/* ── Fix menu grid on mid screens ── */
@media(min-width:481px) and (max-width:640px){
  .menu-grid { grid-template-columns:repeat(3,1fr); gap:9px }
  .timings-grid { grid-template-columns:1fr }
}

/* ── Plans grid: always single column on 980px and below ── */
@media(max-width:640px){
  .plans-grid { grid-template-columns:1fr !important }
}

/* ── Touch-friendly: larger tap targets on mobile ── */
@media(hover:none) and (pointer:coarse){
  nav a { padding:10px 16px }
  .menu-tab { padding:12px 16px }
  .faq-q { padding:18px 24px }
  .btn { padding:15px 28px }
  .btn-lg { padding:18px 36px !important }
  .feat-row { padding:14px 16px }
  .day-card { padding:18px 12px }
}

/* ── Prevent overflow on all screen sizes ── */
img, svg, video, canvas, audio, iframe, embed, object { max-width:100%; }
img, video { height:auto }
iframe:not(.loc-map) { height:auto }
.ticker-item { word-break:normal; white-space:nowrap }
.loc-map { width:100%; height:300px; border:none; display:block; max-height:none }
.ticker-inner { max-width:none }
.header-inner { overflow:visible }

/* ── Improved mobile nav ── */
@media(max-width:980px){
  .mnav { padding-top:80px; padding-bottom:120px; overflow-y:auto }
  .mnav a { font-size:clamp(22px,6vw,32px) }
  .mnav-btns { gap:12px }
  .mnav-btns .btn { width:100%; justify-content:center }
}

/* ── Safe area for notch phones ── */
@supports(padding: max(0px)){
  .mob-cta {
    padding-bottom: max(10px, env(safe-area-inset-bottom));
    padding-left: max(14px, env(safe-area-inset-left));
    padding-right: max(14px, env(safe-area-inset-right));
  }
  #header { padding-top: env(safe-area-inset-top) }
}

/* ── Landscape phone ── */
@media(max-width:812px) and (orientation:landscape){
  .hero { min-height:auto; padding:90px 0 50px }
  .hero h1 { font-size:clamp(30px,5vw,50px) }
  .hero-inner { gap:32px }
  .section { padding:56px 0 }
  .mob-cta { display:none }
}

/* ── Large screens: keep content readable ── */
@media(min-width:1400px){
  .wrap { max-width:1280px }
  .hero-inner { gap:100px }
}

/* ══ BOOK TRIAL NAVBAR BUTTON ══ */
.btn-trial-nav {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  font-size: 13px;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 100%);
  color: #fff;
  border-radius: 100px;
  text-decoration: none;
  border: none;
  cursor: pointer;
  letter-spacing: .01em;
  transition: all .2s;
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(247,120,30,.35);
  position: relative;
  overflow: hidden;
}
.btn-trial-nav::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.15);
  opacity: 0;
  transition: opacity .2s;
}
.btn-trial-nav:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(247,120,30,.5);
}
.btn-trial-nav:hover::before { opacity: 1; }

/* pulse dot on button */
.btn-trial-nav::after {
  content: '';
  position: absolute;
  top: 6px;
  right: 6px;
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: 50%;
  animation: trialPulse 1.8s ease-in-out infinite;
}
@keyframes trialPulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50% { opacity: .4; transform: scale(1.5); }
}

/* Hide on small screens — mobile nav already has it */
@media(max-width: 768px) {
  .btn-trial-nav { display: none; }
}

/* ══ REVIEWS MARQUEE ANIMATION ══ */
.reviews-marquee-outer {
  width: 100%;
  overflow: hidden;
  position: relative;
  padding: 8px 0 20px;
  /* fade edges */
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}
.reviews-marquee-outer:hover .reviews-marquee-track {
  animation-play-state: paused;
}
.reviews-marquee-track {
  display: flex;
  gap: 20px;
  width: max-content;
  animation: reviewsScroll 32s linear infinite;
}
@keyframes reviewsScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Cards inside marquee */
.reviews-marquee-track .review-card {
  width: 320px;
  min-width: 320px;
  flex-shrink: 0;
  cursor: default;
}
.reviews-marquee-track .review-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-lg);
  border-color: rgba(42,125,0,.2);
}

@media(max-width: 600px) {
  .reviews-marquee-track .review-card {
    width: 280px;
    min-width: 280px;
  }
}

/* Inside mobile nav, always show trial button */
.mnav .btn-trial-nav {
  display: flex !important;
}

/* ══ FOUNDER CARD ══ */
.founder-card {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-top: 32px;
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 20px;
  box-shadow: var(--sh-sm);
  backdrop-filter: blur(8px);
}
.founder-img-wrap {
  flex-shrink: 0;
  width: 160px;
  height: 200px;
  border-radius: 16px;
  overflow: hidden;
  border: 3px solid var(--g600);
  box-shadow: 0 4px 16px rgba(42,125,0,.2);
}
.founder-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%;
}
.founder-info { flex: 1; }
.founder-name {
  font-family: 'Playfair Display', serif;
  font-size: 17px;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.2;
}
.founder-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--g700);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: 3px 0 10px;
}
.founder-quote {
  font-size: 13px;
  color: var(--ink60);
  line-height: 1.6;
  margin: 0;
  font-style: italic;
  position: relative;
  padding-left: 14px;
  border-left: 3px solid var(--g400);
}

@media(max-width: 480px) {
  .founder-card {
    flex-direction: column;
    text-align: center;
    gap: 14px;
  }
  .founder-quote {
    text-align: left;
  }
}
