/* ==========================================================================
   Coconut QA Gym — Redesign tokens & component overrides
   Editorial bookshop · Forest green + Coral accent
   --------------------------------------------------------------------------
   Drop-in stylesheet. Use after Tailwind CDN (catalog) and after each page's
   existing inline <style> block. Sets CSS variables AND overrides component
   classes by name (no markup changes required where possible).
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Newsreader:opsz,wght@6..72,400;6..72,500;6..72,600&family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500&display=swap');

:root {
  /* --- Surfaces --- */
  --paper:        #FAF6EE;   /* warm cream — page background */
  --paper-2:      #F3ECDD;   /* slightly deeper cream — section bands */
  --surface:      #FFFFFF;
  --surface-2:    #F7F2E6;   /* card secondary fill */

  /* --- Ink (text) --- */
  --ink:          #14241B;   /* primary text — deep forest near-black */
  --ink-2:        #3E4D44;   /* secondary */
  --muted:        #7C8A82;   /* tertiary / meta */

  /* --- Rules / borders --- */
  --rule:         #E6DFCD;   /* warm rule */
  --rule-2:       #D9D0BB;   /* stronger divider */

  /* --- Brand greens --- */
  --green:        #1F5C42;   /* primary action */
  --green-deep:   #143E2D;   /* hover */
  --green-tint:   #E2ECDF;   /* badge fill / cell tint */
  --green-soft:   #EFF4E9;   /* page accents */

  /* --- Coral accent (CTA / sale flash) --- */
  --coral:        #E26545;
  --coral-deep:   #C24E32;
  --coral-soft:   #FBE6DD;

  /* --- Status --- */
  --gold:         #B68645;   /* stars */
  --gold-soft:    #F5E9D2;
  --error:        #B23A2E;
  --error-soft:   #F7E2DE;
  --info:         #2F5F92;
  --info-soft:    #DBE6F1;

  /* --- Type --- */
  --serif-display: "Instrument Serif", "Newsreader", Georgia, serif;
  --serif-body:    "Newsreader", Georgia, serif;
  --sans:          "Geist", -apple-system, "Segoe UI", sans-serif;
  --mono:          "Geist Mono", ui-monospace, monospace;

  /* --- Radius --- */
  --r-xs: 2px;
  --r-sm: 4px;
  --r-md: 6px;
  --r-lg: 10px;
  --r-pill: 999px;

  /* --- Shadows --- */
  --shadow-1: 0 1px 0 rgba(20, 36, 27, 0.04), 0 1px 3px rgba(20, 36, 27, 0.05);
  --shadow-2: 0 1px 0 rgba(20, 36, 27, 0.05), 0 8px 24px -10px rgba(20, 36, 27, 0.18);
  --shadow-pop: 0 18px 50px -16px rgba(20, 36, 27, 0.35);

  /* --- Motion --- */
  --t-fast: 120ms ease;
  --t-med: 200ms cubic-bezier(.22,.61,.36,1);
}

/* ========== BASE ========== */
html, body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: var(--green-tint); color: var(--ink); }

/* Map old vars (cart/checkout/orders/auth pages reference them) -------------- */
:root {
  --bg: var(--paper);
  --border: var(--rule);
  --text: var(--ink);
  --accent: var(--green);
  --accent-hv: var(--green-deep);
  --success: var(--green);
}

/* ========== HEADER / MASTHEAD ========== */
.header {
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  box-shadow: none;
}
.header-inner { max-width: 1120px; height: 72px; padding: 0 32px; }
.logo {
  font-family: var(--serif-display);
  font-weight: 400;
  font-size: 1.7rem;
  letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1;
  white-space: nowrap;
}
.logo::after {
  content: "EST. 2026 — BOOKSHOP";
  display: block;
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--muted);
  margin-top: 4px;
  font-weight: 500;
}
.nav { gap: 28px; }
.nav a, .nav button {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-2);
  letter-spacing: 0.01em;
  transition: color var(--t-fast);
}
.nav a:hover, .nav button:hover { color: var(--green); }

