/* =================================================================
   NIGERIAN PHONES — design tokens & core styles
   ================================================================= */
:root{
  --bg:#f6f7f9; --bg-elev:#ffffff; --surface:rgba(17,21,26,0.04);
  --text:#11151a; --text-dim:#4a5562; --text-faint:#7c8794;
  --border:rgba(17,21,26,0.10);
  --accent:#00a651; --accent-2:#1f6fff; --accent-soft:rgba(0,166,81,0.12);
  --price:#d97a00;
  --danger:#e0473c;
  --glass-bg:rgba(255,255,255,0.65); --glass-border:rgba(255,255,255,0.5);
  --radius-sm:10px; --radius-md:16px; --radius-lg:24px;
  --shadow-sm:0 2px 8px rgba(17,21,26,0.06);
  --shadow-md:0 8px 30px rgba(17,21,26,0.10);
  --shadow-lg:0 20px 60px rgba(17,21,26,0.16);
  --container:1240px;
  --nav-h:68px;
  --ff-display:'Sora',system-ui,sans-serif;
  --ff-body:'Inter',system-ui,sans-serif;
  --ff-mono:'JetBrains Mono',ui-monospace,monospace;
}
[data-theme="dark"]{
  --bg:#0a0d11; --bg-elev:#11161c; --surface:rgba(255,255,255,0.05);
  --text:#eef1f4; --text-dim:#a7b1bc; --text-faint:#6b7682;
  --border:rgba(255,255,255,0.09);
  --accent:#19d97a; --accent-2:#4d8bff; --accent-soft:rgba(25,217,122,0.14);
  --price:#ffb648;
  --glass-bg:rgba(17,22,28,0.6); --glass-border:rgba(255,255,255,0.08);
  --shadow-sm:0 2px 10px rgba(0,0,0,0.3);
  --shadow-md:0 10px 36px rgba(0,0,0,0.4);
  --shadow-lg:0 24px 70px rgba(0,0,0,0.55);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%}
body{margin:0;min-height:100vh; background:var(--bg);color:var(--text);font-family:var(--ff-body);
  font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;transition:background .25s,color .25s;
  overflow-x:hidden; word-wrap:break-word}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;line-height:1.15;margin:0 0 .5em; word-wrap:break-word}
p{margin:0 0 1em; word-wrap:break-word}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit; cursor:pointer}
.mono{font-family:var(--ff-mono)}
.container{max-width:var(--container);margin:0 auto;padding:0 20px; width:100%}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0); white-space:nowrap}
:focus-visible{outline:2px solid var(--accent-2);outline-offset:3px;border-radius:4px}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms !important;transition-duration:.01ms !important}}

/* ---------- Skip link ---------- */
.skip-link{position:absolute;left:-999px;top:10px;background:var(--accent);color:#04130b;padding:8px 16px;border-radius:8px;z-index:999;font-weight:600}
.skip-link:focus{left:10px}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--text);color:var(--bg);font-size:13px}
[data-theme="dark"] .topbar{background:#04100a}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:34px;gap:16px; flex-wrap:wrap}
.topbar a{opacity:.85}
.topbar a:hover{opacity:1}
@media (max-width:480px){
  .topbar .container{justify-content:center; height:auto; padding:8px 20px; gap:8px; text-align:center}
  .topbar{font-size:12px}
}

/* ---------- Navbar ---------- */
.navbar{position:sticky;top:0;z-index:200;height:var(--nav-h);display:flex;align-items:center;
  backdrop-filter:blur(16px) saturate(160%);background:var(--glass-bg);border-bottom:1px solid var(--glass-border)}
.navbar .container{display:flex;align-items:center;justify-content:space-between;gap:18px;width:100%}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--ff-display);font-weight:800;font-size:19px;letter-spacing:-.01em; flex-shrink:0}
.brand .dot{color:var(--accent)}
.brand-mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(140deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;color:#04130b;font-weight:800;font-family:var(--ff-mono);font-size:13px;flex-shrink:0}
.nav-links{display:flex;gap:4px;list-style:none;align-items:center; flex-wrap:wrap}
.nav-links a{padding:8px 12px;border-radius:8px;font-size:14.5px;font-weight:600;color:var(--text-dim);transition:.15s; white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:var(--surface)}
.nav-actions{display:flex;align-items:center;gap:8px; flex-shrink:0}
.icon-btn{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:var(--surface);
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:.15s;position:relative; flex-shrink:0}
.icon-btn:hover{background:var(--accent-soft);border-color:var(--accent)}
.icon-btn svg{width:18px;height:18px}
.badge-count{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#04130b;font-size:10px;font-weight:800;
  width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-mono)}
