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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Colors */
  --navy:#0b1120;
  --navy-mid:#111827;
  --navy-light:#1e293b;
  --blue:#2563eb;
  --blue-hover:#1d4ed8;
  --blue-light:#3b82f6;
  --blue-glow:rgba(37,99,235,.18);
  --cyan:#06b6d4;
  --orange:#f97316;
  --orange-light:#fb923c;
  --green:#10b981;
  --red:#ef4444;
  --bg:#f5f7fa;
  --surface:#ffffff;
  --surface2:#f0f4f9;
  --surface3:#e8eef6;
  --text:#0f172a;
  --text-light:#334155;
  --muted:#64748b;
  --muted-light:#94a3b8;
  --border:#e2e8f0;
  --border-dark:#cbd5e1;

  /* Spacing */
  --radius:14px;
  --radius-sm:8px;
  --radius-lg:20px;
  --radius-xl:28px;

  /* Shadows */
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow:0 4px 16px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.12),0 4px 12px rgba(0,0,0,.06);
  --shadow-blue:0 8px 30px rgba(37,99,235,.25);

  /* Typography */
  --font-head:'Outfit', sans-serif;
  --font:'Inter', sans-serif;
}

html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:none}
img{max-width:100%;display:block}
ul,ol{list-style:none}
.container{max-width:1260px;margin:0 auto;padding:0 28px}

/* ============================================
   HEADER
============================================ */
header{
  position:sticky;top:0;z-index:200;
  background:var(--navy);
  border-bottom:1px solid rgba(255,255,255,.06);
  backdrop-filter:blur(12px);
  transition:box-shadow .3s;
}
.header-inner{
  display:flex;align-items:center;
  height:72px;gap:32px;
}

