/* ============================================================
   PIZZA HUT — Redesign concept
   Three visual directions share one structure; only tokens change.
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img { display: block; max-width: 100%; }
button { font: inherit; color: inherit; cursor: pointer; border: none; background: none; }
a { color: inherit; text-decoration: none; }
:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }

/* ---------- Base tokens (overridable by Tweaks) ---------- */
.app {
  --radius: 18px;
  --radius-sm: calc(var(--radius) * 0.5);
  --radius-pill: 999px;
  --density: 1;            /* 1 = comfy, 0.8 = compact */
  --maxw: 1180px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.05), 0 2px 8px rgba(0,0,0,.04);
  --shadow-md: 0 4px 14px rgba(0,0,0,.08), 0 12px 40px rgba(0,0,0,.06);
  --shadow-lg: 0 10px 30px rgba(0,0,0,.12), 0 30px 80px rgba(0,0,0,.10);
  background: var(--bg);
  color: var(--ink);
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  transition: background .4s ease, color .4s ease;
}

/* ============================================================
   THEME A — FRESCO  (light, airy, modern)
   ============================================================ */
.app[data-theme="fresco"] {
  --bg: #FFFFFF;
  --surface: #FFFFFF;
  --card: #FFFFFF;
  --tile: #F5F4F2;
  --ink: #1A1715;
  --ink-2: #6B655F;
  --ink-3: #A8A29B;
  --line: #ECEAE6;
  --line-2: #E0DDD8;
  --primary: #C8102E;
  --primary-press: #A20C25;
  --primary-soft: #F8E3E7;
  --primary-ink: #FFFFFF;
  --cta: #C8102E;
  --cta-ink: #FFFFFF;
  --ok: #1F9D57;
  --display: "Bricolage Grotesque", system-ui, sans-serif;
  --body: "Hanken Grotesk", system-ui, sans-serif;
  --display-wght: 700;
  --display-tracking: -0.02em;
  --display-transform: none;
  --hero-bg: #FFFFFF;
  --header-bg: rgba(255,255,255,.86);
  --radius: 18px;
}

/* ============================================================
   THEME B — FORNO  (premium, dark, photo-forward)
   ============================================================ */
.app[data-theme="forno"] {
  --bg: #15100D;
  --surface: #1E1813;
  --card: #211A15;
  --tile: #2A211A;
  --ink: #F5EDE2;
  --ink-2: #B3A595;
  --ink-3: #7E7163;
  --line: #2F261E;
  --line-2: #3B3026;
  --primary: #C8102E;
  --primary-press: #A20C25;
  --primary-soft: #2E1417;
  --primary-ink: #FFFFFF;
  --cta: #C8102E;
  --cta-ink: #FFFFFF;
  --ok: #4BBE7E;
  --gold: #E5B567;
  --display: "Instrument Serif", Georgia, serif;
  --body: "Hanken Grotesk", system-ui, sans-serif;
  --display-wght: 400;
  --display-tracking: -0.01em;
  --display-transform: none;
  --hero-bg: radial-gradient(120% 140% at 80% 0%, #3A241C 0%, #15100D 60%);
  --header-bg: rgba(21,16,13,.78);
  --radius: 14px;
  --shadow-md: 0 4px 14px rgba(0,0,0,.4), 0 12px 40px rgba(0,0,0,.35);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.55);
}

/* ============================================================
   THEME C — PUNCH  (bold, loud, big type)
   ============================================================ */
.app[data-theme="punch"] {
  --bg: #F6ECE1;
  --surface: #FFFFFF;
  --card: #FFFFFF;
  --tile: #FBDFD3;
  --ink: #191210;
  --ink-2: #6E5F57;
  --ink-3: #A99B90;
  --line: #E7D7C8;
  --line-2: #DCC8B6;
  --primary: #C8102E;
  --primary-press: #A20C25;
  --primary-soft: #F8E3E7;
  --primary-ink: #FFFFFF;
  --cta: #C8102E;
  --cta-ink: #FFFFFF;
  --ok: #1F9D57;
  --display: "Anton", system-ui, sans-serif;
  --body: "Hanken Grotesk", system-ui, sans-serif;
  --display-wght: 400;
  --display-tracking: 0.005em;
  --display-transform: uppercase;
  --hero-bg: linear-gradient(160deg, #C8102E 0%, #9C0C24 100%);
  --header-bg: rgba(246,236,225,.85);
  --radius: 8px;
}

/* ---------- Typography ---------- */
.display {
  font-family: var(--display);
  font-weight: var(--display-wght);
  letter-spacing: var(--display-tracking);
  text-transform: var(--display-transform);
  line-height: 1.02;
  margin: 0;
}
.eyebrow {
  font-family: var(--body);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--primary);
  margin: 0;
}
.muted { color: var(--ink-2); }

