/* ═══════════════════════════════════════════════════════════════════
   PriceProwl v2 — Complete Stylesheet
   Light theme (default) + Dark theme + Mobile-first responsive
   Brand color: #ea580c (Tailwind Orange-600)
   ═══════════════════════════════════════════════════════════════════ */

/* ── Light theme ───────────────────────────────────────────────────── */
:root {
  --green:#0d9488; --green-dk:#0f766e; --green-lt:#ccfbf1; --green-mid:#99f6e4;
  --amber:#b45309; --amber-lt:#fffbeb; --amber-mid:#d97706;
  --blue:#1565C0; --blue-lt:#E3F2FD;
  --purple:#6A1B9A; --purple-lt:#F3E5F5;
  --red:#C62828; --red-lt:#FFEBEE;
  --teal:#0d9488; --teal-lt:#ccfbf1;

  --bg:#f0fdfa; --bg2:#e6faf6; --bg3:#ccfbf1;
  --surface:#FFFFFF; --surface2:#f0fdfa;
  --hero-bg:linear-gradient(135deg,#042f2e 0%,#0d4a47 55%,#021a1a 100%);
  --hero-card:rgba(255,255,255,0.08);
  --hero-hover:rgba(255,255,255,0.14);
  --hero-border:rgba(255,255,255,0.14);
  --hero-text:rgba(255,255,255,0.70);

  --border:#99f6e4; --border-dk:#5eead4;
  --text:#0d1a18; --text2:#134e4a; --text3:#0f766e; --text4:#5eead4;

  --shadow:0 1px 4px rgba(13,148,136,.10);
  --shadow-md:0 4px 16px rgba(13,148,136,.12);
  --shadow-lg:0 8px 32px rgba(13,148,136,.18);
  --shadow-card:0 2px 8px rgba(0,0,0,.06);

  --r:10px; --r-lg:16px; --r-xl:24px; --r-full:99px;
  --hdr-h:64px; --cats-h:48px; --cats-sidebar-w:220px; --max-w:1240px; --pad:16px;
  --font:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
}

/* ── Dark theme ────────────────────────────────────────────────────── */
[data-theme="dark"] {
  --bg:#021a1a; --bg2:#042f2e; --bg3:#0d4a47;
  --surface:#042f2e; --surface2:#0d4a47;
  --hero-bg:linear-gradient(135deg,#010f0f 0%,#021a1a 55%,#000a0a 100%);
  --hero-card:rgba(255,255,255,0.06);
  --hero-hover:rgba(255,255,255,0.11);
  --hero-border:rgba(255,255,255,0.09);
  --hero-text:rgba(255,255,255,0.55);

  --border:#0d4a47; --border-dk:#0f766e;
  --text:#f0fdfa; --text2:#ccfbf1; --text3:#5eead4; --text4:#2dd4bf;

  --green-lt:rgba(13,148,136,.18); --green-mid:rgba(13,148,136,.28);
  --amber-lt:rgba(180,83,9,.15);
  --blue-lt:rgba(21,101,192,.16);
  --purple-lt:rgba(106,27,154,.18);
  --red-lt:rgba(198,40,40,.16);
  --teal-lt:rgba(13,148,136,.18);

  --shadow:0 1px 4px rgba(0,0,0,.4);
  --shadow-md:0 4px 16px rgba(0,0,0,.5);
  --shadow-lg:0 8px 32px rgba(0,0,0,.6);
  --shadow-card:0 2px 8px rgba(0,0,0,.3);
}

/* ── Reset ─────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;transition:background .25s,color .25s;min-height:100vh}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
img{max-width:100%}
input,select,textarea{font-family:inherit}

/* ── Header ─────────────────────────────────────────────────────────── */
.hdr{background:var(--surface);border-bottom:1.5px solid var(--border);position:sticky;top:0;z-index:200;box-shadow:var(--shadow);transition:background .25s,border-color .25s}
.hdr-in{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad);height:var(--hdr-h);display:flex;align-items:center;gap:10px}
.logo{display:flex;align-items:center;gap:8px;font-weight:800;font-size:1.15rem;letter-spacing:-.02em;flex-shrink:0;color:var(--text)}
.logo img{width:32px;height:32px;border-radius:8px}
.logo-accent{color:var(--green)}
.logo-tag{font-size:.58rem;font-weight:700;background:var(--green);color:#fff;padding:2px 5px;border-radius:4px;margin-left:2px;vertical-align:middle;letter-spacing:.04em}
.srch{flex:1;max-width:460px;position:relative}
.srch input{width:100%;padding:9px 14px 9px 40px;border:1.5px solid var(--border-dk);border-radius:var(--r-full);font-size:.875rem;background:var(--bg2);color:var(--text);transition:.2s;outline:none}
.srch input::placeholder{color:var(--text4)}
.srch input:focus{border-color:var(--green);background:var(--surface);box-shadow:0 0 0 3px rgba(124,58,237,.12)}
.srch svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--text3);width:16px;height:16px;pointer-events:none}