/* Logo */
.logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-head);font-size:1.3rem;font-weight:800;
  color:#fff;letter-spacing:-.5px;flex-shrink:0;
  text-decoration:none;
}
.logo:hover{text-decoration:none;opacity:.9}
.logo-img{
  width:38px;height:38px;border-radius:10px;object-fit:cover;flex-shrink:0;
  box-shadow:0 0 14px rgba(37,99,235,.5);
}
.logo-name{color:#fff}
.logo-name span{color:var(--cyan)}

/* Nav */
nav{display:flex;align-items:center;gap:2px;flex:1}
nav a{
  color:rgba(255,255,255,.72);font-size:.9rem;font-weight:500;
  padding:7px 14px;border-radius:8px;transition:all .2s;white-space:nowrap;
}
nav a:hover{color:#fff;background:rgba(255,255,255,.08);text-decoration:none}
nav a.active{color:#fff;background:rgba(37,99,235,.25)}

/* Category dropdown in nav */
.nav-dropdown{position:relative}
.nav-dropdown-btn{
  display:flex;align-items:center;gap:5px;cursor:pointer;
  color:rgba(255,255,255,.72);font-size:.9rem;font-weight:500;
  padding:7px 14px;border-radius:8px;border:none;background:none;
  transition:all .2s;white-space:nowrap;font-family:var(--font);
}
.nav-dropdown-btn:hover,.nav-dropdown.open .nav-dropdown-btn{color:#fff;background:rgba(255,255,255,.08)}
.nav-dropdown-btn svg{width:13px;height:13px;transition:transform .2s;opacity:.7}
.nav-dropdown.open .nav-dropdown-btn svg{transform:rotate(180deg)}
.nav-dropdown-menu{
  position:absolute;top:calc(100% + 8px);left:0;
  background:#1e293b;border:1px solid rgba(255,255,255,.1);
  border-radius:12px;padding:8px;min-width:220px;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:all .2s;z-index:300;
}
.nav-dropdown.open .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-menu a{
  display:flex;align-items:center;gap:10px;padding:9px 12px;
  border-radius:8px;color:rgba(255,255,255,.8);font-size:.875rem;
  transition:all .18s;
}
.nav-dropdown-menu a:hover{background:rgba(37,99,235,.2);color:#fff}
.nav-dropdown-menu a .cat-icon{font-size:1rem;width:22px;text-align:center}

/* Nav right side */
.nav-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.nav-reviews-btn{
  background:var(--blue);color:#fff;font-size:.86rem;font-weight:600;
  padding:8px 18px;border-radius:8px;transition:all .2s;white-space:nowrap;
}
.nav-reviews-btn:hover{background:var(--blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-blue);text-decoration:none;color:#fff}

/* Hamburger */
.nav-toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  background:none;border:none;cursor:pointer;padding:8px;flex-shrink:0;
  border-radius:8px;transition:background .2s;
}
.nav-toggle:hover{background:rgba(255,255,255,.08)}
.nav-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
header.nav-open nav{
  display:flex!important;flex-direction:column;align-items:flex-start;
  position:absolute;top:72px;left:0;right:0;
  background:var(--navy-mid);padding:12px 16px 20px;
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 20px 40px rgba(0,0,0,.3);gap:2px;
}
header.nav-open .nav-dropdown-menu{position:static;box-shadow:none;border:none;background:transparent;opacity:1;visibility:visible;transform:none;padding:0}
header.nav-open .nav-right{display:none!important}

/* ============================================
   HERO SECTION
============================================ */
.hero{
  position:relative;overflow:hidden;
  padding:100px 0 90px;
  background:linear-gradient(135deg,var(--navy) 0%,#0d1b3e 50%,#0a2050 100%);
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.22;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(11,17,32,.88) 0%,rgba(11,17,32,.65) 50%,rgba(11,17,32,.80) 100%);
}
.hero-grid-pattern{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(37,99,235,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(37,99,235,.04) 1px,transparent 1px);
  background-size:50px 50px;
}
.hero-content{
  position:relative;z-index:2;
  max-width:740px;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(37,99,235,.18);border:1px solid rgba(37,99,235,.35);
  color:#93c5fd;font-size:.78rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  padding:6px 16px;border-radius:20px;margin-bottom:24px;
}
.hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{
  font-family:var(--font-head);
  font-size:clamp(2.1rem,5vw,3.6rem);
  font-weight:800;color:#fff;
  line-height:1.15;margin-bottom:20px;letter-spacing:-.02em;
}
.hero h1 .accent{
  background:linear-gradient(135deg,#60a5fa,var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero p{
  color:rgba(255,255,255,.72);font-size:1.1rem;
  max-width:520px;margin-bottom:36px;line-height:1.75;
}
.hero-cta{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:48px;
}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue);color:#fff;font-weight:700;font-size:.95rem;
  padding:13px 28px;border-radius:10px;
  transition:all .25s;border:none;cursor:pointer;font-family:var(--font);
}
.btn-primary:hover{background:var(--blue-hover);transform:translateY(-2px);box-shadow:var(--shadow-blue);color:#fff;text-decoration:none}
.btn-secondary{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.08);color:#fff;font-weight:600;font-size:.95rem;
  padding:13px 28px;border-radius:10px;border:1px solid rgba(255,255,255,.14);
  transition:all .25s;cursor:pointer;font-family:var(--font);
}
.btn-secondary:hover{background:rgba(255,255,255,.14);transform:translateY(-2px);text-decoration:none;color:#fff}

/* Hero logo decoration */
.hero-logo-deco{
  position:absolute;right:5%;top:50%;transform:translateY(-50%);
  z-index:2;
  display:flex;align-items:center;justify-content:center;
}
.hero-logo-deco-inner{
  position:relative;width:280px;height:280px;
}
.hero-logo-deco-img{
  width:180px;height:180px;border-radius:30px;
  object-fit:cover;
  box-shadow:0 0 60px rgba(37,99,235,.5),0 0 120px rgba(6,182,212,.2);
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  border:2px solid rgba(37,99,235,.3);
}
.hero-logo-deco-ring{
  position:absolute;inset:-20px;
  border:1px solid rgba(37,99,235,.2);border-radius:50%;
  animation:spin-ring 12s linear infinite;
}
.hero-logo-deco-ring::before{
  content:'';position:absolute;top:-4px;left:50%;transform:translateX(-50%);
  width:8px;height:8px;background:var(--cyan);border-radius:50%;
  box-shadow:0 0 12px var(--cyan);
}
.hero-logo-deco-ring2{
  position:absolute;inset:-50px;
  border:1px solid rgba(6,182,212,.12);border-radius:50%;
  animation:spin-ring 20s linear infinite reverse;
}
@keyframes spin-ring{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Hero stats */
.hero-stats{
  display:flex;gap:36px;flex-wrap:wrap;
}
.hero-stat{border-left:3px solid var(--blue);padding-left:16px}
.hero-stat-num{
  font-family:var(--font-head);font-size:1.8rem;font-weight:800;
  color:#fff;line-height:1;
}
.hero-stat-label{font-size:.78rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}

/* ============================================
   AFFILIATE BAR
============================================ */
.aff-bar{
  background:rgba(249,115,22,.07);
  border-bottom:1px solid rgba(249,115,22,.15);
  padding:9px 0;text-align:center;font-size:.82rem;
  color:var(--muted);
}
.aff-bar strong{color:var(--text)}

/* ============================================
   SECTION HELPERS
============================================ */
.section{padding:80px 0}
.section-sm{padding:52px 0}
.section-head{text-align:center;margin-bottom:52px}
.section-head h2{
  font-family:var(--font-head);font-size:clamp(1.75rem,3vw,2.4rem);
  font-weight:800;color:var(--text);margin-bottom:10px;letter-spacing:-.02em;
}
.section-head p{color:var(--muted);font-size:1.02rem;max-width:520px;margin:0 auto}
.section-head .divider{
  width:48px;height:4px;
  background:linear-gradient(90deg,var(--blue),var(--cyan));
  border-radius:2px;margin:16px auto 0;
}

/* ============================================
   EDITOR'S TOP PICKS (completely different design)
============================================ */
.top-picks-section{
  background:linear-gradient(180deg,var(--navy) 0%,#0d1b3e 100%);
  padding:80px 0;
}
.top-picks-section .section-head h2{color:#fff}
.top-picks-section .section-head p{color:rgba(255,255,255,.6)}
.top-picks-section .divider{background:linear-gradient(90deg,var(--orange),#fbbf24)}

.picks-layout{
  display:grid;
  grid-template-columns:1.5fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:20px;
  height:480px;
}
.pick-card{
  position:relative;overflow:hidden;border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;cursor:pointer;
  transition:transform .3s,box-shadow .3s;
  text-decoration:none!important;
}
.pick-card:hover{transform:scale(1.02);box-shadow:0 20px 60px rgba(0,0,0,.4);text-decoration:none}
.pick-card-1{grid-row:1 / 3}
.pick-card-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
.pick-card-grad{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 60%,transparent 100%);
}
.pick-card-badge{
  position:absolute;top:16px;left:16px;
  background:var(--orange);color:#fff;
  font-family:var(--font-head);font-size:.78rem;font-weight:700;
  padding:4px 12px;border-radius:6px;letter-spacing:.05em;
}
.pick-card-body{position:relative;z-index:2}
.pick-card-rank{
  font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-bottom:6px;
}
.pick-card-title{
  font-family:var(--font-head);font-size:1.1rem;font-weight:700;
  color:#fff;line-height:1.3;margin-bottom:8px;
}
.pick-card-1 .pick-card-title{font-size:1.45rem}
.pick-card-stars{color:#fbbf24;font-size:.9rem;letter-spacing:1px;margin-bottom:8px}
.pick-card-cta{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.12);color:#fff;
  font-size:.82rem;font-weight:600;padding:7px 14px;
  border-radius:7px;border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(8px);transition:all .2s;margin-top:4px;
}
.pick-card:hover .pick-card-cta{background:var(--blue);border-color:var(--blue)}

/* ============================================
   CATEGORY FILTER (nice styled)
============================================ */
.filter-section{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:0;position:sticky;top:72px;z-index:100;
}
.filter-inner{
  display:flex;align-items:center;gap:16px;
  padding:14px 0;flex-wrap:wrap;
}
.filter-label{
  font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--muted);flex-shrink:0;
}
.cat-chips{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1;
}
.cat-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:100px;
  background:var(--surface2);border:1.5px solid var(--border);
  font-size:.83rem;font-weight:600;color:var(--text-light);
  cursor:pointer;transition:all .2s;user-select:none;white-space:nowrap;
}
.cat-chip:hover{border-color:var(--blue);color:var(--blue);background:rgba(37,99,235,.05)}
.cat-chip.active{
  background:var(--blue);border-color:var(--blue);color:#fff;
  box-shadow:0 4px 12px rgba(37,99,235,.25);
}
.cat-chip .chip-icon{font-size:.95rem}
.filter-extras{
  display:flex;align-items:center;gap:10px;flex-shrink:0;
}
.filter-select{
  padding:7px 12px;border-radius:8px;
  border:1.5px solid var(--border);background:var(--surface2);
  font-size:.83rem;color:var(--text);font-family:var(--font);font-weight:500;
  cursor:pointer;transition:border .2s;
}
.filter-select:focus{outline:none;border-color:var(--blue)}
.filter-results{
  font-size:.82rem;color:var(--muted);font-weight:500;white-space:nowrap;
}
.filter-reset{
  padding:7px 12px;border-radius:8px;
  border:1.5px solid var(--border);background:var(--surface);
  font-size:.82rem;color:var(--muted);font-family:var(--font);font-weight:600;
  cursor:pointer;transition:all .2s;
}
.filter-reset:hover{border-color:var(--blue);color:var(--blue)}

/* Brand cloud (hidden by default now, shown in sidebar concept) */
.brand-cloud-section{background:var(--surface2);padding:20px 0;border-bottom:1px solid var(--border)}
.brand-cloud-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:12px}
.brand-cloud{display:flex;flex-wrap:wrap;gap:6px}
.brand-tag{
  padding:5px 12px;border-radius:6px;
  border:1px solid var(--border);background:var(--surface);
  font-size:.78rem;font-weight:500;color:var(--text-light);
  cursor:pointer;transition:all .15s;
}
.brand-tag:hover{border-color:var(--blue);color:var(--blue)}
.brand-tag.active{background:var(--blue);border-color:var(--blue);color:#fff}

/* ============================================
   PRODUCT GRID
============================================ */
.products-section{padding:60px 0}
.products-section .section-head{margin-bottom:36px}
.products-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
@media(max-width:1100px){.products-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:750px){.products-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media(max-width:480px){.products-grid{grid-template-columns:1fr}}

.product-card{
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  display:flex;flex-direction:column;
  color:inherit;text-decoration:none;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.product-card:hover{
  transform:translateY(-5px);box-shadow:var(--shadow-lg);
  border-color:rgba(37,99,235,.25);text-decoration:none;color:inherit;
}
.card-img-wrap{
  position:relative;height:200px;overflow:hidden;
  background:linear-gradient(135deg,#f0f4f9,#e8eef6);
}
.card-img-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s;
}
.product-card:hover .card-img-wrap img{transform:scale(1.06)}
.card-img-wrap.no-img{
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--navy-light));
}
.card-img-placeholder{font-size:3.5rem;opacity:.3}
.card-badge{
  position:absolute;top:10px;left:10px;
  background:var(--orange);color:#fff;
  font-size:.7rem;font-weight:700;padding:3px 9px;
  border-radius:5px;text-transform:uppercase;letter-spacing:.06em;
}
.card-cat-badge{
  position:absolute;top:10px;right:10px;
  background:rgba(11,17,32,.8);color:rgba(255,255,255,.9);
  font-size:.7rem;font-weight:600;padding:3px 9px;border-radius:5px;
  backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1);
}
.card-rating-badge{
  position:absolute;bottom:10px;right:10px;
  background:rgba(11,17,32,.85);color:#fff;
  font-size:.82rem;font-weight:700;padding:4px 9px;border-radius:6px;
  display:flex;align-items:center;gap:3px;backdrop-filter:blur(4px);
}
.card-rating-badge .si{color:#fbbf24;font-size:.85rem}
.card-body{padding:16px 18px;flex:1;display:flex;flex-direction:column}
.card-brand{
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--blue);margin-bottom:5px;
}
.card-title{
  font-family:var(--font-head);font-size:.97rem;font-weight:700;
  line-height:1.4;margin-bottom:8px;color:var(--text);
}
.card-snippet{
  font-size:.84rem;color:var(--muted);line-height:1.6;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.stars-row{display:flex;align-items:center;gap:7px;margin-bottom:8px}
.stars-char{color:#f59e0b;font-size:.9rem;letter-spacing:.5px}
.rating-num{font-weight:700;font-size:.88rem;color:var(--text)}
.rating-count{font-size:.78rem;color:var(--muted-light)}
.card-footer{
  padding:12px 18px;border-top:1px solid var(--border);
}
.btn-review{
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(135deg,var(--blue),#1d4ed8);
  color:#fff;padding:10px 15px;border-radius:8px;
  font-size:.84rem;font-weight:600;transition:all .2s;
}
.btn-review:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px);color:#fff;text-decoration:none}
.btn-review::after{content:'→';font-size:1rem}

/* ============================================
   TOP 10 PRODUCTS (awesome block)
============================================ */
.top10-section{
  background:var(--navy);
  padding:80px 0;
  position:relative;overflow:hidden;
}
.top10-section::before{
  content:'';position:absolute;
  top:-100px;right:-100px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(37,99,235,.12) 0%,transparent 70%);
  pointer-events:none;
}
.top10-section .section-head h2{color:#fff}
.top10-section .section-head p{color:rgba(255,255,255,.55)}
.top10-section .divider{background:linear-gradient(90deg,var(--cyan),var(--blue))}

.top10-list{display:flex;flex-direction:column;gap:12px}
.top10-item{
  display:grid;
  grid-template-columns:52px 80px 1fr auto;
  align-items:center;gap:20px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;
  padding:16px 20px;
  cursor:pointer;
  transition:all .2s;
  text-decoration:none;color:inherit;
}
.top10-item:hover{
  background:rgba(37,99,235,.12);
  border-color:rgba(37,99,235,.3);
  transform:translateX(6px);
  text-decoration:none;
}
.top10-rank{
  font-family:var(--font-head);font-size:2rem;font-weight:900;
  color:rgba(255,255,255,.12);text-align:center;line-height:1;
  transition:color .2s;
}
.top10-item:hover .top10-rank{color:rgba(37,99,235,.5)}
.top10-rank.top3{color:var(--orange);opacity:.8}
.top10-img{
  width:80px;height:64px;border-radius:10px;object-fit:cover;
  background:rgba(255,255,255,.05);flex-shrink:0;
  border:1px solid rgba(255,255,255,.08);
}
.top10-info{min-width:0}
.top10-brand{
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--cyan);margin-bottom:4px;
}
.top10-name{
  font-family:var(--font-head);font-size:1rem;font-weight:700;
  color:#fff;line-height:1.3;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.top10-cat{font-size:.78rem;color:rgba(255,255,255,.4);margin-top:3px}
.top10-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}
.top10-score{
  font-family:var(--font-head);font-size:1.5rem;font-weight:800;
  color:#fff;line-height:1;
}
.top10-score span{font-size:.8rem;color:rgba(255,255,255,.4);font-family:var(--font)}
.top10-stars{color:#fbbf24;font-size:.85rem;letter-spacing:.5px}
.top10-btn{
  font-size:.78rem;font-weight:600;color:rgba(255,255,255,.5);
  transition:color .2s;white-space:nowrap;
}
.top10-item:hover .top10-btn{color:var(--cyan)}

/* ============================================
   COMPARE TABLE (full row clickable)
============================================ */
.compare-section{padding:80px 0;background:var(--surface2)}
.compare-section .section-head h2{color:var(--text)}
.compare-table-wrap{
  overflow-x:auto;
  border-radius:16px;
  border:1.5px solid var(--border);
  box-shadow:var(--shadow);
}
.compare-table{
  width:100%;border-collapse:collapse;
  background:var(--surface);font-size:.88rem;
}
.compare-table thead{background:linear-gradient(135deg,var(--navy),var(--navy-mid))}
.compare-table th{
  padding:14px 18px;text-align:left;
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:rgba(255,255,255,.65);
  white-space:nowrap;
}
.compare-table th:first-child{border-radius:14px 0 0 0}
.compare-table th:last-child{border-radius:0 14px 0 0}
.compare-row{
  border-bottom:1px solid var(--border);
  cursor:pointer;transition:background .15s;
  text-decoration:none;color:inherit;display:table-row;
}
.compare-row:last-child{border-bottom:none}
.compare-row:hover{background:rgba(37,99,235,.04)}
.compare-row:hover td{color:inherit}
.compare-table td{padding:14px 18px;vertical-align:middle;color:var(--text)}
.compare-rank{
  font-family:var(--font-head);font-size:1.4rem;font-weight:800;
  color:var(--muted);text-align:center;
}
.compare-rank.gold{color:#f59e0b}
.compare-rank.silver{color:#94a3b8}
.compare-rank.bronze{color:#cd7f32}
.compare-img{width:56px;height:48px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}
.compare-name{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:3px}
.compare-brand-tag{
  display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--blue);background:rgba(37,99,235,.08);
  padding:2px 7px;border-radius:4px;
}
.compare-cat-tag{
  display:inline-block;font-size:.7rem;font-weight:500;
  color:var(--muted);background:var(--surface2);
  padding:2px 7px;border-radius:4px;margin-top:3px;
}
.compare-score{
  font-family:var(--font-head);font-size:1.3rem;font-weight:800;
  color:var(--text);
}
.compare-bar{
  height:4px;background:var(--surface3);border-radius:2px;margin-top:5px;width:100px;
}
.compare-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:2px}
.compare-link{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--blue);color:#fff;
  font-size:.8rem;font-weight:600;
  padding:7px 14px;border-radius:7px;
  transition:all .2s;white-space:nowrap;
}
.compare-row:hover .compare-link{background:var(--blue-hover)}

/* ============================================
   PAGINATION
============================================ */
.pagination{
  display:flex;justify-content:center;align-items:center;
  gap:6px;margin-top:48px;flex-wrap:wrap;
}
.page-btn{
  width:40px;height:40px;border:1.5px solid var(--border);
  background:var(--surface);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:.86rem;font-weight:600;cursor:pointer;
  transition:all .2s;color:var(--text);font-family:var(--font);
}
.page-btn:hover,.page-btn.active{
  background:var(--blue);color:#fff;border-color:var(--blue);
}
.page-btn.disabled{opacity:.35;pointer-events:none}
.page-nav{padding:0 16px;width:auto;font-size:.82rem}

/* ============================================
   COOKIE BANNER
============================================ */
#cookie-banner{
  position:fixed;bottom:24px;left:24px;right:24px;z-index:999;
  background:var(--navy-mid);border:1px solid rgba(255,255,255,.1);
  border-radius:16px;padding:20px 24px;
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  box-shadow:0 24px 80px rgba(0,0,0,.4);
  transform:translateY(120%);transition:transform .45s cubic-bezier(.22,.61,.36,1);
  max-width:780px;margin:0 auto;
}
#cookie-banner.visible{transform:translateY(0)}
.cookie-text{flex:1;font-size:.875rem;color:rgba(255,255,255,.8);line-height:1.6}
.cookie-text a{color:var(--cyan)}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
#cookie-accept{
  background:var(--blue);color:#fff;border:none;
  padding:9px 20px;border-radius:8px;font-size:.84rem;font-weight:600;
  cursor:pointer;font-family:var(--font);transition:background .2s;
}
#cookie-accept:hover{background:var(--blue-hover)}
#cookie-decline{
  background:rgba(255,255,255,.07);color:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.12);
  padding:9px 20px;border-radius:8px;font-size:.84rem;font-weight:600;
  cursor:pointer;font-family:var(--font);transition:background .2s;
}
#cookie-decline:hover{background:rgba(255,255,255,.12)}

/* ============================================
   PRODUCT PAGE
============================================ */
.page-hero{
  background:var(--navy);padding:20px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.breadcrumb{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:.84rem;color:rgba(255,255,255,.5);
}
.breadcrumb a{color:rgba(255,255,255,.6)}
.breadcrumb a:hover{color:#fff}
.breadcrumb sep{color:rgba(255,255,255,.25)}
.breadcrumb span{color:rgba(255,255,255,.85);font-weight:500}

.product-layout{
  display:grid;grid-template-columns:1fr 1.1fr;gap:48px;
  padding:48px 0;align-items:start;
}
.gallery{position:sticky;top:100px}
.gallery-main{
  border-radius:16px;overflow:hidden;
  border:1.5px solid var(--border);
  background:linear-gradient(135deg,#f0f4f9,#e8eef6);
  aspect-ratio:4/3;
}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.gallery-thumb{
  width:72px;height:60px;border-radius:10px;overflow:hidden;
  border:2px solid var(--border);cursor:pointer;transition:border-color .2s;
  flex-shrink:0;background:var(--surface2);
}
.gallery-thumb img{width:100%;height:100%;object-fit:cover}
.gallery-thumb.active{border-color:var(--blue)}
.gallery-thumb:hover{border-color:var(--blue-light)}

.product-info{}
.p-brand{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--blue);background:rgba(37,99,235,.08);
  padding:5px 12px;border-radius:6px;margin-bottom:14px;
}
.p-title{
  font-family:var(--font-head);font-size:clamp(1.4rem,3vw,1.9rem);
  font-weight:800;color:var(--text);line-height:1.25;
  margin-bottom:16px;letter-spacing:-.02em;
}
.p-rating{
  display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap;
}
.p-rating .stars-char{color:#f59e0b;font-size:1.1rem}
.p-rating .score{
  font-family:var(--font-head);font-size:1.5rem;font-weight:800;color:var(--text);
}
.p-rating .reviews-ct{font-size:.85rem;color:var(--muted)}

.score-bar-wrap{margin-bottom:24px}
.score-bar-label{display:flex;justify-content:space-between;font-size:.82rem;font-weight:600;color:var(--text-light);margin-bottom:6px}
.score-bar-track{height:8px;background:var(--surface3);border-radius:4px}
.score-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:4px;transition:width 1s ease}

.verdict-box{
  background:linear-gradient(135deg,rgba(37,99,235,.06),rgba(6,182,212,.04));
  border:1.5px solid rgba(37,99,235,.15);
  border-radius:14px;padding:20px 22px;margin-bottom:24px;
}
.verdict-label{
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--blue);margin-bottom:8px;
}
.verdict-text{font-size:.92rem;color:var(--text-light);line-height:1.7}

.cta-group{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.btn-read-reviews{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--blue);color:#fff;padding:11px 22px;
  border-radius:9px;font-size:.88rem;font-weight:600;transition:all .2s;
}
.btn-read-reviews:hover{background:var(--blue-hover);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-blue);text-decoration:none}

.features-section-label{
  font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--muted);margin-bottom:14px;margin-top:24px;
}
.features-list{display:flex;flex-direction:column;gap:8px}
.features-list li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:.9rem;color:var(--text-light);line-height:1.5;
}
.features-list li::before{
  content:'✓';color:var(--green);font-weight:700;
  font-size:.9rem;margin-top:1px;flex-shrink:0;
}

.pros-cons{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  margin:32px 0;
}
.pros-box,.cons-box{
  border-radius:14px;padding:20px;
}
.pros-box{
  background:linear-gradient(135deg,rgba(16,185,129,.06),rgba(16,185,129,.03));
  border:1.5px solid rgba(16,185,129,.2);
}
.cons-box{
  background:linear-gradient(135deg,rgba(239,68,68,.05),rgba(239,68,68,.02));
  border:1.5px solid rgba(239,68,68,.18);
}
.box-head{
  font-family:var(--font-head);font-size:1rem;font-weight:700;margin-bottom:14px;
}
.pros-box .box-head{color:var(--green)}
.cons-box .box-head{color:var(--red)}
.pros-box ul li,.cons-box ul li{
  font-size:.88rem;color:var(--text-light);padding:5px 0;
  display:flex;align-items:flex-start;gap:8px;line-height:1.5;
  border-bottom:1px solid rgba(0,0,0,.04);
}
.pros-box ul li:last-child,.cons-box ul li:last-child{border-bottom:none}
.pros-box ul li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0;margin-top:1px}
.cons-box ul li::before{content:'✗';color:var(--red);font-weight:700;flex-shrink:0;margin-top:1px}

.product-desc{
  padding:36px 0;border-top:1px solid var(--border);
}
.product-desc h2{
  font-family:var(--font-head);font-size:1.55rem;font-weight:800;
  color:var(--text);margin-bottom:20px;letter-spacing:-.02em;
}
.product-desc p{
  font-size:.97rem;color:var(--text-light);line-height:1.8;
  margin-bottom:16px;
}

/* Reviews */
.reviews-section{padding:36px 0 24px;border-top:1px solid var(--border)}
.reviews-section h2{
  font-family:var(--font-head);font-size:1.55rem;font-weight:800;
  color:var(--text);margin-bottom:28px;letter-spacing:-.02em;
}
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.review-card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:14px;padding:20px;transition:border-color .2s;
}
.review-card:hover{border-color:rgba(37,99,235,.2)}
.review-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.reviewer-name{font-weight:700;font-size:.9rem;color:var(--text)}
.review-date{font-size:.78rem;color:var(--muted)}
.review-stars{color:#f59e0b;font-size:.95rem;margin-bottom:6px}
.review-title{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--text);margin-bottom:8px}
.review-text{font-size:.875rem;color:var(--text-light);line-height:1.7}

