/* ==========================================================================
   Fluent Spanish Guide — language-desk review system
   Cool paper · grape primary · amber streak · teal "verified" · grotesk + serif accents
   Deliberately distinct from sister sites (no medical-blue magazine, no warm field-manual).
   ========================================================================== */

:root{
  /* paper + ink */
  --bg:      #f5f6fb;
  --bg-2:    #ecedf7;
  --surface: #ffffff;
  --ink:     #16161f;
  --ink-2:   #545467;
  --ink-3:   #8c8ca3;
  --line:    #e7e8f2;
  --line-2:  #d8dae9;

  /* accents */
  --grape:      #5b45e0;
  --grape-2:    #4029bf;
  --grape-tint: #eceafb;
  --amber:      #f3a73a;
  --amber-2:    #d98a1c;
  --amber-tint: #fdf1dc;
  --teal:       #0fa98c;
  --teal-tint:  #def4ef;
  --rose:       #e2557a;

  /* grades */
  --g-a: #0fa98c;
  --g-b: #5b45e0;
  --g-c: #d98a1c;

  --sh-sm: 0 1px 2px rgba(22,22,40,.05), 0 2px 8px rgba(22,22,40,.05);
  --sh:    0 14px 38px -18px rgba(34,28,90,.34), 0 3px 10px -5px rgba(34,28,90,.14);
  --sh-lg: 0 38px 70px -32px rgba(34,28,90,.42);

  --rad:    18px;
  --rad-sm: 12px;
  --rad-xs: 9px;
  --maxw: 1140px;
  --reads: 720px;

  --display: "Bricolage Grotesque", "Segoe UI", system-ui, sans-serif;
  --sans:    "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --serif:   "Newsreader", Georgia, "Times New Roman", serif;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.66;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--grape-2); text-decoration:none; }
a:hover{ text-decoration:underline; }

h1,h2,h3,h4,h5{
  font-family:var(--display);
  font-weight:700;
  line-height:1.08;
  letter-spacing:-.018em;
  color:var(--ink);
  margin:0;
  font-optical-sizing:auto;
}

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 22px; }
.reads{ max-width:var(--reads); }