.nav-toggle{display:none; flex-shrink:0}
.mobile-nav{display:none}

@media (max-width:920px){
  .nav-links{display:none}
  .nav-toggle{display:flex;width:38px;height:38px;border-radius:8px;border:1px solid var(--border);background:var(--surface);align-items:center;justify-content:center;cursor:pointer}
  .mobile-nav{position:fixed;inset:var(--nav-h) 0 0 0;background:var(--bg-elev);z-index:300;padding:20px;overflow-y:auto;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:.2s}
  .mobile-nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .mobile-nav ul{display:flex;flex-direction:column;gap:4px;list-style:none}
  .mobile-nav a{display:block;padding:14px 12px;font-size:17px;font-weight:600;border-bottom:1px solid var(--border)}
}
@media (max-width:480px){
  .navbar{height:58px; --nav-h:58px}
  .brand{font-size:16px; gap:8px}
  .brand-mark{width:28px; height:28px; font-size:11px}
  .icon-btn{width:34px; height:34px}
  .icon-btn svg{width:16px; height:16px}
}

/* ---------- Search bar ---------- */
.search-wrap{position:relative;flex:1;max-width:380px; min-width:0}
.search-input{width:100%;padding:9px 14px 9px 38px;border-radius:999px;border:1px solid var(--border);background:var(--surface);
  color:var(--text);font-size:14px; min-width:0}
.search-input:focus{background:var(--bg-elev)}
.search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-faint);pointer-events:none}
.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-elev);border:1px solid var(--border);
  border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:380px;overflow-y:auto;display:none;z-index:50}
.search-results.show{display:block}
.search-result-item{display:flex;gap:12px;padding:10px 14px;align-items:center;border-bottom:1px solid var(--border)}
.search-result-item:last-child{border-bottom:none}
.search-result-item:hover{background:var(--surface)}
.search-result-item img{width:38px;height:38px;object-fit:contain;border-radius:8px;background:var(--surface); flex-shrink:0}
.search-result-item .sr-name{font-weight:600;font-size:14px}
.search-result-item .sr-price{font-family:var(--ff-mono);font-size:12px;color:var(--price)}
.search-empty{padding:18px;text-align:center;color:var(--text-faint);font-size:14px}

@media (max-width:920px){.search-wrap{display:none}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:999px;
  font-weight:700;font-size:14.5px;border:1px solid transparent;cursor:pointer;transition:.15s;white-space:nowrap; text-align:center}