/* Cart icon badge */
.cart-icon { padding: 6px; }
.cart-badge {
  background: var(--coral);
  font-family: var(--sans);
  font-weight: 600;
  font-size: 10px;
  width: 18px; height: 18px;
  top: -3px; right: -5px;
  box-shadow: 0 0 0 2px var(--paper);
}

/* Balance chip */
.balance-chip { gap: 6px; font-size: 13px; }
.balance-chip #balance-val { font-family: var(--mono); font-weight: 500; font-size: 13px; }
.balance-pen { color: var(--muted); padding: 4px; border-radius: var(--r-sm); }
.balance-pen:hover { color: var(--green); background: var(--green-soft); }
.balance-popover {
  border-radius: var(--r-md);
  border-color: var(--rule);
  box-shadow: var(--shadow-pop);
  padding: 12px;
}
.balance-popover input {
  font-family: var(--mono);
  border-radius: var(--r-sm);
  padding: 7px 10px;
  width: 100px;
}
.balance-popover button {
  border-radius: var(--r-sm);
  font-weight: 600;
  padding: 7px 14px;
  letter-spacing: 0.02em;
  background: var(--green);
  color: #fff;
}
.balance-popover button:hover { background: var(--green-deep); }

/* ========== PAGE ========== */
.page { max-width: 1120px; padding: 56px 32px 80px; }
h1 {
  font-family: var(--serif-display);
  font-weight: 400;
  font-size: clamp(2.2rem, 3.4vw, 3rem);
  letter-spacing: -0.015em;
  line-height: 1.05;
  margin-bottom: 32px;
  color: var(--ink);
}
h1::before {
  content: "";
  display: block;
  width: 36px;
  height: 2px;
  background: var(--green);
  margin-bottom: 18px;
}

/* ========== EMPTY ========== */
.empty {
  padding: 96px 0;
  font-family: var(--serif-display);
  font-size: 1.4rem;
  color: var(--muted);
  font-style: italic;
}
.empty a {
  color: var(--green);
  font-family: var(--sans);
  font-style: normal;
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 4px;
  margin-left: 8px;
}

/* ========== TABLES ========== */
.cart-table, .orders-table {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-1);
  overflow: hidden;
}
.cart-table th, .orders-table th {
  background: var(--paper-2);
  border-bottom: 1px solid var(--rule);
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  padding: 14px 20px;
}
.cart-table td, .orders-table td {
  padding: 18px 20px;
  border-bottom: 1px solid var(--rule);
  font-size: 14px;
}
.cart-table tr:hover, .order-row:hover { background: var(--green-soft); }
.product-name { font-family: var(--serif-display); font-size: 1.1rem; font-weight: 400; }

/* qty controls */
.qty-controls { gap: 4px; align-items: center; display: inline-flex; }
.qty-btn {
  width: 30px; height: 30px;
  border: 1px solid var(--rule-2);
  background: var(--paper);
  color: var(--ink-2);
  border-radius: var(--r-sm);
  font-size: 1rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--t-fast);
}
.qty-btn:hover { background: var(--green); color: #fff; border-color: var(--green); }
.qty-val { width: 32px; font-family: var(--mono); font-size: 14px; font-weight: 500; }

.btn-delete {
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  padding: 6px 10px;
  border-radius: var(--r-sm);
}
.btn-delete:hover { color: var(--coral-deep); background: var(--coral-soft); }

/* ========== CART SUMMARY ========== */
.summary { margin-top: 32px; }
.summary-box {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: 28px;
  max-width: 380px;
  box-shadow: var(--shadow-1);
}
.summary-row { font-size: 14px; margin-bottom: 12px; color: var(--ink-2); }
.summary-row.total {
  font-family: var(--serif-display);
  font-size: 1.45rem;
  font-weight: 400;
  color: var(--ink);
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--rule);
  align-items: baseline;
  white-space: nowrap;
}
.summary-row.total > span { font-feature-settings: "tnum"; white-space: nowrap; }
.promo-row { gap: 0; margin-bottom: 12px; }
.promo-input {
  font-family: var(--mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 12px 14px;
  border-radius: var(--r-sm) 0 0 var(--r-sm);
  border-right: none;
  background: var(--paper);
  font-size: 13px;
}
.promo-input:focus { border-color: var(--green); }
.btn-promo {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 12px 18px;
}
.btn-promo:hover { background: var(--green-deep); border-color: var(--green-deep); }
.promo-msg { font-size: 12px; min-height: 18px; }
.promo-msg.error { color: var(--error); }
.promo-msg.success { color: var(--green); }
#active-promo {
  background: var(--green-soft);
  border: 1px solid var(--green-tint);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  font-size: 12px !important;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ========== PRIMARY ACTIONS ========== */
.btn-checkout, button[type="submit"], .btn {
  background: var(--green);
  color: #fff;
  border: none;
  border-radius: var(--r-md);
  padding: 14px 22px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--t-fast), transform var(--t-fast);
}
.btn-checkout:hover, button[type="submit"]:hover, .btn:hover { background: var(--green-deep); }
.btn-checkout:active, .btn:active, button[type="submit"]:active { transform: translateY(1px); }
.btn:disabled, button[type="submit"]:disabled { opacity: 0.5; cursor: default; }
.btn-checkout { width: 100%; margin-top: 6px; }

