/* ════════════════════════════════════════════════════════════════════════
   pages.css — VOS module styles. ONE markup, TWO visual languages.
   Scoped to .vos-page (= <body>); Daylight = default, Kiosk = [data-theme="dark"].
   Consumes tokens.css (--vos-*) + per-brand --brand / --brand-2.
   Live adaptations from the design canvas:
     · .vos-page drops overflow:hidden (body is the scroll root).
     · .vos-pdp-toast is position:fixed (was absolute in the artboard host).
   ════════════════════════════════════════════════════════════════════════ */

/* ── base ─────────────────────────────────────────────────────────────── */
.vos-page, .vos-page *, .vos-page *::before, .vos-page *::after { box-sizing: border-box; }
.vos-page {
  background: var(--vos-paper);
  color: var(--vos-ink);
  font: 400 var(--vos-fs-body)/var(--vos-lh-body) var(--vos-font-body);
  letter-spacing: var(--vos-tr-body);
  -webkit-font-smoothing: antialiased;
  position: relative;
  margin: 0;
}
.vos-page h1,.vos-page h2,.vos-page h3,.vos-page h4,.vos-page p,.vos-page ul,.vos-page ol { margin: 0; padding: 0; }
.vos-page ul,.vos-page ol { list-style: none; }
.vos-page a { color: inherit; text-decoration: none; }
:where(.vos-page) button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; padding: 0; }
.vos-page img { max-width: 100%; display: block; }
.vos-num { font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; }
.vos-mono { font-family: var(--vos-font-mono); letter-spacing: var(--vos-tr-mono); text-transform: uppercase; }
.vos-wrap { max-width: var(--vos-max-w); margin: 0 auto; padding: 0 var(--vos-pad-x); }
.vos-display { font-family: var(--vos-font-display); letter-spacing: var(--vos-tr-display); font-weight: 700; }
[data-theme="dark"] .vos-display { font-weight: 800; }

/* ── header / chrome ──────────────────────────────────────────────────── */
.vos-hdr {
  position: sticky; top: 0; z-index: var(--vos-z-sticky);
  background: color-mix(in srgb, var(--vos-paper) 88%, transparent);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--vos-hair);
}
.vos-hdr-row { display: flex; align-items: center; gap: var(--vos-s-8); height: 68px; }
.vos-nav { display: flex; gap: var(--vos-s-6); margin-left: var(--vos-s-4); }
.vos-nav a, .vos-nav > .vos-nav-item > button { font-size: 14px; font-weight: 500; color: var(--vos-ink-2); display: inline-flex; align-items: center; gap: 5px; }
.vos-nav a:hover, .vos-nav > .vos-nav-item > button:hover { color: var(--vos-ink); }
.vos-hdr-spacer { flex: 1; }
.vos-hdr-tools { display: flex; align-items: center; gap: var(--vos-s-3); }
.vos-iconbtn { width: 40px; height: 40px; border-radius: var(--vos-r-sm); border: 1px solid var(--vos-hair); display: flex; align-items: center; justify-content: center; color: var(--vos-ink); position: relative; }
.vos-iconbtn:hover { border-color: var(--vos-hair-2); }
.vos-cartbtn { display: flex; align-items: center; gap: 8px; height: 40px; padding: 0 16px; border-radius: var(--vos-r-pill); background: var(--vos-ink); color: var(--vos-paper); font-weight: 600; font-size: 14px; }
.vos-cartbtn .vos-num { font-family: var(--vos-font-display); }

/* age + warning bars */
.vos-topstrip { background: var(--vos-ink); color: var(--vos-paper); font-size: 12px; font-weight: 500; text-align: center; padding: 7px 0; letter-spacing: 0.01em; }
.vos-topstrip .vos-mono { opacity: .7; font-size: 10px; }
.vos-warning { border-top: 1px solid var(--vos-hair); background: var(--vos-paper-deep); color: var(--vos-ink-3); font-size: 11px; letter-spacing: 0.02em; padding: 14px 0; }
.vos-warning b { color: var(--vos-ink-2); }

/* ── footer ───────────────────────────────────────────────────────────── */
.vos-ftr { border-top: 1px solid var(--vos-hair); background: var(--vos-paper); padding: var(--vos-s-16) 0 var(--vos-s-8); }
.vos-ftr-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--vos-s-10); }
.vos-ftr h4 { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--vos-ink-3); font-family: var(--vos-font-mono); margin-bottom: var(--vos-s-4); font-weight: 400; }
.vos-ftr a { display: block; font-size: 14px; color: var(--vos-ink-2); padding: 5px 0; }
.vos-ftr a:hover { color: var(--vos-ink); }
.vos-ftr-bottom { display: flex; align-items: center; gap: 16px; margin-top: var(--vos-s-12); padding-top: var(--vos-s-6); border-top: 1px solid var(--vos-hair); font-size: 12px; color: var(--vos-ink-4); }

/* ── chips / dots / pills ─────────────────────────────────────────────── */
.vos-chip { display: inline-flex; align-items: center; gap: 7px; height: 30px; padding: 0 13px; border-radius: var(--vos-r-pill); border: 1px solid var(--vos-hair); background: var(--vos-glass); font-size: 12.5px; font-weight: 600; color: var(--vos-ink-2); white-space: nowrap; }
.vos-chip .vos-num { color: var(--vos-ink); }
.vos-dot { width: 7px; height: 7px; border-radius: 50%; flex: 0 0 auto; }
.vos-dot-ok { background: var(--vos-signal-ok); box-shadow: 0 0 0 3px color-mix(in srgb, var(--vos-signal-ok) 20%, transparent); }
.vos-dot-no { background: var(--vos-ink-4); }
.vos-chip-brand { border-color: color-mix(in srgb, var(--brand) 40%, transparent); color: var(--brand-ink); background: var(--brand-soft); }

/* ── kicker (Space Mono technical label) ──────────────────────────────── */
.vos-kicker { font-family: var(--vos-font-mono); font-size: 11px; letter-spacing: var(--vos-tr-mono); text-transform: uppercase; color: var(--brand-ink); font-weight: 700; }
.vos-kicker-muted { color: var(--vos-ink-3); font-weight: 400; }

