/* Figro design system — shared across landing + category pages.
   Tokens from the Figro Landing handoff (cobalt accent, warm off-white, Schibsted Grotesk + Geist). */
:root{
  --bg:#FAFAF7; --surface:#FFFFFF; --ink:#15161A;
  --muted:#5B5C64; --muted2:#55565E; --faint:#7C7D84; --faint2:#8A8B91; --faint3:#9A9BA1;
  --border:#EAE9E3; --border2:#ECEBE5; --border3:#E7E6E0; --border4:#E4E3DD; --border-hover:#DCDBD3;
  --tile:#F4F3EE; --tile2:#F2F1EC; --tile3:#F1F0EB;
  --accent:#2B53F0; --accent-hover:#1E3FCC; --accent-glow:rgba(43,83,240,.12);
  --dark:#141519; --dark-card:#191A1F; --dark-border:#262830; --dark-accent:#8B98F7; --dark-accent2:#7E8DF5; --dark-muted:#9A9CA6;
  --sel:#D7DEFD;
  --r-card:16px; --r-card-lg:18px; --r-btn:10px; --r-tile:12px; --r-pill:999px;
  --maxw:1200px; --pad:28px;
  --shadow-card-hover:0 14px 30px -16px rgba(20,22,30,.22);
  --shadow-search:0 12px 34px -14px rgba(20,22,30,.18),0 2px 6px rgba(20,22,30,.04);
  --shadow-drop:0 24px 60px -20px rgba(20,22,30,.28);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:'Geist',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:var(--sel)}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.disp{font-family:'Schibsted Grotesk','Geist',sans-serif}

/* ---------- NAV ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,250,247,.78);
  -webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border2)}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:20px;
  max-width:var(--maxw);margin:0 auto;padding:14px var(--pad)}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:30px;height:30px;border-radius:9px;background:var(--ink);color:#fff;
  font-family:'Schibsted Grotesk',sans-serif;font-weight:800;font-size:17px;
  display:flex;align-items:center;justify-content:center}
.brand-name{font-family:'Schibsted Grotesk',sans-serif;font-weight:700;font-size:21px;letter-spacing:-.02em}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:15px;font-weight:500;color:var(--muted2);transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:12px}
.icon-btn{width:38px;height:38px;border:1px solid var(--border4);background:var(--surface);border-radius:var(--r-btn);
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--faint3);transition:border-color .15s,color .15s}
.icon-btn:hover{border-color:var(--accent);color:var(--accent)}
.btn-primary{background:var(--accent);color:#fff;font-size:14px;font-weight:600;
  padding:10px 18px;border-radius:var(--r-btn);border:none;cursor:pointer;transition:background .15s;white-space:nowrap}
.btn-primary:hover{background:var(--accent-hover)}
@media(max-width:720px){.nav-links{display:none}}

/* ---------- HERO ---------- */
.hero{position:relative;text-align:center;padding:84px var(--pad) 64px;overflow:hidden}
.hero-glow{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:680px;height:420px;
  background:radial-gradient(closest-side,var(--accent-glow),transparent);z-index:0;pointer-events:none}
.hero-in{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto}
.eyebrow-pill{display:inline-flex;align-items:center;gap:8px;background:var(--surface);
  border:1px solid var(--border3);border-radius:var(--r-pill);padding:7px 14px;
  font-size:13.5px;font-weight:500;color:var(--muted2)}
.eyebrow-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
h1.hero-title{font-family:'Schibsted Grotesk',sans-serif;font-weight:800;font-size:64px;line-height:1.02;
  letter-spacing:-.035em;max-width:760px;margin:22px auto 0}
.hero-sub{font-size:19px;line-height:1.55;color:var(--muted);max-width:560px;margin:18px auto 0}

/* ---------- SEARCH ---------- */
.search-wrap{position:relative;max-width:660px;margin:30px auto 0}
.search-bar{display:flex;align-items:center;gap:12px;background:var(--surface);
  border:1px solid var(--border4);border-radius:var(--r-card-lg);height:68px;padding:0 16px;
  box-shadow:var(--shadow-search);transition:border-color .15s}
.search-bar:focus-within{border-color:var(--accent)}
.search-bar svg{flex:0 0 auto}
.search-input{flex:1;border:none;outline:none;background:transparent;font-family:inherit;
  font-size:18px;color:var(--ink)}
.search-input::placeholder{color:var(--faint3)}
.search-clear{width:30px;height:30px;border:none;background:var(--tile3);border-radius:8px;cursor:pointer;
  color:var(--faint);font-size:16px;display:flex;align-items:center;justify-content:center}
.kbd{background:var(--tile);border:1px solid var(--border3);border-radius:7px;padding:4px 8px;
  font-size:12px;font-weight:600;color:var(--faint2);font-family:'Geist',sans-serif}
@media(max-width:540px){.kbd{display:none}}
.results{position:absolute;top:80px;left:0;right:0;background:var(--surface);border:1px solid var(--border4);
  border-radius:var(--r-card-lg);box-shadow:var(--shadow-drop);overflow:hidden;z-index:20;
  animation:figFade .16s ease}
