/* CamAdvisers — editorial review-site theme. System fonts only (no webfonts). */
:root{
  --ink:#0e1016; --ink-2:#161a24; --surface:#1b2030; --surface-2:#222840;
  --line:#2c3450; --text:#e7eaf2; --muted:#9aa3bd; --muted-2:#6b7490;
  --amber:#f6b73c; --amber-ink:#3a2a05;
  --coral:#ff4d6d; --coral-ink:#fff;
  --teal:#3ad0c0;
  --radius:14px; --radius-sm:9px; --maxw:1100px;
  --shadow:0 8px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--ink); color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"Apple Color Emoji",sans-serif;
  line-height:1.65; font-size:17px; -webkit-font-smoothing:antialiased;
}
a{color:var(--teal); text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%; height:auto; display:block}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 20px}
h1,h2,h3{line-height:1.2; letter-spacing:-.02em; font-weight:800}
h1{font-size:clamp(1.9rem,5vw,2.9rem); margin:.2em 0 .4em}
h2{font-size:clamp(1.35rem,3.4vw,1.9rem); margin:1.6em 0 .5em}
h3{font-size:1.2rem; margin:1.2em 0 .4em}
p{margin:0 0 1em}

/* Header */
.site-header{position:sticky; top:0; z-index:50; background:rgba(14,16,22,.92);
  backdrop-filter:saturate(140%) blur(8px); border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex; align-items:center; gap:18px; height:62px}
.brand{display:flex; align-items:center; gap:10px; font-weight:900; font-size:1.25rem;
  color:var(--text); letter-spacing:-.03em; flex-shrink:0}
.brand:hover{text-decoration:none}
.brand .logo{width:30px;height:30px;flex:0 0 30px}
.brand b{color:var(--amber)}
.nav{display:flex; gap:4px; margin-left:auto; flex-wrap:wrap}
.nav a{color:var(--muted); padding:8px 12px; border-radius:8px; font-size:.95rem; font-weight:600}
.nav a:hover{color:var(--text); background:var(--surface); text-decoration:none}
.menu-toggle{display:none}

/* Hero */
.hero{padding:54px 0 40px; background:
  radial-gradient(1200px 400px at 80% -10%, rgba(255,77,109,.18), transparent 60%),
  radial-gradient(900px 360px at 0% 0%, rgba(58,208,192,.12), transparent 55%)}
.kicker{display:inline-block; font-size:.82rem; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; color:var(--amber); background:var(--amber-ink);
  padding:5px 11px; border-radius:999px; margin-bottom:14px}
.hero p.sub{font-size:1.18rem; color:var(--muted); max-width:620px; margin:0 0 22px}

/* Buttons */
.btn{display:inline-flex; align-items:center; gap:8px; font-weight:800; cursor:pointer;
  padding:13px 22px; border-radius:999px; border:0; font-size:1rem; letter-spacing:-.01em}