/* ── buttons ──────────────────────────────────────────────────────────── */
.vos-btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; height: 52px; padding: 0 26px; border-radius: var(--vos-r-pill); font-family: var(--vos-font-display); font-weight: 700; font-size: 16px; letter-spacing: -0.01em; transition: transform var(--vos-dur-fast) var(--vos-ease), box-shadow var(--vos-dur-base); }
.vos-btn:hover { transform: translateY(-1px); }
.vos-btn-brand { background: var(--brand); color: #fff; }
[data-theme="dark"] .vos-btn-brand { background: var(--brand-2); color: var(--vos-on-accent); box-shadow: 0 0 0 1px color-mix(in srgb,var(--brand-2) 50%,transparent), 0 10px 30px -10px color-mix(in srgb,var(--brand-2) 70%,transparent); }
.vos-btn-ghost { border: 1px solid var(--vos-hair-2); color: var(--vos-ink); background: var(--vos-glass); }
.vos-btn-dark { background: var(--vos-ink); color: var(--vos-paper); }
.vos-btn[disabled] { opacity: .55; cursor: not-allowed; transform: none; }
/* legacy aliases used by some templates */
.vos-btn-primary { background: var(--brand); color: #fff; }
.vos-btn-red { background: var(--brand); color: #fff; }

/* ── inverted band (full-bleed; flips to the OPPOSITE ground of the page) ─ */
.vos-invert { background: var(--vos-paper); color: var(--vos-ink); }

/* ── logo / wordmark ──────────────────────────────────────────────────── */
.vos-logo { font-family: var(--vos-font-display); font-weight: 800; font-size: 19px; letter-spacing: -0.03em; display: inline-flex; align-items: center; gap: 10px; color: var(--vos-ink); }
.vos-logo svg { flex: 0 0 auto; }
.vos-logo .vos-logo-word { font-weight: 800; color: var(--brand-ink); }

/* ── glass surface ────────────────────────────────────────────────────── */
.vos-glass { background: var(--vos-glass); border: 1px solid var(--vos-glass-edge); border-radius: var(--vos-r-lg); box-shadow: var(--vos-glass-shadow); }

/* ── image placeholder (brand-tinted) ─────────────────────────────────── */
.vos-ph { position: relative; display: flex; align-items: center; justify-content: center; overflow: hidden; border-radius: var(--vos-r-md);
  background:
    repeating-linear-gradient(135deg, color-mix(in srgb,var(--vos-ink) 5%,transparent) 0 1px, transparent 1px 9px),
    var(--brand-tile);
}
[data-theme="dark"] .vos-ph {
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.10) 0 1px, transparent 1px 9px),
    linear-gradient(150deg, color-mix(in srgb,var(--brand-2) 82%, #0A0A0B), color-mix(in srgb,var(--brand-2) 34%, #0A0A0B));
}
.vos-ph img { width: 100%; height: 100%; object-fit: contain; padding: 12%; }
.vos-ph-cap { position: absolute; bottom: 10px; left: 12px; font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--vos-on-tile); opacity: .5; }
[data-theme="dark"] .vos-ph-cap { color: #fff; opacity: .7; }
.vos-ph-silho { width: 34%; height: 74%; border-radius: 40px / 60px; background: color-mix(in srgb, var(--brand) 26%, transparent); border: 1px solid color-mix(in srgb,var(--brand) 35%,transparent); }
[data-theme="dark"] .vos-ph-silho { background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.18); }

/* ════════════════════════════════════════════════════════════════════════
   PDP
   ════════════════════════════════════════════════════════════════════════ */
.vos-pdp-toast { position: fixed; top: 90px; left: 50%; transform: translateX(-50%); z-index: var(--vos-z-toast);
  display: flex; align-items: center; gap: 11px; padding: 13px 20px; border-radius: var(--vos-r-pill);
  background: var(--vos-ink); color: var(--vos-paper); font-weight: 600; font-size: 14px; box-shadow: var(--vos-elev-3); }
.vos-pdp-toast.is-warning { background: var(--vos-signal-warn); color: #fff; }
.vos-pdp-toast.is-error { background: var(--vos-signal-err); color: #fff; }

.vos-pdp-crumb { display: flex; align-items: center; gap: 12px; padding: 22px 0 18px; font-size: 13px; color: var(--vos-ink-3); flex-wrap: wrap; }
.vos-pdp-crumb .vos-mono { font-size: 11px; }
.vos-pdp-crumb a:hover { color: var(--vos-ink); }
.vos-crumb-sep { opacity: .4; }

.vos-pdp-layout { display: grid; grid-template-columns: 1fr 1fr; gap: var(--vos-s-12); align-items: start; padding-bottom: var(--vos-s-16); }
.vos-pdp-gallery { position: sticky; top: 92px; }
.vos-pdp-gallery .vos-ph, .vos-pdp-gallery-main { aspect-ratio: 1/1; border-radius: var(--vos-r-xl); }
[data-theme="dark"] .vos-pdp-gallery .vos-ph { border: 1px solid var(--vos-hair); }
.vos-pdp-gallery-main { background: var(--vos-glass); border: 1px solid var(--vos-glass-edge); overflow: hidden; position: relative; box-shadow: var(--vos-glass-shadow); }
.vos-pdp-gallery-main img { width: 100%; height: 100%; object-fit: contain; padding: 8%; }
.vos-pdp-thumbs { display: flex; gap: 10px; margin-top: 14px; }
.vos-pdp-thumbs .vos-ph { width: 72px; height: 72px; border-radius: var(--vos-r-sm); }
.vos-pdp-thumbs .vos-ph:first-child { outline: 2px solid var(--brand); outline-offset: 2px; }

.vos-pdp-brandkick { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.vos-pdp-h1 { font-family: var(--vos-font-display); font-weight: 700; font-size: var(--vos-fs-h1); line-height: var(--vos-lh-tight); letter-spacing: var(--vos-tr-display); margin-bottom: 16px; }
[data-theme="dark"] .vos-pdp-h1 { font-weight: 800; }
.vos-pdp-lede { font-size: var(--vos-fs-lead); line-height: 1.5; color: var(--vos-ink-2); margin-bottom: 24px; max-width: 30em; }

.vos-pdp-price-row { display: flex; align-items: baseline; gap: 14px; margin-bottom: 26px; }
.vos-pdp-price { font-family: var(--vos-font-display); font-weight: 800; font-size: 40px; letter-spacing: -0.02em; color: var(--brand-ink); }
.vos-pdp-list, .vos-pdp-price-was { font-size: 18px; color: var(--vos-ink-4); text-decoration: line-through; }
.vos-pdp-pertag { font-size: 13px; color: var(--vos-ink-3); margin-left: auto; }

/* 4-stamp specs */
.vos-pdp-specs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 28px; }
.vos-pdp-spec, .vos-spec { position: relative; padding: 16px 16px 15px; border-radius: var(--vos-r-md); background: var(--vos-glass); border: 1px solid var(--vos-glass-edge); overflow: hidden; }
.vos-pdp-spec::before, .vos-spec::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--brand); }
[data-theme="dark"] .vos-pdp-spec::before, [data-theme="dark"] .vos-spec::before { background: var(--brand-2); box-shadow: 0 0 14px var(--brand-2); }
.vos-pdp-spec-n, .vos-spec-n { font-family: var(--vos-font-mono); font-size: 10px; color: var(--vos-ink-4); letter-spacing: .1em; display: block; }
.vos-pdp-spec-l, .vos-spec-k { font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--vos-ink-3); margin-top: 8px; display: block; }
.vos-pdp-spec-v, .vos-spec-v { font-family: var(--vos-font-display); font-weight: 800; font-size: 26px; line-height: 1; letter-spacing: -0.02em; margin-top: 5px; display: block; }
.vos-spec-v small { font-size: 13px; font-weight: 600; color: var(--vos-ink-3); }

/* flavor chips */
.vos-pdp-flavor-label, .vos-fl-label { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; font-family: var(--vos-font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--vos-ink-3); }
.vos-pdp-flavor-selected { color: var(--brand-ink); }
.vos-pdp-flavor-grid { display: flex; flex-wrap: wrap; gap: 9px; margin-bottom: 28px; }
.vos-pdp-flavor-chip { display: inline-flex; align-items: center; gap: 8px; height: 40px; padding: 0 15px; border-radius: var(--vos-r-pill); border: 1px solid var(--vos-hair-2); font-size: 13.5px; font-weight: 600; color: var(--vos-ink-2); background: var(--vos-glass); }
.vos-pdp-flavor-chip[data-sel], .vos-pdp-flavor-chip.is-selected { border-color: var(--brand); color: var(--brand-ink); background: var(--brand-soft); box-shadow: inset 0 0 0 1px var(--brand); }
.vos-pdp-flavor-chip[data-oos], .vos-pdp-flavor-chip.is-oos { color: var(--vos-ink-4); text-decoration: line-through; opacity: .55; cursor: not-allowed; }
.vos-fl-sw { width: 12px; height: 12px; border-radius: 50%; }

/* cta row */
.vos-pdp-cta-row { display: flex; gap: 12px; margin-bottom: 24px; }
.vos-pdp-qty { display: flex; align-items: center; height: 52px; border: 1px solid var(--vos-hair-2); border-radius: var(--vos-r-pill); overflow: hidden; flex: 0 0 auto; }
.vos-pdp-qty button, .vos-pdp-qty-btn { width: 46px; height: 100%; font-size: 18px; color: var(--vos-ink-2); }
.vos-pdp-qty span, .vos-pdp-qty-input { min-width: 40px; width: 44px; text-align: center; font-family: var(--vos-font-display); font-weight: 700; border: 0; background: none; color: var(--vos-ink); -moz-appearance: textfield; }
.vos-pdp-qty-input::-webkit-outer-spin-button, .vos-pdp-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.vos-pdp-add { flex: 1; }

/* multibuy tiers */
.vos-pdp-multibuy { margin-bottom: 24px; }
.vos-pdp-multibuy-h { font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--vos-ink-3); margin-bottom: 10px; }
.vos-pdp-tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.vos-pdp-tier, .vos-tier { position: relative; padding: 15px 14px; border-radius: var(--vos-r-md); border: 1px solid var(--vos-hair-2); background: var(--vos-glass); text-align: left; transition: border-color var(--vos-dur-base); display: block; width: 100%; }
.vos-pdp-tier.is-active, .vos-tier[data-active] { border-color: var(--brand); box-shadow: inset 0 0 0 1px var(--brand); }
.vos-pdp-tier-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.vos-pdp-tier-qty, .vos-tier-q { font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--vos-ink-3); }
.vos-pdp-tier-total, .vos-tier-total { font-family: var(--vos-font-display); font-weight: 800; font-size: 22px; margin-top: 7px; letter-spacing: -0.02em; display: block; }
.vos-pdp-tier-sub, .vos-tier-sub { font-size: 11px; color: var(--vos-ink-3); margin-top: 3px; display: block; }
.vos-pdp-tier-chip, .vos-freeship { display: inline-flex; align-items: center; gap: 5px; margin-top: 9px; height: 22px; padding: 0 9px; border-radius: var(--vos-r-pill); font-family: var(--vos-font-mono); font-size: 9.5px; letter-spacing: .08em; text-transform: uppercase; font-weight: 700; background: color-mix(in srgb,var(--vos-signal-ok) 16%,transparent); color: var(--vos-signal-ok); }

