
    /* ===== Base & Tokens (single :root) ===== */
:root{
  --brand:#4a0073;
  --accent:#ff007f;
  --ink:#222;
  --muted:#777;
  --deal:#c62828;
  --border:#e9e9e9;
  --fba-blue:#146eb4;
  --fba-orange:#ff9900;
  --ring: color-mix(in oklab, var(--brand) 70%, white);
}

/* Reset-ish */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;color:var(--ink)}
a{color:inherit}
.sr-only{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}

/* ===== Top Bar ===== */
.top-bar{background:#4a0073;color:#fff;font-size:14px;text-align:center;padding:8px 12px;position:relative}
.top-bar .close{position:absolute;right:12px;top:8px;background:transparent;border:none;color:#fff;font-weight:700;cursor:pointer}

/* ===== Header ===== */
.header{border-bottom:1px solid #e6e6e6;background:#fff}
.header-inner{max-width:90%;margin:0 auto;display:grid;grid-template-columns:220px 1fr 320px;gap:20px;align-items:center;padding:18px 16px}
.logo{display:flex;gap:12px;align-items:center;text-decoration:none;color:inherit}
.logo-badge{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#5b0aa6,#2f0066);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;box-shadow:0 2px 6px rgba(0,0,0,.08)}
.logo-text{font-weight:700;font-size:18px;letter-spacing:.2px}

.search{display:flex;align-items:center;gap:10px}
.search-form{display:flex;align-items:center;width:75%;background:#f6f6f6;border-radius:40px;padding:8px 12px;border:1px solid #eee}
.search input[type="search"]{border:0;outline:0;background:transparent;font-size:15px;width:100%}
.search button{background:#4a0073;color:#fff;border:0;padding:8px 12px;border-radius:30px;cursor:pointer;display:flex;align-items:center;justify-content:center}

.nav-row{display:flex;gap:18px;margin-top:10px;font-size:14px;color:#333}
.nav-row a{text-decoration:none;color:inherit;padding:6px 0}

.actions{display:flex;gap:12px;align-items:center;justify-content:flex-end}
.action-item{display:flex;gap:8px;align-items:center;font-size:14px;color:#444;text-decoration:none}
.action-icon{width:22px;height:22px;display:inline-block}
.deals-pill{background:#ff007f;color:#fff;padding:6px 12px;border-radius:20px;font-weight:600;font-size:14px;box-shadow:0 2px 6px rgba(255,0,127,.12)}

@media (max-width:900px){
  .header-inner{grid-template-columns:1fr;gap:10px;padding:12px}
  .search{order:3}
  .nav-row{order:2;flex-wrap:wrap;gap:10px}
  .actions{order:1;justify-content:flex-start;gap:10px}
  .logo{order:4}
}

/* ===== Info Bar ===== */
.info-bar{background:#f8f8f8;border-top:2px solid #0066cc;padding:8px 0;font-size:14px;color:#222}
.info-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px;padding:0 20px}
.info-item{display:flex;align-items:center;gap:8px;text-align:left;min-width:200px}
.info-icon{width:24px;height:24px;object-fit:contain}
.trustpilot-icon{width:80px}
.paypal-icon{width:60px}
@media (max-width:768px){
  .info-container{flex-direction:column;align-items:flex-start}
  .info-item{width:100%}
}

/* ===== Hero Slider ===== */
.hero-slider{position:relative;width:90%;margin:30px auto;border-radius:28px;overflow:hidden;color:#fff;box-shadow:0 10px 25px rgba(0,0,0,.15)}
.slides{display:flex;width:300%;transition:transform .6s ease}
.slide{position:relative;width:100%;flex-shrink:0}
.slide img{width:100%;height:60vh;min-height:380px;object-fit:cover;vertical-align:middle;filter:brightness(.7)}
.caption{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;background:rgba(0,0,0,.45);padding:20px 30px;border-radius:16px;max-width:80%}
.caption h2{font-size:clamp(24px,4vw,40px);margin-bottom:8px}
.caption p{font-size:clamp(14px,1.5vw,18px);margin-bottom:12px}
.btn{display:inline-block;background:#4a0073;color:#fff;padding:10px 22px;border-radius:25px;text-decoration:none;font-weight:600;transition:background .2s}
.btn:hover{background:#350052}
.nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.4);border:none;color:#fff;font-size:28px;width:44px;height:44px;cursor:pointer;border-radius:50%;transition:background .2s;z-index:2}
.nav:hover{background:rgba(0,0,0,.6)}
.prev{left:12px}
.next{right:12px}
@media (max-width:768px){
  .hero-slider{border-radius:16px}
  .caption{width:90%;padding:16px}
  .caption h2{font-size:22px}
}

/* ===== Category (round images + pill) ===== */
.cats-min{padding:40px 0}
.cats-min__wrap{max-width:80%;margin:0 auto}
.cats-min h2{text-align:center;font:800 clamp(20px,3vw,30px)/1.2 system-ui;color:var(--ink);margin:0 0 22px}
.cats-min__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:clamp(14px,2.6vw,28px);list-style:none;padding:0;margin:0;align-items:start}
.cat{display:grid;justify-items:center;text-decoration:none;color:var(--ink);gap:10px;transition:transform .15s ease}
.cat:focus-visible{outline:none}
.cat:focus-visible span{box-shadow:0 0 0 3px var(--ring)}
.cat img{width:165px;height:165px;border-radius:20%;border:2px solid #fff;padding:14px;background:#fff;object-fit:contain;transition:transform .15s ease,border-color .15s ease,opacity .15s ease}
.cat span{display:inline-block;font:700 14px/1 system-ui;color:var(--ink);padding:8px 14px;border-radius:999px;border:1px solid #e8e8e8;background:#fff;transition:border-color .15s ease,color .15s ease,background .15s ease,transform .15s ease}
.cat:hover img{transform:scale(1.04);border-color:var(--ring)}
.cat:hover span{border-color:var(--brand);color:var(--brand);transform:translateY(-1px)}
@media (max-width:520px){
  .cat img{width:92px;height:92px;padding:10px}
  .cat span{font-weight:700;font-size:13px;padding:7px 12px}
}

/* ===== Top Picks ===== */
.top-picks{padding:50px 0 30px}
.tp-wrap{max-width:90%;margin:0 auto}
#top-picks-title{text-align:center;font:800 clamp(22px,3vw,32px)/1.2 system-ui;color:var(--ink);margin-bottom:10px}
.tp-head{text-align:center;margin-bottom:25px}
.tp-viewall{text-decoration:none;color:var(--brand);font-weight:700}
.tp-viewall:hover{text-decoration:underline}
.tp-grid{list-style:none;margin:0;padding:0;display:grid;gap:20px;grid-template-columns:repeat(5,1fr)}
.tp-card{border:1px solid var(--border);border-radius:14px;background:#fff;padding:16px;transition:box-shadow .2s ease,transform .2s ease;display:flex;flex-direction:column;gap:10px}
.tp-card:hover{box-shadow:0 8px 20px rgba(0,0,0,.08);transform:translateY(-2px)}
.tp-media{display:block;aspect-ratio:4/3;background:#f8f8f8;border-radius:10px;overflow:hidden}
.tp-media img{width:100%;height:100%;object-fit:contain}
.tp-title{color:var(--ink);font-weight:600;line-height:1.4;text-decoration:none;font-size:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tp-title:hover{text-decoration:underline}
.tp-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.tp-stars{display:flex;gap:3px}
.star{width:14px;height:14px;background:#f5a623;-webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 17.3l6.18 3.73-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.76-1.64 7.03L12 17.3z"/></svg>') no-repeat center/contain;mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 17.3l6.18 3.73-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.76-1.64 7.03L12 17.3z"/></svg>') no-repeat center/contain}
.star.half{background:linear-gradient(90deg,#f5a623 50%,#ddd 50%)}
.star.empty{background:#ddd}
.tp-fba{display:inline-flex;align-items:center;gap:5px;font-size:12px;white-space:nowrap}
.tp-fba strong{color:var(--muted);font-weight:700}
.tp-fba span{color:var(--fba-blue);font-weight:800}
.fba-smile{width:36px;height:10px}
.fba-smile path{stroke:var(--fba-orange)}
.tp-price{margin-top:auto}
.tp-was{font-size:12px;color:var(--muted)}
.tp-was b{color:var(--deal);margin-left:4px;text-transform:uppercase}
.tp-now{font-weight:800;font-size:20px;color:var(--ink);margin-top:2px}
@media (max-width:1200px){.tp-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:768px){.tp-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.tp-grid{grid-template-columns:1fr}}

/* ===== Three Promo Banners ===== */
.three-banners{padding:32px 0}
.three-banners__wrap{max-width:90%;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.promo{position:relative;display:block;overflow:hidden;border-radius:18px;background:#f6f6f6;box-shadow:0 6px 16px rgba(0,0,0,.05);transition:transform .18s ease,box-shadow .18s ease}
.promo:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.10)}
.promo img{width:100%;height:clamp(180px,30vw,250px);object-fit:cover;object-position:center}
.promo__label{position:absolute;left:14px;bottom:14px;background:rgba(255,255,255,.9);color:var(--ink);font-weight:700;font-size:14px;padding:8px 14px;border-radius:999px;border:1px solid rgba(0,0,0,.05);backdrop-filter:blur(4px)}
@media (max-width:1024px){.three-banners__wrap{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.three-banners__wrap{grid-template-columns:1fr}.promo img{height:clamp(160px,45vw,220px)}}

/* ===== Brands ===== */
.brands{padding:36px 0 24px}
.brands__wrap{max-width:90%;margin:0 auto}
#brands-title{text-align:center;font:800 clamp(20px,3vw,28px)/1.2 system-ui;color:var(--ink);margin:0 0 18px}
.brands__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:22px;list-style:none;padding:0;margin:0;align-items:center}
.brand{display:grid;place-items:center;background:#fff;border:1px solid #eee;border-radius:14px;height:84px;padding:8px 12px;text-decoration:none;transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}
.brand:hover{border-color:color-mix(in oklab, var(--brand) 35%, #eee);box-shadow:0 10px 24px rgba(0,0,0,.06);transform:translateY(-2px)}
.brand img{max-width:140px;max-height:42px;width:auto;height:auto;object-fit:contain;filter:grayscale(20%) contrast(1.05);transition:filter .18s ease}
.brand:hover img{filter:none}
@media (max-width:1200px){.brands__grid{grid-template-columns:repeat(5,1fr)}}
@media (max-width:960px){.brands__grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:720px){.brands__grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.brands__grid{grid-template-columns:repeat(2,1fr)}}

/* ===== Event Banner ===== */
.event-banner{max-width:90%;margin:30px auto;border-radius:14px;overflow:hidden;position:relative}
.event-banner__link{display:flex;align-items:center;justify-content:center;position:relative;text-decoration:none;color:#fff;background:#000;border-radius:14px;overflow:hidden}
.event-banner__link img{width:100%;height:100%;object-fit:cover;opacity:.25;transition:opacity .3s ease}
.event-banner__link:hover img{opacity:.35}
.event-banner__text{position:absolute;text-align:center;font-size:clamp(16px,2vw,20px);font-weight:500;color:#fff;z-index:2;padding:14px 18px;line-height:1.4}
.event-banner__text span{color:var(--accent);font-weight:700}
@media (max-width:768px){.event-banner__text{font-size:15px;padding:10px 12px}}

/* ===== Category-wise Products (Tabs + Grid) ===== */
.cat-products{padding:42px 0 30px}
.cp-wrap{max-width:90%;margin:0 auto}
#cat-products-title{text-align:center;font:800 clamp(22px,3vw,32px)/1.2 system-ui;color:var(--ink);margin:0 0 14px}
.cp-tabs{display:flex;justify-content:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.cp-tab{appearance:none;border:1px solid var(--border);background:#fff;color:var(--ink);padding:8px 14px;border-radius:999px;font-weight:700;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,transform .15s ease}
.cp-tab:hover{border-color:color-mix(in oklab, var(--brand) 40%, var(--border));transform:translateY(-1px)}
.cp-tab.is-active{background:var(--brand);color:#fff;border-color:var(--brand)}
.cp-tab:focus-visible{outline:3px solid color-mix(in oklab, var(--brand) 60%, #fff);outline-offset:2px}
.cp-panels{position:relative}
.cp-panel[hidden]{display:none}
.cp-panel.is-active{display:block}

/* ===== Blogs ===== */
.blogs{padding:50px 0;background:#fafafa}
.blogs-wrap{max-width:90%;margin:0 auto}
#blogs-title{text-align:center;font:800 clamp(22px,3vw,32px)/1.2 system-ui;color:var(--ink);margin:0 0 25px}
.blog-grid{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:0;margin:0}
.blog-card{background:#fff;border-radius:14px;border:1px solid var(--border);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .3s ease,transform .2s ease}
.blog-card:hover{box-shadow:0 10px 25px rgba(0,0,0,.07);transform:translateY(-4px)}
.blog-thumb img{width:100%;height:220px;object-fit:cover}
.blog-body{padding:18px 16px 20px;flex-grow:1}
.blog-body h3{margin:0 0 8px;font-size:18px;line-height:1.4}
.blog-body h3 a{color:var(--ink);text-decoration:none}
.blog-body h3 a:hover{color:var(--brand);text-decoration:underline}
.blog-body p{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:14px}
.blog-read{color:var(--brand);font-weight:600;text-decoration:none;font-size:14px;transition:color .2s ease}
.blog-read:hover{color:color-mix(in oklab, var(--brand) 60%, black);text-decoration:underline}
@media (max-width:992px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.blog-grid{grid-template-columns:1fr}.blog-thumb img{height:200px}}

/* ===== Long Content ===== */
.long-content{background:#fff;padding:50px 0}
.lc-wrap{max-width:90%;margin:0 auto;line-height:1.7;font-size:15px}
.long-content h2{font:800 clamp(24px,3.5vw,34px)/1.2 system-ui;text-align:center;margin-bottom:22px;color:var(--brand)}
.long-content h3{margin-top:24px;margin-bottom:8px;font:700 18px/1.3 system-ui;color:var(--ink)}
.long-content p{margin-bottom:16px}
.long-content strong{color:var(--brand)}
@media(max-width:768px){.lc-wrap{font-size:14px}}

/* ===== Why LaptopsEra ===== */
.why-le{padding:40px 0}
.why-le__wrap{max-width:90%;margin:0 auto}
#why-le-title{text-align:center;font:800 clamp(22px,3vw,32px)/1.2 system-ui;color:var(--ink);margin:0 0 22px}
.why-le__grid{list-style:none;margin:0;padding:0;display:grid;gap:18px;grid-template-columns:repeat(3,1fr)}
.why-card{background:#fff;border:1px solid #eaeaea;border-radius:16px;padding:18px;display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:start;transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}
.why-card:hover{border-color:color-mix(in oklab, var(--brand) 40%, #eaeaea);box-shadow:0 10px 24px rgba(0,0,0,.06);transform:translateY(-2px)}
.why-ico{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;color:var(--brand);background:#faf7ff;border:1px solid color-mix(in oklab, var(--brand) 25%, white)}
.why-ico svg{width:26px;height:26px}
.why-card h3{margin:0;font:700 16px/1.2 system-ui;color:var(--ink)}
.why-card p{grid-column:1/-1;margin:6px 0 0;color:#6f6f6f;font-size:14px;line-height:1.5}
@media (max-width:980px){.why-le__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){
  .why-le__grid{grid-template-columns:1fr}
  .why-card{grid-template-columns:40px 1fr}
  .why-ico{width:40px;height:40px;border-radius:10px}
  .why-ico svg{width:22px;height:22px}
}

/* ===== Footer ===== */
.site-footer{background:#24343b;color:#fff;font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;font-size:14px;line-height:1.6}
.footer-top{text-align:center;padding:40px 20px 30px;border-bottom:1px solid rgba(255,255,255,.15)}
.footer-top h2{font-size:20px;margin:0;font-weight:700}
.footer-top p{margin:6px 0 14px;color:rgba(255,255,255,.8)}
.join-btn{display:inline-block;background:#fff;color:#4a0073;padding:10px 28px;border-radius:50px;font-weight:600;text-decoration:none;transition:.3s ease}
.join-btn:hover{background:#4a0073;color:#fff}
.footer-main{padding:40px 10% 30px;border-bottom:1px solid rgba(255,255,255,.15)}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.footer-col h4{font-size:15px;font-weight:700;margin-bottom:10px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin:6px 0}
.footer-col a{color:rgba(255,255,255,.85);text-decoration:none;transition:color .2s ease}
.footer-col a:hover{color:#fff}
.footer-bottom{text-align:center;padding:24px 5%}
.footer-links{margin-bottom:12px}
.footer-links a{color:rgba(255,255,255,.85);text-decoration:none;margin:0 4px;font-size:13px}
.footer-links a:hover{color:#fff}
.footer-links span{color:rgba(255,255,255,.4)}
.social-icons{margin:12px 0}
.social-icons a{color:#fff;margin:0 6px;font-size:16px;text-decoration:none;transition:opacity .2s ease}
.social-icons a:hover{opacity:.8}
.legal{color:rgba(255,255,255,.6);font-size:12px;margin-top:10px;max-width:800px;margin-left:auto;margin-right:auto}
@media (max-width:900px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr;text-align:center}
  .footer-main{padding:30px 6%}
}

/* ===== Performance: render later hints for below-the-fold ===== */
.cats-min,
.top-picks,
.three-banners,
.brands,
.event-banner,
.cat-products,
.blogs,
.long-content,
.why-le,
.site-footer {
  content-visibility: auto;
  contain-intrinsic-size: 800px 1000px; /* adjust per section if you want */
}

/* ====== Scoped styles for Products Section ====== */
.plp-pro{ --bg:#f5f7fb; background:var(--bg); padding:32px 0; }
.plp-pro__wrap{ max-width:1200px; margin:0 auto; padding:0 16px; display:grid; grid-template-columns:320px 1fr; gap:20px; }
@media (max-width:1024px){ .plp-pro__wrap{ grid-template-columns:1fr; } }

/* Sidebar */
.plp-pro__filters{ position:sticky; top:12px; align-self:start; background:#fff; border:1px solid var(--border); border-radius:16px; padding:16px; box-shadow:0 10px 25px rgba(0,0,0,.06); }
.plp-pro__filters-title{ font:800 16px/1.2 system-ui; color:var(--ink); margin-bottom:8px; }
.plp-acc{ border-top:1px dashed var(--border); }
.plp-acc:first-of-type{ border-top:0; }
.plp-acc__head{ list-style:none; cursor:pointer; padding:14px 6px; font-weight:800; color:#283442; display:flex; align-items:center; gap:8px; position:relative; }
.plp-acc__head::-webkit-details-marker{ display:none; }
.plp-acc__head::before{ content:"+"; color:#8a93a4; font-weight:900; width:18px; text-align:center; }
.plp-acc[open] .plp-acc__head::before{ content:"–"; }
.plp-acc__body{ padding:0 0 14px 6px; display:flex; flex-wrap:wrap; gap:8px; }
.plp-chip{ display:inline-flex; align-items:center; gap:8px; font-size:13px; color:#2d3748; padding:8px 12px; border:1px solid var(--border); border-radius:999px; background:#fff; transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease; }
.plp-chip input{ accent-color:var(--brand); }
.plp-chip:hover{ transform:translateY(-1px); border-color:color-mix(in oklab,var(--brand) 35%, var(--border)); box-shadow:0 6px 14px rgba(0,0,0,.06); }
.plp-clear{ width:100%; margin-top:6px; border:1px dashed var(--border); background:#fff; border-radius:12px; padding:10px 12px; cursor:pointer; font-weight:700; color:#555; }
.plp-clear:hover{ border-color:var(--brand); color:var(--brand); }

/* Header + Toolbar */
.plp-breadcrumb ol{ list-style:none; display:flex; gap:10px; padding:0; margin:0 0 8px; color:#6b7280; font-size:13px; }
.plp-breadcrumb a{ color:inherit; text-decoration:none; }
.plp-breadcrumb li+li::before{ content:"/"; color:#c3c7ce; margin-right:8px; }
.plp-heading{ margin:2px 0 6px; font:800 clamp(22px,3.4vw,36px)/1.15 system-ui; color:var(--ink); }
.plp-heading span{ background: linear-gradient(90deg, color-mix(in oklab, var(--brand) 85%, #000), var(--accent)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.plp-intro{ color:#4b5563; max-width:70ch; margin-bottom:10px; }
.plp-link{ color:var(--brand); font-weight:800; text-decoration:none; }

.plp-toolbar{ display:grid; grid-template-columns: 220px 1fr 180px auto; gap:12px; align-items:center; background:#fff; border:1px solid var(--border); border-radius:14px; padding:10px 12px; box-shadow:0 8px 18px rgba(0,0,0,.04); }
@media (max-width:900px){ .plp-toolbar{ grid-template-columns:1fr 1fr; } }
.plp-field{ display:grid; gap:6px; font-size:12px; color:#6b7280; }
.plp-field select{ padding:10px 12px; border-radius:10px; border:1px solid var(--border); background:#fff; color:var(--ink); }
.plp-search{ display:flex; align-items:center; gap:8px; border:1px solid var(--border); border-radius:999px; padding:6px 8px; }
.plp-search input{ border:0; outline:0; padding:6px 8px; width:100%; background:transparent; }
.plp-search button{ border:0; background:var(--brand); color:#fff; width:36px; height:36px; border-radius:999px; cursor:pointer; }
.plp-count{ justify-self:end; font-weight:700; color:#374151; white-space:nowrap; }

/* Cards Grid */
.plp-grid{ list-style:none; padding:0; margin:14px 0; display:grid; gap:16px; }
.plp-card{
  position:relative;
  display:grid; grid-template-columns: 280px 1fr 260px; gap:0;
  background:#fff; border:1px solid var(--border); border-radius:18px; overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.05);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.plp-card::after{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:linear-gradient(90deg, var(--brand), var(--accent)); opacity:.16; }
.plp-card:hover{ transform:translateY(-2px); border-color:color-mix(in oklab,var(--brand) 35%, var(--border)); box-shadow:0 16px 36px rgba(0,0,0,.08); }
@media (max-width:1024px){ .plp-card{ grid-template-columns: 220px 1fr; } }
@media (max-width:760px){ .plp-card{ grid-template-columns: 1fr; } }

/* Media */
.plp-media{ position:relative; display:grid; place-items:center; padding:16px; background:linear-gradient(180deg,#f8fafc,#f3f4f6); }
.plp-media img{ width:100%; height:auto; object-fit:contain; transition:transform .25s ease; }
.plp-card:hover .plp-media img{ transform:scale(1.02); }
.plp-sticker{ position:absolute; top:12px; left:12px; font-size:12px; font-weight:900; letter-spacing:.2px; padding:6px 10px; border-radius:999px; color:#fff; background:#0b4da2; box-shadow:0 6px 14px rgba(11,77,162,.25); }

/* Info */
.plp-info{ border-left:1px solid var(--border); padding:16px; display:grid; gap:8px; }
@media (max-width:760px){ .plp-info{ border-left:0; } }
.plp-title{ font:700 18px/1.25 system-ui; color:#0f172a; }
.plp-meta{ font-size:13px; color:#6b7280; }
.plp-bullets{ margin:6px 0 0; padding-left:18px; display:grid; gap:6px; color:#374151; font-size:14px; }
.plp-rating{ display:flex; align-items:center; gap:6px; margin-top:4px; }
.star{ width:16px; height:16px; display:inline-block; background:#f59e0b;
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 17.3l6.18 3.73-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.76-1.64 7.03L12 17.3z"/></svg>') no-repeat center/contain;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 17.3l6.18 3.73-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.76-1.64 7.03L12 17.3z"/></svg>') no-repeat center/contain; }
.star--half{ background:linear-gradient(90deg,#f59e0b 50%, #d1d5db 50%); }
.plp-rev{ color:#6b7280; font-size:13px; }
.plp-compare{ margin-top:6px; display:inline-flex; align-items:center; gap:8px; font-size:14px; color:#374151; }
.plp-compare input{ accent-color:var(--brand); }

/* Buy column */
.plp-buy{ padding:16px; display:grid; gap:10px; align-content:start; border-left:1px solid var(--border); }
@media (max-width:1024px){ .plp-buy{ border-top:1px solid var(--border); border-left:0; grid-column:1 / -1; } }

/* Price with SAVE badge next to price */
.plp-price{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.plp-price .now{ font:800 28px/1 system-ui; color:#0f172a; }
.plp-price .save-badge{
  font-size:12px; font-weight:900; color:#fff;
  background:linear-gradient(135deg,#0b4da2,var(--brand));
  padding:6px 10px; border-radius:999px; letter-spacing:.2px;
  box-shadow:0 8px 18px rgba(74,0,115,.22);
}
.plp-price .was{ width:100%; font-size:13px; color:#6b7280; text-decoration:line-through; }

.plp-pay-split{ font-size:13px; color:#475569; }
.plp-stock{ font-size:14px; color:#166534; display:flex; align-items:center; gap:8px; }
.plp-stock .dot{ width:9px; height:9px; border-radius:50%; background:#22c55e; display:inline-block; }
.plp-cta{
  background:linear-gradient(135deg, var(--brand), color-mix(in oklab,var(--brand) 60%, #000));
  color:#fff; border:0; padding:12px 16px; border-radius:999px; font-weight:900; cursor:pointer;
  transition: transform .12s ease, box-shadow .2s ease, filter .12s ease;
  box-shadow:0 10px 22px rgba(74,0,115,.22);
}
.plp-cta:hover{ transform:translateY(-1px); filter:brightness(.98); }

/* Pager */
.plp-pager{ display:flex; gap:8px; justify-content:flex-end; margin-top:8px; }
.page{
  min-width:40px; height:40px; padding:0 12px; border-radius:999px; border:1px solid var(--border);
  background:#fff; cursor:pointer; font-weight:800; color:#334155;
  transition:transform .12s ease, background .12s ease, border-color .12s ease;
}
.page:hover{ transform:translateY(-1px); border-color:color-mix(in oklab,var(--brand) 40%, var(--border)); }
.page.is-active{ background:#0b4da2; color:#fff; border-color:#0b4da2; }

/* Perf hint */
.plp-pro{ content-visibility:auto; contain-intrinsic-size:1200px 1600px; }

/* ===== Scoped FAQ styles (uses your :root tokens) ===== */
.faq{background:#fff;padding:42px 0}
.faq__wrap{max-width:900px;margin:0 auto;padding:0 16px}
.faq__heading{font:800 clamp(22px,3.2vw,32px)/1.15 system-ui;color:var(--ink);text-align:center}
.faq__intro{color:#666;text-align:center;margin:6px auto 18px;max-width:70ch}

.faq__list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.faq__item{border:1px solid var(--border);border-radius:14px;background:#fff;overflow:hidden;
  box-shadow:0 8px 18px rgba(0,0,0,.04)}
.faq__q{
  width:100%;text-align:left;background:#fff;border:0;cursor:pointer;
  padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;
  font:700 15px/1.3 system-ui;color:#0f172a
}
.faq__q:focus-visible{outline:3px solid var(--ring);outline-offset:2px;border-radius:12px}
.faq__chev{width:22px;height:22px;transition:transform .2s ease;color:color-mix(in oklab,var(--brand) 70%, #000)}
.faq__q[aria-expanded="true"] .faq__chev{transform:rotate(180deg)}

.faq__a{
  display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease,padding .25s ease, border-color .25s ease;
  padding:0 16px;border-top:1px dashed transparent
}
.faq__a > p{overflow:hidden;margin:0}
.faq__q[aria-expanded="true"] + .faq__a{grid-template-rows:1fr;padding:8px 16px 14px;border-color:var(--border)}

@media (prefers-reduced-motion:reduce){
  .faq__chev,.faq__a{transition:none}
}
/* ===== Scoped styles for the category rail (uses your :root tokens) ===== */
.cat-rail{background:#f5f7fb;padding:18px 0}
.cat-rail__wrap{max-width:1200px;margin:0 auto;padding:0 16px}
.cat-rail__head h2{
  font:800 clamp(20px,3vw,28px)/1.1 system-ui;color:#0f172a;display:flex;align-items:baseline;gap:8px
}
.cat-rail__count{font-weight:700;color:#6b7280;font-size:.8em}

.cat-rail__viewport{position:relative}
.cat-rail__track{
  display:flex;gap:34px;list-style:none;padding:6px 48px;margin:0;
  overflow:auto hidden;scroll-snap-type:x mandatory;scrollbar-width:none; /* FF */
}
.cat-rail__track::-webkit-scrollbar{display:none} /* WebKit */
.cat-rail__item{scroll-snap-align:center; flex:0 0 auto}
.cat-rail__tile{
  width:165px; display:grid; justify-items:center; text-align:center; gap:10px;
  text-decoration:none; color:var(--ink)
}
.cat-rail__tile img{
  width:140px; height:100px; object-fit:contain; filter:drop-shadow(0 2px 6px rgba(0,0,0,.08));
  transition:transform .18s ease
}
.cat-rail__tile:hover img{ transform:translateY(-3px) }
.cat-rail__label{
  font:700 14px/1.25 system-ui; color:#111827; display:block; min-height:2.5em
}

.cat-rail__nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:40px;height:40px;border-radius:999px;border:1px solid var(--border);
  background:#fff; color:#111; font-size:22px; line-height:1; display:grid; place-items:center;
  cursor:pointer; box-shadow:0 6px 16px rgba(0,0,0,.08);
  transition:transform .12s ease,background .12s ease,border-color .12s ease,opacity .2s ease
}
.cat-rail__nav:hover{ transform:translateY(-50%) scale(1.03); border-color:color-mix(in oklab,var(--brand) 35%, var(--border)) }
.cat-rail__nav[disabled]{opacity:.35; cursor:not-allowed}
.cat-rail__nav:first-of-type{ left:0 }
.cat-rail__nav:last-of-type{ right:0 }

@media (max-width:700px){
  .cat-rail__tile{width:140px}
  .cat-rail__tile img{width:120px;height:90px}
}