/* ===========================================================
   Pickarank — shared stylesheet (pop / primary-colours theme)
   One file powers the whole site. Tweak colours in :root.
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap');

:root{
  --brand:#1f6fff;        /* primary blue */
  --brand-dark:#0b50d0;
  --brand-soft:#e4eeff;
  --accent:#ff3b30;       /* primary red */
  --accent-dark:#d62a20;
  --sun:#ffcf24;          /* primary yellow */
  --mint:#1faa59;         /* primary green */
  --ink:#15192b;          /* near-black ink */
  --muted:#5c6275;
  --line:#e6e8f1;
  --bg:#f6f8fe;           /* bright off-white */
  --card:#ffffff;
  --good:#1faa59;
  --ok:#ffb800;
  --bad:#ff3b30;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 8px 22px rgba(20,30,80,.10);
  --shadow-hover:0 16px 40px rgba(20,30,80,.20);
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Nunito',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5{font-family:'Nunito',sans-serif;font-weight:900;line-height:1.18;letter-spacing:-.3px}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
/* offset in-page anchors so the sticky header doesn't hide the heading */
#how,#categories,#compare-tool{scroll-margin-top:100px}

/* ---------- Header / nav ---------- */
header.site{
  background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(10px);
  border-bottom:3px solid var(--brand);position:sticky;top:0;z-index:50;
}
.nav{display:flex;align-items:center;gap:20px;height:70px}
.logo{font-weight:900;font-size:1.6rem;letter-spacing:-.5px;color:var(--ink)}
.logo span{color:var(--brand)}
.logo .lg-pick{color:var(--ink)}
.logo .lg-a{color:var(--brand)}
.logo .lg-rank{color:var(--ink)}
/* footer logo sits on dark: PICK/RANK white (inherit h4), A stays blue */
footer.site .lg-a{color:var(--brand)}
.nav nav{display:flex;align-items:center;gap:10px;margin-left:auto;flex-wrap:wrap}
.nav nav > a{color:var(--muted);font-weight:800;font-size:.94rem;padding:8px 13px;border-radius:999px;transition:.15s}
.nav nav > a:hover{color:#fff;background:var(--brand);text-decoration:none}

/* All-products dropdown */
.navdrop{position:relative;display:inline-block;outline:none}
.navdrop-btn{display:inline-block;cursor:pointer;color:#fff;background:var(--brand);font-weight:800;font-size:.94rem;padding:9px 16px;border-radius:999px;transition:.15s;user-select:none}
.navdrop:hover .navdrop-btn,.navdrop:focus-within .navdrop-btn{background:var(--brand-dark)}
.navdrop-menu{position:absolute;top:100%;right:0;margin-top:0;min-width:240px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-hover);padding:8px;display:none;z-index:60}
/* small invisible overlap so there is never a hover gap between button and menu */
.navdrop-menu::before{content:"";position:absolute;left:0;right:0;top:-8px;height:8px}
.navdrop:hover .navdrop-menu,.navdrop:focus-within .navdrop-menu,.navdrop.open .navdrop-menu{display:block}
.navdrop.open .navdrop-btn{background:var(--brand-dark)}
.navdrop-menu a{display:block;padding:10px 12px;border-radius:10px;color:var(--ink);font-weight:700;font-size:.92rem}
.navdrop-menu a:hover{background:var(--brand-soft);color:var(--brand-dark);text-decoration:none}
.navdrop-menu .navdrop-all{color:var(--brand);border-bottom:1px solid var(--line);margin-bottom:4px;border-radius:10px 10px 0 0;font-weight:900}

/* tidied grouped mega-menu */
.navdrop-mega{width:min(640px,92vw);max-height:min(72vh,560px);overflow-y:auto}
.navdrop-groups{column-count:3;column-gap:12px;margin-top:4px}
.navdrop-group{break-inside:avoid;-webkit-column-break-inside:avoid;page-break-inside:avoid;margin-bottom:8px}
.navdrop-group-title{margin:6px 10px 2px;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:900}
.navdrop-mega a{font-size:.9rem;padding:8px 10px}
@media (max-width:720px){ .navdrop-groups{column-count:2} }
@media (max-width:480px){ .navdrop-groups{column-count:1} .navdrop-mega{width:92vw} }

/* ---------- Ad zones ---------- */
.ad{
  background:repeating-linear-gradient(135deg,#eef2ff,#eef2ff 12px,#fff5d6 12px,#fff5d6 24px);
  border:2px dashed #c3cdf0;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  color:#8a93b5;font-size:.78rem;font-weight:900;letter-spacing:.08em;
  text-transform:uppercase;text-align:center;overflow:hidden;
}
.ad-leaderboard{width:100%;height:90px;margin:18px 0}
.ad-billboard{width:100%;height:250px;margin:18px 0}
.ad-rectangle{width:100%;height:250px;margin:22px auto}
.ad-skyscraper{width:100%;height:600px;margin-bottom:20px}
.ad-square{width:100%;height:250px;margin-bottom:20px}
.ad-inline{width:100%;height:110px;margin:20px 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;background:var(--accent);color:#fff;font-weight:900;
  padding:12px 20px;border-radius:999px;text-align:center;border:none;cursor:pointer;
  transition:transform .08s ease,box-shadow .15s ease;box-shadow:0 6px 0 var(--accent-dark);
}
.btn:hover{text-decoration:none;color:#fff;transform:translateY(-2px);box-shadow:0 8px 0 var(--accent-dark)}
.btn:active{transform:translateY(2px);box-shadow:0 2px 0 var(--accent-dark)}
.btn-amazon{background:var(--sun);color:#15192b;box-shadow:0 6px 0 #d9a800}
.btn-amazon:hover{color:#15192b;box-shadow:0 8px 0 #d9a800}
.btn-amazon:active{box-shadow:0 2px 0 #d9a800}
.btn-ghost{background:#fff;color:var(--brand-dark);border:none;box-shadow:0 6px 0 rgba(0,0,0,.18)}
.btn-ghost:hover{color:var(--brand-dark)}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  background:linear-gradient(135deg,#2f7bff 0%,#1f6fff 55%,#0b50d0 100%);
  color:#fff;padding:74px 0 88px;text-align:center;overflow:hidden;
  border-radius:0 0 30px 30px;
}
.hero::before{content:"";position:absolute;top:-60px;right:-40px;width:260px;height:260px;border-radius:50%;background:var(--sun);opacity:.85}
.hero::after{content:"";position:absolute;bottom:-80px;left:-50px;width:300px;height:300px;border-radius:50%;background:var(--accent);opacity:.8}
.hero .wrap{position:relative;z-index:1}
.hero h1{font-size:3.1rem;margin:0 0 14px;letter-spacing:-1.5px;color:#fff}
.hero p{font-size:1.2rem;max-width:660px;margin:0 auto 28px;opacity:.98}
.hero-emojis{font-size:2.4rem;margin-bottom:14px;letter-spacing:6px}
.trust-row{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin-top:26px;font-weight:800;font-size:.92rem;opacity:.98}
.trust-row span{display:inline-flex;align-items:center;gap:7px}

/* ---------- Section titles ---------- */
.section-title{font-size:2.1rem;margin:46px 0 6px;letter-spacing:-.6px}
.section-sub{color:var(--muted);margin:0 0 24px;font-size:1.05rem}

/* ---------- Grids & cards ---------- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-2{grid-template-columns:2fr 1fr}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;
}
.card .pad{padding:22px}
.card.pad{padding:22px}
.cat-card{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;position:relative;padding:32px 26px;min-height:240px;transition:transform .15s ease,box-shadow .15s ease;border-top:6px solid var(--brand)}
.cat-card:nth-child(4n+1){border-top-color:var(--brand)}
.cat-card:nth-child(4n+2){border-top-color:var(--accent)}
.cat-card:nth-child(4n+3){border-top-color:var(--sun)}
.cat-card:nth-child(4n){border-top-color:var(--mint)}
.cat-card:hover{transform:translateY(-6px) rotate(-.4deg);box-shadow:var(--shadow-hover);text-decoration:none}
.cat-card .emoji{font-size:3.1rem;line-height:1;margin:0 auto 8px}
.cat-card h3{margin:6px 0 8px;color:var(--ink);font-size:1.35rem;line-height:1.2}
.cat-card p{color:var(--muted);margin:0 auto;font-size:1rem;line-height:1.45}
.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:14px;justify-content:center}
.pill{background:var(--brand-soft);color:var(--brand-dark);font-size:.78rem;font-weight:900;padding:5px 12px;border-radius:999px}
.pill-ready{background:#dcf6e7;color:#137a40}

/* ---------- Layout with sidebar ---------- */
.layout{display:grid;grid-template-columns:1fr 320px;gap:36px;margin:30px 0}
.sidebar{position:sticky;top:90px;align-self:start}
.side-box{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;margin-bottom:20px;box-shadow:var(--shadow);border-top:5px solid var(--sun);
}
.side-box h4{margin:0 0 12px;font-size:1.1rem}
.side-box ol{margin:0;padding-left:20px}
.side-box li{margin-bottom:9px;font-size:.94rem}

/* ---------- Breadcrumb / page head ---------- */
.crumb{color:var(--muted);font-size:.88rem;margin:22px 0 4px}
.crumb a{color:var(--muted)}
.page-head{margin-bottom:8px}
.page-head h1{font-size:2.5rem;margin:8px 0 10px;letter-spacing:-.8px}
.page-head .meta{color:var(--muted);font-size:.9rem;margin-bottom:8px;font-weight:700}
.lede{font-size:1.12rem;color:#3a4055;max-width:790px}

/* ---------- Methodology box ---------- */
.method{
  background:var(--brand-soft);
  border:2px solid #c8dbff;border-radius:var(--radius);
  padding:22px 24px;margin:24px 0;
}
.method h3{margin:0 0 8px;font-size:1.2rem}
.method p,.method ul{max-width:760px}
.method ul{margin:6px 0 0;padding-left:20px;color:#3a4055}
.method li{margin-bottom:5px}

/* ---------- Comparison table ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}
table.compare{border-collapse:collapse;width:100%;background:var(--card);min-width:760px}
table.compare th,table.compare td{padding:14px 15px;text-align:left;border-bottom:1px solid var(--line);font-size:.93rem;vertical-align:middle}
table.compare thead th{background:var(--brand);color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
table.compare tbody tr:nth-child(even){background:#f3f7ff}
table.compare tbody tr:hover{background:var(--brand-soft)}
table.compare .rank-cell{font-weight:900;color:var(--accent);font-size:1.15rem;text-align:center}
table.compare .name-cell{font-weight:800}

/* ---------- Score badge ---------- */
.score{
  display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:14px;color:#fff;font-weight:900;font-size:1.05rem;
}
.score.s-good{background:var(--good)}
.score.s-ok{background:var(--ok);color:#15192b}
.score.s-bad{background:var(--bad)}
.score-lg{width:68px;height:68px;font-size:1.65rem;border-radius:18px}

/* ---------- Ranked entries ---------- */
.entry{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:24px;margin:22px 0;display:grid;
  grid-template-columns:64px 1fr;gap:20px;transition:box-shadow .15s ease;border-left:6px solid var(--brand);
}
.entry:hover{box-shadow:var(--shadow-hover)}
.entry .rankno{
  font-size:2.6rem;font-weight:900;line-height:1;text-align:center;color:var(--brand);
}
.entry .badge-best{display:inline-block;background:var(--accent);color:#fff;font-size:.72rem;font-weight:900;padding:4px 11px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.entry h3{margin:2px 0 6px;font-size:1.4rem}
.entry .price{font-weight:900;color:var(--ink)}
.entry .scorebar{display:flex;align-items:center;gap:14px;margin:12px 0}
.entry .scorebar .label{font-size:.9rem;color:var(--muted)}
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}
.proscons ul{margin:6px 0 0;padding-left:20px}
.proscons .pros li{color:#137a40}
.proscons .cons li{color:#cc2b22}
.proscons h5{margin:0;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink)}
.spec-row{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.spec{background:var(--brand-soft);border-radius:999px;padding:6px 13px;font-size:.82rem;color:var(--brand-dark)}
.spec b{color:var(--ink)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:8px}

/* ---------- FAQ ---------- */
.faq details{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:12px;box-shadow:var(--shadow)}
.faq summary{font-weight:900;cursor:pointer}
.faq p{margin:10px 0 0;color:#3a4055}

/* ---------- Disclosure ---------- */
.disclosure{background:#fff6d6;border:2px solid var(--sun);border-radius:var(--radius-sm);padding:14px 18px;font-size:.88rem;color:#7a5d00;margin:18px 0;max-width:900px}

/* ---------- Top picks summary box ---------- */
.top-picks{background:var(--brand-soft);border:1px solid #cfe0ff;border-radius:var(--radius);padding:22px 22px 18px;margin:22px 0 8px}
.top-picks .tp-title{font-size:1.5rem;margin:0 0 16px;letter-spacing:-.4px}
.pick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pick-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:18px 16px;display:flex;flex-direction:column;align-items:flex-start}
.pick-tag{display:inline-block;background:var(--brand);color:#fff;font-weight:800;font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;padding:4px 10px;border-radius:999px}
.pick-name{font-size:1.12rem;margin:10px 0 8px;line-height:1.25}
.pick-meta{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.pick-meta .pick-reason{font-size:.86rem;color:var(--muted);font-weight:700}
.pick-card .btn{margin-top:auto;width:100%;text-align:center}
.pick-price{font-weight:900;color:var(--ink);margin-top:8px;font-size:.92rem}
.tp-note{font-size:.8rem;color:var(--muted);margin:14px 0 0}

/* ---------- Bottom-line CTA ---------- */
.bottomline{background:#fff6d6;border:2px solid var(--sun);border-radius:var(--radius);padding:22px 24px;margin:34px 0 8px;text-align:center}
.bottomline h3{font-size:1.4rem;margin:0 0 8px}
.bottomline p{max-width:720px;margin:0 auto 16px;color:#3a4055}
.bottomline .price{display:inline-block;margin-left:12px;font-weight:900;color:var(--ink)}
.btn-lg{font-size:1.05rem;padding:14px 26px}

@media(max-width:760px){
  .pick-grid{grid-template-columns:1fr}
  .top-picks{padding:18px 16px 14px}
  .bottomline .price{display:block;margin:10px 0 0}
}

/* ---------- Footer ---------- */
footer.site{background:#15192b;color:#c6cbe0;margin-top:56px;padding:46px 0 30px;border-radius:30px 30px 0 0}
footer.site .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px}
footer.site .foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:48px;flex-wrap:wrap}
footer.site .foot-brand{flex:0 1 340px}
footer.site .foot-nav{flex:0 1 560px;display:grid;grid-template-columns:1.6fr 1fr;gap:28px}
footer.site .foot-cat-list{column-count:2;column-gap:22px}
footer.site .foot-cat-list a{break-inside:avoid;-webkit-column-break-inside:avoid}
footer.site .foot-col h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:#fff;opacity:.85;margin-bottom:10px}
footer.site h4{color:#fff;margin:0 0 12px;font-size:1.05rem}
footer.site a{color:#a7adca;display:block;margin-bottom:8px;font-size:.9rem}
footer.site a:hover{color:var(--sun)}
footer.site .fine{border-top:1px solid #2c3250;margin-top:28px;padding-top:18px;font-size:.8rem;color:#8990b3;max-width:900px;line-height:1.6}

/* ---------- All-products sitemap page ---------- */
.sitemap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:26px;margin:26px 0}
.sitemap-cat{border-top:6px solid var(--brand);padding:28px 26px}
.sitemap-cat:nth-child(4n+2){border-top-color:var(--accent)}
.sitemap-cat:nth-child(4n+3){border-top-color:var(--sun)}
.sitemap-cat:nth-child(4n){border-top-color:var(--mint)}
.sitemap-cat h3{margin:0 0 12px;font-size:1.25rem}
.sitemap-cat h3 a{color:var(--ink)}
.sitemap-cat h3 a:hover{color:var(--brand)}
.sitemap-list{list-style:none;margin:0;padding:0}
.sitemap-list li{margin:0 0 8px}
.sitemap-list a{font-weight:700;color:var(--brand-dark)}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:static}
  .grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  footer.site .cols{grid-template-columns:1fr 1fr}
  footer.site .foot-nav{flex-basis:100%;text-align:left;grid-template-columns:2fr 1fr}
  .ad-skyscraper{height:250px}
  .hero h1{font-size:2.4rem}
}
@media(max-width:600px){
  .hero h1{font-size:2.1rem}
  .grid-3,.grid-4{grid-template-columns:1fr}
  .proscons{grid-template-columns:1fr}
  .entry{grid-template-columns:1fr}
  .entry .rankno{text-align:left}
  .wrap{padding:0 16px}
  footer.site .cols{grid-template-columns:1fr}
  footer.site .foot-nav{grid-template-columns:1fr;gap:18px}
  footer.site .foot-cat-list{column-count:2}
  .nav{height:auto;flex-wrap:wrap;padding:10px 0}
}