/* trust list */
.vos-pdp-trust { display: grid; grid-template-columns: 1fr 1fr; gap: 11px 18px; padding: 18px 20px; border-radius: var(--vos-r-md); background: var(--vos-paper-deep); margin-bottom: 18px; list-style: none; }
.vos-trust-i, .vos-pdp-trust li { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; line-height: 1.3; color: var(--vos-ink-2); font-weight: 500; }
.vos-trust-i svg { margin-top: 1px; color: var(--brand-ink); flex: 0 0 auto; }

/* xref banner */
.vos-pdp-xref { display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-radius: var(--vos-r-pill); border: 1px dashed color-mix(in srgb,var(--brand) 45%,transparent); color: var(--brand-ink); font-weight: 600; font-size: 14px; }
.vos-pdp-xref svg { margin-left: auto; }
.vos-pdp-xref-label { font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; opacity: .8; margin-right: 4px; }

/* sticky section nav */
.vos-pdp-nav { position: sticky; top: 68px; z-index: var(--vos-z-sticky); border-top: 1px solid var(--vos-hair); border-bottom: 1px solid var(--vos-hair);
  background: color-mix(in srgb, var(--vos-paper) 90%, transparent); backdrop-filter: blur(12px); }
.vos-pdp-nav-inner, .vos-pdp-nav-row { display: flex; align-items: center; gap: 4px; height: 56px; max-width: var(--vos-max-w); margin: 0 auto; padding: 0 var(--vos-pad-x); }
.vos-pdp-nav-links { display: flex; align-items: center; gap: 4px; }
.vos-pdp-nav a { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; border-radius: var(--vos-r-pill); font-size: 13.5px; font-weight: 600; color: var(--vos-ink-3); }
.vos-pdp-nav a span, .vos-pdp-nav-n { font-family: var(--vos-font-mono); font-size: 10px; opacity: .7; }
.vos-pdp-nav a:hover, .vos-pdp-nav a[data-on] { color: var(--vos-ink); background: var(--vos-paper-deep); }
.vos-pdp-nav .vos-jump, .vos-pdp-nav-cta { margin-left: auto; color: var(--brand-ink); }