.btn-primary{background:var(--accent);color:#04130b}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-outline{background:transparent;border-color:var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost{background:var(--surface);color:var(--text)}
.btn-ghost:hover{background:var(--accent-soft)}
.btn-whatsapp{background:#1fae5b;color:#fff}
.btn-whatsapp:hover{filter:brightness(1.08)}
.btn-sm{padding:7px 14px;font-size:13px}
.btn-block{width:100%}
.btn svg{width:16px;height:16px; flex-shrink:0}

@media (max-width:480px){
  .btn{padding:10px 16px; font-size:13.5px}
  .btn-sm{padding:6px 12px; font-size:12px}
}

/* ---------- Hero ---------- */
.hero{position:relative;padding:64px 0 56px;overflow:hidden}
.hero-grid-bg{position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:radial-gradient(circle at 18% 20%, var(--accent-soft), transparent 40%),
                    radial-gradient(circle at 85% 0%, rgba(31,111,255,.10), transparent 45%)}
.hero .container{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-mono);font-size:12.5px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:6px 14px;border-radius:999px;margin-bottom:18px}
.hero h1{font-size:clamp(28px,5.6vw,58px);max-width:820px;letter-spacing:-0.02em; word-wrap:break-word}
.hero h1 .accent-text{color:var(--accent)}
.hero-sub{font-size:18px;color:var(--text-dim);max-width:600px;margin-bottom:28px}
.hero-search{max-width:560px;display:flex;gap:10px;margin-bottom:30px; flex-wrap:wrap}
.hero-search .search-wrap{max-width:none; flex:1 1 100%; min-width:0}
.hero-search .search-input{padding:15px 16px 15px 42px;border-radius:14px;font-size:15px;background:var(--bg-elev);box-shadow:var(--shadow-sm); width:100%}
.hero-search .search-icon{left:16px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap}
.hero-stat b{font-family:var(--ff-mono);font-size:26px;display:block;color:var(--text)}
.hero-stat span{font-size:13px;color:var(--text-faint)}

@media (max-width:768px){
  .hero{padding:40px 0 36px}
  .hero h1{font-size:clamp(24px,7vw,36px)}
  .hero-sub{font-size:16px}
  .hero-stats{gap:20px}
  .hero-stat b{font-size:22px}
  .hero-cta{gap:10px}
}
@media (max-width:480px){
  .hero{padding:28px 0 24px}
  .eyebrow{font-size:11px; padding:5px 12px; margin-bottom:14px}
  .hero h1{font-size:clamp(22px,8vw,30px)}
  .hero-sub{font-size:15px; margin-bottom:20px}
  .hero-search .search-input{padding:12px 14px 12px 38px; font-size:14px; border-radius:12px}
  .hero-cta{margin-bottom:24px}
  .hero-stats{gap:16px; width:100%}
  .hero-stat b{font-size:20px}
  .hero-stat span{font-size:12px}
}

/* trending ticker */
.ticker{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface);overflow:hidden;padding:12px 0}
.ticker-track{display:flex;gap:28px;white-space:nowrap;animation:scrollTicker 32s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
@keyframes scrollTicker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{font-family:var(--ff-mono);font-size:13px;color:var(--text-dim);display:flex;gap:8px;align-items:center}
.ticker-item b{color:var(--text)}
.ticker-item .tprice{color:var(--price)}

@media (max-width:480px){
  .ticker{padding:10px 0}
  .ticker-item{font-size:11.5px; gap:6px}
}

/* ---------- Section heading ---------- */
.section{padding:56px 0}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.section-head h2{font-size:clamp(22px,3vw,32px);letter-spacing:-.01em}
.section-head p{color:var(--text-dim);margin:0}
.section-tag{font-family:var(--ff-mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:8px;display:block}

@media (max-width:768px){
  .section{padding:40px 0}
  .section-head h2{font-size:clamp(20px,4vw,26px)}
}
@media (max-width:480px){
  .section{padding:28px 0}
  .section-head{flex-direction:column; align-items:flex-start; gap:8px; margin-bottom:20px}
  .section-head h2{font-size:clamp(18px,5vw,22px)}
  .section-tag{font-size:11px}
}

/* ---------- Grids ---------- */
.grid{display:grid;gap:20px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:1080px){.grid-4{grid-template-columns:repeat(3,1fr)}}
@media (max-width:780px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
@media (max-width:480px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr; gap:16px}}

/* ---------- Phone Card ---------- */
.phone-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;
  display:flex;flex-direction:column;transition:.2s;position:relative; min-width:0}
.phone-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.phone-card .card-media{aspect-ratio:1/0.95;background:var(--surface);display:flex;align-items:center;justify-content:center;padding:22px;position:relative; min-height:180px}
.phone-card .card-media img{height:100%;max-height:200px;object-fit:contain;filter:drop-shadow(0 10px 18px rgba(0,0,0,0.12))}
.fav-btn{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:var(--glass-bg);
  border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(6px);z-index:2}
.fav-btn svg{width:16px;height:16px;color:var(--text-dim)}
.fav-btn.active svg{color:var(--danger);fill:var(--danger)}
.card-tag{position:absolute;top:10px;left:10px;background:var(--accent);color:#04130b;font-size:11px;font-weight:800;
  padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em;z-index:2}
.card-body{padding:16px;display:flex;flex-direction:column;gap:6px;flex:1; min-width:0}
.card-brand{font-size:12px;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.card-title{font-family:var(--ff-display);font-size:16.5px;font-weight:700;line-height:1.3; word-wrap:break-word}
.card-specs{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0}
.spec-chip{font-family:var(--ff-mono);font-size:11px;background:var(--surface);border:1px solid var(--border);
  padding:3px 8px;border-radius:6px;color:var(--text-dim)}
.card-price-row{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:10px; gap:8px; flex-wrap:wrap}
.card-price{font-family:var(--ff-mono);font-weight:700;color:var(--price);font-size:15px; white-space:nowrap}
.card-rating{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-dim); white-space:nowrap; flex-shrink:0}
.card-rating svg{width:13px;height:13px;color:#ffb020}
.card-actions{display:flex;gap:8px;padding:0 16px 16px; flex-wrap:wrap}
.card-actions .btn{flex:1; min-width:0}

@media (max-width:480px){
  .phone-card .card-media{padding:16px; min-height:160px}
  .phone-card .card-media img{max-height:160px}
  .card-body{padding:14px; gap:5px}
  .card-title{font-size:15px}
  .card-actions{padding:0 14px 14px; gap:6px}
  .card-actions .btn{font-size:12.5px; padding:8px 12px}
  .fav-btn{width:30px; height:30px; top:8px; right:8px}
  .fav-btn svg{width:14px; height:14px}
  .card-tag{font-size:10px; padding:3px 8px; top:8px; left:8px}
  .spec-chip{font-size:10px; padding:2px 6px}
  .card-price{font-size:14px}
}

/* ---------- Brand Card ---------- */
.brand-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-md);padding:26px 20px;
  text-align:center;transition:.2s; min-width:0}