/* ---- announcement strip -------------------------------------------------- */
.ann{
  background:var(--ink);
  color:#dcdcec;
  font-size:12.5px;
  letter-spacing:.01em;
}
.ann .wrap{ display:flex; justify-content:space-between; align-items:center; gap:16px; height:34px; }
.ann a{ color:#fff; font-weight:600; }
.ann .a-r{ display:flex; gap:18px; }
@media (max-width:620px){ .ann .a-l{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; } }

/* ---- top bar ------------------------------------------------------------- */
.tb{
  position:sticky; top:0; z-index:40;
  background:rgba(245,246,251,.86);
  backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--line);
}
.tb .wrap{ display:flex; align-items:center; gap:22px; height:62px; }
.brand{ display:flex; align-items:center; gap:11px; color:var(--ink); flex:0 0 auto; }
.brand:hover{ text-decoration:none; }
.bmark{
  width:34px; height:34px; border-radius:10px; flex:0 0 auto;
  display:grid; place-items:center;
  background:linear-gradient(150deg, var(--grape), var(--grape-2));
  color:#fff; font-family:var(--display); font-weight:800; font-size:19px;
  box-shadow:var(--sh-sm);
}
.bname{ font-family:var(--display); font-weight:700; font-size:18px; letter-spacing:-.02em; }
.bname b{ color:var(--grape-2); font-weight:700; }
.tb-nav{ display:flex; gap:20px; margin-left:6px; }
.tb-nav a{ color:var(--ink-2); font-weight:500; font-size:14.5px; }
.tb-nav a:hover{ color:var(--grape-2); text-decoration:none; }
.tb-nav a.on{ color:var(--ink); font-weight:600; }
.tb-right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.langsw{ display:flex; border:1px solid var(--line-2); border-radius:999px; overflow:hidden; font-size:12.5px; font-weight:600; }
.langsw a{ padding:5px 11px; color:var(--ink-3); }
.langsw a:hover{ text-decoration:none; color:var(--ink); }
.langsw a.on{ background:var(--grape); color:#fff; }
.tb-cta{
  display:inline-flex; align-items:center; gap:7px;
  background:var(--ink); color:#fff; font-weight:600; font-size:13.5px;
  padding:9px 15px; border-radius:999px;
}
.tb-cta:hover{ text-decoration:none; background:#000; }
@media (max-width:860px){ .tb-nav{ display:none; } }

/* ---- buttons ------------------------------------------------------------- */
.btn{ display:inline-flex; align-items:center; gap:9px; font-weight:600; font-family:var(--sans);
  border-radius:999px; padding:12px 20px; font-size:15px; cursor:pointer; border:1px solid transparent; transition:transform .12s ease; }
.btn:hover{ text-decoration:none; transform:translateY(-1px); }
.btn .arr{ transition:transform .15s ease; }
.btn:hover .arr{ transform:translateX(3px); }
.btn-primary{ background:linear-gradient(150deg,var(--grape),var(--grape-2)); color:#fff; box-shadow:var(--sh); }
.btn-ink{ background:var(--ink); color:#fff; }
.btn-ghost{ background:var(--surface); color:var(--ink); border-color:var(--line-2); box-shadow:var(--sh-sm); }
.btn-sm{ padding:9px 15px; font-size:13.5px; }

/* ---- hero ---------------------------------------------------------------- */
.hero{ padding:54px 0 28px; }
.hero-grid{ display:grid; grid-template-columns:1.35fr .9fr; gap:42px; align-items:center; }
.hk{ font-family:var(--sans); font-weight:700; font-size:12.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--grape-2); margin:0 0 16px; display:flex; align-items:center; gap:9px; }
.hk::before{ content:""; width:22px; height:2px; background:var(--grape); border-radius:2px; }
.hero h1{ font-size:50px; line-height:1.02; letter-spacing:-.03em; }
.hero h1 .hl{ background:linear-gradient(transparent 62%, var(--amber-tint) 62%); padding:0 .04em; }
.hsub{ font-size:18.5px; color:var(--ink-2); margin:20px 0 26px; max-width:33em; }
.hcta{ display:flex; gap:13px; flex-wrap:wrap; align-items:center; }
.hchips{ display:flex; flex-wrap:wrap; gap:9px 16px; margin-top:26px; }
.hchips span{ font-size:13px; color:var(--ink-2); font-weight:500; display:inline-flex; align-items:center; gap:7px; }
.hchips span::before{ content:"✓"; color:var(--teal); font-weight:800; }

/* hero pick card (the editor's pick app) */
.pickcard{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--rad);
  box-shadow:var(--sh-lg); padding:22px; position:relative;
}
.pickcard .pc-tag{ position:absolute; top:-12px; left:22px; background:var(--amber); color:#3a2a06;
  font-size:11.5px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; padding:5px 11px; border-radius:999px; box-shadow:var(--sh-sm); }
.pc-top{ display:flex; align-items:center; gap:14px; margin-top:6px; }
.pc-top img{ width:60px; height:60px; border-radius:15px; box-shadow:var(--sh-sm); }
.pc-top h3{ font-size:19px; }
.pc-top .pc-cat{ font-size:13px; color:var(--ink-3); margin-top:3px; }
.pc-grade{ margin-left:auto; text-align:center; }
.pc-grade .gr{ font-family:var(--display); font-weight:800; font-size:26px; color:var(--teal); line-height:1; }
.pc-grade .gl{ font-size:10.5px; color:var(--ink-3); text-transform:uppercase; letter-spacing:.08em; }
.pc-body{ font-size:14.5px; color:var(--ink-2); margin:15px 0 17px; }
.pc-meta{ display:flex; gap:7px; flex-wrap:wrap; margin-bottom:17px; }
.pc-meta span{ font-size:11.5px; font-weight:600; color:var(--grape-2); background:var(--grape-tint); padding:4px 9px; border-radius:7px; }
.pickcard .btn{ width:100%; justify-content:center; }
@media (max-width:880px){
  .hero-grid{ grid-template-columns:1fr; gap:34px; }
  .hero h1{ font-size:38px; }
  .hero{ padding:36px 0 18px; }
}

/* ---- trust band ---------------------------------------------------------- */
.band{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-top:30px; background:var(--bg-2); }
.band .wrap{ display:flex; flex-wrap:wrap; gap:10px 30px; padding:15px 22px; justify-content:center; }
.band span{ font-size:13px; color:var(--ink-2); font-weight:500; }
.band b{ color:var(--ink); font-weight:700; }

/* ---- section heading ----------------------------------------------------- */
.sh{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin:46px 0 20px; }
.sh h2{ font-size:27px; letter-spacing:-.025em; }
.sh .more{ font-size:14px; font-weight:600; white-space:nowrap; }
.eyebrow{ font-family:var(--sans); font-weight:700; font-size:12px; letter-spacing:.15em; text-transform:uppercase; color:var(--grape-2); margin:0 0 12px; }

/* ---- shortlist (ranked preview) ------------------------------------------ */
.short{ background:var(--surface); border:1px solid var(--line); border-radius:var(--rad); box-shadow:var(--sh-sm); overflow:hidden; }
.srow{ display:flex; align-items:center; gap:15px; padding:14px 18px; border-top:1px solid var(--line); color:var(--ink); }
.srow:first-child{ border-top:0; }
.srow:hover{ background:var(--bg-2); text-decoration:none; }
.srow .rk{ font-family:var(--display); font-weight:800; font-size:17px; color:var(--ink-3); width:22px; text-align:center; flex:0 0 auto; }
.srow.lead .rk{ color:var(--grape-2); }
.srow img{ width:42px; height:42px; border-radius:11px; flex:0 0 auto; box-shadow:var(--sh-sm); }
.srow .nm{ flex:1; font-weight:600; font-size:15.5px; }
.srow .nm small{ display:block; font-weight:500; color:var(--ink-3); font-size:12.5px; margin-top:1px; }
.srow .gd{ font-family:var(--display); font-weight:800; font-size:16px; flex:0 0 auto; padding:3px 10px; border-radius:8px; background:var(--bg-2); }
.srow .gd.a{ color:var(--g-a); } .srow .gd.b{ color:var(--g-b); } .srow .gd.c{ color:var(--g-c); }
.srow.lead{ background:linear-gradient(90deg,var(--grape-tint),transparent 70%); }

/* ---- deck grid (guide cards) --------------------------------------------- */
.deck{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.dcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--rad); overflow:hidden;
  box-shadow:var(--sh-sm); display:flex; flex-direction:column; color:var(--ink); transition:transform .14s ease, box-shadow .14s ease; }
.dcard:hover{ text-decoration:none; transform:translateY(-3px); box-shadow:var(--sh); }
.dcard .ph{ aspect-ratio:16/10; object-fit:cover; width:100%; background:var(--bg-2); }
.dcard .db{ padding:16px 17px 18px; display:flex; flex-direction:column; gap:9px; flex:1; }
.cat{ align-self:flex-start; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--grape-2); background:var(--grape-tint); padding:3px 9px; border-radius:7px; }
.cat.travel{ color:var(--amber-2); background:var(--amber-tint); }
.cat.method{ color:var(--teal); background:var(--teal-tint); }
.dcard h3{ font-size:18.5px; line-height:1.15; }
.dcard p{ margin:0; font-size:14px; color:var(--ink-2); flex:1; }
.dcard .rd{ font-size:13px; color:var(--ink-3); font-weight:500; }
@media (max-width:900px){ .deck{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .deck{ grid-template-columns:1fr; } }

/* ---- front layout (grid + rail) ------------------------------------------ */
.front{ display:grid; grid-template-columns:1fr 320px; gap:40px; align-items:start; }
.rail{ position:sticky; top:84px; display:flex; flex-direction:column; gap:20px; }
.railcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--rad); box-shadow:var(--sh-sm); overflow:hidden; }
.railcard .rh{ padding:15px 18px 0; }
.railcard .rh .e{ font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--grape-2); }
.railcard .rh h4{ font-size:18px; margin-top:5px; }
.railcard .rf{ padding:13px 18px; border-top:1px solid var(--line); font-size:13.5px; font-weight:600; }
.railcard .pad{ padding:16px 18px; }
.railcard .pad p{ margin:0; font-size:14px; color:var(--ink-2); }
@media (max-width:900px){ .front{ grid-template-columns:1fr; } .rail{ position:static; } }