/* ========== STATUS BADGES ========== */
.status-badge {
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
}
.status-processing { background: var(--info-soft); color: var(--info); border-color: #B6CADF; }
.status-pending    { background: var(--gold-soft); color: var(--gold); border-color: #E4D2A6; }
.status-completed,
.status-delivered  { background: var(--green-tint); color: var(--green); border-color: #C5D9C5; }
.status-cancelled  { background: var(--error-soft); color: var(--error); border-color: #ECC6BF; }
.status-unknown    { background: var(--paper-2); color: var(--muted); border-color: var(--rule); }

.btn-cancel {
  border: 1px solid var(--rule-2);
  background: transparent;
  color: var(--ink-2);
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 7px 14px;
}
.btn-cancel:hover { border-color: var(--coral); color: var(--coral-deep); background: var(--coral-soft); }

/* order detail row */
.detail-row td { background: var(--paper-2); }
.detail-box { padding: 20px 24px; gap: 18px 36px; border-top: 1px solid var(--rule); }
.detail-row-item { font-size: 13px; color: var(--muted); }
.detail-row-item span { color: var(--ink); font-weight: 500; }

/* ========== FOOTER ========== */
.footer {
  border-top: 1px solid var(--rule);
  margin-top: 96px;
  padding: 40px 24px 60px;
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--muted);
}
.footer a { color: var(--muted); text-decoration: none; }
.footer a:hover { color: var(--ink); }

/* ========== AUTH (auth.html) ========== */
body:has(> .card) {
  background:
    radial-gradient(60% 60% at 50% 0%, var(--green-soft), transparent 70%),
    var(--paper);
}
.card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  padding: 48px 52px;
  box-shadow: var(--shadow-2);
  max-width: 460px;
}
.card .logo {
  text-align: center;
  font-family: var(--serif-display);
  font-size: 2rem;
  color: var(--ink);
  margin-bottom: 6px;
}
.card .logo::after {
  content: "Welcome back";
  font-family: var(--serif-body);
  font-style: italic;
  font-size: 14px;
  color: var(--muted);
  letter-spacing: 0;
  text-transform: none;
  margin-top: 0;
  display: block;
}
.tabs { border-bottom: 1px solid var(--rule); margin: 28px 0 32px; gap: 4px; }
.tab {
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 14px 10px;
  color: var(--muted);
  border-bottom: 2px solid transparent;
}
.tab.active { color: var(--ink); border-bottom-color: var(--green); }
.form { gap: 18px; }
.card label {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 6px;
}
.card input {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: 12px 14px;
  font-size: 15px;
  font-family: var(--sans);
}
.card input:focus { border-color: var(--green); background: var(--surface); box-shadow: 0 0 0 4px var(--green-soft); }
.card .error { color: var(--error); font-size: 12px; min-height: 16px; }
.card button[type="submit"] {
  margin-top: 8px;
  padding: 14px;
  border-radius: var(--r-md);
}
.card .msg { font-size: 13px; }
.card .msg.error   { color: var(--error); }
.card .msg.success { color: var(--green); }

/* ========== CHECKOUT (checkout.html) ========== */
.page:has(> h1):has(.card) { max-width: 600px; }
.card .field { margin-bottom: 22px; }
.card .field label {
  display: block;
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.card .field input,
.card .field select {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: 13px 14px;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
  width: 100%;
}
.card .field input:focus,
.card .field select:focus { border-color: var(--green); box-shadow: 0 0 0 4px var(--green-soft); }

/* ========================================================================== */
/* CATALOG — Tailwind page (index.html)                                       */
/* These overrides apply on top of Tailwind utilities. Use !important sparingly */
/* ========================================================================== */

body.bg-slate-50 { background: var(--paper) !important; color: var(--ink) !important; }

/* Catalog header */
body.bg-slate-50 > #app > header {
  background: var(--paper) !important;
  border-color: var(--rule) !important;
}
body.bg-slate-50 > #app > header .max-w-6xl { max-width: 1120px; height: 72px; padding: 0 32px; }
body.bg-slate-50 > #app > header .font-lora {
  font-family: var(--serif-display) !important;
  font-size: 1.7rem;
  letter-spacing: -0.01em;
  white-space: nowrap;
  line-height: 1;
}
body.bg-slate-50 > #app > header .font-lora::after {
  content: "EST. 2026 — BOOKSHOP";
  display: block;
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--muted);
  margin-top: 2px;
  font-weight: 500;
}
body.bg-slate-50 > #app > header nav a,
body.bg-slate-50 > #app > header nav button { color: var(--ink-2) !important; font-size: 13px !important; font-weight: 500; }
body.bg-slate-50 > #app > header nav a:hover,
body.bg-slate-50 > #app > header nav button:hover { color: var(--green) !important; }
body.bg-slate-50 > #app > header .bg-emerald-700 { background: var(--coral) !important; box-shadow: 0 0 0 2px var(--paper) !important; }

