/* =================================================================
   RACKET INDEX by Padel Haze — Award-grade redesign
   Design system + components + motion
   ================================================================= */

:root{
  /* "Cork & Forest" warm palette (light is primary) */
  --ink:        #FAF8F3;   /* warm-white canvas */
  --ink-soft:   #F2EAD8;   /* beige — alt sections */
  --ink-card:   #E8D9BC;   /* sand — surfaces / cards */
  --paper:      #111209;   /* dark ink — body text */
  --paper-dim:  #6E6C5B;   /* muted ink */
  --volt:       #C8A96A;   /* cork — the one strong accent / fills */
  --cyan:       #1A2C1E;   /* forest green — deep / secondary */
  --bar:        #1A2C1E;   /* forest green — spec-bar fill (high contrast on light cards) */
  --coral:      #B5683C;   /* warm terracotta (sparing) */
  --line:       rgba(17,18,9,.12);
  --line-2:     rgba(17,18,9,.22);

  --accent-text:#1A2C1E;   /* forest — readable accent labels on light */
  --cmp-a:      #1A2C1E;   /* compare A bar (forest) */
  --cmp-b:      #C8A96A;   /* compare B bar (cork) */
  --link-soft:  #4A4B3E;   /* footer links */
  --hover:      #1A2C1E;   /* link hover */
  --opt-hover:  #E0D2B4;   /* sand-darker option hover */
  --stuck:      rgba(250,248,243,.72);  /* stuck nav bg */
  --stroke:     rgba(17,18,9,.3);       /* marquee outline */

  --font-display: "Clash Display", "Satoshi", sans-serif;
  --font-body:    "Satoshi", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, monospace;

  --ease: cubic-bezier(.16,1,.3,1);
  --ease-2: cubic-bezier(.7,0,.2,1);

  --pad: clamp(20px, 5vw, 90px);
  --maxw: 1640px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--ink);
  color:var(--paper);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  cursor:none;
}
@media (hover:none){ body{ cursor:auto; } }

a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:none; }
img{ display:block; max-width:100%; }
::selection{ background:var(--volt); color:var(--ink); }

/* lenis */
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