/* ---- phrasebook (language flavor) ---------------------------------------- */
.pbook{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.pcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--rad-sm); box-shadow:var(--sh-sm);
  padding:16px 16px 14px; position:relative; }
.pcard::before{ content:""; position:absolute; top:0; left:16px; right:16px; height:3px; border-radius:0 0 3px 3px; background:var(--grape); }
.pcard:nth-child(4n+2)::before{ background:var(--amber); }
.pcard:nth-child(4n+3)::before{ background:var(--teal); }
.pcard:nth-child(4n+4)::before{ background:var(--rose); }
.pcard .es{ font-family:var(--serif); font-style:italic; font-size:21px; font-weight:500; color:var(--ink); line-height:1.18; }
.pcard .en{ font-size:13.5px; color:var(--ink-3); margin-top:7px; }
.pcard .ipa{ font-family:var(--serif); font-size:13px; color:var(--grape-2); margin-top:3px; }
@media (max-width:820px){ .pbook{ grid-template-columns:repeat(2,1fr); } }

/* ---- article ------------------------------------------------------------- */
.art{ padding:30px 0 10px; }
.backlink{ font-size:13.5px; font-weight:600; color:var(--ink-3); }
.backlink:hover{ color:var(--grape-2); text-decoration:none; }
.meta{ display:flex; flex-wrap:wrap; gap:9px; align-items:center; font-size:13px; color:var(--ink-3); margin:16px 0 14px; }
.meta .c{ color:var(--grape-2); font-weight:700; text-transform:uppercase; letter-spacing:.05em; font-size:12px; }
.art h1{ font-size:40px; line-height:1.04; letter-spacing:-.03em; }
.lede{ font-size:20px; line-height:1.5; color:var(--ink-2); margin:18px 0 16px; font-family:var(--serif); }
.byrow{ display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--ink-3); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:12px 0; }
.byrow .tick{ width:18px; height:18px; border-radius:50%; background:var(--teal); color:#fff; display:grid; place-items:center; font-size:11px; font-weight:800; flex:0 0 auto; }
.hero-img{ margin:24px 0 8px; border-radius:var(--rad); overflow:hidden; box-shadow:var(--sh); border:1px solid var(--line); }
.hero-img img{ aspect-ratio:16/9; object-fit:cover; width:100%; }
.cap{ font-size:13px; color:var(--ink-3); text-align:center; margin:0 0 6px; font-style:italic; }

.prose{ font-size:17.5px; line-height:1.72; color:#24242f; }
.prose > p{ margin:18px 0; }
.prose h2{ font-size:26px; margin:38px 0 12px; letter-spacing:-.022em; }
.prose h3{ font-size:20px; margin:26px 0 9px; }
.prose ul,.prose ol{ margin:16px 0; padding-left:22px; }
.prose li{ margin:8px 0; }
.prose strong{ color:var(--ink); font-weight:700; }
.prose a{ color:var(--grape-2); font-weight:600; text-decoration:underline; text-decoration-color:var(--line-2); text-underline-offset:2px; }
/* buttons inside prose (e.g. the app-rec promo card) must keep button styling, not link styling */
.prose a.btn{ text-decoration:none; }
.prose a.btn-primary,.prose a.btn-ink{ color:#fff; }
.prose a.btn-ghost{ color:var(--ink); }
.prose blockquote{ margin:24px 0; padding:4px 0 4px 22px; border-left:3px solid var(--amber);
  font-family:var(--serif); font-size:21px; font-style:italic; color:var(--ink); line-height:1.45; }

/* key facts box */
.keyfacts{ background:var(--grape-tint); border:1px solid #ddd6f7; border-radius:var(--rad); padding:18px 20px; margin:26px 0; }
.keyfacts h4{ font-size:13px; text-transform:uppercase; letter-spacing:.1em; color:var(--grape-2); margin-bottom:10px; }
.keyfacts ul{ margin:0; padding-left:18px; }
.keyfacts li{ font-size:15px; margin:7px 0; color:#2c2a3a; }

/* tables */
.tw{ overflow-x:auto; margin:18px 0; border:1px solid var(--line); border-radius:var(--rad-sm); }
table{ border-collapse:collapse; width:100%; font-size:15px; }
th,td{ text-align:left; padding:11px 14px; border-bottom:1px solid var(--line); vertical-align:top; }
th{ background:var(--bg-2); font-weight:700; font-size:13px; }
tr:last-child td{ border-bottom:0; }
td strong{ color:var(--ink); }

/* phrase-table (ES/EN flavor) */
.ptab td:first-child{ font-family:var(--serif); font-style:italic; font-size:16.5px; color:var(--grape-2); white-space:nowrap; }

/* app recommendation card */
.apprec{ display:grid; grid-template-columns:auto 1fr auto; gap:16px; align-items:center; background:var(--ink); color:#eceaf6;
  border-radius:var(--rad); padding:20px 22px; margin:30px 0; }
.apprec img{ width:60px; height:60px; border-radius:15px; box-shadow:var(--sh-sm); }
.apprec .t{ font-size:11.5px; text-transform:uppercase; letter-spacing:.08em; color:var(--amber); font-weight:700; }
.apprec h4{ color:#fff; font-size:19px; margin:3px 0 6px; }
.apprec p{ margin:0; font-size:14px; color:#bdbcd2; }
.apprec p a{ color:#fff; }
.apprec .btn-primary{ box-shadow:none; }
@media (max-width:640px){ .apprec{ grid-template-columns:auto 1fr; } .apprec .btn{ grid-column:1/-1; justify-content:center; } }

/* faq */
.faq{ margin:14px 0; }
.faq details{ border:1px solid var(--line); border-radius:var(--rad-sm); background:var(--surface); margin:10px 0; box-shadow:var(--sh-sm); }
.faq summary{ list-style:none; cursor:pointer; padding:15px 18px; font-weight:600; font-size:16px; color:var(--ink);
  display:flex; justify-content:space-between; align-items:center; gap:12px; font-family:var(--display); }
.faq summary::-webkit-details-marker{ display:none; }
.faq .ic{ color:var(--grape); font-size:20px; font-weight:700; transition:transform .15s ease; }
.faq details[open] .ic{ transform:rotate(45deg); }
.faq p{ margin:0; padding:0 18px 16px; font-size:15px; color:var(--ink-2); }
.faq a{ color:var(--grape-2); font-weight:600; }

/* read next */
.readnext{ margin:34px 0 8px; padding:22px; background:var(--bg-2); border-radius:var(--rad); }
.readnext ul{ list-style:none; margin:8px 0 0; padding:0; }
.readnext li{ border-top:1px solid var(--line); }
.readnext li:first-child{ border-top:0; }
.readnext li a{ display:block; padding:11px 0; font-weight:600; font-size:15.5px; color:var(--ink); }
.readnext li a:hover{ color:var(--grape-2); text-decoration:none; }
.readnext li.all a{ color:var(--grape-2); }

.disclosure{ margin:26px 0 8px; padding:15px 17px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--rad-sm); font-size:13px; color:var(--ink-3); line-height:1.6; }
.disclosure b{ color:var(--ink-2); }

/* ---- ranking report cards ------------------------------------------------ */
.post{ padding:30px 0 10px; }
.standfirst{ font-size:20px; line-height:1.5; color:var(--ink-2); margin:18px 0 16px; font-family:var(--serif); }
.reviewed{ display:flex; align-items:center; gap:10px; font-size:13.5px; color:var(--ink-2); background:var(--teal-tint);
  border:1px solid #c7ece3; border-radius:var(--rad-sm); padding:11px 15px; margin:6px 0 4px; }
.reviewed .tick{ width:20px; height:20px; border-radius:50%; background:var(--teal); color:#fff; display:grid; place-items:center; font-size:12px; font-weight:800; flex:0 0 auto; }

/* winners at a glance */
.verdicts{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin:26px 0; }
.vcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--rad-sm); box-shadow:var(--sh-sm); padding:15px 16px; }
.vcard .vt{ font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-3); }
.vcard .vn{ font-family:var(--display); font-weight:700; font-size:18px; margin:5px 0 7px; }
.vcard a{ font-size:13px; font-weight:600; }
@media (max-width:760px){ .verdicts{ grid-template-columns:repeat(2,1fr); } }

/* report card */
.rep{ background:var(--surface); border:1px solid var(--line); border-radius:var(--rad); box-shadow:var(--sh-sm); padding:24px; margin:20px 0; scroll-margin-top:80px; }
.rep.win{ border:1.5px solid var(--grape); box-shadow:var(--sh); position:relative; }
.rep.win::before{ content:"Editor’s Choice"; position:absolute; top:-11px; left:24px; background:var(--grape); color:#fff;
  font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; padding:4px 11px; border-radius:999px; }
.rep-head{ display:flex; align-items:center; gap:15px; }
.rep-head .rank{ font-family:var(--display); font-weight:800; font-size:30px; color:var(--ink-3); width:34px; flex:0 0 auto; text-align:center; }
.rep.win .rank{ color:var(--grape); }
.rep-head img.ic{ width:56px; height:56px; border-radius:14px; flex:0 0 auto; box-shadow:var(--sh-sm); }
.rep-head .nm{ flex:1; }
.rep-head .nm h3{ font-size:21px; }
.rep-head .nm .tag{ font-size:13px; color:var(--ink-3); margin-top:2px; }
.grade{ flex:0 0 auto; text-align:center; }
.grade .lt{ font-family:var(--display); font-weight:800; font-size:30px; line-height:1; }
.grade.a .lt{ color:var(--g-a); } .grade.b .lt{ color:var(--g-b); } .grade.c .lt{ color:var(--g-c); }
.grade .sc{ font-size:11.5px; color:var(--ink-3); margin-top:3px; }
.rep .desc{ font-size:15.5px; color:var(--ink-2); margin:15px 0; line-height:1.6; }
.spec{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--rad-xs); overflow:hidden; margin:15px 0; }
.spec .s{ background:var(--surface); padding:10px 13px; }
.spec .k{ font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-3); font-weight:600; }
.spec .v{ font-size:14px; font-weight:600; color:var(--ink); margin-top:2px; }
.pc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:15px 0 4px; }
.pc-grid .h{ font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; margin-bottom:7px; }
.pros .h{ color:var(--teal); } .cons .h{ color:var(--amber-2); }
.pc-grid ul{ margin:0; padding-left:17px; }
.pc-grid li{ font-size:14px; margin:5px 0; color:var(--ink-2); }
.verdict{ display:flex; gap:13px; flex-wrap:wrap; align-items:center; margin-top:16px; padding-top:16px; border-top:1px solid var(--line); }
.verdict .vtxt{ font-size:14px; color:var(--ink-2); flex:1; min-width:240px; }
.verdict .vtxt b{ color:var(--ink); }
@media (max-width:640px){ .spec{ grid-template-columns:repeat(2,1fr); } .pc-grid{ grid-template-columns:1fr; } }

/* how we test */
.testbox{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--rad); padding:22px 24px; margin:30px 0; }
.testbox h2{ font-size:22px; margin-bottom:10px; }
.testbox ol{ margin:0; padding-left:20px; }
.testbox li{ margin:9px 0; font-size:15px; color:var(--ink-2); }

/* ---- guides index hero --------------------------------------------------- */
.pagehero{ padding:42px 0 8px; }
.pagehero h1{ font-size:42px; letter-spacing:-.03em; }
.pagehero .dek{ font-size:19px; color:var(--ink-2); margin-top:14px; max-width:40em; font-family:var(--serif); }

/* ---- error --------------------------------------------------------------- */
.err{ text-align:center; padding:70px 0; }
.err .big{ font-family:var(--display); font-weight:800; font-size:80px; color:var(--grape); letter-spacing:-.04em; }
.err h1{ font-size:30px; margin:6px 0 12px; }
.err p{ color:var(--ink-2); max-width:34em; margin:0 auto 22px; }
.err .row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ---- footer -------------------------------------------------------------- */
.ft{ margin-top:64px; background:var(--ink); color:#c7c6da; }
.ft .wrap{ padding:46px 22px 30px; }
.ft .top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:30px; }
.ft .brand .bname{ color:#fff; }
.ft .blurb{ font-size:14px; color:#9897b3; margin:14px 0 0; max-width:30em; }
.ft h5{ color:#fff; font-size:13px; text-transform:uppercase; letter-spacing:.08em; margin:0 0 12px; font-family:var(--sans); font-weight:700; }
.ft ul{ list-style:none; margin:0; padding:0; }
.ft li{ margin:8px 0; }
.ft a{ color:#bdbcd2; font-size:14px; }
.ft a:hover{ color:#fff; }
.ft .legal{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; margin-top:34px; padding-top:20px; border-top:1px solid #2c2c3e; font-size:12.5px; color:#7a7995; }
@media (max-width:760px){ .ft .top{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .ft .top{ grid-template-columns:1fr; } }
