/* ============================================================================
   MATCHDAY — Storefront Theme
   Dark stadium / streetwear soccer aesthetic. Electric lime + struck-gold accent.
   Fonts: Bricolage Grotesque (display) · Instrument Serif (accent) · Hanken Grotesk (body)
   (Banned fonts never used: Inter, Roboto, Arial, Helvetica, Space Grotesk,
    Open Sans, Lato, Montserrat, Poppins.)
   Class names + element IDs match assets/app.js — do not rename.
   ========================================================================= */

/* ---- 1. Tokens ---------------------------------------------------------- */
:root {
  /* Surfaces — deep, never pure #000 */
  --bg:        #0E1018;   /* page — dark charcoal, not pitch black */
  --bg-alt:    #1A1C27;   /* raised band / cards — clearly distinct */
  --bg-card:   #1F2235;   /* card bg — visible against bg-alt */
  --bg-deep:   #090B10;   /* footer / darkest */
  --ink:       #F5F3EF;   /* primary text on dark */
  --ink-soft:  #C8C5BE;
  --muted:     #9B9BAC;   /* AA on dark surfaces — readable gray */

  /* Accents */
  --accent:      #10b981;   /* emerald green — primary action */
  --accent-2:    #059669;
  --accent-soft: #34d399;
  --accent-ink:  #ffffff;   /* text on emerald */
  --gold:        #E0B341;   /* struck gold — premium highlight */

  /* Functional */
  --success: #4FD08A;
  --danger:  #FF6B5B;

  /* Lines & overlays */
  --hairline:  rgba(243,241,236,0.20);
  --hairline-2:rgba(243,241,236,0.10);
  --scrim:     rgba(0,0,0,0.10);
  --shadow-overlay: 0 2px 8px rgba(0,0,0,0.35), 0 24px 60px rgba(0,0,0,0.45);

  /* Type */
  --f-display: "Bricolage Grotesque", Georgia, serif;
  --f-accent:  "Instrument Serif", Georgia, serif;
  --f-body:    "Hanken Grotesk", system-ui, sans-serif;

  --fs-eyebrow: 0.8rem;
  --fs-meta:    0.9375rem;
  --fs-body:    1.0625rem;
  --fs-lead:    1.3rem;
  --fs-h3:      1.75rem;
  --fs-h2:      clamp(2rem, 3.8vw, 2.75rem);
  --fs-h1:      clamp(3rem, 7vw, 5.25rem);

  /* Spacing (8pt) */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s6:24px;
  --s8:32px; --s12:48px; --s16:64px; --s24:96px; --s32:128px;

  /* Radius & geometry */
  --r-sm:8px; --r-md:14px; --r-pill:999px;
  --maxw:1340px; --gutter:32px;

  /* Motion */
  --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-io:   cubic-bezier(0.4, 0, 0.2, 1);
  --d-micro:180ms; --d-reveal:300ms; --d-section:520ms;
}

/* Slightly lifted surface scheme used by upsell card etc. */
[data-scheme="ink"] {
  --bg:#121319; --bg-alt:#1A1C24; --ink:#F3F1EC; --ink-soft:#C3C0B8;
  --muted:#8A8A93; --hairline:rgba(243,241,236,0.16); --hairline-2:rgba(243,241,236,0.08);
}

/* ---- 2. Reset / base --------------------------------------------------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body {
  background:var(--bg); color:var(--ink);
  font-family:var(--f-body); font-size:var(--fs-body); line-height:1.55;
  font-weight:400; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video { display:block; max-width:100%; }
img { height:auto; }
a { color:inherit; text-decoration:none; }
button { font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
input,select,textarea { font:inherit; color:inherit; }
ul { list-style:none; }
::selection { background:var(--accent); color:var(--accent-ink); }
:focus-visible { outline:2px solid var(--accent); outline-offset:2px; border-radius:var(--r-sm); }

/* a11y utilities */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.skip-link { position:fixed; top:8px; left:8px; z-index:200; background:var(--accent); color:var(--accent-ink); padding:10px 16px; border-radius:var(--r-md); font-weight:700; transform:translateY(-150%); transition:transform var(--d-micro) var(--ease-out); }
.skip-link:focus { transform:translateY(0); }
main:focus { outline:none; }

/* ---- 3. Typography ----------------------------------------------------- */
h1,h2,h3,h4 { font-family:var(--f-display); font-weight:700; line-height:1.08; letter-spacing:-0.02em; }
h1,.display { font-size:var(--fs-h1); line-height:1.02; letter-spacing:-0.03em; }
h2 { font-size:var(--fs-h2); }
h3 { font-size:var(--fs-h3); line-height:1.16; }
h4 { font-size:var(--fs-lead); }
p { max-width:68ch; }
.lead { font-size:var(--fs-lead); line-height:1.5; color:var(--ink-soft); }
.accent { font-family:var(--f-accent); font-style:italic; font-weight:400; letter-spacing:0; color:var(--accent); }
.eyebrow {
  font-size:var(--fs-eyebrow); text-transform:uppercase; letter-spacing:0.2em;
  font-weight:700; color:var(--accent);
}
.muted { color:var(--muted); }
.meta { font-size:var(--fs-meta); color:var(--ink-soft); }
.price { font-variant-numeric:tabular-nums; }
.price-was { color:var(--muted); text-decoration:line-through; font-weight:400; }
.price-save { color:var(--accent); font-weight:700; }

