/* ===================== RacketIQ — shared site styles ===================== */
:root{
  --bg:#ffffff; --panel:#ffffff; --panel-2:#f3f6f9; --line:#e3e9ef;
  --ink:#16222e; --ink-soft:#3a4753; --muted:#566472; --faint:#647280;
  --accent:#12b386; --accent-2:#0e9b73; --accent-ink:#04241c; --accent-text:#0a7d5e;
  --tint:#e8f7f1; --tint-ink:#0f5a43;
  --warn:#c9821a; --bad:#d64545; --good:#0a7d5e;
  --shadow:0 6px 24px rgba(20,40,55,.08);
  --radius:16px;
  --font:'Segoe UI',-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--accent-text);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}
.narrow{max-width:760px}
.hide{display:none!important}
em{color:var(--accent-text);font-style:normal}

/* ---------- top nav ---------- */
.topbar{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:62px;gap:16px}
.brand{display:flex;align-items:center;gap:11px}
.brand:hover{text-decoration:none}
.logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:grid;place-items:center;color:var(--accent-ink);font-weight:800;font-size:18px}
.brand b{font-size:17px;color:var(--ink);letter-spacing:.2px}
nav.main{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
nav.main a{color:var(--muted);font-size:14px;padding:8px 12px;border-radius:9px;font-weight:500}
nav.main a:hover{color:var(--ink);background:var(--panel-2);text-decoration:none}
nav.main a.active{color:var(--ink);background:var(--panel-2)}
nav.main a.cta{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--accent-ink);font-weight:700}
nav.main a.cta:hover{filter:brightness(1.08)}
.navtoggle{display:none;background:none;border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:7px 11px;font-size:18px;cursor:pointer}
@media(max-width:760px){
  .navtoggle{display:block}
  nav.main{display:none;position:absolute;top:62px;left:0;right:0;background:var(--panel);border-bottom:1px solid var(--line);flex-direction:column;padding:10px;gap:2px}
  nav.main.open{display:flex}
  nav.main a{width:100%;padding:11px 12px}
}

/* ---------- buttons ---------- */
.btn{display:inline-block;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--accent-ink);
  border:none;padding:13px 26px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s}
.btn:hover{filter:brightness(1.07);transform:translateY(-1px);text-decoration:none}
.btn.lg{padding:15px 32px;font-size:16px}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.ghost{display:inline-block;background:transparent;border:1px solid var(--line);color:var(--muted);padding:12px 22px;
  border-radius:12px;font-size:14px;cursor:pointer;font-family:inherit;font-weight:600}
.ghost:hover{border-color:var(--accent);color:var(--ink);text-decoration:none}