/* sections / prose / steps */
.vos-pdp-section { padding: var(--vos-s-16) 0; border-top: 1px solid var(--vos-hair); scroll-margin-top: 120px; }
.vos-pdp-section > .vos-wrap > h2, .vos-pdp-section > h2 { font-family: var(--vos-font-display); font-weight: 700; font-size: var(--vos-fs-h2); letter-spacing: -0.02em; margin-bottom: 22px; }
.vos-section-h { font-family: var(--vos-font-display); font-weight: 700; font-size: var(--vos-fs-h2); letter-spacing: -0.02em; margin-bottom: 22px; display: flex; align-items: baseline; gap: 14px; }
.vos-section-h .vos-mono { font-size: 12px; color: var(--vos-ink-4); font-weight: 400; }
.vos-pdp-prose { max-width: var(--vos-max-w-nb); font-size: 17px; line-height: 1.7; color: var(--vos-ink-2); }
.vos-pdp-prose p { margin-bottom: 16px; }
.vos-pdp-prose strong { color: var(--vos-ink); }
.vos-pdp-prose a { color: var(--brand-ink); font-weight: 600; }
.vos-pdp-steps { display: flex; flex-direction: column; gap: 10px; max-width: var(--vos-max-w-nb); counter-reset: step; }
.vos-pdp-steps > li, .vos-step { display: flex; gap: 18px; align-items: flex-start; padding: 20px 22px; border-radius: var(--vos-r-md); background: var(--vos-glass); border: 1px solid var(--vos-glass-edge); }
.vos-pdp-steps > li { counter-increment: step; }
.vos-pdp-steps > li::before { content: "0" counter(step); font-family: var(--vos-font-display); font-weight: 800; font-size: 22px; color: var(--brand-ink); min-width: 34px; }
.vos-step-n { font-family: var(--vos-font-display); font-weight: 800; font-size: 22px; color: var(--brand-ink); min-width: 34px; }
.vos-step b { display: block; margin-bottom: 3px; }
.vos-step p { font-size: 14.5px; color: var(--vos-ink-3); }

/* ── device card (shared PDP/hub) ─────────────────────────────────────── */
.vos-prod-card { display: flex; flex-direction: column; border-radius: var(--vos-r-lg); border: 1px solid var(--vos-hair); background: var(--vos-card); overflow: hidden; transition: transform var(--vos-dur-base) var(--vos-ease), box-shadow var(--vos-dur-base); }
.vos-prod-card:hover { transform: translateY(-3px); box-shadow: var(--vos-elev-2); }
.vos-prod-img, .vos-prod-media { aspect-ratio: 4/3; position: relative; }
.vos-prod-img .vos-ph, .vos-prod-media .vos-ph { width: 100%; height: 100%; border-radius: 0; }
.vos-prod-media { background: var(--vos-glass); }
.vos-prod-media img { width: 100%; height: 100%; object-fit: contain; padding: 14px; }
.vos-oos-badge { position: absolute; top: 12px; left: 12px; font-family: var(--vos-font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; font-weight: 700; padding: 5px 9px; border-radius: var(--vos-r-pill); background: var(--vos-ink); color: var(--vos-paper); z-index: 2; }
.vos-prod-body { padding: 16px 17px 18px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.vos-prod-name, .vos-prod-body h3 { font-family: var(--vos-font-display); font-weight: 700; font-size: 16px; line-height: 1.2; letter-spacing: -0.01em; }
.vos-prod-meta { font-family: var(--vos-font-mono); font-size: 10.5px; letter-spacing: .04em; color: var(--vos-ink-3); text-transform: uppercase; }
.vos-prod-foot { display: flex; align-items: baseline; gap: 9px; margin-top: auto; padding-top: 6px; }
.vos-prod-price { font-family: var(--vos-font-display); font-weight: 800; font-size: 19px; color: var(--brand-ink); }
.vos-prod-list { font-size: 13px; color: var(--vos-ink-4); text-decoration: line-through; }
.vos-prod-stock { margin-left: auto; display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 600; color: var(--vos-ink-3); }
.vos-prod-card[data-oos] { opacity: .72; }
.vos-prod-card[data-oos] .vos-prod-price { color: var(--vos-ink-3); }

.vos-prod-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.vos-prod-grid-3 { grid-template-columns: repeat(3, 1fr); }
.vos-prod-brand { font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; font-weight: 700; color: var(--brand-ink); }

/* ── tables (price / compare) ─────────────────────────────────────────── */
.vos-table { width: 100%; border-collapse: separate; border-spacing: 0; border: 1px solid var(--vos-hair); border-radius: var(--vos-r-md); overflow: hidden; }
.vos-table th { text-align: left; font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--vos-ink-3); font-weight: 400; padding: 14px 16px; background: var(--vos-paper-deep); border-bottom: 1px solid var(--vos-hair); }
.vos-table td { padding: 15px 16px; border-bottom: 1px solid var(--vos-hair); font-size: 14px; color: var(--vos-ink-2); }
.vos-table tr:last-child td { border-bottom: 0; }
.vos-table .vos-td-name { font-weight: 600; color: var(--vos-ink); }
.vos-table .vos-td-name a { color: var(--vos-ink); }
.vos-table .vos-td-price { font-family: var(--vos-font-display); font-weight: 700; color: var(--brand-ink); }

/* ── FAQ ──────────────────────────────────────────────────────────────── */
.vos-faq { max-width: var(--vos-max-w-nb); display: flex; flex-direction: column; }
.vos-faq-item { border-bottom: 1px solid var(--vos-hair); padding: 20px 0; }
.vos-faq-item summary { display: flex; align-items: center; justify-content: space-between; gap: 16px; cursor: pointer; list-style: none; font-family: var(--vos-font-display); font-weight: 700; font-size: 18px; }
.vos-faq-item summary::-webkit-details-marker { display: none; }
.vos-faq-item summary::after { content: "+"; font-family: var(--vos-font-display); font-weight: 400; font-size: 24px; color: var(--brand-ink); }
.vos-faq-item[open] summary::after { content: "\2013"; }
.vos-faq-item p, .vos-faq-item .vos-faq-a { margin-top: 12px; font-size: 15px; line-height: 1.65; color: var(--vos-ink-2); max-width: 62ch; }

/* ════════════════════════════════════════════════════════════════════════
   BRAND HUB
   ════════════════════════════════════════════════════════════════════════ */
.vos-hub-hero { padding: var(--vos-s-16) 0 var(--vos-s-12); position: relative; overflow: hidden; }
[data-theme="dark"] .vos-hub-hero { background: radial-gradient(120% 100% at 0% 0%, color-mix(in srgb,var(--brand-2) 16%, transparent), transparent 60%); }
[data-theme="light"] .vos-hub-hero { background: linear-gradient(180deg, var(--brand-soft), transparent 70%); }
.vos-hub-hero h1 { font-family: var(--vos-font-display); font-weight: 700; font-size: var(--vos-fs-h1-xl); line-height: var(--vos-lh-tight); letter-spacing: -0.03em; margin: 14px 0 18px; max-width: 16ch; }
[data-theme="dark"] .vos-hub-hero h1 { font-weight: 800; }
.vos-hub-hero h1 em { font-style: normal; color: var(--brand-ink); }
.vos-hub-lede { font-size: 20px; line-height: 1.5; color: var(--vos-ink-2); max-width: 52ch; margin-bottom: 24px; }
.vos-hub-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px; }
.vos-hub-jump { display: flex; flex-wrap: wrap; gap: 6px; padding-top: 22px; border-top: 1px solid var(--vos-hair); }
.vos-hub-jump a { padding: 8px 14px; border-radius: var(--vos-r-pill); font-size: 13px; font-weight: 600; color: var(--vos-ink-3); border: 1px solid var(--vos-hair); }
.vos-hub-jump a:hover { color: var(--vos-ink); border-color: var(--vos-hair-2); }
.vos-hub-jump a span { font-family: var(--vos-font-mono); font-size: 10px; opacity: .6; margin-right: 5px; }