.brand-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.brand-card img{height:42px;margin:0 auto 14px;object-fit:contain; max-width:100%}
.brand-card h3{font-size:16px;margin-bottom:4px}
.brand-card span{font-size:12.5px;color:var(--text-faint)}

@media (max-width:480px){
  .brand-card{padding:20px 16px}
  .brand-card img{height:36px; margin-bottom:10px}
  .brand-card h3{font-size:14px}
  .brand-card span{font-size:11.5px}
}

/* ---------- Filters / toolbar ---------- */
.toolbar{display:flex;gap:14px;flex-wrap:wrap;align-items:center;background:var(--bg-elev);border:1px solid var(--border);
  border-radius:var(--radius-md);padding:16px;margin-bottom:26px}
.toolbar select,.toolbar input[type="text"]{padding:9px 12px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13.5px; min-width:0}
.toolbar label{font-size:12px;color:var(--text-faint);display:block;margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.filter-group{display:flex;flex-direction:column;gap:0; min-width:0; flex:1 1 160px}
.chip-group{display:flex;gap:6px;flex-wrap:wrap}
.filter-chip{padding:7px 13px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-size:13px;font-weight:600;cursor:pointer;color:var(--text-dim); white-space:nowrap}
.filter-chip.active{background:var(--accent);color:#04130b;border-color:var(--accent)}
.results-count{font-size:13.5px;color:var(--text-faint);margin-bottom:16px}

@media (max-width:768px){
  .toolbar{padding:14px; gap:12px}
  .filter-group{flex:1 1 140px}
  .filter-chip{padding:6px 11px; font-size:12.5px}
}
@media (max-width:480px){
  .toolbar{padding:12px; gap:10px; margin-bottom:20px}
  .toolbar select,.toolbar input[type="text"]{font-size:13px; padding:8px 10px}
  .filter-group{flex:1 1 120px}
  .filter-chip{padding:5px 10px; font-size:12px}
  .chip-group{gap:5px}
}

/* ---------- Breadcrumbs ---------- */
.breadcrumbs{font-size:13px;color:var(--text-faint);display:flex;gap:6px;flex-wrap:wrap;padding:18px 0;align-items:center}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs .sep{opacity:.5}

@media (max-width:480px){
  .breadcrumbs{font-size:12px; padding:14px 0}
}

/* ---------- Page header band ---------- */
.page-head{background:var(--surface);border-bottom:1px solid var(--border);padding:34px 0}
.page-head h1{font-size:clamp(24px,4vw,38px);margin-bottom:6px; word-wrap:break-word}
.page-head p{color:var(--text-dim);margin:0;max-width:680px}

@media (max-width:768px){
  .page-head{padding:28px 0}
  .page-head h1{font-size:clamp(22px,5vw,30px)}
}
@media (max-width:480px){
  .page-head{padding:22px 0}
  .page-head h1{font-size:clamp(20px,6vw,26px)}
  .page-head p{font-size:14px}
}

/* ---------- Phone Detail ---------- */
.phone-hero{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;padding:40px 0;align-items:start}
@media (max-width:880px){.phone-hero{grid-template-columns:1fr;gap:24px}}
.phone-gallery{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;
  display:flex;align-items:center;justify-content:center;position:sticky;top:calc(var(--nav-h) + 20px); min-height:300px}
.phone-gallery img{max-height:420px; width:100%; object-fit:contain}
@media (max-width:880px){.phone-gallery{position:static; min-height:250px; padding:28px}}
.phone-info .brand-tag{color:var(--accent);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:6px}
.phone-info h1{font-size:clamp(24px,4vw,36px);margin-bottom:10px; word-wrap:break-word}
.rating-row{display:flex;align-items:center;gap:10px;margin-bottom:18px; flex-wrap:wrap}
.stars{display:flex;gap:2px}
.stars svg{width:16px;height:16px;color:#ffb020}
.price-box{background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius-md);padding:18px 20px;margin-bottom:20px}
.price-box .label{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);font-weight:700;margin-bottom:4px}
.price-box .amount{font-family:var(--ff-mono);font-size:28px;font-weight:800;color:var(--price); word-wrap:break-word}
.action-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.quick-specs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:22px}
.quick-spec{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:11px 14px; min-width:0}
.quick-spec .qs-label{font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.03em}
.quick-spec .qs-value{font-family:var(--ff-mono);font-size:13.5px;font-weight:700;margin-top:2px; word-wrap:break-word}
.share-row{display:flex;align-items:center;gap:10px; flex-wrap:wrap}
.share-row span{font-size:13px;color:var(--text-faint)}