/* Catalog page layout */
body.bg-slate-50 .max-w-6xl.mx-auto.px-6.py-6 { max-width: 1120px; padding-top: 40px; padding-bottom: 80px; gap: 48px; }

/* Catalog masthead — removed, header logo carries identity */
body.bg-slate-50 section.flex-1::before { display: none; }

/* Sidebar — Filters card */
body.bg-slate-50 aside .bg-white {
  background: var(--surface) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-md) !important;
  padding: 24px !important;
  box-shadow: var(--shadow-1);
}
body.bg-slate-50 aside h2 {
  font-family: var(--serif-display) !important;
  font-size: 1.4rem !important;
  font-weight: 400 !important;
  letter-spacing: -0.01em;
  margin-bottom: 20px !important;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule);
}
body.bg-slate-50 aside label.block {
  font-family: var(--sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase;
  color: var(--muted) !important;
  font-weight: 600 !important;
  margin-bottom: 10px !important;
}
body.bg-slate-50 aside select,
body.bg-slate-50 aside input[type="number"],
body.bg-slate-50 aside input[type="text"] {
  background: var(--paper) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 12px !important;
  font-family: var(--sans);
  color: var(--ink) !important;
  font-size: 13px !important;
}
body.bg-slate-50 aside select:focus,
body.bg-slate-50 aside input:focus {
  border-color: var(--green) !important;
  box-shadow: 0 0 0 4px var(--green-soft) !important;
}
body.bg-slate-50 aside .accent-emerald-700 { accent-color: var(--green) !important; }
body.bg-slate-50 aside button[type="submit"] {
  background: var(--green) !important;
  color: #fff !important;
  border-radius: var(--r-md) !important;
  padding: 12px 16px !important;
  font-family: var(--sans);
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 12px !important;
}
body.bg-slate-50 aside button[type="submit"]:hover { background: var(--green-deep) !important; }

/* Search input */
body.bg-slate-50 section input[type="text"] {
  background: var(--surface) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-md) !important;
  padding: 16px 20px !important;
  font-size: 15px !important;
  font-family: var(--sans);
  box-shadow: var(--shadow-1);
}
body.bg-slate-50 section input[type="text"]::placeholder { color: var(--muted); }
body.bg-slate-50 section input[type="text"]:focus {
  border-color: var(--green) !important;
  box-shadow: 0 0 0 4px var(--green-soft) !important;
}

/* PRODUCT GRID */
body.bg-slate-50 section .grid { gap: 28px 24px !important; }

