/* ============================================================
   VAPÉ — Quiet-Luxury Design System
   Warm taupe + bone/sand neutrals · serif/grotesque pairing
   (class names preserved; restyled for a premium feel)
   ============================================================ */

:root {
  /* Base — neutral near-black (monochrome, faintly warm so it isn't clinical) */
  --bg-0: #0d0d0c;
  --bg-1: #151513;
  --bg-2: #1d1d1b;

  /* Ink — high-legibility off-white (raised for readability) */
  --ink:   #f4f1ec;
  --ink-2: rgba(244, 241, 236, 0.68);
  --ink-3: rgba(244, 241, 236, 0.46);

  /* Glass surfaces — neutral frosted */
  --glass:        rgba(244, 241, 236, 0.042);
  --glass-2:      rgba(244, 241, 236, 0.075);
  --glass-stroke:      rgba(244, 241, 236, 0.11);
  --glass-stroke-soft: rgba(244, 241, 236, 0.065);
  --glass-hi:     rgba(255, 255, 255, 0.14);   /* lit top edge */

  /* Accent = light neutral (near-white). Monochrome — no colour. (var names kept) */
  --gold-1: #f3f0ea;   /* near-white highlight */
  --gold-2: #cfccc4;   /* light grey */
  --gold-3: #9b988f;   /* mid grey (borders/depth) */
  --gold-line: rgba(244, 241, 236, 0.22);
  --grad-gold: linear-gradient(180deg, #f6f3ee 0%, #e7e3db 100%);  /* flat near-white pill */

  --sage: #aab3ab;     /* legacy var, unused in theme */
  --plat: #c4cedb;     /* legacy var */

  /* Status — muted functional signals only (stock / order states) */
  --ok:   #93c2a4;   /* available */
  --warn: #d3b481;   /* low */
  --bad:  #d59a8d;   /* out / error */

  --radius-xl: 26px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 10px;

  --shadow-soft: 0 18px 50px -24px rgba(0,0,0,0.7);
  --shadow-pop:  0 34px 80px -28px rgba(0,0,0,0.8);
  --shadow-gold: 0 16px 44px -20px rgba(0,0,0,0.55);
  --blur: 30px;

  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);

  --font-serif: "Playfair Display", "Noto Sans Thai", Georgia, serif;
  --font-display: "Space Grotesk", "Noto Sans Thai", system-ui, sans-serif;
  --font-body: "Inter", "Noto Sans Thai", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }

body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--bg-0);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  letter-spacing: 0.08px;
}
:lang(th), [lang="th"] { font-family: "Noto Sans Thai", var(--font-body); }

/* ---------------- Ambient background ---------------- */
.bg-stage {
  position: fixed; inset: 0; z-index: -2;
  background:
    radial-gradient(110% 80% at 50% -25%, rgba(244,241,236,0.045) 0%, transparent 55%),
    linear-gradient(180deg, #0f0f0e 0%, #0c0c0b 100%);
}
.orb { display:none; }   /* monochrome: no coloured light */
.orb-1, .orb-2, .orb-3 { display:none; }
.bg-grain { position:absolute; inset:0; opacity:0.035; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
@keyframes float1 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(3vw,2vh)} }
@keyframes float2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-2vw,-3vh)} }

/* ---------------- Glass primitive ---------------- */
.glass {
  background:
    radial-gradient(120% 100% at 0% 0%, rgba(255,255,255,0.06), transparent 42%),
    linear-gradient(180deg, rgba(247,243,236,0.055), rgba(247,243,236,0.02));
  backdrop-filter: blur(var(--blur)) saturate(150%);
  -webkit-backdrop-filter: blur(var(--blur)) saturate(150%);
  border: 1px solid var(--glass-stroke);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft), inset 0 1px 0 var(--glass-hi), inset 0 0 0 0.5px rgba(255,255,255,0.02);
}
.glass-soft {
  background: var(--glass);
  backdrop-filter: blur(16px) saturate(120%);
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  border: 1px solid var(--glass-stroke-soft);
  border-radius: var(--radius-md);
}

/* ---------------- Typography ---------------- */
.serif { font-family: var(--font-serif); font-weight: 600; letter-spacing: 0; }
.display { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em; line-height: 1.0; }
.eyebrow { font-family: var(--font-display); font-size: 10.5px; letter-spacing: 0.42em; text-transform: uppercase; color: var(--gold-2); font-weight: 600; }
.muted { color: var(--ink-2); }
.muted-2 { color: var(--ink-3); }
.gold-text { background: var(--grad-gold); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ---------------- Buttons ---------------- */
.btn {
  font-family: var(--font-display); font-weight: 600; font-size: 13.5px; letter-spacing: 0.01em;
  border: 1px solid transparent; border-radius: 999px; padding: 12px 22px;
  cursor: pointer; transition: transform .25s var(--ease), box-shadow .3s var(--ease), background .3s, border-color .3s, color .3s;
  display: inline-flex; align-items: center; gap: 9px; white-space: nowrap;
}
/* keep button icons a fixed size — otherwise an unsized <svg> balloons to fill a wide flex button */
.btn svg { width: 18px; height: 18px; flex: none; }
.btn:active { transform: scale(.97); }
.btn-primary {
  color: #2a2620; background: var(--grad-gold);
  box-shadow: var(--shadow-gold), inset 0 1px 0 rgba(255,255,255,0.4);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 14px 34px -16px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.6); }
.btn-ghost { color: var(--ink); background: var(--glass-2); border-color: var(--glass-stroke); }
.btn-ghost:hover { background: rgba(247,243,236,0.11); border-color: var(--gold-line); }
.btn-dark { color: var(--ink); background: rgba(10,8,7,0.55); border-color: var(--glass-stroke); }
.btn-dark:hover { background: rgba(10,8,7,0.8); }
.btn-sm { padding: 8px 15px; font-size: 12.5px; }
.btn-icon { padding: 11px; border-radius: 50%; aspect-ratio: 1; justify-content: center; }
.btn:disabled { opacity: .42; cursor: not-allowed; box-shadow:none; }
.btn:disabled:hover { transform:none; }
.btn-block { width: 100%; justify-content: center; }