@media (max-width:768px){
  .phone-hero{padding:28px 0}
  .phone-gallery{padding:24px; min-height:220px}
  .phone-gallery img{max-height:300px}
  .phone-info h1{font-size:clamp(22px,5vw,30px)}
  .price-box{padding:14px 16px}
  .price-box .amount{font-size:24px}
  .quick-specs{gap:8px}
  .quick-spec{padding:10px 12px}
  .quick-spec .qs-value{font-size:12.5px}
}
@media (max-width:480px){
  .phone-hero{padding:20px 0; gap:18px}
  .phone-gallery{padding:18px; min-height:180px; border-radius:var(--radius-md)}
  .phone-gallery img{max-height:220px}
  .phone-info .brand-tag{font-size:12px}
  .phone-info h1{font-size:clamp(20px,6vw,26px); margin-bottom:8px}
  .rating-row{gap:8px; margin-bottom:14px}
  .stars svg{width:14px; height:14px}
  .price-box{padding:12px 14px; margin-bottom:16px}
  .price-box .amount{font-size:22px}
  .action-row{gap:8px; margin-bottom:18px}
  .action-row .btn{padding:9px 16px; font-size:13px}
  .quick-specs{grid-template-columns:1fr; gap:6px; margin-bottom:18px}
  .quick-spec{padding:9px 12px}
  .quick-spec .qs-value{font-size:12px}
  .share-row{gap:8px}
}

.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin:46px 0 0;overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none}
.tabs::-webkit-scrollbar{display:none}
.tab-btn{padding:14px 18px;font-weight:700;font-size:14.5px;color:var(--text-faint);border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none; flex-shrink:0}
.tab-btn.active{color:var(--accent);border-color:var(--accent)}
.tab-panel{display:none;padding:30px 0}
.tab-panel.active{display:block}

@media (max-width:768px){
  .tabs{margin:32px 0 0}
  .tab-btn{padding:12px 14px; font-size:14px}
  .tab-panel{padding:22px 0}
}
@media (max-width:480px){
  .tabs{margin:24px 0 0}
  .tab-btn{padding:10px 12px; font-size:13px}
  .tab-panel{padding:18px 0}
}