/* ░░ Grain ░░ */
.grain{
  position:fixed; inset:0; z-index:9000; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ░░ Custom cursor ░░ */
.cursor{ position:fixed; top:0; left:0; z-index:9999; pointer-events:none; mix-blend-mode:difference; }
.cursor__dot{
  position:fixed; top:0; left:0; width:7px; height:7px; border-radius:50%;
  background:var(--paper); transform:translate(-50%,-50%);
}
.cursor__ring{
  position:fixed; top:0; left:0; width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(242,238,228,.6); transform:translate(-50%,-50%);
  transition:width .35s var(--ease), height .35s var(--ease), background .35s, border-color .35s;
}
.cursor__label{
  position:fixed; top:0; left:0; transform:translate(-50%,-50%);
  font-family:var(--font-mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink); opacity:0; white-space:nowrap; font-weight:700;
}
body.cursor-hover .cursor__ring{ width:74px; height:74px; background:var(--volt); border-color:transparent; }
body.cursor-hover .cursor__label{ opacity:1; }
body.cursor-down .cursor__ring{ width:26px; height:26px; }

/* ░░ Preloader ░░ */
.preloader{
  position:fixed; inset:0; z-index:10000; background:var(--ink);
  display:grid; place-items:center;
}
.preloader__inner{ width:min(78vw,460px); text-align:center; }
.preloader__mark{
  font-family:var(--font-display); font-weight:600; letter-spacing:.12em;
  font-size:clamp(22px,4vw,30px); color:var(--paper); margin-bottom:8px;
  opacity:0; transform:translateY(14px);
}
.preloader__by{
  font-family:var(--font-mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--volt); margin-bottom:24px;
}
.preloader__bar{ height:2px; width:100%; background:var(--line-2); overflow:hidden; border-radius:2px; }
.preloader__fill{ display:block; height:100%; width:0%; background:var(--volt); }
.preloader__count{
  margin-top:18px; font-family:var(--font-mono); font-size:13px; color:var(--paper-dim);
  display:flex; justify-content:flex-end; gap:1px;
}
.preloader__count i{ font-style:normal; }
.preloader__tag{
  margin-top:8px; font-family:var(--font-mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--volt); text-align:left; opacity:.0;
}

/* ░░ Scroll progress ░░ */
.scrollbar{ position:fixed; top:0; left:0; right:0; height:2px; z-index:8000; background:transparent; }
.scrollbar__fill{ display:block; height:100%; width:0%; background:linear-gradient(90deg,var(--volt),var(--cyan)); }

/* ░░ Buttons ░░ */
.btn{
  position:relative; display:inline-flex; align-items:center; gap:10px;
  font-weight:700; font-size:15px; letter-spacing:.01em;
  padding:16px 26px; border-radius:100px; overflow:hidden; white-space:nowrap;
  transition:color .4s var(--ease), transform .4s var(--ease);
}
.btn svg{ transition:transform .4s var(--ease); }
.btn--primary{ background:var(--volt); color:var(--ink); }
.btn--primary::before{
  content:""; position:absolute; inset:0; background:var(--paper);
  transform:translateY(101%); transition:transform .5s var(--ease); z-index:-1;
}
.btn--primary:hover::before{ transform:translateY(0); }
.btn--primary:hover svg{ transform:translateX(5px); }
.btn--ghost{ border:1px solid var(--line-2); color:var(--paper); }
.btn--ghost::before{
  content:""; position:absolute; inset:0; background:var(--paper); z-index:-1;
  transform:translateY(101%); transition:transform .5s var(--ease);
}
.btn--ghost:hover{ color:var(--ink); border-color:var(--paper); }
.btn--ghost:hover::before{ transform:translateY(0); }
.btn--mini{ padding:11px 18px; font-size:13px; background:var(--paper); color:var(--ink); }
.btn--mini::before{ content:""; position:absolute; inset:0; background:var(--volt); transform:translateY(101%); transition:transform .45s var(--ease); z-index:-1; }
.btn--mini:hover::before{ transform:translateY(0); }

/* ░░ Navigation ░░ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:7000;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px var(--pad); transition:padding .4s var(--ease), background .4s, backdrop-filter .4s;
}
.nav.is-stuck{ padding:14px var(--pad); background:rgba(8,9,11,.6); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); }
.nav__logo{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:600; font-size:19px; letter-spacing:-.01em; }
.nav__logo-lockup{ display:flex; flex-direction:column; line-height:1; gap:3px; }
.nav__logo-by{ font-family:var(--font-mono); font-weight:500; font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-dim); }
.nav__logo-mark{
  width:13px; height:13px; border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--volt), #7d9a18);
  box-shadow:0 0 18px rgba(215,255,62,.7); position:relative;
}
.nav__logo-mark::after{ content:""; position:absolute; inset:0; border-radius:50%; border:1px solid rgba(8,9,11,.5); }
.beta{ font-family:var(--font-mono); font-style:normal; font-size:9px; letter-spacing:.08em; color:var(--ink); background:var(--cyan); padding:2px 5px; border-radius:4px; }
@media (max-width:600px){ .nav .btn--mini{ display:none; } }

/* top bar right cluster: CTA + burger (burger is the menu on ALL viewports) */
.nav__bar{ display:flex; align-items:center; gap:14px; }
/* quick-access login / account icon in the top bar */
.nav__login{ display:flex; align-items:center; justify-content:center; width:38px; height:38px; flex:0 0 auto; border:1px solid var(--line); border-radius:50%; color:var(--paper); transition:border-color .3s, color .3s, background .3s; }
.nav__login:hover{ border-color:var(--volt); color:var(--volt); }
.nav__login-ico{ display:flex; align-items:center; justify-content:center; line-height:1; }
.nav__login.is-auth{ background:var(--volt); color:#111209; border-color:transparent; font-family:var(--font-mono); font-weight:700; font-size:14px; }
.nav__burger{ display:flex; flex-direction:column; justify-content:center; gap:5px; width:34px; height:22px; position:relative; z-index:7100; }
.nav__burger span{ height:1.5px; background:var(--paper); width:100%; transition:transform .3s var(--ease), background .3s; }
body.menu-open .nav__burger span:nth-child(1){ transform:translateY(3.25px) rotate(45deg); }
body.menu-open .nav__burger span:nth-child(2){ transform:translateY(-3.25px) rotate(-45deg); }
body.menu-open{ overflow:hidden; }

/* full-screen menu overlay (sized in viewport units so a backdrop-filter
   containing block on the stuck nav can't shrink it) */
.nav__menu{
  position:fixed; top:0; left:0; width:100vw; height:100vh; height:100dvh; z-index:7050;
  display:flex; flex-direction:column; justify-content:center; gap:clamp(28px,5vh,56px);
  padding:max(96px,13vh) var(--pad) max(36px,7vh);
  background:var(--ink);
  transform:translateY(-100%); visibility:hidden; opacity:0;
  transition:transform .7s var(--ease), opacity .4s ease, visibility 0s linear .7s;
}
body.menu-open .nav__menu{ transform:translateY(0); visibility:visible; opacity:1; transition:transform .7s var(--ease), opacity .4s ease; }
.nav__links{ display:flex; flex-direction:column; align-items:flex-start; gap:2px; }
.nav__link{ position:relative; display:flex; align-items:center; gap:12px; padding:6px 0; color:var(--paper); font-family:var(--font-display); font-weight:600; font-size:clamp(32px,7vw,66px); line-height:1.06; transition:color .3s; }
.nav__link:hover{ color:var(--volt); }
.nav__link .beta{ font-size:11px; align-self:center; }
.nav__menu-foot{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; border-top:1px solid var(--line); padding-top:clamp(20px,3vh,30px); }
.nav__prefs{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.nav__theme{ display:inline-flex; align-items:center; justify-content:center; gap:9px; border:1px solid var(--line); border-radius:100px; padding:9px 16px; color:var(--paper); transition:border-color .3s, color .3s; }
.nav__theme:hover{ border-color:var(--volt); color:var(--volt); }
.nav__theme svg{ width:16px; height:16px; flex:0 0 auto; }
.nav__theme-label{ font-size:13px; }
.nav__theme .icon-moon{ display:none; }
[data-theme="light"] .nav__theme .icon-sun{ display:none; }
[data-theme="light"] .nav__theme .icon-moon{ display:block; }
.nav__lang{ display:inline-flex; gap:4px; border:1px solid var(--line); border-radius:100px; padding:4px; }
.nav__lang button{ font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; padding:6px 12px; border-radius:100px; color:var(--paper-dim); transition:.25s; }
.nav__lang button:hover{ color:var(--paper); }
.nav__lang button.is-active{ background:var(--volt); color:#111209; }

/* ░░ HERO ░░ */
.hero{ position:relative; height:100svh; min-height:660px; overflow:hidden; display:flex; align-items:center; }
.hero__canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:1; }
.hero::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    linear-gradient(95deg, rgba(8,9,11,.94) 0%, rgba(8,9,11,.82) 28%, rgba(8,9,11,.35) 55%, transparent 78%),
    linear-gradient(0deg, rgba(8,9,11,.8) 0%, transparent 30%);
}
.hero__court{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(120% 90% at 50% 120%, rgba(22,224,200,.10), transparent 60%),
    radial-gradient(80% 60% at 80% -10%, rgba(215,255,62,.08), transparent 60%),
    var(--ink);
}
.hero__court::after{
  content:""; position:absolute; inset:0;
  background-image:url("../assets/img/hero-court.png");
  background-size:cover; background-position:center 70%;
  opacity:.34; mix-blend-mode:screen;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 40%,#000 70%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 40%,#000 70%,transparent);
}
/* real rotating padel ball */
.hero__ball{
  position:absolute; z-index:2; pointer-events:none;
  width:min(28vw,380px); aspect-ratio:1/1;
  right:5%; bottom:6%;
  /* screen blend on the WRAPPER (not the video) blends the whole ball group with the court
     behind it → the black background drops out while the full ball is preserved (no eaten
     felt, no fringe). Putting it here (not on the video) avoids the z-index stacking-context
     isolation that previously caused a dark square. */
  mix-blend-mode:screen;
}
.hero__ball-glow{
  position:absolute; inset:-6%;
  background:radial-gradient(circle at 50% 50%, rgba(215,255,62,.20), rgba(22,224,200,.08) 42%, transparent 66%);
  filter:blur(14px);
}
.hero__ball-video{
  position:relative; width:100%; height:100%; object-fit:contain; display:block;
  /* mask hugs the ball edge so the screen blend only affects the ball, not the surrounding court */
  -webkit-mask-image:radial-gradient(circle at 50% 50%, #000 55%, transparent 60%);
          mask-image:radial-gradient(circle at 50% 50%, #000 55%, transparent 60%);
}

.hero__content{ position:relative; z-index:3; padding:0 var(--pad); max-width:1180px; }
.hero__eyebrow{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--volt); margin-bottom:clamp(14px,2.4vh,24px); display:flex; align-items:center; gap:12px;
}
.hero__eyebrow::before{ content:""; width:42px; height:1px; background:var(--volt); display:inline-block; }
.hero__title{
  font-family:var(--font-display); font-weight:600; line-height:.92; letter-spacing:-.03em;
  /* cap by viewport HEIGHT too so the (tall) block never collides with the fixed nav */
  font-size:clamp(48px, min(12vw, 15vh), 184px); text-transform:none;
}
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .w{ display:inline-block; }
.hero__title .outline{ -webkit-text-stroke:1.4px var(--paper); color:transparent; }
.hero__title .accent{ color:var(--volt); font-style:italic; font-weight:500; }
.hero__title .dot{ color:var(--cyan); display:inline-block; }
/* French words run longer — ease the scale so the hero breathes and stays inside the column */
html[lang="fr"] .hero__title{ font-size:clamp(44px, min(9.5vw, 12vh), 130px); }
html[lang="fr"] .hero__sub{ max-width:480px; }
.hero__sub{ max-width:520px; margin-top:clamp(18px,3vh,34px); font-size:clamp(16px,1.4vw,20px); color:#C9CBC5; line-height:1.55; }
.hero__cta{ display:flex; gap:14px; margin-top:clamp(22px,3.4vh,40px); flex-wrap:wrap; }

.hero__meta{
  position:absolute; z-index:3; top:50%; font-family:var(--font-mono); font-size:11px;
  letter-spacing:.16em; color:var(--paper-dim); display:flex; align-items:center; gap:8px;
}
.hero__meta--left{ left:var(--pad); transform:translateY(-50%) rotate(-90deg); transform-origin:left center; }
.hero__meta--right{ right:var(--pad); transform:translateY(-50%) rotate(90deg); transform-origin:right center; }
.hero__meta .tick{ color:var(--volt); animation:blink 2s infinite; }
@keyframes blink{ 0%,100%{opacity:1;} 50%{opacity:.25;} }
/* leave a left gutter for the rotated meta strip (shown >860px) so it never overlaps the title */
@media (min-width:861px){ .hero__content{ padding-left:calc(var(--pad) + 58px); } }

.hero__scroll{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:10px; font-family:var(--font-mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--paper-dim); }
.hero__scroll-line{ width:1px; height:48px; background:var(--line-2); overflow:hidden; position:relative; }
.hero__scroll-line i{ position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--volt); animation:scrolldown 1.8s var(--ease) infinite; }
@keyframes scrolldown{ 0%{transform:translateY(-100%);} 60%,100%{transform:translateY(300%);} }

/* ░░ Marquee ░░ */
.marquee{ border-block:1px solid var(--line); overflow:hidden; padding:26px 0; background:var(--ink-soft); }
.marquee__track{ display:flex; align-items:center; gap:42px; white-space:nowrap; width:max-content; will-change:transform; }
.marquee__track span{ font-family:var(--font-display); font-weight:500; font-size:clamp(26px,4vw,52px); letter-spacing:-.02em; text-transform:uppercase; color:transparent; -webkit-text-stroke:1px rgba(242,238,228,.35); }
.marquee__track b{ color:var(--volt); font-size:18px; }

/* ░░ Section primitives ░░ */
.kicker{ font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--volt); display:inline-flex; align-items:center; gap:8px; }
.section-head{ padding:0 var(--pad); max-width:var(--maxw); margin:0 auto; }
.section-head--center{ text-align:center; display:flex; flex-direction:column; align-items:center; }
.section-title{ font-family:var(--font-display); font-weight:600; letter-spacing:-.03em; line-height:.95; font-size:clamp(40px,7vw,108px); margin:18px 0 14px; }
.section-lead{ color:var(--paper-dim); font-size:clamp(15px,1.3vw,18px); max-width:560px; }
.section-lead em{ color:var(--paper); font-style:italic; }

/* ░░ INTRO ░░ */
.intro{ padding:clamp(90px,14vh,180px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.intro__index{ margin-bottom:40px; }
.intro__statement{
  font-family:var(--font-display); font-weight:500; letter-spacing:-.025em; line-height:1.06;
  font-size:clamp(28px,4.6vw,74px); max-width:18ch;
}
.intro__statement em{ color:var(--volt); font-style:italic; }
.intro__foot{ display:grid; grid-template-columns:repeat(3,1fr); gap:34px; margin-top:90px; padding-top:42px; border-top:1px solid var(--line); }
.intro__col .num{ font-family:var(--font-mono); font-size:13px; color:var(--cyan); }
.intro__col h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(20px,2vw,28px); margin:14px 0 10px; }
.intro__col p{ color:var(--paper-dim); font-size:15px; max-width:34ch; }

/* ░░ LINEUP ░░ */
.lineup{ padding:clamp(70px,9vh,120px) 0; overflow:hidden; }
.lineup .section-head{ margin-bottom:48px; }
.lineup__viewport{ width:100%; cursor:grab; }
.lineup__viewport.is-drag{ cursor:grabbing; }
.lineup__track{ display:flex; gap:26px; padding:0 var(--pad); width:max-content; will-change:transform; }
/* mobile/touch: native momentum scroll + snap instead of the JS transform drag */
.lineup__viewport--native{ overflow-x:auto; overflow-y:hidden; -webkit-overflow-scrolling:touch; scroll-snap-type:x proximity; scroll-padding-left:var(--pad); cursor:auto; scrollbar-width:none; -ms-overflow-style:none; }
.lineup__viewport--native::-webkit-scrollbar{ display:none; }
.lineup__viewport--native .lineup__track{ transform:none !important; will-change:auto; }
.lineup__viewport--native .rcard{ scroll-snap-align:start; }
.rcard{
  position:relative; width:clamp(280px,30vw,400px); flex:0 0 auto;
  background:var(--ink-card); border:1px solid var(--line); border-radius:22px; overflow:hidden;
  transition:border-color .4s var(--ease), transform .5s var(--ease);
}
.rcard:hover{ border-color:var(--line-2); }
.rcard__media{ position:relative; aspect-ratio:4/4.4; overflow:hidden; background:radial-gradient(120% 90% at 50% 40%, #1b1e25, #0b0c10); }
.rcard__glow{ position:absolute; inset:0; opacity:.5; mix-blend-mode:screen; transition:opacity .5s; }
.rcard__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; padding:14% 12% 8%; transition:transform .7s var(--ease); will-change:transform; }
.rcard:hover .rcard__img{ transform:scale(1.06) translateY(-2%); }
.rcard__rank{ position:absolute; top:16px; left:16px; font-family:var(--font-mono); font-size:11px; color:var(--paper-dim); letter-spacing:.1em; }
.rcard__score{ position:absolute; top:14px; right:16px; text-align:right; }
.rcard__score b{ font-family:var(--font-display); font-weight:600; font-size:34px; line-height:1; color:var(--paper); }
.rcard__score i{ font-style:normal; font-family:var(--font-mono); font-size:10px; color:var(--paper-dim); display:block; margin-top:2px; }
.rcard__body{ padding:22px; }
.rcard__shape{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-text); }
.rcard__name{ font-family:var(--font-display); font-weight:600; font-size:24px; margin:8px 0 12px; letter-spacing:-.01em; }
.rcard__blurb{ color:var(--paper-dim); font-size:13.5px; line-height:1.5; min-height:60px; }
.rcard__foot{ display:flex; align-items:center; justify-content:space-between; margin-top:18px; padding-top:16px; border-top:1px solid var(--line); }
.rcard__price{ font-family:var(--font-mono); font-size:15px; }
.rcard__cta{ font-size:13px; font-weight:700; display:flex; align-items:center; gap:6px; color:var(--volt); }
.rcard__tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:14px; }
.rcard__tag{ font-family:var(--font-mono); font-size:10px; letter-spacing:.05em; text-transform:uppercase; color:var(--paper-dim); border:1px solid var(--line-2); border-radius:100px; padding:4px 9px; white-space:nowrap; }
.rcard__tag--lvl{ color:var(--volt); border-color:color-mix(in srgb, var(--volt) 45%, transparent); }
.rcard__specs{ list-style:none; display:flex; flex-direction:column; gap:6px; margin-top:14px; }
.rcard__specs li{ display:grid; grid-template-columns:76px 1fr 24px; align-items:center; gap:8px; font-family:var(--font-mono); font-size:9.5px; letter-spacing:.03em; text-transform:uppercase; color:var(--paper-dim); }
.rcard__specs li i{ height:4px; border-radius:3px; background:var(--line-2); position:relative; }
.rcard__specs li i::after{ content:""; position:absolute; inset:0; width:var(--v,50%); background:var(--bar); border-radius:3px; }
.rcard__specs li b{ color:var(--paper); text-align:right; font-family:var(--font-display); font-weight:600; font-size:12px; }
.lineup__hint{ text-align:center; margin-top:40px; font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); }
.drag-icon{ color:var(--volt); }

/* ░░ MATCH / QUIZ ░░ */
.match{ position:relative; padding:clamp(90px,13vh,170px) var(--pad); overflow:hidden; }
.match__glow{ position:absolute; top:20%; left:50%; transform:translateX(-50%); width:80vw; height:80vw; max-width:900px; max-height:900px; background:radial-gradient(circle, rgba(22,224,200,.12), transparent 60%); pointer-events:none; }
.match .section-head{ margin-bottom:54px; position:relative; }
.quiz{ max-width:980px; margin:0 auto; position:relative; }
.quiz__progress{ display:flex; gap:8px; justify-content:center; margin-bottom:42px; }
.quiz__step{ width:38px; height:3px; border-radius:3px; background:var(--line-2); transition:background .5s var(--ease); }
.quiz__step.is-active{ background:var(--volt); }
.quiz__stage{ position:relative; min-height:360px; }
.quiz__panel{ position:absolute; inset:0; opacity:0; visibility:hidden; pointer-events:none; }
.quiz__panel.is-active{ opacity:1; visibility:visible; pointer-events:auto; position:relative; }
.quiz__q-index{ font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; color:var(--cyan); }
.quiz__q{ font-family:var(--font-display); font-weight:600; font-size:clamp(26px,3.6vw,46px); letter-spacing:-.02em; margin:14px 0 38px; max-width:16ch; }
.quiz__opts{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.opt{
  text-align:left; padding:26px 24px; border:1px solid var(--line-2); border-radius:18px;
  background:var(--ink-card); transition:border-color .4s var(--ease), background .4s, transform .4s var(--ease);
  display:flex; flex-direction:column; gap:8px;
}
.opt b{ font-family:var(--font-display); font-weight:600; font-size:22px; }
.opt span{ color:var(--paper-dim); font-size:13.5px; }
.opt:hover{ border-color:var(--volt); background:#15181d; transform:translateY(-4px); }
.opt.is-picked{ border-color:var(--volt); background:linear-gradient(180deg,rgba(215,255,62,.10),transparent); }

/* result */
.quiz__result.is-active{ animation:fadeUp .7s var(--ease) both; }
@keyframes fadeUp{ from{opacity:0; transform:translateY(30px);} to{opacity:1; transform:none;} }
.result{ display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:center; }
.result__media{ position:relative; aspect-ratio:4/4.6; border-radius:24px; overflow:hidden; background:radial-gradient(120% 90% at 50% 35%, #1b1e25, #0a0b0e); border:1px solid var(--line); }
.result__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; padding:12%; z-index:2; }
.result__halo{ position:absolute; inset:0; background:radial-gradient(circle at 50% 45%, rgba(215,255,62,.28), transparent 60%); z-index:1; }
.result__score{ position:absolute; top:16px; right:18px; z-index:3; font-family:var(--font-display); font-weight:600; font-size:42px; color:var(--volt); }
.result__score i{ font-style:normal; font-family:var(--font-mono); font-size:12px; color:var(--paper-dim); }
.result__tag{ font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--cyan); }
.result__name{ font-family:var(--font-display); font-weight:600; font-size:clamp(30px,4vw,56px); letter-spacing:-.02em; margin:10px 0 4px; }
.result__shape{ color:var(--paper-dim); font-family:var(--font-mono); font-size:13px; letter-spacing:.06em; }
.result__why{ margin:20px 0; font-size:17px; line-height:1.55; color:#D6D8D2; max-width:42ch; }
.result__specs{ list-style:none; display:flex; flex-wrap:wrap; gap:10px; margin-bottom:28px; }
.result__specs li{ font-family:var(--font-mono); font-size:12px; padding:7px 13px; border:1px solid var(--line-2); border-radius:100px; color:var(--paper); }
.result__specs li b{ color:var(--volt); }
.result__actions{ display:flex; gap:14px; flex-wrap:wrap; }

/* ===== extended match quiz ===== */
.quiz__opts{ grid-template-columns:repeat(auto-fit,minmax(158px,1fr)); }
.opt b{ font-size:clamp(16px,1.5vw,20px); line-height:1.2; }
.quiz__hint{ margin:-24px 0 26px; color:var(--paper-dim); font-size:14px; }
.quiz__nav{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:30px; min-height:40px; }
.quiz__back{ font-family:var(--font-mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); }
.quiz__back:hover{ color:var(--paper); }
.opt--chip{ flex-direction:row; align-items:center; justify-content:center; text-align:center; padding:18px 16px; }

/* match results — top-3 shortlist */
.mqres__head{ text-align:center; margin-bottom:34px; }
.mqres__head p{ color:var(--paper-dim); margin-top:8px; }
.mqres__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; }
.mqres__card{ position:relative; display:flex; flex-direction:column; border:1px solid var(--line-2); border-radius:20px; overflow:hidden; background:var(--ink-card); }
.mqres__card--lead{ border-color:var(--volt); box-shadow:0 0 0 1px var(--volt); }
.mqres__rank{ position:absolute; top:12px; left:14px; z-index:3; font-family:var(--font-mono); font-size:12px; color:#FAF8F3; mix-blend-mode:difference; }
.mqres__media{ position:relative; aspect-ratio:4/3.3; background:radial-gradient(70% 60% at 50% 42%, color-mix(in srgb, var(--c,#888) 24%, transparent), transparent 72%), #1A2C1E; }
.mqres__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; padding:13% 18%; }
.mqres__fit{ position:absolute; top:11px; right:14px; z-index:3; text-align:right; }
.mqres__fit b{ font-family:var(--font-display); font-weight:600; font-size:30px; color:#C8A96A; line-height:1; }
.mqres__fit span{ display:block; font-family:var(--font-mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:#CFC9B6; }
.mqres__body{ padding:18px 18px 22px; display:flex; flex-direction:column; flex:1; }
.mqres__brand{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; }
.mqres__name{ font-family:var(--font-display); font-weight:600; font-size:22px; margin:4px 0 12px; }
.mqres__why{ font-size:13.5px; color:var(--paper-dim); margin:10px 0 16px; line-height:1.5; }
.mqres__specs{ list-style:none; display:flex; flex-direction:column; gap:7px; margin:0 0 18px; }
.mqres__specs li{ display:grid; grid-template-columns:78px 1fr 24px; align-items:center; gap:9px; font-family:var(--font-mono); font-size:10px; letter-spacing:.03em; text-transform:uppercase; color:var(--paper-dim); }
.mqres__specs li i{ height:4px; border-radius:3px; background:var(--line-2); position:relative; }
.mqres__specs li i::after{ content:""; position:absolute; inset:0; width:var(--v,50%); background:var(--bar); border-radius:3px; }
.mqres__specs li b{ color:var(--paper); text-align:right; }
.mqres__link{ margin-top:auto; width:100%; justify-content:center; }
.mqres__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:36px; }
@media (max-width:860px){ .mqres__grid{ grid-template-columns:1fr; max-width:420px; margin:0 auto; } }

/* ░░ COMPARE ░░ */
.compare{ padding:clamp(80px,12vh,160px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.compare .section-head{ padding:0; margin-bottom:54px; }
.compare__wrap{ display:grid; grid-template-columns:1fr 1.6fr 1fr; gap:30px; align-items:start; }
.compare__pick{ display:flex; flex-direction:column; gap:12px; padding-top:30px; }
.compare__pick--b{ text-align:right; align-items:flex-end; }
.compare__label{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); }
.compare__select{
  font-family:var(--font-display); font-weight:600; font-size:clamp(20px,2.2vw,30px); color:var(--paper);
  background:var(--ink-card); border:1px solid var(--line-2); border-radius:14px; padding:16px 18px; width:100%;
  cursor:none; appearance:none; transition:border-color .3s;
}
.compare__pick--a .compare__select{ border-left:3px solid var(--volt); }
.compare__pick--b .compare__select{ border-right:3px solid var(--cyan); text-align:right; }
.compare__select:hover{ border-color:var(--paper); }
.compare__bars{ display:flex; flex-direction:column; gap:22px; padding:14px 0; }
.cbar{ }
.cbar__head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:9px; }
.cbar__a, .cbar__b{ font-family:var(--font-mono); font-size:15px; font-weight:700; }
.cbar__a{ color:var(--volt); } .cbar__b{ color:var(--cyan); }
.cbar__label{ font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--paper-dim); }
.cbar__track{ position:relative; height:8px; display:flex; }
.cbar__fill-a, .cbar__fill-b{ height:100%; }
.cbar__fill-a{ background:linear-gradient(90deg,transparent,var(--volt)); border-radius:6px 0 0 6px; transform-origin:right; transform:scaleX(0); transition:transform .9s var(--ease); }
.cbar__fill-b{ background:linear-gradient(90deg,var(--cyan),transparent); border-radius:0 6px 6px 0; transform-origin:left; transform:scaleX(0); transition:transform .9s var(--ease); }
.cbar__mid{ width:1px; background:var(--line-2); }

/* ── comparator: versus cards + radar + stat table ── */
.cmp-vs{ display:grid; grid-template-columns:1fr auto 1fr; gap:20px; align-items:stretch; margin-bottom:40px; }
.cmp-vs__sep{ align-self:center; font-family:var(--font-display); font-weight:600; font-size:22px; color:var(--paper-dim); }
.cmp-card{ position:relative; display:flex; flex-direction:column; align-items:center; text-align:center; padding:20px 18px; border:1px solid var(--line-2); border-radius:20px; background:var(--ink-card); }
.cmp-card[data-side="a"]{ border-top:3px solid var(--volt); }
.cmp-card[data-side="b"]{ border-top:3px solid var(--cyan); }
.cmp-card__tag{ font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; }
.cmp-card[data-side="a"] .cmp-card__tag{ color:var(--volt); }
.cmp-card[data-side="b"] .cmp-card__tag{ color:var(--cyan); }
.cmp-pick__sel{ display:flex; flex-direction:column; align-items:center; gap:3px; width:100%; }
.cmp-card__media{ display:block; width:118px; height:118px; border-radius:14px; background:radial-gradient(60% 55% at 50% 42%, rgba(200,169,106,.18), transparent 70%), #1A2C1E; margin:12px 0; }
.cmp-card__media img{ width:100%; height:100%; object-fit:contain; padding:13%; }
.cmp-card__brand{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--paper-dim); }
.cmp-card__name{ font-family:var(--font-display); font-weight:600; font-size:20px; margin:2px 0 12px; }
.cmp-card__scores{ display:flex; gap:20px; margin-bottom:16px; }
.cmp-card__scores b{ font-family:var(--font-display); font-weight:600; font-size:25px; }
.cmp-card__scores i{ display:block; font-family:var(--font-mono); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-dim); font-style:normal; }
.cmp-card[data-side="a"] .cmp-card__scores span:first-child b{ color:var(--volt); }
.cmp-card[data-side="b"] .cmp-card__scores span:first-child b{ color:var(--cyan); }
.cmp-card__search{ position:relative; width:100%; margin-top:auto; }
.cmp-pick__input{ width:100%; background:var(--ink); border:1px solid var(--line-2); border-radius:10px; padding:11px 14px; font:inherit; font-size:14px; color:var(--paper); text-align:center; }
.cmp-pick__input::placeholder{ color:var(--paper-dim); }
.cmp-pick__list{ position:absolute; z-index:60; left:0; right:0; bottom:calc(100% + 6px); max-height:300px; overflow:auto; background:var(--ink-card); border:1px solid var(--line-2); border-radius:14px; box-shadow:0 -18px 50px rgba(0,0,0,.4); padding:6px; text-align:left; }
.cmp-pick__opt{ display:flex; align-items:center; gap:11px; width:100%; padding:8px 10px; border-radius:9px; color:var(--paper); transition:background .2s; }
.cmp-pick__opt:hover{ background:color-mix(in srgb, var(--volt) 14%, transparent); }
.cmp-pick__opt img{ width:32px; height:32px; object-fit:contain; flex:0 0 auto; }
.cmp-pick__opt span{ flex:1; font-size:13.5px; }
.cmp-pick__opt i{ font-family:var(--font-mono); font-size:12px; color:var(--volt); font-style:normal; }
.cmp-pick__none{ padding:14px; text-align:center; color:var(--paper-dim); font-size:13px; }

.cmp-radar-wrap{ display:flex; flex-direction:column; align-items:center; gap:16px; margin:0 auto 34px; }
.radar{ width:100%; max-width:440px; height:auto; overflow:visible; }
.radar__ring{ fill:none; stroke:var(--line-2); stroke-width:1; }
.radar__spoke{ stroke:var(--line); stroke-width:1; }
.radar__lbl{ font-family:var(--font-mono); font-size:10px; letter-spacing:.04em; text-transform:uppercase; fill:var(--paper-dim); }
.radar__area{ fill-opacity:.22; stroke-width:2; stroke-linejoin:round; }
.radar__area--a{ fill:var(--volt); stroke:var(--volt); }
.radar__area--b{ fill:var(--cyan); stroke:var(--cyan); }
.radar__dot--a{ fill:var(--volt); } .radar__dot--b{ fill:var(--cyan); }
.radar-legend{ display:flex; gap:22px; flex-wrap:wrap; justify-content:center; }
.radar-legend__i{ font-family:var(--font-mono); font-size:12px; display:flex; align-items:center; gap:7px; color:var(--paper); }
.radar-legend__i::before{ content:""; width:11px; height:11px; border-radius:3px; }
.radar-legend__i--a::before{ background:var(--volt); }
.radar-legend__i--b::before{ background:var(--cyan); }

.cmp-stats{ max-width:540px; margin:0 auto; }
.cmp-stats__head{ display:flex; justify-content:space-between; align-items:center; gap:16px; padding-bottom:14px; margin-bottom:4px; border-bottom:1px solid var(--line-2); }
.cmp-stats__name{ display:flex; align-items:center; gap:8px; max-width:45%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-family:var(--font-mono); font-size:12px; color:var(--paper); }
.cmp-stats__name--b{ flex-direction:row-reverse; text-align:right; }
.cmp-dot{ width:11px; height:11px; border-radius:3px; flex:0 0 auto; }
.cmp-dot--a{ background:var(--volt); } .cmp-dot--b{ background:var(--cyan); }
.cmp-stat{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; padding:11px 4px; border-bottom:1px solid var(--line); }
.cmp-stat:last-child{ border-bottom:0; }
.cmp-stat__label{ text-align:center; padding:0 14px; font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-dim); }
.cmp-stat__v{ font-family:var(--font-display); font-weight:600; font-size:20px; color:var(--paper-dim); }
.cmp-stat__a{ justify-self:start; } .cmp-stat__b{ justify-self:end; }
.cmp-stat__v.is-win{ color:var(--paper); font-weight:700; padding:3px 12px; border-radius:9px; }
.cmp-stat__a.is-win{ background:color-mix(in srgb, var(--cmp-a) 22%, transparent); box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--cmp-a) 55%, transparent); }
.cmp-stat__b.is-win{ background:color-mix(in srgb, var(--cmp-b) 22%, transparent); box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--cmp-b) 55%, transparent); }

/* dedicated, legible comparison colours (the palette's --cyan is dark forest, not
   distinct enough as a 2nd colour): A = cork, B = petrol teal. */
:root{ --cmp-a:var(--volt); --cmp-b:#3E97A8; }
.cmp-card[data-side="a"]{ border-top-color:var(--cmp-a); }
.cmp-card[data-side="b"]{ border-top-color:var(--cmp-b); }
.cmp-card[data-side="a"] .cmp-card__tag, .cmp-card[data-side="a"] .cmp-card__scores span:first-child b{ color:var(--cmp-a); }
.cmp-card[data-side="b"] .cmp-card__tag, .cmp-card[data-side="b"] .cmp-card__scores span:first-child b{ color:var(--cmp-b); }
.radar__area--a{ fill:var(--cmp-a); stroke:var(--cmp-a); }
.radar__area--b{ fill:var(--cmp-b); stroke:var(--cmp-b); }
.radar__dot--a{ fill:var(--cmp-a); } .radar__dot--b{ fill:var(--cmp-b); }
.radar-legend__i--a::before, .cmp-dot--a{ background:var(--cmp-a); }
.radar-legend__i--b::before, .cmp-dot--b{ background:var(--cmp-b); }
@media (max-width:780px){ .cmp-vs{ grid-template-columns:1fr; } .cmp-vs__sep{ padding:4px 0; } }

.compare__verdict{ margin-top:50px; text-align:center; padding:34px; border:1px solid var(--line); border-radius:20px; background:linear-gradient(180deg,var(--ink-card),transparent); }
.compare__verdict-tag{ font-family:var(--font-mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--volt); }
.compare__verdict p{ font-family:var(--font-display); font-weight:500; font-size:clamp(20px,2.4vw,32px); letter-spacing:-.02em; margin-top:14px; line-height:1.25; }
.compare__verdict b{ color:var(--volt); }

/* ░░ SÉLECTIONS (par besoin) ░░ */
.sel{ padding:clamp(80px,12vh,160px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.sel .section-head{ padding:0; margin-bottom:48px; }
.sel__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.sel__card{ position:relative; display:flex; flex-direction:column; justify-content:space-between; gap:36px; min-height:196px; padding:26px; border:1px solid var(--line-2); border-radius:20px; background:var(--ink-card); overflow:hidden; transition:border-color .4s var(--ease), transform .4s var(--ease); }
.sel__card::before{ content:""; position:absolute; right:-30%; top:-30%; width:70%; height:70%; background:radial-gradient(circle, color-mix(in srgb, var(--volt) 28%, transparent), transparent 70%); opacity:0; transition:opacity .5s; pointer-events:none; }
.sel__card:hover{ border-color:var(--volt); transform:translateY(-5px); }
.sel__card:hover::before{ opacity:1; }
.sel__idx{ font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; color:var(--volt); position:relative; }
.sel__title{ font-family:var(--font-display); font-weight:600; font-size:clamp(23px,2.5vw,33px); letter-spacing:-.02em; line-height:1.06; position:relative; }
.sel__cta{ display:flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--paper-dim); position:relative; }
.sel__arrow{ transition:transform .4s var(--ease); }
.sel__card:hover .sel__cta{ color:var(--paper); }
.sel__card:hover .sel__arrow{ transform:translateX(5px); color:var(--volt); }
@media (max-width:860px){ .sel__grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .sel__grid{ grid-template-columns:1fr; } }

/* ░░ GUIDES (legacy, unused) ░░ */
.guides{ padding:clamp(80px,12vh,160px) var(--pad); max-width:var(--maxw); margin:0 auto; }
.guides .section-head{ padding:0; margin-bottom:48px; }
.guides__grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:240px; gap:18px; }
.guide{
  position:relative; overflow:hidden; border-radius:20px; padding:26px; display:flex; flex-direction:column; justify-content:flex-end;
  background:var(--ink-card); border:1px solid var(--line); transition:border-color .4s; isolation:isolate;
}
.guide--lg{ grid-column:span 2; grid-row:span 2; }
.guide--wide{ grid-column:span 2; }
.guide__bg{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:.32; z-index:-1; transition:transform .8s var(--ease), opacity .5s; }
.guide:hover{ border-color:var(--line-2); }
.guide:hover .guide__bg{ transform:scale(1.08); opacity:.5; }
.guide__top{ position:absolute; top:22px; left:26px; right:26px; display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; color:var(--paper-dim); }
.guide__title{ font-family:var(--font-display); font-weight:600; font-size:clamp(19px,1.8vw,26px); letter-spacing:-.01em; line-height:1.05; }
.guide--lg .guide__title{ font-size:clamp(28px,3vw,44px); }
.guide__desc{ color:var(--paper-dim); font-size:14px; margin-top:10px; max-width:38ch; }
.guide__arrow{ position:absolute; top:50px; right:26px; font-size:22px; color:var(--volt); opacity:0; transform:translate(-6px,6px); transition:.45s var(--ease); }
.guide:hover .guide__arrow{ opacity:1; transform:none; }

/* ░░ METHOD ░░ */
.method{ padding:clamp(80px,12vh,170px) var(--pad); border-top:1px solid var(--line); }
.method__inner{ max-width:var(--maxw); margin:0 auto; }
.method__title{ font-family:var(--font-display); font-weight:600; font-size:clamp(34px,6vw,92px); letter-spacing:-.03em; line-height:.98; margin:22px 0 70px; }
.method__stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat{ border-top:1px solid var(--line-2); padding-top:22px; display:flex; flex-direction:column; }
.stat__value{ display:flex; align-items:flex-end; line-height:.9; }
.stat__num{ font-family:var(--font-display); font-weight:600; font-size:clamp(48px,7vw,108px); line-height:.9; letter-spacing:-.03em; }
.stat__suffix{ font-family:var(--font-display); font-weight:600; font-size:clamp(28px,3.6vw,52px); line-height:1; color:var(--cyan); margin-left:2px; }
.stat__label{ font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-dim); margin-top:14px; }
.stat:nth-child(1) .stat__num{ color:var(--volt); }
.stat:nth-child(3) .stat__num{ color:var(--cyan); }

/* ░░ FOOTER ░░ */
.footer{ background:var(--ink-soft); border-top:1px solid var(--line); padding:clamp(70px,9vh,120px) var(--pad) 40px; }
.footer__cta{ text-align:center; padding:30px 0 80px; border-bottom:1px solid var(--line); }
.footer__eyebrow{ font-family:var(--font-mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--volt); margin-bottom:24px; }
.footer__big{ display:inline-flex; align-items:center; gap:24px; font-family:var(--font-display); font-weight:600; font-size:clamp(44px,10vw,150px); letter-spacing:-.04em; line-height:.9; transition:color .4s; }
.footer__big svg{ flex:0 0 auto; transition:transform .5s var(--ease); }
.footer__big:hover{ color:var(--volt); }
.footer__big:hover svg{ transform:rotate(-45deg); color:var(--volt); }
.footer__grid{ display:grid; grid-template-columns:1.6fr repeat(3,1fr); gap:34px; padding:64px 0; }
.footer__brand{ max-width:30ch; }
.footer__brandname{ display:block; font-family:var(--font-display); font-weight:600; font-size:21px; letter-spacing:-.01em; }
.footer__brandname i{ font-style:normal; font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--paper-dim); margin-left:6px; }
.footer__brand p{ color:var(--paper-dim); font-size:14px; margin-top:14px; }
.footer__col h4{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:18px; font-weight:500; }
.footer__col a{ display:block; font-size:15px; padding:6px 0; color:#C9CBC5; transition:color .3s, padding-left .3s; }
.footer__col a:hover{ color:var(--volt); padding-left:6px; }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:30px; border-top:1px solid var(--line); font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; color:var(--paper-dim); flex-wrap:wrap; gap:14px; }
.footer__lang button{ font-family:var(--font-mono); font-size:11px; padding:5px 10px; border:1px solid var(--line); border-radius:6px; color:var(--paper-dim); margin-left:6px; }
.footer__lang button.is-active{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

/* ░░ Reveal helpers ░░ */
.reveal-up{ opacity:0; transform:translateY(28px); }
.split-words .word, .split-chars .char{ display:inline-block; }
.split-chars .char-word{ display:inline-block; white-space:nowrap; }
.word-mask{ display:inline-block; overflow:hidden; vertical-align:top; }

/* ░░ Responsive ░░ */
@media (max-width:1080px){
  .result{ grid-template-columns:1fr; gap:28px; }
  .result__media{ max-width:340px; }
  .guides__grid{ grid-template-columns:repeat(2,1fr); }
  .guide--lg{ grid-column:span 2; grid-row:span 1; min-height:300px; }
  .guide--wide{ grid-column:span 2; }
}
@media (max-width:860px){
  .intro__foot{ grid-template-columns:1fr; gap:30px; }
  .quiz__opts{ grid-template-columns:1fr; }
  .compare__wrap{ grid-template-columns:1fr; gap:22px; }
  .compare__pick--b{ text-align:left; align-items:stretch; }
  .compare__pick--b .compare__select{ text-align:left; }
  .method__stats{ grid-template-columns:repeat(2,1fr); gap:30px 20px; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .hero__meta{ display:none; }
  .hero__ball{ width:min(44vw,240px); right:3%; bottom:8%; }
}
@media (max-width:680px){
  /* mobile only: a small, sharp ball to the RIGHT of the title (in the right
     gutter beside the headline), clear of the full-width CTAs. Desktop/tablet unchanged. */
  .hero__ball{ top:30%; right:5%; bottom:auto; left:auto; width:min(24vw,92px); }
}
@media (max-width:520px){
  .guides__grid{ grid-template-columns:1fr; }
  .guide--lg, .guide--wide{ grid-column:span 1; }
  .method__stats{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; }
  .btn{ width:100%; justify-content:center; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
  .reveal-up{ opacity:1; transform:none; }
  .hero__title .w, .hero__title .dot{ transform:none; }
}

/* =================================================================
   THEME — "Cork & Forest"
   Light (default): warm-white canvas, sand surfaces, dark-ink text,
   forest-green deep blocks, cork as the single strong accent.
   Dark: dark-ink canvas, forest surfaces, warm-white text, cork accent.
   The hero + product-image panels are always forest "islands".
   ================================================================= */
:root{ color-scheme:light; }
[data-theme="dark"]{
  color-scheme:dark;
  --ink:#111209; --ink-soft:#15160C; --ink-card:#1A2C1E;
  --paper:#FAF8F3; --paper-dim:#A8A593;
  --line:rgba(250,248,243,.10); --line-2:rgba(250,248,243,.18);
  --bar:#7FBE96;                    /* lightened green — visible on the dark forest cards */
  --accent-text:#C8A96A;            /* cork reads well on dark */
  --cmp-a:#C8A96A; --cmp-b:#E8D9BC;
  --link-soft:#B7B2A0; --hover:#C8A96A;
  --opt-hover:#22382A; --stuck:rgba(17,18,9,.62); --stroke:rgba(250,248,243,.3);
}
body{ transition:background .5s var(--ease), color .5s var(--ease); }

/* forest "islands" — always dark, in both themes */
.hero, .preloader{
  --ink:#1A2C1E; --ink-soft:#1A2C1E; --paper:#FAF8F3; --paper-dim:#B8B2A0;
  --line:rgba(250,248,243,.12); --line-2:rgba(250,248,243,.20);
  color:var(--paper);
}
.rcard__media, .result__media{ --paper:#FAF8F3; --paper-dim:#B8B2A0; }

/* on HOME the nav floats over the forest hero → keep it light until it sticks.
   On other routes the top of the page is light, so the nav uses normal theme colours. */
body[data-route="home"]:not(.menu-open) .nav:not(.is-stuck){
  color:#FAF8F3; --paper:#FAF8F3; --paper-dim:#CFC9B6;
  --line:rgba(250,248,243,.2); --line-2:rgba(250,248,243,.32);
}
body[data-route="home"]:not(.menu-open) .nav:not(.is-stuck) .btn--mini{ background:#FAF8F3; color:#111209; }
.nav.is-stuck{ background:var(--stuck); }

/* hardcoded-dark surfaces remapped to the warm palette */
.hero::before{
  background:
    linear-gradient(95deg, rgba(11,18,12,.93) 0%, rgba(11,18,12,.8) 28%, rgba(11,18,12,.34) 55%, transparent 78%),
    linear-gradient(0deg, rgba(11,18,12,.8) 0%, transparent 30%);
}
.hero__court{
  background:
    radial-gradient(120% 90% at 72% 8%, rgba(200,169,106,.16), transparent 55%),
    radial-gradient(120% 100% at 28% 112%, rgba(12,24,16,.5), transparent 60%),
    #1A2C1E;
}
/* real padel-court photo, forest-tinted + edge-faded so it sits behind the hero */
.hero__court::after{
  display:block; content:""; opacity:.85; mix-blend-mode:normal;
  background-repeat:no-repeat, no-repeat;
  background-position:center, center 58%;
  background-size:cover, cover;
  /* fallback: WebP is universally supported (≈98% smaller than the source PNG) */
  background-image:
    linear-gradient(180deg, rgba(26,44,30,.62), rgba(18,34,24,.5) 55%, rgba(26,44,30,.7)),
    url("../assets/img/court-warm.webp");
  /* progressive: AVIF first, then WebP, for capable browsers */
  background-image:
    linear-gradient(180deg, rgba(26,44,30,.62), rgba(18,34,24,.5) 55%, rgba(26,44,30,.7)),
    image-set(
      url("../assets/img/court-warm.avif") type("image/avif"),
      url("../assets/img/court-warm.webp") type("image/webp"));
  -webkit-mask-image:linear-gradient(180deg, transparent, #000 24%, #000 78%, transparent);
          mask-image:linear-gradient(180deg, transparent, #000 24%, #000 78%, transparent);
}
.hero__ball-glow{ background:radial-gradient(circle at 50% 50%, rgba(200,169,106,.3), rgba(232,217,188,.12) 38%, transparent 62%); }
.match__glow{ background:radial-gradient(circle, rgba(200,169,106,.14), transparent 60%); }
.result__halo{ background:radial-gradient(circle at 50% 45%, rgba(200,169,106,.3), transparent 60%); }
.rcard__media{ background:radial-gradient(120% 90% at 50% 40%, #243F2C, #142318); }
.result__media{ background:radial-gradient(120% 90% at 50% 35%, #243F2C, #11201A); border-color:rgba(250,248,243,.12); }
.marquee__track span{ -webkit-text-stroke-color:var(--stroke); }
.opt:hover{ background:var(--opt-hover); }
::selection{ color:#111209; }

/* accent TEXT on light surfaces → forest (cork stays for fills + dark islands) */
.kicker, .rcard__cta, .result__specs li b, .result__tag, .quiz__q-index,
.compare__verdict-tag, .compare__verdict b, .guide__arrow, .footer__eyebrow,
.intro__col .num, .intro__statement em, .stat__suffix,
.method .stat:nth-child(1) .stat__num,
.method .stat:nth-child(3) .stat__num{ color:var(--accent-text); }

/* scores pop in cork on the forest media panels */
.rcard__score b{ color:var(--volt); }

/* compare bars: forest vs cork (numbers neutral, bars carry identity) */
.cbar__a, .cbar__b{ color:var(--paper); }
.cbar__fill-a{ background:linear-gradient(90deg,transparent,var(--cmp-a)); }
.cbar__fill-b{ background:linear-gradient(90deg,var(--cmp-b),transparent); }

/* softer text + link colours */
.result__why{ color:var(--paper); }
.footer__col a{ color:var(--link-soft); }
.footer__col a:hover, .footer__big:hover, .nav__theme:hover{ color:var(--hover); }

/* buttons: cork fill + dark label, forest fill + light label on hover */
.btn--primary{ color:#111209; }
.btn--primary::before{ background:#1A2C1E; }
.btn--primary:hover{ color:#FAF8F3; }
.btn--mini:hover{ color:#111209; }


/* image guide cards stay forest feature panels */
.guide--lg, .guide--wide{ background:#1A2C1E; --paper:#FAF8F3; --paper-dim:#CFC9B6; color:var(--paper); }

/* =================================================================
   SPA SHELL + MULTI-PAGE VIEWS
   ================================================================= */
#app{ display:block; min-height:60vh; }

/* logo lockup (Racket Index / by Padel Haze) */
.nav__logo-lockup{ display:flex; flex-direction:column; line-height:1; gap:2px; }
.nav__logo-by{ font-family:var(--font-mono); font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); font-weight:500; }
.preloader__by{ font-family:var(--font-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--volt); margin-top:6px; opacity:0; }
.nav__link.is-active{ color:var(--volt); }
.nav__link.is-active::after{ transform:scaleX(1); }

/* page transition wipe */
.page-wipe{
  position:fixed; inset:0; z-index:8500; display:none; align-items:center; justify-content:center;
  background:#1A2C1E; will-change:transform;
}
.page-wipe__mark{ font-family:var(--font-display); font-weight:600; font-size:clamp(28px,6vw,64px); color:#FAF8F3; letter-spacing:-.02em; }
.page-wipe__mark::after{ content:""; display:inline-block; width:10px; height:10px; border-radius:50%; background:var(--volt); margin-left:10px; box-shadow:0 0 18px var(--volt); }

/* generic page scaffold */
.page{ padding:calc(var(--pad) + 84px) var(--pad) clamp(70px,10vh,140px); max-width:var(--maxw); margin:0 auto; }
.page__head{ margin-bottom:46px; max-width:760px; }
.page__head--center{ margin-inline:auto; text-align:center; }
.page__title{ font-family:var(--font-display); font-weight:600; letter-spacing:-.03em; line-height:.96; font-size:clamp(40px,7vw,96px); margin:16px 0 14px; }
.page__lead{ color:var(--paper-dim); font-size:clamp(15px,1.4vw,19px); max-width:60ch; }

/* shared grid */
.grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(258px,1fr)); gap:22px; }
.grid--4{ grid-template-columns:repeat(4,1fr); }
.grid .rcard{ width:auto; }
.rcard{ display:flex; flex-direction:column; }
.rcard__body{ flex:1; display:flex; flex-direction:column; }
.rcard__foot{ margin-top:auto; }

/* home teaser band */
/* matcher call-to-action band (home — the differentiating feature) */
.matchcta{ text-align:center; padding:clamp(56px,9vh,110px) var(--pad); background:var(--ink-soft); border-block:1px solid var(--line); }
.matchcta .kicker{ justify-content:center; }
.matchcta__title{ font-family:var(--font-display); font-weight:600; letter-spacing:-.02em; line-height:1.02; font-size:clamp(30px,5vw,60px); margin:14px auto 16px; max-width:16ch; }
.matchcta__lead{ color:var(--paper-dim); font-size:clamp(15px,1.6vw,19px); max-width:520px; margin:0 auto 28px; line-height:1.5; }
.matchcta__steps{ display:flex; justify-content:center; gap:clamp(26px,6vw,72px); margin-bottom:32px; }
.matchcta__steps span{ display:flex; flex-direction:column; align-items:center; }
.matchcta__steps b{ font-family:var(--font-display); font-weight:600; font-size:clamp(28px,4vw,46px); color:var(--accent-text); line-height:1; }
.matchcta__steps i{ font-family:var(--font-mono); font-style:normal; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); margin-top:7px; }

.band{ padding:clamp(20px,4vh,40px) var(--pad) clamp(40px,7vh,90px); max-width:var(--maxw); margin:0 auto; }
.band__inner{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.band__card{ border:1px solid var(--line); border-radius:24px; padding:clamp(28px,4vw,52px); background:var(--ink-card); display:flex; flex-direction:column; align-items:flex-start; gap:14px; }
.band__title{ font-family:var(--font-display); font-weight:600; font-size:clamp(28px,3.4vw,46px); letter-spacing:-.02em; }
.band__lead{ color:var(--paper-dim); font-size:16px; max-width:40ch; margin-bottom:6px; }

/* lineup foot row */
.lineup__foot{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; padding:34px var(--pad) 0; max-width:var(--maxw); margin:0 auto; }

/* ===== CATALOGUE ===== */
.cat__bar{ position:sticky; top:62px; z-index:60; display:flex; flex-direction:column; gap:14px; padding:16px 0; margin-bottom:8px; background:color-mix(in srgb, var(--ink) 86%, transparent); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.cat__search{ display:flex; align-items:center; gap:12px; border:1px solid var(--line-2); border-radius:14px; padding:0 16px; background:var(--ink-card); }
.cat__search svg{ color:var(--paper-dim); flex:0 0 auto; }
.cat__search input{ flex:1; background:none; border:none; outline:none; padding:15px 0; font:inherit; font-size:16px; color:var(--paper); }
.cat__search input::placeholder{ color:var(--paper-dim); }
.cat__filters{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.cat__sel{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); }
.cat__sel select{ font:inherit; font-family:var(--font-body); font-size:13px; text-transform:none; letter-spacing:0; color:var(--paper); background:var(--ink-card); border:1px solid var(--line-2); border-radius:100px; padding:8px 14px; cursor:none; appearance:none; }
.cat__reset{ font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--volt); border:1px solid var(--line-2); border-radius:100px; padding:8px 16px; margin-left:auto; }
.cat__meta{ font-family:var(--font-mono); font-size:12px; color:var(--paper-dim); margin:8px 0 24px; }
.cat__none{ grid-column:1/-1; padding:60px 0; text-align:center; color:var(--paper-dim); }
.cat__more{ display:flex; justify-content:center; margin-top:48px; }

/* ===== DETAIL ===== */
.crumb{ display:flex; align-items:center; gap:10px; font-family:var(--font-mono); font-size:12px; color:var(--paper-dim); margin-bottom:30px; flex-wrap:wrap; }
.crumb a:hover{ color:var(--volt); }
.crumb i{ font-style:normal; opacity:.5; }
.crumb span{ color:var(--paper); }
.detail__top{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(28px,5vw,72px); align-items:start; }
.detail__media{ position:relative; border-radius:28px; overflow:hidden; aspect-ratio:1/1.04; background:radial-gradient(120% 90% at 50% 38%, #243F2C, #11201A); border:1px solid rgba(250,248,243,.12); }
.detail__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; padding:10%; z-index:2; }
.detail__halo{ position:absolute; inset:0; z-index:1; }
.detail__score{ position:absolute; top:20px; right:22px; z-index:3; font-family:var(--font-display); font-weight:600; font-size:46px; color:var(--volt); line-height:1; }
.detail__score i{ font-style:normal; font-family:var(--font-mono); font-size:13px; color:#9A9C97; }
.detail__brand{ font-family:var(--font-mono); font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent-text); }
.detail__name{ font-family:var(--font-display); font-weight:600; font-size:clamp(34px,4.4vw,64px); letter-spacing:-.02em; line-height:1; margin:10px 0 18px; }
.detail__tags{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:20px; }
.tagchip{ font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; padding:7px 13px; border:1px solid var(--line-2); border-radius:100px; color:var(--paper); }
.tagchip:first-child{ border-color:var(--c, var(--volt)); }
.detail__blurb{ font-size:17px; line-height:1.55; color:var(--paper); max-width:50ch; }
.detail__price{ font-family:var(--font-display); font-weight:600; font-size:32px; margin:18px 0 26px; }
.detail__price-note{ font-family:var(--font-mono); font-weight:400; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); vertical-align:middle; margin-left:6px; }
.detail__sub{ font-family:var(--font-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:16px; }
.detail__bars{ display:flex; flex-direction:column; gap:14px; margin-bottom:30px; }
.dbar__head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:7px; font-size:14px; }
.dbar__head b{ font-family:var(--font-mono); color:var(--accent-text); }
.dbar__track{ height:7px; background:var(--line-2); border-radius:6px; overflow:hidden; }
.dbar__track span{ display:block; height:100%; width:var(--v); background:linear-gradient(90deg,var(--cyan),var(--volt)); border-radius:6px; }
.detail__cta{ display:flex; gap:14px; flex-wrap:wrap; }
.detail__rich{ margin-top:clamp(50px,8vh,100px); display:flex; flex-direction:column; gap:clamp(36px,5vh,64px); }
.detail__loading{ color:var(--paper-dim); font-family:var(--font-mono); font-size:13px; }
.detail__block h3{ margin-bottom:14px; }
.detail__block p{ font-size:17px; line-height:1.65; color:var(--paper); max-width:70ch; }
.ratings{ display:flex; gap:18px; flex-wrap:wrap; }
.rating{ border:1px solid var(--line-2); border-radius:16px; padding:20px 28px; min-width:150px; }
.rating b{ font-family:var(--font-display); font-weight:600; font-size:40px; color:var(--volt); line-height:1; }
.rating i{ font-style:normal; font-family:var(--font-mono); font-size:13px; color:var(--paper-dim); }
.rating span{ display:block; margin-top:8px; font-size:13px; color:var(--paper-dim); }
.metagrid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:16px; overflow:hidden; }
.metarow{ display:flex; justify-content:space-between; gap:12px; padding:16px 20px; background:var(--ink); }
.metarow span{ color:var(--paper-dim); font-size:13px; }
.metarow b{ font-weight:600; font-size:14px; text-align:right; }
.proscons{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.proscons__col{ border:1px solid var(--line); border-radius:18px; padding:26px; background:var(--ink-card); }
.proscons__col h4{ font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; margin-bottom:14px; }
.proscons__col--pro h4{ color:var(--accent-text); }
.proscons__col--con h4{ color:var(--coral); }
.proscons__col ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.proscons__col li{ font-size:15px; line-height:1.45; padding-left:22px; position:relative; color:var(--paper); }
.proscons__col--pro li::before{ content:"＋"; position:absolute; left:0; color:var(--accent-text); }
.proscons__col--con li::before{ content:"－"; position:absolute; left:0; color:var(--coral); }
.detail__official{ align-self:flex-start; font-family:var(--font-mono); font-size:13px; color:var(--accent-text); border-bottom:1px solid var(--line-2); padding-bottom:3px; }
.detail__similar{ margin-top:clamp(56px,8vh,100px); }
.detail__similar .detail__sub{ margin-bottom:22px; }

/* compare page links */
.compare__links{ display:flex; gap:14px; justify-content:center; margin-top:26px; flex-wrap:wrap; }
.compare-page .compare__wrap{ padding:0; }

/* match page reuses .quiz/.result; ensure relative for glow */
.match-page{ position:relative; }

@media (max-width:1080px){
  .detail__top{ grid-template-columns:1fr; }
  .detail__media{ max-width:460px; }
  .grid--4{ grid-template-columns:repeat(2,1fr); }
  .band__inner{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  .proscons{ grid-template-columns:1fr; }
  .cat__reset{ margin-left:0; }
  .lineup__foot{ flex-direction:column; align-items:flex-start; }
  .grid{ grid-template-columns:repeat(auto-fill,minmax(46%,1fr)); gap:14px; }
  .grid--4{ grid-template-columns:1fr 1fr; }
}

/* =================================================================
   COMMUNITY SCORING (Haze Score)
   ================================================================= */
.detail__score-lbl{ display:block; font-family:var(--font-mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:#9A9C97; text-align:right; margin-bottom:2px; }

/* card Haze chip (on the dark media) */
.rcard__haze{ position:absolute; left:14px; bottom:14px; z-index:3; display:inline-flex; align-items:baseline; gap:5px; font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--volt); background:rgba(8,9,11,.46); backdrop-filter:blur(6px); border:1px solid rgba(250,248,243,.16); padding:4px 11px; border-radius:100px; }
.rcard__haze i{ font-family:var(--font-mono); font-size:8px; letter-spacing:.12em; color:#CFC9B6; font-style:normal; }
.rcard__haze--low, .rcard__haze.is-pending{ color:#CFC9B6; }
.rcard:hover .rcard__haze{ border-color:rgba(250,248,243,.3); }

/* score section */
.cscore{ margin-top:clamp(50px,8vh,96px); padding-top:clamp(40px,6vh,72px); border-top:1px solid var(--line); }
.cscore__head{ display:flex; align-items:baseline; gap:18px; flex-wrap:wrap; margin-bottom:30px; }
.cscore__tagline{ font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; color:var(--paper-dim); font-style:italic; }
.cscore__pending{ border:1px dashed var(--line-2); border-radius:20px; padding:44px; text-align:center; }
.cscore__pending h3{ font-family:var(--font-display); font-weight:600; font-size:26px; margin-bottom:8px; }
.cscore__pending p{ color:var(--paper-dim); margin-bottom:22px; }
.cscore__grid{ display:grid; grid-template-columns:auto 1fr; gap:clamp(28px,5vw,60px); align-items:center; padding:8px 0 30px; }
.cscore__haze{ display:flex; flex-direction:column; align-items:center; gap:10px; text-align:center; }
.hazewheel{ width:140px; height:140px; }
.hazewheel__bg{ fill:none; stroke:var(--line-2); stroke-width:8; }
.hazewheel__fg{ fill:none; stroke:var(--volt); stroke-width:8; stroke-linecap:round; transform:rotate(-90deg); transform-origin:60px 60px; }
.hazewheel__n{ fill:var(--paper); font-family:var(--font-display); font-weight:600; font-size:36px; text-anchor:middle; }
.hazewheel__o{ fill:var(--paper-dim); font-family:var(--font-mono); font-size:10px; text-anchor:middle; }
.cscore__state{ font-family:var(--font-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-text); }
.cscore__based{ font-size:13px; color:var(--paper-dim); max-width:220px; }
.cscore__based b{ color:var(--paper); }
.cscore__conf{ font-family:var(--font-mono); font-size:11px; padding:4px 12px; border-radius:100px; border:1px solid var(--line-2); }
.cscore__conf--high{ color:var(--accent-text); border-color:currentColor; }
.cscore__conf--low{ color:var(--paper-dim); }
.cscore__reading{ display:flex; flex-direction:column; gap:12px; align-items:flex-start; }
.cscore__reading p{ font-size:clamp(17px,1.7vw,22px); line-height:1.45; color:var(--paper); max-width:46ch; }
.cscore__polar{ font-family:var(--font-mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--coral); }
.cscore__signals{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin:10px 0 40px; }
.signal{ border:1px solid var(--line); border-radius:16px; padding:20px; background:var(--ink-card); }
.signal b{ display:block; font-family:var(--font-display); font-weight:600; font-size:clamp(18px,2vw,26px); line-height:1.1; }
.signal span{ display:block; margin-top:8px; font-size:12px; color:var(--paper-dim); }
.signal--warn b{ color:var(--coral); font-size:15px; }
.cscore__panels{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,54px); margin-bottom:40px; }
.cscore__bars{ display:flex; flex-direction:column; gap:13px; margin-top:16px; }
.cscore__quotes{ display:flex; flex-direction:column; gap:14px; margin-top:16px; }
.quote{ border:1px solid var(--line); border-left:3px solid var(--accent-text); border-radius:0 14px 14px 0; padding:18px 20px; background:var(--ink-card); }
.quote--you{ border-left-color:var(--volt); }
.quote blockquote{ font-size:15px; line-height:1.5; color:var(--paper); }
.quote figcaption{ margin-top:10px; font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:var(--paper-dim); }
.cscore__dist .cscore__distgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,40px); margin-top:16px; }
.distcol h5{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:12px; }
.distrow{ display:grid; grid-template-columns:1fr 1.4fr auto; align-items:center; gap:10px; margin-bottom:9px; font-size:13px; }
.distbar{ height:6px; background:var(--line-2); border-radius:6px; overflow:hidden; }
.distbar i{ display:block; height:100%; background:linear-gradient(90deg,var(--cyan),var(--volt)); border-radius:6px; }
.distrow b{ font-family:var(--font-mono); color:var(--paper-dim); }

/* compare Haze head-to-head */
.compare__haze{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:16px; padding:26px; margin-bottom:30px; border:1px solid var(--line); border-radius:20px; background:linear-gradient(180deg,var(--ink-card),transparent); }
.cmphz__cell{ display:flex; flex-direction:column; gap:4px; }
.cmphz__cell:last-child{ text-align:right; align-items:flex-end; }
.cmphz__name{ font-size:13px; color:var(--paper-dim); }
.cmphz__score{ font-family:var(--font-display); font-weight:600; font-size:44px; line-height:1; color:var(--volt); }
.cmphz__score i{ font-style:normal; font-family:var(--font-mono); font-size:12px; color:var(--paper-dim); margin-left:4px; }
.cmphz__keep{ font-size:12px; color:var(--paper-dim); }
.cmphz__vs{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent-text); }

/* contribution modal */
body.modal-open{ overflow:hidden; }
.csmodal{ position:fixed; inset:0; z-index:9500; display:none; align-items:center; justify-content:center; padding:20px; }
.csmodal.is-open{ display:flex; }
.csmodal__scrim{ position:absolute; inset:0; background:rgba(8,9,11,.6); backdrop-filter:blur(6px); }
.csmodal__panel{ position:relative; z-index:1; width:min(640px,100%); max-height:90vh; max-height:90dvh; overflow-y:auto; -webkit-overflow-scrolling:touch; overscroll-behavior:contain; background:var(--ink-soft); border:1px solid var(--line-2); border-radius:24px; padding:clamp(24px,4vw,40px); }
.csmodal__close{ position:absolute; top:18px; right:18px; width:34px; height:34px; border:1px solid var(--line-2); border-radius:50%; color:var(--paper); }
.csmodal__head .kicker{ color:var(--accent-text); }
.csmodal__head h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(22px,3vw,32px); margin:6px 0 18px; }
.csmodal__dots{ display:flex; gap:6px; margin-bottom:24px; }
.csmodal__dot{ width:30px; height:3px; border-radius:3px; background:var(--line-2); transition:background .4s; }
.csmodal__dot.is-on{ background:var(--volt); }
.csstep{ display:none; }
.csstep.is-active{ display:block; }
.csstep h4{ font-family:var(--font-display); font-weight:600; font-size:20px; margin-bottom:18px; }
.csstep .field{ margin-bottom:18px; }
.csstep .field > label{ display:block; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:8px; }
.chips{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{ font-size:13px; padding:9px 15px; border:1px solid var(--line-2); border-radius:100px; color:var(--paper); transition:.25s; }
.chip:hover{ border-color:var(--paper); }
.chip.is-on{ background:var(--volt); color:#111209; border-color:var(--volt); }
.csopt{ padding:16px 18px; }
.csopt.is-picked{ border-color:var(--volt); background:linear-gradient(180deg,rgba(200,169,106,.14),transparent); }
.csstep__hint{ font-size:13px; color:var(--paper-dim); line-height:1.5; margin:-6px 0 18px; }
.sliders{ display:grid; grid-template-columns:1fr 1fr; gap:18px 24px; }
.slider{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:6px 12px; }
.slider__head{ grid-column:1/-1; display:flex; flex-direction:column; gap:1px; margin-bottom:-2px; }
.slider__name{ font-size:13px; color:var(--paper); }
.slider__desc{ font-size:11px; color:var(--paper-dim); line-height:1.3; }
.slider input[type=range]{ width:100%; accent-color:var(--volt); cursor:none; }
.slider__val{ font-family:var(--font-mono); font-size:13px; color:var(--accent-text); min-width:74px; text-align:right; white-space:nowrap; align-self:center; }
.csstep textarea{ width:100%; background:var(--ink-card); border:1px solid var(--line-2); border-radius:12px; padding:12px 14px; font:inherit; font-size:15px; color:var(--paper); resize:vertical; }
.cssuggest{ margin-top:12px; }
.cssuggest__label{ display:block; font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:8px; }
.cssuggest__chips{ display:flex; flex-wrap:wrap; gap:7px; }
.cssuggest__chip{ font-size:12px; color:var(--paper); border:1px solid var(--line-2); border-radius:100px; padding:6px 11px; transition:border-color .2s, background .2s, color .2s; }
.cssuggest__chip:hover{ border-color:var(--volt); color:var(--volt); }
.cssuggest__chip.is-used{ background:color-mix(in srgb, var(--volt) 16%, transparent); border-color:transparent; color:var(--accent-text); }
.csexample__toggle{ margin-top:16px; font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; color:var(--accent-text); text-decoration:underline; text-underline-offset:3px; }
.csexample{ margin-top:12px; display:flex; flex-direction:column; gap:10px; }
.csexample__tag{ font-family:var(--font-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-dim); }
.csexample__q{ font-size:13.5px; line-height:1.55; color:var(--paper-dim); border-left:2px solid var(--line-2); padding:4px 0 4px 14px; font-style:italic; }
.csfreebie{ display:flex; align-items:center; gap:10px; font-size:13px; color:var(--paper-dim); margin-top:18px; }
.csfreebie input{ accent-color:var(--volt); }
.cssummary .csrow{ display:flex; justify-content:space-between; gap:14px; padding:12px 0; border-bottom:1px solid var(--line); font-size:14px; }
.cssummary .csnote{ font-size:12px; color:var(--coral); margin-top:10px; }
.csimpact{ display:flex; justify-content:space-between; align-items:center; margin-top:18px; padding:18px; border-radius:14px; background:var(--ink-card); }
.csimpact b{ font-family:var(--font-display); font-weight:600; font-size:24px; color:var(--accent-text); }
.csmodal__nav{ display:flex; justify-content:space-between; gap:12px; margin-top:26px; }

/* toast */
.toast{ position:fixed; left:50%; bottom:30px; transform:translate(-50%,20px); z-index:9600; background:#1A2C1E; color:#FAF8F3; padding:14px 24px; border-radius:100px; font-size:14px; opacity:0; pointer-events:none; transition:opacity .4s, transform .4s; box-shadow:0 10px 40px rgba(0,0,0,.3); }
.toast.is-on{ opacity:1; transform:translate(-50%,0); }

/* =================================================================
   PHASE 0 — empty-state community + preview · auth · profile · legal
   ================================================================= */

/* nav account control */
.nav__account{ display:inline-flex; align-items:center; gap:8px; padding:5px 14px 5px 5px; border:1px solid var(--line); border-radius:100px; color:var(--paper); transition:border-color .3s, color .3s; }
.nav__account:hover{ border-color:var(--line-2); color:var(--volt); }
.nav__account-avatar{ width:28px; height:28px; flex:0 0 auto; display:flex; align-items:center; justify-content:center; border-radius:50%; background:var(--ink-card); font-family:var(--font-display); font-weight:600; font-size:13px; color:var(--accent-text); }
.nav__account-avatar svg{ width:15px; height:15px; }
.nav__account.is-auth .nav__account-avatar{ background:var(--volt); color:#111209; }
.nav__account.is-auth .nav__account-avatar svg{ display:none; }
.nav__account-label{ font-size:13px; }

/* community — honest empty state */
.cscore__empty{ display:grid; gap:24px; }
.cscore__empty-main{ display:flex; align-items:center; gap:clamp(20px,4vw,44px); flex-wrap:wrap; border:1px dashed var(--line-2); border-radius:20px; padding:clamp(24px,4vw,40px); }
.hazewheel--pending{ width:118px; height:118px; flex:0 0 auto; opacity:.75; }
.hazewheel--pending .hazewheel__n{ font-size:30px; fill:var(--paper-dim); }
.cscore__empty-text{ flex:1; min-width:260px; }
.cscore__empty-text h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(22px,2.6vw,30px); margin-bottom:8px; }
.cscore__empty-text > p{ color:var(--paper-dim); max-width:52ch; margin-bottom:18px; }
.cscore__expect{ list-style:none; display:flex; flex-direction:column; gap:7px; margin-top:16px; }
.cscore__expect li{ position:relative; padding-left:22px; font-size:13.5px; color:var(--paper); }
.cscore__expect li::before{ content:"›"; position:absolute; left:6px; color:var(--volt); font-weight:700; }
.cscore__yours{ border:1px solid var(--line); border-radius:16px; padding:20px; background:var(--ink-card); }
.cscore__yours .kicker{ color:var(--accent-text); margin-bottom:10px; }
.cscore__progress{ font-family:var(--font-mono); font-size:12px; color:var(--paper-dim); margin-top:12px; }

/* community — illustrative preview (clearly labelled, never a real score) */
.cspreview-wrap{ margin-top:26px; }
.cspreview__toggle{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; color:var(--accent-text); border:1px solid var(--line-2); border-radius:100px; padding:10px 18px; transition:border-color .25s; }
.cspreview__toggle:hover{ border-color:var(--volt); }
.cspreview__toggle svg{ transition:transform .35s var(--ease); }
.cspreview-wrap.is-open .cspreview__toggle svg{ transform:rotate(180deg); }
.cspreview__toggle .t-hide{ display:none; }
.cspreview-wrap.is-open .cspreview__toggle .t-show{ display:none; }
.cspreview-wrap.is-open .cspreview__toggle .t-hide{ display:inline; }
.cspreview-panel{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .5s var(--ease), margin-top .4s; }
.cspreview-wrap.is-open .cspreview-panel{ grid-template-rows:1fr; margin-top:18px; }
.cspreview-panel__inner{ min-height:0; overflow:hidden; opacity:0; transition:opacity .45s ease; }
.cspreview-wrap.is-open .cspreview-panel__inner{ opacity:1; }
.cspreview__note{ font-size:13.5px; color:var(--paper-dim); max-width:72ch; margin-bottom:16px; font-style:italic; }
.cspreview{ position:relative; border:1px dashed var(--line-2); border-radius:20px; padding:clamp(22px,3vw,36px); overflow:hidden; }
.cspreview__ribbon{ position:absolute; top:0; left:0; z-index:3; font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; background:var(--cyan); color:#FAF8F3; padding:5px 12px; border-radius:0 0 12px 0; }
.cspreview__inner{ position:relative; opacity:.85; }
.cspreview__stamp{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:700; font-size:clamp(30px,7vw,72px); letter-spacing:.08em; text-transform:uppercase; color:var(--paper); opacity:.05; transform:rotate(-11deg); pointer-events:none; z-index:1; white-space:nowrap; }
.cspreview__top{ display:grid; grid-template-columns:auto 1fr; gap:clamp(20px,4vw,44px); align-items:center; margin:22px 0 26px; position:relative; z-index:2; }
.cspreview__top .cscore__haze-demo{ filter:saturate(.55); }
.cspreview__signals{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.cspreview__subs, .cspreview__say{ position:relative; z-index:2; }
.cspreview__subs{ margin-bottom:24px; }
.cspreview__subs .kicker, .cspreview__say .kicker{ color:var(--accent-text); }
.quote--example{ border-left-color:var(--line-2); }

/* auth modal (built on .csmodal) */
.authmodal[data-mode="signin"] [data-signup]{ display:none; }
.auth-sub{ color:var(--paper-dim); font-size:14px; margin:-8px 0 18px; }
.authform .field{ display:block; margin-bottom:14px; }
.authform .field > span{ display:block; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:7px; }
.authform input{ width:100%; background:var(--ink-card); border:1px solid var(--line-2); border-radius:12px; padding:12px 14px; font:inherit; font-size:15px; color:var(--paper); }
.authform input:focus{ outline:none; border-color:var(--volt); }
.authprofile{ border-top:1px solid var(--line); margin-top:8px; padding-top:16px; }
.authprofile .kicker{ color:var(--accent-text); }
.auth-hint{ font-size:12px; color:var(--paper-dim); margin:6px 0 14px; }
.authprofile .field{ margin-bottom:14px; }
.authprofile .field > label{ display:block; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:8px; }
.auth-err{ color:var(--coral); font-size:13px; margin-bottom:12px; }
#authSubmit{ width:100%; justify-content:center; }
.auth-switch{ text-align:center; margin-top:16px; }
.auth-switch button{ font-size:13px; color:var(--accent-text); text-decoration:underline; text-underline-offset:3px; }
.auth-note{ text-align:center; font-size:11px; color:var(--paper-dim); margin-top:14px; }
.auth-gate{ border:1px solid var(--volt); background:linear-gradient(180deg,rgba(200,169,106,.14),transparent); border-radius:14px; padding:14px 16px; margin-bottom:18px; }
.auth-gate .kicker{ color:var(--accent-text); }
.auth-gate p{ font-size:13.5px; color:var(--paper); margin-top:5px; }
.auth-alt{ margin-top:16px; }
.auth-or{ display:flex; align-items:center; gap:12px; justify-content:center; font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:14px; }
.auth-or i{ flex:1; height:1px; background:var(--line); }
.auth-google{ width:100%; justify-content:center; gap:10px; }
.quote__report{ margin-left:10px; font-family:var(--font-mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--paper-dim); text-decoration:underline; text-underline-offset:2px; }
.quote__report:hover{ color:var(--coral); }

/* profile page */
.profile__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,36px); }
.profile__card{ border:1px solid var(--line); border-radius:20px; padding:clamp(22px,3vw,32px); background:var(--ink-card); }
.profile__card > .kicker{ color:var(--accent-text); display:block; margin-bottom:18px; }
.profile__card .field{ margin-bottom:14px; }
.profile__card .field > span, .profile__card .field > label{ display:block; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:8px; }
.profile__card input{ width:100%; background:var(--ink-soft); border:1px solid var(--line-2); border-radius:12px; padding:12px 14px; font:inherit; font-size:15px; color:var(--paper); }
.profile__card input:focus{ outline:none; border-color:var(--volt); }
.profile__card input:disabled{ opacity:.55; }
.profile__since{ font-size:13px; color:var(--paper-dim); margin-top:6px; }
.profile__actions{ display:flex; gap:14px; flex-wrap:wrap; margin:30px 0; }
.profile__block{ margin-top:20px; }
.profile__block > .kicker{ display:block; margin-bottom:18px; }
.profile__reviews{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; }
.profrev{ display:flex; align-items:center; gap:14px; border:1px solid var(--line); border-radius:14px; padding:12px 14px; background:var(--ink-card); transition:border-color .25s; }
.profrev:hover{ border-color:var(--volt); }
.profrev img{ width:46px; height:46px; object-fit:contain; flex:0 0 auto; }
.profrev b{ display:block; font-size:14px; }
.profrev span{ font-size:12px; color:var(--paper-dim); }
.profile__empty{ color:var(--paper-dim); }
.profile__guest{ border:1px dashed var(--line-2); border-radius:20px; padding:clamp(28px,5vw,48px); text-align:center; max-width:640px; }
.profile__guest h3{ font-family:var(--font-display); font-weight:600; font-size:26px; margin-bottom:8px; }
.profile__guest p{ color:var(--paper-dim); margin-bottom:22px; }
.profile__guest-cta{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }

/* legal pages */
.legal__body{ max-width:760px; }
.legal__body h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(18px,2vw,24px); margin:30px 0 10px; }
.legal__body p, .legal__body li{ color:var(--paper); line-height:1.65; margin-bottom:10px; font-size:15px; }
.legal__body ul{ padding-left:20px; margin-bottom:10px; }
.legal__body a{ color:var(--accent-text); text-decoration:underline; }
.legal__body .legal-draft{ font-family:var(--font-mono); font-size:12px; color:var(--coral); border:1px solid var(--line-2); border-radius:12px; padding:12px 14px; background:linear-gradient(180deg,rgba(181,104,60,.08),transparent); }

/* about page */
.page__lede{ color:var(--paper-dim); font-size:clamp(15px,1.5vw,18px); line-height:1.5; max-width:620px; }
.about__body .about-lede{ font-size:clamp(17px,1.9vw,21px); line-height:1.5; color:var(--paper); margin-bottom:10px; }
.about__body section{ scroll-margin-top:104px; padding-top:26px; margin-top:26px; border-top:1px solid var(--line); }
.about__body section:first-of-type{ border-top:0; }
.about__body h3{ display:flex; align-items:center; gap:12px; }
.about__body h3::before{ content:""; width:22px; height:2px; background:var(--accent-text); border-radius:2px; flex:none; }

/* footer legal links */
.footer__legal{ display:flex; gap:18px; flex-wrap:wrap; }
.footer__legal a{ font-size:13px; color:var(--link-soft); }
.footer__legal a:hover{ color:var(--hover); }

/* consent banner */
.consent{ position:fixed; left:50%; bottom:24px; transform:translate(-50%,150%); z-index:9400; width:min(740px,calc(100% - 32px)); display:flex; align-items:center; gap:18px; flex-wrap:wrap; justify-content:space-between; background:var(--ink-soft); border:1px solid var(--line-2); border-radius:18px; padding:16px 20px; box-shadow:0 20px 60px rgba(0,0,0,.18); opacity:0; transition:transform .5s var(--ease), opacity .4s; }
.consent.is-on{ transform:translate(-50%,0); opacity:1; }
.consent.is-hiding{ transform:translate(-50%,150%); opacity:0; }
.consent p{ font-size:13px; color:var(--paper); flex:1; min-width:240px; line-height:1.5; }
.consent a{ color:var(--accent-text); text-decoration:underline; }
.consent__btns{ display:flex; gap:10px; flex-wrap:wrap; }
.consent__btns .btn{ padding:10px 16px; font-size:13px; }

@media (max-width:860px){
  .profile__grid{ grid-template-columns:1fr; }
  .cspreview__top{ grid-template-columns:1fr; justify-items:start; }
  .cspreview__signals{ grid-template-columns:1fr; }
  .cscore__empty-main{ flex-direction:column; align-items:flex-start; }
}

@media (max-width:980px){
  .cscore__grid{ grid-template-columns:1fr; justify-items:start; }
  .cscore__signals{ grid-template-columns:repeat(2,1fr); }
  .cscore__panels{ grid-template-columns:1fr; }
  .cscore__dist .cscore__distgrid{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .cscore__signals{ grid-template-columns:1fr 1fr; }
  .sliders{ grid-template-columns:1fr; }
  .compare__haze{ grid-template-columns:1fr; text-align:center; }
  .cmphz__cell:last-child{ text-align:center; align-items:center; }
}

/* =================================================================
   KEYBOARD FOCUS — the design hides the system cursor (cursor:none),
   so every interactive element needs a clear :focus-visible ring.
   Placed last so it overrides the earlier `:focus{ outline:none }`
   rules on text inputs for keyboard users.
   ================================================================= */
a:focus-visible, button:focus-visible, select:focus-visible, textarea:focus-visible,
input:focus-visible, .chip:focus-visible, .opt:focus-visible, .csopt:focus-visible,
.cspreview__toggle:focus-visible, .nav__account:focus-visible, .footer__lang button:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid var(--volt); outline-offset:3px;
}
.authform input:focus-visible, .profile__card input:focus-visible, .cat__search input:focus-visible{
  outline:2px solid var(--volt); outline-offset:2px;
}
/* skip-to-content link (a11y) — off-screen until keyboard-focused */
.skip-link{ position:absolute; top:10px; left:10px; z-index:200; transform:translateY(-220%);
  background:var(--volt); color:#111209; padding:10px 18px; border-radius:10px;
  font-family:var(--font-mono); font-size:13px; letter-spacing:.04em; text-decoration:none;
  transition:transform .18s var(--ease); }
.skip-link:focus{ transform:translateY(0); outline:2px solid #111209; outline-offset:2px; }
#app:focus, #app:focus-visible{ outline:none; }   /* programmatic focus target on route change */
@media (prefers-reduced-motion:reduce){
  .skip-link{ transition:none; }
  .cspreview-panel, .cspreview-panel__inner{ transition:none !important; }
}