/* Related */
.related-section{background:var(--surface2);padding:60px 0}
.related-section .section-head{margin-bottom:32px}
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.related-card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.related-card:hover{
  transform:translateY(-4px);box-shadow:var(--shadow);
  border-color:rgba(37,99,235,.2);text-decoration:none;
}
.related-img{height:130px;overflow:hidden;background:var(--surface2)}
.related-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.related-card:hover .related-img img{transform:scale(1.05)}
.related-body{padding:14px;flex:1;display:flex;flex-direction:column}
.related-brand{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-bottom:4px}
.related-title{font-family:var(--font-head);font-size:.9rem;font-weight:700;color:var(--text);line-height:1.35;flex:1;margin-bottom:8px}
.related-stars{font-size:.82rem;color:#f59e0b;margin-bottom:8px}
.related-link{
  display:inline-flex;align-items:center;gap:4px;
  font-size:.78rem;font-weight:600;color:var(--blue);
  transition:gap .2s;
}
.related-card:hover .related-link{gap:8px}

/* ============================================
   STATIC PAGES (about, terms, cookies)
============================================ */
.static-hero{
  background:linear-gradient(135deg,var(--navy) 0%,#0d1b3e 100%);
  padding:60px 0;border-bottom:1px solid rgba(255,255,255,.07);
}
.static-hero h1{
  font-family:var(--font-head);font-size:clamp(2rem,4vw,2.8rem);
  font-weight:800;color:#fff;margin-bottom:12px;letter-spacing:-.02em;
}
.static-hero p{color:rgba(255,255,255,.6);font-size:1.05rem}
.static-content{max-width:860px;margin:0 auto;padding:56px 28px}
.static-content h2{
  font-family:var(--font-head);font-size:1.45rem;font-weight:800;
  color:var(--text);margin:40px 0 14px;letter-spacing:-.02em;
}
.static-content h2:first-child{margin-top:0}
.static-content h3{
  font-family:var(--font-head);font-size:1.1rem;font-weight:700;
  color:var(--text-light);margin:24px 0 10px;
}
.static-content p{
  font-size:.97rem;color:var(--text-light);line-height:1.8;margin-bottom:14px;
}
.static-content ul{margin:14px 0 20px;display:flex;flex-direction:column;gap:8px}
.static-content ul li{
  font-size:.95rem;color:var(--text-light);
  display:flex;align-items:flex-start;gap:10px;line-height:1.65;
}
.static-content ul li::before{
  content:'•';color:var(--blue);font-size:1.2rem;flex-shrink:0;margin-top:-1px;
}
.static-content a{color:var(--blue);font-weight:500}
.static-content a:hover{text-decoration:underline}
.about-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin:32px 0 40px;
}
.about-card{
  background:linear-gradient(135deg,rgba(37,99,235,.05),rgba(6,182,212,.03));
  border:1.5px solid rgba(37,99,235,.12);
  border-radius:16px;padding:24px;text-align:center;
}
.about-icon{font-size:2rem;margin-bottom:12px}
.about-card h3{
  font-family:var(--font-head);font-size:1.05rem;font-weight:700;
  color:var(--text);margin-bottom:8px;
}
.about-card p{font-size:.88rem;color:var(--muted);line-height:1.65;margin:0}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:24px 0}
.team-card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:14px;padding:20px;display:flex;gap:16px;align-items:flex-start;
}
.team-avatar{
  width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--cyan));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:1.2rem;font-weight:800;color:#fff;flex-shrink:0;
}
.team-info{}
.team-name{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--text)}
.team-role{font-size:.8rem;color:var(--blue);font-weight:600;margin-bottom:6px}
.team-bio{font-size:.84rem;color:var(--muted);line-height:1.6}
.contact-box{
  background:linear-gradient(135deg,var(--blue),var(--navy-light));
  border-radius:16px;padding:36px;text-align:center;margin-top:40px;
  border:1px solid rgba(37,99,235,.3);
}
.contact-box h3{
  font-family:var(--font-head);font-size:1.4rem;font-weight:800;
  color:#fff;margin-bottom:10px;
}
.contact-box p{color:rgba(255,255,255,.75);margin-bottom:20px;margin-top:0}
.contact-box a{
  display:inline-block;background:#fff;color:var(--blue);
  padding:11px 24px;border-radius:9px;font-weight:700;font-size:.9rem;
  transition:transform .2s;
}
.contact-box a:hover{transform:scale(1.04);text-decoration:none}