.vos-hub-section { padding: var(--vos-s-16) 0; border-top: 1px solid var(--vos-hair); scroll-margin-top: 120px; }
.vos-bigword { position: absolute; font-family: var(--vos-font-display); font-weight: 800; font-size: 240px; line-height: .8; letter-spacing: -0.04em; color: color-mix(in srgb, var(--brand) 10%, transparent); top: -20px; right: -10px; pointer-events: none; user-select: none; white-space: nowrap; }
[data-theme="dark"] .vos-bigword { color: color-mix(in srgb, var(--brand-2) 16%, transparent); }

/* guide if→then rows */
.vos-guide-row { display: grid; grid-template-columns: 1fr auto 1.2fr 1.5fr; gap: 20px; align-items: center; padding: 20px 22px; border-radius: var(--vos-r-md); background: var(--vos-glass); border: 1px solid var(--vos-glass-edge); margin-bottom: 10px; }
.vos-guide-if { font-size: 15px; color: var(--vos-ink-2); }
.vos-guide-if b { color: var(--vos-ink); }
.vos-guide-arr { color: var(--brand-ink); }
.vos-guide-dev { font-family: var(--vos-font-display); font-weight: 700; font-size: 16px; }
.vos-guide-why { font-size: 13.5px; color: var(--vos-ink-3); }

/* ── reviews chips ────────────────────────────────────────────────────── */
.vos-review { padding: 20px 22px; border-radius: var(--vos-r-md); border: 1px solid var(--vos-hair); background: var(--vos-glass); }
.vos-review-stars { color: var(--brand-ink); font-size: 13px; letter-spacing: 2px; }
.vos-review-q { font-size: 15px; line-height: 1.5; color: var(--vos-ink); margin: 10px 0; }
.vos-review-by { font-size: 12px; color: var(--vos-ink-3); display: flex; align-items: center; gap: 8px; }
.vos-verified { color: var(--vos-signal-ok); font-weight: 600; }

/* ════════════════════════════════════════════════════════════════════════
   HOME
   ════════════════════════════════════════════════════════════════════════ */
.vos-home-hero { padding: var(--vos-s-20) 0; }
.vos-home-hero h1 { font-family: var(--vos-font-display); font-weight: 800; font-size: var(--vos-fs-h1-xl); line-height: .98; letter-spacing: -0.035em; max-width: 17ch; margin: 14px 0 22px; }
.vos-home-hero h1 em { font-style: normal; color: var(--brand-ink); }
.vos-home-hero .vos-hub-lede { max-width: 50ch; }
.vos-home-search { display: flex; align-items: center; gap: 12px; max-width: 540px; height: 60px; padding: 0 8px 0 22px; border-radius: var(--vos-r-pill); border: 1px solid var(--vos-hair-2); background: var(--vos-glass); margin: 28px 0 18px; }
.vos-home-search input { flex: 1; border: 0; background: none; font: 500 16px var(--vos-font-body); color: var(--vos-ink); outline: none; }
.vos-home-search input::placeholder { color: var(--vos-ink-3); }
.vos-home-search .vos-btn { height: 44px; }

.vos-home-section { padding: var(--vos-s-16) 0; border-top: 1px solid var(--vos-hair); }
.vos-home-sectop { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 26px; gap: 16px; flex-wrap: wrap; }
.vos-home-sectop h2 { font-family: var(--vos-font-display); font-weight: 700; font-size: var(--vos-fs-h2); letter-spacing: -0.02em; }
.vos-home-sectop a { font-family: var(--vos-font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--brand-ink); display: inline-flex; align-items: center; gap: 6px; }