/* ---------------- Chips / badges ---------------- */
.chip {
  font-family: var(--font-display); font-size: 12px; font-weight: 500; padding: 6px 13px; border-radius: 999px;
  background: var(--glass-2); border: 1px solid var(--glass-stroke-soft); color: var(--ink-2);
  cursor: pointer; transition: all .22s var(--ease); white-space: nowrap;
}
.chip:hover { color: var(--ink); border-color: var(--gold-line); }
.chip.active { background: var(--grad-gold); color:#2a2620; border-color: transparent; font-weight:600; }
.badge { font-family: var(--font-display); font-size: 10.5px; font-weight: 600; padding: 5px 11px; border-radius: 999px; letter-spacing: .05em; text-transform: uppercase; display:inline-flex; align-items:center; gap:6px; }
.badge .dot { width:5px; height:5px; border-radius:50%; background: currentColor; }
.badge-ok   { color: var(--ok);   background: rgba(143,200,164,0.10); }
.badge-warn { color: var(--warn); background: rgba(216,184,120,0.10); }
.badge-bad  { color: var(--bad);  background: rgba(213,154,141,0.10); }
.badge-info { color: var(--plat); background: rgba(196,206,219,0.10); }
.badge-neutral { color: var(--ink-2); background: var(--glass-2); }
.badge-credit { color: #2a2620; background: var(--grad-gold); box-shadow: 0 3px 12px -5px rgba(0,0,0,0.5); }
.badge-credit .dot { background:#2a2620; }

/* ---------------- Layout shell ---------------- */
.shell { display: grid; grid-template-columns: 256px 1fr; min-height: 100vh; }
.sidebar {
  position: sticky; top: 0; height: 100vh; padding: 28px 18px;
  display: flex; flex-direction: column; gap: 4px;
  border-right: 1px solid var(--glass-stroke-soft);
  background: linear-gradient(180deg, rgba(247,243,236,0.035), rgba(247,243,236,0.01));
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
}
.brand { display:flex; align-items:center; gap:10px; padding: 4px 12px 24px; }
.brand .logo { font-family: var(--font-serif); font-weight: 700; font-size: 27px; letter-spacing: 0.01em; line-height:1; }
.brand .logo span { color: var(--gold-2); }
.brand .role-tag { font-family: var(--font-display); font-size: 9.5px; letter-spacing: .34em; color: var(--ink-3); text-transform: uppercase; margin-top: 5px; }
.nav-item {
  display:flex; align-items:center; gap:13px; padding: 12px 14px; border-radius: 12px;
  color: var(--ink-2); cursor: pointer; font-weight: 500; font-size: 14px; transition: all .22s var(--ease); border:1px solid transparent; position:relative;
}
.nav-item .ic { width:19px; height:19px; flex:none; opacity:.75; }
.nav-item:hover { color: var(--ink); background: var(--glass); }
.nav-item.active { color: var(--ink); background: var(--glass-2); border-color: var(--glass-stroke-soft); box-shadow: inset 0 1px 0 var(--glass-hi); }
.nav-item.active::before { content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:3px; height:18px; border-radius:3px; background: var(--grad-gold); }
.nav-item.active .ic { opacity: 1; color: var(--gold-1); }
.nav-spacer { flex: 1; }

.main { min-width: 0; display: flex; flex-direction: column; }
.topbar {
  position: sticky; top: 0; z-index: 30; display:flex; align-items:center; gap: 16px;
  padding: 17px 32px; border-bottom: 1px solid var(--glass-stroke-soft);
  background: rgba(12,10,9,0.55); backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
}
.topbar .page-title { font-family: var(--font-display); font-weight: 600; font-size: 18px; letter-spacing:-0.01em; }
.topbar .spacer { flex: 1; }
.content { padding: 34px 32px; max-width: 1340px; width: 100%; margin: 0 auto; }

/* Lang toggle */
.lang-toggle { display:inline-flex; background: var(--glass-2); border:1px solid var(--glass-stroke-soft); border-radius:999px; padding:3px; }
.lang-toggle button { border:none; background:transparent; color:var(--ink-3); font-family:var(--font-display); font-weight:600; font-size:11.5px; padding:6px 12px; border-radius:999px; cursor:pointer; transition:all .22s var(--ease); letter-spacing:.05em; }
.lang-toggle button.active { background: var(--ink); color: var(--bg-0); }

/* Inputs */
.field {
  background: var(--glass); border:1px solid var(--glass-stroke-soft); border-radius: 11px;
  padding: 11px 15px; color: var(--ink); font-family: var(--font-body); font-size: 14px; width: 100%;
  transition: border-color .25s, background .25s;
}
.field::placeholder { color: var(--ink-3); }
.field:focus { outline:none; border-color: var(--gold-line); background: var(--glass-2); }
.field-wrap { position: relative; }
.field-wrap .ic { position:absolute; left:13px; top:50%; transform:translateY(-50%); opacity:.5; width:18px; height:18px; pointer-events:none; }
.field-wrap .field { padding-left: 40px; }
label.lbl { font-family: var(--font-display); font-size: 11px; color: var(--ink-2); font-weight:500; display:block; margin-bottom:7px; letter-spacing:.03em; }
select.field { appearance: none; cursor:pointer; }

/* search box — icon is a flex sibling, never overlaps the input */
.search-box { display:flex; align-items:center; gap:9px; width:240px; max-width:100%;
  background: var(--glass); border:1px solid var(--glass-stroke-soft); border-radius:11px; padding:0 14px;
  transition: border-color .25s, background .25s; cursor:text; position:relative; z-index:10; }
.search-box:focus-within { border-color: var(--gold-line); background: var(--glass-2); }
.search-box .search-ic { display:flex; align-items:center; opacity:.5; pointer-events:none; flex:none; }
.search-box .search-ic svg { width:18px; height:18px; }
.search-box input { flex:1; min-width:0; background:transparent; border:none; outline:none;
  color: var(--ink); font-family: var(--font-body); font-size:14px; padding:11px 0; }
.search-box input::placeholder { color: var(--ink-3); }

/* Avatar */
.avatar { width: 38px; height: 38px; border-radius: 50%; background: var(--grad-gold); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:700; color:#2a2620; font-size:14px; box-shadow: inset 0 1px 0 rgba(255,255,255,0.4); }

/* ---------------- Grids ---------------- */
.grid { display:grid; gap: 18px; }
.cols-2 { grid-template-columns: repeat(2,1fr); }
.cols-3 { grid-template-columns: repeat(3,1fr); }
.cols-4 { grid-template-columns: repeat(4,1fr); }
.cols-auto { grid-template-columns: repeat(auto-fill, minmax(258px, 1fr)); }

/* Product card — ABC-style: image header, then padded body */
.pcard { padding: 0; display:flex; flex-direction:column; position:relative; overflow:hidden; transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .3s; }
.pcard::after { content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; opacity:0; transition:opacity .35s var(--ease);
  background: radial-gradient(120% 80% at 50% -10%, rgba(255,255,255,0.06), transparent 60%); }
.pcard:hover { transform: translateY(-6px); box-shadow: var(--shadow-pop), inset 0 1px 0 var(--glass-hi); border-color: var(--gold-line); }
.pcard:hover::after { opacity:1; }
.pcard.sold-out { opacity: .82; }
.pcard .pimg { aspect-ratio: 16/11; border-radius: var(--radius-lg) var(--radius-lg) 0 0; overflow:hidden; position:relative; cursor: zoom-in;
  background: radial-gradient(circle at 50% 28%, rgba(244,241,236,0.07), rgba(244,241,236,0.012)); display:flex; align-items:center; justify-content:center; border-bottom:1px solid var(--glass-stroke-soft); }
.zoom-hint { position:absolute; top:10px; right:10px; z-index:1; width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background: rgba(12,11,10,0.5); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); border:1px solid var(--glass-stroke-soft); color: var(--ink); opacity:0; transition: opacity .25s var(--ease); }
.zoom-hint svg { width:15px; height:15px; opacity:.9; }
.pcard:hover .zoom-hint { opacity:1; }
.pcard .pimg svg { width: 60%; height: 60%; }
.pcard .pimg img.prod-img { width: 100%; height: 100%; object-fit: cover; object-position: left center; transition: transform .5s var(--ease); }
.pcard:hover .pimg img.prod-img { transform: scale(1.04); }
.cart-line .thumb img.prod-img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; }
.pcard .pimg .stock-pill { position:absolute; top:10px; left:10px; z-index:1; }
.pcard-body { padding: 17px 17px 18px; display:flex; flex-direction:column; gap: 12px; }
.pcard .psku { font-family: var(--font-display); font-size: 10px; color: var(--ink-3); letter-spacing:.12em; text-transform:uppercase; margin-bottom:4px; }
.pcard .ptitle { font-family: var(--font-display); font-weight:600; font-size: 16.5px; letter-spacing:-0.01em; line-height:1.15; }
.pcard .ptag { font-size: 12px; color: var(--ink-2); line-height:1.5; }
.pcard .pprice-wrap { flex:none; text-align:right; }
.pcard .plbl { font-family: var(--font-display); font-size: 8.5px; letter-spacing:.14em; text-transform:uppercase; color: var(--ink-3); }
.pcard .pprice { font-family: var(--font-serif); font-weight:600; font-size: 24px; letter-spacing:0; line-height:1.1; }
.pcard.sold-out .ptitle { color: var(--ink-3); text-decoration: line-through; text-decoration-color: var(--bad); }
.pcard.sold-out .prod-img { filter: grayscale(0.95) brightness(0.6); }

/* spec pills */
.spec-row { display:flex; flex-wrap:wrap; gap:6px; }
.spec-pill { display:inline-flex; align-items:center; gap:5px; font-family: var(--font-display); font-size:10.5px; font-weight:500; letter-spacing:.01em;
  color: var(--ink-2); background: var(--glass-2); border:1px solid var(--glass-stroke-soft); border-radius:8px; padding:5px 9px; }
.spec-pill svg { opacity:.65; }

/* sold-out ribbon */
.soldout-overlay { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background: rgba(8,7,6,0.45); z-index:2; }
.soldout-overlay span {
  font-family: var(--font-display); font-weight:700; font-size:13px; letter-spacing:.16em; text-transform:uppercase;
  color: var(--bad); border:1px solid var(--bad); padding:8px 18px; border-radius:999px;
  transform: rotate(-8deg); background: rgba(8,7,6,0.6); }

/* Flavour pills — auto-width, full names always visible */
.flavor-head { font-family: var(--font-display); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color: var(--ink); display:flex; align-items:center; gap:6px; }
.flavor-grid { display:flex; flex-wrap:wrap; gap:6px; }
.flavor { display:inline-flex; align-items:center; gap:6px; font-family: var(--font-body); font-size:11.5px; padding:7px 12px; border-radius:999px;
  background: var(--glass-2); border:1px solid var(--glass-stroke-soft); cursor:pointer; color:var(--ink-2); transition:all .2s var(--ease); }
.flavor:hover:not(:disabled) { border-color: var(--gold-line); color: var(--ink); background: rgba(244,241,236,0.09); }
.flavor .fnm { white-space:nowrap; }
.flavor .fstk { opacity:.7; font-size:10px; }
.flavor.active { background: var(--ink); color: var(--bg-0); border-color:transparent; font-weight:500; }
.flavor.out { opacity:.5; text-decoration: line-through; text-decoration-color: var(--bad); cursor:not-allowed; color: var(--bad); border-color: rgba(213,154,141,0.25); background: rgba(213,154,141,0.05); }
.flv-x { margin-left:2px; font-weight:700; text-decoration:none; color: var(--bad); }
.line-total { padding-top:11px; margin-top:2px; border-top:1px solid var(--glass-stroke-soft); }

/* Qty stepper */
.qty { display:inline-flex; align-items:center; background: var(--glass-2); border:1px solid var(--glass-stroke-soft); border-radius: 999px; overflow:hidden; }
.qty button { border:none; background:transparent; color:var(--ink); width:34px; height:34px; font-size:17px; cursor:pointer; transition:background .18s; }
.qty button:hover { background: var(--glass-2); }
.qty input { width: 50px; text-align:center; background:transparent; border:none; color:var(--ink); font-family:var(--font-display); font-weight:600; font-size:15px; }
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{ -webkit-appearance:none; }

/* buy row */
.buy-row { display:flex; gap:10px; align-items:center; margin-top: 4px; }
.buy-row .qty { flex:none; }
.add-btn { flex:1; justify-content:center; font-weight:600; }
.add-btn span { white-space:nowrap; }

/* cart pill */
.cart-pill { gap:9px; padding:10px 16px; }
.cart-pill-count { background: rgba(42,38,32,0.22); color:#2a2620; min-width:20px; height:20px; border-radius:999px; font-family:var(--font-display); font-weight:700; font-size:12px; display:inline-flex; align-items:center; justify-content:center; padding:0 6px; }
.cart-pill-sep { width:1px; height:16px; background: rgba(42,38,32,0.25); }
.cart-pill-total { font-family:var(--font-display); font-weight:700; font-size:14px; }

/* ---------------- Tables ---------------- */
.tbl-wrap { overflow-x:auto; border-radius: var(--radius-lg); }
table.tbl { width:100%; border-collapse: collapse; font-size: 14px; }
table.tbl thead th { text-align:left; font-family:var(--font-display); font-weight:600; font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); padding: 15px 16px; border-bottom:1px solid var(--glass-stroke); white-space:nowrap; }
table.tbl tbody td { padding: 14px 16px; border-bottom: 1px solid var(--glass-stroke-soft); vertical-align: middle; }
table.tbl tbody tr { transition: background .18s; }
table.tbl tbody tr:hover { background: var(--glass); }
table.tbl tbody tr:last-child td { border-bottom: none; }
.mono { font-family: var(--font-display); font-weight:600; font-variant-numeric: tabular-nums; }

/* ---------------- Stat cards ---------------- */
.stat { padding: 22px 24px; display:flex; flex-direction:column; gap: 9px; }
.stat .label { font-family: var(--font-display); font-size: 11px; color: var(--ink-2); font-weight:500; letter-spacing:.06em; text-transform:uppercase; }
.stat .value { font-family: var(--font-serif); font-weight:600; font-size: 30px; letter-spacing:-0.01em; }
.stat .delta { font-size: 12px; font-weight:600; }
.stat .delta.up { color: var(--ok); } .stat .delta.down { color: var(--bad); }

/* Section header */
.section-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom: 22px; gap: 16px; flex-wrap:wrap; }
.section-head h2 { font-family:var(--font-serif); font-weight:600; font-size: 24px; letter-spacing:0; }
.toolbar { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* ---------------- Modal ---------------- */
.modal-overlay { position:fixed; inset:0; z-index:100; background: rgba(6,5,4,0.62); backdrop-filter: blur(10px); display:flex; align-items:center; justify-content:center; padding:24px; animation: fade .25s var(--ease); }
.modal { width: min(560px, 100%); max-height: 88vh; overflow-y:auto; padding: 28px; animation: pop .3s var(--ease); }
.modal.wide { width: min(840px, 100%); }
.modal-head { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom: 20px; gap: 14px; }
.modal-head h3 { font-family:var(--font-serif); font-weight:600; font-size: 21px; }
.modal .close { cursor:pointer; color:var(--ink-3); font-size:22px; line-height:1; background:none; border:none; transition:color .2s; }
.modal .close:hover { color: var(--ink); }
@keyframes fade { from{opacity:0} to{opacity:1} }
@keyframes pop { from{opacity:0; transform: translateY(16px) scale(.985)} to{opacity:1; transform:none} }

/* ---------------- Toast ---------------- */
.toast-host { position: fixed; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 200; display:flex; flex-direction:column; gap:10px; align-items:center; }
.toast { padding: 13px 20px; font-size:13.5px; font-weight:500; display:flex; align-items:center; gap:10px; animation: pop .28s var(--ease); border-radius: 999px; }
.toast.ok { border-color: var(--gold-line); }
.toast.bad { border-color: rgba(213,154,141,0.4); }

/* ---------------- Demo dock ---------------- */
.demo-dock { position: fixed; bottom: 22px; right: 22px; z-index: 90; display:flex; align-items:center; gap:4px; padding: 7px; border-radius: 999px; }
.demo-dock .demo-label { font-family:var(--font-display); font-size:9px; letter-spacing:.28em; color:var(--gold-2); padding: 0 9px; }
.demo-dock button { border:none; background: transparent; color:var(--ink-2); font-family:var(--font-body); font-weight:500; font-size:12.5px; padding: 8px 14px; border-radius:999px; cursor:pointer; transition:all .22s var(--ease); }
.demo-dock button:hover { color: var(--ink); }
.demo-dock button.active { background: var(--ink); color: var(--bg-0); }

/* ---------------- Age gate ---------------- */
.age-gate { position:fixed; inset:0; z-index:300; background: rgba(8,7,6,0.78); backdrop-filter: blur(16px); display:flex; align-items:center; justify-content:center; padding: 24px; }
.age-gate.hidden { display:none; }
.age-card { width: min(440px, 100%); padding: 44px 36px; text-align:center; }
.age-logo { font-family:var(--font-serif); font-weight:700; font-size: 38px; margin-bottom: 24px; }
.age-logo span { color: var(--gold-2); }
.age-card h1 { font-family:var(--font-serif); font-weight:600; font-size: 25px; margin-bottom: 12px; }
.age-card p { color: var(--ink-2); font-size: 15px; line-height:1.65; margin-bottom: 28px; }
.age-actions { display:flex; flex-direction:column; gap: 12px; }
.age-fine { font-size: 11.5px !important; color: var(--ink-3) !important; margin: 20px 0 0 !important; }

/* ---------------- Auth ---------------- */
.auth-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; padding: 30px; }
.auth-card { width: min(440px, 100%); padding: 40px 36px; }
.auth-card .brand { justify-content:center; padding-bottom: 8px; }
.auth-card h1 { font-family:var(--font-serif); font-weight:600; font-size: 25px; text-align:center; margin-bottom: 6px; }
.auth-card .sub { text-align:center; color:var(--ink-2); font-size:14px; margin-bottom: 28px; }
.form-row { margin-bottom: 16px; }
.auth-switch { text-align:center; margin-top: 20px; font-size:13.5px; color:var(--ink-2); }
.auth-switch a { color: var(--gold-1); cursor:pointer; font-weight:600; }

/* ---------------- Cart drawer ---------------- */
.drawer-overlay { position:fixed; inset:0; z-index:110; background:rgba(6,5,4,0.58); backdrop-filter:blur(8px); animation: fade .25s var(--ease); }
.drawer { position:fixed; top:0; right:0; height:100vh; width: min(440px,100%); z-index:111; padding: 28px; display:flex; flex-direction:column; border-radius: var(--radius-xl) 0 0 var(--radius-xl); animation: slideIn .35s var(--ease); }
@keyframes slideIn { from{ transform: translateX(44px); opacity:0 } to{ transform:none; opacity:1 } }
.cart-line { display:flex; gap:13px; padding: 15px 0; border-bottom:1px solid var(--glass-stroke-soft); }
.cart-line .thumb { width:54px; height:54px; border-radius:12px; background: var(--glass-2); display:flex; align-items:center; justify-content:center; flex:none; overflow:hidden; }
.cart-line .thumb svg { width:60%; height:60%; }

/* ---------------- Credit toggle ---------------- */
.credit-card { display:flex; align-items:center; justify-content:space-between; gap:14px; padding:15px 18px; border-radius:16px;
  border:1px solid var(--glass-stroke); background: var(--glass); cursor:pointer; transition: all .3s var(--ease); }
.credit-card:hover { background: var(--glass-2); border-color: var(--gold-line); }
.credit-card.on { border-color: transparent; background: linear-gradient(135deg, rgba(214,200,176,0.14), rgba(166,180,166,0.10));
  box-shadow: 0 0 0 1px var(--gold-line), var(--shadow-gold); }
.credit-card .credit-ic { width:42px; height:42px; border-radius:12px; flex:none; display:flex; align-items:center; justify-content:center;
  background: var(--glass-2); color: var(--gold-1); transition: all .3s var(--ease); }
.credit-card.on .credit-ic { background: var(--grad-gold); color:#2a2620; }
.credit-card .credit-ic .ic { width:22px; height:22px; }
.credit-card .ttl { font-family:var(--font-display); font-weight:600; font-size:14.5px; }
.switch { width:52px; height:30px; border-radius:999px; background: var(--glass-2); border:1px solid var(--glass-stroke); position:relative; flex:none; transition: background .3s var(--ease); }
.switch .knob { position:absolute; top:3px; left:3px; width:22px; height:22px; border-radius:50%; background: var(--ink-2); transition: all .3s var(--ease); }
.credit-card.on .switch { background: var(--grad-gold); border-color:transparent; }
.credit-card.on .switch .knob { left:25px; background:#2a2620; }

/* ---------------- Utilities ---------------- */
.row { display:flex; align-items:center; gap: 12px; }
.col { display:flex; flex-direction:column; }
.gap-6{gap:6px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}
.between { justify-content: space-between; }
.wrap { flex-wrap: wrap; }
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.text-r { text-align:right; }
.hr { height:1px; background: var(--glass-stroke-soft); border:none; margin: 16px 0; }
.divider { width:1px; align-self:stretch; background: var(--glass-stroke-soft); }
.pill-num { font-family:var(--font-display); font-weight:700; }
.hide { display:none !important; }
.cost-tag { color: var(--gold-1); }

/* Timeline */
.timeline { display:flex; flex-direction:column; gap:0; }
.tl-step { display:flex; gap:14px; }
.tl-step .tl-dot { width:13px; height:13px; border-radius:50%; border:2px solid var(--glass-stroke); margin-top:3px; flex:none; background: var(--bg-1); }
.tl-step.done .tl-dot { background: var(--ok); border-color: var(--ok); }
.tl-step.current .tl-dot { background: var(--gold-1); border-color: var(--gold-1); box-shadow:0 0 0 4px rgba(214,200,176,0.18); }
.tl-step .tl-line { width:2px; flex:1; background: var(--glass-stroke-soft); margin: 4px 0; min-height: 18px; }
.tl-step:last-child .tl-line { display:none; }
.tl-body { padding-bottom: 18px; }
.tl-body .t { font-weight:600; font-size:14px; }
.tl-body .d { font-size:12px; color:var(--ink-3); }

/* Empty state */
.empty { text-align:center; padding: 64px 20px; color: var(--ink-3); display:flex; flex-direction:column; align-items:center; }
.empty .ic { opacity:.4; margin-bottom: 14px; }
.empty .ic svg { width: 40px; height: 40px; }

/* ---------------- Hero ---------------- */
.hero { padding: 52px 48px; position:relative; overflow:hidden; margin-bottom: 30px; }
.hero::after { content:""; position:absolute; left:48px; bottom:0; width:56px; height:2px; background: var(--grad-gold); opacity:.8; }
.hero h1 { font-weight:600; font-size: clamp(38px, 5.5vw, 68px); letter-spacing:-0.02em; line-height:1.0; max-width: 13ch; }
html[lang="en"] .hero h1 { font-family: var(--font-serif); }
html[lang="th"] .hero h1 { font-family: "Noto Sans Thai", var(--font-display); font-weight:600; letter-spacing:0; }
.hero p { color: var(--ink-2); max-width: 460px; margin-top: 18px; font-size: 15px; line-height:1.7; }
.hero .hero-orb { position:absolute; right:0; top:50%; transform:translateY(-50%); width: 320px; height:320px; opacity:.9; pointer-events:none; }
.hero .hero-orb { opacity:.7; }
.hero .hero-orb svg { filter: grayscale(1) brightness(1.25) drop-shadow(0 20px 60px rgba(0,0,0,0.4)); }

/* ---------------- Responsive ---------------- */
@media (max-width: 1000px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { position:fixed; left:0; top:0; z-index:80; transform: translateX(-100%); transition: transform .35s var(--ease); width: 256px; }
  .sidebar.open { transform:none; }
  .cols-4 { grid-template-columns: repeat(2,1fr); }
  .cols-3 { grid-template-columns: repeat(2,1fr); }
  .content { padding: 22px; }
  .topbar { padding: 14px 18px; }
  .hero { padding: 36px 28px; }
  .hero::after { left:28px; }
  .menu-btn { display:inline-flex !important; }
}
@media (max-width: 620px) {
  .cols-4, .cols-3, .cols-2 { grid-template-columns: 1fr; }
  .demo-dock { left: 12px; right: 12px; bottom: 12px; justify-content:center; }
}
.menu-btn { display:none; }

/* ============================================================
   FUTURISTIC LAYER — monochrome "light + tech" (no colour)
   ambient grid / aurora / scanline · glowing cursor · card bloom
   ============================================================ */

/* ---- ambient tech background (added layers inside .bg-stage) ---- */
.bg-grid {
  position: absolute; inset: -2px; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(244,241,236,0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(244,241,236,0.05) 1px, transparent 1px);
  background-size: 64px 64px;
  -webkit-mask-image: radial-gradient(120% 90% at 50% 0%, #000 12%, transparent 78%);
          mask-image: radial-gradient(120% 90% at 50% 0%, #000 12%, transparent 78%);
  animation: gridDrift 26s linear infinite;
  opacity: .55;
}
@keyframes gridDrift { from { background-position: 0 0, 0 0; } to { background-position: 0 64px, 64px 0; } }

.bg-aurora {
  position: absolute; left: 50%; top: -18%; width: 80vw; height: 70vh;
  transform: translateX(-50%); pointer-events: none; z-index: 0;
  background:
    radial-gradient(50% 50% at 50% 50%, rgba(255,255,255,0.06), transparent 70%),
    radial-gradient(40% 60% at 30% 40%, rgba(244,241,236,0.045), transparent 72%);
  filter: blur(20px);
  animation: auroraFloat 22s var(--ease) infinite;
}
@keyframes auroraFloat {
  0%,100% { transform: translateX(-50%) translateY(0) scale(1); opacity:.8; }
  50%     { transform: translateX(-46%) translateY(3vh) scale(1.12); opacity:1; }
}

.bg-scan {
  position: absolute; left:0; right:0; top:0; height: 180px; z-index:0; pointer-events:none;
  background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.05) 48%, rgba(255,255,255,0.09) 50%, transparent);
  opacity:.5; animation: scanSweep 8.5s linear infinite;
}
@keyframes scanSweep { 0% { transform: translateY(-200px); opacity:0; } 12%,88% { opacity:.5; } 100% { transform: translateY(105vh); opacity:0; } }

/* ---- clean native cursors — premium minimal, zero lag ---- */
a, button, .btn, .chip, .flavor, .nav-item, .lang-toggle button, #demo-dock button,
[onclick], select, summary, label.btn, .close, .qty button, .demo-dock button {
  cursor: pointer;
}
.pcard .pimg { cursor: zoom-in; }
/* disabled / sold-out keep the not-allowed cue */
button:disabled, .btn:disabled, .flavor.out, [disabled] { cursor: not-allowed; }

/* ---- card / glass bloom on hover (white light, no colour) ---- */
.pcard:hover { box-shadow: var(--shadow-pop), 0 0 0 1px rgba(255,255,255,0.06), 0 18px 60px -26px rgba(255,255,255,0.18), inset 0 1px 0 var(--glass-hi); }
.stat { position: relative; overflow: hidden; }
.stat::before {
  content:""; position:absolute; top:-1px; left:14%; width:42%; height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.55), transparent);
  opacity:.7;
}

/* ---- hero: sweeping light sheen + HUD corner brackets ---- */
.hero::before {
  content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
  background: linear-gradient(115deg, transparent 38%, rgba(255,255,255,0.07) 49%, transparent 60%);
  background-size: 280% 100%; animation: heroSheen 9s var(--ease) infinite;
}
@keyframes heroSheen { 0% { background-position: 140% 0; } 60%,100% { background-position: -40% 0; } }
.hero-orb { filter: drop-shadow(0 0 30px rgba(255,255,255,0.12)); animation: orbBob 7s var(--ease) infinite; }
@keyframes orbBob { 0%,100%{ transform: translateY(-50%) translateX(0); } 50%{ transform: translateY(-54%) translateX(-6px); } }

/* live pulse dot next to the eyebrow label */
.eyebrow::after {
  content:""; display:inline-block; width:6px; height:6px; border-radius:50%; margin-left:9px;
  background:#fff; box-shadow:0 0 8px 1px rgba(255,255,255,0.8); vertical-align: middle;
  animation: livePulse 2.4s ease-in-out infinite;
}
@keyframes livePulse { 0%,100%{ opacity:.35; transform: scale(.85);} 50%{ opacity:1; transform: scale(1);} }

/* ============================================================
   ROBOT LUNG — 3D-holographic hero banner (monochrome, breathing)
   ============================================================ */
.hero .hero-lung { width: 380px; height: 380px; right: -26px; opacity: 1;
  filter: drop-shadow(0 0 26px rgba(255,255,255,0.10)); }
.lung-art { width: 100%; height: 100%; overflow: visible; color: var(--ink); }
@media (max-width: 900px) { .hero .hero-lung { opacity: .42; right: -70px; } }

/* breathing in/out */
.lung-art .breathe { transform-box: view-box; transform-origin: 180px 210px;
  animation: lungBreathe 5.2s ease-in-out infinite; }
@keyframes lungBreathe {
  0%,100% { transform: scale(0.965); }
  50%     { transform: scale(1.035); }
}
/* holographic echo pulses counter-phase for depth shimmer */
.lung-art .echo { transform-box: view-box; transform-origin: 180px 210px;
  animation: lungEcho 5.2s ease-in-out infinite; }
@keyframes lungEcho {
  0%,100% { transform: scale(1.0);  opacity: .5; }
  50%     { transform: scale(1.07); opacity: .18; }
}
/* ambient aura breath */
.lung-art .aura { transform-box: view-box; transform-origin: 180px 200px;
  animation: lungAura 5.2s ease-in-out infinite; }
@keyframes lungAura { 0%,100% { opacity: .55; transform: scale(.96); } 50% { opacity: 1; transform: scale(1.06); } }

/* rotating HUD rings */
.lung-art .hud-ring { transform-box: view-box; transform-origin: 180px 200px;
  animation: hudSpin 26s linear infinite; }
.lung-art .hud-ring.rev { animation-duration: 34s; animation-direction: reverse; }
@keyframes hudSpin { to { transform: rotate(360deg); } }

/* glowing alveoli nodes pulse */
.lung-art .node { animation: nodeGlow 2.8s ease-in-out infinite; }
.lung-art .node.n2 { animation-delay: .5s; }
.lung-art .node.n3 { animation-delay: 1s; }
@keyframes nodeGlow { 0%,100% { opacity: .35; } 50% { opacity: 1; } }

/* clean air flowing down the windpipe into the lungs */
.lung-art .air { transform-box: view-box; animation: airDown 2.9s linear infinite; }
.lung-art .air2 { animation-delay: .95s; }
.lung-art .air3 { animation-delay: 1.9s; }
@keyframes airDown {
  0%   { transform: translateY(-8px);  opacity: 0; }
  18%  { opacity: 1; }
  72%  { opacity: .9; }
  100% { transform: translateY(94px);  opacity: 0; }
}

/* ============================================================
   LIGHT THEME — "Harmony" (bright minimal luxe)
   class names preserved; values overridden. Source order wins.
   ============================================================ */
:root {
  --bg-0:#eceae6; --bg-1:#f5f3f0; --bg-2:#ffffff;
  --ink:#18181b; --ink-2:rgba(24,24,27,0.60); --ink-3:rgba(24,24,27,0.40);
  --glass: rgba(255,255,255,0.66); --glass-2: rgba(255,255,255,0.92);
  --glass-stroke: rgba(20,20,25,0.10); --glass-stroke-soft: rgba(20,20,25,0.06); --glass-hi: rgba(255,255,255,0.9);
  --gold-1:#18181b; --gold-2:#56565c; --gold-3:#8c8c92;
  --gold-line: rgba(20,20,25,0.20);
  --grad-gold: linear-gradient(180deg,#26262b 0%,#141417 100%);
  --ok:#3f9d68; --warn:#bd8a2c; --bad:#d05a47; --plat:#5b7fb0; --sage:#7f9a8c;
  --shadow-soft: 0 22px 48px -30px rgba(40,42,55,0.42), 0 4px 14px -10px rgba(40,42,55,0.16);
  --shadow-pop:  0 40px 80px -34px rgba(40,42,55,0.48), 0 10px 26px -16px rgba(40,42,55,0.22);
  --shadow-gold: 0 14px 30px -16px rgba(20,20,30,0.42);
  --radius-xl: 30px; --radius-lg: 24px; --radius-md: 16px; --radius-sm: 11px;
  --blur: 16px;
}
body { background: var(--bg-0); color: var(--ink); }
.bg-stage { background:
  radial-gradient(120% 80% at 50% -8%, #ffffff 0%, #efedea 46%, #e6e3de 100%); }
.bg-grid, .bg-aurora, .bg-scan, .bg-grain { display: none; }

/* glass -> solid white cards with soft light shadow */
.glass { background:#ffffff; backdrop-filter:none; -webkit-backdrop-filter:none;
  border:1px solid var(--glass-stroke-soft); box-shadow: var(--shadow-soft); }
.glass-soft { background:#f5f3f0; backdrop-filter:none; -webkit-backdrop-filter:none;
  border:1px solid var(--glass-stroke-soft); }

/* buttons */
.btn-primary { color:#fff; background: var(--grad-gold); box-shadow: var(--shadow-gold), inset 0 1px 0 rgba(255,255,255,0.12); }
.btn-primary:hover { box-shadow: 0 18px 34px -16px rgba(20,20,30,0.5); }
.btn-ghost { color: var(--ink); background:#ffffff; border-color: var(--glass-stroke); }
.btn-ghost:hover { background:#f3f1ee; border-color: var(--gold-line); }
.btn-dark { color:#fff; background:#18181b; border-color:transparent; }
.btn-dark:hover { background:#000; }

/* chips / badges */
.chip { background:#ffffff; border-color: var(--glass-stroke); color: var(--ink-2); }
.chip:hover { color: var(--ink); border-color: var(--gold-line); }
.chip.active { background:#18181b; color:#fff; border-color:transparent; }
.badge-neutral { background:#eeece8; color: var(--ink-2); }
.badge-credit { color:#fff; }
.badge-credit .dot { background:#fff; }
.avatar { color:#fff; box-shadow: var(--shadow-gold); }
.cart-pill-count { background: rgba(255,255,255,0.22); color:#fff; }
.cart-pill-sep { background: rgba(255,255,255,0.3); }

/* shell chrome */
.sidebar { background:#ffffff; backdrop-filter:none; -webkit-backdrop-filter:none; border-right:1px solid var(--glass-stroke-soft); }
.topbar { background: rgba(255,255,255,0.82); backdrop-filter: saturate(140%) blur(14px); -webkit-backdrop-filter: saturate(140%) blur(14px); border-bottom:1px solid var(--glass-stroke-soft); }
.nav-item:hover { background:#f3f1ee; }
.nav-item.active { background:#f0eeea; border-color: var(--glass-stroke-soft); box-shadow:none; }
.nav-item.active .ic { color: var(--ink); }
.brand .logo span, .age-logo span { color: var(--gold-3); }

/* inputs */
.field { background:#ffffff; border-color: var(--glass-stroke); }
.field:focus { background:#ffffff; border-color: var(--ink); }
.search-box { background:#ffffff; border-color: var(--glass-stroke); }
.search-box:focus-within { background:#ffffff; border-color: var(--ink); }

/* product card */
.pcard .pimg { background: linear-gradient(180deg,#f5f3f0,#e9e6e1); border-bottom:1px solid var(--glass-stroke-soft); }
.zoom-hint { background: rgba(255,255,255,0.85); color: var(--ink); border-color: var(--glass-stroke); }
.pcard:hover { box-shadow: var(--shadow-pop); border-color: var(--glass-stroke); }
.soldout-overlay { background: rgba(245,243,240,0.6); }
.soldout-overlay span { background: rgba(255,255,255,0.85); }
.spec-pill, .flavor, .qty { background:#ffffff; border-color: var(--glass-stroke); }
.flavor:hover:not(:disabled) { background:#f3f1ee; }
.qty button { color: var(--ink); }
.qty button:hover { background:#f0eeea; }

/* tables */
table.tbl tbody tr:hover { background:#faf8f5; }

/* modal / drawer / overlays */
.modal-overlay { background: rgba(28,28,32,0.34); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.drawer-overlay { background: rgba(28,28,32,0.3); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); }
.modal .close { color: var(--ink-3); } .modal .close:hover { color: var(--ink); }

/* age gate */
.age-gate { background: rgba(236,234,230,0.84); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }

/* toast — dark pill pops on light bg */
.toast { background:#18181b; color:#fff; border:1px solid transparent; box-shadow: var(--shadow-pop); }

/* demo dock */
.demo-dock .demo-label { color: var(--gold-3); }
.demo-dock button.active { background:#18181b; color:#fff; }

/* misc accents */
.hero::after { background:#18181b; }
.hero .hero-lung { filter: drop-shadow(0 18px 30px rgba(40,42,55,0.16)); }
.hero h1 { font-weight: 500; }
.eyebrow::after { background:#18181b; box-shadow: 0 0 6px rgba(20,20,25,0.35); }
.stat::before { background: linear-gradient(90deg, transparent, rgba(20,20,25,0.22), transparent); }
.cost-tag { color:#b07d24; }
.auth-switch a { color: var(--ink); }
.switch { background:#e3e0db; border-color: var(--glass-stroke); }
.switch .knob { background:#fff; box-shadow: 0 1px 3px rgba(0,0,0,0.2); }
.credit-card { background:#ffffff; }
.credit-card:hover { background:#faf8f5; }
.credit-card.on { background:#f3f1ec; box-shadow: 0 0 0 1px var(--gold-line); }
.credit-card .credit-ic { background:#f0eeea; color: var(--ink); }
.credit-card.on .credit-ic { color:#fff; }
.credit-card.on .switch { background:#18181b; }
.credit-card.on .switch .knob { background:#fff; }
.tl-step .tl-dot { background:#fff; }
.tl-step.current .tl-dot { background: var(--ink); border-color: var(--ink); box-shadow: 0 0 0 4px rgba(20,20,25,0.12); }

/* ============================================================
   DASHBOARD CHARTS — animated infographics (reports)
   ============================================================ */
.dash-grid { display:grid; gap:18px; grid-template-columns: repeat(12, 1fr); }
.dash-grid > .span-3 { grid-column: span 3; } .dash-grid > .span-4 { grid-column: span 4; }
.dash-grid > .span-6 { grid-column: span 6; } .dash-grid > .span-8 { grid-column: span 8; }
.dash-grid > .span-12 { grid-column: span 12; }
@media (max-width: 1000px){ .dash-grid > [class*="span-"]{ grid-column: span 6; } }
@media (max-width: 620px){ .dash-grid > [class*="span-"]{ grid-column: span 12; } }

.chart-card { padding: 22px 24px; }
.chart-card .ch-title { font-family: var(--font-display); font-weight:600; font-size:14px; letter-spacing:-0.01em; }
.chart-card .ch-sub { font-size:11.5px; color: var(--ink-3); margin-top:2px; }
.kpi .value, .countup { font-variant-numeric: tabular-nums; }
.kpi-ic { width:34px; height:34px; border-radius:10px; background:#f0eeea; display:flex; align-items:center; justify-content:center; color: var(--ink); }
.kpi-ic svg { width:18px; height:18px; }

/* donut / ring */
.donut-wrap { display:flex; align-items:center; gap:20px; }
.donut { position:relative; width:148px; height:148px; flex:none; }
.donut svg { width:100%; height:100%; transform: rotate(-90deg); }
.donut .track { stroke:#ece9e4; }
.donut-seg { stroke-linecap: butt; animation: donutGrow 1.1s var(--ease) both; }
@keyframes donutGrow { from { stroke-dashoffset: var(--hid); } to { stroke-dashoffset: var(--off); } }
.donut-center { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.donut-center .big { font-family: var(--font-serif); font-weight:600; font-size:30px; line-height:1; }
.donut-center .cap { font-size:10px; letter-spacing:.12em; text-transform:uppercase; color: var(--ink-3); margin-top:4px; }
.legend { display:flex; flex-direction:column; gap:11px; }
.legend .lg { display:flex; align-items:center; gap:9px; font-size:12.5px; }
.legend .sw { width:11px; height:11px; border-radius:4px; flex:none; }
.legend b { margin-left:auto; font-family: var(--font-display); font-variant-numeric: tabular-nums; }

/* vertical bars */
.bars { display:flex; align-items:flex-end; gap:14px; height:170px; padding-top:8px; }
.bar-col { flex:1; display:flex; flex-direction:column; align-items:center; gap:8px; height:100%; justify-content:flex-end; min-width:0; }
.bar-track { width:100%; max-width:46px; flex:1; display:flex; align-items:flex-end; }
.bar-fill { width:100%; border-radius:8px 8px 4px 4px; background: linear-gradient(180deg,#3a3a40,#18181b);
  transform-origin: bottom; animation: barGrow .9s var(--ease) both; min-height:3px; }
@keyframes barGrow { from { transform: scaleY(0); } }
.bar-val { font-family: var(--font-display); font-weight:600; font-size:12px; font-variant-numeric:tabular-nums; }
.bar-name { font-size:10.5px; color: var(--ink-3); text-align:center; line-height:1.2; max-width:100%;
  overflow:hidden; text-overflow:ellipsis; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; }

/* proportion bar (ledger flows) */
.flow-row { display:flex; flex-direction:column; gap:7px; margin-bottom:15px; }
.flow-head { display:flex; justify-content:space-between; font-size:12.5px; }
.flow-head .mono { font-variant-numeric: tabular-nums; }
.propbar { height:10px; border-radius:999px; background:#ece9e4; overflow:hidden; }
.propbar-seg { height:100%; border-radius:999px; transform-origin:left; animation: barGrowX 1s var(--ease) both; }
@keyframes barGrowX { from { transform: scaleX(0); } }

/* mini stock-status stacked bar */
.stack { height:14px; border-radius:999px; overflow:hidden; display:flex; background:#ece9e4; }
.stack > span { height:100%; transform-origin:left; animation: barGrowX 1s var(--ease) both; }

.fade-up { animation: fadeUp .5s var(--ease) both; }
.fade-up.d1{animation-delay:.05s}.fade-up.d2{animation-delay:.12s}.fade-up.d3{animation-delay:.19s}.fade-up.d4{animation-delay:.26s}
@keyframes fadeUp { from { opacity:0; transform: translateY(10px); } }

/* ============================================================
   ELEVATE — dramatic hero + bento + big device renders
   ============================================================ */
.bg-stage { background:
  radial-gradient(130% 95% at 50% -12%, #ffffff 0%, #ecebe9 38%, #ddddda 74%, #d3d3d0 100%); }

/* big product renders */
svg.device-art { display:block; overflow:visible; }
.pcard .pimg { aspect-ratio: 1 / 0.94; overflow:hidden; }
.pcard .pimg::before { content:""; position:absolute; width:78%; aspect-ratio:1; border-radius:50%; z-index:0;
  background: radial-gradient(circle, rgba(255,255,255,0.95), rgba(228,231,238,0.45) 45%, transparent 70%); }
.pcard .pimg img.prod-img { position:relative; z-index:1; }
.pcard .pimg svg.device-art { position:relative; z-index:1; width:auto !important; height:90% !important;
  filter: drop-shadow(0 16px 22px rgba(40,46,60,0.22)); transition: transform .5s var(--ease); }
.pcard:hover .pimg svg.device-art { transform: translateY(-7px) scale(1.03); }
.cart-line .thumb svg.device-art { width:auto; height:92%; }
.lightbox-device svg.device-art { width:auto; height:min(60vh, 440px); }

/* hero — ELEVATE layout */
.hero-elevate { position:relative; display:grid; grid-template-columns: 1.05fr 1fr; gap:28px; align-items:center;
  padding: 40px 46px; margin-bottom: 26px; border-radius: var(--radius-xl); overflow:hidden;
  background: linear-gradient(155deg, #ffffff 0%, #f1f0ee 45%, #e4e4e1 100%);
  border:1px solid var(--glass-stroke-soft); box-shadow: var(--shadow-soft); }
.hero-elevate::before { content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(60% 80% at 78% 40%, rgba(255,255,255,0.6), transparent 60%); }
.hero-copy { position:relative; z-index:2; }
.hero-mega { font-family: var(--font-display); font-weight:700; font-size: clamp(40px,6vw,76px);
  line-height:0.92; letter-spacing:-0.03em; text-transform:uppercase; }
html[lang="th"] .hero-mega { font-family:"Noto Sans Thai", var(--font-display); font-weight:700;
  text-transform:none; letter-spacing:-0.01em; line-height:1.02; font-size: clamp(34px,5vw,62px); }
.hero-copy p { color: var(--ink-2); max-width:440px; margin-top:16px; font-size:14.5px; line-height:1.7; }
.hero-tagline { display:inline-flex; align-items:center; gap:8px; margin-top:22px; font-size:12.5px;
  color: var(--ink-2); background:#fff; border:1px solid var(--glass-stroke); padding:8px 15px; border-radius:999px; box-shadow: var(--shadow-soft); }
.hero-tagline svg { width:15px; height:15px; }

.hero-stage { position:relative; min-height:380px; display:flex; align-items:center; justify-content:center; }
.hero-ring { position:absolute; width:min(360px,80%); aspect-ratio:1; border-radius:50%;
  background: radial-gradient(circle, rgba(255,255,255,0.95) 0%, rgba(233,236,242,0.55) 40%, transparent 66%);
  box-shadow: inset 0 0 70px rgba(255,255,255,0.7), 0 36px 90px -34px rgba(60,70,90,0.45);
  animation: ringPulse 6s ease-in-out infinite; }
.hero-ring::after { content:""; position:absolute; inset:7%; border-radius:50%;
  border:1px solid rgba(255,255,255,0.85); box-shadow: 0 0 46px rgba(180,190,210,0.5), inset 0 0 30px rgba(255,255,255,0.5); }
.hero-glowwrap { position:relative; z-index:2; height:382px; display:flex; align-items:flex-end; justify-content:center;
  filter: drop-shadow(0 34px 42px rgba(40,46,60,0.32)); animation: floatY 6s ease-in-out infinite; }
.hero-glowwrap svg.device-art { height:380px; width:auto; }
.hero-glowwrap::after { content:""; position:absolute; bottom:-6px; left:50%; transform:translateX(-50%);
  width:140px; height:22px; background: radial-gradient(ellipse, rgba(40,40,52,0.2), transparent 70%); z-index:-1; }
.hero-chips { position:absolute; right:0; top:50%; transform:translateY(-50%); display:flex; flex-direction:column; gap:11px; z-index:3; }
.hero-stat { display:flex; align-items:center; gap:9px; background: rgba(255,255,255,0.82);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border:1px solid var(--glass-stroke);
  border-radius:14px; padding:8px 13px; box-shadow: var(--shadow-soft); font-size:11.5px; font-weight:500;
  white-space:nowrap; animation: floatY 5s ease-in-out infinite; }
.hero-stat.hs-1 { animation-delay:.5s; } .hero-stat.hs-2 { animation-delay:1s; }
.hero-stat .hs-ic { width:26px; height:26px; border-radius:8px; background:#18181b; color:#fff; display:flex; align-items:center; justify-content:center; flex:none; }
.hero-stat .hs-ic svg { width:14px; height:14px; }
@keyframes floatY { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }
@keyframes ringPulse { 0%,100%{ opacity:.9; transform:scale(1); } 50%{ opacity:1; transform:scale(1.03); } }
@media (max-width: 900px) {
  .hero-elevate { grid-template-columns:1fr; }
  .hero-chips { position:static; transform:none; flex-direction:row; flex-wrap:wrap; justify-content:center; margin-top:16px; }
  .hero-stage { min-height:300px; }
  .hero-glowwrap { height:300px; } .hero-glowwrap svg.device-art { height:300px; }
}

/* bento feature grid */
.bento { display:grid; grid-template-columns: repeat(4,1fr); gap:16px; margin-bottom:30px; }
.bento-big { position:relative; overflow:hidden; grid-column: span 2; grid-row: span 2;
  border-radius: var(--radius-lg); padding:30px; color:#fff; display:flex; flex-direction:column;
  background: linear-gradient(150deg, #2a2c33 0%, #16171b 100%); box-shadow: var(--shadow-pop); min-height:280px; }
.bento-big h3 { font-family: var(--font-display); font-weight:700; font-size:26px; line-height:1.06; margin-top:8px; max-width:11ch; }
.bento-big p { color: rgba(255,255,255,0.6); font-size:13px; margin-top:10px; max-width:30ch; line-height:1.6; }
.bento-big .bento-device { position:absolute; right:-26px; bottom:-34px; width:230px; height:300px; pointer-events:none;
  filter: drop-shadow(0 24px 30px rgba(0,0,0,0.55)); }
.bento-big .bento-device svg.device-art { height:300px; width:auto; }
.bento-cell { padding:22px; display:flex; flex-direction:column; justify-content:flex-end; min-height:128px; }
.bento-ic { width:38px; height:38px; border-radius:11px; background:#f0eeea; color:var(--ink);
  display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.bento-ic svg { width:19px; height:19px; }
.bento-cell .bt { font-family: var(--font-display); font-weight:600; font-size:15px; }
.bento-cell .bs { font-size:12px; color: var(--ink-2); line-height:1.5; margin-top:3px; }
@media (max-width: 900px) { .bento { grid-template-columns: repeat(2,1fr); } .bento-big { grid-column: span 2; grid-row:auto; } }
@media (max-width: 560px) { .bento { grid-template-columns:1fr; } .bento-big { grid-column:span 1; } }

/* ============================================================
   BENTO product cards — horizontal, mobile-first flavor picking
   (image + info on top row, flavors full-width, buy full-width)
   ============================================================ */
/* ABC layout: name/price top-left + compact device top-right, flavor grid below */
.store-grid { grid-template-columns: repeat(auto-fill, minmax(min(100%, 440px), 1fr)); align-items: start; }
.pcard.bento {
  display: grid; padding: 14px; gap: 10px 14px; align-items: start;
  grid-template-columns: minmax(0, 1fr) 138px;
  grid-template-areas:
    "info img"
    "flav flav"
    "buy  buy";
}
/* compact, near-square device — not a tall strip */
.pcard.bento .pimg {
  grid-area: img; align-self: start; aspect-ratio: 1 / 1; height: auto; min-height: 0;
  border-radius: 16px; border: 1px solid var(--glass-stroke-soft);
}
.pcard.bento .pimg svg.device-art { height: 90% !important; }
.pcard.bento .pinfo { grid-area: info; display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.pcard.bento .pinfo .spec-row { margin-top: 2px; }
.pcard.bento .pprice-wrap { text-align: right; flex: none; }
.pcard.bento .pprice { font-size: 21px; }
/* flavors: dense multi-column grid (ABC style) below the header, full names wrap */
.pcard.bento .pflav { grid-area: flav; display: flex; flex-direction: column; gap: 8px;
  padding-top: 10px; border-top: 1px solid var(--glass-stroke-soft); }
.pcard.bento .pflav .flavor-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(114px, 1fr)); gap: 6px; }
.pcard.bento .pflav .flavor { justify-content: space-between; min-width: 0; }
.pcard.bento .pflav .flavor .fnm { white-space: normal; overflow-wrap: anywhere; line-height: 1.2; text-align: left; }
.pcard.bento .pbuy { grid-area: buy; display: flex; flex-direction: column; gap: 9px; margin-top: 2px; }
.pcard.bento .ptag { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.pcard.bento .line-total { border-top: none; padding-top: 0; }
@media (max-width: 480px) {
  .pcard.bento { grid-template-columns: minmax(0, 1fr) 116px; gap: 9px 11px; padding: 11px; }
  .pcard.bento .pflav .flavor-grid { grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); }
  .pcard.bento .ptitle { font-size: 15px; }
  .pcard.bento .pprice { font-size: 19px; }
  .pcard.bento .ptag { display: none; }
}

/* ============================================================
   ADD-TO-CART feedback — confirm motion (single click, clear)
   ============================================================ */
.add-btn.added {
  background: linear-gradient(180deg, #37a86a, #268a52) !important; color: #fff !important;
  box-shadow: 0 12px 26px -12px rgba(38, 138, 82, 0.6) !important;
  animation: addPop .42s var(--ease);
}
@keyframes addPop { 0% { transform: scale(1); } 35% { transform: scale(.93); } 68% { transform: scale(1.05); } 100% { transform: scale(1); } }

.cart-pill.bump { animation: cartBump .5s var(--ease); }
@keyframes cartBump { 0% { transform: scale(1); } 28% { transform: scale(1.13); } 60% { transform: scale(.96); } 100% { transform: scale(1); } }

.fly-dot {
  position: fixed; z-index: 400; width: 30px; height: 30px; margin: -15px 0 0 -15px; border-radius: 50%;
  background: #18181b; color: #fff; display: flex; align-items: center; justify-content: center;
  pointer-events: none; box-shadow: var(--shadow-pop);
  transition: transform .66s cubic-bezier(.45, 0, .2, 1), opacity .66s ease;
}
.fly-dot svg { width: 16px; height: 16px; }

/* accessibility: respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .fly-dot { display: none !important; }
}