/* ── Advanced search dropdown ──────────────────────────────────────── */
.srch-drop{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1.5px solid var(--border-dk);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:500;overflow:hidden;display:none}
.srch-drop.open{display:block}
.srch-drop-section{padding:8px 12px 4px;font-size:.65rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.srch-drop-item{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;transition:.15s;font-size:.88rem;color:var(--text)}
.srch-drop-item:hover,.srch-drop-item.active{background:var(--bg2)}
.srch-drop-item-icon{width:30px;height:30px;border-radius:8px;background:var(--green-lt);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.srch-drop-item-sub{font-size:.72rem;color:var(--text3);margin-top:1px}
.srch-drop-item-badge{margin-left:auto;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:var(--r-full);background:var(--green-lt);color:var(--green)}
.srch-drop-empty{padding:20px 14px;font-size:.84rem;color:var(--text3);text-align:center}
.srch-adv-btn{display:flex;align-items:center;gap:5px;padding:9px 14px;font-size:.82rem;font-weight:600;color:var(--green);border-top:1px solid var(--border);width:100%;background:none;border-left:none;border-right:none;border-bottom:none;cursor:pointer;transition:.15s}
.srch-adv-btn:hover{background:var(--green-lt)}
.srch-adv-btn svg{width:14px;height:14px;transition:.2s}
.srch-adv-btn.open svg{transform:rotate(180deg)}

/* ── Advanced filter panel ─────────────────────────────────────────── */
.adv-filters{background:var(--bg2);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:14px;margin-top:8px;display:none;gap:10px;flex-wrap:wrap;align-items:center}
.adv-filters.open{display:flex}
.adv-filter-group{display:flex;flex-direction:column;gap:4px;min-width:140px;flex:1}
.adv-filter-label{font-size:.65rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em}
.adv-filter-clear{margin-left:auto;font-size:.75rem;color:var(--green);font-weight:700;cursor:pointer;background:none;border:none;padding:4px 8px;border-radius:6px;transition:.15s}
.adv-filter-clear:hover{background:var(--green-lt)}

/* ── Reusable input / select ─────────────────────────────── */
.inp{width:100%;padding:8px 14px;border:1.5px solid var(--border-dk);border-radius:var(--r);
  font-size:.85rem;background:var(--bg2);color:var(--text);outline:none;transition:.2s;
  font-family:var(--font)}
.inp::placeholder{color:var(--text4)}
.inp:focus{border-color:var(--green);background:var(--surface);
  box-shadow:0 0 0 3px rgba(124,58,237,.12)}
.fsel,.sel{padding:8px 30px 8px 12px;border:1.5px solid var(--border-dk);
  border-radius:var(--r);font-size:.82rem;
  background:var(--bg2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239a6040' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 10px center;
  appearance:none;color:var(--text);cursor:pointer;outline:none;transition:.15s;
  font-family:var(--font)}
.fsel:focus,.sel:focus{border-color:var(--green)}
[data-theme="dark"] .fsel,[data-theme="dark"] .sel{
  background-color:var(--bg2);color:var(--text)}
.nav{display:flex;align-items:center;gap:3px;margin-left:auto}
.nbtn{padding:7px 12px;border-radius:var(--r-full);font-size:.82rem;font-weight:600;color:var(--text2);transition:.15s}
.nbtn:hover{background:var(--green-lt);color:var(--green-dk)}
.nbtn.active{color:var(--green);background:var(--green-lt)}
.nbtn-cta{background:var(--green);color:#fff;padding:8px 16px;border-radius:var(--r-full);font-size:.82rem;font-weight:700;transition:.15s}
.nbtn-cta:hover{background:var(--green-dk)}
.theme-btn{width:34px;height:34px;border-radius:var(--r-full);background:var(--bg2);border:1.5px solid var(--border);font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0}
.theme-btn:hover{border-color:var(--green);background:var(--green-lt)}

/* Mobile categories menu toggle button */
.cat-toggle-btn{display:none;width:36px;height:36px;border-radius:var(--r-full);background:var(--bg2);border:1.5px solid var(--border);flex-shrink:0;align-items:center;justify-content:center;transition:.2s;cursor:pointer}
.cat-toggle-btn:hover{border-color:var(--green);background:var(--green-lt)}
.cat-toggle-btn svg{width:18px;height:18px;color:var(--text2)}

/* ── Page layout: sidebar + content ────────────────────────────────── */
.page-layout{display:flex;align-items:flex-start;gap:0;max-width:var(--max-w);margin:0 auto;padding:0 var(--pad)}
.page-layout .main{flex:1;min-width:0;max-width:none;padding-left:20px;padding-right:0;margin:0}

/* ── Category sidebar ───────────────────────────────────────────────── */
.cats{background:var(--surface);border-right:1px solid var(--border);transition:background .25s;flex-shrink:0}
.cats-in{padding:14px 0;display:flex;flex-direction:column;gap:4px;width:var(--cats-sidebar-w)}
.cpill{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--r);font-size:.82rem;font-weight:600;border:none;color:var(--text2);background:transparent;transition:.15s;cursor:pointer;white-space:nowrap;width:100%;text-align:left}
.cpill:hover{background:var(--green-lt);color:var(--green-dk)}
.cpill.on{background:var(--green);color:#fff}
.cpill .cn{font-size:.66rem;background:rgba(0,0,0,.08);padding:1px 5px;border-radius:var(--r-full);margin-left:auto}
.cpill.on .cn{background:rgba(255,255,255,.22)}

/* Sidebar sticky positioning on desktop */
.cats-sticky{position:sticky;top:var(--hdr-h);height:calc(100vh - var(--hdr-h));overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.cats-sticky::-webkit-scrollbar{width:4px}
.cats-sticky::-webkit-scrollbar-track{background:transparent}
.cats-sticky::-webkit-scrollbar-thumb{background:var(--border-dk);border-radius:4px}

/* Sidebar title on desktop */
.cats-title{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);padding:6px 14px 2px;margin-top:4px}

/* Mobile: cat overlay backdrop */
.cat-overlay{visibility:hidden;pointer-events:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:299;opacity:0;transition:opacity .3s, visibility .3s}
.cat-overlay.open{opacity:1;visibility:visible;pointer-events:all}

/* ── Hero Carousel ─────────────────────────────────────────────────────── */
.hero{background:var(--hero-bg);color:#fff;position:relative;overflow:hidden;min-height:360px}
.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(124,58,237,.2) 0%,transparent 60%);pointer-events:none}
.hero-in{max-width:var(--max-w);margin:0 auto;padding:26px var(--pad) 40px;position:relative;z-index:2}

/* Hero Tabs */
.hero-tabs{display:flex;gap:16px;margin-bottom:24px;border-bottom:1px solid rgba(255,255,255,.1)}
.htab{background:none;border:none;color:rgba(255,255,255,.5);font-size:.9rem;font-weight:700;padding:0 4px 12px;font-family:var(--font);cursor:pointer;transition:.2s;position:relative}
.htab:hover{color:rgba(255,255,255,.8)}
.htab.active{color:#fff}
.htab.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:3px;background:#c084fc;border-radius:3px 3px 0 0}

/* Slides Container */
.hero-slider{position:relative;min-height:240px}
.hero-slides{display:flex;transition:transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);will-change:transform}
.hero-slide{flex:0 0 100%;width:100%;opacity:0;transition:opacity .3s;pointer-events:none}
.hero-slide.active{opacity:1;pointer-events:all}

/* Hero Card (Large Format) */
.hcard-wrap{display:flex;gap:16px;overflow-x:auto;scrollbar-width:none;padding-bottom:10px;-webkit-overflow-scrolling:touch}
.hcard-wrap::-webkit-scrollbar{display:none}
.hcard{background:var(--hero-card);border:1px solid var(--hero-border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--r-xl);width:280px;flex-shrink:0;display:flex;flex-direction:column;cursor:pointer;transition:.2s;overflow:hidden;position:relative}
.hcard::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.05) 0%,transparent 100%);opacity:0;transition:.2s}
.hcard:hover{background:var(--hero-hover);border-color:rgba(255,255,255,.2);transform:translateY(-3px)}
.hcard:hover::before{opacity:1}

