/* =========================================================================
   VINNOX — Foundations + page styles
   Tokens (palette, type, spacing) followed by the one-pager layout and the
   webshop drawer.
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Cormorant+Garamond:wght@300;400;500;600&display=swap');

:root {
  --vinnox-olive:       #859D3F;
  --vinnox-olive-ink:   #6E8434;
  --vinnox-olive-soft:  #EFF2E3;

  --vinnox-white:       #FFFFFF;
  --vinnox-bone:        #FAFAF8;
  --vinnox-mist:        #F2F2F0;

  --vinnox-silver:      #A6A6A6;
  --vinnox-steel:       #737373;
  --vinnox-graphite:    #2A2A2A;
  --vinnox-shadow:      #1A1A1A;

  --fg-1: var(--vinnox-graphite);
  --fg-2: var(--vinnox-steel);
  --fg-3: var(--vinnox-silver);
  --fg-on-dark: var(--vinnox-white);
  --fg-brand: var(--vinnox-olive);

  --bg-page:   var(--vinnox-bone);
  --bg-card:   var(--vinnox-white);
  --bg-muted:  var(--vinnox-mist);
  --bg-tint:   var(--vinnox-olive-soft);
  --bg-dark:   var(--vinnox-shadow);

  --line-hair: rgba(0,0,0,.08);
  --line-soft: rgba(0,0,0,.14);
  --line-on-dark: rgba(255,255,255,.14);

  --font-display: 'Cormorant Garamond', 'Times New Roman', serif;
  --font-sans:    'Inter', system-ui, -apple-system, 'Helvetica Neue', Arial, sans-serif;
  --font-mono:    ui-monospace, 'SF Mono', Menlo, Consolas, monospace;

  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 16px;
  --r-pill: 999px;

  --shadow-1: 0 1px 2px rgba(0,0,0,.04), 0 1px 1px rgba(0,0,0,.03);
  --shadow-2: 0 4px 16px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-3: 0 16px 48px rgba(0,0,0,.10), 0 2px 6px rgba(0,0,0,.05);

  --ease-out: cubic-bezier(.2,.7,.2,1);
  --dur-fast: 140ms;
  --dur-base: 240ms;
  --dur-slow: 480ms;
}

/* ---------- Page reset ---------- */
html, body { margin:0; padding:0; background:var(--bg-page); color:var(--fg-1); font-family:var(--font-sans); scroll-behavior:smooth; }
* { box-sizing:border-box; }
img { max-width:100%; display:block; }
.container { max-width:1200px; margin:0 auto; padding:0 clamp(24px,5vw,64px); }