/* ---------- Layout ---------- */
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.screen { padding-bottom: 80px; min-height: 60vh; }
.section { margin-top: calc(56px * var(--density)); }
.section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 16px; margin-bottom: 22px;
}
.section-head h2 { font-size: clamp(26px, 3.4vw, 40px); }
.link-more {
  font-weight: 700; font-size: 13px; letter-spacing: .04em; text-transform: uppercase;
  color: var(--primary); display: inline-flex; align-items: center; gap: 6px;
}

/* ============================================================
   HEADER
   ============================================================ */
.ph-header {
  position: sticky; top: 0; z-index: 40;
  background: var(--header-bg);
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  border-bottom: 1px solid var(--line);
}
.ph-header-row {
  display: flex; align-items: center; gap: 18px;
  height: 68px;
}
.logo {
  font-family: var(--display);
  font-weight: var(--display-wght);
  text-transform: var(--display-transform);
  letter-spacing: -0.01em;
  font-size: 24px; color: var(--primary);
  display: inline-flex; align-items: center; gap: 9px;
  white-space: nowrap; flex: none;
}
.logo .logo-mark {
  width: 30px; height: 30px; flex: none;
}
.app[data-theme="punch"] .logo { font-size: 26px; letter-spacing: .01em; }
.app[data-theme="forno"] .logo { font-size: 25px; }

.mode-chip {
  display: inline-flex; align-items: center; gap: 8px; flex: none;
  background: var(--tile); color: var(--ink);
  border-radius: var(--radius-pill); padding: 9px 15px;
  font-weight: 600; font-size: 13px; border: 1px solid transparent;
  white-space: nowrap;
}
.mode-chip:hover { border-color: var(--line-2); }
.mode-chip .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--ok); }

.header-spacer { flex: 1; }

.header-actions { display: flex; align-items: center; gap: 6px; }
.h-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 13px; border-radius: var(--radius-pill);
  font-weight: 600; font-size: 13.5px; color: var(--ink); white-space: nowrap;
}
.h-btn:hover { background: var(--tile); }
.h-btn.icon { padding: 9px; }
.h-btn.signup {
  border: 1.5px solid var(--ink); font-weight: 700;
}
.app[data-theme="forno"] .h-btn.signup { border-color: var(--line-2); }
.h-btn.signup:hover { background: var(--ink); color: var(--bg); }
.cart-btn { position: relative; }
.cart-count {
  position: absolute; top: -3px; right: -3px;
  background: var(--primary); color: #fff; font-size: 10px; font-weight: 800;
  min-width: 17px; height: 17px; border-radius: 9px;
  display: grid; place-items: center; padding: 0 4px;
}