/* brand wall — the centerpiece */
.vos-brandgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.vos-brandtile { position: relative; border-radius: var(--vos-r-lg); padding: 20px 20px 18px; min-height: 138px; color: #fff; display: flex; flex-direction: column; justify-content: space-between; overflow: hidden; transition: transform var(--vos-dur-base) var(--vos-ease); }
.vos-brandtile:hover { transform: translateY(-3px); }
.vos-brandtile-wm { position: absolute; right: -8px; bottom: -28px; font-family: var(--vos-font-display); font-weight: 900; font-size: 110px; line-height: 1; color: rgba(255,255,255,.16); pointer-events: none; }
.vos-brandtile-arr { align-self: flex-end; opacity: .85; }
.vos-brandtile-name { font-family: var(--vos-font-display); font-weight: 800; font-size: 21px; letter-spacing: -0.02em; line-height: 1.05; position: relative; }
.vos-brandtile-meta { font-family: var(--vos-font-mono); font-size: 10.5px; letter-spacing: .04em; text-transform: uppercase; color: rgba(255,255,255,.82); margin-top: 6px; position: relative; }

/* guides */
.vos-guidegrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.vos-guidecard { padding: 24px; border-radius: var(--vos-r-lg); border: 1px solid var(--vos-hair); background: var(--vos-glass); display: flex; flex-direction: column; gap: 12px; min-height: 168px; transition: border-color var(--vos-dur-base); }
.vos-guidecard:hover { border-color: var(--vos-hair-2); }
.vos-guidecard .vos-mono { font-size: 10px; color: var(--vos-ink-3); }
.vos-guidecard h3 { font-family: var(--vos-font-display); font-weight: 700; font-size: 20px; letter-spacing: -0.01em; }
.vos-guidecard p { font-size: 13.5px; color: var(--vos-ink-3); line-height: 1.5; }
.vos-guidecard .vos-guide-go { margin-top: auto; color: var(--brand-ink); display: inline-flex; align-items: center; gap: 7px; font-weight: 600; font-size: 14px; }

/* home trust band */
.vos-home-trust { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.vos-htrust { display: flex; flex-direction: column; gap: 10px; }
.vos-htrust-i { width: 44px; height: 44px; border-radius: var(--vos-r-md); display: flex; align-items: center; justify-content: center; background: var(--brand-soft); color: var(--brand-ink); border: 1px solid color-mix(in srgb,var(--brand) 30%, transparent); }
.vos-htrust b { font-family: var(--vos-font-display); font-weight: 700; font-size: 17px; }
.vos-htrust p { font-size: 13px; color: var(--vos-ink-3); line-height: 1.45; }

/* ════════════════════════════════════════════════════════════════════════
   PAGE HEADER (shared by utility / static / blog / catalog)
   ════════════════════════════════════════════════════════════════════════ */
.vos-pagehead { padding: var(--vos-s-12) 0; border-bottom: 1px solid var(--vos-hair); }
.vos-pagehead h1 { font-family: var(--vos-font-display); font-weight: 800; font-size: var(--vos-fs-h1); letter-spacing: -0.03em; line-height: 1.02; margin: 12px 0 12px; }
.vos-pagehead h1 em { font-style: normal; color: var(--brand-ink); }
.vos-pagehead p { font-size: 18px; color: var(--vos-ink-2); max-width: 56ch; line-height: 1.5; }
.vos-crumbs { display: flex; gap: 10px; font-size: 12px; color: var(--vos-ink-3); flex-wrap: wrap; }
.vos-crumbs .vos-mono { font-size: 11px; }
.vos-crumbs a { color: var(--vos-ink-3); }
.vos-crumbs a:hover { color: var(--vos-ink); }

/* ── CART ──────────────────────────────────────────────────────────────── */
.vos-cart-layout { display: grid; grid-template-columns: 1fr 380px; gap: var(--vos-s-12); align-items: start; padding: var(--vos-s-12) 0 var(--vos-s-16); }
.vos-cart-line { display: grid; grid-template-columns: 96px 1fr auto; gap: 18px; align-items: center; padding: 20px 0; border-bottom: 1px solid var(--vos-hair); }
.vos-cart-line .vos-ph { width: 96px; height: 96px; border-radius: var(--vos-r-md); }
.vos-cart-line .vos-prod-brand { margin-bottom: 4px; display: block; }
.vos-cart-name { font-family: var(--vos-font-display); font-weight: 700; font-size: 17px; }
.vos-cart-flav { font-size: 13px; color: var(--vos-ink-3); margin-top: 3px; }
.vos-cart-right { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
.vos-cart-price { font-family: var(--vos-font-display); font-weight: 800; font-size: 19px; color: var(--brand-ink); }
.vos-cart-rm { font-size: 12px; color: var(--vos-ink-3); }
.vos-summary { position: sticky; top: 92px; border-radius: var(--vos-r-lg); border: 1px solid var(--vos-hair); background: var(--vos-glass); padding: 26px; }
.vos-summary h3 { font-family: var(--vos-font-display); font-weight: 700; font-size: 20px; margin-bottom: 18px; }
.vos-sum-row { display: flex; justify-content: space-between; font-size: 14px; padding: 9px 0; color: var(--vos-ink-2); }
.vos-sum-row.vos-sum-total { border-top: 1px solid var(--vos-hair); margin-top: 8px; padding-top: 16px; font-family: var(--vos-font-display); font-weight: 800; font-size: 22px; color: var(--vos-ink); }

/* ── CHECKOUT ──────────────────────────────────────────────────────────── */
.vos-co-layout { display: grid; grid-template-columns: 1fr 380px; gap: var(--vos-s-12); align-items: start; padding: var(--vos-s-12) 0 var(--vos-s-16); }
.vos-co-step { border: 1px solid var(--vos-hair); border-radius: var(--vos-r-lg); background: var(--vos-glass); padding: 26px; margin-bottom: 16px; }
.vos-co-step-h { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.vos-co-step-n { width: 28px; height: 28px; border-radius: 50%; background: var(--brand); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--vos-font-display); font-weight: 800; font-size: 14px; flex: 0 0 auto; }
[data-theme="dark"] .vos-co-step-n { background: var(--brand-2); color: var(--vos-on-accent); }
.vos-co-step-h h3 { font-family: var(--vos-font-display); font-weight: 700; font-size: 19px; }
.vos-fieldgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.vos-field { display: flex; flex-direction: column; gap: 6px; }
.vos-field.vos-field-full { grid-column: 1 / -1; }
.vos-field label { font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--vos-ink-3); }
.vos-input { height: 48px; border-radius: var(--vos-r-sm); border: 1px solid var(--vos-hair-2); background: var(--vos-paper); padding: 0 14px; font: 500 15px var(--vos-font-body); color: var(--vos-ink); display: flex; align-items: center; width: 100%; }
.vos-input.vos-input-ph { color: var(--vos-ink-4); }
.vos-co-secure { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; color: var(--vos-ink-3); margin-top: 14px; }
.vos-authnet { font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--vos-ink-3); border: 1px solid var(--vos-hair); border-radius: var(--vos-r-pill); padding: 5px 10px; }
.vos-age-confirm { display: flex; gap: 12px; align-items: flex-start; padding: 16px; border-radius: var(--vos-r-md); background: var(--brand-soft); border: 1px solid color-mix(in srgb,var(--brand) 28%,transparent); }
.vos-checkbox { width: 22px; height: 22px; border-radius: 6px; border: 2px solid var(--brand); flex: 0 0 auto; display: flex; align-items: center; justify-content: center; color: var(--brand-ink); }

/* ── ACCOUNT ───────────────────────────────────────────────────────────── */
.vos-acct-layout { display: grid; grid-template-columns: 240px 1fr; gap: var(--vos-s-10); align-items: start; padding: var(--vos-s-12) 0 var(--vos-s-16); }
.vos-acct-nav { display: flex; flex-direction: column; gap: 2px; position: sticky; top: 92px; }
.vos-acct-nav a { padding: 11px 14px; border-radius: var(--vos-r-sm); font-size: 14px; font-weight: 600; color: var(--vos-ink-3); }
.vos-acct-nav a[data-on] { background: var(--vos-paper-deep); color: var(--vos-ink); }
.vos-acct-nav a[data-on]::before { content: ""; display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--brand); margin-right: 8px; vertical-align: middle; }
.vos-order { border: 1px solid var(--vos-hair); border-radius: var(--vos-r-lg); overflow: hidden; margin-bottom: 14px; }
.vos-order-h { display: flex; align-items: center; gap: 18px; padding: 16px 20px; background: var(--vos-paper-deep); border-bottom: 1px solid var(--vos-hair); font-size: 13px; }
.vos-order-h b { font-family: var(--vos-font-display); }
.vos-order-status { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; font-weight: 600; }
.vos-order-body { display: flex; gap: 14px; padding: 18px 20px; align-items: center; }
.vos-order-body .vos-ph { width: 56px; height: 56px; border-radius: var(--vos-r-sm); flex: 0 0 auto; }