/* ---------- Nav ---------- */
.nav { position:sticky; top:0; z-index:50; background:rgba(250,250,248,.82); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--line-hair); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:72px; }
.brand { display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--fg-1); }
.brand img { height:28px; width:28px; }
.brand .wm { font-size:14px; font-weight:500; letter-spacing:.22em; }
.nav-links { display:flex; gap:36px; }
.nav-links a { font-size:12px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--fg-2); text-decoration:none; transition:color var(--dur-base) var(--ease-out); }
.nav-links a:hover { color:var(--fg-1); }
.nav-cta { display:flex; align-items:center; gap:16px; }
.nav-cta .price { font-size:13px; color:var(--fg-2); font-variant-numeric:tabular-nums; }
.pill-btn { display:inline-flex; align-items:center; justify-content:center; height:40px; padding:0 20px; border-radius:999px; font-size:11px; font-weight:500; letter-spacing:.16em; text-transform:uppercase; text-decoration:none; border:1px solid transparent; cursor:pointer; transition:all var(--dur-base) var(--ease-out); font-family:var(--font-sans); }
.pill-btn.primary { background:var(--vinnox-olive); color:#fff; }
.pill-btn.primary:hover { background:var(--vinnox-olive-ink); }
.pill-btn.primary:disabled { background:var(--vinnox-silver); cursor:not-allowed; }
.pill-btn.dark { background:var(--vinnox-graphite); color:#fff; }
.pill-btn.dark:hover { background:#000; }
.pill-btn.ghost { background:transparent; color:var(--fg-1); border-color:var(--line-soft); }
.pill-btn.ghost:hover { border-color:var(--fg-1); }
.pill-btn.lg { height:52px; padding:0 28px; font-size:12px; }

@media (max-width:900px) { .nav-links { display:none; } }

/* ---------- Hero ---------- */
.hero { padding:clamp(56px,9vh,120px) 0 clamp(56px,9vh,96px); position:relative; }
.hero-grid { display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,6vw,96px); align-items:center; }
.hero .eyebrow { font-size:11px; font-weight:500; letter-spacing:.24em; text-transform:uppercase; color:var(--vinnox-olive); margin-bottom:28px; display:inline-flex; align-items:center; gap:14px; }
.hero .eyebrow::before { content:""; width:32px; height:1px; background:var(--vinnox-olive); }
.hero h1 { font-family:var(--font-display); font-weight:400; font-size:clamp(48px,6.4vw,92px); line-height:1.04; letter-spacing:-.018em; margin:0 0 40px; text-wrap:balance; color:var(--fg-1); }
.hero h1 em { font-style:italic; color:var(--vinnox-olive); }
.hero p.lead { font-size:18px; line-height:1.6; color:var(--fg-2); max-width:46ch; margin:0 0 40px; }
.hero-cta { display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.hero-meta { display:flex; gap:24px; margin-top:48px; padding-top:24px; border-top:1px solid var(--line-hair); }
.hero-meta .m { display:flex; flex-direction:column; gap:4px; }
.hero-meta .m .l { font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--fg-3); }
.hero-meta .m .v { font-size:14px; color:var(--fg-1); font-weight:500; }
.hero-img { aspect-ratio:3/4; background:url(assets/product-pool.png) center/cover no-repeat; border-radius:2px; box-shadow:var(--shadow-3); }

@media (max-width:900px) { .hero-grid { grid-template-columns:1fr; } .hero-img { aspect-ratio:4/3; } }

/* ---------- Section header ---------- */
.section { padding:clamp(64px,10vh,128px) 0; }
.section-head { display:flex; flex-direction:column; gap:18px; margin-bottom:64px; max-width:760px; }
.section-head .eyebrow { font-size:11px; font-weight:500; letter-spacing:.24em; text-transform:uppercase; color:var(--vinnox-olive); }
.section-head h2 { font-family:var(--font-display); font-weight:400; font-size:clamp(34px,4.2vw,60px); line-height:1.04; letter-spacing:-.012em; margin:0; text-wrap:balance; }
.section-head .sub { font-size:18px; line-height:1.6; color:var(--fg-2); max-width:56ch; }

/* ---------- Intro band ---------- */
.intro { background:var(--bg-card); border-top:1px solid var(--line-hair); border-bottom:1px solid var(--line-hair); }
.intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,96px); align-items:center; }
.intro-img { aspect-ratio:4/5; background:url(assets/product-detail-bw.jpg) center/cover no-repeat; filter:grayscale(.1); }
.intro .eyebrow { font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--vinnox-olive); font-weight:500; }
.intro h2 { font-family:var(--font-display); font-weight:400; font-size:clamp(34px,4.2vw,56px); line-height:1.05; letter-spacing:-.012em; margin:18px 0 28px; }
.intro p { font-size:18px; line-height:1.7; color:var(--fg-2); margin:0 0 20px; }
.intro p:first-of-type { font-size:22px; line-height:1.55; color:var(--fg-1); }
.intro .feature-list { margin-top:32px; padding-top:24px; border-top:1px solid var(--line-hair); display:flex; flex-direction:column; gap:14px; }
.intro .feature-list .f { display:flex; gap:18px; align-items:flex-start; }
.intro .feature-list .f .num { font-family:var(--font-mono); font-size:11px; color:var(--vinnox-olive); min-width:28px; padding-top:3px; }
.intro .feature-list .f .t { font-size:15px; color:var(--fg-1); line-height:1.5; }

@media (max-width:900px) { .intro-grid { grid-template-columns:1fr; } }

/* ---------- Why grid ---------- */
.why-grid { display:grid; grid-template-columns:repeat(5,1fr); background:var(--bg-card); border:1px solid var(--line-hair); border-radius:2px; }
.why-cell { padding:36px 28px 40px; border-right:1px solid var(--line-hair); display:flex; flex-direction:column; gap:14px; min-height:280px; }
.why-cell:last-child { border-right:none; }
.why-cell .num { font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:var(--vinnox-olive); }
.why-cell h3 { font-family:var(--font-display); font-weight:400; font-size:24px; line-height:1.12; margin:0; color:var(--fg-1); text-wrap:balance; }
.why-cell p { font-size:14px; line-height:1.6; color:var(--fg-2); margin:0; margin-top:auto; }