.hc-img{height:150px;width:100%;background:rgba(0,0,0,.2);display:flex;align-items:center;justify-content:center;position:relative}
.hc-img img{width:100%;height:100%;object-fit:cover}
.hc-bdg{position:absolute;top:10px;right:10px;background:#f59e0b;color:#fff;font-weight:900;font-size:.8rem;padding:4px 8px;border-radius:6px;box-shadow:0 4px 12px rgba(245,158,11,.4)}

.hc-bd{padding:16px;flex:1;display:flex;flex-direction:column}
.hc-str{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.hc-slogo{width:22px;height:22px;border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hc-slogo img{width:100%;height:100%;object-fit:contain}
.hc-sname{font-size:.75rem;font-weight:700;color:var(--hero-text)}

.hc-title{font-size:1rem;font-weight:700;line-height:1.3;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}
.hc-cta{margin-top:auto;width:100%;padding:10px;background:#2dd4bf;color:#042f2e;border-radius:var(--r);font-weight:800;font-size:.85rem;text-align:center;transition:.2s}
.hcard:hover .hc-cta{background:#5eead4}

/* Controls */
.hc-ctrls{position:absolute;top:50%;left:-20px;right:-20px;transform:translateY(-50%);display:flex;justify-content:space-between;pointer-events:none}
.hc-btn{width:40px;height:40px;border-radius:20px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(8px);pointer-events:all;transition:.2s}
.hc-btn:hover{background:rgba(255,255,255,.2);transform:scale(1.05)}
.hc-dots{display:flex;justify-content:center;gap:6px;margin-top:20px}
.hd-dot{width:8px;height:8px;border-radius:4px;background:rgba(255,255,255,.2);transition:.3s;cursor:pointer}
.hd-dot.active{background:#c084fc;width:24px}

/* ── Main ───────────────────────────────────────────────────────────── */
.main{max-width:var(--max-w);margin:0 auto;padding:20px var(--pad) 96px}
.sec-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sec-title{font-size:.97rem;font-weight:700;display:flex;align-items:center;gap:7px;color:var(--text)}
.sec-ct{font-size:.77rem;color:var(--text3);font-weight:400}

/* Flash */
.flash-sec{background:linear-gradient(135deg,#7f0000,#c62828);border-radius:var(--r-xl);padding:18px 16px;margin-bottom:22px}
.flash-hd{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.flash-title{color:#fff;font-weight:800;font-size:1rem}
.cd-bl{background:rgba(0,0,0,.3);color:#fff;border-radius:6px;padding:3px 6px;font-family:monospace;font-weight:700;font-size:.8rem;min-width:26px;text-align:center}

/* Filter bar */
.fbar{display:flex;align-items:center;gap:7px;margin-bottom:16px;flex-wrap:wrap}
.fsel{padding:7px 28px 7px 11px;border:1.5px solid var(--border-dk);border-radius:var(--r);font-size:.8rem;background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239a6040' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 9px center;appearance:none;color:var(--text2);cursor:pointer;outline:none;transition:border-color .15s}
.fsel:focus{border-color:var(--green)}
[data-theme="dark"] .fsel{background-color:var(--surface)}
.ftog{padding:6px 13px;border:1.5px solid var(--border-dk);border-radius:var(--r-full);font-size:.78rem;font-weight:600;color:var(--text2);background:var(--surface);transition:.15s;cursor:pointer}
.ftog:hover{border-color:var(--green);color:var(--green)}
.ftog.on{background:var(--green-lt);border-color:var(--green);color:var(--green-dk)}
[data-theme="dark"] .ftog.on{color:var(--green)}
.fcount{font-size:.78rem;color:var(--text3);margin-left:auto}

/* ── Deal grid ──────────────────────────────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:13px}
/* Defer off-screen card rendering — improves LCP by letting browser focus on visible cards */
.card{content-visibility:auto;contain-intrinsic-size:0 320px}

/* ── Deal card ──────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s,transform .2s;overflow:hidden;box-shadow:var(--shadow-card)}
.card:hover{border-color:var(--green);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card-bar{height:4px}
.t-coupon .card-bar{background:var(--green)}
.t-cashback .card-bar{background:var(--blue)}
.t-flash_sale .card-bar{background:var(--red)}
.t-free_trial .card-bar{background:var(--purple)}
.t-referral .card-bar{background:var(--amber-mid)}
.t-deal .card-bar{background:var(--teal)}
.t-promo_banner .card-bar{background:var(--amber)}
.card-body{padding:13px;flex:1;display:flex;flex-direction:column;gap:8px}
.srow{display:flex;align-items:center;gap:9px}
.slogo{width:34px;height:34px;border-radius:9px;background:var(--bg2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--green-dk);font-size:.85rem;overflow:hidden}
.slogo img{width:100%;height:100%;object-fit:contain;border-radius:9px}
.sname{font-size:.8rem;font-weight:700;color:var(--text2)}
.scat{font-size:.68rem;color:var(--text3)}
.badges{margin-left:auto;display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.bdg{display:inline-flex;align-items:center;padding:2px 6px;border-radius:var(--r-full);font-size:.65rem;font-weight:700;white-space:nowrap}
.bdg-v{background:var(--green-lt);color:var(--green-dk)}
.bdg-n{background:var(--amber-lt);color:var(--amber)}
.bdg-x{background:rgba(106,27,154,.15);color:var(--purple)}
.bdg-f{background:var(--red-lt);color:var(--red);animation:fp 1.5s infinite}
@keyframes fp{0%,100%{opacity:1}50%{opacity:.6}}
.disc{font-size:1.6rem;font-weight:900;line-height:1;color:var(--amber)}
.disc.pct{color:var(--green)}
.disc.pct.big{font-size:2rem}
.disc.cb{color:var(--blue)}
.disc.tr{color:var(--purple)}
.disc.fl{color:var(--red)}
[data-theme="dark"] .disc.pct{color:#fb923c}
[data-theme="dark"] .disc.cb{color:#60a5fa}
[data-theme="dark"] .disc.tr{color:#c084fc}
[data-theme="dark"] .disc.fl{color:#f87171}
[data-theme="dark"] .disc{color:#fdba74}
.dtitle{font-size:.875rem;font-weight:600;color:var(--text);line-height:1.45}
.ddesc{font-size:.775rem;color:var(--text3);line-height:1.55}
.cb-pill{display:inline-flex;align-items:center;gap:4px;background:var(--blue-lt);color:var(--blue);padding:4px 10px;border-radius:var(--r-full);font-size:.75rem;font-weight:700}
.cdown{display:flex;gap:4px;align-items:center;font-size:.7rem}
.cdown-lbl{color:var(--text3)}
.cdown-time{display:flex;gap:3px}
.code-row{display:flex;align-items:center;gap:7px}
.code-box{flex:1;background:var(--amber-lt);border:2px dashed var(--amber-mid);border-radius:8px;padding:7px 10px;font-family:monospace;font-weight:800;font-size:.875rem;color:var(--amber);text-align:center;cursor:pointer;transition:.15s;user-select:all;letter-spacing:.06em}
.code-box:hover{background:#fef3c7;border-color:var(--amber)}
[data-theme="dark"] .code-box{background:rgba(180,83,9,.15)}
[data-theme="dark"] .code-box:hover{background:rgba(180,83,9,.25)}
.btn-copy{padding:7px 12px;background:var(--green-lt);color:var(--green);border:1.5px solid var(--green);border-radius:8px;font-size:.75rem;font-weight:700;transition:.15s;flex-shrink:0;cursor:pointer}
.btn-copy:hover{background:var(--green);color:#fff}
.btn-copy.ok{background:var(--green);color:#fff;border-color:var(--green)}
.no-code{font-size:.72rem;color:var(--text3);font-style:italic}
.cta{display:block;text-align:center;padding:10px;background:var(--green);color:#fff;border-radius:var(--r);font-weight:700;font-size:.875rem;transition:.15s;margin-top:auto}
.cta:hover{background:var(--green-dk)}
.cta.cb{background:var(--blue)}.cta.cb:hover{background:#0d47a1}
.cta.tr{background:var(--purple)}.cta.tr:hover{background:#4a148c}
.cta.rf{background:var(--amber-mid)}.cta.rf:hover{background:var(--amber)}
.cta.fl{background:var(--red)}.cta.fl:hover{background:#b71c1c}
.dmeta{display:flex;align-items:center;gap:8px;font-size:.7rem;color:var(--text4);flex-wrap:wrap}
.dmeta-v{color:var(--green);font-weight:700}
.dexp{margin-left:auto}
.dexp.soon{color:var(--red);font-weight:700}

/* ── Misc ───────────────────────────────────────────────────────────── */
.empty{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--text3)}
.empty h3{color:var(--text2);margin-bottom:8px;font-size:1.05rem}
.empty p{font-size:.875rem}
.lmore-btn{padding:11px 36px;border:2px solid var(--border-dk);border-radius:var(--r-full);font-weight:700;font-size:.875rem;color:var(--text2);transition:.15s;cursor:pointer;background:var(--surface)}
.lmore-btn:hover{border-color:var(--green);color:var(--green)}
.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:max-content;max-width:calc(100vw - 32px)}
.toast{background:var(--text);color:var(--bg);padding:10px 20px;border-radius:var(--r-full);font-size:.84rem;font-weight:600;box-shadow:var(--shadow-lg);animation:ti .3s ease;pointer-events:all;white-space:nowrap}
.toast.ok{background:var(--green);color:#fff}
@keyframes ti{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.modal-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;align-items:center;justify-content:center;padding:var(--pad)}
.modal-ov.open{display:flex}
.modal-bx{background:var(--surface);border-radius:var(--r-xl);padding:24px;max-width:400px;width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.bnav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);z-index:200;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 16px rgba(0,0,0,.08)}
.bnav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 4px;font-size:.63rem;font-weight:600;color:var(--text3);transition:.15s;cursor:pointer;background:none;border:none;font-family:var(--font);text-decoration:none}
.bnav-btn.on,.bnav-btn:hover{color:var(--green)}
.bnav-btn svg{width:21px;height:21px}
.skel{background:linear-gradient(90deg,var(--bg2) 25%,var(--bg3) 50%,var(--bg2) 75%);background-size:200% 100%;animation:sk 1.4s infinite;border-radius:var(--r)}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}
.hm{display:none}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */

/* 480px — large phones */
@media(min-width:480px){
  .logo-tag{display:inline}
}

/* 640px — small tablets */
@media(min-width:640px){
  :root{--hdr-h:64px;--pad:20px}
  .hm{display:initial}
  .logo{font-size:1.25rem}
  .logo img{width:36px;height:36px}
  .srch{max-width:380px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
}

/* 768px — tablets: hide bottom nav */
@media(min-width:768px){
  .bnav{display:none!important}
  .srch{max-width:440px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
  .nbtn{display:inline-flex}
  .nbtn-cta{display:inline-block}
}

/* 1024px — desktop: activate sidebar layout */
@media(min-width:1024px){
  :root{--pad:24px}
  .srch{max-width:480px}
  .nav .nbtn{font-size:.875rem;padding:8px 15px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}

  /* Sidebar becomes visible on desktop */
  .cats{display:block;border-right:1.5px solid var(--border);border-bottom:none}
  .cats-in{width:var(--cats-sidebar-w);flex-direction:column;height:auto;white-space:normal}
  .page-layout{padding:0 var(--pad)}
  .page-layout .main{padding:20px 0 48px 20px}
  /* cat-toggle hidden on desktop */
  .cat-toggle-btn{display:none!important}
  .cat-overlay{display:none!important}
}

/* Mobile only (<1024px) */
@media(max-width:1023px){
  /* Sidebar is a fixed drawer on mobile/tablet */
  .cats{
    position:fixed;
    top:0;left:-100%;
    width:280px;height:100%;
    z-index:300;
    border-right:1.5px solid var(--border);
    border-bottom:none;
    box-shadow:var(--shadow-lg);
    transition:left .3s cubic-bezier(.34,1.1,.64,1);
    overflow-y:auto;
    padding-top:calc(var(--hdr-h) + 10px);
  }
  .cats.open{left:0}
  .cats-in{width:100%;flex-direction:column;height:auto;gap:2px;padding:8px 8px 24px}
  .cpill{border-radius:var(--r);padding:10px 14px}
  .cat-toggle-btn{display:flex}
  .cat-overlay{display:block}
  .page-layout{flex-direction:column;padding:0;max-width:none}
  .page-layout .main{padding:20px var(--pad) 96px;max-width:var(--max-w);margin:0 auto;width:100%}
}

/* Mobile only (<768px) */
@media(max-width:767px){
  .bnav{display:flex}
  .main{padding-bottom:calc(60px + 20px + env(safe-area-inset-bottom))}
  /* Hide text nav links — bottom nav takes over */
  .nav .nbtn:not(.nbtn-cta):not(.theme-btn){display:none}
  .nav .nbtn-cta{font-size:.76rem;padding:7px 12px}
  .fc-disc{font-size:1.2rem}
  .srch{max-width:none;flex:1;min-width:0}
  .srch input{font-size:.82rem;padding:8px 12px 8px 36px}
  .logo-tag{display:none}
  .hdr-in{gap:6px;padding:0 12px}
  .logo{font-size:1rem;gap:6px}
  .logo img{width:28px;height:28px}
  /* Cards: 2 columns on phones, 1 on tiny */
  .grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .card-img{height:120px}
  .disc{font-size:1.35rem}
  .disc.pct.big{font-size:1.6rem}
  .dtitle{font-size:.8rem}
  .ddesc{display:none}  /* hide desc on tiny screens */
  .code-box{font-size:.78rem;padding:6px 8px}
  .btn-copy{padding:6px 10px;font-size:.7rem}
  .fbar{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;-webkit-overflow-scrolling:touch}
  .fbar::-webkit-scrollbar{display:none}
  .ftog{flex-shrink:0}
  .hero{padding:18px 0 14px}
  .hero-in{padding:0 12px}
  .sec-hd{margin-bottom:10px}
}
/* Very small phones (<400px) */
@media(max-width:400px){
  .grid{grid-template-columns:1fr}
  .ftog{padding:5px 10px;font-size:.72rem}
  .fbar{gap:4px}
  .disc.pct.big{font-size:1.4rem}
}

/* Touch devices */
@media(hover:none) and (pointer:coarse){
  .cpill{padding:10px 16px}
  .ftog{padding:8px 14px}
  .btn-copy{padding:9px 14px}
  .cta{padding:12px}
  .bnav-btn{padding:10px 4px}
  .card:hover{transform:none}
  .fc:hover{transform:none}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ── Promo banner (Admitad / affiliate HTML) ────────────────────────── */
.banner-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  border-radius: var(--r);
  background: var(--bg2);
  min-height: 60px;
}
.banner-wrap a   { display: block; line-height: 0; }
.banner-wrap img {
  max-width: 100%; height: auto; display: block;
  border-radius: calc(var(--r) - 2px);
}

/* ── Expiry popup on mobile: stack above bottom nav ─────────────────── */
@media (max-width: 767px) {
  #expiryPopup > div {
    bottom: calc(64px + env(safe-area-inset-bottom)) !important;
    right: 8px !important;
    width: calc(100vw - 16px) !important;
  }
}

/* ── Product / Deal images ──────────────────────────────────────────── */
/* Deal card product image */
.card-img {
  width: calc(100% + 2px);
  margin: -1px -1px 0;
  height: 160px;
  overflow: hidden;
  border-radius: var(--r) var(--r) 0 0;
  background: var(--bg2);
}
.card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.card:hover .card-img img { transform: scale(1.03); }

/* Flash / featured cards with images get slightly taller */
.card.t-deal .card-img,
.card.t-coupon .card-img { height: 150px; }

/* ── Trust / Why PriceProwl bar ─────────────────────────────────── */
.trust-bar{background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.trust-bar::-webkit-scrollbar{display:none}
.trust-in{max-width:var(--max-w);margin:0 auto;padding:10px var(--pad);display:flex;gap:8px;align-items:center;white-space:nowrap;flex-wrap:nowrap}
.trust-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:var(--green-lt);border:1px solid var(--green-mid);border-radius:var(--r-full);font-size:.76rem;color:var(--green-dk);flex-shrink:0}
.trust-pill strong{font-weight:700}
[data-theme="dark"] .trust-pill{background:rgba(234,88,12,.15);border-color:rgba(234,88,12,.3);color:#fb923c}

/* ── Social share button on deal cards ──────────────────────────── */
.share-row{display:flex;align-items:center;gap:5px;padding-top:9px;border-top:1px solid var(--border);margin-top:2px}
.share-label{font-size:.65rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;margin-right:2px}
.share-ic{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1.5px solid var(--border);cursor:pointer;transition:.15s;flex-shrink:0;text-decoration:none;background:var(--surface)}
.share-ic svg{width:14px;height:14px;flex-shrink:0}
.share-ic:hover{transform:translateY(-2px);box-shadow:0 3px 8px rgba(0,0,0,.15)}
/* Brand colours */
.share-tw{color:#000;border-color:#00000022}
.share-tw:hover{background:#000;color:#fff;border-color:#000}
[data-theme="dark"] .share-tw{color:#fff;border-color:#ffffff22}
[data-theme="dark"] .share-tw:hover{background:#fff;color:#000;border-color:#fff}
.share-fb{color:#1877F2;border-color:#1877F222}
.share-fb:hover{background:#1877F2;color:#fff;border-color:#1877F2}
.share-wa{color:#25D366;border-color:#25D36622}
.share-wa:hover{background:#25D366;color:#fff;border-color:#25D366}
.share-pt{color:#E60023;border-color:#E6002322}
.share-pt:hover{background:#E60023;color:#fff;border-color:#E60023}
.share-cp{color:var(--green);border-color:var(--border);background:none;border:1.5px solid var(--border);font-family:inherit}
.share-cp:hover{background:var(--green-lt);border-color:var(--green);color:var(--green-dk)}
/* On small phones hide Pinterest to save space */
@media(max-width:380px){.share-pt{display:none}}

/* ── Deal detail page — fully theme-aware ────────────────────────── */
.deal-detail-card{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-md)}
.deal-detail-hero{background:linear-gradient(135deg,var(--green-dk),var(--green));padding:32px 24px;text-align:center}
.deal-detail-disc{font-size:3rem;font-weight:900;color:#fff;line-height:1;margin-bottom:8px}
.deal-detail-store{font-size:.85rem;color:rgba(255,255,255,.8);text-transform:uppercase;letter-spacing:.07em;display:flex;align-items:center;justify-content:center;gap:8px}
.deal-detail-logo{width:28px;height:28px;border-radius:6px;object-fit:contain;background:rgba(255,255,255,.15)}
.deal-detail-body{padding:24px;display:flex;flex-direction:column;gap:14px}
.deal-detail-title{font-size:1.2rem;font-weight:700;color:var(--text);line-height:1.45;margin:0}
.deal-detail-desc{font-size:.9rem;color:var(--text2);line-height:1.65;margin:0}
.deal-detail-code-wrap{display:flex;flex-direction:column;gap:7px}
.deal-detail-code-label{font-size:.76rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em}
.deal-detail-code-row{display:flex;gap:10px;align-items:center}
.deal-detail-no-code{font-size:.82rem;color:var(--text3);font-style:italic;padding:10px 0}
.deal-detail-cta{font-size:1rem;padding:14px}
.deal-detail-share{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.deal-detail-meta{display:flex;align-items:center;gap:10px;font-size:.78rem;flex-wrap:wrap}

/* Also fix the "Back to deals" link and moreDeals section */
.deal-back-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text3);margin-bottom:20px;transition:.15s}
.deal-back-link:hover{color:var(--green)}

/* Fix any remaining hardcoded colours leaking through on other pages */
#catGrid > div{background:var(--surface) !important;color:var(--text) !important}
#catGrid > div > div:first-child + div{color:var(--text) !important}

/* Stores page store cards */
#storesGrid > div,
#featuredStores div[onclick]{background:var(--surface) !important;border-color:var(--border) !important;color:var(--text) !important}
#storesGrid .sname,
#featuredStores .sname{color:var(--text) !important}

/* Fix loader bar in dark mode */
[data-theme="dark"] #loader div:last-child{background:var(--bg3)}

/* ── Rating modal buttons ────────────────────────────────────────── */
.rating-btn{flex:1;padding:12px;border-radius:10px;font-weight:700;cursor:pointer;font-family:var(--font);background:var(--surface);transition:.15s;border:2px solid}
.rating-ok{border-color:var(--green);color:var(--green)}
.rating-ok:hover{background:var(--green);color:#fff}
.rating-no{border-color:var(--red);color:var(--red)}
.rating-no:hover{background:var(--red);color:#fff}

/* ── about.html stat number colours ─────────────────────────────── */
[data-theme="dark"] .about-stat-green{color:#fb923c !important}
[data-theme="dark"] .about-stat-orange{color:#fb923c !important}
[data-theme="dark"] .about-stat-purple{color:#c084fc !important}

/* ── Stores page search/select dark mode ─────────────────────────── */
[data-theme="dark"] #storeSrch,
[data-theme="dark"] #storeCatSel{background:var(--surface);color:var(--text);border-color:var(--border)}

/* ── Categories page card dark hover fix ─────────────────────────── */
[data-theme="dark"] #catGrid > div:hover{box-shadow:0 6px 16px rgba(0,0,0,.4) !important}

/* ── Conversion signals ──────────────────────────────────────────── */
.was-now{font-size:.75rem;color:var(--text3);margin-bottom:4px}
.was-now s{color:var(--text4)}
.was-now strong{color:var(--green);font-weight:700}

.coupon-saving{font-size:.75rem;color:var(--amber);font-weight:600;
  background:var(--amber-lt,#fffbeb);border-radius:6px;
  padding:4px 8px;margin-top:6px;display:inline-block}

.social-proof{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.sp-sold{font-size:.72rem;font-weight:700;color:var(--red,#e53e3e);
  background:#fff5f5;border-radius:4px;padding:2px 7px}
.sp-feedback{font-size:.72rem;color:var(--text3);background:var(--bg2);
  border-radius:4px;padding:2px 7px}
[data-theme="dark"] .sp-sold{background:rgba(229,62,62,.15)}
[data-theme="dark"] .coupon-saving{background:rgba(180,83,9,.15)}

/* ── Video badge on card image ───────────────────────────────────── */
.card-img{position:relative;overflow:hidden}
.video-badge{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.7);
  color:#fff;font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:4px;
  text-decoration:none;z-index:2;display:flex;align-items:center;gap:4px;
  border:none;cursor:pointer;font-family:inherit;line-height:1.2}
.video-badge:hover{background:rgba(0,0,0,.9)}

/* ── Deal detail conversion signals ─────────────────────────────── */
.conv-wasnow{font-size:.9rem;color:var(--text2);margin-bottom:8px}
.conv-wasnow s{color:var(--text4);text-decoration:line-through}
.conv-wasnow strong{color:var(--green);font-weight:800;font-size:1rem}

.conv-coupon{background:var(--amber-lt,#fffbeb);border:1.5px solid var(--amber-mid,#d97706);
  border-radius:8px;padding:8px 14px;font-size:.82rem;font-weight:600;
  color:var(--amber,#b45309);margin-bottom:10px;display:inline-block}
[data-theme="dark"] .conv-coupon{background:rgba(180,83,9,.15);color:#fcd34d}

.conv-proof{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.conv-sold{background:#fff5f5;color:#e53e3e;font-weight:700;font-size:.8rem;
  padding:4px 10px;border-radius:6px;border:1px solid #fed7d7}
.conv-fb{background:var(--bg2);color:var(--text3);font-size:.8rem;
  padding:4px 10px;border-radius:6px;border:1px solid var(--border)}
[data-theme="dark"] .conv-sold{background:rgba(229,62,62,.15);border-color:rgba(229,62,62,.3)}

/* conv-video now a <button> — keep identical visual appearance */
.conv-video{display:inline-flex;align-items:center;gap:6px;background:#000;
  color:#fff;padding:8px 16px;border-radius:8px;font-weight:600;font-size:.85rem;
  text-decoration:none;margin-bottom:12px;transition:.15s;
  border:none;cursor:pointer;font-family:inherit}
.conv-video:hover{background:#333}

/* ── CLS fix: loader has a stable min-height so hiding it doesn't
      cause a massive upward layout shift ─────────────────────────── */
#loader{min-height:340px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:56px 20px}
#app{transition:opacity .28s}

/* ── Video modal overlay (created by JS) ─────────────────────────── */
#pp-video-modal video:focus{outline:none}

.gen-step{padding:14px;background:var(--bg2);border-radius:10px}

/* ── Featured carousel card redesign ────────────────────────────── */
.fc{width:200px;flex-shrink:0;border-radius:14px;overflow:hidden;
  background:var(--surface);border:1.5px solid var(--border);
  transition:.2s;cursor:pointer;display:flex;flex-direction:column}
.fc:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.15)}
.fc-img-wrap{position:relative;height:140px;background:var(--bg2);overflow:hidden}
.fc-img-el{width:100%;height:100%;object-fit:contain;padding:6px;background:var(--bg2)}
.fc-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;font-weight:900;color:var(--green);background:var(--green-lt)}
.fc-disc-badge{position:absolute;top:8px;left:8px;background:var(--green);color:#fff;
  font-size:.72rem;font-weight:800;padding:3px 8px;border-radius:6px}
.fc-video-btn{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);color:#fff;
  font-size:.7rem;font-weight:700;padding:4px 8px;border-radius:6px;text-decoration:none;
  z-index:2}
.fc-video-btn:hover{background:#000}
.fc-body{padding:10px 12px;flex:1;display:flex;flex-direction:column}
.fc-store{font-size:.68rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.fc-title{font-size:.8rem;font-weight:600;color:var(--text);line-height:1.35;
  margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.fc-wasnow{font-size:.68rem;color:var(--text3);margin-bottom:4px}
.fc-wasnow s{color:var(--text4)}
.fc-sold{font-size:.68rem;color:var(--red,#e53e3e);font-weight:700;margin-bottom:5px}
.fc-code{font-size:.72rem;font-family:monospace;font-weight:800;color:var(--amber);
  background:var(--amber-lt,#fffbeb);border:1px dashed var(--amber-mid);border-radius:5px;
  padding:3px 8px;margin-bottom:6px;text-align:center;cursor:pointer}
.fc-cta{display:block;text-align:center;background:var(--green);color:#fff;border-radius:8px;
  padding:7px;font-size:.78rem;font-weight:700;text-decoration:none;transition:.15s;margin-top:auto}
.fc-cta:hover{background:var(--green-dk)}

/* ── Featured card description ───────────────────────────────────── */
.fc-desc{font-size:.7rem;color:var(--text3);line-height:1.4;margin-bottom:5px;
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ── Store card dark mode fix ────────────────────────────────────── */
.store-card:hover{border-color:var(--green) !important;
  box-shadow:0 4px 14px rgba(234,88,12,.12) !important}
[data-theme="dark"] .store-card:hover{box-shadow:0 4px 14px rgba(234,88,12,.25) !important}

.fbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* ── Footer ───────────────────────────────────────────────────────────── */
.ftr{background:var(--surface);border-top:1px solid var(--border);padding:48px var(--pad) calc(28px + env(safe-area-inset-bottom));margin-top:auto}
.ftr-nav{display:flex;flex-wrap:wrap;gap:48px;justify-content:center;text-align:left;margin-bottom:36px;padding-bottom:36px;border-bottom:1px solid rgba(150,150,150,.15);max-width:var(--max-w);margin-left:auto;margin-right:auto}
.ftr-col{flex:1;min-width:220px}
.ftr-title{color:var(--text2);font-weight:800;font-size:.85rem;margin-bottom:16px;text-transform:uppercase;letter-spacing:.09em}
.ftr-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(130px, 1fr));gap:10px}
.ftr-link{color:var(--text3);text-decoration:none;font-size:.78rem;padding:3px 0;transition:.2s;display:block}
.ftr-link:hover{color:var(--green);transform:translateX(4px)}