@keyframes figFade{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.results-head{padding:12px 18px;font-size:12.5px;font-weight:600;color:var(--faint2);
  border-bottom:1px solid var(--border2);text-transform:uppercase;letter-spacing:.04em}
.result-row{display:flex;align-items:center;gap:13px;padding:13px 18px;transition:background .12s}
.result-row:hover{background:var(--tile2)}
.result-tile{width:38px;height:38px;flex:0 0 38px;background:var(--tile);border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:18px}
.result-main{flex:1;min-width:0}
.result-name{font-size:15px;font-weight:600;color:var(--ink)}
.result-desc{font-size:13px;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.result-cat{font-size:11.5px;font-weight:600;color:var(--faint2);background:var(--tile);
  border-radius:var(--r-pill);padding:4px 10px;white-space:nowrap}
.results-empty{padding:22px 18px;text-align:center;color:var(--faint);font-size:14.5px}

/* ---------- POPULAR CHIPS ---------- */
.chips{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:9px;margin-top:22px}
.chips-label{font-size:13.5px;color:var(--faint2);font-weight:500}
.chip{background:var(--surface);border:1px solid var(--border3);border-radius:var(--r-pill);
  padding:7px 14px;font-size:13.5px;font-weight:500;color:var(--muted2);cursor:pointer;
  font-family:inherit;transition:border-color .15s,color .15s}
.chip:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- STATS ---------- */
.stats{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;margin-top:46px;padding-top:34px;
  border-top:1px solid var(--border2)}
.stat-n{font-family:'Schibsted Grotesk',sans-serif;font-weight:800;font-size:34px;line-height:1;letter-spacing:-.02em}
.stat-l{font-size:13.5px;color:var(--faint2);margin-top:6px}

/* ---------- SECTION ---------- */
.section{padding:56px var(--pad)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px}
.eyebrow{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent)}
h2.section-title{font-family:'Schibsted Grotesk',sans-serif;font-weight:800;font-size:38px;
  letter-spacing:-.03em;margin-top:8px}
.section-meta{font-size:14.5px;color:var(--faint2)}
.section-meta a{color:var(--accent);font-weight:500}

/* ---------- CATEGORY GRID ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.cat-card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);
  padding:20px;transition:transform .15s,box-shadow .15s,border-color .15s}
.cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover);border-color:var(--border-hover)}
.cat-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cat-tile{width:46px;height:46px;background:var(--tile);border-radius:var(--r-tile);
  display:flex;align-items:center;justify-content:center;font-size:23px}
.cat-count{font-size:12.5px;font-weight:600;color:var(--faint2);background:var(--tile);
  border-radius:var(--r-pill);padding:5px 11px}
.cat-name{font-size:17px;font-weight:600;letter-spacing:-.01em}
.cat-eg{font-size:13.5px;color:var(--faint2);margin-top:4px}

/* ---------- TOOL GRID ---------- */
.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px}
.tool-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-card);padding:22px;min-height:158px;transition:transform .15s,box-shadow .15s,border-color .15s}
.tool-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover);border-color:var(--border-hover)}
.tool-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.tool-tile{width:42px;height:42px;background:var(--tile);border-radius:11px;
  display:flex;align-items:center;justify-content:center;font-size:21px}
.tool-cat{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--faint3)}
.tool-name{font-size:17.5px;font-weight:600;letter-spacing:-.01em}
.tool-desc{font-size:14px;line-height:1.5;color:var(--faint);margin-top:7px}

/* ---------- DARK BAND ---------- */
.dark-band{background:var(--dark);padding:72px var(--pad)}
.dark-band .wrap{max-width:var(--maxw)}
.dark-band .eyebrow{color:var(--dark-accent2)}
.dark-title{font-family:'Schibsted Grotesk',sans-serif;font-weight:800;font-size:40px;color:#fff;
  letter-spacing:-.03em;max-width:620px;margin:8px 0 30px}
.prop-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.prop-card{background:var(--dark-card);border:1px solid var(--dark-border);border-radius:var(--r-card);padding:24px}
.prop-n{font-family:'Schibsted Grotesk',sans-serif;font-weight:800;font-size:30px;color:var(--dark-accent)}
.prop-t{font-size:16.5px;font-weight:600;color:#fff;margin-top:10px}
.prop-d{font-size:14px;line-height:1.55;color:var(--dark-muted);margin-top:7px}

/* ---------- FOOTER ---------- */
.footer{padding:56px var(--pad) 40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;
  padding-bottom:32px;border-bottom:1px solid var(--border2)}
.footer-tag{font-size:14px;line-height:1.6;color:var(--faint);margin-top:14px;max-width:280px}
.footer-col h4{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--faint2);margin-bottom:14px}
.footer-col a{display:block;font-size:14px;color:var(--faint);padding:5px 0;transition:color .15s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{font-size:13px;color:var(--faint3);padding-top:24px}
@media(max-width:780px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* ---------- responsive type ---------- */
@media(max-width:760px){
  h1.hero-title{font-size:42px}
  h2.section-title,.dark-title{font-size:30px}
  .hero{padding:60px var(--pad) 48px}
  .section{padding:44px var(--pad)}
}

/* ---------- AFFILIATE (recommended partners) ---------- */
.aff{margin:40px 0 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);padding:24px}
.aff h3{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:2px}
.aff .aff-sub{font-size:12.5px;color:var(--faint2);margin-bottom:16px}
.aff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.aff-card{display:block;background:var(--bg);border:1px solid var(--border3);border-radius:12px;
  padding:14px 16px;transition:border-color .15s,transform .15s}
.aff-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.aff-name{font-size:14.5px;font-weight:600;color:var(--ink)}
.aff-name::after{content:" ↗";font-size:11px;color:var(--faint3);font-weight:500}
.aff-desc{font-size:12.5px;line-height:1.5;color:var(--faint);margin-top:4px}
.aff-disc{font-size:11.5px;color:var(--faint3);margin-top:14px;line-height:1.55}
