/* dn-theme.css — Discount Nexus design system. LIGHT / Amazon-parity. Scoped under .dn.
   STOPLIGHT (deal quality): green = solid buy, amber = caution (fair/a bit high), red = NOT recommended (over market).
   Purple = special only. Dark is reserved for the shell frame only. */
.dn{
  --bg:#eaeded;          /* page gray */
  --panel:#ffffff;        /* white cards */
  --panel-2:#ffffff;
  --raise:#f3f4f6;        /* subtle gray (inputs/hover) */
  --line:#d5d9d9;         /* border gray */
  --sheen:none;
  --shadow:0 1px 3px rgba(15,17,17,.10);
  --ink:#0f1111;          /* near-black text */
  --soft:#333538; --muted:#6f7679;
  --green:#1a8f4d; --green-2:#15803d; --green-ink:#ffffff;   /* GO / solid buy */
  --yellow:#c8901f; --yellow-2:#9a6a00;                       /* CAUTION / Scarab gold */
  --red:#c7341c; --red-2:#b12704;                             /* STOP / over market */
  --special:#6b4fbb;
  color:var(--ink); font:15px/1.5 -apple-system,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
}
.dn *{box-sizing:border-box}
.dn a{color:inherit;text-decoration:none}
.dn .ico{width:18px;height:18px;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:middle}

/* full-bleed: fill the screen, not a small floating box */
body.dn-runtime-page{overflow-x:hidden}
body.dn-runtime-page .dn{width:100vw;max-width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;overflow-x:hidden;background:var(--bg)}
.dn .wrap{max-width:1500px;margin:0 auto;padding:20px 32px 56px}
/* the theme renders my routes as a single blog post and prints its post header ("Hello world!") — hide it (also removes the block that caused the bounce) */
body.dn-runtime-page .single-post-header{display:none !important}
/* header consistency: the DN front page renders Bootstrap's boxed .container (1170px) while every
   inner page uses the theme's wide .martfury-container (1650px) — so the logo/search jump on nav.
   Widen the front-page header to match the inner pages (max-width keeps it responsive). */
body.home .header-main .container{width:1650px;max-width:100%;margin-left:auto;margin-right:auto}