.spec-table{width:100%;border-collapse:collapse; display:block; overflow-x:auto; white-space:nowrap}
.spec-table tbody, .spec-table thead{display:table; width:100%; min-width:500px}
.spec-table tr{border-bottom:1px solid var(--border)}
.spec-table td{padding:13px 8px;font-size:14.5px}
.spec-table td:first-child{color:var(--text-faint);width:38%;font-weight:600}
.spec-table td:last-child{font-family:var(--ff-mono);font-weight:600}

@media (max-width:480px){
  .spec-table td{padding:10px 6px; font-size:13.5px}
  .spec-table td:first-child{width:45%}
}

.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:600px){.pros-cons{grid-template-columns:1fr}}
.pc-box{border-radius:var(--radius-md);padding:20px;border:1px solid var(--border)}
.pc-box.pros{background:rgba(0,166,81,.06);border-color:rgba(0,166,81,.3)}
.pc-box.cons{background:rgba(224,71,60,.06);border-color:rgba(224,71,60,.3)}
.pc-box h4{display:flex;align-items:center;gap:8px;font-size:15px}
.pc-box ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:14px;margin-top:10px}
.pc-box li{display:flex;gap:8px;align-items:flex-start}
.pc-box li svg{width:15px;height:15px;flex-shrink:0;margin-top:2px}
.pc-box.pros li svg{color:var(--accent)}
.pc-box.cons li svg{color:var(--danger)}

@media (max-width:480px){
  .pc-box{padding:16px}
  .pc-box h4{font-size:14px}
  .pc-box ul{gap:6px; font-size:13px}
  .pc-box li svg{width:14px; height:14px}
}

.faq-item{border-bottom:1px solid var(--border)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 4px;cursor:pointer;font-weight:700;font-size:15px; gap:12px}
.faq-q svg{width:18px;height:18px;color:var(--text-faint);transition:.2s;flex-shrink:0}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-a{padding:0 4px 0;max-height:0;overflow:hidden;color:var(--text-dim);font-size:14.5px;transition:.25s}
.faq-item.open .faq-a{padding-bottom:18px;max-height:400px}

@media (max-width:480px){
  .faq-q{padding:14px 4px; font-size:14px}
  .faq-a{font-size:13.5px}
  .faq-item.open .faq-a{padding-bottom:14px; max-height:500px}
}

.review-item{border:1px solid var(--border);border-radius:var(--radius-md);padding:18px;margin-bottom:14px;background:var(--bg-elev)}
.review-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px; gap:10px; flex-wrap:wrap}
.review-author{font-weight:700;font-size:14px}
.review-city{font-size:12px;color:var(--text-faint)}
.review-title{font-weight:700;font-size:14.5px;margin-bottom:4px}
.review-body{font-size:14px;color:var(--text-dim)}

@media (max-width:480px){
  .review-item{padding:14px; margin-bottom:10px}
  .review-author{font-size:13px}
  .review-title{font-size:13.5px}
  .review-body{font-size:13px}
}

/* ---------- Compare ---------- */
.compare-slots{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:32px}
.compare-slot{border:2px dashed var(--border);border-radius:var(--radius-md);min-height:160px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:10px;padding:18px;text-align:center;cursor:pointer;position:relative;background:var(--bg-elev); min-width:0}
.compare-slot.filled{border-style:solid;align-items:stretch;justify-content:flex-start;cursor:default}
.compare-slot.filled img{height:70px;object-fit:contain;margin:0 auto; max-width:100%}
.compare-slot .remove{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:var(--surface);
  display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px}
.compare-table-wrap{overflow-x:auto; -webkit-overflow-scrolling:touch}
.compare-table{width:100%;border-collapse:collapse;min-width:600px}
.compare-table th,.compare-table td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;font-size:14px}
.compare-table th{font-family:var(--ff-display);background:var(--surface);position:sticky;top:0}
.compare-table td:first-child,.compare-table th:first-child{color:var(--text-faint);font-weight:600;white-space:nowrap}

@media (max-width:768px){
  .compare-slots{grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:12px}
  .compare-slot{min-height:140px; padding:14px}
  .compare-table th,.compare-table td{padding:10px 12px; font-size:13px}
}
@media (max-width:480px){
  .compare-slots{grid-template-columns:1fr; gap:10px}
  .compare-slot{min-height:120px; padding:12px}
  .compare-table th,.compare-table td{padding:8px 10px; font-size:12.5px}
  .compare-table{min-width:480px}
}