/* CARD — editorial style: tinted block image area, type-led footer */
body.bg-slate-50 article {
  background: var(--surface) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-md) !important;
  transition: box-shadow var(--t-med), transform var(--t-med), border-color var(--t-med) !important;
  overflow: hidden !important;
}
body.bg-slate-50 article:hover {
  box-shadow: var(--shadow-2) !important;
  transform: translateY(-3px) !important;
  border-color: var(--rule-2) !important;
}
body.bg-slate-50 article.discounted {
  border-color: var(--coral) !important;
}
body.bg-slate-50 article .aspect-\[3\/4\] {
  background: #FFFFFF !important;
  border-bottom: 1px solid var(--rule) !important;
  position: relative;
}
body.bg-slate-50 article .aspect-\[3\/4\]::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  box-shadow: inset 0 -40px 60px -50px rgba(20,36,27,0.10);
}
body.bg-slate-50 article img { display: block; width: 100%; height: 100%; object-fit: cover; }
body.bg-slate-50 article .p-3\.5 { padding: 20px 18px 22px !important; gap: 10px !important; }

/* Category caps */
body.bg-slate-50 article span.uppercase,
body.bg-slate-50 article .text-\[0\.7rem\].uppercase {
  font-family: var(--sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.16em !important;
  color: var(--muted) !important;
  font-weight: 600 !important;
}

/* Title — serif display */
body.bg-slate-50 article h3 {
  font-family: var(--serif-display) !important;
  font-size: 1.15rem !important;
  font-weight: 400 !important;
  line-height: 1.15 !important;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin-top: 2px;
}

/* Description */
body.bg-slate-50 article p {
  font-family: var(--serif-body) !important;
  font-size: 14px !important;
  color: var(--ink-2) !important;
  line-height: 1.45 !important;
  font-style: italic;
}

/* Tags */
body.bg-slate-50 article span.bg-slate-100 {
  background: var(--paper-2) !important;
  color: var(--ink-2) !important;
  font-family: var(--sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 4px 10px !important;
  border-radius: var(--r-pill) !important;
}

/* Price */
body.bg-slate-50 article .text-emerald-700 {
  color: var(--ink) !important;
  font-family: var(--serif-display) !important;
  font-size: 1.3rem !important;
  font-weight: 400 !important;
  letter-spacing: -0.01em;
  font-feature-settings: "tnum" !important;
  white-space: nowrap;
}
body.bg-slate-50 article .text-slate-400.line-through {
  color: var(--muted) !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
}
body.bg-slate-50 article .bg-emerald-50 {
  background: var(--coral-soft) !important;
  color: var(--coral-deep) !important;
  font-family: var(--sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.08em;
  font-weight: 700 !important;
  padding: 3px 8px !important;
  border-radius: var(--r-sm) !important;
}

/* Primary button on card */
body.bg-slate-50 article button.bg-emerald-700 {
  background: var(--green) !important;
  color: #fff !important;
  border-radius: var(--r-md) !important;
  padding: 12px 16px !important;
  font-family: var(--sans);
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase;
  margin-top: 12px !important;
  transition: background var(--t-fast);
}
body.bg-slate-50 article button.bg-emerald-700:hover { background: var(--green-deep) !important; }
body.bg-slate-50 article button.disabled\:bg-slate-400:disabled { background: var(--rule-2) !important; color: var(--muted) !important; }

/* In-cart state */
body.bg-slate-50 article .border-slate-300 {
  border-color: var(--rule-2) !important;
  color: var(--ink-2) !important;
  border-radius: var(--r-sm) !important;
}
body.bg-slate-50 article .border-slate-300:hover { background: var(--green) !important; color: #fff !important; border-color: var(--green) !important; }
body.bg-slate-50 article .bg-slate-200 {
  background: var(--green-soft) !important;
  color: var(--green) !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600 !important;
  border: 1px solid var(--green-tint) !important;
}

/* Out-of-stock state — preserve U-1 bug visual (opacity), refresh aesthetic */
body.bg-slate-50 article.out-of-stock { opacity: 0.55 !important; }
body.bg-slate-50 article.discounted   { opacity: 1 !important; }

/* Pagination */
body.bg-slate-50 .border-slate-200.rounded-md.text-sm {
  background: var(--surface) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-sm) !important;
  font-family: var(--sans);
  font-size: 12px !important;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 10px 16px !important;
  color: var(--ink-2) !important;
}
body.bg-slate-50 .mt-6.flex.items-center.justify-center span { font-family: var(--sans); font-size: 13px; color: var(--ink-2); }

/* ========================================================================== */
/* MODAL — Catalog product modal                                              */
/* ========================================================================== */

body.bg-slate-50 > #app > .fixed.inset-0 {
  background: rgba(20, 36, 27, 0.55) !important;
  backdrop-filter: blur(4px);
  padding: 24px !important;
}
body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white {
  background: var(--surface) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-lg) !important;
  max-width: 880px !important;
  max-height: 90vh !important;
  box-shadow: var(--shadow-pop) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  position: relative;
  padding: 0 !important;
}
/* The catalog modal uses a flex row of image+content. Make image full-bleed left. */
body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white > .flex.flex-col.sm\:flex-row {
  flex-direction: row !important;
  align-items: stretch;
}
body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white > .flex.flex-col.sm\:flex-row > div:first-child {
  width: 320px !important;
  height: auto !important;
  flex-shrink: 0;
  background: var(--green-soft) !important;
  border-radius: 0 !important;
  border-right: 1px solid var(--rule);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px;
}
body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white img {
  object-fit: contain;
  width: 100%;
  height: auto;
  max-height: 460px;
  min-height: 0;
  display: block;
  filter: drop-shadow(0 12px 24px rgba(20,36,27,0.18));
}
body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white > .flex.flex-col.sm\:flex-row > div:last-child {
  padding: 44px 44px 28px !important;
  flex: 1;
  min-width: 0;
}

/* Close button repositioned */
body.bg-slate-50 > #app > .fixed.inset-0 .flex.justify-end.px-4 {
  position: absolute !important;
  top: 16px;
  right: 16px;
  z-index: 5;
  padding: 0 !important;
}
body.bg-slate-50 > #app > .fixed.inset-0 .flex.justify-end.px-4 button {
  width: 36px;
  height: 36px;
  border-radius: var(--r-pill);
  background: var(--surface);
  border: 1px solid var(--rule);
  color: var(--ink) !important;
  font-size: 1.2rem;
  box-shadow: var(--shadow-1);
}