/* reusable hero slider (home, categories, brand pages) */
.dn .dn-slider{position:relative;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);height:var(--dnsh,360px);margin-bottom:10px}
.dn .dn-slider .dn-sl{position:absolute;inset:0;display:flex;align-items:center;padding:0 7%;opacity:0;transition:opacity .8s ease;color:#fff}
.dn .dn-slider .dn-sl.on{opacity:1}
.dn .dn-slider .dn-sl-in{max-width:560px}
.dn .dn-slider .dn-sl-in .k{font-size:12px;font-weight:800;letter-spacing:2px;text-transform:uppercase;opacity:.88}
.dn .dn-slider .dn-sl-in h2{font-size:40px;line-height:1.06;margin:10px 0 12px;letter-spacing:-.5px;color:#fff}
.dn .dn-slider .dn-sl-in p{font-size:16px;opacity:.92;margin:0 0 20px;max-width:480px}
.dn .dn-slider .dn-sl-in .cta{display:inline-block;background:#fff;color:#0f1111;font-weight:800;padding:12px 22px;border-radius:10px}
.dn .dn-slider .dn-dots{position:absolute;bottom:14px;left:0;right:0;display:flex;gap:8px;justify-content:center;z-index:3}
.dn .dn-slider .dn-dots b{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.45);cursor:pointer}
.dn .dn-slider .dn-dots b.on{background:#fff;width:24px;border-radius:5px}
@media(max-width:1000px){.dn .dn-slider .dn-sl-in h2{font-size:28px}}
/* editable intro / description block (below hero on brand-hub & category pages) */
.dn .dn-intro{margin:8px 0 24px}
.dn .dn-intro-in{max-width:980px}
.dn .dn-intro p{color:var(--soft);font-size:15px;line-height:1.7;margin:0 0 13px}
.dn .dn-intro p.cta-line{color:var(--ink);font-weight:800;font-size:17px;margin-top:2px}

.dn .card{background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow)}
.dn .card:hover{border-color:var(--yellow)}
.dn .btn-buy{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--green);color:var(--green-ink);border:0;font-weight:700;border-radius:9px;padding:13px 18px;cursor:pointer;box-shadow:0 1px 2px rgba(0,0,0,.12)}
.dn .btn-buy:hover{background:var(--green-2)}
.dn .btn-ghost{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;border-radius:8px;padding:8px 14px;font-weight:600;font-size:12.5px;color:var(--soft)}
.dn .btn-ghost:hover{border-color:var(--yellow);background:var(--raise)}

/* STOPLIGHT */
.dn .deal-good{color:var(--green-2)} .dn .deal-fair{color:var(--yellow-2)} .dn .deal-bad{color:var(--red-2)}
.dn .pill-good,.dn .pill-fair,.dn .pill-bad{font-size:11px;font-weight:700;padding:3px 8px;border-radius:5px;letter-spacing:.2px}
.dn .pill-good{background:#e3f3ea;color:var(--green-2);border:1px solid #b6ddc4}
.dn .pill-fair{background:#fbf2dc;color:var(--yellow-2);border:1px solid #ecd9a6}
.dn .pill-bad{background:#fbe6e2;color:var(--red-2);border:1px solid #efc3b8}
.dn .price{font-weight:800;letter-spacing:-.3px}

/* Gold Scarab medallion (gold reads well on white) */
.dn .scarab-medal{border-radius:50%;background:radial-gradient(circle at 34% 26%,#fff0c4,var(--yellow) 52%,#9a6a00 88%);box-shadow:0 2px 8px rgba(154,106,0,.35),inset 0 2px 4px rgba(255,255,255,.6)}
.dn .scarab-verdict{font-weight:800;letter-spacing:.2px}

/* product image placeholder — light */
.dn .img-ph{background:#f3f4f6;border:1px solid #e7e9eb;display:flex;align-items:center;justify-content:center;color:#c4c9cd;font-weight:800}

.dn table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden}
.dn th{text-align:left;color:var(--muted);font-weight:700;font-size:11.5px;letter-spacing:.4px;padding:11px 14px;border-bottom:1px solid var(--line);background:#f7f8f8}
.dn td{padding:14px;border-bottom:1px solid #eceeef;font-size:13.5px}
.dn tr:hover td{background:#fafbfb}

.dn .crumbs{color:var(--muted);font-size:12.5px}
.dn .crumbs a:hover{color:var(--green-2);text-decoration:underline} .dn .crumbs .here{color:var(--ink);font-weight:600} .dn .crumbs .s{margin:0 8px;opacity:.6}
.dn .side a{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:7px;font-size:13.5px;color:var(--soft)}
.dn .side a:hover{background:var(--raise)}
.dn .side a.on{background:#e3f3ea;color:var(--green-2);font-weight:700}
.dn .side a .c{color:var(--muted);font-size:11.5px}
.dn .side .lab{font-size:10.5px;letter-spacing:1px;color:var(--muted);margin:2px 8px 8px;text-transform:uppercase}

.dn .pending{display:inline-block;color:var(--muted);font-size:13px;border:1px dashed var(--line);border-radius:8px;padding:7px 12px;background:#fff}
.dn .sechead{display:flex;align-items:baseline;gap:12px;margin:34px 0 14px}
.dn .sechead h2{font-size:21px;margin:0} .dn .sechead a{margin-left:auto;color:var(--green-2);font-size:13px;font-weight:600}
.dn .adzone{margin-top:16px}
.dn .ad-label{color:var(--muted);font-size:9.5px;letter-spacing:.7px;text-transform:uppercase;margin:0 2px 7px}

/* shared header strip (real site supplies the true shell) */
.dn .dnhead{display:flex;align-items:center;gap:16px;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.dn .dnhead .medal{width:38px;height:38px;border-radius:50%;background:radial-gradient(circle at 34% 26%,#fff0c4,var(--yellow) 52%,#9a6a00 88%)}
.dn .dnhead .brand{font-weight:800;letter-spacing:.4px;color:var(--ink)} .dn .dnhead .brand i{color:var(--green-2);font-style:normal}