/* ---- 4. Layout --------------------------------------------------------- */
.container { width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section { padding-block:var(--s24); }
.section--tight { padding-block:var(--s16); }
.bg-alt { background:var(--bg-alt); }
.bg-deep { background:var(--bg-deep); }
.center { text-align:center; }
.stack > * + * { margin-top:var(--s4); }
.section-head { max-width:42rem; margin-bottom:var(--s12); }
.section-head.center { margin-inline:auto; }
.split { display:grid; gap:var(--s12); align-items:center; }
@media (min-width:900px){
  .split { grid-template-columns:1fr 1fr; gap:var(--s24); }
  .split--57 { grid-template-columns:5fr 7fr; }
  .split--75 { grid-template-columns:7fr 5fr; }
  .split.reverse > :first-child { order:2; }
}

/* ---- 5. Buttons -------------------------------------------------------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:var(--s2);
  font-family:var(--f-body); font-weight:700; font-size:0.9rem;
  text-transform:uppercase; letter-spacing:0.07em;
  padding:0 var(--s8); height:52px; border-radius:var(--r-md);
  transition:background var(--d-micro) var(--ease-io), color var(--d-micro), transform var(--d-micro), border-color var(--d-micro), box-shadow var(--d-micro);
  white-space:nowrap;
}
.btn:active { transform:scale(0.985); }
.btn--primary { background:var(--accent); color:var(--accent-ink); }
.btn--primary:hover { background:var(--accent-soft); transform:translateY(-1px); box-shadow:0 8px 28px rgba(16,185,129,0.32); }
.btn--secondary { border:1px solid var(--hairline); color:var(--ink); }
.btn--secondary:hover { border-color:var(--accent); color:var(--accent); }
.btn--accent { background:var(--gold); color:#1a1304; }
.btn--accent:hover { background:#f0c659; }
.btn--ghost { color:var(--ink); border:1px solid var(--hairline); background:transparent; }
.btn--ghost:hover { border-color:var(--accent); color:var(--accent); }
.btn--block { width:100%; }
.btn--lg { height:58px; font-size:0.875rem; }
.btn--sm { height:42px; font-size:0.75rem; }
.btn[disabled] { opacity:0.4; pointer-events:none; }
.link-underline { position:relative; font-weight:600; color:var(--ink); }
.link-underline::after { content:""; position:absolute; left:0; bottom:-2px; width:100%; height:1px; background:currentColor; transform:scaleX(0); transform-origin:left; transition:transform var(--d-micro) var(--ease-io); }
.link-underline:hover::after { transform:scaleX(1); }

/* ---- 6. Announcement bar (rotator: .announce__rot w/ 3 spans) ----------- */
.announce {
  background:var(--bg-deep); color:var(--ink); text-align:center;
  font-size:0.75rem; letter-spacing:0.08em; text-transform:uppercase; font-weight:600;
  min-height:40px; border-bottom:1px solid var(--hairline-2);
  display:flex; align-items:center; justify-content:center; gap:var(--s6);
  padding:var(--s2) var(--s12); position:relative;
}
.announce__rot { position:relative; height:1.25em; line-height:1.25em; overflow:hidden; }
.announce__rot span { display:block; height:1.25em; line-height:1.25em; animation:announceRot 12s infinite; }
.announce__rot b { color:var(--accent); }
@keyframes announceRot { 0%,28%{transform:translateY(0)} 33%,61%{transform:translateY(-1.25em)} 66%,94%{transform:translateY(-2.5em)} 100%{transform:translateY(0)} }
.announce__close { position:absolute; right:var(--s4); top:50%; transform:translateY(-50%); opacity:.6; font-size:1rem; }
.announce__close:hover { opacity:1; }
@media (prefers-reduced-motion:reduce){ .announce__rot{ height:auto; } .announce__rot span{ animation:none; } .announce__rot span+span{ display:none; } }

/* ---- 7. Header / nav --------------------------------------------------- */
.header { position:sticky; top:0; z-index:60; background:color-mix(in srgb, var(--bg) 82%, transparent); backdrop-filter:blur(14px); border-bottom:1px solid transparent; transition:border-color var(--d-micro), background var(--d-micro); }
.header.is-stuck { border-bottom-color:var(--hairline); background:color-mix(in srgb, var(--bg) 94%, transparent); }
.header__bar { display:flex; align-items:center; justify-content:space-between; height:76px; transition:height var(--d-micro) var(--ease-io); }
.header.is-stuck .header__bar { height:62px; }
.brand { font-family:var(--f-display); font-weight:800; font-size:1.5rem; letter-spacing:-0.03em; text-transform:uppercase; }
.brand sup { font-family:var(--f-accent); font-style:italic; font-size:.55em; color:var(--accent); margin-left:1px; }
.nav { display:none; gap:var(--s8); }
.nav__item { font-size:0.85rem; font-weight:600; text-transform:uppercase; letter-spacing:0.05em; padding-block:var(--s3); position:relative; display:inline-flex; align-items:center; gap:4px; }
.nav__item::after { content:""; position:absolute; left:0; bottom:8px; width:100%; height:2px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform var(--d-micro) var(--ease-io); }
.nav__item:hover { color:var(--accent); }
.nav__item:hover::after { transform:scaleX(1); }
.header__actions { display:flex; align-items:center; gap:var(--s2); }
.icon-btn { position:relative; width:42px; height:42px; display:inline-flex; align-items:center; justify-content:center; border-radius:var(--r-md); transition:background var(--d-micro), color var(--d-micro); }
.icon-btn:hover { background:var(--bg-alt); color:var(--accent); }
.cart-count { position:absolute; top:4px; right:2px; min-width:18px; height:18px; padding:0 4px; background:var(--accent); color:var(--accent-ink); font-size:0.625rem; font-weight:800; border-radius:var(--r-pill); display:flex; align-items:center; justify-content:center; }
.nav-toggle { display:inline-flex; }
@media (min-width:1000px){ .nav { display:flex; } .nav-toggle{ display:none; } }

/* ---- Countries mega-menu (desktop) ----------------------------------- */
.nav__has-mega { position:relative; display:inline-flex; align-items:center; }
.nav__mega-trigger { background:none; border:0; cursor:pointer; color:inherit; font:inherit; }
.cmega {
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%) translateY(8px);
  width:min(720px, 90vw); background:var(--bg-card); border:1px solid var(--hairline);
  border-radius:var(--r-md); box-shadow:var(--shadow-overlay); padding:var(--s6);
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity var(--d-micro) var(--ease-out), transform var(--d-micro) var(--ease-out);
  z-index:80;
}
.cmega::before { content:""; position:absolute; top:-14px; left:0; right:0; height:14px; }
.nav__has-mega:hover .cmega,
.nav__has-mega:focus-within .cmega {
  opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0);
}
.cmega__grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:var(--s5) var(--s6); }
.cmega__col { display:flex; flex-direction:column; gap:2px; }
.cmega__confed {
  font-family:var(--f-display); font-weight:700; font-size:0.72rem; text-transform:uppercase;
  letter-spacing:0.08em; color:var(--accent); margin-bottom:6px;
}
.cmega a {
  display:flex; align-items:center; gap:8px; padding:5px 8px; border-radius:var(--r-sm);
  font-size:0.875rem; font-weight:600; color:var(--ink-soft); text-transform:none; letter-spacing:0;
  transition:background var(--d-micro), color var(--d-micro);
}
.cmega a:hover, .cmega a:focus-visible { background:var(--bg-alt); color:var(--ink); }
.cmega__flag { font-size:1.05rem; line-height:1; width:1.4em; text-align:center; }
.cmega__all {
  display:inline-flex; margin-top:var(--s5); padding-top:var(--s4);
  border-top:1px solid var(--hairline-2); font-weight:700; font-size:0.85rem; color:var(--accent);
}
.cmega__all:hover { color:var(--accent-soft); }

/* ---- Countries accordion (mobile nav) -------------------------------- */
.mnav__acc {
  display:flex; align-items:center; justify-content:space-between; width:100%;
  padding:var(--s4) 0; background:none; border:0; border-bottom:1px solid var(--hairline-2);
  font-family:var(--f-display); font-weight:700; font-size:1.3rem; text-transform:uppercase;
  color:var(--ink); cursor:pointer;
}
.mnav__acc:hover { color:var(--accent); }
.mnav__acc-ic { font-size:1.5rem; line-height:1; color:var(--accent); }
.mnav__panel {
  display:none; flex-direction:column; gap:2px; padding:var(--s3) 0 var(--s4) var(--s3);
  max-height:46vh; overflow-y:auto;
}
.mnav__acc[aria-expanded="true"] + .mnav__panel { display:flex; }
.mnav__confed {
  font-family:var(--f-display); font-weight:700; font-size:0.68rem; text-transform:uppercase;
  letter-spacing:0.08em; color:var(--accent); margin:var(--s3) 0 4px;
}
.mnav .mnav__country {
  display:flex; align-items:center; gap:8px; padding:7px 0 !important; border-bottom:0 !important;
  font-family:var(--f-body) !important; font-weight:600 !important; font-size:0.95rem !important;
  text-transform:none !important;
}
.mnav .mnav__country:hover { color:var(--accent); }

/* ---- 8. Hero ----------------------------------------------------------- */
.hero { position:relative; min-height:90vh; display:flex; align-items:flex-end; color:#fff; overflow:hidden; }
.hero__media, .hero__media img, .hero__media video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero__media::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,9,12,.55) 0%, rgba(8,9,12,.25) 35%, rgba(8,9,12,.97) 100%); }
.hero__media::before { content:""; position:absolute; inset:0; z-index:1; background-image: repeating-linear-gradient(45deg, transparent, transparent 2px, rgba(16,185,129,0.025) 2px, rgba(16,185,129,0.025) 4px); pointer-events:none; }
.hero__scrim { position:absolute; inset:0; background:var(--scrim); }
.hero__inner { position:relative; z-index:2; padding-block:var(--s24); max-width:56rem; }
.hero h1 { color:#fff; text-transform:uppercase; font-size:clamp(3.5rem, 9vw, 6.5rem); }
.hero h1 .accent { display:block; color:var(--accent); }
.hero .eyebrow { color:var(--accent); }
.hero .lead { color:rgba(255,255,255,.9); }
.hero__trust { display:flex; flex-wrap:wrap; align-items:center; gap:var(--s4); margin-top:var(--s6); font-size:0.85rem; color:rgba(255,255,255,.92); }
.hero__trust .stars { color:var(--gold); }
.announce__sep { color:var(--muted); }
@media (max-width:640px){ .announce__sep{ display:none; } }

/* ---- 9. Trust / press / stats / ticker -------------------------------- */
.pressbar { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:var(--s8) var(--s12); }
.pressbar span { font-family:var(--f-display); font-weight:700; font-size:1.05rem; letter-spacing:.02em; text-transform:uppercase; color:var(--muted); }
.usps { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--s8) var(--s6); }
.usp { display:flex; gap:var(--s3); align-items:flex-start; }
.usp svg { flex:0 0 22px; margin-top:2px; color:var(--accent); }
.usp b { display:block; font-weight:700; }
.usp p { font-size:0.875rem; color:var(--ink-soft); }
.stats { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--s12); text-align:center; }
.stat .num { font-family:var(--f-display); font-weight:800; font-size:clamp(2.4rem,4.5vw,3.4rem); line-height:1; color:var(--accent); }
.stat .lbl { font-size:0.85rem; color:var(--ink-soft); margin-top:var(--s2); text-transform:uppercase; letter-spacing:0.06em; }
@media (min-width:768px){ .usps{ grid-template-columns:repeat(4,1fr); } .stats{ grid-template-columns:repeat(4,1fr); } }

