/* =====================================================================
   VoltGear · Reviews Lab — design system
   Modern, professional, magazine-grade aesthetic
   ===================================================================== */

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

:root{
  /* Brand palette */
  --c-ink:        #0B0F1F;
  --c-ink-2:      #1A2138;
  --c-paper:      #FFFFFF;
  --c-cream:      #F8FAFC;
  --c-mist:       #EEF2F7;
  --c-fog:        #DCE3EE;
  --c-mute:       #5A6A85;
  --c-mute-2:     #7B8AA3;

  --c-accent:     #3D2BFF;
  --c-accent-2:   #00D9FF;
  --c-accent-3:   #FFB347;
  --c-success:    #16A34A;
  --c-danger:     #DC2626;
  --c-warning:    #F59E0B;

  --grad-brand:   linear-gradient(135deg, #3D2BFF 0%, #00D9FF 100%);
  --grad-brand-2: linear-gradient(135deg, #1e1b4b 0%, #3D2BFF 60%, #00D9FF 100%);
  --grad-amber:   linear-gradient(135deg, #FFB347 0%, #FF7A45 100%);
  --grad-dark:    linear-gradient(180deg, #0B0F1F 0%, #1A2138 100%);

  --f-sans:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, system-ui, sans-serif;
  --f-display:'Space Grotesk', 'Inter', sans-serif;
  --f-mono:   'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --container:  1240px;
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;

  --sh-sm:  0 1px 2px rgba(11,15,31,.06), 0 1px 1px rgba(11,15,31,.04);
  --sh-md:  0 4px 18px -2px rgba(11,15,31,.10), 0 2px 6px rgba(11,15,31,.06);
  --sh-lg:  0 22px 60px -20px rgba(11,15,31,.25), 0 10px 22px -12px rgba(11,15,31,.12);
  --sh-glow:0 0 0 1px rgba(61,43,255,.18), 0 18px 50px -12px rgba(61,43,255,.35);

  --muted: var(--c-mute);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family: var(--f-sans);
  background: var(--c-cream);
  color: var(--c-ink);
  font-size: 16px;
  line-height: 1.6;
  font-feature-settings: 'cv11','ss01';
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img{ max-width:100%; display:block; }
a{ color: var(--c-accent); text-decoration:none; transition: color .2s ease; }
a:hover{ color: #2516cc; }
button{ font-family: inherit; cursor:pointer; }

h1,h2,h3,h4,h5{
  font-family: var(--f-display);
  color: var(--c-ink);
  letter-spacing:-0.015em;
  margin:0 0 .5em;
  line-height:1.15;
  font-weight:700;
}
h1{ font-size: clamp(2.4rem, 5.5vw, 4.2rem); letter-spacing:-0.03em; }
h2{ font-size: clamp(1.8rem, 3.6vw, 2.6rem); letter-spacing:-0.025em; }
h3{ font-size: 1.25rem; }
h4{ font-size: 1.05rem; }
p{ margin:0 0 1em; }

.container{ width:100%; max-width: var(--container); margin: 0 auto; padding: 0 24px; }

/* ---------- Header / Navigation ---------- */
header.site-header{
  position: sticky; top:0; z-index:100;
  background: rgba(255,255,255,.85);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid rgba(11,15,31,.06);
  transition: box-shadow .25s ease, background .25s ease;
}
header.site-header.scrolled{
  box-shadow: 0 6px 28px -12px rgba(11,15,31,.18);
  background: rgba(255,255,255,.95);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height: 76px; gap: 24px;
}
.brand{
  display:inline-flex; align-items:center; gap:12px;
  text-decoration:none; color: var(--c-ink);
  font-family: var(--f-display);
}
.brand-mark{
  width:42px; height:42px; flex:none;
  display:grid; place-items:center;
  border-radius: 12px;
  background: var(--grad-brand-2);
  box-shadow: 0 8px 22px -10px rgba(61,43,255,.55), inset 0 0 0 1px rgba(255,255,255,.18);
  position:relative; overflow:hidden;
}
.brand-mark img{ width:100%; height:100%; object-fit:cover; }
.brand-mark::after{
  content:''; position:absolute; inset:0;
  background: radial-gradient(120% 120% at 0 0, rgba(255,255,255,.22), transparent 55%);
  pointer-events:none;
}
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{
  font-size: 1.35rem; font-weight: 700; letter-spacing:-0.02em;
  background: linear-gradient(135deg, #0B0F1F 0%, #3D2BFF 130%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.brand-tag-line{
  font-size: .68rem; letter-spacing:.28em; font-weight:600;
  color: var(--c-mute); text-transform:uppercase;
  margin-top:5px;
}

.primary-nav{
  display:flex; align-items:center; gap:6px;
  font-family: var(--f-sans);
}
.primary-nav a{
  position:relative;
  display:inline-flex; align-items:center; gap:6px;
  padding: 9px 14px;
  font-size:.95rem; font-weight:600;
  color: var(--c-ink-2);
  border-radius: 10px;
  transition: color .2s, background .2s;
}
.primary-nav a:hover{ color: var(--c-accent); background: rgba(61,43,255,.06); }
.primary-nav a.active{ color: var(--c-accent); background: rgba(61,43,255,.08); }
.nav-cta{
  margin-left: 8px;
  background: var(--c-ink) !important;
  color: #fff !important;
  padding: 11px 18px !important;
  border-radius: 10px !important;
  box-shadow: 0 8px 20px -10px rgba(11,15,31,.55);
}
.nav-cta:hover{
  background: var(--c-accent) !important;
  color:#fff !important;
}
.nav-cta .arr{ transition: transform .2s; }
.nav-cta:hover .arr{ transform: translateX(3px); }

.nav-toggle{
  display:none; width:42px; height:42px;
  background:transparent; border:1px solid var(--c-fog);
  border-radius:10px; padding:0;
  flex-direction:column; align-items:center; justify-content:center; gap:4px;
}
.nav-toggle span{ display:block; width:18px; height:2px; background: var(--c-ink); border-radius:2px; transition: transform .25s, opacity .25s; }
.nav-toggle.active span:nth-child(1){ transform: translateY(6px) rotate(45deg); }
.nav-toggle.active span:nth-child(2){ opacity:0; }
.nav-toggle.active span:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 900px){
  .nav-toggle{ display:flex; }
  .primary-nav{
    position:absolute; top:76px; left:0; right:0;
    flex-direction:column; align-items:stretch;
    gap:0; padding:14px;
    background:#fff; border-top:1px solid var(--c-mist);
    box-shadow: var(--sh-md);
    transform: translateY(-12px); opacity:0; pointer-events:none;
    transition: transform .25s, opacity .25s;
  }
  .primary-nav a{ width:100%; padding:14px 16px; border-radius:10px; }
  .nav-cta{ margin: 6px 0 0 !important; text-align:center; justify-content:center; }
  header.site-header.nav-open .primary-nav{ transform:none; opacity:1; pointer-events:auto; }
}

/* ---------- Hero ---------- */
.hero{
  position:relative; overflow:hidden;
  isolation:isolate;
  padding: 80px 0 100px;
  color:#fff;
  background: var(--grad-dark);
}
.hero::before{
  content:''; position:absolute; inset:0; z-index:-2;
  background-image: url('images/hero-bg.webp');
  background-size: cover; background-position: center;
  opacity:.55;
  filter: saturate(115%);
}
.hero::after{
  content:''; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(60% 60% at 18% 30%, rgba(61,43,255,.45), transparent 60%),
    radial-gradient(70% 70% at 90% 80%, rgba(0,217,255,.30), transparent 60%),
    linear-gradient(180deg, rgba(11,15,31,.65) 0%, rgba(11,15,31,.85) 100%);
}
.hero-grid{
  display:grid; grid-template-columns: 1.15fr .85fr; gap: 60px;
  align-items:center;
}
.hero-pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  font-size:.78rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:#fff;
  backdrop-filter: blur(12px);
}
.hero-pill .dot{ width:8px; height:8px; border-radius:50%; background: var(--c-accent-2); box-shadow: 0 0 0 4px rgba(0,217,255,.18); }
.hero h1{ color:#fff; margin:22px 0 18px; max-width: 16ch; }
.hero h1 em{
  font-style:normal;
  background: linear-gradient(120deg, #00D9FF 0%, #FFB347 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-lede{
  font-size: 1.15rem; line-height:1.55;
  color: rgba(255,255,255,.78);
  max-width: 52ch; margin-bottom: 32px;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; }
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 14px 22px; border-radius:12px;
  font-weight:600; font-size:.95rem;
  text-decoration:none; transition: transform .2s, box-shadow .2s, background .2s, color .2s;
  border:1px solid transparent;
  cursor:pointer;
}
.btn-primary{
  background: var(--grad-brand);
  color:#fff;
  box-shadow: 0 14px 32px -12px rgba(61,43,255,.7);
}
.btn-primary:hover{ transform: translateY(-2px); box-shadow: 0 18px 40px -12px rgba(61,43,255,.8); color:#fff; }
.btn-ghost{
  background: rgba(255,255,255,.08);
  color:#fff; border-color: rgba(255,255,255,.22);
  backdrop-filter: blur(10px);
}
.btn-ghost:hover{ background: rgba(255,255,255,.16); color:#fff; transform: translateY(-2px); }
.btn-dark{ background: var(--c-ink); color:#fff; }
.btn-dark:hover{ background: var(--c-accent); color:#fff; transform: translateY(-2px); }

/* Hero · Brand panel (replaces stats) */
.hero-panel{
  position:relative;
  padding: 28px;
  border-radius: var(--r-xl);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(14px);
  box-shadow: 0 30px 80px -30px rgba(0,0,0,.6);
}
.hero-panel-head{
  display:flex; align-items:center; justify-content:space-between;
  font-family: var(--f-mono); font-size:.7rem; letter-spacing:.2em;
  text-transform:uppercase; color: rgba(255,255,255,.55);
  margin-bottom: 18px;
}
.hero-panel-head .led{ display:inline-flex; align-items:center; gap:8px; }
.hero-panel-head .led .lamp{
  width:8px; height:8px; border-radius:50%;
  background: #16A34A; box-shadow: 0 0 0 3px rgba(22,163,74,.25);
  animation: pulse 1.6s infinite;
}
@keyframes pulse{ 0%,100%{ opacity:1 } 50%{ opacity:.55 } }

.hero-logo-stage{
  position:relative;
  height: 230px;
  margin-bottom: 24px;
  display:grid; place-items:center;
  isolation:isolate;
}
.hero-logo-ring{
  position:absolute;
  width:200px; height:200px; border-radius:50%;
  border:1px dashed rgba(255,255,255,.20);
  animation: spin 22s linear infinite;
}
.hero-logo-ring::before, .hero-logo-ring::after{
  content:''; position:absolute; width:8px; height:8px; border-radius:50%;
  background: var(--c-accent-2); box-shadow:0 0 18px var(--c-accent-2);
  top:-4px; left:50%; transform: translateX(-50%);
}
.hero-logo-ring::after{
  background: var(--c-accent-3); box-shadow:0 0 18px var(--c-accent-3);
  top:auto; bottom:-4px;
}
.hero-logo-ring.outer{ width:270px; height:270px; animation-duration:38s; animation-direction:reverse; opacity:.55; }
@keyframes spin{ to{ transform: rotate(360deg); } }

.hero-logo-glow{
  position:absolute; width:240px; height:240px; border-radius:50%;
  background: radial-gradient(closest-side, rgba(61,43,255,.55), rgba(0,217,255,.18) 50%, transparent 70%);
  filter: blur(18px);
  z-index:-1;
}
.hero-logo-img{
  width: 132px; height: 132px;
  border-radius: 30px;
  box-shadow: 0 30px 60px -16px rgba(0,217,255,.35), 0 12px 28px rgba(0,0,0,.45), inset 0 0 0 1px rgba(255,255,255,.18);
  animation: float 6s ease-in-out infinite;
  object-fit: cover;
}
@keyframes float{ 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-8px) } }

.hero-panel-meta{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  border-top:1px solid rgba(255,255,255,.10);
  padding-top: 18px;
}
.hpm{ text-align:center; }
.hpm-num{
  font-family: var(--f-display);
  font-size: 1.55rem; font-weight:700; line-height:1;
  background: linear-gradient(135deg, #fff 0%, #00D9FF 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  margin-bottom:4px;
}
.hpm-lbl{
  font-size:.7rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color: rgba(255,255,255,.55);
}
.hero-panel-band{
  margin-top: 22px;
  padding: 12px 16px;
  border-radius: 14px;
  background: rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; gap:14px;
}
.band-wave{
  flex:1; height:34px;
  background:
    repeating-linear-gradient(90deg, transparent 0 14px, rgba(255,255,255,.05) 14px 15px),
    radial-gradient(ellipse at center, rgba(0,217,255,.10), transparent 70%);
  position:relative;
  overflow:hidden;
  border-radius: 6px;
}
.band-wave svg{ position:absolute; inset:0; width:100%; height:100%; }
.band-stat{ font-family: var(--f-mono); font-size:.78rem; color: var(--c-accent-2); white-space:nowrap; }

@media (max-width: 900px){
  .hero{ padding: 56px 0 70px; }
  .hero-grid{ grid-template-columns: 1fr; gap: 40px; }
  .hero-logo-img{ width:108px; height:108px; }
  .hero-logo-stage{ height:200px; }
}

/* ---------- Disclosure bar ---------- */
.disclosure-bar{
  background: var(--c-ink);
  color: rgba(255,255,255,.78);
  font-size:.85rem; padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.disclosure-bar strong{ color:#fff; margin-right:6px; font-weight:600; }
.disclosure-bar .container{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.disclosure-bar .icon{ flex:none; }

/* ---------- Section scaffolding ---------- */
.section{ padding: 88px 0; }
.section.tight{ padding: 56px 0; }
.section-head{ text-align:center; max-width: 720px; margin: 0 auto 48px; }
.section-eyebrow{
  display:inline-block;
  font-family: var(--f-mono); font-size:.78rem; letter-spacing:.22em;
  text-transform:uppercase; color: var(--c-accent);
  background: rgba(61,43,255,.08);
  padding: 6px 12px; border-radius: 999px;
  margin-bottom: 16px;
}
.section-head p{
  color: var(--c-mute);
  font-size: 1.05rem;
  margin: 12px auto 0;
  max-width: 60ch;
}
.divider{
  width: 56px; height: 4px;
  background: var(--grad-brand); border-radius: 4px;
  margin: 18px auto 0;
}

/* ---------- Top Picks (redesigned) ---------- */
.top-picks{
  background: linear-gradient(180deg, #fff 0%, #F4F7FB 100%);
  position:relative;
}
.podium-wrap{
  display:grid; grid-template-columns: 1fr 1.18fr 1fr;
  gap: 24px;
  align-items:end;
  margin-top: 24px;
}
.pick-card{
  background:#fff;
  border-radius: var(--r-xl);
  border: 1px solid var(--c-mist);
  overflow:hidden;
  text-decoration:none; color: inherit;
  position:relative;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  box-shadow: var(--sh-sm);
  display:flex; flex-direction:column;
}
.pick-card:hover{ transform: translateY(-6px); box-shadow: var(--sh-lg); border-color: rgba(61,43,255,.18); }
.pick-card .pick-rank{
  position:absolute; top:18px; left:18px; z-index:2;
  display:inline-flex; align-items:center; justify-content:center;
  width: 44px; height: 44px;
  border-radius: 50%;
  font-family: var(--f-display); font-weight:700; font-size:1.1rem;
  background: var(--c-ink); color:#fff;
  box-shadow: 0 8px 22px -10px rgba(11,15,31,.55);
}
.pick-card.gold .pick-rank{ background: linear-gradient(135deg, #F5B642, #C57E00); box-shadow: 0 10px 28px -8px rgba(245,182,66,.6); }
.pick-card.silver .pick-rank{ background: linear-gradient(135deg, #C9D1DC, #7C8AA0); }
.pick-card.bronze .pick-rank{ background: linear-gradient(135deg, #D38A4A, #8C5424); }
.pick-img{
  background: linear-gradient(135deg, #F4F7FB 0%, #E5EAF3 100%);
  aspect-ratio: 4 / 3;
  display:grid; place-items:center;
  padding: 28px;
  position:relative;
}
.pick-img img{ max-width:100%; max-height:100%; object-fit:contain; transition: transform .3s; }
.pick-card:hover .pick-img img{ transform: scale(1.04); }
.pick-card.gold .pick-img{ aspect-ratio: 4 / 3.4; background: linear-gradient(135deg, #FFF8E7 0%, #FFE7B0 100%); }
.pick-card .pick-ribbon{
  position:absolute; top:18px; right:-50px;
  background: var(--c-ink); color:#fff;
  font-size:.62rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  padding: 6px 56px;
  transform: rotate(38deg);
  z-index:2;
}
.pick-card.gold .pick-ribbon{ background: var(--grad-amber); }
.pick-body{
  padding: 22px;
  display:grid; gap: 8px;
  flex:1;
}
.pick-meta{
  display:flex; align-items:center; gap:10px;
  font-size:.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color: var(--c-mute);
}
.pick-meta .brand-chip{
  padding: 4px 10px;
  background: rgba(61,43,255,.08);
  color: var(--c-accent);
  border-radius:999px;
  letter-spacing:.06em;
}
.pick-card .pick-title{
  font-family: var(--f-display); font-size: 1.22rem; font-weight:700;
  color: var(--c-ink);
  letter-spacing:-0.015em;
  line-height:1.25;
  margin:0;
}
.pick-card.gold .pick-title{ font-size: 1.4rem; }
.pick-rating{
  display:flex; align-items:center; gap:10px;
  margin-top: 4px;
}
.pick-rating .stars{ color: #FFB347; letter-spacing:1px; font-size:.95rem; }
.pick-rating .num{ font-family: var(--f-mono); font-size:.92rem; font-weight:700; color: var(--c-ink); }
.pick-rating .scale{ color: var(--c-mute); font-size:.82rem; }
.pick-cta{
  margin-top: 14px;
  display:inline-flex; align-items:center; gap:8px;
  font-weight:600; color: var(--c-accent);
  font-size:.92rem;
}
.pick-cta::after{ content:'→'; transition: transform .2s; }
.pick-card:hover .pick-cta::after{ transform: translateX(4px); }

@media (max-width: 900px){
  .podium-wrap{ grid-template-columns: 1fr; }
}

/* ---------- Filter bar (redesigned) ---------- */
.filter-bar{
  display:flex; flex-wrap:wrap; gap:14px; align-items:center;
  padding: 18px 22px;
  background:#fff;
  border:1px solid var(--c-mist);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
  margin-bottom: 32px;
}
.filter-label{
  font-size: .82rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color: var(--c-mute);
}
.filter-select{
  appearance:none; -webkit-appearance:none;
  padding: 10px 36px 10px 14px;
  background:#fff;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path fill='%235A6A85' d='M3 4.5l3 3 3-3'/></svg>");
  background-repeat:no-repeat; background-position: right 12px center;
  border:1px solid var(--c-fog); border-radius: 10px;
  font: 600 .9rem var(--f-sans); color: var(--c-ink);
  cursor:pointer; transition: border-color .2s, box-shadow .2s;
}
.filter-select:focus{ outline:none; border-color: var(--c-accent); box-shadow: 0 0 0 4px rgba(61,43,255,.10); }
.filter-reset{
  margin-left:auto;
  padding: 10px 16px;
  background:#fff; color: var(--c-ink);
  border:1px solid var(--c-fog); border-radius: 10px;
  font: 600 .85rem var(--f-sans);
  display:inline-flex; align-items:center; gap:6px;
  transition: background .2s, color .2s, border-color .2s;
}
.filter-reset:hover{ background: var(--c-ink); color:#fff; border-color: var(--c-ink); }
.filter-results{
  font-family: var(--f-mono); font-size:.85rem; color: var(--c-accent); font-weight:700;
}

/* ---------- Product cards (grid) ---------- */
.products-grid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 22px;
}
@media (max-width: 1180px){ .products-grid{ grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 920px){  .products-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px){  .products-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px){  .products-grid{ grid-template-columns: 1fr; } }

.product-card{
  display:flex; flex-direction:column;
  background:#fff;
  border:1px solid var(--c-mist);
  border-radius: var(--r-lg);
  text-decoration:none; color: inherit;
  overflow:hidden;
  transition: transform .25s, box-shadow .25s, border-color .25s;
  box-shadow: var(--sh-sm);
}
.product-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--sh-lg);
  border-color: rgba(61,43,255,.20);
}
.card-img-wrap{
  position:relative;
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, #F8FAFC 0%, #ECF1F7 100%);
  display:grid; place-items:center;
  padding: 16px;
  overflow:hidden;
}
.card-img-wrap img{
  max-width:100%; max-height:100%; object-fit:contain;
  transition: transform .3s ease;
}
.product-card:hover .card-img-wrap img{ transform: scale(1.05); }
.card-badge{
  position:absolute; top:10px; left:10px;
  background: rgba(11,15,31,.92);
  color:#fff;
  font-size:.65rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding: 4px 9px; border-radius:6px;
  backdrop-filter: blur(6px);
}
.card-rating-badge{
  position:absolute; top:10px; right:10px;
  display:inline-flex; align-items:center; gap:4px;
  background:#fff; color: var(--c-ink);
  font: 700 .78rem var(--f-mono);
  padding: 4px 9px; border-radius: 6px;
  box-shadow: var(--sh-sm);
}
.card-rating-badge .si{ color: #FFB347; }
.card-body{
  padding: 16px 16px 8px;
  display:grid; gap:8px;
  flex:1;
}
.card-brand{
  font-family: var(--f-mono);
  font-size:.7rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color: var(--c-accent);
}
.card-title{
  font-family: var(--f-display); font-size: 1rem; font-weight:600;
  color: var(--c-ink); margin:0; letter-spacing:-0.01em;
  line-height:1.3;
}
.stars-row{ display:flex; align-items:center; gap:6px; font-size:.82rem; flex-wrap:wrap; }
.stars-char{ color:#FFB347; letter-spacing:1px; }
.rating-num{ font-family: var(--f-mono); font-weight:700; color: var(--c-ink); }
.rating-count{ color: var(--c-mute); font-size:.78rem; }
.card-snippet{ display:none; }
.card-footer{
  padding: 0 16px 16px;
  margin-top: auto;
}
.btn-review{
  display:inline-flex; align-items:center; gap:6px;
  font-size: .82rem; font-weight:600; color: var(--c-accent);
}
.btn-review::after{ content:'→'; transition: transform .2s; }
.product-card:hover .btn-review::after{ transform: translateX(4px); }

/* ---------- Pagination ---------- */
.pagination{
  display:flex; flex-wrap:wrap; gap:6px; justify-content:center;
  margin-top: 36px;
}
.page-btn{
  min-width: 40px; height: 40px;
  padding: 0 12px;
  background:#fff; color: var(--c-ink);
  border:1px solid var(--c-fog); border-radius:10px;
  font: 600 .9rem var(--f-sans);
  display:inline-flex; align-items:center; justify-content:center;
  transition: all .2s;
}
.page-btn:hover{ background: var(--c-ink); color:#fff; border-color: var(--c-ink); }
.page-btn.active{ background: var(--grad-brand); color:#fff; border-color: transparent; box-shadow: 0 8px 22px -10px rgba(61,43,255,.55); }
.page-btn.disabled{ opacity:.4; pointer-events:none; }
.pg-empty{
  text-align:center; color: var(--c-mute);
  padding: 48px 24px; background:#fff; border-radius:14px; border:1px dashed var(--c-fog);
  margin-top:24px;
}
.pg-empty-btn{ margin-left:8px; padding:8px 14px; border-radius:8px; border:1px solid var(--c-accent); color:#fff; background: var(--c-accent); }

/* ---------- Compare table ---------- */
.compare-section{ background: linear-gradient(180deg, #F4F7FB 0%, #fff 100%); }
.compare-table-wrap{
  background:#fff; border-radius: var(--r-xl);
  border:1px solid var(--c-mist);
  box-shadow: var(--sh-md);
  overflow:hidden;
}
.compare-scroll{ overflow-x:auto; }
.compare-table{ width:100%; border-collapse:collapse; min-width: 720px; }
.compare-table thead th{
  text-align:left; padding: 18px 16px;
  font: 700 .72rem var(--f-mono); letter-spacing:.16em; text-transform:uppercase;
  color: var(--c-mute);
  background: #F8FAFC;
  border-bottom: 1px solid var(--c-mist);
}
.compare-table tbody td{
  padding: 16px;
  border-bottom: 1px solid var(--c-mist);
  vertical-align:middle;
  font-size:.92rem;
}
.compare-row{ cursor:pointer; transition: background .2s; }
.compare-row:hover{ background:#F8FAFC; }
.compare-rank{ font-family: var(--f-display); font-weight:700; font-size:1.1rem; color: var(--c-ink); width: 60px; }
.compare-img{ width:64px; height:64px; object-fit:contain; padding:4px; background:#F4F7FB; border-radius:10px; }
.compare-name{ font-family: var(--f-display); font-weight:600; color: var(--c-ink); }
.compare-brand-tag{ font-size:.78rem; color: var(--c-accent); font-weight:600; margin-top:2px; }
.compare-score{ font-family: var(--f-mono); font-weight:700; color: var(--c-ink); font-size:1.02rem; }
.compare-bar{ width:120px; height:6px; background: var(--c-mist); border-radius: 4px; margin-top:6px; overflow:hidden; }
.compare-bar-fill{ height:100%; background: var(--grad-brand); border-radius: 4px; }
.compare-link{
  display:inline-flex; align-items:center; gap:6px;
  background: var(--c-ink); color:#fff; padding: 8px 14px; border-radius: 9px;
  font-size:.82rem; font-weight:600;
  transition: background .2s;
}
.compare-link:hover{ background: var(--c-accent); color:#fff; }

/* ---------- Trust strip ---------- */
.trust-strip{
  background: #fff;
  border-top:1px solid var(--c-mist);
  border-bottom:1px solid var(--c-mist);
  padding: 32px 0;
}
.trust-row{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:24px;
  align-items:start;
}
.trust-item{ display:flex; gap:14px; align-items:flex-start; }
.trust-icon{
  width:42px; height:42px; flex:none;
  border-radius: 10px;
  display:grid; place-items:center;
  background: rgba(61,43,255,.10);
  color: var(--c-accent);
  font-size: 20px;
}
.trust-item h4{ font-family: var(--f-display); margin:0 0 4px; font-size:.98rem; }
.trust-item p{ font-size:.86rem; color: var(--c-mute); margin:0; line-height:1.5; }
@media (max-width: 920px){ .trust-row{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px){ .trust-row{ grid-template-columns: 1fr; } }

/* ---------- Footer ---------- */
footer.site-footer{
  background: var(--c-ink);
  color: rgba(255,255,255,.72);
  padding: 72px 0 32px;
  margin-top: 72px;
  position:relative;
  overflow:hidden;
}
footer.site-footer::before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background: linear-gradient(90deg, transparent, var(--c-accent-2), transparent);
  opacity:.5;
}
.footer-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 48px;
}
.footer-brand-block{ max-width: 360px; }
.footer-logo{
  display:inline-flex; align-items:center; gap:12px;
  margin-bottom: 18px;
}
.footer-logo img{ width:38px; height:38px; border-radius:10px; }
.footer-logo .ftn{ font: 700 1.2rem var(--f-display); color:#fff; letter-spacing:-0.02em; }
.footer-brand-block p{ font-size:.92rem; line-height:1.6; }
.footer-disclaimer{
  display:block; margin-top:14px;
  padding: 12px 14px;
  background: rgba(255,255,255,.05);
  border-left:3px solid var(--c-accent-2);
  border-radius: 6px;
  font-size:.82rem; color: rgba(255,255,255,.65);
}
.footer-col h4{
  font-family: var(--f-mono); font-size:.78rem; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  color:#fff; margin: 0 0 16px;
}
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.footer-col a{
  color: rgba(255,255,255,.72); font-size:.92rem;
  transition: color .2s;
}
.footer-col a:hover{ color: var(--c-accent-2); }
.footer-bottom{
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.08);
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  font-size:.85rem; color: rgba(255,255,255,.55);
}
.footer-bottom a{ color: rgba(255,255,255,.72); margin: 0 4px; }
.footer-bottom a:hover{ color: var(--c-accent-2); }
@media (max-width: 920px){ .footer-grid{ grid-template-columns: 1fr 1fr; } .footer-brand-block{ grid-column: 1 / -1; max-width:none; } }
@media (max-width: 540px){ .footer-grid{ grid-template-columns: 1fr; } }

/* ---------- Page hero (subpages) ---------- */
.page-hero{
  background: var(--grad-dark);
  color:#fff;
  padding: 64px 0 80px;
  position:relative; overflow:hidden;
}
.page-hero::after{
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(40% 40% at 20% 30%, rgba(61,43,255,.35), transparent 60%),
    radial-gradient(50% 50% at 80% 80%, rgba(0,217,255,.20), transparent 60%);
}
.page-hero .container{ position:relative; z-index:1; }
.breadcrumb{
  display:flex; flex-wrap:wrap; align-items:center; gap:8px;
  font-size:.85rem; color: rgba(255,255,255,.65);
  margin-bottom: 18px;
}
.breadcrumb a{ color: rgba(255,255,255,.85); text-decoration:none; }
.breadcrumb a:hover{ color: var(--c-accent-2); }
.breadcrumb sep{ opacity:.4; }
.page-hero h1{ color:#fff; max-width:24ch; }

/* ---------- Static page content ---------- */
.static-hero{
  background: var(--grad-dark);
  color:#fff;
  padding: 64px 0 80px;
  position:relative; overflow:hidden;
  text-align:center;
}
.static-hero::after{
  content:''; position:absolute; inset:0;
  background: radial-gradient(60% 60% at 50% 30%, rgba(61,43,255,.45), transparent 60%);
}
.static-hero .container{ position:relative; z-index:1; }
.static-hero h1{ color:#fff; margin-bottom:18px; }
.static-hero p{ color: rgba(255,255,255,.78); font-size:1.1rem; max-width: 60ch; margin:0 auto; }
.static-content{
  max-width: 800px; margin: -40px auto 0;
  background:#fff; padding: 56px 56px;
  border-radius: var(--r-xl);
  border: 1px solid var(--c-mist);
  box-shadow: var(--sh-md);
  position:relative; z-index:2;
}
.static-content h2{
  margin: 32px 0 14px; font-size: 1.5rem;
  position:relative; padding-left:18px;
}
.static-content h2::before{
  content:''; position:absolute; left:0; top:.35em; bottom:.35em; width:5px;
  background: var(--grad-brand); border-radius: 4px;
}
.static-content h2:first-child{ margin-top:0; }
.static-content p, .static-content ul, .static-content ol{ font-size: 1rem; color: var(--c-ink-2); }
.static-content ul{ padding-left: 22px; }
.static-content ul li{ margin-bottom: 8px; }
.static-content strong{ color: var(--c-ink); }
@media (max-width:680px){ .static-content{ padding: 32px 24px; } }

/* ---------- Product page ---------- */
.product-page-wrap{ padding: 56px 0 32px; }
.product-layout{
  display:grid; grid-template-columns: 1.05fr 1fr;
  gap: 56px;
  margin-bottom: 48px;
}
@media (max-width: 920px){ .product-layout{ grid-template-columns: 1fr; gap: 32px; } }

.gallery{ align-self:start; }
@media (min-width: 921px){
  .gallery{
    position:sticky; top:96px;
    max-height: calc(100vh - 120px);
    overflow:visible;
  }
  .gallery-main{ max-height: calc(100vh - 280px); }
}
.gallery-main{
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, #F4F7FB 0%, #E5EAF3 100%);
  border-radius: var(--r-xl);
  overflow:hidden;
  display:grid; place-items:center;
  padding: 32px;
  border: 1px solid var(--c-mist);
}
.gallery-main img{ max-width:100%; max-height:100%; object-fit:contain; }
.gallery-thumbs{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:10px;
  margin-top: 12px;
}
.gallery-thumb{
  aspect-ratio: 1;
  background:#F4F7FB;
  border-radius: 12px;
  border: 2px solid transparent;
  display:grid; place-items:center;
  padding:8px;
  cursor:pointer;
  transition: border-color .2s, transform .2s;
}
.gallery-thumb:hover{ transform: translateY(-2px); }
.gallery-thumb.active{ border-color: var(--c-accent); }
.gallery-thumb img{ max-width:100%; max-height:100%; object-fit:contain; }

.p-brand{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--f-mono); font-size:.78rem; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase;
  color: var(--c-accent);
  background: rgba(61,43,255,.08);
  padding: 6px 12px; border-radius: 999px;
  margin-bottom: 16px;
}
.p-title{
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  margin-bottom: 16px;
  letter-spacing:-0.02em;
}
.p-rating{
  display:flex; align-items:center; gap:12px;
  margin-bottom: 24px; flex-wrap:wrap;
}
.p-rating .stars-char{ font-size:1.1rem; }
.p-rating .score{ font: 700 1.05rem var(--f-mono); color: var(--c-ink); }
.p-rating .reviews-ct{ color: var(--c-mute); font-size:.88rem; }
.score-bar-wrap{ margin-bottom: 26px; }
.score-bar-label{
  display:flex; justify-content:space-between;
  font: 600 .78rem var(--f-mono); letter-spacing:.12em; text-transform:uppercase;
  color: var(--c-mute); margin-bottom: 8px;
}
.score-bar-track{
  height: 10px; background: var(--c-mist); border-radius: 6px; overflow:hidden;
}
.score-bar-fill{
  height:100%; background: var(--grad-brand);
  border-radius: 6px; box-shadow: 0 0 12px rgba(61,43,255,.45);
}
.verdict-box{
  background: linear-gradient(135deg, #F8FAFC 0%, #EEF3FA 100%);
  border-left: 4px solid var(--c-accent);
  border-radius: 14px;
  padding: 20px 22px;
  margin-bottom: 24px;
}
.verdict-label{
  font: 700 .72rem var(--f-mono); letter-spacing:.18em; text-transform:uppercase;
  color: var(--c-accent); margin-bottom: 8px;
}
.verdict-text{ margin: 0; color: var(--c-ink-2); font-size:.98rem; line-height:1.6; }

.cta-group{
  display:flex; flex-wrap:wrap; gap:12px;
  margin: 24px 0 8px;
}
.btn-buy{
  display:inline-flex; align-items:center; gap:8px;
  padding: 14px 22px;
  background: var(--grad-brand);
  color:#fff;
  border-radius: 12px;
  font-weight:700; font-size:.95rem;
  text-decoration:none;
  box-shadow: 0 14px 30px -12px rgba(61,43,255,.6);
  transition: transform .2s, box-shadow .2s;
}
.btn-buy:hover{ transform: translateY(-2px); color:#fff; box-shadow: 0 18px 40px -12px rgba(61,43,255,.75); }
.btn-buy.alt{ background: var(--grad-amber); box-shadow: 0 14px 30px -12px rgba(255,179,71,.65); }
.btn-buy.alt:hover{ box-shadow: 0 18px 40px -12px rgba(255,179,71,.8); }
.btn-buy.outline{ background: transparent; color: var(--c-accent); border: 2px solid var(--c-accent); box-shadow:none; }
.btn-buy.outline:hover{ background: var(--c-accent); color:#fff; }
.btn-read-reviews{
  display:inline-flex; align-items:center; gap:8px;
  padding: 14px 20px;
  background: #fff; color: var(--c-ink);
  border:1px solid var(--c-fog);
  border-radius: 12px;
  font-weight:600; font-size:.92rem;
  text-decoration:none; transition: all .2s;
}
.btn-read-reviews:hover{ background: var(--c-ink); color:#fff; border-color: var(--c-ink); }
.cta-disclosure{
  font-size:.78rem; color: var(--c-mute); margin: 8px 0 24px;
}

.features-block{
  margin: 12px 0 24px;
}
.features-block-head{
  font-family: var(--f-mono); font-size: .78rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .16em;
  color: var(--c-mute); margin-bottom: 12px;
}
.features-list{
  list-style:none; padding:0; margin: 0;
  display:grid; gap:10px;
}
.features-list li{
  position:relative; padding: 10px 14px 10px 42px;
  background: #F8FAFC;
  border-radius: 10px;
  font-size:.94rem;
  color: var(--c-ink-2);
  border:1px solid var(--c-mist);
}
.features-list li::before{
  content:'⚡'; position:absolute; left: 12px; top: 50%; transform: translateY(-50%);
  width: 22px; height: 22px;
  display:grid; place-items:center;
  background: var(--grad-brand);
  color:#fff; border-radius: 6px;
  font-size:.72rem;
}

/* Pros / Cons */
.pros-cons{
  display:grid; grid-template-columns: 1fr 1fr; gap: 22px;
  margin: 12px 0 32px;
}
.pros-box, .cons-box{
  background:#fff;
  border:1px solid var(--c-mist);
  border-radius: var(--r-lg);
  padding: 24px;
  box-shadow: var(--sh-sm);
}
.pros-box{ border-top: 4px solid var(--c-success); }
.cons-box{ border-top: 4px solid var(--c-danger); }
.box-head{
  font: 700 .82rem var(--f-mono); letter-spacing:.16em; text-transform:uppercase;
  margin-bottom: 14px;
}
.pros-box .box-head{ color: var(--c-success); }
.cons-box .box-head{ color: var(--c-danger); }
.pros-box ul, .cons-box ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.pros-box li, .cons-box li{
  position:relative; padding-left: 26px;
  font-size:.92rem; color: var(--c-ink-2);
}
.pros-box li::before, .cons-box li::before{
  position:absolute; left:0; top:1px;
  width:18px; height:18px;
  display:grid; place-items:center;
  border-radius: 5px;
  font-size:.7rem; font-weight:700;
}
.pros-box li::before{ content:'✓'; background: rgba(22,163,74,.12); color: var(--c-success); }
.cons-box li::before{ content:'✕'; background: rgba(220,38,38,.12); color: var(--c-danger); }
@media (max-width:640px){ .pros-cons{ grid-template-columns: 1fr; } }

.product-desc{
  background:#fff;
  border:1px solid var(--c-mist);
  border-radius: var(--r-lg);
  padding: 28px 32px;
  margin-bottom: 28px;
  box-shadow: var(--sh-sm);
}
.product-desc h2{ font-size: 1.4rem; margin-bottom: 14px; }
.product-desc p{ font-size: 1rem; color: var(--c-ink-2); line-height: 1.7; }

/* Reviews */
.reviews-section{ margin-top: 32px; }
.reviews-section h2{ font-size: 1.5rem; margin-bottom: 20px; }
.reviews-grid{
  display:grid; grid-template-columns: repeat(2, 1fr); gap: 18px;
}
@media (max-width: 720px){ .reviews-grid{ grid-template-columns: 1fr; } }
.review-card{
  background:#fff;
  border:1px solid var(--c-mist);
  border-radius: var(--r-lg);
  padding: 22px;
  box-shadow: var(--sh-sm);
}
.review-top{
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom: 6px;
}
.reviewer-name{ font-weight:700; color: var(--c-ink); font-size:.95rem; }
.review-date{ font-size:.78rem; color: var(--c-mute); }
.review-stars{ color:#FFB347; letter-spacing:1px; margin-bottom: 6px; font-size:.92rem; }
.review-title{ font-family: var(--f-display); font-weight:600; color: var(--c-ink); margin-bottom: 6px; }
.review-text{ color: var(--c-ink-2); font-size:.92rem; line-height: 1.55; }

/* ---------- Related Products ---------- */
.related-section{ background: linear-gradient(180deg, #F4F7FB 0%, #fff 100%); padding: 64px 0; }
.related-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
}
@media (max-width:1080px){ .related-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width:760px){ .related-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width:420px){ .related-grid{ grid-template-columns: 1fr; } }
.related-card{
  background:#fff; border:1px solid var(--c-mist); border-radius: var(--r-lg);
  text-decoration:none; color: inherit;
  overflow:hidden;
  transition: all .25s;
  box-shadow: var(--sh-sm);
}
.related-card:hover{ transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: rgba(61,43,255,.18); }
.related-img{
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, #F8FAFC 0%, #ECF1F7 100%);
  display:grid; place-items:center; padding: 14px;
}
.related-img img{ max-width:100%; max-height:100%; object-fit:contain; }
.related-body{ padding: 16px; display:grid; gap:6px; }
.related-brand{ font: 700 .7rem var(--f-mono); letter-spacing:.16em; text-transform:uppercase; color: var(--c-accent); }
.related-title{ font-family: var(--f-display); font-size:.98rem; font-weight:600; color: var(--c-ink); line-height:1.3; }
.related-stars{ color:#FFB347; font-size:.85rem; }
.related-link{ font-size:.82rem; font-weight:600; color: var(--c-accent); }

/* ---------- Categories cloud ---------- */
.categories-section{ background: #fff; }
.categories-grid{
  display:grid; grid-template-columns: repeat(6, 1fr); gap: 12px;
  margin-top: 24px;
}
@media (max-width: 1080px){ .categories-grid{ grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 720px){ .categories-grid{ grid-template-columns: repeat(2, 1fr); } }
.category-chip{
  background:#fff;
  border:1px solid var(--c-mist);
  border-radius: 12px;
  padding: 16px 18px;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  text-decoration:none; color: var(--c-ink);
  font: 600 .92rem var(--f-sans);
  transition: all .2s;
  box-shadow: var(--sh-sm);
}
.category-chip:hover{ background: var(--c-ink); color:#fff; border-color: var(--c-ink); transform: translateY(-2px); }
.category-chip .chip-count{
  font: 700 .72rem var(--f-mono);
  background: rgba(61,43,255,.10); color: var(--c-accent);
  padding: 4px 9px; border-radius: 6px;
  transition: background .2s, color .2s;
}
.category-chip:hover .chip-count{ background: rgba(255,255,255,.18); color:#fff; }

/* ---------- Cookie Banner ---------- */
#cookie-banner{
  position:fixed; bottom: 20px; left: 50%; transform: translate(-50%, 30px);
  width: calc(100% - 40px); max-width: 720px;
  background: var(--c-ink); color: #fff;
  border-radius: 16px;
  padding: 18px 22px;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.6);
  z-index: 200;
  opacity:0; pointer-events:none;
  transition: opacity .3s, transform .3s;
}
#cookie-banner.visible{ opacity:1; transform: translate(-50%, 0); pointer-events:auto; }
.cookie-inner{ display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.cookie-text{ flex:1 1 320px; margin:0; font-size:.88rem; color: rgba(255,255,255,.85); }
.cookie-text a{ color: var(--c-accent-2); }
.cookie-btns{ display:flex; gap:8px; }
.cookie-accept, .cookie-decline{
  padding: 10px 16px; border-radius: 10px; border:0;
  font: 600 .86rem var(--f-sans); cursor:pointer;
  transition: background .2s;
}
.cookie-accept{ background: var(--grad-brand); color:#fff; }
.cookie-accept:hover{ filter: brightness(1.1); }
.cookie-decline{ background: rgba(255,255,255,.1); color:#fff; }
.cookie-decline:hover{ background: rgba(255,255,255,.18); }

/* ---------- Ads ---------- */
.ad-placement{ padding: 32px 0; background: var(--c-cream); }
.ad-placement-inner{
  display:flex; flex-wrap:wrap; gap:18px; justify-content:center;
}
.ad-unit{ min-width: 300px; min-height: 250px; background: #fff; border:1px dashed var(--c-fog); border-radius:12px; }

img[loading]{ background: #f4f7fb; }

/* ---------- Price block (product page) ---------- */
.price-block{
  margin: 22px 0 24px;
  padding: 22px 24px;
  background: linear-gradient(135deg, #0B0F1F 0%, #1A2138 100%);
  color: #fff;
  border-radius: var(--r-lg);
  position:relative; overflow:hidden;
  box-shadow: var(--sh-md);
}
.price-block::before{
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(40% 60% at 0% 0%, rgba(61,43,255,.35), transparent 60%),
    radial-gradient(50% 60% at 100% 100%, rgba(0,217,255,.22), transparent 60%);
  pointer-events:none;
}
.price-block > *{ position:relative; z-index:1; }
.price-row{
  display:flex; align-items:flex-end; gap:14px;
  flex-wrap:wrap;
}
.price-now{
  font-family: var(--f-display);
  font-size: 2.4rem; font-weight: 700; line-height:1;
  letter-spacing:-0.02em;
  background: linear-gradient(135deg, #fff 0%, #00D9FF 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.price-label{
  font: 700 .68rem var(--f-mono); letter-spacing:.2em; text-transform:uppercase;
  color: rgba(255,255,255,.5);
  margin-bottom:4px;
}
.price-trend{
  display:inline-flex; align-items:center; gap:6px;
  padding: 4px 10px; border-radius: 999px;
  font: 600 .78rem var(--f-mono);
  background: rgba(22,163,74,.22); color:#7BE6A0;
}
.price-trend.up{ background: rgba(220,38,38,.22); color:#F8A5A5; }
.price-meta{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 18px;
  border-top:1px solid rgba(255,255,255,.10);
  padding-top: 14px;
}
.price-meta .pm{ text-align:left; }
.price-meta .pm-lbl{
  font: 600 .65rem var(--f-mono); letter-spacing:.18em; text-transform:uppercase;
  color: rgba(255,255,255,.45);
}
.price-meta .pm-val{
  font-family: var(--f-mono); font-size:1.02rem; font-weight:700; color:#fff;
  margin-top: 2px;
}
.price-meta .pm-val.lo{ color: #7BE6A0; }
.price-meta .pm-val.hi{ color: #F8A5A5; }

/* Sparkline */
.spark-wrap{
  margin-top: 18px;
  background: rgba(0,0,0,.3);
  border-radius: 12px;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.08);
}
.spark-head{
  display:flex; justify-content:space-between; align-items:center;
  font: 600 .68rem var(--f-mono); letter-spacing:.18em; text-transform:uppercase;
  color: rgba(255,255,255,.55);
  margin-bottom: 6px;
}
.spark-head .spark-period{ color: rgba(255,255,255,.7); }
.spark-svg{ display:block; width:100%; height: 70px; }

/* ---------- Price chart section (full chart on product page) ---------- */
.price-history-section{
  background: #fff;
  border:1px solid var(--c-mist);
  border-radius: var(--r-lg);
  padding: 28px 32px;
  margin: 0 0 28px;
  box-shadow: var(--sh-sm);
}
.price-history-section h2{
  font-size: 1.4rem; margin-bottom: 8px;
  display:flex; align-items:center; gap:10px;
}
.price-history-section h2 .badge-est{
  font: 700 .58rem var(--f-mono); letter-spacing:.16em; text-transform:uppercase;
  background: rgba(245,158,11,.14); color: #B45309;
  padding: 4px 8px; border-radius: 6px;
}
.price-history-section .ph-sub{
  color: var(--c-mute); font-size:.92rem; margin: 0 0 18px;
}
.ph-chart-wrap{
  position:relative;
  background: linear-gradient(180deg, #F8FAFC 0%, #fff 100%);
  border-radius: 12px;
  border: 1px solid var(--c-mist);
  padding: 18px;
}
.ph-chart-wrap svg{ display:block; width:100%; height: 240px; }
.ph-stats{
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  margin-top: 18px;
}
.ph-stat{
  background:#F8FAFC; border:1px solid var(--c-mist); border-radius:10px;
  padding: 12px 14px;
}
.ph-stat .lbl{
  font: 700 .65rem var(--f-mono); letter-spacing:.16em; text-transform:uppercase;
  color: var(--c-mute);
}
.ph-stat .val{
  font-family: var(--f-mono); font-weight:700; color: var(--c-ink);
  font-size: 1.05rem; margin-top: 4px;
}
.ph-stat .val.lo{ color: var(--c-success); }
.ph-stat .val.hi{ color: var(--c-danger); }
@media (max-width:680px){
  .ph-stats{ grid-template-columns: repeat(2, 1fr); }
  .price-history-section{ padding: 22px; }
}

/* ---------- Price badge on product card (index) ---------- */
.card-price-badge{
  position:absolute; bottom:10px; left:10px;
  display:inline-flex; align-items:center; gap:4px;
  background: rgba(11,15,31,.92); color:#fff;
  font: 700 .82rem var(--f-mono);
  padding: 5px 10px; border-radius: 8px;
  backdrop-filter: blur(6px);
  box-shadow: 0 8px 18px -8px rgba(11,15,31,.55);
}
.card-price-badge .pcurr{ color: var(--c-accent-2); margin-right:1px; }
.card-price-badge .pdelta{
  font: 600 .68rem var(--f-mono);
  color:#7BE6A0; margin-left:4px;
  padding: 1px 5px; border-radius: 4px;
  background: rgba(22,163,74,.22);
}
.card-price-badge .pdelta.up{ color:#F8A5A5; background: rgba(220,38,38,.22); }