@media (max-width:1080px) {
  .why-grid { grid-template-columns:repeat(2,1fr); }
  .why-cell { border-right:1px solid var(--line-hair); border-bottom:1px solid var(--line-hair); }
  .why-cell:nth-child(2n) { border-right:none; }
  .why-cell:nth-last-child(-n+1) { border-bottom:none; }
}
@media (max-width:560px) { .why-grid { grid-template-columns:1fr; } .why-cell { border-right:none !important; } }

/* ---------- For who ---------- */
.who { background:var(--bg-tint); }
.who-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(40px,6vw,96px); align-items:center; }
.who-img { aspect-ratio:4/5; background:url(assets/product-piper.png) center/cover no-repeat; border-radius:2px; }
.who .eyebrow { font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--vinnox-olive); font-weight:500; }
.who h2 { font-family:var(--font-display); font-weight:400; font-size:clamp(34px,4.2vw,60px); line-height:1.04; letter-spacing:-.012em; margin:18px 0 12px; }
.who p { font-size:17px; line-height:1.6; color:var(--fg-2); margin:0; max-width:38ch; }
.who-list { list-style:none; padding:0; margin:32px 0 0; display:flex; flex-direction:column; gap:0; border-top:1px solid rgba(0,0,0,.08); }
.who-list li { font-family:var(--font-display); font-weight:400; font-size:clamp(24px,2.6vw,34px); line-height:1.2; color:var(--fg-1); padding:18px 0; border-bottom:1px solid rgba(0,0,0,.08); display:flex; justify-content:space-between; align-items:baseline; }
.who-list li .idx { font-family:var(--font-sans); font-size:11px; color:var(--vinnox-olive); letter-spacing:.04em; }

@media (max-width:900px) { .who-grid { grid-template-columns:1fr; } }

/* ---------- Buy ---------- */
.buy { background:var(--bg-card); border-top:1px solid var(--line-hair); border-bottom:1px solid var(--line-hair); }
.buy-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(40px,6vw,96px); align-items:stretch; }
.buy-img { background:url(assets/product-pouring.jpg) center/cover no-repeat; border-radius:2px; min-height:560px; }
.buy-panel { padding:clamp(24px,3vw,40px) 0; display:flex; flex-direction:column; justify-content:center; }
.buy-panel .eyebrow { font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--vinnox-olive); font-weight:500; margin-bottom:18px; }
.buy-panel h2 { font-family:var(--font-display); font-weight:400; font-size:48px; line-height:1.04; letter-spacing:-.012em; margin:0 0 16px; }
.buy-panel .desc { font-size:17px; line-height:1.6; color:var(--fg-2); margin:0 0 28px; }
.price-row { display:flex; align-items:baseline; gap:14px; padding:20px 0; border-top:1px solid var(--line-hair); border-bottom:1px solid var(--line-hair); }
.price-row .p { font-family:var(--font-display); font-weight:400; font-size:56px; line-height:1; color:var(--fg-1); }
.price-row .note { font-size:13px; color:var(--fg-2); }
.buy-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:32px; padding:28px 0; border-bottom:1px solid var(--line-hair); }
.buy-grid-2 .h { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--fg-3); margin-bottom:12px; }
.buy-grid-2 ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.buy-grid-2 li { font-size:14px; line-height:1.5; color:var(--fg-1); display:flex; gap:10px; align-items:flex-start; }
.buy-grid-2 li::before { content:"·"; color:var(--vinnox-olive); font-weight:700; margin-top:-1px; }
.buy-cta { display:flex; gap:12px; flex-wrap:wrap; margin-top:28px; }

@media (max-width:900px) { .buy-grid { grid-template-columns:1fr; } .buy-img { min-height:380px; } }