/* Terms/Privacy legal boxes */
.legal-toc{
  background:var(--surface2);border:1.5px solid var(--border);
  border-radius:14px;padding:20px 24px;margin-bottom:36px;
}
.legal-toc h4{
  font-family:var(--font-head);font-weight:700;color:var(--text);margin-bottom:12px;font-size:.95rem;
}
.legal-toc ol{
  display:flex;flex-direction:column;gap:4px;
  padding-left:0;list-style:none;counter-reset:toc-counter;
}
.legal-toc ol li{
  counter-increment:toc-counter;font-size:.88rem;color:var(--text-light);
  display:flex;align-items:center;gap:8px;
}
.legal-toc ol li::before{
  content:counter(toc-counter)'.';color:var(--blue);font-weight:700;width:18px;flex-shrink:0;
}
.legal-toc ol li a{color:var(--blue);font-weight:500}

/* ============================================
   FOOTER
============================================ */
footer{
  background:var(--navy);color:rgba(255,255,255,.7);
  padding:64px 0 0;border-top:1px solid rgba(255,255,255,.06);
}
.footer-grid{
  display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;
  gap:48px;padding-bottom:52px;
}
.footer-brand{}
.footer-logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-head);font-size:1.3rem;font-weight:800;
  color:#fff;margin-bottom:16px;
}
.footer-logo-img{
  width:34px;height:34px;border-radius:8px;object-fit:cover;
  box-shadow:0 0 12px rgba(37,99,235,.4);
}
.footer-brand p{font-size:.875rem;color:rgba(255,255,255,.5);line-height:1.75;margin-bottom:10px}
.footer-disclaimer{
  font-size:.8rem;color:rgba(255,255,255,.35);line-height:1.65;
}
.footer-social{display:flex;gap:8px;margin-top:20px}
.social-btn{
  width:36px;height:36px;border-radius:8px;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;transition:all .2s;color:rgba(255,255,255,.6);
  text-decoration:none;
}
.social-btn:hover{background:var(--blue);border-color:var(--blue);color:#fff;transform:translateY(-2px)}
footer h4{
  font-family:var(--font-head);font-size:1rem;font-weight:700;
  color:#fff;margin-bottom:18px;letter-spacing:-.01em;
}
footer ul li{margin-bottom:9px}
footer ul li a{
  color:rgba(255,255,255,.5);font-size:.875rem;transition:color .2s;
  display:inline-flex;align-items:center;gap:5px;
}
footer ul li a:hover{color:#fff;text-decoration:none}
footer ul li a::before{content:'→';font-size:.75rem;opacity:0;transition:opacity .2s,transform .2s;transform:translateX(-4px)}
footer ul li a:hover::before{opacity:.5;transform:translateX(0)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.07);
  padding:20px 0;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;
}
.footer-copy{font-size:.8rem;color:rgba(255,255,255,.3)}
.footer-links{display:flex;gap:20px}
.footer-links a{font-size:.8rem;color:rgba(255,255,255,.35);transition:color .2s}
.footer-links a:hover{color:rgba(255,255,255,.7)}

/* Ad unit */
.ad-placement{padding:32px 0}
.ad-placement-inner{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.ad-unit{min-width:300px;min-height:250px;background:var(--surface2);border-radius:10px;border:1px solid var(--border)}

/* ============================================
   RESPONSIVE
============================================ */
@media(max-width:1024px){
  .hero-logo-deco{display:none}
  .picks-layout{grid-template-columns:1fr 1fr;grid-template-rows:auto auto;height:auto}
  .pick-card-1{grid-row:1;height:280px}
  .pick-card-2,.pick-card-3{height:220px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .product-layout{grid-template-columns:1fr}
  .gallery{position:static}
  .reviews-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .top10-item{grid-template-columns:40px 60px 1fr auto}
}
@media(max-width:768px){
  nav{display:none}
  .nav-toggle{display:flex}
  .header-inner{gap:16px}
  .hero{padding:70px 0 60px}
  .picks-layout{grid-template-columns:1fr;height:auto}
  .pick-card-1,.pick-card-2,.pick-card-3{height:220px}
  .about-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .pros-cons{grid-template-columns:1fr}
  .top10-item{grid-template-columns:36px 1fr auto;gap:12px}
  .top10-img{display:none}
  .filter-inner{gap:10px}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero-stats{gap:24px}
  .hero-cta{flex-direction:column;align-items:flex-start}
  .picks-layout{height:auto;gap:12px}
  .compare-table{font-size:.8rem}
}