/* ── ORDER TRACKING (timeline) ─────────────────────────────────────────── */
.vos-track-layout { display: grid; grid-template-columns: 1fr 360px; gap: var(--vos-s-12); align-items: start; padding: var(--vos-s-12) 0 var(--vos-s-16); }
.vos-timeline { position: relative; padding-left: 34px; }
.vos-timeline::before { content: ""; position: absolute; left: 11px; top: 8px; bottom: 8px; width: 2px; background: var(--vos-hair); }
.vos-tstep { position: relative; padding: 0 0 28px; }
.vos-tstep::before { content: ""; position: absolute; left: -28px; top: 2px; width: 24px; height: 24px; border-radius: 50%; border: 2px solid var(--vos-hair); background: var(--vos-paper); }
.vos-tstep[data-done]::before { border-color: var(--brand); background: var(--brand); box-shadow: 0 0 0 4px var(--brand-soft); }
.vos-tstep[data-now]::before { border-color: var(--brand); background: var(--vos-paper); }
.vos-tstep b { font-family: var(--vos-font-display); font-weight: 700; font-size: 16px; }
.vos-tstep[data-pending] { opacity: .5; }
.vos-tstep p { font-size: 13px; color: var(--vos-ink-3); margin-top: 2px; }
.vos-tstep .vos-mono { font-size: 10px; color: var(--vos-ink-4); }