/* edge-to-edge marquee ticker */
.ticker { background:var(--accent); color:#fff; overflow:hidden; padding:12px 0; border-block:1px solid var(--bg); }
.ticker__track { display:inline-flex; gap:var(--s6); white-space:nowrap; animation:tickerScroll 30s linear infinite; will-change:transform; }
.ticker__track span { font-family:var(--f-display); font-weight:800; font-size:1.05rem; text-transform:uppercase; letter-spacing:0.04em; display:inline-flex; align-items:center; gap:var(--s6); padding-right:var(--s6); }
.ticker__track span::after { content:"●"; font-size:0.55rem; opacity:.5; }
@keyframes tickerScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@media (prefers-reduced-motion:reduce){ .ticker__track{ animation:none; } }

/* ---- 10. Product card -------------------------------------------------- */
.grid-products { display:grid; gap:var(--s8) var(--s6); grid-template-columns:repeat(2,1fr); }
@media (min-width:700px){ .grid-products{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1040px){ .grid-products{ grid-template-columns:repeat(4,1fr); } }
.card { position:relative; display:flex; flex-direction:column; }
.card__media { position:relative; aspect-ratio:4/5; overflow:hidden; border-radius:10px; background:var(--bg-alt); border:1px solid var(--hairline-2); box-shadow:0 2px 16px rgba(0,0,0,0.18); transition:border-color var(--d-micro), box-shadow var(--d-micro); }
.card__media img { width:100%; height:100%; object-fit:cover; transition:transform var(--d-reveal) var(--ease-out), opacity var(--d-reveal); }
.card__media img.alt { position:absolute; inset:0; opacity:0; }
.card:hover .card__media { border-color:var(--accent); box-shadow:0 8px 40px rgba(16,185,129,0.15); }
.card:hover .card__media img.main { transform:scale(1.03); }
.card:hover .card__media img.alt { opacity:1; }
.card__quick { position:absolute; left:var(--s3); right:var(--s3); bottom:var(--s3); opacity:0; transform:translateY(10px); transition:opacity var(--d-reveal) var(--ease-out), transform var(--d-reveal) var(--ease-out); }
.card:hover .card__quick { opacity:1; transform:translateY(0); }
.card__quick .btn { background:var(--accent); color:#fff; box-shadow:var(--shadow-overlay); height:46px; }
.card__quick .btn:hover { background:var(--accent-2); }
.card__body { padding-top:var(--s4); }
.card__title { font-family:var(--f-display); font-weight:800; font-size:1.12rem; letter-spacing:-0.02em; line-height:1.2; }
.card__desc { font-size:0.875rem; color:var(--muted); margin-top:3px; }
.card__price { margin-top:var(--s3); font-size:1.05rem; display:flex; gap:var(--s3); align-items:baseline; font-weight:700; }
@media (hover:none){ .card__quick{ opacity:1; transform:none; } }

/* ---- 11. Badges & stars ----------------------------------------------- */
.badge { display:inline-flex; align-items:center; gap:4px; font-size:0.6875rem; font-weight:800; text-transform:uppercase; letter-spacing:0.08em; padding:4px 9px; border-radius:var(--r-sm); }
.badge--sale { background:var(--accent); color:var(--accent-ink); }
.badge--new { background:var(--gold); color:#1a1304; }
.badge--soft { background:var(--bg-alt); color:var(--ink-soft); border:1px solid var(--hairline); }
.card__badge { position:absolute; top:var(--s3); left:var(--s3); z-index:2; }
.card__flag { position:absolute; top:var(--s3); right:var(--s3); z-index:2; font-size:1.15rem; line-height:1; background:rgba(8,9,12,.55); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.18); border-radius:var(--r-sm); padding:3px 6px; box-shadow:0 2px 8px rgba(0,0,0,.25); }
.card__save { font-size:0.72rem; font-weight:800; letter-spacing:0.04em; text-transform:uppercase; color:var(--accent); background:color-mix(in srgb,var(--accent) 12%, transparent); border-radius:var(--r-sm); padding:2px 7px; margin-left:auto; }
.stars { color:var(--gold); letter-spacing:1px; font-size:0.9rem; }
.rating { display:inline-flex; align-items:center; gap:var(--s2); font-size:0.85rem; }
.rating a { color:var(--ink-soft); }

/* ---- 12. Cart drawer --------------------------------------------------- */
.overlay { position:fixed; inset:0; background:rgba(0,0,0,.62); opacity:0; visibility:hidden; transition:opacity var(--d-reveal); z-index:90; backdrop-filter:blur(2px); }
.overlay.open { opacity:1; visibility:visible; }
.drawer { position:fixed; top:0; right:0; height:100dvh; width:min(420px,100%); background:#0F1F38; z-index:100; transform:translateX(100%); transition:transform var(--d-section) var(--ease-out); display:flex; flex-direction:column; box-shadow:var(--shadow-overlay); border-left:1px solid var(--hairline); }
.drawer.open { transform:translateX(0); }
.drawer__head { display:flex; align-items:center; justify-content:space-between; padding:var(--s6); border-bottom:1px solid var(--hairline); }
.drawer__head h3 { font-size:1.15rem; text-transform:uppercase; }
.ship-bar { padding:var(--s4) var(--s6); background:var(--bg-card); font-size:0.825rem; }
.ship-bar__msg b { color:var(--accent); }
.ship-bar__track { height:6px; border-radius:var(--r-pill); background:var(--hairline); margin-top:var(--s2); overflow:hidden; }
.ship-bar__fill { height:100%; background:var(--accent); width:0; transition:width var(--d-section) var(--ease-out); }
.drawer__items { flex:1; overflow-y:auto; padding:var(--s4) var(--s6); }
.line { display:grid; grid-template-columns:64px 1fr auto; gap:var(--s4); padding:var(--s4) 0; border-bottom:1px solid var(--hairline-2); }
.line__img { width:64px; height:80px; object-fit:cover; border-radius:var(--r-sm); background:var(--bg-card); }
.line__t { font-weight:700; font-size:0.9rem; }
.line__v { font-size:0.8rem; color:var(--muted); }
.qty { display:inline-flex; align-items:center; border:1px solid var(--hairline); border-radius:var(--r-md); margin-top:var(--s2); }
.qty button { width:28px; height:28px; font-size:1rem; }
.qty button:hover { color:var(--accent); }
.qty span { min-width:26px; text-align:center; font-size:0.85rem; font-variant-numeric:tabular-nums; }
.line__rm { font-size:0.75rem; color:var(--muted); text-decoration:underline; margin-top:6px; }
.line__rm:hover { color:var(--danger); }
.line__price { font-size:0.9rem; font-variant-numeric:tabular-nums; text-align:right; font-weight:600; }
.crosssell { padding:var(--s4) var(--s6); border-top:1px solid var(--hairline); }
.crosssell h5 { font-size:var(--fs-eyebrow); text-transform:uppercase; letter-spacing:0.14em; color:var(--muted); margin-bottom:var(--s3); }
.cs-item { display:flex; align-items:center; gap:var(--s3); padding:var(--s2) 0; }
.cs-item img { width:44px; height:54px; object-fit:cover; border-radius:var(--r-sm); }
.cs-item .t { font-size:0.85rem; font-weight:600; flex:1; }
.cs-add { font-size:0.7rem; font-weight:800; text-transform:uppercase; letter-spacing:0.05em; border:1px solid var(--accent); color:var(--accent); border-radius:var(--r-pill); padding:5px 12px; }
.cs-add:hover { background:var(--accent); color:var(--accent-ink); }
.drawer__foot { padding:var(--s6); border-top:1px solid var(--hairline); }
.drawer__sub { display:flex; justify-content:space-between; font-weight:700; margin-bottom:var(--s2); }
.drawer__note { font-size:0.75rem; color:var(--muted); margin-bottom:var(--s4); }
.trust-row { display:flex; align-items:center; justify-content:center; gap:var(--s4); font-size:0.72rem; color:var(--muted); margin-top:var(--s4); }
.pay-icons { display:flex; gap:6px; align-items:center; justify-content:center; margin-top:var(--s3); color:var(--muted); }
.pay-icons img, .pay-icons svg { height:22px; }
.drawer__empty { padding:var(--s16) var(--s6); text-align:center; color:var(--muted); }
.divider { display:flex; align-items:center; gap:var(--s4); color:var(--muted); font-size:0.78rem; text-transform:uppercase; letter-spacing:0.08em; margin:var(--s6) 0; }
.divider::before, .divider::after { content:""; flex:1; height:1px; background:var(--hairline); }

/* Mobile nav (built by app.js) */
.mnav { position:fixed; top:0; left:0; height:100dvh; width:min(330px,84%); background:var(--bg-alt); z-index:100; transform:translateX(-100%); transition:transform var(--d-section) var(--ease-out); box-shadow:var(--shadow-overlay); padding:var(--s6); display:flex; flex-direction:column; border-right:1px solid var(--hairline); }
.mnav.open { transform:translateX(0); }
.mnav__head { display:flex; justify-content:space-between; align-items:center; margin-bottom:var(--s6); }
.mnav a:not(.brand) { padding:var(--s4) 0; font-family:var(--f-display); font-weight:700; font-size:1.3rem; text-transform:uppercase; border-bottom:1px solid var(--hairline-2); }
.mnav a:not(.brand):hover { color:var(--accent); }

/* ---- 12b. Search overlay ---------------------------------------------- */
.search { position:fixed; top:0; left:0; right:0; z-index:100; background:var(--bg-alt); border-bottom:1px solid var(--hairline); transform:translateY(-110%); transition:transform var(--d-section) var(--ease-out); box-shadow:var(--shadow-overlay); }
.search.open { transform:translateY(0); }
.search__bar { display:flex; align-items:center; gap:var(--s4); max-width:var(--maxw); margin-inline:auto; padding:var(--s6) var(--gutter); }
.search__bar svg { flex:0 0 22px; color:var(--muted); }
#search-input { flex:1; height:54px; background:transparent; border:none; border-bottom:2px solid var(--hairline); font-family:var(--f-display); font-weight:700; font-size:1.4rem; color:var(--ink); }
#search-input:focus { outline:none; border-color:var(--accent); }
#search-input::placeholder { color:var(--muted); }
.search__results { max-width:var(--maxw); margin-inline:auto; padding:0 var(--gutter) var(--s8); display:grid; gap:var(--s2); grid-template-columns:1fr; max-height:60vh; overflow-y:auto; }
@media (min-width:760px){ .search__results{ grid-template-columns:1fr 1fr; gap:var(--s3); } }
.search-hit { display:flex; align-items:center; gap:var(--s4); padding:var(--s3); border-radius:var(--r-md); border:1px solid var(--hairline-2); transition:border-color var(--d-micro), background var(--d-micro); }
.search-hit:hover { border-color:var(--accent); background:var(--bg-card); }
.search-hit img { width:48px; height:60px; object-fit:cover; border-radius:var(--r-sm); }
.search-hit__t { font-weight:700; }

/* ---- 13. Sticky ATC ---------------------------------------------------- */
.sticky-atc { position:fixed; left:0; right:0; bottom:0; z-index:70; background:color-mix(in srgb,var(--bg) 92%, transparent); backdrop-filter:blur(14px); border-top:1px solid var(--hairline); transform:translateY(110%); transition:transform var(--d-section) var(--ease-out); }
.sticky-atc.show { transform:translateY(0); }
.sticky-atc__in { display:flex; align-items:center; gap:var(--s4); padding:var(--s3) var(--gutter); max-width:var(--maxw); margin-inline:auto; }
.sticky-atc img { width:42px; height:52px; object-fit:cover; border-radius:var(--r-sm); }
.sticky-atc__t { flex:1; min-width:0; }
.sticky-atc__t b { display:block; font-size:0.9rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sticky-atc__t .price { font-size:0.85rem; color:var(--accent); font-weight:700; }
@media (max-width:640px){ .sticky-atc__t b{ font-size:0.8rem; } .sticky-atc img{ display:none; } }

/* ---- 14. Modal --------------------------------------------------------- */
.modal { position:fixed; inset:0; z-index:110; display:none; align-items:center; justify-content:center; padding:var(--s6); }
.modal.open { display:flex; }
.modal__card { position:relative; background:var(--bg-alt); border:1px solid var(--hairline); border-radius:var(--r-md); max-width:520px; width:100%; padding:var(--s12); box-shadow:var(--shadow-overlay); z-index:2; }
.modal__close { position:absolute; top:var(--s4); right:var(--s4); font-size:1.3rem; color:var(--muted); }

/* ---- 15. Accordion ----------------------------------------------------- */
.accordion { border-top:1px solid var(--hairline); }
.acc { border-bottom:1px solid var(--hairline); }
.acc__q { width:100%; display:flex; justify-content:space-between; align-items:center; gap:var(--s4); padding:var(--s6) 0; text-align:left; font-family:var(--f-display); font-weight:700; font-size:1.05rem; }
.acc__q:hover { color:var(--accent); }
.acc__q svg { flex:0 0 18px; transition:transform var(--d-reveal) var(--ease-io); }
.acc.open .acc__q svg { transform:rotate(180deg); color:var(--accent); }
/* Reliable max-height reveal (fr-unit transitions miscompute in some engines). */
.acc__a { overflow:hidden; max-height:0; transition:max-height var(--d-reveal) var(--ease-io); }
.acc.open .acc__a { max-height:600px; }
.acc__a > div { overflow:hidden; }
.acc__a p { padding-bottom:var(--s6); color:var(--ink-soft); }

/* ---- 16. Forms --------------------------------------------------------- */
.field { display:block; margin-bottom:var(--s4); }
.field label { display:block; font-size:0.8rem; font-weight:600; margin-bottom:6px; }
.input, .select, textarea.input { width:100%; height:52px; padding:0 var(--s4); background:var(--bg); border:1px solid var(--hairline); border-radius:var(--r-md); color:var(--ink); transition:border-color var(--d-micro); }
textarea.input { height:auto; padding:var(--s4); }
.input::placeholder { color:var(--muted); }
.input:focus, .select:focus { border-color:var(--accent); outline:none; }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:var(--s4); }
.newsletter { display:flex; gap:var(--s2); max-width:440px; }
.newsletter .input { flex:1; }

/* ---- 17. PDP ----------------------------------------------------------- */
.pdp { display:grid; gap:var(--s12); padding-block:var(--s12); }
@media (min-width:980px){ .pdp{ grid-template-columns:1.1fr 1fr; gap:var(--s24); align-items:start; } }
.gallery__main { aspect-ratio:4/5; border-radius:var(--r-md); overflow:hidden; background:var(--bg-alt); position:relative; border:1px solid var(--hairline-2); }
.gallery__main img { width:100%; height:100%; object-fit:cover; }
.gallery__main .badge { position:absolute; top:var(--s4); left:var(--s4); }
.gallery__thumbs { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--s2); margin-top:var(--s2); }
.gallery__thumbs button { aspect-ratio:1/1; border-radius:var(--r-sm); overflow:hidden; background:var(--bg-alt); opacity:.6; transition:opacity var(--d-micro), border-color var(--d-micro); border:1px solid var(--hairline-2); }
.gallery__thumbs button[aria-current="true"], .gallery__thumbs button:hover { opacity:1; border-color:var(--accent); }
.gallery__thumbs img { width:100%; height:100%; object-fit:cover; }
.buybox { position:sticky; top:90px; }
.buybox > * + * { margin-top:var(--s4); }
.buybox h1 { font-size:clamp(2rem,3.6vw,2.8rem); text-transform:uppercase; }
.offer-line { font-size:0.85rem; color:var(--accent); font-weight:700; }
.price-block { display:flex; align-items:baseline; gap:var(--s3); font-size:1.7rem; font-family:var(--f-display); font-weight:800; }
.price-block .price-was { font-size:1.1rem; }
.afterpay { font-size:0.8rem; color:var(--muted); }
.variant-row { display:flex; gap:var(--s3); flex-wrap:wrap; }
.variant { min-width:52px; padding:12px 18px; border:1px solid var(--hairline); border-radius:var(--r-md); font-size:0.9rem; font-weight:700; transition:border-color var(--d-micro), background var(--d-micro), color var(--d-micro); }
.variant:hover { border-color:var(--ink-soft); }
.variant[aria-pressed="true"] { border-color:var(--accent); background:var(--accent); color:var(--accent-ink); }
.label-sm { font-size:0.8rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; margin-bottom:var(--s2); }

/* ---- Pack tier selector ---- */
.tiers { display:flex; flex-direction:column; gap:8px; }
.tier { position:relative; display:flex; align-items:center; gap:12px; padding:13px 16px; border:1.5px solid var(--hairline); border-radius:var(--r-md); cursor:pointer; transition:border-color var(--d-micro), background var(--d-micro); user-select:none; }
.tier:hover { border-color:var(--ink-soft); }
.tier:has(input:checked) { border-color:var(--accent); background:color-mix(in srgb, var(--accent) 14%, var(--bg-card)); }
.tier__dot { width:18px; height:18px; border-radius:50%; border:1.5px solid var(--hairline); flex-shrink:0; display:grid; place-items:center; transition:border-color var(--d-micro); }
.tier:has(input:checked) .tier__dot { border-color:var(--accent); }
.tier:has(input:checked) .tier__dot::after { content:""; width:9px; height:9px; border-radius:50%; background:var(--accent); display:block; }
.tier__body { flex:1; min-width:0; }
.tier__row1 { display:flex; align-items:center; gap:8px; }
.tier__name { font-size:0.9rem; font-weight:600; }
.tier__badge { font-size:0.6rem; font-weight:800; text-transform:uppercase; letter-spacing:0.07em; background:var(--accent); color:var(--accent-ink); padding:2px 8px; border-radius:20px; white-space:nowrap; }
.tier__sub { font-size:0.75rem; color:var(--muted); margin-top:2px; }
.tier__price { text-align:right; flex-shrink:0; }
.tier__price b { font-size:1rem; font-weight:700; display:block; font-variant-numeric:tabular-nums; }
.tier__save { font-size:0.72rem; color:var(--accent); display:block; }

/* purchase mode */
.purchase-mode { display:grid; gap:var(--s2); }
.pmode { display:flex; align-items:center; gap:var(--s3); padding:var(--s3) var(--s4); border:1.5px solid var(--hairline); border-radius:var(--r-md); cursor:pointer; font-size:0.875rem; }
.pmode:has(input:checked) { border-color:var(--accent); }
.pmode:has(input:focus-visible) { outline:2px solid var(--accent); outline-offset:2px; }
.pmode .tag { margin-left:auto; font-size:0.72rem; color:var(--success); font-weight:700; }

.atc-row { display:flex; gap:var(--s3); align-items:stretch; }
.atc-row .btn { flex:1; }
.review-snip { font-size:0.85rem; color:var(--ink-soft); border-left:2px solid var(--accent); padding-left:var(--s3); }
.trust-trio { display:grid; gap:var(--s3); padding:var(--s4) 0; border-top:1px solid var(--hairline-2); border-bottom:1px solid var(--hairline-2); }
.trust-trio div { display:flex; gap:var(--s3); align-items:center; font-size:0.85rem; }
.trust-trio svg { flex:0 0 20px; color:var(--success); }
.ship-est { font-size:0.825rem; color:var(--ink-soft); display:flex; gap:var(--s2); align-items:center; }

/* ---- 18. Comparison ---------------------------------------------------- */
.compare { width:100%; border-collapse:collapse; }
.compare th, .compare td { padding:var(--s4); text-align:center; border-bottom:1px solid var(--hairline); font-size:0.9rem; }
.compare th:first-child, .compare td:first-child { text-align:left; color:var(--ink-soft); }
.compare thead th { font-family:var(--f-display); font-weight:700; text-transform:uppercase; }
.compare .us { background:color-mix(in srgb,var(--accent) 9%, var(--bg)); color:var(--ink); }
.compare thead .us { color:var(--accent); }
.compare .yes { color:var(--success); font-weight:800; }
.compare .no { color:var(--muted); }

/* ---- 19. Reviews ------------------------------------------------------- */
.reviews-summary { display:grid; gap:var(--s8); align-items:center; }
@media (min-width:768px){ .reviews-summary{ grid-template-columns:auto 1fr; gap:var(--s16); } }
.rs-score { text-align:center; }
.rs-score .big { font-family:var(--f-display); font-weight:800; font-size:3.6rem; line-height:1; color:var(--accent); }
.rs-bars { display:grid; gap:6px; }
.rs-bar { display:grid; grid-template-columns:auto 1fr auto; gap:var(--s3); align-items:center; font-size:0.8rem; }
.rs-bar__track { height:7px; background:var(--hairline); border-radius:var(--r-pill); overflow:hidden; }
.rs-bar__fill { height:100%; background:var(--accent); }
.filter-chips { display:flex; gap:var(--s2); flex-wrap:wrap; justify-content:center; margin:var(--s8) 0; }
.chip { font-size:0.85rem; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; padding:10px 20px; border:1px solid var(--hairline); border-radius:var(--r-pill); color:var(--ink-soft); transition:border-color var(--d-micro), color var(--d-micro), background var(--d-micro); }
.chip:hover { border-color:var(--accent); color:var(--accent); }
.chip[aria-current="true"] { background:var(--accent); color:#fff; border-color:var(--accent); }
.review-grid { display:grid; gap:var(--s6); grid-template-columns:1fr; }
@media (min-width:768px){ .review-grid{ grid-template-columns:repeat(3,1fr); } }
.review { padding:var(--s6); border:1px solid var(--hairline); border-radius:var(--r-md); background:var(--bg-alt); }
.review__top { display:flex; justify-content:space-between; align-items:center; margin-bottom:var(--s2); }
.review__name { font-weight:700; font-size:0.9rem; }
.review__name span { font-weight:400; color:var(--success); font-size:0.75rem; margin-left:6px; }
.review p { font-size:0.92rem; color:var(--ink-soft); }
.review__photos { display:flex; gap:6px; margin-top:var(--s3); }
.review__photos img { width:64px; height:64px; object-fit:cover; border-radius:var(--r-sm); }

/* ---- 20. Media card / editorial --------------------------------------- */
.media-card { position:relative; border-radius:var(--r-md); overflow:hidden; min-height:340px; display:flex; align-items:flex-end; color:#fff; border:1px solid var(--hairline-2); }
.media-card img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.media-card__body { position:relative; padding:var(--s12); background:linear-gradient(transparent, rgba(0,0,0,.78)); width:100%; }
.media-card h3 { color:#fff; text-transform:uppercase; }
.media-card .eyebrow { color:var(--accent); }

/* full-bleed lifestyle band */
.lifestyle { position:relative; min-height:480px; display:flex; align-items:center; overflow:hidden; color:#fff; }
.lifestyle img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.lifestyle::after { content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(8,9,12,.88), rgba(8,9,12,.3) 70%, transparent); }
.lifestyle__inner { position:relative; z-index:2; max-width:34rem; }
.lifestyle h2 { color:#fff; text-transform:uppercase; font-size:clamp(2.2rem,5vw,3.6rem); }
.lifestyle h2 .accent { display:block; color:var(--accent); }
.lifestyle .lead { color:rgba(255,255,255,.85); }

/* ---- 21. Footer -------------------------------------------------------- */
.footer { background:var(--bg-deep); color:var(--ink-soft); padding-block:var(--s16) var(--s8); border-top:1px solid var(--hairline); }
.footer a:hover { color:var(--accent); }
.footer__grid { display:grid; gap:var(--s12); grid-template-columns:1fr; }
@media (min-width:760px){ .footer__grid{ grid-template-columns:1.6fr 1fr 1fr 1fr; } }
.footer h5 { font-family:var(--f-body); font-size:var(--fs-eyebrow); text-transform:uppercase; letter-spacing:0.14em; color:var(--muted); margin-bottom:var(--s4); }
.footer li { margin-bottom:var(--s2); font-size:0.9rem; }
.footer .brand { color:var(--ink); }
.footer__bottom { display:flex; flex-wrap:wrap; gap:var(--s4); justify-content:space-between; align-items:center; margin-top:var(--s12); padding-top:var(--s6); border-top:1px solid var(--hairline); font-size:0.78rem; color:var(--muted); }

/* ---- 22. Checkout ------------------------------------------------------ */
.checkout { display:grid; gap:0; min-height:100dvh; }
@media (min-width:900px){ .checkout{ grid-template-columns:1.1fr 0.9fr; } }
.checkout__main { padding:var(--s12) clamp(var(--s6),6vw,var(--s24)); }
.checkout__aside { background:var(--bg-alt); padding:var(--s12) clamp(var(--s6),5vw,var(--s16)); border-left:1px solid var(--hairline); }
.steps { display:flex; gap:var(--s2); align-items:center; font-size:0.78rem; color:var(--muted); margin-bottom:var(--s8); flex-wrap:wrap; text-transform:uppercase; letter-spacing:0.04em; }
.steps b { color:var(--ink); }
.steps .on { color:var(--accent); font-weight:700; }
.step { display:none; }
.step.active { display:block; animation:fade var(--d-reveal) var(--ease-out); }
@keyframes fade { from{opacity:0; transform:translateY(6px)} to{opacity:1; transform:none} }
.express { display:grid; gap:var(--s2); }
.express .btn { height:48px; }
.btn-applepay { background:#fff; color:#000; }
.btn-paypal { background:#FFC439; color:#003087; font-style:italic; font-weight:800; text-transform:none; letter-spacing:0; }
.btn-gpay { background:#fff; color:#3c4043; }
.pay-tabs { display:flex; gap:var(--s2); margin-bottom:var(--s4); }
.pay-tab { flex:1; padding:var(--s4); border:1.5px solid var(--hairline); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; gap:var(--s2); font-size:0.85rem; font-weight:700; }
.pay-tab[aria-current="true"] { border-color:var(--accent); color:var(--accent); }
.pay-pane { display:none; padding:var(--s6); border:1px solid var(--hairline); border-radius:var(--r-md); }
.pay-pane.active { display:block; }
.card-field { background:var(--bg); border:1px solid var(--hairline); border-radius:var(--r-md); padding:var(--s4); font-variant-numeric:tabular-nums; color:var(--muted); display:flex; justify-content:space-between; }
.sum-line { display:flex; justify-content:space-between; padding:var(--s2) 0; font-size:0.9rem; }
.sum-total { display:flex; justify-content:space-between; padding-top:var(--s4); margin-top:var(--s2); border-top:1px solid var(--hairline); font-family:var(--f-display); font-weight:800; font-size:1.3rem; }
.sum-items { display:grid; gap:var(--s4); margin-bottom:var(--s6); }
.sum-item { display:grid; grid-template-columns:56px 1fr auto; gap:var(--s3); align-items:center; }
.sum-item img { width:56px; height:70px; object-fit:cover; border-radius:var(--r-sm); }
.sum-item .t { font-size:0.85rem; font-weight:600; }
.sum-item .v { font-size:0.75rem; color:var(--muted); }
.sum-item .price { font-weight:600; }
.secure-note { font-size:0.78rem; color:var(--muted); display:flex; align-items:center; gap:6px; justify-content:center; margin-top:var(--s4); }

/* ---- 23. Confirmation -------------------------------------------------- */
.confirm { max-width:640px; margin-inline:auto; text-align:center; padding-block:var(--s24); }
.confirm__check { width:64px; height:64px; border-radius:50%; background:var(--accent); color:var(--accent-ink); display:grid; place-items:center; margin:0 auto var(--s6); }
.confirm__card { text-align:left; border:1px solid var(--hairline); border-radius:var(--r-md); padding:var(--s8); margin-top:var(--s8); background:var(--bg-alt); }
.upsell { border:1.5px solid var(--accent); border-radius:var(--r-md); padding:var(--s8); margin-top:var(--s12); text-align:left; display:grid; grid-template-columns:auto 1fr; gap:var(--s6); align-items:center; background:color-mix(in srgb,var(--accent) 5%, var(--bg-alt)); }
.upsell img { width:96px; height:120px; object-fit:cover; border-radius:var(--r-sm); }

/* ---- 24. Reveal / utilities ------------------------------------------- */
[data-reveal] { opacity:0; transform:translateY(22px); transition:opacity var(--d-section) var(--ease-out), transform var(--d-section) var(--ease-out); }
[data-reveal].in { opacity:1; transform:none; }
.hide-mobile { display:none; }
@media (min-width:768px){ .hide-mobile{ display:inline-flex; } .hide-desktop{ display:none; } }
.flow > * + * { margin-top:var(--s6); }

/* ---- 25. Authenticity Badge --------------------------------------------- */
.auth-badge {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: color-mix(in srgb, var(--accent) 8%, var(--bg-alt));
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  border-radius: var(--r-md);
  padding: 12px 14px;
  margin: 12px 0;
}
.auth-badge__icon {
  color: var(--accent);
  flex-shrink: 0;
  margin-top: 1px;
}
.auth-badge__title {
  display: block;
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--accent);
  letter-spacing: 0.02em;
}
.auth-badge__sub {
  display: block;
  font-size: 0.78rem;
  color: var(--ink-soft);
  margin-top: 2px;
  line-height: 1.5;
}

/* ---- 26. Size Guide Link + Modal --------------------------------------- */
.size-guide-link {
  background: none;
  border: none;
  color: var(--accent);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-family: inherit;
  transition: opacity .15s;
}
.size-guide-link:hover { opacity: .7; }

.sg-modal {
  position: fixed; inset: 0; z-index: 9000;
  display: flex; align-items: flex-end; justify-content: center;
  pointer-events: none; opacity: 0;
  transition: opacity .22s var(--ease-out);
}
@media (min-width: 600px) { .sg-modal { align-items: center; } }
.sg-modal.open { opacity: 1; pointer-events: all; }

.sg-modal__panel {
  background: var(--bg-alt);
  border: 1px solid var(--hairline);
  border-radius: 16px 16px 0 0;
  padding: 28px 24px 40px;
  width: 100%;
  max-width: 640px;
  max-height: 90vh;
  overflow-y: auto;
  transform: translateY(40px);
  transition: transform .28s var(--ease-out);
  position: relative; z-index: 1;
}
@media (min-width: 600px) {
  .sg-modal__panel { border-radius: 16px; transform: scale(.96); }
  .sg-modal.open .sg-modal__panel { transform: scale(1); }
}
.sg-modal.open .sg-modal__panel { transform: translateY(0); }

.sg-modal__head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px;
}
.sg-modal__head h3 {
  display: flex; align-items: center; gap: 10px;
  font-size: 1.2rem; margin: 0;
}
.sg-modal__note {
  font-size: 0.88rem; color: var(--ink-soft);
  border-left: 3px solid var(--accent);
  padding-left: 12px; margin-bottom: 20px; line-height: 1.6;
}

.sg-howto {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 24px;
}
.sg-howto > div {
  background: var(--bg-card); border: 1px solid var(--hairline);
  border-radius: 10px; padding: 16px; text-align: center;
}
.sg-howto svg { color: var(--accent); margin-bottom: 8px; }
.sg-howto b { display: block; font-size: 0.95rem; margin-bottom: 4px; }
.sg-howto p { font-size: 0.78rem; color: var(--ink-soft); margin: 0; line-height: 1.5; }

.sg-table-wrap { overflow-x: auto; border-radius: 10px; border: 1px solid var(--hairline); }
.sg-table { width: 100%; border-collapse: collapse; font-size: 0.88rem; }
.sg-table thead { background: var(--bg-deep); }
.sg-table th {
  padding: 10px 16px; text-align: left;
  font-size: 0.75rem; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: var(--ink-soft);
  border-bottom: 1px solid var(--hairline);
}
.sg-table td { padding: 12px 16px; border-bottom: 1px solid var(--hairline-2); }
.sg-table tr:last-child td { border-bottom: none; }
.sg-table tr:hover td { background: color-mix(in srgb, var(--accent) 4%, transparent); }
.sg-table .sg-size {
  font-weight: 800; font-size: 1rem;
  color: var(--accent); letter-spacing: .03em;
}

.sg-brand {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 20px; padding-top: 16px;
  border-top: 1px solid var(--hairline);
  font-size: 0.82rem;
}
.sg-brand span:first-child { font-family: var(--f-display); font-weight: 700; font-size: 1rem; }

.sg-backdrop {
  position: fixed; inset: 0; z-index: 8999;
  background: rgba(0,0,0,.7);
  opacity: 0; pointer-events: none;
  transition: opacity .22s var(--ease-out);
}
.sg-backdrop.open { opacity: 1; pointer-events: all; }

/* ---- also: surface-2 / border aliases for shop.html -------------------- */
:root {
  --surface:   var(--bg);
  --surface-2: var(--bg-alt);
  --border:    var(--hairline);
}

/* ---- Products light band ------------------------------------------------ */
.products-band {
  background: #F5F2EC;
  padding: 0 0 80px;
}
.products-band .coll-toolbar {
  border-bottom-color: rgba(0,0,0,0.12);
}
.products-band .coll-chips .chip {
  background: #fff;
  border-color: rgba(0,0,0,0.15);
  color: #444;
}
.products-band .coll-chips .chip:hover,
.products-band .coll-chips .chip[aria-current="true"] {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.products-band .prod-count { color: #666; }
.products-band .sort-select {
  background: #fff;
  border-color: rgba(0,0,0,0.15);
  color: #111;
}
.products-band .card__media {
  background: #fff;
  border-color: rgba(0,0,0,0.09);
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}
.products-band .card:hover .card__media {
  border-color: var(--accent);
  box-shadow: 0 4px 24px rgba(0,0,0,0.14);
}
.products-band .card__title { color: #111318; }
.products-band .card__desc  { color: #666; }
.products-band .card__price { color: #111318; }
.products-band .price-was   { color: #999; }
.products-band .badge--soft {
  background: rgba(0,0,0,0.06);
  border-color: transparent;
  color: #444;
}
.products-band .bundle-cta .bcta-card {
  background: #1a1c24;
}


/* ── Review author / avatar ──────────────────────────────── */
.review__author {
  display: flex;
  align-items: center;
  gap: 10px;
}
.review__av {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  letter-spacing: 0.03em;
}
.review__jersey {
  font-size: 0.7rem;
  color: var(--ink-soft);
  margin-top: 1px;
}

/* ── Team filter row ─────────────────────────────────────── */
.team-filter-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 16px 0 0;
  flex-wrap: wrap;
}
.team-filter-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
  flex-shrink: 0;
  padding-top: 6px;
}
.team-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.chip--team {
  font-size: 0.72rem;
  padding: 4px 10px;
  border-radius: 20px;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--ink-soft);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.chip--team:hover,
.chip--team-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  font-weight: 600;
}
.products-band .chip--team {
  border-color: rgba(0,0,0,0.18);
  color: #555;
}
.products-band .chip--team:hover,
.products-band .chip--team-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

/* ── Payment logos ───────────────────────────────────────── */
.pay-icon {
  width: 40px;
  height: 26px;
  border-radius: 4px;
  display: inline-block;
  vertical-align: middle;
}
.pay-icons--row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  margin-top: 10px;
}
.co-pay-logos {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation-duration:0.001ms !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
  [data-reveal]{ opacity:1; transform:none; }
}

/* ============================================================================
   MATCHDAY — elevation layer (payments, social proof, policy, micro-interactions)
   Appended; uses existing brand tokens only (dark theme + lime accent).
   ========================================================================== */

/* ---- Stripe Payment Element host + states ---- */
#stripe-payment-element { margin:6px 0 4px; min-height:48px; }
.pay-skeleton { display:grid; gap:10px; }
.pay-skeleton span {
  display:block; height:46px; border-radius:var(--r-md);
  background:linear-gradient(100deg, rgba(243,241,236,0.05) 30%, rgba(243,241,236,0.11) 50%, rgba(243,241,236,0.05) 70%);
  background-size:200% 100%; animation:pay-shimmer 1.3s ease-in-out infinite;
}
.pay-skeleton span:first-child { height:38px; }
@keyframes pay-shimmer { 0%{ background-position:200% 0; } 100%{ background-position:-200% 0; } }
.pay-error {
  margin:12px 0; padding:10px 14px; border-radius:var(--r-md); font-size:0.85rem; font-weight:600;
  color:var(--danger); background:color-mix(in srgb, var(--danger) 12%, transparent);
  border:1px solid color-mix(in srgb, var(--danger) 40%, transparent);
}
.pay-note--testmode {
  color:var(--accent); font-weight:600;
}
.btn.is-busy { opacity:0.75; cursor:progress; }

/* ---- Express wallet buttons: tighten to premium, recognisable shape ---- */
.express { grid-template-columns:1fr 1fr; gap:var(--s2); }
.express .btn { height:50px; font-weight:700; border-radius:var(--r-md); }
.express .btn-applepay { background:#000; color:#fff; border:1px solid #000; }
.express .btn-gpay { background:#fff; color:#3c4043; border:1px solid #dadce0; }
.express .btn-shoppay { background:#5a31f4; color:#fff; border:1px solid #5a31f4; }
.express .btn svg { display:inline-block; vertical-align:middle; }
.gpay-mark b { font-weight:700; }
@media (max-width:390px){ .express { grid-template-columns:1fr; } }

/* ---- Express-checkout lead label + helper foot (Step 1) ---- */
.express__lead {
  font-size:0.7rem; text-transform:uppercase; letter-spacing:0.12em;
  font-weight:700; color:var(--ink-soft); margin-bottom:var(--s3);
}
.express-foot { font-size:0.74rem; color:var(--muted); text-align:center; margin-top:var(--s3); }

/* ---- Promo / discount-code row (order summary) ---- */
.promo-row { display:flex; gap:var(--s2); margin-bottom:var(--s4); }
.promo-row .input { flex:1; }
.promo-msg { font-size:0.76rem; margin:-8px 0 var(--s4); min-height:1em; }
.promo-msg.ok { color:var(--success); }
.promo-msg.err { color:var(--danger); }

/* PayPal SDK button container spacing */
#paypal-button-container:not(:empty) { margin-bottom:8px; }
#paypal-button-container:not(:empty) + #pay-paypal-btn { display:none; } /* SDK rendered → hide fallback */

/* ---- Stripe Express Checkout Element host (Apple/Google Pay, Link, Amazon Pay, PayPal) ---- */
.express-ece { margin:0 0 12px; }
.express-ece[hidden] { display:none; }

/* ---- "Also accepted" logo / chip strip ---- */
.also-accepted-label {
  margin:18px 0 8px; font-size:0.7rem; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--ink-soft); text-align:center;
}
.also-accepted {
  display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-bottom:4px;
}
.aa-chip {
  display:inline-flex; align-items:center; gap:5px;
  padding:5px 10px; border-radius:var(--r-sm);
  background:rgba(243,241,236,0.05); border:1px solid var(--hairline);
  font-size:0.72rem; font-weight:700; color:var(--ink-soft); white-space:nowrap;
}
.aa-chip svg { flex:none; }
.aa-cashapp { color:#00d54b; border-color:rgba(0,213,75,0.35); }
.aa-crypto { color:#26a17b; border-color:rgba(38,161,123,0.35); }

/* ---- Trust badges row ---- */
.trust-badges {
  margin-top:18px; display:flex; flex-direction:column; gap:8px;
  padding-top:16px; border-top:1px solid var(--hairline);
}
.trust-badge {
  display:flex; align-items:center; gap:8px; justify-content:center;
  font-size:0.78rem; color:var(--ink-soft); font-weight:500; text-align:center;
}
.trust-badge svg { flex:none; color:var(--accent); }
.trust-badge--stars .stars { color:var(--gold,#f5c542); letter-spacing:1px; font-size:0.85rem; }

/* ---- Checkout: always-visible order summary on mobile ---- */
.co-msummary {
  display:none; position:sticky; top:76px; z-index:30;
  background:var(--bg-alt); border-bottom:1px solid var(--hairline);
  padding:12px clamp(var(--s4),5vw,var(--s8));
}
.co-msummary__bar {
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:10px;
  background:none; color:var(--ink); font-weight:600; font-size:0.92rem;
}
.co-msummary__bar .chev { transition:transform var(--d-micro) var(--ease-io); color:var(--ink-soft); }
.co-msummary.open .co-msummary__bar .chev { transform:rotate(180deg); }
.co-msummary__total { font-family:var(--f-display); font-weight:700; }
.co-msummary__total b { color:var(--accent); }
.co-msummary__panel { max-height:0; overflow:hidden; transition:max-height var(--d-reveal) var(--ease-io); }
.co-msummary.open .co-msummary__panel { max-height:60vh; overflow:auto; margin-top:12px; }
@media (max-width:899px){
  .co-msummary { display:block; }
  .checkout__aside { display:none; }       /* desktop aside hidden on mobile; msummary replaces it */
}

/* ---- Trust stats strip (home) ---- */
.trust-stats {
  display:grid; grid-template-columns:1fr; gap:var(--s4);
  border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:var(--s6); background:var(--bg-alt);
}
.trust-stat { display:flex; align-items:center; gap:12px; }
.trust-stat svg { flex:none; }
.trust-stat b { display:block; font-family:var(--f-display); font-size:1rem; }
.trust-stat span { font-size:0.82rem; color:var(--ink-soft); }
@media (min-width:760px){ .trust-stats { grid-template-columns:repeat(4,1fr); gap:var(--s8); } .trust-stat { flex-direction:column; text-align:center; gap:8px; } }

/* ---- PDP scarcity cue ---- */
.stock-cue {
  display:inline-flex; align-items:center; gap:9px; margin:10px 0 2px;
  font-size:0.86rem; color:var(--ink-soft);
}
.stock-cue b { color:var(--ink); }
.stock-cue__pulse {
  width:9px; height:9px; border-radius:50%; background:var(--accent); flex:none;
  box-shadow:0 0 0 0 rgba(16,185,129,0.6); animation:stock-pulse 2s infinite;
}
@keyframes stock-pulse {
  0%{ box-shadow:0 0 0 0 rgba(16,185,129,0.5); } 70%{ box-shadow:0 0 0 8px rgba(16,185,129,0); } 100%{ box-shadow:0 0 0 0 rgba(16,185,129,0); }
}

/* ---- Recent-purchase social-proof toast ---- */
.sp-toast {
  position:fixed; left:16px; bottom:16px; z-index:80; max-width:340px;
  display:flex; align-items:center; gap:12px;
  background:color-mix(in srgb, var(--bg-card) 96%, transparent);
  backdrop-filter:blur(10px);
  border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:12px 40px 12px 14px; box-shadow:var(--shadow-overlay);
  transform:translateY(140%); opacity:0; transition:transform var(--d-reveal) var(--ease-out), opacity var(--d-reveal);
}
.sp-toast.show { transform:translateY(0); opacity:1; }
.sp-toast__dot { width:8px; height:8px; border-radius:50%; background:var(--accent); flex:none; }
.sp-toast__body { font-size:0.82rem; line-height:1.35; color:var(--ink-soft); }
.sp-toast__body b { color:var(--ink); font-weight:600; }
.sp-toast__time { display:block; margin-top:3px; font-size:0.7rem; color:var(--muted); }
.sp-toast__x { position:absolute; top:8px; right:10px; font-size:1.1rem; line-height:1; color:var(--muted); }
.sp-toast__x:hover { color:var(--ink); }
@media (max-width:520px){ .sp-toast { left:10px; right:10px; bottom:10px; max-width:none; } }

/* ---- Cookie consent ---- */
.cookie-bar {
  position:fixed; left:0; right:0; bottom:0; z-index:120;
  background:color-mix(in srgb, var(--bg-deep) 96%, transparent);
  backdrop-filter:blur(12px); border-top:1px solid var(--hairline);
  transform:translateY(110%); transition:transform var(--d-reveal) var(--ease-out);
}
.cookie-bar.show { transform:translateY(0); }
.cookie-bar__in {
  max-width:1200px; margin:0 auto; padding:16px clamp(var(--s4),5vw,var(--s8));
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.cookie-bar p { font-size:0.83rem; color:var(--ink-soft); margin:0; max-width:60ch; }
.cookie-bar__btns { display:flex; gap:10px; flex:none; }
@media (max-width:640px){ .cookie-bar__btns { width:100%; } .cookie-bar__btns .btn { flex:1; } }

/* ---- Footer legal links (minimal footers) ---- */
.footer__legal-links { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; align-items:center; }
.footer__legal-links a { color:var(--ink-soft); font-size:0.85rem; }
.footer__legal-links a:hover { color:var(--accent); }
.footer__legal-links span { color:var(--muted); }

/* ---- Legal / policy pages ---- */
.legal { padding:clamp(var(--s12),7vw,var(--s24)) 0; }
.legal__inner { max-width:760px; }
.legal__bc { margin-bottom:var(--s6); }
.legal h1 { margin:6px 0 12px; }
.legal h2 { font-size:1.25rem; margin:var(--s8) 0 var(--s3); }
.legal p, .legal li { color:var(--ink-soft); line-height:1.65; }
.legal p { margin-bottom:var(--s3); }
.legal ul, .legal ol { margin:0 0 var(--s4) 1.1em; display:grid; gap:6px; }
.legal li { padding-left:2px; }
.legal a { color:var(--accent); }
.legal__updated { margin-top:var(--s8); padding-top:var(--s4); border-top:1px solid var(--hairline); font-size:0.8rem; color:var(--muted); }
.legal__cards { display:grid; grid-template-columns:1fr; gap:var(--s4); margin:var(--s6) 0 var(--s8); }
.legal__card { border:1px solid var(--hairline); border-radius:var(--r-md); padding:var(--s4) var(--s6); background:var(--bg-alt); }
.legal__card b { display:block; font-family:var(--f-display); color:var(--accent); margin-bottom:4px; }
.legal__card p { margin:0; font-size:0.88rem; }
@media (min-width:680px){ .legal__cards { grid-template-columns:repeat(3,1fr); } }

/* ---- Premium micro-interactions: featured media + card lift ---- */
#featured-media { overflow:hidden; }
#featured-media img { transition:transform var(--d-section) var(--ease-out); }
#featured-media:hover img { transform:scale(1.03); }

/* subtle accent underline sweep on section headings with eyebrow */
.section-head .eyebrow { position:relative; }

/* ---- Shipping Protection toggle ---- */
.ship-protect { border-top:1px solid var(--hairline); padding:14px 20px; }
.sp-row { display:flex; align-items:center; gap:10px; cursor:pointer; }
.sp-row input { display:none; }
.sp-cb { width:18px; height:18px; border:2px solid var(--hairline); border-radius:4px; flex-shrink:0; display:grid; place-items:center; transition:background .15s, border-color .15s; }
.sp-row:has(input:checked) .sp-cb { background:var(--accent); border-color:var(--accent); }
.sp-row:has(input:checked) .sp-cb::after { content:"✓"; color:#fff; font-size:11px; font-weight:700; line-height:1; }
.sp-copy { flex:1; }
.sp-copy strong { display:block; font-size:.85rem; font-weight:600; }
.sp-copy span { font-size:.78rem; color:var(--muted); }
/* ---- Checkout order bump ---- */
.ob-protect { margin:16px 0; }
.ob-protect__card { display:flex; align-items:center; gap:12px; padding:14px 16px; border:2px solid var(--accent); border-radius:var(--r-md); cursor:pointer; background:color-mix(in srgb, var(--accent) 8%, transparent); }
.ob-protect__card input { display:none; }
.ob-protect__icon { font-size:1.4rem; flex-shrink:0; }
.ob-protect__text { flex:1; }
.ob-protect__text strong { display:block; font-weight:600; font-size:.9rem; }
.ob-protect__text span { font-size:.8rem; color:var(--muted); }
.ob-protect__price { font-weight:700; color:var(--accent); white-space:nowrap; }