/* category nav */
.cat-nav { border-bottom: 1px solid var(--line); background: var(--surface); position: sticky; top: 67px; z-index: 39; }
.app[data-theme="forno"] .cat-nav { background: var(--bg); }
.cat-row {
  display: flex; gap: 8px; padding: 12px 0; overflow-x: auto;
  justify-content: center;
  scrollbar-width: none;
}
.cat-row::-webkit-scrollbar { display: none; }
.cat {
  display: inline-flex; align-items: center; gap: 9px; flex: none;
  padding: 9px 16px 9px 9px; border-radius: var(--radius-pill);
  background: var(--card); border: 1px solid var(--line);
  font-weight: 600; font-size: 14px; color: var(--ink);
  transition: all .15s ease;
}
.cat:hover { border-color: var(--primary); transform: translateY(-1px); }
.cat.active { background: var(--primary); color: var(--primary-ink); border-color: var(--primary); }
.cat .cat-ico {
  width: 30px; height: 30px; border-radius: 50%; flex: none;
  display: grid; place-items: center; background: var(--primary-soft); color: var(--primary);
}
.cat.active .cat-ico { background: rgba(255,255,255,.22); color: #fff; }

/* ============================================================
   COLLAPSING NAV (Concepto C)
   La cabecera de dos filas se contrae a una sola barra de chips
   compactos al hacer scroll.
   ============================================================ */
.ph-nav {
  position: sticky; top: 0; z-index: 40;
  background: var(--header-bg);
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  border-bottom: 1px solid transparent;
  transition: border-color .24s ease;
}
/* only the floating collapsed bar keeps a separator over the page */
.ph-nav.collapsed { border-bottom-color: var(--line); }

/* full (top of page) — content slides up & fades as the bar shrinks */
.nav-full {
  max-height: 150px; overflow: hidden;
  transition: max-height .44s cubic-bezier(.4,0,.2,1);
}
.nav-full-inner {
  transition: transform .44s cubic-bezier(.4,0,.2,1), opacity .26s ease;
}
.ph-nav.collapsed .nav-full { max-height: 0; }
.ph-nav.collapsed .nav-full-inner { transform: translateY(-22px); opacity: 0; pointer-events: none; }
.cat-shelf { border-top: 1px solid var(--line); background: var(--surface); }
.app[data-theme="forno"] .cat-shelf { background: var(--bg); }

/* mini (after scroll) — chips slide up into place, just after the full row leaves */
.nav-mini {
  height: 0; overflow: hidden;
  transition: height .44s cubic-bezier(.4,0,.2,1);
}
.ph-nav.collapsed .nav-mini { height: 58px; }
.nav-mini-row {
  display: flex; align-items: center; gap: 14px; height: 58px;
  transform: translateY(20px); opacity: 0;
  transition: transform .44s cubic-bezier(.4,0,.2,1) .08s, opacity .3s ease .08s;
}
.ph-nav.collapsed .nav-mini-row { transform: translateY(0); opacity: 1; }
.nav-mini-row .mini-logo { flex: none; }
.mini-chips {
  display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0;
  overflow-x: auto; scrollbar-width: none;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 18px, #000 calc(100% - 18px), transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 18px, #000 calc(100% - 18px), transparent 100%);
}
.mini-chips::-webkit-scrollbar { display: none; }
.mini-chip {
  display: inline-flex; align-items: center; gap: 8px; flex: none;
  padding: 7px 15px 7px 7px; border-radius: var(--radius-pill);
  background: var(--tile); border: 1px solid transparent;
  font-weight: 600; font-size: 13.5px; color: var(--ink); white-space: nowrap;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.mini-chip:hover { border-color: var(--line-2); }
.mini-chip .mc-ico {
  width: 26px; height: 26px; border-radius: 50%; flex: none;
  display: grid; place-items: center; background: var(--primary-soft); color: var(--primary);
}
.mini-chip.active { background: var(--primary); color: var(--primary-ink); border-color: var(--primary); }
.mini-chip.active .mc-ico { background: rgba(255,255,255,.22); color: #fff; }
.nav-mini-row .mini-act { flex: none; }

@media (prefers-reduced-motion: reduce) {
  .nav-full, .nav-mini, .nav-full-inner, .nav-mini-row { transition: none; }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--body); font-weight: 700; font-size: 15px;
  padding: 14px 22px; border-radius: var(--radius-sm); white-space: nowrap;
  transition: transform .12s ease, background .15s ease, box-shadow .15s ease;
  text-align: center; line-height: 1;
}
.btn:active { transform: scale(.98); }
.btn-primary { background: var(--primary); color: var(--primary-ink); }
.btn-primary:hover { background: var(--primary-press); box-shadow: var(--shadow-md); }
.btn-cta { background: var(--cta); color: var(--cta-ink); }
.btn-cta:hover { filter: brightness(1.06); box-shadow: var(--shadow-md); }
.btn-ghost { background: var(--tile); color: var(--ink); }
.btn-ghost:hover { background: var(--line); }
.btn-outline { border: 1.5px solid var(--line-2); color: var(--ink); background: var(--card); }
.btn-outline:hover { border-color: var(--primary); color: var(--primary); }
.btn-block { width: 100%; }
.btn-lg { padding: 17px 26px; font-size: 16px; }
.app[data-theme="punch"] .btn { text-transform: uppercase; letter-spacing: .03em; }

.iconbtn {
  width: 38px; height: 38px; border-radius: 50%;
  display: grid; place-items: center; background: var(--tile); color: var(--ink);
  transition: all .15s ease;
}
.iconbtn:hover { background: var(--primary); color: #fff; }

/* ============================================================
   HERO + ORDER MODULE
   ============================================================ */
.hero { background: var(--hero-bg); position: relative; overflow: hidden; }
.hero-inner {
  display: grid; grid-template-columns: 1.05fr .95fr; gap: 40px;
  align-items: center; padding: 56px 0 64px;
}
.hero-copy { max-width: 520px; }
.hero h1 {
  font-size: clamp(40px, 6.4vw, 76px);
  margin: 16px 0 18px;
}
.app[data-theme="punch"] .hero h1 { color: #fff; }
.app[data-theme="punch"] .hero .btn-primary { background: #fff; color: var(--primary); }
.app[data-theme="punch"] .hero .btn-primary:hover { background: #fff; filter: brightness(.97); }
.app[data-theme="punch"] .hero .btn-outline { background: transparent; border-color: rgba(255,255,255,.65); color: #fff; }
.app[data-theme="punch"] .hero .btn-outline:hover { border-color: #fff; color: #fff; }
.app[data-theme="punch"] .hero .eyebrow { color: #ffd9d3; }
.app[data-theme="punch"] .hero p { color: rgba(255,255,255,.9); }
.hero p { font-size: 18px; color: var(--ink-2); margin: 0 0 28px; max-width: 440px; }
.hero-cta-row { display: flex; gap: 12px; flex-wrap: wrap; }

.hero-art { position: relative; min-height: 340px; display: grid; place-items: center; }

/* order card */
.order-card {
  background: var(--card); border-radius: var(--radius);
  box-shadow: var(--shadow-lg); border: 1px solid var(--line);
  padding: 10px; width: 100%; max-width: 420px;
}
.order-tabs { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; background: var(--tile); padding: 4px; border-radius: calc(var(--radius) - 6px); }
.order-tab {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  padding: 13px; border-radius: calc(var(--radius) - 10px);
  font-weight: 700; font-size: 14px; color: var(--ink-2);
  transition: all .15s ease; white-space: nowrap;
}
.order-tab.active { background: var(--card); color: var(--ink); box-shadow: var(--shadow-sm); }
.order-row {
  display: flex; align-items: center; gap: 13px;
  padding: 15px 14px; border-radius: var(--radius-sm);
  border: 1px solid var(--line); margin-top: 10px;
  transition: border-color .15s ease;
}
.order-row:hover { border-color: var(--line-2); }
.order-row .or-ico { width: 36px; height: 36px; border-radius: 10px; background: var(--tile); display: grid; place-items: center; color: var(--primary); flex: none; }
.order-row .or-main { flex: 1; min-width: 0; }
.order-row .or-label { font-size: 12px; color: var(--ink-3); font-weight: 600; }
.order-row .or-value { font-weight: 700; font-size: 15px; }
.order-row .chev { color: var(--ink-3); }
.order-card .btn { margin-top: 10px; }

/* ============================================================
   PRODUCT CARDS
   ============================================================ */
.grid { display: grid; gap: 22px; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }

.pcard {
  background: var(--card); border-radius: var(--radius);
  border: 1px solid var(--line); overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position: relative;
}
.pcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--line-2); }
.pcard-media {
  position: relative; aspect-ratio: 4 / 3; background: var(--tile);
  display: grid; place-items: center; overflow: hidden;
}
.pcard-body { padding: 16px 17px 18px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.pcard-title { font-family: var(--display); font-weight: var(--display-wght); text-transform: var(--display-transform); letter-spacing: var(--display-tracking); font-size: 20px; }
.app[data-theme="fresco"] .pcard-title { font-weight: 600; }
.pcard-sub { font-size: 13px; color: var(--ink-2); line-height: 1.45; }
.pcard-foot { margin-top: auto; padding-top: 12px; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.price { font-weight: 800; font-size: 18px; font-family: var(--body); white-space: nowrap; }
.price .from { font-size: 11px; font-weight: 600; color: var(--ink-3); display: block; text-transform: uppercase; letter-spacing: .08em; }
.price-strike { text-decoration: line-through; color: var(--ink-3); font-weight: 600; font-size: 14px; margin-right: 6px; }

.tag {
  position: absolute; top: 12px; left: 12px; z-index: 2; white-space: nowrap;
  background: var(--primary); color: #fff; font-weight: 800;
  font-size: 11px; letter-spacing: .06em; text-transform: uppercase;
  padding: 6px 11px; border-radius: var(--radius-pill);
}
.tag.dark { background: var(--ink); color: var(--bg); }
.tag.gold { background: var(--gold, #E5B567); color: #2a1c08; }

.add-btn {
  width: 42px; height: 42px; border-radius: 12px; flex: none;
  background: var(--cta); color: var(--cta-ink);
  display: grid; place-items: center;
  transition: transform .12s ease, background .15s ease;
}
.add-btn:hover { filter: brightness(1.07); transform: translateY(-1px); }
.add-btn:active { transform: scale(.94); }

/* bestseller compact row card */
.bs-card {
  display: flex; align-items: center; gap: 14px;
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 12px; transition: all .18s ease;
}
.bs-card:hover { border-color: var(--line-2); box-shadow: var(--shadow-sm); transform: translateY(-2px); }
.bs-media { width: 76px; height: 76px; border-radius: var(--radius-sm); background: var(--tile); flex: none; display: grid; place-items: center; overflow: hidden; }
.bs-main { flex: 1; min-width: 0; }
.bs-title { font-weight: 700; font-size: 15px; }
.bs-sub { font-size: 12px; color: var(--ink-2); }
.bs-price { font-weight: 800; margin-top: 4px; }

/* offers (wide) */
.offer-card {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 0;
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius); overflow: hidden; transition: all .18s ease;
}
.offer-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.offer-art { background: var(--primary); color: #fff; padding: 26px; display: flex; flex-direction: column; justify-content: center; position: relative; min-height: 190px; }
.offer-art .o-kicker { font-weight: 800; text-transform: uppercase; letter-spacing: .1em; font-size: 12px; opacity: .85; }
.offer-art .o-big { font-family: var(--display); font-weight: var(--display-wght); text-transform: var(--display-transform); font-size: clamp(30px,4vw,46px); line-height: .95; margin: 8px 0; }
.offer-info { padding: 22px; display: flex; flex-direction: column; gap: 8px; justify-content: center; }
.offer-info h3 { font-size: 19px; margin: 0; font-weight: 700; }
.offer-info p { font-size: 13.5px; color: var(--ink-2); margin: 0; }
.offer-info .offer-foot { margin-top: 10px; display: flex; align-items: center; justify-content: space-between; }

/* promo strip */
.promo {
  border-radius: var(--radius); overflow: hidden; position: relative;
  background: var(--hero-bg); border: 1px solid var(--line);
  padding: 34px 36px; display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.app[data-theme="punch"] .promo { background: var(--primary); border-color: transparent; }
.promo .promo-big { font-family: var(--display); font-weight: var(--display-wght); text-transform: var(--display-transform); font-size: clamp(28px,4.4vw,52px); line-height: .96; }
.app[data-theme="punch"] .promo, .app[data-theme="punch"] .promo .promo-big { color: #fff; }
.promo p { margin: 8px 0 0; color: var(--ink-2); max-width: 420px; }
.app[data-theme="punch"] .promo p { color: rgba(255,255,255,.92); }

/* ============================================================
   FILTER PILLS
   ============================================================ */
.filters { display: flex; gap: 9px; flex-wrap: wrap; margin-bottom: 26px; }
.fpill {
  padding: 9px 16px; border-radius: var(--radius-pill); white-space: nowrap;
  border: 1px solid var(--line); background: var(--card);
  font-weight: 600; font-size: 13.5px; color: var(--ink-2); transition: all .15s ease;
}
.fpill:hover { border-color: var(--line-2); color: var(--ink); }
.fpill.active { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.app[data-theme="punch"] .fpill.active { background: var(--primary); border-color: var(--primary); }

/* ============================================================
   PRODUCT DETAIL (PDP)
   ============================================================ */
.pdp { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; padding-top: 28px; }
.pdp-media {
  position: sticky; top: 92px; align-self: start;
  border-radius: var(--radius); overflow: hidden;
  background: var(--tile); aspect-ratio: 1; display: grid; place-items: center;
  border: 1px solid var(--line);
}
.back-link { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 14px; color: var(--ink-2); margin-bottom: 18px; }
.back-link:hover { color: var(--primary); }
.pdp-info h1 { font-size: clamp(34px, 4.6vw, 52px); margin: 0 0 8px; }
.pdp-info .pdp-meta { color: var(--ink-2); font-weight: 600; font-size: 14px; }
.pdp-desc { font-size: 16px; color: var(--ink-2); line-height: 1.55; margin: 18px 0 0; }
.pdp-price-row { display: flex; align-items: center; gap: 18px; margin: 22px 0; }
.pdp-price { font-size: 30px; font-weight: 800; }

.opt-block { margin-top: 28px; }
.opt-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.opt-head h3 { font-size: 17px; margin: 0; font-weight: 700; letter-spacing: .01em; white-space: nowrap; }
.opt-head .helper { font-size: 12.5px; color: var(--ink-3); white-space: nowrap; flex: none; }

.size-row { display: flex; gap: 10px; flex-wrap: wrap; }
.size-opt {
  flex: 1; min-width: 96px; border: 1.5px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px 12px; text-align: center; background: var(--card); transition: all .15s ease;
}
.size-opt:hover { border-color: var(--line-2); }
.size-opt .so-disc { width: 38px; height: 38px; margin: 0 auto 8px; border-radius: 50%; background: var(--primary-soft); display: grid; place-items: center; color: var(--primary); }
.size-opt .so-name { font-weight: 700; font-size: 14px; }
.size-opt .so-price { font-size: 12px; color: var(--ink-2); margin-top: 2px; }
.size-opt.active { border-color: var(--primary); background: var(--primary-soft); }
.app[data-theme="forno"] .size-opt.active { background: var(--primary-soft); }

.dough-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.dough-opt {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  border: 1.5px solid var(--line); border-radius: var(--radius-sm); padding: 14px 16px;
  background: var(--card); transition: all .15s ease; text-align: left;
}
.dough-opt:hover { border-color: var(--line-2); }
.dough-opt.active { border-color: var(--primary); background: var(--primary-soft); }
.dough-opt .do-name { font-weight: 700; font-size: 14.5px; white-space: nowrap; }
.dough-opt .do-tag { font-size: 11px; color: var(--ink-3); font-weight: 600; }
.dough-opt .do-price { font-size: 13px; color: var(--ink-2); font-weight: 700; }

/* ingredient selector */
.ing-wrap { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: 10px; }
.ing {
  border: 1.5px solid var(--line); border-radius: var(--radius-sm); padding: 12px 8px 10px;
  background: var(--card); text-align: center; transition: all .15s ease; position: relative;
}
.ing:hover { border-color: var(--line-2); transform: translateY(-2px); }
.ing.active { border-color: var(--primary); background: var(--primary-soft); }
.ing .ing-disc { width: 46px; height: 46px; margin: 0 auto 8px; border-radius: 14px; display: grid; place-items: center; background: var(--tile, #F5F4F2); transition: background .15s ease; }
.ing.active .ing-disc { background: #fff; }
.ing .ing-disc .ing-ico { display: block; }
.ing .ing-name { font-size: 12.5px; font-weight: 600; }
.ing .ing-check {
  position: absolute; top: 7px; right: 7px; width: 20px; height: 20px; border-radius: 50%;
  background: var(--primary); color: #fff; display: none; place-items: center;
}
.ing.active .ing-check { display: grid; }

.ing-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin: 14px 0 4px; font-size: 13px; color: var(--ink-2);
}
.ing-bar > span { white-space: nowrap; flex: none; }
.ing-progress { flex: 1; height: 6px; border-radius: 3px; background: var(--line); overflow: hidden; }
.ing-progress span { display: block; height: 100%; background: var(--primary); border-radius: 3px; transition: width .3s ease; }

/* sticky add bar */
.add-bar {
  position: sticky; bottom: 0; margin-top: 30px;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow-md); padding: 14px; display: flex; align-items: center; gap: 14px;
}

/* qty stepper */
.stepper { display: inline-flex; align-items: center; gap: 2px; background: var(--tile); border-radius: var(--radius-pill); padding: 4px; }
.stepper button { width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; font-size: 18px; font-weight: 700; color: var(--ink); transition: background .15s ease; }
.stepper button:hover { background: var(--card); }
.stepper .qv { min-width: 30px; text-align: center; font-weight: 800; }

/* ============================================================
   CART
   ============================================================ */
.cart-grid { display: grid; grid-template-columns: 1fr 360px; gap: 32px; align-items: start; padding-top: 20px; }
.cart-line {
  display: flex; gap: 16px; align-items: center;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 14px; margin-bottom: 14px; transition: box-shadow .15s ease;
}
.cart-line:hover { box-shadow: var(--shadow-sm); }
.cart-line .cl-media { width: 84px; height: 84px; border-radius: var(--radius-sm); background: var(--tile); flex: none; display: grid; place-items: center; overflow: hidden; }
.cart-line .cl-main { flex: 1; min-width: 0; }
.cart-line .cl-title { font-weight: 700; font-size: 16px; }
.cart-line .cl-sub { font-size: 12.5px; color: var(--ink-2); margin-top: 2px; }
.cart-line .cl-edit { font-size: 12px; font-weight: 700; color: var(--primary); margin-top: 8px; display: inline-flex; gap: 5px; align-items: center; }
.cart-line .cl-right { display: flex; flex-direction: column; align-items: flex-end; gap: 12px; white-space: nowrap; }
.cart-remove { color: var(--ink-3); font-size: 12px; font-weight: 600; }
.cart-remove:hover { color: var(--primary); }

.summary {
  position: sticky; top: 92px;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px; box-shadow: var(--shadow-sm);
}
.summary h3 { margin: 0 0 16px; font-size: 18px; }
.sum-row { display: flex; justify-content: space-between; font-size: 14.5px; padding: 7px 0; color: var(--ink-2); white-space: nowrap; gap: 16px; }
.sum-row.total { color: var(--ink); font-weight: 800; font-size: 20px; border-top: 1px solid var(--line); margin-top: 8px; padding-top: 16px; }
.pickup-pill { display: flex; align-items: center; gap: 12px; background: var(--tile); border-radius: var(--radius-sm); padding: 13px 14px; margin-bottom: 18px; }
.pickup-pill .pp-ico { width: 34px; height: 34px; border-radius: 9px; background: var(--card); display: grid; place-items: center; color: var(--primary); flex: none; }

/* upsell */
.upsell {
  background: var(--tile); border-radius: var(--radius); padding: 16px;
  display: flex; align-items: center; gap: 16px; margin: 18px 0 28px;
}
.upsell .up-media { width: 64px; height: 64px; border-radius: 12px; background: var(--card); display: grid; place-items: center; flex: none; overflow: hidden; }
.upsell .up-main { flex: 1; }
.upsell .up-q { font-size: 13px; color: var(--ink-2); }
.upsell .up-title { font-weight: 700; }

.empty-cart { background: var(--card); border: 1px dashed var(--line-2); border-radius: var(--radius); padding: 56px 24px; text-align: center; }
.empty-cart .ec-disc { width: 76px; height: 76px; border-radius: 50%; background: var(--primary-soft); display: grid; place-items: center; color: var(--primary); margin: 0 auto 18px; }

/* ============================================================
   CHECKOUT
   ============================================================ */
.checkout-grid { display: grid; grid-template-columns: 1fr 380px; gap: 32px; align-items: start; padding-top: 20px; }
.co-card { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; margin-bottom: 18px; }
.co-card h3 { margin: 0 0 4px; font-size: 18px; display: flex; align-items: center; gap: 10px; white-space: nowrap; }
.co-step-no { width: 26px; height: 26px; border-radius: 50%; background: var(--primary); color: #fff; display: grid; place-items: center; font-size: 13px; font-weight: 800; flex: none; }
.co-card .co-hint { color: var(--ink-2); font-size: 13px; margin: 0 0 18px 36px; }
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 12.5px; font-weight: 700; color: var(--ink-2); margin-bottom: 7px; letter-spacing: .02em; }
.field input, .field select, .field textarea {
  width: 100%; padding: 13px 15px; border-radius: var(--radius-sm);
  border: 1.5px solid var(--line); background: var(--surface); color: var(--ink);
  font: inherit; transition: border-color .15s ease;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--primary); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.field-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }

.pay-opt {
  display: flex; align-items: center; gap: 14px; padding: 15px 16px;
  border: 1.5px solid var(--line); border-radius: var(--radius-sm); margin-bottom: 10px;
  transition: all .15s ease; cursor: pointer;
}
.pay-opt:hover { border-color: var(--line-2); }
.pay-opt.active { border-color: var(--primary); background: var(--primary-soft); }
.pay-radio { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--line-2); flex: none; display: grid; place-items: center; }
.pay-opt.active .pay-radio { border-color: var(--primary); }
.pay-opt.active .pay-radio::after { content: ""; width: 10px; height: 10px; border-radius: 50%; background: var(--primary); }
.pay-opt .pay-ico { width: 38px; height: 38px; border-radius: 9px; background: var(--tile); display: grid; place-items: center; color: var(--ink); flex: none; }
.pay-opt .pay-name { font-weight: 700; font-size: 14.5px; }
.pay-opt .pay-sub { font-size: 12px; color: var(--ink-2); }

.co-line { display: flex; gap: 12px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--line); }
.co-line:last-of-type { border-bottom: none; }
.co-line .col-media { width: 50px; height: 50px; border-radius: 10px; background: var(--tile); flex: none; display: grid; place-items: center; overflow: hidden; }
.co-line .col-main { flex: 1; }
.co-line .col-title { font-weight: 700; font-size: 14px; }
.co-line .col-sub { font-size: 11.5px; color: var(--ink-2); }
.co-line .col-qty { font-size: 12px; color: var(--ink-3); }
.promo-input { display: flex; gap: 8px; margin: 16px 0; }
.promo-input input { flex: 1; padding: 12px 14px; border-radius: var(--radius-sm); border: 1.5px solid var(--line); background: var(--surface); color: var(--ink); font: inherit; }

/* ============================================================
   FOOTER
   ============================================================ */
.ph-footer { background: var(--surface); border-top: 1px solid var(--line); margin-top: 60px; padding: 54px 0 30px; }
.app[data-theme="forno"] .ph-footer { background: #100C0A; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 32px; }
.footer-grid h4 { font-size: 13px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-3); margin: 0 0 16px; }
.footer-grid a { display: block; font-size: 14px; color: var(--ink-2); padding: 5px 0; }
.footer-grid a:hover { color: var(--primary); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--line); font-size: 13px; color: var(--ink-3); flex-wrap: wrap; gap: 16px; }
.foot-brand { font-family: var(--display); font-weight: var(--display-wght); text-transform: var(--display-transform); font-size: 22px; color: var(--primary); }

/* ============================================================
   PIZZA ILLUSTRATION (flat motif)
   ============================================================ */
.pizza {
  position: relative; border-radius: 50%; aspect-ratio: 1;
  background:
    radial-gradient(circle at 50% 42%, #F4C36B 0 60%, #E89F3F 60% 70%, #D8852E 70% 100%);
  box-shadow: inset 0 -6px 18px rgba(120,60,10,.25);
}
.pizza::before {
  content: ""; position: absolute; inset: 11%; border-radius: 50%;
  background: radial-gradient(circle at 45% 40%, #F6D58A, #E7B05A);
}
.pizza::after {
  content: ""; position: absolute; inset: 11%; border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(207,58,40,.0) 56%, rgba(207,58,40,.18) 57%);
}
.pizza .topping { position: absolute; border-radius: 50%; transform: translate(-50%,-50%); box-shadow: 0 1px 2px rgba(80,30,0,.25); }
.pizza .pep { background: radial-gradient(circle at 38% 35%, #E8634A, #C0301E); }
.pizza .veg { background: radial-gradient(circle at 40% 35%, #5BAE4E, #2F7A37); }
.pizza .mush { background: radial-gradient(circle at 40% 35%, #E8D7B8, #B89B6E); }
.pizza .olive { background: radial-gradient(circle at 40% 35%, #4a4034, #1d1812); }
.pizza .basil { background: radial-gradient(circle at 40% 35%, #6FBE5C, #357d2c); border-radius: 60% 0 60% 0; }

.media-label {
  position: absolute; bottom: 10px; left: 10px; z-index: 2;
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 9.5px; letter-spacing: .04em; text-transform: uppercase;
  color: var(--ink-3); background: color-mix(in srgb, var(--card) 80%, transparent);
  padding: 3px 7px; border-radius: 5px; backdrop-filter: blur(4px);
}

/* tiny pizza for icons */
.pizza-ico { width: 100%; height: 100%; }

/* real product photo fills its media container */
.photo { width: 100%; height: 100%; object-fit: cover; display: block; }

/* generic warm placeholder (non-pizza foods) */
.foodph {
  width: 100%; height: 100%; display: grid; place-items: center; position: relative;
  background:
    repeating-linear-gradient(135deg, transparent 0 12px, rgba(0,0,0,.025) 12px 13px),
    var(--tile);
}
.foodph .fp-disc {
  width: 46%; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle at 42% 38%, color-mix(in srgb, var(--primary) 22%, var(--card)), var(--tile));
  border: 1px dashed var(--line-2);
}

/* ============================================================
   MISC
   ============================================================ */
.divider { height: 1px; background: var(--line); border: none; margin: 0; }
.toast {
  position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%) translateY(20px);
  background: var(--ink); color: var(--bg); padding: 14px 22px; border-radius: var(--radius-pill);
  font-weight: 700; font-size: 14px; box-shadow: var(--shadow-lg); z-index: 200;
  opacity: 0; pointer-events: none; transition: all .3s cubic-bezier(.2,.8,.2,1);
  display: flex; align-items: center; gap: 10px;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast .t-check { width: 22px; height: 22px; border-radius: 50%; background: var(--ok); display: grid; place-items: center; color: #fff; flex: none; }

.fade-in { animation: fadeUp .4s ease both; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .hero-inner { grid-template-columns: 1fr; gap: 28px; }
  .hero-art { min-height: 280px; }
  .order-card { max-width: 100%; }
  .pdp { grid-template-columns: 1fr; gap: 28px; }
  .pdp-media { position: static; }
  .cart-grid, .checkout-grid { grid-template-columns: 1fr; }
  .summary { position: static; }
  .grid-4 { grid-template-columns: repeat(3, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
  .container { padding: 0 16px; }
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-2 { grid-template-columns: 1fr; }
  .offer-card { grid-template-columns: 1fr; }
  .bs-grid { grid-template-columns: 1fr !important; }
  .header-actions .hide-sm { display: none; }
  .ph-header-row { height: 60px; gap: 10px; }
  .cat-nav { top: 59px; }
  .dough-grid { grid-template-columns: 1fr; }
  .field-row, .field-row-3 { grid-template-columns: 1fr; }
  .section { margin-top: 40px; }
  .promo { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 420px) {
  .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