/* Modal typography */
body.bg-slate-50 > #app > .fixed.inset-0 .text-\[0\.72rem\].uppercase {
  font-family: var(--sans) !important;
  font-size: 10px !important;
  letter-spacing: 0.18em;
  color: var(--muted) !important;
  font-weight: 600 !important;
}
body.bg-slate-50 > #app > .fixed.inset-0 h2.font-lora {
  font-family: var(--serif-display) !important;
  font-size: 2rem !important;
  font-weight: 400 !important;
  line-height: 1.1 !important;
  margin: 6px 0 14px !important;
}
body.bg-slate-50 > #app > .fixed.inset-0 .text-xl.font-bold.text-emerald-700 {
  font-family: var(--serif-display) !important;
  font-size: 1.7rem !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  letter-spacing: -0.01em;
  white-space: nowrap;
  font-feature-settings: "tnum";
}
body.bg-slate-50 > #app > .fixed.inset-0 .text-sm.text-slate-400.line-through {
  font-family: var(--sans) !important;
  font-size: 15px !important;
  color: var(--muted) !important;
}
body.bg-slate-50 > #app > .fixed.inset-0 .text-xs.font-bold.bg-emerald-50 {
  background: var(--coral-soft) !important;
  color: var(--coral-deep) !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em;
  padding: 4px 9px !important;
  border-radius: var(--r-sm) !important;
}
body.bg-slate-50 > #app > .fixed.inset-0 p.text-sm.text-slate-500 {
  font-family: var(--serif-body) !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
  color: var(--ink-2) !important;
  font-style: italic;
}