.btn-primary{background:var(--coral); color:var(--coral-ink)}
.btn-primary:hover{background:#ff3358; text-decoration:none; color:#fff}
.btn-ghost{background:var(--surface-2); color:var(--text); border:1px solid var(--line)}
.btn-ghost:hover{background:var(--surface); text-decoration:none}
.btn-visit{background:var(--amber); color:var(--amber-ink)}
.btn-visit:hover{background:#ffc24d; text-decoration:none; color:var(--amber-ink)}

/* Breadcrumb */
.crumbs{font-size:.85rem; color:var(--muted-2); padding:18px 0 0}
.crumbs a{color:var(--muted)}

/* Rating badge */
.score{display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto;
  width:54px; height:54px; border-radius:12px; font-weight:900; font-size:1.25rem;
  background:linear-gradient(160deg,#2a3150,#1a1f33); border:1px solid var(--line); color:var(--amber)}
.stars{color:var(--amber); letter-spacing:2px; font-size:.95rem}
.stars .off{color:var(--muted-2)}

/* Platform card grid */
.grid{display:grid; gap:18px; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); margin:24px 0}
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:20px; display:flex; flex-direction:column; gap:10px; transition:border-color .15s,transform .15s}
.card:hover{border-color:var(--teal); transform:translateY(-2px)}
.card .top{display:flex; align-items:center; gap:13px}
.card .mono{width:46px;height:46px;border-radius:11px;flex:0 0 46px}
.card h3{margin:0; font-size:1.15rem}
.card .tagline{color:var(--muted); font-size:.95rem; margin:0; flex:1}
.card .meta{display:flex; flex-wrap:wrap; gap:6px; margin-top:2px}
.tag{font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  color:var(--muted); background:var(--ink-2); border:1px solid var(--line); padding:3px 8px; border-radius:6px}
.card .row{display:flex; align-items:center; justify-content:space-between; margin-top:auto; gap:10px}

/* Ranked list */
.rank{counter-reset:r}
.rank .card{position:relative}
.rank .rnum{position:absolute; top:-10px; left:-10px; width:30px;height:30px;border-radius:50%;
  background:var(--coral); color:#fff; font-weight:900; display:flex;align-items:center;justify-content:center;
  font-size:.95rem; box-shadow:var(--shadow)}

/* Review layout */
.review-head{display:flex; gap:18px; align-items:flex-start; flex-wrap:wrap; margin:8px 0 6px}
.review-head .mono{width:64px;height:64px;border-radius:14px;flex:0 0 64px}
.review-head .ttl{flex:1; min-width:200px}
.review-head h1{margin:0}
.verdict-box{background:var(--surface); border:1px solid var(--line); border-left:4px solid var(--amber);
  border-radius:var(--radius-sm); padding:16px 18px; margin:22px 0}
.verdict-box strong{color:var(--amber)}
.tldr{background:var(--surface); border:1px solid var(--line); border-left:4px solid var(--amber);
  border-radius:var(--radius-sm); padding:16px 18px; margin:18px 0; max-width:820px}
.tldr .lbl{display:block; text-transform:uppercase; letter-spacing:.06em; font-size:.72rem;
  font-weight:700; color:var(--amber); margin-bottom:6px}
.tldr p{margin:0; font-size:1.05rem; color:var(--text)}
.faq{margin:14px 0 4px}
.faq .qa{border-top:1px solid var(--line); padding:14px 0}
.faq .qa h3{margin:0 0 6px; font-size:1.05rem}
.faq .qa p{margin:0; color:var(--muted); max-width:820px}
.facts{width:100%; border-collapse:collapse; margin:18px 0; font-size:.96rem}
.facts th,.facts td{text-align:left; padding:10px 12px; border-bottom:1px solid var(--line); vertical-align:top}
.facts th{color:var(--muted); font-weight:600; width:38%; white-space:nowrap}
.pc{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:20px 0}
.pc .box{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); padding:16px 18px}
.pc h3{margin:0 0 8px; font-size:1.05rem}
.pc ul{margin:0; padding-left:20px}
.pc li{margin:6px 0}
.pc .pros h3{color:var(--teal)} .pc .cons h3{color:var(--coral)}
.cta-band{background:linear-gradient(135deg,var(--surface-2),var(--surface));
  border:1px solid var(--line); border-radius:var(--radius); padding:22px; margin:26px 0;
  display:flex; align-items:center; gap:18px; flex-wrap:wrap; justify-content:space-between}
.cta-band .t{font-weight:800; font-size:1.15rem}

/* Article prose */
.prose{max-width:760px}
.prose h2{border-top:1px solid var(--line); padding-top:.7em}
.prose ul{padding-left:22px}

/* Groups */
.groups{display:grid; gap:18px; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); margin:22px 0}
.groups .g{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:18px}
.groups .g h3{margin:0 0 10px}
.groups .g a{display:inline-block; margin:0 8px 8px 0; background:var(--ink-2); border:1px solid var(--line);
  padding:6px 11px; border-radius:8px; color:var(--text); font-size:.92rem; font-weight:600}
.groups .g a:hover{border-color:var(--teal); text-decoration:none}

/* Comparison table */
.table-scroll{overflow-x:auto; margin:18px 0}
.compare{width:100%; border-collapse:collapse; min-width:560px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden}
.compare th,.compare td{padding:12px 14px; border-bottom:1px solid var(--line); text-align:left; vertical-align:middle}
.compare thead th,.compare tr:first-child th{background:var(--surface-2)}
.compare tr:first-child th{text-align:center; font-size:1rem}
.compare tr:first-child th a{color:var(--text)}
.compare th:first-child,.compare td:first-child{color:var(--muted); font-weight:600; white-space:nowrap}
.compare td{color:var(--text); font-size:.95rem}
.mono-sm{width:34px;height:34px;border-radius:8px;display:inline-block;vertical-align:middle;margin-right:6px}

/* Footer */
.site-footer{border-top:1px solid var(--line); margin-top:50px; padding:30px 0; color:var(--muted-2); font-size:.9rem}
.site-footer .fnav{display:flex; flex-wrap:wrap; gap:16px; margin-bottom:12px}
.site-footer .fnav a{color:var(--muted)}
.disclaimer{font-size:.82rem; color:var(--muted-2); max-width:760px}
.age{display:inline-block; border:1px solid var(--coral); color:var(--coral); font-weight:800;
  border-radius:6px; padding:1px 7px; font-size:.8rem; margin-right:8px}

@media (max-width:640px){
  body{font-size:16px}
  .nav{position:fixed; inset:62px 0 auto 0; flex-direction:column; background:var(--ink-2);
    border-bottom:1px solid var(--line); padding:8px 16px 16px; gap:2px; display:none}
  .nav.open{display:flex}
  .nav a{padding:11px 8px}
  .menu-toggle{display:inline-flex; margin-left:auto; background:var(--surface); border:1px solid var(--line);
    color:var(--text); width:40px;height:40px;border-radius:9px; align-items:center;justify-content:center; cursor:pointer; font-size:1.2rem}
  .pc{grid-template-columns:1fr}
  .cta-band{flex-direction:column; align-items:stretch; text-align:center}
}