/* ---------- Dealer / Repair Card ---------- */
.dealer-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-md);padding:22px; min-width:0}
.dealer-card .dealer-top{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px;align-items:flex-start}
.dealer-card h3{font-size:17px;margin-bottom:2px; word-wrap:break-word}
.dealer-meta{font-size:13px;color:var(--text-faint);margin-bottom:12px}
.verified-badge{display:inline-flex;align-items:center;gap:4px;background:var(--accent-soft);color:var(--accent);font-size:11px;
  font-weight:700;padding:3px 9px;border-radius:999px; white-space:nowrap}
.dealer-specialties{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0}
.dealer-actions{display:flex;gap:8px;margin-top:14px; flex-wrap:wrap}

@media (max-width:480px){
  .dealer-card{padding:16px}
  .dealer-card h3{font-size:15px}
  .dealer-meta{font-size:12px}
  .dealer-actions .btn{padding:8px 14px; font-size:12.5px}
}

/* ---------- Article / Guide / News card ---------- */
.article-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column; min-width:0}
.article-card .am{aspect-ratio:16/9;background:var(--surface);overflow:hidden; min-height:160px}
.article-card .am img{width:100%;height:100%;object-fit:cover}
.article-card .ab{padding:18px;display:flex;flex-direction:column;gap:8px;flex:1; min-width:0}
.article-cat{font-family:var(--ff-mono);font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.04em}
.article-card h3{font-size:17px;line-height:1.35; word-wrap:break-word}
.article-card p{font-size:14px;color:var(--text-dim);margin:0;flex:1}
.article-date{font-size:12px;color:var(--text-faint);margin-top:auto}

@media (max-width:480px){
  .article-card .am{min-height:140px}
  .article-card .ab{padding:14px; gap:6px}
  .article-card h3{font-size:15px}
  .article-card p{font-size:13px}
  .article-cat{font-size:10px}
  .article-date{font-size:11px}
}

.article-detail{max-width:740px;margin:0 auto; padding:0 16px}
.article-detail h1{font-size:clamp(24px,4vw,36px); word-wrap:break-word}
.article-detail .meta{display:flex;gap:14px;color:var(--text-faint);font-size:13.5px;margin-bottom:24px; flex-wrap:wrap}
.article-detail .cover{border-radius:var(--radius-lg);overflow:hidden;margin-bottom:28px;aspect-ratio:16/9;background:var(--surface); min-height:180px}
.article-detail .cover img{width:100%;height:100%;object-fit:cover}
.article-body{font-size:16.5px;line-height:1.8;color:var(--text)}
.article-body p{margin-bottom:1.2em}

@media (max-width:768px){
  .article-detail h1{font-size:clamp(22px,5vw,30px)}
  .article-body{font-size:15px}
}
@media (max-width:480px){
  .article-detail{padding:0 12px}
  .article-detail h1{font-size:clamp(20px,6vw,26px)}
  .article-detail .meta{font-size:12px; gap:10px; margin-bottom:18px}
  .article-detail .cover{border-radius:var(--radius-md); min-height:140px; margin-bottom:20px}
  .article-body{font-size:14.5px; line-height:1.7}
}

/* ---------- Generic content / static pages ---------- */
.prose{max-width:760px; margin:0 auto; padding:0 16px}
.prose h2{margin-top:1.6em}
.prose ul{margin:1em 0 1.4em 1.4em;list-style:disc}
.prose li{margin-bottom:.5em}

@media (max-width:480px){
  .prose{padding:0 12px}
  .prose h2{font-size:clamp(18px,5vw,22px)}
}

/* ---------- Contact form ---------- */
.form-grid{display:grid;gap:16px;max-width:560px; width:100%}
.form-field label{display:block;font-size:13px;font-weight:700;margin-bottom:6px}
.form-field input,.form-field textarea,.form-field select{width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--border);
  background:var(--bg-elev);color:var(--text);font-family:inherit;font-size:14.5px; min-width:0}
.form-field textarea{resize:vertical;min-height:120px}
.form-success{display:none;background:var(--accent-soft);border:1px solid var(--accent);border-radius:10px;padding:14px 16px;font-size:14px;margin-top:10px}
.form-success.show{display:block}