/* ── DOC / LEGAL / ARTICLE (TOC sidebar + prose) ───────────────────────── */
.vos-doc-layout { display: grid; grid-template-columns: 220px 1fr; gap: var(--vos-s-12); align-items: start; padding: var(--vos-s-12) 0 var(--vos-s-16); }
.vos-toc { position: sticky; top: 92px; display: flex; flex-direction: column; gap: 3px; }
.vos-toc-h { font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--vos-ink-3); margin-bottom: 10px; }
.vos-toc a { padding: 7px 12px; border-radius: var(--vos-r-sm); font-size: 13.5px; color: var(--vos-ink-3); border-left: 2px solid transparent; }
.vos-toc a[data-on], .vos-toc a:hover { color: var(--vos-ink); border-left-color: var(--brand); background: var(--vos-paper-deep); }
.vos-doc-body { max-width: 64ch; }
.vos-doc-body h2 { font-family: var(--vos-font-display); font-weight: 700; font-size: 26px; letter-spacing: -0.02em; margin: 40px 0 14px; }
.vos-doc-body h2:first-child { margin-top: 0; }
.vos-doc-body h3 { font-family: var(--vos-font-display); font-weight: 700; font-size: 19px; margin: 26px 0 10px; }
.vos-doc-body p { font-size: 16.5px; line-height: 1.7; color: var(--vos-ink-2); margin-bottom: 16px; }
.vos-doc-body ul { margin: 0 0 18px; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.vos-doc-body li { position: relative; padding-left: 22px; font-size: 16px; line-height: 1.6; color: var(--vos-ink-2); }
.vos-doc-body li::before { content: ""; position: absolute; left: 4px; top: 11px; width: 6px; height: 6px; border-radius: 50%; background: var(--brand); }
.vos-doc-body strong { color: var(--vos-ink); }
.vos-doc-body a { color: var(--brand-ink); font-weight: 600; }
.vos-article-meta { display: flex; align-items: center; gap: 14px; font-size: 13px; color: var(--vos-ink-3); margin-top: 14px; flex-wrap: wrap; }
.vos-article-hero { aspect-ratio: 21/8; border-radius: var(--vos-r-lg); margin: 8px 0 0; }

/* ── CONTACT ───────────────────────────────────────────────────────────── */
.vos-contact-layout { display: grid; grid-template-columns: 1fr 380px; gap: var(--vos-s-12); align-items: start; padding: var(--vos-s-12) 0 var(--vos-s-16); }
.vos-contact-card { border: 1px solid var(--vos-hair); border-radius: var(--vos-r-lg); background: var(--vos-glass); padding: 24px; margin-bottom: 14px; }
.vos-contact-card .vos-mono { font-size: 10px; color: var(--vos-ink-3); }
.vos-contact-card b { font-family: var(--vos-font-display); font-weight: 700; font-size: 17px; display: block; margin: 6px 0 4px; }
.vos-contact-card p { font-size: 14px; color: var(--vos-ink-3); }

/* ── BLOG ──────────────────────────────────────────────────────────────── */
.vos-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.vos-blogcard { border-radius: var(--vos-r-lg); border: 1px solid var(--vos-hair); overflow: hidden; background: var(--vos-card); display: flex; flex-direction: column; transition: transform var(--vos-dur-base) var(--vos-ease); }
.vos-blogcard:hover { transform: translateY(-3px); }
.vos-blogcard .vos-ph { aspect-ratio: 16/10; border-radius: 0; }
.vos-blogcard-body { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.vos-blogcard .vos-mono { font-size: 10px; color: var(--brand-ink); font-weight: 700; }
.vos-blogcard h3 { font-family: var(--vos-font-display); font-weight: 700; font-size: 19px; line-height: 1.18; letter-spacing: -0.01em; }
.vos-blogcard p { font-size: 13.5px; color: var(--vos-ink-3); line-height: 1.5; }
.vos-blogcard .vos-blog-foot { margin-top: auto; padding-top: 6px; font-size: 12px; color: var(--vos-ink-4); }
.vos-blog-feature { display: grid; grid-template-columns: 1.2fr 1fr; gap: 0; border-radius: var(--vos-r-xl); overflow: hidden; border: 1px solid var(--vos-hair); margin-bottom: 28px; }
.vos-blog-feature .vos-ph { border-radius: 0; min-height: 320px; }
.vos-blog-feature-body { padding: 40px; display: flex; flex-direction: column; justify-content: center; gap: 14px; }
.vos-blog-feature-body h2 { font-family: var(--vos-font-display); font-weight: 800; font-size: 34px; letter-spacing: -0.02em; line-height: 1.08; }

/* ── FLAVOR HUB ────────────────────────────────────────────────────────── */
.vos-flavorgrid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.vos-flavorcard { border-radius: var(--vos-r-md); border: 1px solid var(--vos-hair); overflow: hidden; background: var(--vos-card); display: block; transition: transform var(--vos-dur-base) var(--vos-ease); }
.vos-flavorcard:hover { transform: translateY(-3px); box-shadow: var(--vos-elev-2); }
.vos-flavorcard .vos-fl-chip-img { height: 96px; position: relative; }
.vos-flavorcard-body { padding: 12px 13px 13px; }
.vos-flavorcard b { font-family: var(--vos-font-display); font-weight: 700; font-size: 13.5px; line-height: 1.15; display: block; }
.vos-flavorcard .vos-prod-meta { margin-top: 5px; }
.vos-flavorcard[data-oos] { opacity: .55; }
.vos-fl-filterbar { display: flex; flex-wrap: wrap; gap: 8px; padding: var(--vos-s-8) 0; }

/* ── BEST / RANKED ─────────────────────────────────────────────────────── */
.vos-rank-row { display: grid; grid-template-columns: 56px 120px 1fr auto; gap: 22px; align-items: center; padding: 20px 22px; border: 1px solid var(--vos-hair); border-radius: var(--vos-r-lg); background: var(--vos-card); margin-bottom: 12px; }
.vos-rank-n { font-family: var(--vos-font-display); font-weight: 900; font-size: 38px; letter-spacing: -0.03em; color: var(--brand-ink); line-height: 1; }
.vos-rank-row .vos-ph { width: 120px; height: 90px; border-radius: var(--vos-r-sm); }
.vos-rank-name { font-family: var(--vos-font-display); font-weight: 700; font-size: 19px; }
.vos-rank-why { font-size: 13.5px; color: var(--vos-ink-3); margin-top: 4px; max-width: 52ch; }
.vos-rank-right { text-align: right; }
.vos-rank-price { font-family: var(--vos-font-display); font-weight: 800; font-size: 20px; color: var(--brand-ink); }

/* ── empty / 404 ──────────────────────────────────────────────────────── */
.vos-empty { text-align: center; max-width: 320px; margin: 80px auto; }
.vos-empty-code { font-family: var(--vos-font-display); font-weight: 900; font-size: 64px; letter-spacing: -0.03em; color: var(--brand-ink); line-height: 1; }
.vos-empty h3 { font-family: var(--vos-font-display); font-weight: 700; font-size: 20px; margin: 10px 0 6px; }
.vos-empty p { font-size: 13px; color: var(--vos-ink-3); margin-bottom: 16px; line-height: 1.5; }

/* ════════════════════════════════════════════════════════════════════════
   RESPONSIVE — real viewport media queries (live site, not artboard classes)
   ════════════════════════════════════════════════════════════════════════ */
@media (max-width: 960px) {
  :root { --vos-fs-h1-xl: 48px; --vos-fs-h1: 38px; --vos-fs-h2: 27px; --vos-pad-x: 20px; }
  .vos-pdp-layout { grid-template-columns: 1fr; gap: 28px; }
  .vos-pdp-gallery { position: static; }
  .vos-cart-layout, .vos-co-layout, .vos-track-layout, .vos-acct-layout,
  .vos-doc-layout, .vos-contact-layout { grid-template-columns: 1fr; }
  .vos-acct-nav, .vos-toc, .vos-summary { position: static; }
  .vos-acct-nav, .vos-toc { flex-direction: row; flex-wrap: wrap; }
  .vos-prod-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .vos-prod-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .vos-brandgrid { grid-template-columns: repeat(2, 1fr); }
  .vos-guidegrid { grid-template-columns: 1fr; }
  .vos-home-trust { grid-template-columns: repeat(2, 1fr); }
  .vos-blog-grid { grid-template-columns: 1fr 1fr; }
  .vos-flavorgrid { grid-template-columns: repeat(3, 1fr); }
  .vos-blog-feature { grid-template-columns: 1fr; }
  .vos-guide-row { grid-template-columns: 1fr; gap: 8px; }
  .vos-guide-arr { display: none; }
  .vos-ftr-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .vos-nav { display: none; }
  .vos-rank-row { grid-template-columns: 44px 1fr; row-gap: 10px; }
  .vos-rank-row .vos-ph, .vos-rank-right { display: none; }
  .vos-bigword { font-size: 120px; }
  /* table → card reflow */
  .vos-table, .vos-table tbody, .vos-table tr, .vos-table td { display: block; }
  .vos-table { border: 0; }
  .vos-table thead { display: none; }
  .vos-table tr { border: 1px solid var(--vos-hair); border-radius: var(--vos-r-md); padding: 14px 16px; margin-bottom: 10px; }
  .vos-table td { display: flex; justify-content: space-between; align-items: center; border: 0; padding: 4px 0; font-size: 13.5px; text-align: left !important; }
  .vos-table td.vos-td-name { font-family: var(--vos-font-display); font-weight: 700; font-size: 15px; padding-bottom: 8px; border-bottom: 1px solid var(--vos-hair); margin-bottom: 6px; }
  .vos-table td[data-label]::before { content: attr(data-label); font-family: var(--vos-font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--vos-ink-3); }
}
@media (max-width: 560px) {
  .vos-prod-grid, .vos-prod-grid-3, .vos-brandgrid, .vos-flavorgrid, .vos-home-trust { grid-template-columns: 1fr 1fr; }
  .vos-blog-grid { grid-template-columns: 1fr; }
  .vos-pdp-specs { grid-template-columns: 1fr 1fr; }
  .vos-pdp-tiers { grid-template-columns: 1fr; }
  .vos-ftr-grid { grid-template-columns: 1fr; }
}