/* ---------- Mission ---------- */
.mission { background:var(--bg-dark); color:#fff; padding:clamp(80px,12vh,160px) 0; position:relative; overflow:hidden; }
.mission .container { position:relative; z-index:1; }
.mission .eyebrow { font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--vinnox-olive); margin-bottom:32px; display:inline-flex; gap:14px; align-items:center; }
.mission .eyebrow::before { content:""; width:32px; height:1px; background:var(--vinnox-olive); }
.mission blockquote { font-family:var(--font-display); font-weight:400; font-size:clamp(34px,4.6vw,64px); line-height:1.08; letter-spacing:-.012em; color:#fff; margin:0; max-width:24ch; text-wrap:balance; }
.mission blockquote em { font-style:italic; color:var(--vinnox-olive); }
.mission .sig { margin-top:48px; display:flex; align-items:center; gap:14px; color:rgba(255,255,255,.6); font-size:12px; letter-spacing:.18em; text-transform:uppercase; }
.mission .sig img { height:24px; width:24px; opacity:.7; }
.mission-watermark { position:absolute; right:-60px; bottom:-100px; width:560px; height:560px; opacity:.04; pointer-events:none; }

/* ---------- Footer ---------- */
footer { background:var(--bg-card); padding:64px 0 32px; }
.foot-grid { display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid var(--line-hair); }
.foot-grid .col { display:flex; flex-direction:column; gap:14px; }
.foot-grid .col .h { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--fg-3); margin-bottom:6px; }
.foot-grid .col a { font-size:14px; color:var(--fg-1); text-decoration:none; transition:color var(--dur-base) var(--ease-out); }
.foot-grid .col a:hover { color:var(--vinnox-olive); }
.foot-brand { display:flex; flex-direction:column; gap:18px; }
.foot-brand .lock { display:flex; align-items:center; gap:12px; }
.foot-brand .lock img { height:36px; width:36px; }
.foot-brand .lock .wm { font-size:16px; font-weight:500; letter-spacing:.24em; color:var(--fg-1); }
.foot-brand p { font-size:14px; color:var(--fg-2); line-height:1.55; margin:0; max-width:30ch; }
.foot-bot { display:flex; justify-content:space-between; align-items:center; padding-top:24px; font-size:12px; color:var(--fg-3); letter-spacing:.04em; }
.foot-bot a { color:var(--fg-3); text-decoration:none; }

@media (max-width:900px) { .foot-grid { grid-template-columns:1fr 1fr; gap:32px; } }
@media (max-width:560px) { .foot-grid { grid-template-columns:1fr; } }

/* =========================================================================
   Cart + checkout drawer
   ========================================================================= */