@media (max-width:480px){
  .form-field input,.form-field textarea,.form-field select{padding:10px 12px; font-size:14px}
  .form-field textarea{min-height:100px}
}

/* ---------- Footer ---------- */
.site-footer{background:var(--bg-elev);border-top:1px solid var(--border);padding:54px 0 24px;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:30px;margin-bottom:40px}
@media (max-width:880px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr; gap:24px; margin-bottom:30px}}
.footer-grid h4{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);margin-bottom:14px}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-grid a{font-size:14px;color:var(--text-dim)}
.footer-grid a:hover{color:var(--accent)}
.footer-about p{color:var(--text-dim);font-size:14px;max-width:280px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding-top:24px;
  border-top:1px solid var(--border);font-size:13px;color:var(--text-faint)}
.social-row{display:flex;gap:8px; flex-wrap:wrap}

@media (max-width:480px){
  .site-footer{padding:36px 0 20px; margin-top:40px}
  .footer-grid h4{font-size:12px}
  .footer-grid a{font-size:13px}
  .footer-about p{font-size:13px}
  .footer-bottom{flex-direction:column; text-align:center; gap:8px; padding-top:18px}
}

/* ---------- Empty states ---------- */
.empty-state{text-align:center;padding:70px 20px;color:var(--text-faint)}
.empty-state svg{width:48px;height:48px;margin-bottom:16px;opacity:.5}
.empty-state h3{color:var(--text);margin-bottom:6px}

@media (max-width:480px){
  .empty-state{padding:50px 16px}
  .empty-state svg{width:40px; height:40px}
  .empty-state h3{font-size:16px}
}

/* ---------- 404 ---------- */
.error-page{text-align:center;padding:100px 20px;max-width:560px;margin:0 auto}
.error-page .code{font-family:var(--ff-mono);font-size:clamp(70px,14vw,130px);font-weight:800;color:var(--accent);line-height:1}

@media (max-width:480px){
  .error-page{padding:60px 16px}
}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--text);color:var(--bg);
  padding:12px 22px;border-radius:999px;font-size:14px;font-weight:600;opacity:0;pointer-events:none;transition:.25s;z-index:999;box-shadow:var(--shadow-lg); max-width:90vw; text-align:center; white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media (max-width:480px){
  .toast{padding:10px 18px; font-size:13px; bottom:16px}
}

/* ---------- Skeleton loading ---------- */
.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--border) 37%,var(--surface) 63%);background-size:400% 100%;
  animation:skeletonShine 1.4s ease infinite;border-radius:var(--radius-md)}
@keyframes skeletonShine{0%{background-position:100% 50%}100%{background-position:0 50%}}
.skel-card{height:330px}

@media (max-width:480px){
  .skel-card{height:280px}
}

/* ---------- Compare button float on phone cards ---------- */
.add-compare{position:absolute;top:10px;right:50px;width:34px;height:34px;border-radius:50%;background:var(--glass-bg);
  border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(6px);z-index:2}
.add-compare svg{width:15px;height:15px;color:var(--text-dim)}
.add-compare.active{background:var(--accent);border-color:var(--accent)}
.add-compare.active svg{color:#04130b}

@media (max-width:480px){
  .add-compare{width:30px; height:30px; top:8px; right:44px}
  .add-compare svg{width:13px; height:13px}
}

/* utility */
.mt-0{margin-top:0}.flex{display:flex}.gap-8{gap:8px}.items-center{align-items:center}
.text-faint{color:var(--text-faint)}
.center{text-align:center}

/* Additional responsive utilities */
.hide-mobile{display:block}
.show-mobile{display:none}
@media (max-width:768px){
  .hide-mobile{display:none !important}
  .show-mobile{display:block !important}
}
@media (max-width:480px){
  .hide-mobile-sm{display:none !important}
  .show-mobile-sm{display:block !important}
}

/* Touch-friendly tap targets on mobile */
@media (pointer: coarse) {
  .nav-links a, .filter-chip, .tab-btn, .faq-q, .btn, .icon-btn, .fav-btn, .add-compare {
    min-height: 44px;
  }
  .nav-links a{padding:12px 14px}
  .tab-btn{padding:16px 18px}
  .faq-q{padding:20px 4px}
}