/* ---------- generic sections ---------- */
.section{padding:52px 0}
.section.tight{padding:34px 0}
.eyebrow{font-size:12.5px;color:var(--accent-text);text-transform:uppercase;letter-spacing:2px;font-weight:700;margin:0 0 10px}
h1.page{font-size:34px;margin:0 0 8px;line-height:1.15}
h2.sec{font-size:25px;margin:0 0 6px}
.lead{color:var(--muted);font-size:17px;margin:0 0 6px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.pad{padding:28px 30px}
@media(max-width:640px){.pad{padding:20px 18px}}

/* ---------- hero ---------- */
.hero{padding:64px 0 40px;background:radial-gradient(1100px 520px at 78% -20%,var(--tint) 0%,transparent 65%)}
.hero h1{font-size:42px;line-height:1.1;margin:0 0 16px;max-width:760px}
.hero p.sub{font-size:19px;color:var(--muted);max-width:620px;margin:0 0 26px}
.hero .cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
@media(max-width:640px){.hero h1{font-size:31px}.hero p.sub{font-size:16px}}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.hero-text{min-width:0}
.hero-img img{width:100%;height:auto;max-height:380px;object-fit:cover;border-radius:16px;box-shadow:var(--shadow);display:block}
@media(max-width:760px){.hero-grid{grid-template-columns:1fr;gap:22px}}
.banner{margin:0 0 22px;position:relative}
.banner-tint{position:absolute;inset:0;border-radius:14px;background:linear-gradient(120deg,rgba(18,179,134,.32),rgba(14,155,115,.16));mix-blend-mode:multiply;pointer-events:none}
.video{margin:0 0 22px}
.vidcard{display:flex;gap:14px;align-items:center;text-decoration:none;border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--panel);box-shadow:var(--shadow);transition:.15s}
.vidcard:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-1px)}
.vthumb{position:relative;flex:0 0 auto;width:190px;aspect-ratio:16/9;border-radius:9px;overflow:hidden;background:#0b0b0b}
.vthumb img{width:100%;height:100%;object-fit:cover;display:block}
.vplay{position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:30px;text-shadow:0 2px 8px rgba(0,0,0,.6)}
.vmeta b{display:block;color:var(--ink);font-size:15px;margin-bottom:3px}
.vmeta span{color:var(--muted);font-size:12.5px}
@media(max-width:520px){.vidcard{flex-direction:column;align-items:stretch}.vthumb{width:100%}}
.banner img{width:100%;height:200px;object-fit:cover;border-radius:14px;box-shadow:var(--shadow);display:block}
@media(max-width:560px){.banner img{height:150px}}
.legal a{color:var(--muted);text-decoration:underline}
.pills{display:flex;flex-wrap:wrap;gap:10px;margin:26px 0 0}
.pill{display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:30px;padding:7px 14px;font-size:13px;color:var(--muted)}
.pill b{color:var(--ink)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}

/* ---------- card grids ---------- */
.grid{display:grid;gap:16px}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.grid.c3,.grid.c4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid.c2,.grid.c3,.grid.c4{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;transition:.15s}
.card.link:hover{border-color:var(--accent);transform:translateY(-2px)}
.card .ico{font-size:26px;margin-bottom:10px}
.card h3{margin:0 0 6px;font-size:18px}
.card p{margin:0;color:var(--muted);font-size:14px}
.card .more{display:inline-block;margin-top:12px;color:var(--accent-text);font-size:13.5px;font-weight:600}

/* ---------- game promo and play page ---------- */
.game-promo-band{background:linear-gradient(180deg,#ffffff 0%,#f7fbf9 100%)}
.game-promo{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,420px);gap:28px;align-items:center}
.game-promo .cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.game-promo-preview{display:block;text-decoration:none}
.game-promo-preview:hover{text-decoration:none}
.mini-court{position:relative;display:block;min-height:220px;overflow:hidden;border:1px solid var(--line);border-radius:14px;background:linear-gradient(#bfe3f5 0 72%,#cfb584 72%);box-shadow:var(--shadow)}
.mini-court:before{content:'';position:absolute;left:8%;right:8%;bottom:28%;height:2px;background:#fff;box-shadow:0 -72px 0 rgba(255,255,255,.38)}
.mini-net{position:absolute;left:50%;bottom:28%;width:2px;height:48%;background:#e9eef2;transform:translateX(-1px)}
.mini-net:after{content:'';position:absolute;left:-18px;right:-18px;top:0;height:3px;background:#1c2a33;border-radius:3px}
.mini-player{position:absolute;bottom:29%;width:24px;height:70px}
.mini-player.left{left:24%}
.mini-player.right{right:24%;transform:scaleX(-1)}
.mini-player:before{content:'';position:absolute;left:6px;top:0;width:18px;height:18px;border-radius:50%;background:#1c2530}
.mini-player:after{content:'';position:absolute;left:14px;top:20px;width:4px;height:50px;border-radius:6px;background:#1c2530;box-shadow:-10px 46px 0 -1px #1c2530,10px 46px 0 -1px #1c2530}
.mini-shuttle{position:absolute;left:47%;top:28%;width:14px;height:14px;border-radius:50%;background:#fff;border:1px solid #9fb0c0;animation:miniRally 1.8s ease-in-out infinite alternate}
@keyframes miniRally{from{transform:translate(-130px,36px)}to{transform:translate(130px,-18px)}}

.game-page{background:linear-gradient(180deg,#ffffff 0%,#f6fbf8 54%,#f8fafc 100%)}
.game-page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px}
.game-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:18px;align-items:start}
.game-main{overflow:hidden;background:var(--panel);box-shadow:0 18px 54px rgba(15,35,50,.12)}
.game-stage{position:relative;background:#123448}
.game-stage canvas{display:block;width:100%;height:auto;aspect-ratio:16/9;background:#123448;touch-action:none}
.game-overlay{position:absolute;inset:0;display:grid;place-items:center;padding:20px;background:linear-gradient(135deg,rgba(8,28,40,.64),rgba(11,63,75,.42));backdrop-filter:blur(3px)}
.game-overlay-card{width:min(410px,100%);background:rgba(255,255,255,.95);border:1px solid rgba(255,255,255,.78);border-radius:14px;padding:28px;text-align:center;box-shadow:0 18px 50px rgba(15,35,50,.24)}
.game-overlay-card h2{font-size:28px;line-height:1.15;margin:0 0 8px}
.game-overlay-card p{margin:0 0 18px;color:var(--muted);font-size:15px}
.game-overlay-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.game-modes{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.game-modes-label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.game-modes-row{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.game-modes-row .ghost{font-size:13px;padding:8px 12px}
.feed-speed.on{border-color:var(--accent);background:var(--tint);color:var(--tint-ink)}
.game-setup{margin-top:4px;padding-top:14px;border-top:1px solid var(--line)}
.char-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0 0 14px}
.char-pick{display:flex;align-items:center;gap:8px;padding:9px 11px;border:1.5px solid var(--line);border-radius:10px;background:var(--panel-2);color:var(--ink);font-weight:700;font-size:14px;cursor:pointer;transition:border-color .12s,background .12s}
.char-pick small{margin-left:auto;color:var(--faint);font-weight:600;font-size:11.5px}
.char-pick .char-dot{width:14px;height:14px;border-radius:50%;flex:none;box-shadow:inset 0 0 0 1px rgba(0,0,0,.18)}
.char-pick:hover{border-color:var(--accent)}
.char-pick.on{border-color:var(--accent);background:var(--tint);color:var(--tint-ink)}
.diff-row{display:flex;justify-content:center;gap:8px}
.diff-pick{flex:1;padding:9px 0;border:1.5px solid var(--line);border-radius:10px;background:var(--panel-2);color:var(--ink);font-weight:700;font-size:14px;cursor:pointer;transition:border-color .12s,background .12s}
.diff-pick:hover{border-color:var(--accent)}
.diff-pick.on{border-color:var(--accent);background:var(--accent);color:var(--accent-ink)}
.game-toolbar{display:grid;grid-template-columns:1fr minmax(160px,240px) auto;align-items:center;gap:12px;padding:12px 14px;border-top:1px solid var(--line);background:var(--panel)}
.game-status{display:flex;flex-direction:column;gap:2px;min-width:0}
#scoreText{font-weight:800;color:var(--ink);font-size:14px}
#statusText{color:var(--faint);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.power-wrap{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center;color:var(--faint);font-size:12px;text-transform:uppercase;letter-spacing:1px;font-weight:700}
.power-track{height:10px;overflow:hidden;border-radius:999px;background:var(--panel-2);border:1px solid var(--line)}
#powerFill{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,#12b386,#e0b33a,#e45f4d);transition:width .12s linear}
.game-actions{display:flex;align-items:center;gap:8px}
.game-icon-btn{min-width:48px;padding:9px 12px;border-radius:10px}
.touch-controls{display:grid;gap:10px;padding:12px;border-top:1px solid var(--line);background:var(--panel-2)}
.control-row{display:grid;gap:10px}
.move-controls{grid-template-columns:auto 1fr 1fr 1fr auto}
.shot-controls{grid-template-columns:repeat(5,1fr)}
.game-pad{min-height:48px;border:1px solid var(--line);border-radius:12px;background:var(--panel);color:var(--ink);font-size:20px;font-weight:800;cursor:pointer;touch-action:none}
.game-pad:hover,.game-pad.on{border-color:var(--accent);background:var(--tint)}
.game-pad.jump{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--accent-ink);border-color:transparent}
.game-pad.shot{font-size:12px;text-transform:uppercase;letter-spacing:.6px;line-height:1.2;padding:8px 9px}
.game-pad.smash{color:#fff;background:linear-gradient(135deg,#e45f4d,#c9821a);border-color:transparent}
.game-pad.smash.on{box-shadow:0 0 0 2px rgba(228,95,77,.22)}
.game-pad.super-pad{color:#fff;background:linear-gradient(135deg,#7a5cc0,#12b386);border-color:transparent;font-weight:800}
.game-pad kbd{display:inline-block;margin-left:6px;padding:1px 5px;border-radius:5px;background:rgba(255,255,255,.82);color:#16222e;border:1px solid rgba(0,0,0,.16);font:700 11px/1.4 ui-monospace,Menlo,Consolas,monospace;vertical-align:middle}
.controls-hint{margin:8px 0 0;text-align:center;font-size:12px;color:var(--muted)}
.controls-hint kbd{display:inline-block;padding:1px 5px;border-radius:5px;background:var(--panel);color:var(--ink);border:1px solid var(--line);font:700 11px/1.4 ui-monospace,Menlo,Consolas,monospace}
.game-side .lead{font-size:15px}
.game-side .why{margin:14px 0 0}
.game-side .why li{font-size:13.5px}
@media(max-width:900px){
  .game-promo,.game-layout{grid-template-columns:1fr}
  .game-side{order:2}
}
@media(max-width:560px){
  .game-page-head{display:block}
  .game-page-head .ghost{margin-top:14px}
  .game-stage canvas{height:340px}
  .game-overlay{padding:14px}
  .game-overlay-card{max-height:calc(100% - 10px);overflow:auto;padding:20px 16px}
  .game-overlay-card h2{font-size:24px}
  .game-overlay-card p{font-size:14px;margin-bottom:14px}
  .game-toolbar{grid-template-columns:1fr;align-items:stretch}
  .power-wrap{grid-template-columns:auto 1fr}
  .game-actions{width:100%;display:grid;grid-template-columns:1fr 1fr}
  .game-icon-btn{width:100%}
  .shot-controls{grid-template-columns:repeat(3,1fr)}
  .game-pad{min-width:0}
  .mini-court{min-height:180px}
}
@media(max-width:380px){.game-stage canvas{height:320px}.game-pad.smash{font-size:12px}.game-pad kbd{display:none}}

/* ---------- prose / articles ---------- */
.prose{font-size:16px;color:var(--ink)}
.prose h2{font-size:23px;margin:34px 0 10px}
.prose h3{font-size:18px;margin:24px 0 6px}
.prose p{color:var(--ink-soft);margin:0 0 14px}
.prose ul,.prose ol{color:var(--ink-soft);padding-left:22px;margin:0 0 16px}
.prose li{margin-bottom:7px}
.prose strong{color:var(--ink)}
.terms{margin:0 0 16px}
.terms>div{padding:11px 0;border-top:1px solid var(--line)}
.terms dt{font-weight:600;color:var(--ink);font-size:15px}
.terms dd{margin:3px 0 0;color:var(--ink-soft);font-size:14.5px}

/* ---------- diagrams (inline SVG) ---------- */
figure.diagram{margin:22px 0;padding:0;text-align:center}
figure.diagram svg{width:100%;height:auto;max-width:540px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px}
figure.diagram figcaption{font-size:13px;color:var(--muted);margin:8px auto 0;max-width:540px}
.dg-courtfill{fill:#eaf4ef;stroke:#2f8466;stroke-width:2}
.dg-line{stroke:#2f8466;stroke-width:1.3;fill:none}
.dg-net{stroke:#1c2a33;stroke-width:3;fill:none}
.dg-ground{stroke:#566472;stroke-width:2}
.dg-base{fill:#12b386}
.dg-target{fill:#ffffff;stroke:#0a7d5e;stroke-width:1.6}
.dg-arrow{stroke:#0a7d5e;stroke-width:2;fill:none}
.dg-p1{fill:#0a7d5e}
.dg-p2{fill:#c9821a}
.dg-clear{stroke:#0a7d5e;stroke-width:2.5;fill:none}
.dg-drop{stroke:#c9821a;stroke-width:2.5;fill:none}
.dg-smash{stroke:#d64545;stroke-width:2.5;fill:none}
.dg-octa{fill:#f3f6f9;stroke:#566472;stroke-width:2}
.dg-hot{stroke:#0a7d5e;fill:none}
.dg-label{fill:#16222e;font-family:var(--font);font-size:13px;font-weight:600}
.dg-sub{fill:#566472;font-family:var(--font);font-size:12px;font-weight:600}
.dg-tiny{fill:#566472;font-family:var(--font);font-size:11px}
.dg-shade{fill:#d6efe4}
.dg-fig{stroke:#16222e;stroke-width:2.5;fill:none}
.dg-fig-fill{fill:#16222e}
.dg-x{stroke:#d64545;stroke-width:4}
.callout{background:var(--tint);border:1px solid var(--accent-2);border-radius:12px;padding:15px 18px;margin:18px 0;color:var(--tint-ink);font-size:15px}
.callout b{color:var(--ink)}

/* dimension / spec explainer cards */
.dim{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:12px;padding:18px 20px;margin-bottom:14px}
.dim h3{margin:0 0 4px;font-size:17px}
.dim .typ{font-size:12.5px;color:var(--faint);margin:0 0 8px}
.dim p{margin:0;color:var(--ink-soft);font-size:14.5px}

/* rule list (buying guides) */
.rule{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:15px 18px;margin-bottom:12px}
.rule .when{font-weight:700;color:var(--ink);font-size:15px}
.rule .prefer{color:var(--accent-text);font-size:14px;margin:6px 0 4px}
.rule .why{color:var(--muted);font-size:13.5px}

/* faq */
.faq details{background:var(--panel);border:1px solid var(--line);border-radius:12px;margin-bottom:10px;overflow:hidden}
.faq summary{cursor:pointer;padding:16px 20px;font-weight:600;font-size:16px;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary:before{content:'+';color:var(--accent-text);font-weight:800;margin-right:10px}
.faq details[open] summary:before{content:'–'}
.faq .ans{padding:0 20px 16px;color:var(--ink-soft);font-size:15px}

/* brand cards */
.brand-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px}
.brand-card h3{margin:0 0 4px;font-size:20px}
.brand-card .kf{color:var(--accent-text);font-size:13px;margin:0 0 10px;font-weight:600}
.brand-card p{color:var(--ink-soft);font-size:14.5px;margin:0 0 10px}
.brand-card .lines{display:flex;flex-wrap:wrap;gap:6px}
.brand-card .lines span{font-size:11.5px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:20px;padding:3px 10px}

/* ---------- catalog browser ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:8px}
.filters select{background:var(--panel-2);border:1px solid var(--line);color:var(--ink);padding:10px 12px;border-radius:10px;font-size:14px;font-family:inherit}
.filters .count{margin-left:auto;color:var(--faint);font-size:13px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.chip{font-size:13px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);border-radius:30px;padding:7px 14px;cursor:pointer}
.chip.on{background:var(--tint);border-color:var(--accent);color:var(--ink)}
.prodgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.prod{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:16px 17px;display:flex;flex-direction:column}
.prod .ptier{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--faint)}
.prod h3{margin:3px 0 2px;font-size:16px}
.prod .brand{color:var(--muted);font-size:12.5px;margin-bottom:8px}
.prod .bf{color:var(--ink-soft);font-size:13px;margin:0 0 10px;flex:1}
.prod .specs{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.prod .specs span{font-size:11px;color:var(--faint);background:var(--panel-2);border:1px solid var(--line);border-radius:6px;padding:2px 7px}
.prod .foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.prod .price{font-size:18px;font-weight:800}
.prod .price small{font-size:12px;color:var(--muted);font-weight:400}
.prod .view{font-size:12.5px;border:1px solid var(--line);padding:5px 11px;border-radius:8px;color:var(--muted)}
.prod .view:hover{border-color:var(--accent);color:var(--ink);text-decoration:none}
.tagrow{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px}
.lvl{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;border-radius:5px;padding:2px 7px;border:1px solid var(--line);color:var(--muted)}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--line);margin-top:40px;background:var(--panel)}
footer.site .wrap{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px;padding:40px 20px 30px}
@media(max-width:760px){footer.site .wrap{grid-template-columns:1fr 1fr}}
footer.site h4{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--faint);margin:0 0 12px}
footer.site a{display:block;color:var(--muted);font-size:14px;margin-bottom:8px}
footer.site a:hover{color:var(--ink)}
footer.site .about p{color:var(--muted);font-size:13.5px;margin:10px 0 0;max-width:280px}
.legal{border-top:1px solid var(--line);text-align:center;color:var(--faint);font-size:12px;padding:16px}

/* ===================== recommender wizard (advisor page) ===================== */
.steplabel{font-size:12.5px;color:var(--faint);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px}
.steps{display:flex;align-items:center;gap:6px;margin-bottom:26px}
.stepdot{flex:1;height:6px;border-radius:6px;background:var(--line);transition:.3s}
.stepdot.on{background:var(--accent)}
.stepdot.done{background:var(--accent-2)}
h3.qh{font-size:22px;margin:0 0 4px}
.qsub{color:var(--muted);font-size:14px;margin:0 0 24px}
.field{margin-bottom:24px}
.field>label.q{display:block;font-weight:600;font-size:15px;margin-bottom:4px}
.hint{color:var(--faint);font-size:12.5px;margin:2px 0 10px;font-weight:400}
.opts{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;align-items:stretch}
.opt{position:relative;cursor:pointer;display:flex}
.opt input{position:absolute;opacity:0;inset:0;cursor:pointer;margin:0}
.opt .box{border:1.5px solid var(--line);border-radius:12px;padding:13px 14px;background:var(--panel-2);transition:.15s;width:100%}
.opt .t{font-weight:600;font-size:14.5px;display:block}
.opt .d{font-size:12px;color:var(--muted);margin-top:3px;display:block}
.opt input:checked+.box{border-color:var(--accent);background:var(--tint);box-shadow:0 0 0 1px var(--accent)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.row{grid-template-columns:1fr}.opts{grid-template-columns:1fr 1fr}}
input[type=number],.field select{width:100%;background:var(--panel-2);border:1.5px solid var(--line);color:var(--ink);padding:12px 13px;border-radius:11px;font-size:15px;font-family:inherit}
input[type=number]:focus,select:focus{outline:none;border-color:var(--accent)}
.unit{display:flex;align-items:center;gap:8px}
.unit .u{color:var(--faint);font-size:13px}
.checkrow{display:flex;flex-wrap:wrap;gap:10px}
.chk{display:flex;align-items:center;gap:9px;background:var(--panel-2);border:1.5px solid var(--line);padding:11px 14px;border-radius:11px;cursor:pointer;font-size:14px}
.chk input{width:17px;height:17px;accent-color:var(--accent)}
.chk.on{border-color:var(--accent);background:var(--tint)}
.nav-btns{display:flex;justify-content:space-between;gap:12px;margin-top:30px}
.summary{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 22px}
.tag{background:var(--panel-2);border:1px solid var(--line);border-radius:30px;padding:6px 13px;font-size:12.5px;color:var(--muted)}
.tag b{color:var(--ink)}
.advice{background:var(--tint);border:1px solid var(--accent-2);border-radius:12px;padding:14px 16px;margin:2px 0 18px;font-size:13.5px;color:var(--tint-ink)}
.advice b{color:var(--ink)}
.catblock{margin-bottom:22px}
.catblock h4{font-size:18px;margin:0 0 2px;display:flex;align-items:center;gap:9px}
.catblock .cdesc{color:var(--muted);font-size:13px;margin:0 0 16px}
.cat-ico{width:30px;height:30px;border-radius:9px;background:var(--panel-2);display:grid;place-items:center;font-size:16px;border:1px solid var(--line)}
.recs{display:grid;gap:14px}
.rec{display:grid;grid-template-columns:64px 1fr auto;gap:16px;align-items:start;background:var(--panel-2);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.rec.top{border-color:var(--accent);box-shadow:0 0 0 1px rgba(22,199,154,.3)}
@media(max-width:640px){.rec{grid-template-columns:52px 1fr}.rec .price{grid-column:1/-1;text-align:left}}
.score{width:64px;text-align:center}
.ring{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:15px;background:conic-gradient(var(--accent) calc(var(--p)*1%),var(--line) 0)}
.ring span{width:42px;height:42px;border-radius:50%;background:var(--panel-2);display:grid;place-items:center}
.score .lbl{font-size:10px;color:var(--faint);text-transform:uppercase;letter-spacing:1px;margin-top:4px}
.rec .name{font-weight:700;font-size:16px;margin:0}
.rec .badge{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--accent-ink);background:var(--accent);border-radius:6px;padding:2px 7px;margin-left:8px;vertical-align:middle}
.rec .tier{font-size:12px;color:var(--faint);margin:2px 0 0}
.why{list-style:none;padding:0;margin:10px 0 0}
.why li{font-size:13px;color:var(--muted);padding-left:20px;position:relative;margin-bottom:4px}
.why li:before{content:'✓';position:absolute;left:0;color:var(--accent-text);font-weight:700}
.specrow{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px}
.spec{font-size:11.5px;color:var(--faint);background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:3px 8px}
.price{text-align:right;min-width:84px}
.price .amt{font-size:20px;font-weight:800}
.price .cur{font-size:13px;color:var(--muted)}
.price a{display:inline-block;margin-top:8px;font-size:12px;color:var(--muted);border:1px solid var(--line);padding:5px 10px;border-radius:8px}
.price a:hover{border-color:var(--accent);color:var(--ink);text-decoration:none}
.conf{font-size:10.5px;color:var(--faint);margin-top:6px}
.conf.high:before{content:'● ';color:var(--good)}
.conf.medium:before{content:'● ';color:var(--warn)}
.conf.low:before{content:'● ';color:var(--bad)}
details.how{margin-top:12px;border:1px solid var(--line);border-radius:12px;background:var(--panel-2)}
details.how summary{cursor:pointer;padding:12px 16px;font-size:13.5px;color:var(--muted);font-weight:600;list-style:none}
details.how summary::-webkit-details-marker{display:none}
details.how summary:before{content:'▸ ';color:var(--accent-text)}
details.how[open] summary:before{content:'▾ '}
details.how .body{padding:0 16px 14px;font-size:13px;color:var(--muted)}
details.how .rrow{padding:9px 0;border-top:1px solid var(--line)}
details.how .rrow b{color:var(--ink)}
.empty{color:var(--muted);font-size:14px;background:var(--panel-2);border:1px dashed var(--line);border-radius:12px;padding:16px}

/* modal */
.modal{position:fixed;inset:0;background:rgba(20,35,45,.45);display:none;place-items:center;padding:20px;z-index:60}
.modal.show{display:grid}
.modal .box{max-width:560px;width:100%;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow)}
.modal h3{margin:0 0 6px}
.modal p{color:var(--muted);font-size:13.5px;margin:0 0 16px}
.filein{border:1.5px dashed var(--line);border-radius:12px;padding:18px;text-align:center;margin:14px 0;font-size:13px;color:var(--muted)}
.msg{font-size:13px;margin-top:12px;padding:10px 12px;border-radius:9px;display:none}
.msg.ok{display:block;background:var(--tint);border:1px solid var(--accent-2);color:var(--tint-ink)}
.msg.err{display:block;background:#fdecec;border:1px solid var(--bad);color:#9a2a2a}