.scrim { position:fixed; inset:0; background:rgba(26,26,26,.4); backdrop-filter:blur(4px); opacity:0; pointer-events:none; transition:opacity var(--dur-base) var(--ease-out); z-index:100; }
.drawer { position:fixed; top:0; right:0; bottom:0; width:min(460px,100vw); max-width:100vw; background:#fff; transform:translateX(100%); transition:transform var(--dur-slow) var(--ease-out); z-index:101; display:flex; flex-direction:column; box-shadow:-24px 0 48px rgba(0,0,0,.06); overflow:hidden; }
.open .scrim { opacity:1; pointer-events:auto; }
.open .drawer { transform:none; }

.drawer-head { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:18px 20px; border-bottom:1px solid var(--line-hair); flex:none; }
.drawer-head .t { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--fg-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.drawer-head .close { background:none; border:none; cursor:pointer; color:var(--fg-2); font-size:20px; line-height:1; padding:4px 8px; flex:none; }
.drawer-head .back { background:none; border:none; cursor:pointer; color:var(--fg-2); font-size:11px; letter-spacing:.18em; text-transform:uppercase; padding:0; flex:none; }
.drawer-head .back::before { content:"← "; }

.drawer-body { padding:20px; flex:1 1 auto; min-height:0; overflow-y:auto; -webkit-overflow-scrolling:touch; display:flex; flex-direction:column; gap:18px; }
.drawer-foot { padding:16px 20px calc(16px + env(safe-area-inset-bottom)); border-top:1px solid var(--line-hair); display:flex; flex-direction:column; gap:10px; background:#fff; flex:none; }

/* Views toggle */
.view { display:none; }
.view.active { display:flex; flex-direction:column; flex:1 1 auto; min-height:0; }
.view-checkout .drawer-body, .view-success .drawer-body { gap:16px; }

@media (min-width:560px) {
  .drawer-head { padding:22px 24px; }
  .drawer-body { padding:24px; gap:20px; }
  .drawer-foot { padding:20px 24px 24px; gap:12px; }
}

/* Cart line item */
.cart-item { display:grid; grid-template-columns:auto 1fr auto; gap:14px; align-items:center; padding:14px; border:1px solid var(--line-hair); border-radius:8px; }
.cart-item .thumb { width:56px; height:56px; background:url(assets/product-piper.png) center/cover; border-radius:4px; flex:none; }
.cart-item .info { display:flex; flex-direction:column; gap:4px; min-width:0; }
.cart-item .name { font-size:14px; font-weight:500; color:var(--fg-1); }
.cart-item .sub { font-size:12px; color:var(--fg-2); line-height:1.45; }
.cart-item .price { font-size:14px; font-weight:600; color:var(--fg-1); white-space:nowrap; align-self:start; }
@media (min-width:560px) {
  .cart-item .thumb { width:64px; height:64px; }
}

.qty { display:inline-flex; align-items:center; border:1px solid var(--line-soft); border-radius:999px; overflow:hidden; margin-top:8px; align-self:flex-start; }
.qty button { width:36px; height:36px; background:transparent; border:none; cursor:pointer; font-size:16px; color:var(--fg-1); font-family:var(--font-sans); padding:0; touch-action:manipulation; }
.qty button:hover { background:var(--bg-muted); }
.qty button:disabled { color:var(--fg-3); cursor:not-allowed; }
.qty .n { min-width:32px; text-align:center; font-size:14px; font-weight:500; font-variant-numeric:tabular-nums; }

/* Shipping radio group */
.shipping-group { display:flex; flex-direction:column; gap:8px; }
.shipping-group .label { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--fg-3); margin-bottom:4px; }
.radio-opt { display:flex; align-items:flex-start; gap:12px; padding:12px 14px; border:1px solid var(--line-hair); border-radius:8px; cursor:pointer; transition:border-color var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out); }
.radio-opt > span:last-child { flex:1; min-width:0; }
.radio-opt:hover { border-color:var(--line-soft); }
.radio-opt input { margin-top:3px; accent-color:var(--vinnox-olive); flex:none; }
.radio-opt:has(input:checked) { border-color:var(--vinnox-olive); background:var(--bg-tint); }
.radio-opt .name { font-size:14px; font-weight:500; color:var(--fg-1); display:flex; justify-content:space-between; gap:8px; flex-wrap:wrap; }
.radio-opt .name .cost { color:var(--vinnox-olive); font-weight:500; white-space:nowrap; }
.radio-opt .desc { display:block; font-size:12px; color:var(--fg-2); line-height:1.5; margin-top:4px; }

/* Totals */
.totals { display:flex; flex-direction:column; gap:6px; padding:14px 16px; background:var(--bg-muted); border-radius:8px; }
.totals .row { display:flex; justify-content:space-between; gap:12px; font-size:13px; color:var(--fg-2); font-variant-numeric:tabular-nums; }
.totals .row > :first-child { min-width:0; }
.totals .row.total { font-size:15px; color:var(--fg-1); font-weight:600; padding-top:8px; margin-top:4px; border-top:1px solid var(--line-hair); align-items:baseline; }
.totals .row.total .v { font-family:var(--font-display); font-size:22px; font-weight:400; white-space:nowrap; }

/* Form */
form.checkout { display:flex; flex-direction:column; gap:14px; }
.field { display:flex; flex-direction:column; gap:6px; }
.field label { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--fg-3); }
.field input, .field select, .field textarea {
  font-family:var(--font-sans); font-size:14px; color:var(--fg-1);
  padding:12px 14px; border:1px solid var(--line-soft); border-radius:var(--r-lg);
  background:#fff; outline:none; transition:border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
  width:100%;
}
.field textarea { min-height:80px; resize:vertical; font-family:var(--font-sans); }
.field input:focus, .field select:focus, .field textarea:focus { border-color:var(--vinnox-olive); box-shadow:0 0 0 3px rgba(133,157,63,.15); }
.field.error input, .field.error select, .field.error textarea { border-color:#B83A2B; }
.field .err { font-size:12px; color:#B83A2B; min-height:0; }
.field.row-2 { display:grid; grid-template-columns:1fr; gap:14px; }
.field.row-2 > .field { width:auto; min-width:0; }
@media (min-width:480px) {
  .field.row-2 { grid-template-columns:1fr 1fr; }
}

.checkout-section-title { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--fg-3); margin:8px 0 4px; }

.banner-error { background:#FBECEA; color:#7A2418; border:1px solid #E9BAB1; padding:12px 14px; border-radius:8px; font-size:13px; line-height:1.5; }

/* Success view */
.success { display:flex; flex-direction:column; gap:18px; padding:8px 4px; }
.success .check { width:48px; height:48px; border-radius:999px; background:var(--bg-tint); color:var(--vinnox-olive); display:inline-flex; align-items:center; justify-content:center; font-size:24px; }
.success h3 { font-family:var(--font-display); font-weight:400; font-size:28px; line-height:1.15; color:var(--fg-1); margin:0; }
.success p { font-size:14px; line-height:1.6; color:var(--fg-2); margin:0; }
.success .ref { font-family:var(--font-mono); font-size:13px; color:var(--fg-1); padding:10px 12px; background:var(--bg-muted); border-radius:6px; display:inline-block; }
.success .pay-note { padding:14px; border:1px solid var(--line-hair); border-left:3px solid var(--vinnox-olive); border-radius:6px; font-size:13px; color:var(--fg-1); line-height:1.6; background:#fff; }

/* ---------- Toast ---------- */
.toast { position:fixed; left:50%; bottom:32px; transform:translateX(-50%) translateY(20px); background:var(--vinnox-graphite); color:#fff; font-size:13px; padding:14px 22px; border-radius:999px; opacity:0; pointer-events:none; transition:all var(--dur-base) var(--ease-out); z-index:102; display:flex; align-items:center; gap:10px; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast .dot { width:6px; height:6px; border-radius:50%; background:var(--vinnox-olive); }

/* ---------- Terms checkbox in checkout ---------- */
.terms-check { display:flex; gap:12px; align-items:flex-start; padding:14px; border:1px solid var(--line-hair); border-radius:8px; cursor:pointer; margin-top:4px; transition:border-color var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out); }
.terms-check:hover { border-color:var(--line-soft); }
.terms-check input { margin-top:3px; accent-color:var(--vinnox-olive); width:16px; height:16px; flex:none; cursor:pointer; }
.terms-check:has(input:checked) { border-color:var(--vinnox-olive); background:var(--bg-tint); }
.terms-text { font-size:13px; line-height:1.55; color:var(--fg-1); }
.terms-text a { color:var(--vinnox-olive); text-decoration:none; border-bottom:1px solid rgba(133,157,63,.4); }
.terms-text a:hover { border-bottom-color:var(--vinnox-olive); }
.terms-check.error { border-color:#B83A2B; background:#FBECEA; }

/* ---------- Legal / terms page ---------- */
.legal-section { padding:clamp(56px,8vh,96px) 0 clamp(64px,10vh,128px); background:var(--bg-page); }
.legal { max-width:760px; }
.legal .eyebrow { font-size:11px; font-weight:500; letter-spacing:.24em; text-transform:uppercase; color:var(--vinnox-olive); display:inline-flex; align-items:center; gap:14px; margin-bottom:24px; }
.legal .eyebrow::before { content:""; width:32px; height:1px; background:var(--vinnox-olive); }
.legal h1 { font-family:var(--font-display); font-weight:400; font-size:clamp(40px,5vw,72px); line-height:1.04; letter-spacing:-.015em; margin:0 0 24px; color:var(--fg-1); text-wrap:balance; }
.legal p.lead { font-size:18px; line-height:1.6; color:var(--fg-2); margin:0 0 48px; max-width:56ch; }
.legal-list { list-style:none; counter-reset:legal; padding:0; margin:0; border-top:1px solid var(--line-hair); }
.legal-list > li { counter-increment:legal; padding:28px 0 24px 56px; border-bottom:1px solid var(--line-hair); position:relative; }
.legal-list > li::before {
  content: counter(legal, decimal-leading-zero);
  position:absolute; left:0; top:30px;
  font-family:var(--font-mono); font-size:12px; color:var(--vinnox-olive); letter-spacing:.04em;
}
.legal-list h2 { font-family:var(--font-display); font-weight:400; font-size:22px; line-height:1.2; margin:0 0 10px; color:var(--fg-1); }
.legal-list p { font-size:15px; line-height:1.7; color:var(--fg-2); margin:0; text-wrap:pretty; }
.legal-foot { margin-top:48px; font-size:14px; color:var(--fg-2); }
.legal-foot a { color:var(--vinnox-olive); text-decoration:none; border-bottom:1px solid rgba(133,157,63,.4); }
.legal-foot a:hover { border-bottom-color:var(--vinnox-olive); }

@media (max-width:560px) {
  .legal-list > li { padding-left:40px; }
  .legal-list > li::before { top:31px; }
}

/* Focus ring */
a:focus-visible, button:focus-visible { outline:2px solid var(--vinnox-olive); outline-offset:3px; border-radius:4px; }