/* Sticky add-to-cart bar */
body.bg-slate-50 > #app > .fixed.inset-0 .px-6.py-4.border-t {
  padding: 18px 32px !important;
  background: var(--paper) !important;
  border-top: 1px solid var(--rule) !important;
  position: sticky;
  bottom: 0;
  z-index: 4;
}
body.bg-slate-50 > #app > .fixed.inset-0 .px-6.py-4 input[type="number"] {
  background: var(--surface) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-sm) !important;
  width: 64px !important;
  padding: 10px !important;
  font-family: var(--mono) !important;
  font-size: 14px !important;
  text-align: center;
}
body.bg-slate-50 > #app > .fixed.inset-0 .px-6.py-4 button.bg-emerald-700 {
  background: var(--green) !important;
  color: #fff !important;
  border-radius: var(--r-md) !important;
  padding: 12px 28px !important;
  font-family: var(--sans);
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* Reviews block */
body.bg-slate-50 > #app > .fixed.inset-0 .px-6.py-5.border-t,
body.bg-slate-50 > #app > .fixed.inset-0 .px-6.pb-6.pt-4.border-t {
  padding: 32px 48px !important;
  background: var(--paper);
  border-top: 1px solid var(--rule) !important;
}
body.bg-slate-50 > #app > .fixed.inset-0 h3.text-sm.font-semibold {
  font-family: var(--serif-display) !important;
  font-size: 1.4rem !important;
  font-weight: 400 !important;
  margin-bottom: 18px !important;
  letter-spacing: -0.01em;
}
body.bg-slate-50 > #app > .fixed.inset-0 .bg-slate-50.border {
  background: var(--surface) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-md) !important;
  padding: 16px 18px !important;
}
body.bg-slate-50 > #app > .fixed.inset-0 .text-amber-400 { color: var(--gold) !important; font-size: 1rem !important; letter-spacing: 1px; }
body.bg-slate-50 > #app > .fixed.inset-0 textarea {
  background: var(--surface) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-md) !important;
  padding: 14px !important;
  font-family: var(--sans) !important;
  font-size: 14px !important;
  min-height: 90px;
}
body.bg-slate-50 > #app > .fixed.inset-0 textarea:focus { border-color: var(--green) !important; box-shadow: 0 0 0 4px var(--green-soft) !important; }
body.bg-slate-50 > #app > .fixed.inset-0 button.text-2xl.leading-none.focus\:outline-none { padding: 0 2px; }

/* Footer */
body.bg-slate-50 footer.text-center {
  border-top: 1px solid var(--rule) !important;
  margin-top: 96px !important;
  padding: 40px !important;
}
body.bg-slate-50 footer.text-center a { font-family: var(--sans); font-size: 12px; letter-spacing: 0.06em; color: var(--muted) !important; }

/* ========== TOASTS (toast.js injects) ========== */
#toast-container .toast {
  background: var(--surface) !important;
  color: var(--ink) !important;
  border: 1px solid var(--rule) !important;
  border-radius: var(--r-md) !important;
  font-family: var(--sans) !important;
  font-size: 14px !important;
  padding: 14px 22px !important;
  box-shadow: var(--shadow-pop) !important;
  letter-spacing: 0.01em;
}
#toast-container .toast.toast-error   { border-top: 3px solid var(--coral) !important; }
#toast-container .toast.toast-success { border-top: 3px solid var(--green) !important; }

/* ========== RESPONSIVE — keep simple, mobile gracefully ========== */
@media (max-width: 720px) {
  .header-inner, .page { padding-left: 20px; padding-right: 20px; }
  .nav { gap: 16px; }
  .logo { font-size: 1.4rem; }
  .logo::after { display: none; }
  .card { padding: 32px 24px; }
  body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white > .flex.flex-col.sm\:flex-row { flex-direction: column !important; }
  body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white > .flex.flex-col.sm\:flex-row > div:first-child { width: 100% !important; height: 280px !important; min-height: 0 !important; position: static; }
  body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white img { min-height: 0 !important; }
  body.bg-slate-50 > #app > .fixed.inset-0 > .bg-white > .flex.flex-col.sm\:flex-row > div:last-child { padding: 28px !important; }
  body.bg-slate-50 > #app > .fixed.inset-0 .px-6.py-5.border-t,
  body.bg-slate-50 > #app > .fixed.inset-0 .px-6.pb-6.pt-4.border-t { padding: 24px !important; }
}
