/* ═════════════════════════════════════════════════════════════════════════
   DeskPickr V13 · "RETAIL"
   Design from zero · Wirecutter / RTINGS inspired · conversion-first
   Palette : white + navy + amber yellow (Amazon-native CTA)
   Dernière refonte — 19 avril 2026
═══════════════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────────────
   1. TOKENS
───────────────────────────────────────────────────────────────────────── */
:root{
  /* Backgrounds — crisp white retail */
  --bg:#ffffff;
  --bg-2:#f7f8fa;
  --bg-3:#eef1f6;
  --bg-4:#e4e8ef;

  /* Ink — deep navy for body, better than #000 */
  --ink:#0b1e3d;
  --ink-2:#1f3155;
  --ink-3:#4b5b79;
  --ink-4:#7a8aa3;
  --ink-5:#aab5c7;

  /* Lines — precise, thin, high-contrast */
  --line:#e5e8ef;
  --line-2:#d3d9e3;
  --line-strong:#b8c0cd;

  /* Brand — navy */
  --navy:#0b1e3d;
  --navy-2:#122a55;
  --navy-3:#1d3c77;

  /* Amazon-native amber for prices + primary CTA */
  --amber:#ffd400;
  --amber-2:#f5c500;
  --amber-3:#ddb000;
  --amber-ink:#0b1e3d;

  /* Retail commerce colors */
  --green:#047a3f;      /* in stock · prix OK */
  --green-bg:#e6f4ec;
  --red:#d91e18;        /* discount · rupture */
  --red-bg:#fdeae9;
  --star:#f5a623;       /* rating stars */
  --blue-link:#1664c0;  /* hyperlinks */
  --blue-link-hover:#0b4d9a;

  /* Badges */
  --badge-bestseller:#f05a00;   /* top seller orange Amazon */
  --badge-editors:#5b2cc7;      /* editor's choice violet */
  --badge-deal:#d91e18;

  /* Radii — sharper than v12 */
  --r1:2px; --r2:4px; --r3:6px; --r4:10px; --r5:14px;

  /* Shadows — commerce clean */
  --sh-1:0 1px 2px rgba(10,24,54,.05);
  --sh-2:0 4px 12px rgba(10,24,54,.08);
  --sh-3:0 12px 28px rgba(10,24,54,.12);
  --sh-focus:0 0 0 3px rgba(255,212,0,.45);

  /* Typography */
  --font-display:"Inter Tight","Inter",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --font-body:"Inter",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --font-num:"Inter","SF Pro Display",system-ui,sans-serif;

  /* Layout */
  --shell-max:1280px;
  --shell-pad:24px;

  /* Easing */
  --e:cubic-bezier(.2,.8,.2,1);
}

[data-theme="dark"]:root,
[data-theme="dark"]{
  --bg:#0b0f17;
  --bg-2:#121826;
  --bg-3:#1a2334;
  --bg-4:#232f44;

  --ink:#e9eef7;
  --ink-2:#c5cfe0;
  --ink-3:#8a97b0;
  --ink-4:#5f6d86;
  --ink-5:#3c4762;

  --line:#1f2a3d;
  --line-2:#2b384f;
  --line-strong:#3f4d68;

  --navy:#4a7bd1;
  --navy-2:#5a8ce0;
  --navy-3:#3868b9;

  --amber:#ffd400;
  --amber-2:#f5c500;
  --amber-3:#ddb000;
  --amber-ink:#0b1e3d;

  --green:#3fbf6e;
  --green-bg:#0f2a1c;
  --red:#ff6961;
  --red-bg:#2d1413;
  --blue-link:#6eaff5;
  --blue-link-hover:#a1cbff;

  --sh-1:0 1px 2px rgba(0,0,0,.4);
  --sh-2:0 4px 12px rgba(0,0,0,.5);
  --sh-3:0 12px 28px rgba(0,0,0,.6);
}

/* ─────────────────────────────────────────────────────────────────────────
   2. GLOBAL RESET + BASE
───────────────────────────────────────────────────────────────────────── */
html{ color-scheme:light dark; }
html[data-theme="light"]{ color-scheme:light; }
html[data-theme="dark"]{ color-scheme:dark; }

body,
body.wp-singular,
body.home,
body.archive,
body.blog,
body.page,
body.single{
  background:var(--bg)!important;
  color:var(--ink)!important;
  font-family:var(--font-body)!important;
  font-size:15px!important;
  line-height:1.6!important;
  font-feature-settings:"cv11","ss01","ss03"!important;
  -webkit-font-smoothing:antialiased!important;
  -moz-osx-font-smoothing:grayscale!important;
}

body *{ box-sizing:border-box; }

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display)!important;
  font-weight:700!important;
  color:var(--ink)!important;
  letter-spacing:-.02em!important;
  line-height:1.15!important;
  margin:0 0 .5em!important;
}

p,li{ color:var(--ink-2); }

a{ color:var(--blue-link); text-decoration:none; transition:color .15s; }
a:hover{ color:var(--blue-link-hover); text-decoration:underline; }

img,picture,video{ max-width:100%; height:auto; display:block; }

::selection{ background:var(--amber); color:var(--amber-ink); }

/* Kill legacy GeneratePress chrome */
.site-header,
.main-navigation,
#site-navigation,
#primary-menu,
.navigation-branding,
.main-nav,
.dp-wow-menu,
#dp-wow-menu,
.dp-wow-nav,
.dp-nav-brand,
.inside-header,
.gp-mobile-header{
  display:none!important;
  visibility:hidden!important;
  height:0!important;
  overflow:hidden!important;
  padding:0!important;
  margin:0!important;
}

/* Shell */
.dp-shell,
.grid-container,
.inside-article,
.inside-content{
  max-width:var(--shell-max)!important;
  margin-left:auto!important;
  margin-right:auto!important;
  padding-left:var(--shell-pad)!important;
  padding-right:var(--shell-pad)!important;
}

/* Inner article wrapper kill */
.inside-article{ background:transparent!important; box-shadow:none!important; padding:0!important; }

/* ─────────────────────────────────────────────────────────────────────────
   3. MENUBAR · utility retail bar
───────────────────────────────────────────────────────────────────────── */
#dp-menubar,
.dp-menubar{
  position:sticky!important;
  top:0; z-index:800;
  background:var(--bg)!important;
  border-bottom:1px solid var(--line)!important;
  box-shadow:var(--sh-1)!important;
  font-family:var(--font-body)!important;
}

.dp-menubar__trust{
  background:var(--bg-2);
  border-bottom:1px solid var(--line);
  font-size:12px;
  color:var(--ink-3);
  padding:6px 0;
}
.dp-menubar__trust-inner{
  max-width:var(--shell-max);
  margin:0 auto;
  padding:0 var(--shell-pad);
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  flex-wrap:wrap;
}
.dp-menubar__trust-badges{ display:flex; gap:18px; align-items:center; flex-wrap:wrap; }
.dp-menubar__trust-item{
  display:inline-flex; align-items:center; gap:6px;
}
.dp-menubar__trust-item svg,
.dp-menubar__trust-item i{ color:var(--green); font-size:13px; }
.dp-menubar__trust a{ color:var(--ink-3); }
.dp-menubar__trust a:hover{ color:var(--navy); }

.dp-menubar__main{
  max-width:var(--shell-max);
  margin:0 auto;
  padding:14px var(--shell-pad);
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}

.dp-menubar__brand{
  display:inline-flex; align-items:baseline; gap:8px;
  font-family:var(--font-display);
  font-weight:800; font-size:24px; letter-spacing:-.03em;
  color:var(--navy)!important; text-decoration:none!important;
}
.dp-menubar__brand strong{ color:var(--navy); }
.dp-menubar__brand em{
  font-style:normal;
  font-size:10px; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-4);
  padding:3px 7px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--r2);
}

/* Search bar (central, dominant like Amazon) */
.dp-menubar__search{
  position:relative;
  max-width:560px; width:100%;
  margin:0 auto;
}
.dp-menubar__search-form{
  display:flex;
  background:var(--bg);
  border:2px solid var(--line-2);
  border-radius:var(--r3);
  overflow:hidden;
  transition:border-color .15s, box-shadow .15s;
}
.dp-menubar__search-form:focus-within{
  border-color:var(--amber);
  box-shadow:var(--sh-focus);
}
.dp-menubar__search-form select,
.dp-menubar__search-form .dp-menubar__cat-pick{
  background:var(--bg-2);
  border:0; border-right:1px solid var(--line);
  padding:0 12px; font-size:13px; color:var(--ink-2);
  font-family:var(--font-body);
  max-width:140px;
  cursor:pointer;
}
.dp-menubar__search-input{
  flex:1; border:0; outline:0;
  padding:12px 14px; font-size:14px;
  background:var(--bg); color:var(--ink);
  font-family:var(--font-body);
}
.dp-menubar__search-input::placeholder{ color:var(--ink-4); }
.dp-menubar__search-btn{
  background:var(--amber);
  border:0; color:var(--amber-ink);
  padding:0 18px; font-size:15px; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .15s;
}
.dp-menubar__search-btn:hover{ background:var(--amber-2); }

/* Right cluster */
.dp-menubar__actions{ display:flex; align-items:center; gap:14px; }
.dp-menubar__action{
  display:inline-flex; align-items:center; gap:6px;
  font-size:12.5px; color:var(--ink-3);
  padding:6px 10px;
  border-radius:var(--r2);
  text-decoration:none;
  transition:background .15s, color .15s;
}
.dp-menubar__action:hover{ background:var(--bg-2); color:var(--navy); }
.dp-menubar__action strong{ color:var(--ink); font-weight:700; font-size:13px; }

/* Category nav row (secondary, below main bar) */
.dp-menubar__nav-row{
  background:var(--navy);
  border-top:1px solid var(--line);
}
.dp-menubar__nav{
  max-width:var(--shell-max);
  margin:0 auto;
  padding:0 var(--shell-pad);
  display:flex; align-items:center; gap:4px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.dp-menubar__nav::-webkit-scrollbar{ display:none; }
.dp-menubar__link{
  display:inline-flex; align-items:center;
  padding:11px 14px;
  color:rgba(255,255,255,.85)!important;
  font-size:13.5px; font-weight:500;
  text-decoration:none!important;
  white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color .15s, border-color .15s, background .15s;
}
.dp-menubar__link:hover{ color:#fff!important; background:rgba(255,255,255,.06); }
.dp-menubar__link.is-active,
.dp-menubar__link:focus{
  color:#fff!important;
  border-bottom-color:var(--amber);
  background:rgba(255,255,255,.04);
}
.dp-menubar__nav-cta{
  margin-left:auto;
  background:var(--amber); color:var(--amber-ink)!important;
  font-weight:700; padding:9px 16px;
  border-radius:var(--r2);
  font-size:13px;
  border-bottom:0!important;
}
.dp-menubar__nav-cta:hover{ background:var(--amber-2); border-bottom-color:transparent!important; }

/* Compact on scroll */
.dp-menubar.is-compact .dp-menubar__trust{ display:none; }
.dp-menubar.is-compact .dp-menubar__main{ padding:8px var(--shell-pad); }

/* ─────────────────────────────────────────────────────────────────────────
   4. BUTTONS · retail CTAs
───────────────────────────────────────────────────────────────────────── */
.dp-btn,
.dpv6-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 20px;
  font-family:var(--font-body)!important;
  font-size:14px!important; font-weight:600!important;
  letter-spacing:0!important; text-transform:none!important;
  border-radius:var(--r3)!important;
  border:1px solid transparent!important;
  cursor:pointer; text-decoration:none!important;
  transition:all .15s var(--e)!important;
  white-space:nowrap;
}

.dp-btn--primary,
.dpv6-btn--primary,
.dp-btn-amazon{
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
  border-color:var(--amber-2)!important;
  box-shadow:var(--sh-1)!important;
}
.dp-btn--primary:hover,
.dpv6-btn--primary:hover,
.dp-btn-amazon:hover{
  background:var(--amber-2)!important;
  box-shadow:var(--sh-2)!important;
  transform:translateY(-1px)!important;
}
.dp-btn--primary::before,
.dpv6-btn--primary::before{ display:none!important; }

.dp-btn--ghost,
.dpv6-btn--ghost{
  background:var(--bg)!important;
  color:var(--navy)!important;
  border-color:var(--line-2)!important;
}
.dp-btn--ghost:hover,
.dpv6-btn--ghost:hover{
  background:var(--bg-2)!important;
  border-color:var(--navy)!important;
}

.dp-btn--navy{
  background:var(--navy)!important;
  color:#fff!important;
  border-color:var(--navy)!important;
}
.dp-btn--navy:hover{ background:var(--navy-2)!important; }

.dp-btn--lg{ padding:14px 26px!important; font-size:15px!important; }
.dp-btn--sm{ padding:7px 14px!important; font-size:12.5px!important; }

/* Amazon inline CTA (product cards, in-content) */
.dp-amazon-cta,
.dp-cta-amazon{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--amber); color:var(--amber-ink);
  padding:10px 18px; border-radius:var(--r3);
  font-weight:700; font-size:13.5px;
  border:1px solid var(--amber-2);
  box-shadow:var(--sh-1);
  transition:all .15s;
}
.dp-amazon-cta::before{
  content:""; display:inline-block;
  width:16px; height:16px;
  background:currentColor;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M6 8h12l-1 10H7L6 8zm2-3a4 4 0 118 0h-2a2 2 0 10-4 0H8z'/></svg>") no-repeat center/contain;
}
.dp-amazon-cta:hover{ background:var(--amber-2); transform:translateY(-1px); box-shadow:var(--sh-2); }

/* ─────────────────────────────────────────────────────────────────────────
   5. HERO · utility (not editorial)
───────────────────────────────────────────────────────────────────────── */
.dp-hero,
.dpv6-hero,
.dp-v11 .dpv6-hero,
.dp-hero--v11{
  background:var(--bg-2)!important;
  border-bottom:1px solid var(--line)!important;
  padding:48px 0 40px!important;
  margin:0 0 32px!important;
}
.dp-hero-inner,
.dpv6-hero-inner{
  max-width:var(--shell-max)!important;
  margin:0 auto!important;
  padding:0 var(--shell-pad)!important;
  display:grid!important;
  grid-template-columns:minmax(0,1.3fr) minmax(0,1fr)!important;
  gap:48px!important;
  align-items:center!important;
}

.dp-hero__kicker,
.dpv6-hero__kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-body);
  font-size:11.5px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--green);
  background:var(--green-bg);
  padding:5px 10px;
  border-radius:var(--r2);
  margin-bottom:16px;
}
.dp-hero__kicker::before{
  content:"●"; color:var(--green); font-size:10px;
}

.dp-hero h1,
.dp-hero__title,
.dpv6-hero__title{
  font-family:var(--font-display)!important;
  font-size:clamp(32px,5vw,52px)!important;
  font-weight:800!important;
  letter-spacing:-.035em!important;
  line-height:1.05!important;
  color:var(--ink)!important;
  margin:0 0 18px!important;
}

.dp-hero__lead,
.dpv6-hero__lead,
.dpv6-lead{
  font-size:17px!important;
  color:var(--ink-3)!important;
  line-height:1.55!important;
  max-width:560px!important;
  margin:0 0 28px!important;
  font-weight:400!important;
}

.dp-hero__actions,
.dpv6-hero__actions,
.dpv6-actions{
  display:flex!important;
  gap:12px!important;
  flex-wrap:wrap!important;
  margin:0 0 24px!important;
}

/* Hero stats row (social proof) */
.dp-hero__stats{
  display:flex; flex-wrap:wrap; gap:28px;
  padding-top:20px;
  border-top:1px solid var(--line);
  margin-top:24px;
}
.dp-hero__stat strong{
  display:block;
  font-family:var(--font-display);
  font-size:22px; font-weight:800;
  color:var(--navy);
  letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;
}
.dp-hero__stat span{
  display:block;
  font-size:12px; color:var(--ink-3);
  margin-top:2px;
}

/* Hero feature (right column) */
.dp-hero__feature,
.dpv6-hero__feature{
  position:relative;
  border-radius:var(--r5)!important;
  overflow:hidden!important;
  aspect-ratio:4/3!important;
  max-height:440px!important;
  background:var(--bg-3);
  box-shadow:var(--sh-2)!important;
  border:1px solid var(--line)!important;
}
.dp-hero__feature img,
.dp-hero__feature picture,
.dpv6-hero__feature img,
.dpv6-hero__feature picture{
  width:100%; height:100%; object-fit:cover;
  position:absolute; inset:0;
}
.dp-hero__feature::after,
.dpv6-hero__feature::after{
  content:"";
  position:absolute; inset:0; z-index:2;
  background:linear-gradient(180deg, transparent 0%, transparent 45%, rgba(11,30,61,.85) 100%);
}
.dp-hero__feature-body,
.dpv6-hero__feature-body{
  position:absolute; z-index:3;
  inset:auto 0 0 0;
  padding:24px;
  color:#fff;
}
.dp-hero__feature-tag,
.dpv6-hero__feature-tag{
  display:inline-block;
  background:var(--amber);
  color:var(--amber-ink);
  padding:3px 8px;
  font-size:10.5px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  border-radius:var(--r2);
  margin-bottom:10px;
}
.dp-hero__feature-title,
.dpv6-hero__feature-title{
  font-family:var(--font-display);
  font-size:clamp(18px,2.2vw,24px);
  font-weight:700;
  color:#fff!important;
  margin:0 0 12px;
  line-height:1.25;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}

/* ─────────────────────────────────────────────────────────────────────────
   6. SECTION HEADERS
───────────────────────────────────────────────────────────────────────── */
.dp-section,
.dpv6-section{
  padding:48px 0!important;
  background:var(--bg)!important;
  border:0!important;
}
.dp-section--tinted,
.dpv6-section--tinted,
.dpv6-section--best-of{
  background:var(--bg-2)!important;
  border-top:1px solid var(--line)!important;
  border-bottom:1px solid var(--line)!important;
}

.dp-section-head,
.dpv6-section-head{
  display:flex!important;
  align-items:flex-end!important;
  justify-content:space-between!important;
  margin:0 0 28px!important;
  gap:20px!important;
  border-bottom:2px solid var(--ink)!important;
  padding:0 0 14px!important;
  max-width:var(--shell-max);
}
.dp-section-head h2,
.dpv6-section-head h2{
  font-family:var(--font-display)!important;
  font-size:26px!important;
  font-weight:800!important;
  color:var(--ink)!important;
  letter-spacing:-.02em!important;
  font-style:normal!important;
  margin:0!important;
}
.dp-section-head h2::after,
.dpv6-section-head h2::after{ display:none!important; }
.dp-section-head p,
.dpv6-section-head p{
  font-size:14px!important;
  color:var(--ink-3)!important;
  font-family:var(--font-body)!important;
}
.dp-section-head a,
.dpv6-section-head a{
  color:var(--blue-link)!important;
  font-family:var(--font-body)!important;
  font-size:13.5px!important;
  font-weight:600!important;
  letter-spacing:0!important;
  text-transform:none!important;
  white-space:nowrap;
}
.dp-section-head a:hover,
.dpv6-section-head a:hover{ color:var(--blue-link-hover)!important; text-decoration:underline!important; }

.dp-kicker,
.dpv6-panel-kicker,
.dpv6-kicker{
  display:inline-block;
  font-family:var(--font-body)!important;
  font-size:11px!important;
  font-weight:700!important;
  letter-spacing:.12em!important;
  text-transform:uppercase!important;
  color:var(--navy)!important;
  background:var(--bg-3);
  padding:4px 9px;
  border-radius:var(--r2);
  margin-bottom:10px!important;
}

/* ─────────────────────────────────────────────────────────────────────────
   7. PRODUCT CARDS · THE CORE COMPONENT
───────────────────────────────────────────────────────────────────────── */
.dp-product-card,
.dpv6-product-card,
.product-card{
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--r4);
  overflow:hidden;
  transition:box-shadow .2s var(--e), border-color .2s, transform .2s;
  display:flex; flex-direction:column;
  position:relative;
}
.dp-product-card:hover,
.dpv6-product-card:hover{
  box-shadow:var(--sh-3);
  border-color:var(--line-strong);
  transform:translateY(-2px);
}

.dp-product-card__badge,
.dpv6-product-card__badge{
  position:absolute; top:12px; left:12px; z-index:5;
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 9px;
  font-size:11px; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase;
  background:var(--badge-bestseller);
  color:#fff;
  border-radius:var(--r2);
  box-shadow:var(--sh-1);
}
.dp-product-card__badge--editors{ background:var(--badge-editors); }
.dp-product-card__badge--deal{ background:var(--badge-deal); }
.dp-product-card__badge--best{ background:var(--green); }

.dp-product-card__image,
.dpv6-product-card__image{
  background:#fff;
  aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center;
  padding:18px;
  border-bottom:1px solid var(--line);
  position:relative;
}
.dp-product-card__image img,
.dpv6-product-card__image img{
  max-width:100%; max-height:100%;
  object-fit:contain;
  transition:transform .3s var(--e);
}
.dp-product-card:hover .dp-product-card__image img{ transform:scale(1.05); }

.dp-product-card__body,
.dpv6-product-card__body{
  padding:16px 18px 18px;
  display:flex; flex-direction:column;
  flex:1;
}

.dp-product-card__brand,
.dpv6-product-card__brand{
  font-size:11px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--ink-4);
  margin-bottom:4px;
}

.dp-product-card__title,
.dpv6-product-card__title{
  font-family:var(--font-display);
  font-size:15px; font-weight:600;
  color:var(--ink);
  line-height:1.35;
  margin:0 0 10px;
  display:-webkit-box;
  -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.dp-product-card__title a{ color:inherit; text-decoration:none; }
.dp-product-card__title a:hover{ color:var(--navy); }

.dp-product-card__rating,
.dpv6-product-card__rating{
  display:flex; align-items:center; gap:6px;
  margin:0 0 10px;
  font-size:12.5px;
}
.dp-stars{
  color:var(--star);
  font-size:14px;
  letter-spacing:1px;
  white-space:nowrap;
}
.dp-product-card__reviews{
  color:var(--blue-link);
  font-weight:600;
  font-size:12px;
}

.dp-product-card__price-row,
.dpv6-product-card__price-row{
  display:flex; align-items:baseline; gap:8px; flex-wrap:wrap;
  margin:6px 0 14px;
}
.dp-price-old,
.dpv6-price-old{
  color:var(--ink-4);
  text-decoration:line-through;
  font-size:13px;
  font-variant-numeric:tabular-nums;
}
.dp-price,
.dpv6-price{
  font-family:var(--font-num);
  font-size:22px; font-weight:800;
  color:var(--ink);
  letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.dp-price sup{ font-size:13px; font-weight:600; vertical-align:top; top:-.2em; margin-left:1px; }
.dp-price-discount,
.dpv6-price-discount{
  display:inline-flex; align-items:center;
  padding:2px 7px;
  background:var(--red-bg);
  color:var(--red);
  font-size:12px; font-weight:700;
  border-radius:var(--r2);
  font-variant-numeric:tabular-nums;
}

.dp-product-card__pros{
  font-size:13px;
  color:var(--ink-3);
  margin:0 0 14px;
  padding:0;
  list-style:none;
}
.dp-product-card__pros li{
  display:flex; align-items:flex-start; gap:6px;
  margin-bottom:4px;
  color:var(--ink-3);
}
.dp-product-card__pros li::before{
  content:"✓"; color:var(--green); font-weight:700; flex-shrink:0;
}

.dp-product-card__cta-row{
  margin-top:auto;
  padding-top:12px;
  border-top:1px dashed var(--line-2);
  display:flex; gap:8px;
}
.dp-product-card__cta-row .dp-btn--primary{ flex:1; }

.dp-product-card__shipping{
  font-size:11.5px;
  color:var(--green);
  margin-top:8px;
  display:flex; align-items:center; gap:5px;
}

/* Grid for product cards */
.dp-product-grid,
.dpv6-product-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:20px;
}
@media (max-width:1024px){ .dp-product-grid,.dpv6-product-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:720px){ .dp-product-grid,.dpv6-product-grid{ grid-template-columns:repeat(2,1fr); gap:12px; } }
@media (max-width:440px){ .dp-product-grid,.dpv6-product-grid{ grid-template-columns:1fr; } }

/* ─────────────────────────────────────────────────────────────────────────
   8. STORY / ARTICLE CARDS (guides, blog posts)
───────────────────────────────────────────────────────────────────────── */
.dpv6-story-card,
.dpv6-story-card--feature,
.dpv6-story-card--grid,
.dpv6-story-card--compact{
  background:var(--bg)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r4)!important;
  overflow:hidden!important;
  transition:box-shadow .2s var(--e), border-color .2s, transform .2s!important;
  box-shadow:none!important;
  position:relative;
}
.dpv6-story-card:hover,
.dpv6-story-card--feature:hover,
.dpv6-story-card--grid:hover,
.dpv6-story-card--compact:hover{
  box-shadow:var(--sh-3)!important;
  border-color:var(--line-strong)!important;
  transform:translateY(-2px)!important;
}

.dpv6-story-link{ display:block!important; color:inherit!important; text-decoration:none!important; height:100%!important; }

.dpv6-story-media{
  background:var(--bg-3)!important;
  aspect-ratio:16/10!important;
  overflow:hidden!important;
  position:relative;
}
.dpv6-story-media img{
  width:100%; height:100%;
  object-fit:cover;
  transition:transform .4s var(--e);
}
.dpv6-story-card:hover .dpv6-story-media img{ transform:scale(1.04); }

.dpv6-story-content{
  padding:18px 20px 20px!important;
}

.dpv6-story-meta{
  display:flex!important; flex-wrap:wrap!important;
  align-items:center!important; gap:10px!important;
  margin:0 0 10px!important;
  font-size:11.5px!important;
  font-family:var(--font-body)!important;
  letter-spacing:0!important;
  text-transform:none!important;
  color:var(--ink-4)!important;
}
.dpv6-story-meta span:not(.dpv6-story-taxonomy){
  color:var(--ink-4)!important;
  font-weight:400!important;
}

.dpv6-story-taxonomy,
.dp-v11 .dpv6-story-taxonomy,
.dpv6-bestof-card .dpv6-story-taxonomy,
.dpv6-story-meta--hero .dpv6-story-taxonomy{
  display:inline-flex; align-items:center;
  background:var(--navy)!important;
  color:#fff!important;
  border:0!important;
  border-radius:var(--r2)!important;
  padding:3px 8px!important;
  font-family:var(--font-body)!important;
  font-size:10.5px!important;
  font-weight:700!important;
  letter-spacing:.04em!important;
  text-transform:uppercase!important;
  text-decoration:none!important;
}
.dpv6-story-taxonomy:hover,
.dp-v11 .dpv6-story-taxonomy:hover{
  background:var(--navy-2)!important;
  color:#fff!important;
}

.dpv6-story-card h3,
.dpv6-story-content h3{
  font-family:var(--font-display)!important;
  font-size:16px!important;
  font-weight:700!important;
  letter-spacing:-.015em!important;
  color:var(--ink)!important;
  line-height:1.3!important;
  margin:0 0 8px!important;
  display:-webkit-box;
  -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}

.dpv6-story-card p,
.dpv6-story-content p{
  font-size:13.5px!important;
  color:var(--ink-3)!important;
  line-height:1.55!important;
  font-family:var(--font-body)!important;
  margin:0!important;
  display:-webkit-box;
  -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

.dpv6-story-cta,
.dpv6-category-copy .dpv6-story-cta{
  display:inline-flex; align-items:center; gap:4px;
  margin-top:12px!important;
  color:var(--blue-link)!important;
  font-family:var(--font-body)!important;
  font-size:13px!important;
  font-weight:600!important;
  letter-spacing:0!important;
  text-transform:none!important;
}
.dpv6-story-cta::after{ content:"→"; transition:transform .15s; }
.dpv6-story-card:hover .dpv6-story-cta::after{ transform:translateX(3px); }

.dpv6-story-card--feature .dpv6-story-media{ aspect-ratio:16/9!important; }
.dpv6-story-card--feature h3{ font-size:20px!important; -webkit-line-clamp:3!important; }

.dpv6-story-card--compact .dpv6-story-link{
  display:grid!important;
  grid-template-columns:110px 1fr!important;
}
.dpv6-story-card--compact .dpv6-story-media{
  width:110px!important; aspect-ratio:1!important; min-height:auto!important;
}
.dpv6-story-card--compact .dpv6-story-content{ padding:12px 16px!important; }
.dpv6-story-card--compact h3{ font-size:14px!important; }
.dpv6-story-card--compact p{ display:none!important; }

/* ─────────────────────────────────────────────────────────────────────────
   9. BEST-OF HUB (numbered rankings)
───────────────────────────────────────────────────────────────────────── */
.dpv6-bestof-grid{
  display:grid!important;
  grid-template-columns:repeat(3,1fr)!important;
  gap:20px!important;
}
@media (max-width:900px){ .dpv6-bestof-grid{ grid-template-columns:repeat(2,1fr)!important; } }
@media (max-width:600px){ .dpv6-bestof-grid{ grid-template-columns:1fr!important; } }

.dpv6-bestof-card{
  background:var(--bg)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r4)!important;
  padding:24px!important;
  box-shadow:none!important;
  transition:box-shadow .2s, border-color .2s, transform .2s!important;
  display:flex!important; flex-direction:column!important;
  position:relative;
}
.dpv6-bestof-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--amber) 0%, var(--navy) 100%);
  border-radius:var(--r4) var(--r4) 0 0;
}
.dpv6-bestof-card:hover{
  box-shadow:var(--sh-3)!important;
  border-color:var(--line-strong)!important;
  transform:translateY(-3px)!important;
}

.dpv6-bestof-head{
  display:flex!important;
  align-items:center!important;
  gap:14px!important;
  margin:4px 0 14px!important;
  padding:0!important;
  border:0!important;
}

.dpv6-bestof-index{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px!important; height:42px!important;
  background:var(--navy)!important;
  color:#fff!important;
  font-family:var(--font-display)!important;
  font-size:18px!important;
  font-weight:800!important;
  font-style:normal!important;
  border-radius:var(--r3)!important;
  letter-spacing:-.01em!important;
  flex-shrink:0;
  line-height:1!important;
}

.dpv6-bestof-head h3{
  font-family:var(--font-display)!important;
  font-size:16px!important;
  font-weight:700!important;
  font-style:normal!important;
  letter-spacing:-.015em!important;
  color:var(--ink)!important;
  line-height:1.3!important;
  margin:0!important;
}
.dpv6-bestof-head h3 a{ color:inherit!important; text-decoration:none!important; }
.dpv6-bestof-head h3 a:hover{ color:var(--blue-link)!important; }

.dpv6-bestof-summary,
.dpv6-bestof-lead{
  color:var(--ink-3)!important;
  font-family:var(--font-body)!important;
  font-size:13.5px!important;
  line-height:1.6!important;
  margin:0 0 14px!important;
}

.dpv6-bestof-actions{ margin-top:auto!important; }
.dpv6-bestof-actions .dpv6-btn{
  width:100%;
  justify-content:center;
}

/* ─────────────────────────────────────────────────────────────────────────
   10. SINGLE ARTICLE · centered prose + sticky sidebar
───────────────────────────────────────────────────────────────────────── */
.dpv6-single-hero{
  display:grid!important;
  grid-template-columns:minmax(0,1.4fr) minmax(0,1fr)!important;
  gap:40px!important;
  padding:40px 0 32px!important;
  border-bottom:1px solid var(--line)!important;
  margin-bottom:32px!important;
}

.dpv6-single-hero h1{
  font-family:var(--font-display)!important;
  font-size:clamp(28px,4vw,44px)!important;
  font-weight:800!important;
  letter-spacing:-.03em!important;
  line-height:1.1!important;
  color:var(--ink)!important;
  margin:12px 0 16px!important;
  font-style:normal!important;
}

.dpv6-single-hero .dpv6-lead{
  font-size:17px!important;
  color:var(--ink-2)!important;
  line-height:1.55!important;
  font-weight:400!important;
  margin:0 0 22px!important;
}

.dpv6-story-meta--hero{
  display:flex!important;
  flex-wrap:wrap!important;
  align-items:center!important;
  gap:10px!important;
  font-family:var(--font-body)!important;
  font-size:12px!important;
  color:var(--ink-4)!important;
  text-transform:none!important;
  letter-spacing:0!important;
}

.dpv6-single-media{ border-radius:var(--r4)!important; overflow:hidden!important; }
.dpv6-single-media img{ width:100%; height:100%; object-fit:cover; }

/* Two-col layout */
.dpv6-single-layout{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) 320px!important;
  gap:48px!important;
  padding:0 0 40px!important;
}
@media (max-width:980px){ .dpv6-single-layout{ grid-template-columns:1fr!important; } }

.dpv6-article-prose{
  font-family:var(--font-body)!important;
  font-size:16.5px!important;
  line-height:1.75!important;
  color:var(--ink-2)!important;
  max-width:none!important;
}
.dpv6-article-prose p{
  color:var(--ink-2)!important;
  margin:0 0 1.2em!important;
  font-family:var(--font-body)!important;
  font-style:normal!important;
}
.dpv6-article-prose p:first-of-type::first-letter{
  /* Remove dropcaps — commerce site, not mag */
  font-size:inherit!important; font-weight:inherit!important;
  color:inherit!important; float:none!important;
  padding:0!important; line-height:inherit!important;
  font-family:inherit!important;
}
.dpv6-article-prose h2{
  font-size:24px!important;
  font-weight:800!important;
  margin:2em 0 .6em!important;
  padding:0 0 8px!important;
  border-bottom:2px solid var(--ink)!important;
  color:var(--ink)!important;
  letter-spacing:-.02em!important;
  font-style:normal!important;
}
.dpv6-article-prose h3{
  font-size:19px!important;
  font-weight:700!important;
  margin:1.6em 0 .5em!important;
  color:var(--ink)!important;
  letter-spacing:-.015em!important;
  font-style:normal!important;
}
.dpv6-article-prose h4{
  font-size:16px!important;
  font-weight:700!important;
  color:var(--navy)!important;
  margin:1.4em 0 .4em!important;
}
.dpv6-article-prose a{ color:var(--blue-link)!important; text-decoration:underline!important; text-underline-offset:2px!important; }
.dpv6-article-prose a:hover{ color:var(--blue-link-hover)!important; }
.dpv6-article-prose ul,
.dpv6-article-prose ol{
  margin:.6em 0 1.2em 0!important;
  padding-left:1.4em!important;
}
.dpv6-article-prose ul li,
.dpv6-article-prose ol li{
  margin:.3em 0!important;
  color:var(--ink-2)!important;
  line-height:1.65!important;
}
.dpv6-article-prose blockquote{
  margin:1.4em 0!important;
  padding:16px 20px!important;
  background:var(--bg-2)!important;
  border-left:4px solid var(--amber)!important;
  border-radius:var(--r3)!important;
  color:var(--ink-2)!important;
  font-style:normal!important;
  font-size:15.5px!important;
}
.dpv6-article-prose table,
.dpv6-article-prose .tablepress{
  width:100%!important;
  border-collapse:collapse!important;
  margin:1.4em 0!important;
  font-size:14px!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r3)!important;
  overflow:hidden;
}
.dpv6-article-prose th{
  background:var(--bg-2)!important;
  color:var(--ink)!important;
  font-weight:700!important;
  padding:12px 14px!important;
  text-align:left!important;
  border-bottom:2px solid var(--line-2)!important;
  font-size:12.5px!important;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.dpv6-article-prose td{
  padding:12px 14px!important;
  border-bottom:1px solid var(--line)!important;
  color:var(--ink-2)!important;
}
.dpv6-article-prose tr:last-child td{ border-bottom:0!important; }
.dpv6-article-prose tr:hover td{ background:var(--bg-2)!important; }

/* Sidebar */
.dpv6-sidecar{
  display:flex; flex-direction:column; gap:20px;
  position:sticky; top:90px; align-self:start;
}
.dpv6-sidecard{
  background:var(--bg)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r4)!important;
  padding:20px!important;
  box-shadow:var(--sh-1)!important;
}
.dpv6-sidecard h3{
  font-family:var(--font-display)!important;
  font-size:15px!important;
  font-weight:700!important;
  color:var(--ink)!important;
  margin:0 0 12px!important;
  letter-spacing:-.01em!important;
  font-style:normal!important;
}

.dpv6-side-list{ list-style:none; padding:0; margin:0; font-size:13px; }
.dpv6-side-list li{
  display:flex; justify-content:space-between;
  padding:8px 0;
  border-bottom:1px solid var(--line);
}
.dpv6-side-list li:last-child{ border-bottom:0; }
.dpv6-side-list span{ color:var(--ink-3); }
.dpv6-side-list strong{ color:var(--ink); font-weight:600; }

.dpv6-related-mini{ list-style:none; padding:0; margin:0; font-size:13px; }
.dpv6-related-mini li{
  padding:8px 0;
  border-bottom:1px solid var(--line);
}
.dpv6-related-mini li:last-child{ border-bottom:0; }
.dpv6-related-mini a{ color:var(--ink-2)!important; line-height:1.4; }
.dpv6-related-mini a:hover{ color:var(--blue-link)!important; }

.dpv6-sidecard--bestof{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%)!important;
  color:#fff!important;
  border-color:var(--navy)!important;
}
.dpv6-sidecard--bestof h3{ color:#fff!important; }
.dpv6-sidecard--bestof p{ color:rgba(255,255,255,.85)!important; font-size:13px; line-height:1.5; }
.dpv6-sidecard--bestof .dpv6-btn--ghost{
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
  border-color:var(--amber)!important;
}
.dpv6-sidecard--bestof .dpv6-btn--ghost:hover{
  background:var(--amber-2)!important;
}
.dpv6-sidecard--bestof .dpv6-panel-kicker{
  background:rgba(255,255,255,.12)!important;
  color:#fff!important;
}

.dpv6-sidecard--cta{
  background:var(--bg-2)!important;
  border-color:var(--line)!important;
}
.dpv6-sidecard--cta h3{ color:var(--ink)!important; }
.dpv6-sidecard--cta p{ color:var(--ink-3); font-size:13px; line-height:1.55; }

/* Related articles grid at bottom */
.dpv6-related-articles{
  padding:40px 0;
  border-top:1px solid var(--line);
}
.dpv6-related-articles__header{
  display:flex; align-items:flex-end; justify-content:space-between;
  border-bottom:2px solid var(--ink)!important;
  padding:0 0 14px!important;
  margin:0 0 28px!important;
}
.dpv6-related-articles__title{
  font-family:var(--font-display)!important;
  font-size:22px!important;
  font-weight:800!important;
  color:var(--ink)!important;
  margin:0!important;
  font-style:normal!important;
  letter-spacing:-.02em!important;
}
.dpv6-related-articles__more{
  color:var(--blue-link)!important;
  font-size:13.5px!important;
  font-weight:600!important;
}
.dpv6-related-articles__grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
}
@media (max-width:1024px){ .dpv6-related-articles__grid{ grid-template-columns:repeat(2, 1fr); } }
@media (max-width:600px){ .dpv6-related-articles__grid{ grid-template-columns:1fr; } }

.dpv6-related-card{
  background:var(--bg)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r4)!important;
  overflow:hidden!important;
  text-decoration:none!important;
  color:inherit!important;
  transition:box-shadow .2s, border-color .2s, transform .2s!important;
  display:flex; flex-direction:column;
}
.dpv6-related-card:hover{
  box-shadow:var(--sh-3)!important;
  border-color:var(--line-strong)!important;
  transform:translateY(-2px)!important;
}
.dpv6-related-card__img{ aspect-ratio:16/10; background:var(--bg-3); overflow:hidden; }
.dpv6-related-card__img img{ width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.dpv6-related-card:hover .dpv6-related-card__img img{ transform:scale(1.04); }
.dpv6-related-card__body{ padding:14px 16px 16px; display:flex; flex-direction:column; flex:1; }
.dpv6-related-card__cat{
  display:inline-block;
  background:var(--navy); color:#fff;
  font-size:10.5px; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase;
  padding:3px 7px;
  border-radius:var(--r2);
  margin-bottom:8px;
  width:fit-content;
}
.dpv6-related-card__title{
  font-family:var(--font-display)!important;
  font-size:14.5px!important;
  font-weight:700!important;
  color:var(--ink)!important;
  line-height:1.35!important;
  margin:0 0 10px!important;
  display:-webkit-box;
  -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}
.dpv6-related-card__cta{
  margin-top:auto;
  color:var(--blue-link);
  font-size:12.5px;
  font-weight:600;
}

/* Single article actions */
.dpv6-single-article .dpv6-actions .dpv6-btn--primary{
  background:var(--amber)!important; color:var(--amber-ink)!important;
}
.dpv6-single-article .dpv6-actions .dpv6-btn--ghost{
  background:var(--bg)!important; color:var(--navy)!important; border-color:var(--line-2)!important;
}

/* ─────────────────────────────────────────────────────────────────────────
   11. BREADCRUMBS
───────────────────────────────────────────────────────────────────────── */
.dp-breadcrumbs,
.dpv6-breadcrumbs{
  padding:14px 0!important;
  font-size:12.5px!important;
  color:var(--ink-4)!important;
  font-family:var(--font-body)!important;
}
.dp-breadcrumbs a,
.dpv6-breadcrumbs a{
  color:var(--ink-3)!important;
  text-decoration:none!important;
}
.dp-breadcrumbs a:hover{ color:var(--blue-link)!important; text-decoration:underline!important; }
.dp-breadcrumbs .sep,
.dpv6-breadcrumbs .sep{ margin:0 8px; color:var(--ink-5); }

/* ─────────────────────────────────────────────────────────────────────────
   12. FILTER BAR (category archive)
───────────────────────────────────────────────────────────────────────── */
.dp-filter-bar,
.dpv6-filter-bar{
  display:flex; flex-wrap:wrap;
  gap:12px; align-items:center;
  padding:14px 18px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--r4);
  margin:0 0 28px;
}
.dp-filter-label{
  font-size:12px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3);
  margin-right:4px;
}
.dp-filter-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 12px;
  border:1px solid var(--line-2);
  border-radius:999px;
  background:var(--bg);
  color:var(--ink-2);
  font-size:12.5px; font-weight:500;
  cursor:pointer;
  transition:all .15s;
}
.dp-filter-chip:hover{ border-color:var(--navy); color:var(--navy); }
.dp-filter-chip.is-active{
  background:var(--navy); color:#fff; border-color:var(--navy);
}

/* ─────────────────────────────────────────────────────────────────────────
   13. NEWSLETTER
───────────────────────────────────────────────────────────────────────── */
.dpv6-newsletter{
  background:var(--navy)!important;
  color:#fff!important;
  border-radius:var(--r5)!important;
  padding:44px 40px!important;
  display:grid!important;
  grid-template-columns:1.2fr 1fr!important;
  gap:32px!important;
  align-items:center!important;
  margin:40px auto!important;
  max-width:var(--shell-max);
  position:relative;
  overflow:hidden;
}
.dpv6-newsletter::before{
  content:""; position:absolute;
  top:-80px; right:-80px;
  width:240px; height:240px;
  background:var(--amber);
  border-radius:50%;
  opacity:.1;
}
.dpv6-newsletter-copy .dpv6-panel-kicker,
.dpv6-newsletter .dpv6-panel-kicker{
  background:rgba(255,255,255,.1)!important;
  color:var(--amber)!important;
}
.dpv6-newsletter h2,
.dpv6-newsletter h3{
  color:#fff!important;
  font-size:26px!important;
  font-weight:800!important;
  letter-spacing:-.02em!important;
  margin:0 0 10px!important;
}
.dpv6-newsletter p{
  color:rgba(255,255,255,.8)!important;
  font-size:15px!important;
  line-height:1.55!important;
}
.dpv6-newsletter input[type="email"]{
  background:#fff!important;
  border:0!important;
  padding:14px 16px!important;
  border-radius:var(--r3)!important;
  font-size:14px!important;
  color:var(--ink)!important;
  width:100%;
}
.dpv6-newsletter button,
.dpv6-newsletter .dpv6-btn--primary{
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
  padding:14px 22px!important;
  font-weight:700!important;
  border:0!important;
  border-radius:var(--r3)!important;
  cursor:pointer;
}
.dpv6-newsletter button:hover{ background:var(--amber-2)!important; }
@media (max-width:820px){ .dpv6-newsletter{ grid-template-columns:1fr!important; padding:32px 24px!important; } }

/* ─────────────────────────────────────────────────────────────────────────
   14. FOOTER
───────────────────────────────────────────────────────────────────────── */
.site-footer{
  background:var(--ink)!important;
  color:rgba(255,255,255,.75)!important;
  padding:48px 0 20px!important;
  border:0!important;
  margin-top:64px!important;
  font-family:var(--font-body)!important;
}
.site-footer .dp-shell,
.site-footer .grid-container{ color:rgba(255,255,255,.75)!important; }
.site-footer h3, .site-footer h4, .site-footer .dp-footer-col-title{
  color:#fff!important;
  font-size:13px!important;
  font-weight:700!important;
  letter-spacing:.04em!important;
  text-transform:uppercase!important;
  margin:0 0 14px!important;
  font-style:normal!important;
}
.site-footer a{
  color:rgba(255,255,255,.7)!important;
  text-decoration:none!important;
  font-size:13.5px!important;
}
.site-footer a:hover{ color:var(--amber)!important; }
.site-footer .site-info, .site-footer .copyright-bar{
  border-top:1px solid rgba(255,255,255,.1)!important;
  padding-top:16px!important;
  margin-top:28px!important;
  font-size:12px!important;
  color:rgba(255,255,255,.5)!important;
}

/* ─────────────────────────────────────────────────────────────────────────
   15. SEARCH OVERLAY
───────────────────────────────────────────────────────────────────────── */
#dp-search-overlay,
.dp-search-overlay{
  position:fixed; inset:0; z-index:1000;
  background:rgba(11,30,61,.7);
  backdrop-filter:blur(8px);
  display:none;
  align-items:flex-start; justify-content:center;
  padding:80px 20px 20px;
}
#dp-search-overlay.is-open{ display:flex; }
.dp-search-box{
  background:var(--bg);
  border-radius:var(--r4);
  width:100%; max-width:680px;
  box-shadow:var(--sh-3);
  overflow:hidden;
}
.dp-search-input-wrap{
  display:flex; align-items:center;
  padding:14px 18px;
  border-bottom:1px solid var(--line);
}
.dp-search-input-wrap::before{
  content:"⌕"; font-size:20px; color:var(--ink-3); margin-right:10px;
}
#dp-search-input,
.dp-search-input{
  flex:1; border:0; outline:0;
  font-size:17px; font-family:var(--font-body);
  background:transparent; color:var(--ink);
}
.dp-search-input::placeholder{ color:var(--ink-4); }
.dp-search-close{
  background:var(--bg-2); border:0;
  width:32px; height:32px; border-radius:50%;
  cursor:pointer; color:var(--ink-3);
}
.dp-search-close:hover{ background:var(--bg-3); color:var(--ink); }
.dp-search-results{
  max-height:420px; overflow-y:auto;
  padding:8px 0;
}
.dp-search-result-item{
  display:flex; align-items:center; gap:12px;
  padding:12px 18px;
  text-decoration:none;
  color:var(--ink-2);
  transition:background .12s;
}
.dp-search-result-item:hover{
  background:var(--bg-2); color:var(--ink);
}
.dp-search-result-item strong{ color:var(--navy); font-weight:600; }

/* ─────────────────────────────────────────────────────────────────────────
   16. DARK MODE TOGGLE
───────────────────────────────────────────────────────────────────────── */
#dp-dm-toggle{
  position:fixed!important;
  bottom:20px!important; right:20px!important;
  width:44px!important; height:44px!important;
  border-radius:50%!important;
  background:var(--bg)!important;
  border:1px solid var(--line-2)!important;
  color:var(--ink)!important;
  cursor:pointer!important;
  z-index:800!important;
  display:flex!important; align-items:center!important; justify-content:center!important;
  box-shadow:var(--sh-2)!important;
  font-size:18px!important;
  padding:0!important;
  transition:all .2s var(--e)!important;
}
#dp-dm-toggle:hover{
  transform:translateY(-2px) rotate(15deg)!important;
  background:var(--navy)!important;
  color:#fff!important;
  border-color:var(--navy)!important;
  box-shadow:var(--sh-3)!important;
}

/* ─────────────────────────────────────────────────────────────────────────
   17. GDPR / CONSENT
───────────────────────────────────────────────────────────────────────── */
#dp-gdpr{
  position:fixed;
  bottom:20px; left:20px; right:20px;
  max-width:420px;
  background:var(--bg)!important;
  border:1px solid var(--line-2)!important;
  border-radius:var(--r4)!important;
  padding:18px 20px!important;
  box-shadow:var(--sh-3)!important;
  z-index:850;
  font-size:13.5px;
  color:var(--ink-2);
}
#dp-gdpr a{ color:var(--blue-link)!important; }
.dp-gdpr-accept{
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
  border:0!important;
  padding:8px 16px!important;
  border-radius:var(--r3)!important;
  font-weight:700!important;
  cursor:pointer;
}
.dp-gdpr-decline{
  background:transparent!important;
  color:var(--ink-3)!important;
  border:1px solid var(--line-2)!important;
  padding:8px 16px!important;
  border-radius:var(--r3)!important;
  cursor:pointer;
}

/* ─────────────────────────────────────────────────────────────────────────
   18. CATEGORY / CATALOG
───────────────────────────────────────────────────────────────────────── */
.dpv6-categories-catalog,
.dpv6-cat-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
@media (max-width:980px){ .dpv6-categories-catalog,.dpv6-cat-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px){ .dpv6-categories-catalog,.dpv6-cat-grid{ grid-template-columns:1fr; } }

.dpv6-category-tile,
.dp-category-card{
  background:var(--bg)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r4)!important;
  overflow:hidden!important;
  text-decoration:none!important;
  color:inherit!important;
  transition:box-shadow .2s, border-color .2s, transform .2s!important;
  box-shadow:none!important;
}
.dpv6-category-tile:hover,
.dp-category-card:hover{
  box-shadow:var(--sh-3)!important;
  border-color:var(--line-strong)!important;
  transform:translateY(-2px)!important;
}
.dpv6-category-tile__img,
.dp-category-card__img{
  aspect-ratio:16/10;
  background:var(--bg-3);
  overflow:hidden;
}
.dpv6-category-tile__img img{ width:100%; height:100%; object-fit:cover; }
.dpv6-category-copy,
.dp-category-card__body{
  padding:18px 20px 20px;
}
.dpv6-category-copy h3{
  font-family:var(--font-display)!important;
  font-size:17px!important;
  font-weight:700!important;
  color:var(--ink)!important;
  margin:0 0 6px!important;
  letter-spacing:-.015em!important;
  font-style:normal!important;
}
.dpv6-category-copy p{
  font-size:13px!important;
  color:var(--ink-3)!important;
  line-height:1.5!important;
  margin:0 0 10px!important;
}

/* ─────────────────────────────────────────────────────────────────────────
   19. PAGE HEROES (archives, blog, static pages)
───────────────────────────────────────────────────────────────────────── */
.dpv6-page-hero,
.dpv6-category-hero{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%)!important;
  color:#fff!important;
  padding:56px 0 48px!important;
  border:0!important;
  position:relative;
  overflow:hidden;
}
.dpv6-page-hero::before{
  content:""; position:absolute;
  top:-60px; right:-60px;
  width:300px; height:300px;
  background:var(--amber);
  border-radius:50%;
  opacity:.08;
  pointer-events:none;
}
.dpv6-page-hero-inner,
.dpv6-category-hero-inner{
  max-width:var(--shell-max)!important;
  margin:0 auto!important;
  padding:0 var(--shell-pad)!important;
  position:relative; z-index:2;
}
.dpv6-page-hero h1,
.dpv6-category-hero h1{
  color:#fff!important;
  font-size:clamp(30px,4vw,44px)!important;
  font-weight:800!important;
  letter-spacing:-.03em!important;
  margin:10px 0 14px!important;
  font-style:normal!important;
}
.dpv6-page-hero p,
.dpv6-category-hero p,
.dpv6-page-hero .dpv6-lead{
  color:rgba(255,255,255,.85)!important;
  font-size:16px!important;
  line-height:1.55!important;
  margin:0!important;
  max-width:620px;
  font-weight:400!important;
}
.dpv6-page-hero .dpv6-panel-kicker,
.dpv6-category-hero .dpv6-panel-kicker{
  background:rgba(255,255,255,.1)!important;
  color:var(--amber)!important;
}

.dpv6-stat-pill{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px;
  background:rgba(255,255,255,.1);
  border-radius:999px;
  font-size:12px; font-weight:500;
  color:rgba(255,255,255,.9);
}

/* ─────────────────────────────────────────────────────────────────────────
   20. PAGINATION
───────────────────────────────────────────────────────────────────────── */
.dpv6-pagination,
.pagination,
.nav-links{
  display:flex; gap:6px; justify-content:center;
  padding:32px 0;
}
.dpv6-pagination a,
.dpv6-pagination span,
.pagination a, .pagination span,
.nav-links a, .nav-links span{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:38px; height:38px; padding:0 12px;
  background:var(--bg)!important;
  border:1px solid var(--line-2)!important;
  border-radius:var(--r3)!important;
  color:var(--ink-2)!important;
  font-family:var(--font-body)!important;
  font-size:13px!important; font-weight:600!important;
  text-decoration:none!important;
  transition:all .15s;
}
.dpv6-pagination a:hover,
.pagination a:hover,
.nav-links a:hover{
  background:var(--navy)!important; color:#fff!important; border-color:var(--navy)!important;
}
.dpv6-pagination .current,
.pagination .current,
.nav-links .current{
  background:var(--navy)!important; color:#fff!important; border-color:var(--navy)!important;
}

/* ─────────────────────────────────────────────────────────────────────────
   21. WINNER BOX (dp_winner_box shortcode)
───────────────────────────────────────────────────────────────────────── */
.dp-winner-box,
.dpv6-winner-box{
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%)!important;
  color:#fff!important;
  padding:28px!important;
  border-radius:var(--r4)!important;
  margin:28px 0!important;
  border:0!important;
  position:relative;
  overflow:hidden;
}
.dp-winner-box::before{
  content:"NOTRE CHOIX";
  position:absolute; top:0; right:0;
  background:var(--amber);
  color:var(--amber-ink);
  font-size:11px; font-weight:800;
  letter-spacing:.1em;
  padding:6px 14px;
  border-radius:0 0 0 var(--r3);
}
.dp-winner-box h3,
.dpv6-winner-box h3{ color:#fff!important; }
.dp-winner-box p{ color:rgba(255,255,255,.85)!important; }
.dp-winner-box .dp-btn--primary,
.dp-winner-box a.button{
  background:var(--amber)!important; color:var(--amber-ink)!important;
}

/* Pros/cons (dp_pros_cons shortcode) */
.dp-pros-cons,
.dpv6-pros-cons{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin:20px 0;
}
@media (max-width:640px){ .dp-pros-cons,.dpv6-pros-cons{ grid-template-columns:1fr; } }
.dp-pros,
.dp-cons{
  padding:16px 18px;
  border-radius:var(--r3);
  border:1px solid var(--line);
}
.dp-pros{ background:var(--green-bg); border-color:rgba(4,122,63,.2); }
.dp-cons{ background:var(--red-bg); border-color:rgba(217,30,24,.2); }
.dp-pros h4, .dp-cons h4{
  font-size:13px!important; font-weight:700!important;
  letter-spacing:.04em; text-transform:uppercase;
  margin:0 0 10px!important;
}
.dp-pros h4{ color:var(--green)!important; }
.dp-pros h4::before{ content:"✓ "; }
.dp-cons h4{ color:var(--red)!important; }
.dp-cons h4::before{ content:"✗ "; }
.dp-pros ul, .dp-cons ul{ list-style:none; padding:0; margin:0; font-size:13.5px; }
.dp-pros li, .dp-cons li{ margin:5px 0; color:var(--ink-2)!important; line-height:1.45; }

/* ─────────────────────────────────────────────────────────────────────────
   22. DARK MODE OVERRIDES
───────────────────────────────────────────────────────────────────────── */
[data-theme="dark"] body{
  background:var(--bg)!important;
  color:var(--ink)!important;
}
[data-theme="dark"] .dp-menubar,
[data-theme="dark"] #dp-menubar{
  background:var(--bg-2)!important;
  border-bottom-color:var(--line)!important;
}
[data-theme="dark"] .dp-menubar__trust{ background:var(--bg-3)!important; border-bottom-color:var(--line)!important; }
[data-theme="dark"] .dp-menubar__brand strong,
[data-theme="dark"] .dp-menubar__brand{ color:var(--ink)!important; }
[data-theme="dark"] .dp-menubar__search-form{
  background:var(--bg-3)!important;
  border-color:var(--line-strong)!important;
}
[data-theme="dark"] .dp-menubar__search-input{
  background:transparent!important; color:var(--ink)!important;
}
[data-theme="dark"] .dp-menubar__search-form select,
[data-theme="dark"] .dp-menubar__cat-pick{
  background:var(--bg-4)!important; color:var(--ink-2)!important; border-color:var(--line)!important;
}
[data-theme="dark"] .dp-menubar__nav-row{ background:var(--bg-3)!important; border-top-color:var(--line)!important; }

[data-theme="dark"] .dp-hero,
[data-theme="dark"] .dpv6-hero{ background:var(--bg-2)!important; border-bottom-color:var(--line)!important; }

[data-theme="dark"] .dp-section--tinted,
[data-theme="dark"] .dpv6-section--tinted,
[data-theme="dark"] .dpv6-section--best-of{
  background:var(--bg-2)!important;
  border-color:var(--line)!important;
}

[data-theme="dark"] .dp-product-card,
[data-theme="dark"] .dpv6-product-card,
[data-theme="dark"] .dpv6-story-card,
[data-theme="dark"] .dpv6-story-card--feature,
[data-theme="dark"] .dpv6-story-card--grid,
[data-theme="dark"] .dpv6-story-card--compact,
[data-theme="dark"] .dpv6-bestof-card,
[data-theme="dark"] .dpv6-related-card,
[data-theme="dark"] .dpv6-category-tile,
[data-theme="dark"] .dpv6-sidecard,
[data-theme="dark"] .dp-category-card{
  background:var(--bg-2)!important;
  border-color:var(--line)!important;
}
[data-theme="dark"] .dp-product-card__image{ background:#fff!important; }

[data-theme="dark"] .dp-section-head,
[data-theme="dark"] .dpv6-section-head{ border-bottom-color:var(--ink-2)!important; }
[data-theme="dark"] .dp-kicker,
[data-theme="dark"] .dpv6-panel-kicker,
[data-theme="dark"] .dpv6-kicker{ background:var(--bg-3)!important; color:var(--navy-2)!important; }

[data-theme="dark"] .dpv6-story-taxonomy,
[data-theme="dark"] .dpv6-related-card__cat{
  background:var(--navy)!important; color:#fff!important;
}
[data-theme="dark"] .dpv6-story-cta,
[data-theme="dark"] .dpv6-related-card__cta{ color:var(--navy-2)!important; }

[data-theme="dark"] .dp-btn--ghost,
[data-theme="dark"] .dpv6-btn--ghost{
  background:var(--bg-3)!important;
  color:var(--ink)!important;
  border-color:var(--line-strong)!important;
}
[data-theme="dark"] .dp-btn--ghost:hover,
[data-theme="dark"] .dpv6-btn--ghost:hover{
  background:var(--navy)!important; color:#fff!important; border-color:var(--navy)!important;
}

[data-theme="dark"] .dpv6-newsletter{ background:linear-gradient(135deg, var(--bg-3) 0%, var(--bg-4) 100%)!important; }
[data-theme="dark"] .dpv6-newsletter h2{ color:var(--ink)!important; }
[data-theme="dark"] .dpv6-newsletter p{ color:var(--ink-2)!important; }
[data-theme="dark"] .dpv6-newsletter input[type="email"]{ background:var(--bg)!important; color:var(--ink)!important; }

[data-theme="dark"] .dpv6-sidecard--bestof{
  background:linear-gradient(135deg, var(--bg-3) 0%, var(--bg-4) 100%)!important;
  border-color:var(--line-strong)!important;
}
[data-theme="dark"] .dpv6-sidecard--bestof h3{ color:var(--ink)!important; }
[data-theme="dark"] .dpv6-sidecard--bestof p{ color:var(--ink-2)!important; }

[data-theme="dark"] .site-footer{ background:var(--bg)!important; border-top:1px solid var(--line)!important; }

[data-theme="dark"] #dp-gdpr{
  background:var(--bg-2)!important; color:var(--ink-2)!important; border-color:var(--line-strong)!important;
}

[data-theme="dark"] .dpv6-article-prose h2{
  border-bottom-color:var(--ink-2)!important;
}
[data-theme="dark"] .dpv6-article-prose blockquote{
  background:var(--bg-3)!important;
  color:var(--ink-2)!important;
}
[data-theme="dark"] .dpv6-article-prose table,
[data-theme="dark"] .dpv6-article-prose .tablepress{ border-color:var(--line)!important; }
[data-theme="dark"] .dpv6-article-prose th{ background:var(--bg-3)!important; border-bottom-color:var(--line-strong)!important; }
[data-theme="dark"] .dpv6-article-prose td{ border-bottom-color:var(--line)!important; color:var(--ink-2)!important; }
[data-theme="dark"] .dpv6-article-prose tr:hover td{ background:var(--bg-3)!important; }

[data-theme="dark"] .dp-pros{ background:var(--green-bg)!important; }
[data-theme="dark"] .dp-cons{ background:var(--red-bg)!important; }

[data-theme="dark"] #dp-dm-toggle{
  background:var(--bg-2)!important;
  color:var(--amber)!important;
  border-color:var(--line-strong)!important;
}
[data-theme="dark"] #dp-dm-toggle:hover{
  background:var(--amber)!important; color:var(--amber-ink)!important; border-color:var(--amber)!important;
}

/* ─────────────────────────────────────────────────────────────────────────
   23. RESPONSIVE TWEAKS
───────────────────────────────────────────────────────────────────────── */
@media (max-width:900px){
  .dp-menubar__main{ grid-template-columns:auto 1fr auto; gap:12px; }
  .dp-menubar__search{ max-width:none; }
  .dp-menubar__action span:not(strong){ display:none; }
  .dp-hero-inner{ grid-template-columns:1fr!important; }
  .dp-hero__feature{ max-height:280px!important; aspect-ratio:16/10!important; }
  .dpv6-single-hero{ grid-template-columns:1fr!important; }
}
@media (max-width:640px){
  :root{ --shell-pad:16px; }
  .dp-menubar__trust-inner{ font-size:11px; gap:10px; }
  .dp-menubar__trust-badges{ gap:10px; }
  .dp-menubar__brand{ font-size:20px; }
  .dp-menubar__brand em{ display:none; }
  .dp-menubar__actions .dp-menubar__action{ padding:6px 8px; }
  .dp-hero{ padding:32px 0 24px!important; }
  .dp-section{ padding:32px 0!important; }
}

/* ─────────────────────────────────────────────────────────────────────────
   24. UTILITIES
───────────────────────────────────────────────────────────────────────── */
.dp-sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.dp-text-navy{ color:var(--navy)!important; }
.dp-text-amber{ color:var(--amber-3)!important; }
.dp-text-green{ color:var(--green)!important; }
.dp-text-red{ color:var(--red)!important; }

/* ═════════════════════════════════════════════════════════════════════════
   PATCH v13.1 · couverture complète des prefixes `dpx-*`, `dp-mega-*`,
   `dp-compare-*`, `dp-cookie__*`, `dp-footer-*`, `dp-scroll-top`, `dp-top`
   (front-page.php et composants historiques)
═══════════════════════════════════════════════════════════════════════════ */

/* Kill residual floats + legacy orange */
.dp-search-trigger,
#dp-scroll-top,
#dp-top,
.dp-top,
.dp-top--visible{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}

/* Kill mega menu (legacy nav not compatible with retail menubar) */
.dp-mega-menu,
.dp-mega-grid,
.dp-mega-card,
.dp-mega-img,
.dp-mega-text{
  display:none!important;
}

/* ─── dpx-home page wrapper ─────────────────────────────────────────── */
.dpx-home,
body.home .dpx-home{
  background:var(--bg)!important;
  color:var(--ink)!important;
  font-family:var(--font-body)!important;
}

.dpx-surface{
  background:var(--bg)!important;
  color:var(--ink)!important;
}

/* ─── dpx-hero · homepage hero ─────────────────────────────────────── */
.dpx-hero{
  background:var(--bg-2)!important;
  border-bottom:1px solid var(--line)!important;
  padding:48px 0 40px!important;
  margin:0 0 40px!important;
  border-radius:0!important;
}
.dpx-hero__inner{
  max-width:var(--shell-max)!important;
  margin:0 auto!important;
  padding:0 var(--shell-pad)!important;
  display:grid!important;
  grid-template-columns:minmax(0,1.2fr) minmax(0,1fr)!important;
  gap:48px!important;
  align-items:center!important;
}
.dpx-hero__copy{
  max-width:620px;
}
.dpx-hero__copy h1,
.dpx-hero h1{
  font-family:var(--font-display)!important;
  font-size:clamp(30px,4.4vw,48px)!important;
  font-weight:800!important;
  letter-spacing:-.035em!important;
  line-height:1.08!important;
  color:var(--ink)!important;
  margin:0 0 18px!important;
  font-style:normal!important;
}
.dpx-lead{
  font-size:17px!important;
  color:var(--ink-3)!important;
  line-height:1.55!important;
  max-width:560px!important;
  margin:0 0 26px!important;
  font-weight:400!important;
  font-family:var(--font-body)!important;
}
.dpx-hero__actions{
  display:flex!important;
  gap:12px!important;
  flex-wrap:wrap!important;
  margin:0 0 28px!important;
}
.dpx-hero__stats{
  display:flex!important;
  gap:32px!important;
  flex-wrap:wrap!important;
  padding-top:24px!important;
  border-top:1px solid var(--line)!important;
  margin-top:4px!important;
}
.dpx-stat{
  display:flex!important;
  flex-direction:column!important;
  gap:2px!important;
  font-family:var(--font-body)!important;
}
.dpx-stat strong{
  font-family:var(--font-display)!important;
  font-size:22px!important;
  font-weight:800!important;
  color:var(--navy)!important;
  letter-spacing:-.02em!important;
  font-variant-numeric:tabular-nums!important;
  line-height:1!important;
  margin-bottom:4px!important;
}
.dpx-stat span{
  font-size:12.5px!important;
  color:var(--ink-3)!important;
  font-weight:500!important;
}

/* Hero feature image (right column) */
.dpx-hero__feature{
  position:relative!important;
  border-radius:var(--r5)!important;
  overflow:hidden!important;
  aspect-ratio:4/3!important;
  max-height:440px!important;
  background:var(--bg-3)!important;
  box-shadow:var(--sh-2)!important;
  border:1px solid var(--line)!important;
  margin:0!important;
}
.dpx-hero__feature .dpx-card,
.dpx-hero__feature .dpx-card--hero{
  position:absolute!important;
  inset:0!important;
  margin:0!important;
  border:0!important;
  border-radius:var(--r5)!important;
  background:transparent!important;
  box-shadow:none!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-end!important;
}
.dpx-hero__feature img,
.dpx-hero__feature picture,
.dpx-hero__feature .dpx-card__media,
.dpx-hero__feature .dpx-card__media img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  position:absolute!important;
  inset:0!important;
  z-index:1!important;
}
.dpx-hero__feature::after,
.dpx-hero__feature .dpx-card::after{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:2!important;
  background:linear-gradient(180deg, transparent 0%, transparent 40%, rgba(11,30,61,.85) 100%)!important;
  pointer-events:none;
}
.dpx-hero__feature .dpx-card__body{
  position:relative!important;
  z-index:3!important;
  padding:24px!important;
  background:transparent!important;
  color:#fff!important;
}
.dpx-hero__feature .dpx-card__kicker{
  display:inline-block;
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
  padding:3px 9px!important;
  font-size:10.5px!important;
  font-weight:700!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
  border-radius:var(--r2)!important;
  margin-bottom:10px!important;
  width:fit-content;
}
.dpx-hero__feature .dpx-card__title{
  font-family:var(--font-display)!important;
  font-size:clamp(18px,2.2vw,24px)!important;
  font-weight:700!important;
  color:#fff!important;
  margin:0 0 12px!important;
  line-height:1.25!important;
  display:-webkit-box;
  -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.dpx-hero__feature .dpx-card__meta{
  color:rgba(255,255,255,.85)!important;
  font-size:12px!important;
  display:flex;
  gap:8px;
  align-items:center;
}
.dpx-hero__feature .dpx-card__meta > *{ color:rgba(255,255,255,.85)!important; }
.dpx-hero__feature .dpx-card__meta > *:not(:last-child)::after{
  content:"·"; margin-left:8px; color:rgba(255,255,255,.5);
}

/* ─── dpx-btn buttons ──────────────────────────────────────────────── */
.dpx-btn{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  padding:11px 20px!important;
  font-family:var(--font-body)!important;
  font-size:14px!important;
  font-weight:600!important;
  letter-spacing:0!important;
  text-transform:none!important;
  border-radius:var(--r3)!important;
  border:1px solid transparent!important;
  text-decoration:none!important;
  cursor:pointer;
  transition:all .15s var(--e)!important;
  white-space:nowrap;
}
.dpx-btn--solid{
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
  border-color:var(--amber-2)!important;
  box-shadow:var(--sh-1)!important;
}
.dpx-btn--solid:hover{
  background:var(--amber-2)!important;
  transform:translateY(-1px)!important;
  box-shadow:var(--sh-2)!important;
}
.dpx-btn--line{
  background:var(--bg)!important;
  color:var(--navy)!important;
  border-color:var(--line-2)!important;
}
.dpx-btn--line:hover{
  background:var(--bg-2)!important;
  border-color:var(--navy)!important;
}

/* ─── dpx-section · generic section wrapper ───────────────────────── */
.dpx-section{
  padding:48px 0!important;
  background:var(--bg)!important;
  border:0!important;
  border-radius:0!important;
}
.dpx-section--ink{
  background:var(--bg-2)!important;
  border-top:1px solid var(--line)!important;
  border-bottom:1px solid var(--line)!important;
}
.dpx-section--picks,
.dpx-section--method{
  background:var(--bg)!important;
}
.dpx-section__head{
  max-width:var(--shell-max)!important;
  margin:0 auto 28px!important;
  padding:0 var(--shell-pad) 14px!important;
  border-bottom:2px solid var(--ink)!important;
  display:flex!important;
  align-items:flex-end!important;
  justify-content:space-between!important;
  gap:20px!important;
  flex-wrap:wrap;
}
.dpx-section__head h2,
.dpx-section__head h3{
  font-family:var(--font-display)!important;
  font-size:26px!important;
  font-weight:800!important;
  color:var(--ink)!important;
  letter-spacing:-.02em!important;
  margin:0!important;
  font-style:normal!important;
}
.dpx-section__head p,
.dpx-section__head .dpx-lead{
  font-size:14px!important;
  color:var(--ink-3)!important;
  max-width:560px;
  margin:0!important;
}
.dpx-section__head a{
  color:var(--blue-link)!important;
  font-family:var(--font-body)!important;
  font-size:13.5px!important;
  font-weight:600!important;
  text-decoration:none!important;
  white-space:nowrap;
}
.dpx-section__head a:hover{ color:var(--blue-link-hover)!important; text-decoration:underline!important; }

/* Tags / kickers */
.dpx-tag,
.dpx-card__kicker{
  display:inline-block!important;
  font-family:var(--font-body)!important;
  font-size:11px!important;
  font-weight:700!important;
  letter-spacing:.06em!important;
  text-transform:uppercase!important;
  color:var(--navy)!important;
  background:var(--bg-3)!important;
  padding:4px 9px!important;
  border-radius:var(--r2)!important;
  margin-bottom:10px!important;
  width:fit-content;
}

/* ─── dpx-card · story card ───────────────────────────────────────── */
.dpx-card{
  background:var(--bg)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r4)!important;
  overflow:hidden!important;
  box-shadow:none!important;
  transition:box-shadow .2s var(--e), border-color .2s, transform .2s!important;
  display:flex;
  flex-direction:column;
  position:relative;
}
.dpx-card:hover{
  box-shadow:var(--sh-3)!important;
  border-color:var(--line-strong)!important;
  transform:translateY(-2px)!important;
}
.dpx-card__link{
  display:flex!important;
  flex-direction:column!important;
  color:inherit!important;
  text-decoration:none!important;
  height:100%!important;
}
.dpx-card__media{
  background:var(--bg-3)!important;
  aspect-ratio:16/10!important;
  overflow:hidden!important;
  width:100%!important;
  height:auto!important;
  position:relative;
}
.dpx-card__media img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  transition:transform .4s var(--e);
}
.dpx-card:hover .dpx-card__media img{ transform:scale(1.04); }
.dpx-card__body{
  padding:18px 20px 20px!important;
  display:flex;
  flex-direction:column;
  flex:1;
}
.dpx-card__meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px!important;
  margin:0 0 10px!important;
  font-family:var(--font-body)!important;
  font-size:11.5px!important;
  color:var(--ink-4)!important;
  font-weight:500!important;
}
.dpx-card__meta > *:not(:last-child){
  position:relative;
}
.dpx-card__meta a,
.dpx-card__meta .dpx-tag{
  color:var(--navy)!important;
  margin-bottom:0!important;
}
.dpx-card__title{
  font-family:var(--font-display)!important;
  font-size:16px!important;
  font-weight:700!important;
  letter-spacing:-.015em!important;
  color:var(--ink)!important;
  line-height:1.3!important;
  margin:0 0 8px!important;
  font-style:normal!important;
  display:-webkit-box;
  -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}
.dpx-card__excerpt{
  font-family:var(--font-body)!important;
  font-size:13.5px!important;
  color:var(--ink-3)!important;
  line-height:1.55!important;
  margin:0!important;
  display:-webkit-box;
  -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

/* Card variants */
.dpx-card--hero{
  /* Handled above under .dpx-hero__feature .dpx-card--hero */
}
.dpx-card--spot{
  background:var(--bg-2)!important;
}
.dpx-card--grid{
  /* Default card styling */
}

/* ─── dpx-grid · main grid layout ─────────────────────────────────── */
.dpx-grid,
.dpx-spot-grid{
  max-width:var(--shell-max)!important;
  margin:0 auto!important;
  padding:0 var(--shell-pad)!important;
  display:grid!important;
  grid-template-columns:repeat(4, minmax(0,1fr))!important;
  gap:20px!important;
}
@media (max-width:1024px){
  .dpx-grid,.dpx-spot-grid{ grid-template-columns:repeat(2,1fr)!important; }
}
@media (max-width:600px){
  .dpx-grid,.dpx-spot-grid{ grid-template-columns:1fr!important; }
}

/* ─── dpx-rubrics · category chips row ────────────────────────────── */
.dpx-rubrics{
  max-width:var(--shell-max);
  margin:0 auto;
  padding:0 var(--shell-pad);
}
.dpx-rubrics__track{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  padding:12px 0;
}
.dpx-rubric-chip{
  display:inline-flex!important;
  align-items:center!important;
  padding:8px 14px!important;
  background:var(--bg)!important;
  color:var(--ink-2)!important;
  border:1px solid var(--line-2)!important;
  border-radius:999px!important;
  font-size:13px!important;
  font-weight:500!important;
  font-family:var(--font-body)!important;
  text-decoration:none!important;
  transition:all .15s!important;
  letter-spacing:0!important;
  text-transform:none!important;
}
.dpx-rubric-chip:hover{
  background:var(--navy)!important;
  color:#fff!important;
  border-color:var(--navy)!important;
}

/* ─── dpx-editor-picks · ranked list ──────────────────────────────── */
.dpx-editor-picks__list{
  max-width:var(--shell-max);
  margin:0 auto;
  padding:0 var(--shell-pad);
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
}
@media (max-width:900px){ .dpx-editor-picks__list{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .dpx-editor-picks__list{ grid-template-columns:1fr; } }

.dpx-editor-pick{
  background:var(--bg)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r4)!important;
  padding:24px!important;
  position:relative;
  transition:box-shadow .2s, border-color .2s, transform .2s;
  display:flex;
  flex-direction:column;
}
.dpx-editor-pick::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--amber) 0%, var(--navy) 100%);
  border-radius:var(--r4) var(--r4) 0 0;
}
.dpx-editor-pick:hover{
  box-shadow:var(--sh-3)!important;
  border-color:var(--line-strong)!important;
  transform:translateY(-3px)!important;
}
.dpx-editor-pick__rank{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px!important;
  height:42px!important;
  background:var(--navy)!important;
  color:#fff!important;
  font-family:var(--font-display)!important;
  font-size:18px!important;
  font-weight:800!important;
  border-radius:var(--r3)!important;
  line-height:1!important;
  margin-bottom:12px!important;
}
.dpx-editor-pick__badge{
  display:inline-block!important;
  background:var(--badge-bestseller)!important;
  color:#fff!important;
  font-size:10.5px!important;
  font-weight:700!important;
  letter-spacing:.06em!important;
  text-transform:uppercase!important;
  padding:3px 8px!important;
  border-radius:var(--r2)!important;
  margin-bottom:10px!important;
  width:fit-content;
}
.dpx-editor-pick__body{
  flex:1;
  display:flex;
  flex-direction:column;
}
.dpx-editor-pick__body h3{
  font-family:var(--font-display)!important;
  font-size:16px!important;
  font-weight:700!important;
  color:var(--ink)!important;
  margin:0 0 10px!important;
  line-height:1.3!important;
  letter-spacing:-.015em!important;
  font-style:normal!important;
}
.dpx-editor-pick__body p{
  color:var(--ink-3)!important;
  font-size:13.5px!important;
  line-height:1.55!important;
  margin:0 0 14px!important;
}
.dpx-editor-pick__meta{
  margin-top:auto;
  padding-top:12px;
  border-top:1px dashed var(--line-2);
  font-size:12px;
  color:var(--ink-4);
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

/* ─── dpx-method · "how we work" grid ─────────────────────────────── */
.dpx-method-grid{
  max-width:var(--shell-max);
  margin:0 auto;
  padding:0 var(--shell-pad);
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:20px;
}
@media (max-width:1024px){ .dpx-method-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .dpx-method-grid{ grid-template-columns:1fr; } }

.dpx-method-item{
  background:var(--bg)!important;
  border:1px solid var(--line)!important;
  border-radius:var(--r4)!important;
  padding:22px!important;
  transition:border-color .2s, box-shadow .2s;
}
.dpx-method-item:hover{
  border-color:var(--navy)!important;
  box-shadow:var(--sh-2)!important;
}
.dpx-method-item h3{
  font-family:var(--font-display)!important;
  font-size:16px!important;
  font-weight:700!important;
  color:var(--ink)!important;
  margin:0 0 8px!important;
  font-style:normal!important;
  letter-spacing:-.015em!important;
}
.dpx-method-item p{
  font-size:13.5px!important;
  color:var(--ink-3)!important;
  line-height:1.55!important;
  margin:0!important;
}

/* ─── dpx-newsletter ──────────────────────────────────────────────── */
.dpx-section--newsletter,
.dpx-newsletter{
  background:var(--navy)!important;
  color:#fff!important;
  border-radius:var(--r5)!important;
  padding:48px 40px!important;
  max-width:calc(var(--shell-max) - 48px);
  margin:40px auto!important;
  position:relative;
  overflow:hidden;
  display:grid!important;
  grid-template-columns:1.2fr 1fr!important;
  gap:40px!important;
  align-items:center!important;
  border:0!important;
}
.dpx-section--newsletter::before,
.dpx-newsletter::before{
  content:""; position:absolute;
  top:-80px; right:-80px;
  width:240px; height:240px;
  background:var(--amber);
  border-radius:50%;
  opacity:.1;
}
.dpx-newsletter__copy h2,
.dpx-newsletter__copy h3{
  color:#fff!important;
  font-family:var(--font-display)!important;
  font-size:28px!important;
  font-weight:800!important;
  margin:0 0 10px!important;
  letter-spacing:-.02em!important;
  font-style:normal!important;
}
.dpx-newsletter__copy p{
  color:rgba(255,255,255,.85)!important;
  font-size:15px!important;
  line-height:1.55!important;
}
.dpx-newsletter__form{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.dpx-newsletter__form input[type="email"]{
  flex:1;
  min-width:220px;
  background:#fff!important;
  border:0!important;
  padding:14px 16px!important;
  border-radius:var(--r3)!important;
  font-size:14px!important;
  color:var(--ink)!important;
  font-family:var(--font-body)!important;
}
.dpx-newsletter__form button{
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
  padding:14px 22px!important;
  font-weight:700!important;
  border:0!important;
  border-radius:var(--r3)!important;
  cursor:pointer!important;
  font-family:var(--font-body)!important;
  font-size:14px!important;
}
.dpx-newsletter__form button:hover{ background:var(--amber-2)!important; }
@media (max-width:820px){
  .dpx-section--newsletter,.dpx-newsletter{
    grid-template-columns:1fr!important;
    padding:32px 24px!important;
  }
}

/* ─── dpx-final · bottom CTA section ──────────────────────────────── */
.dpx-final{
  background:var(--bg-2)!important;
  padding:60px 0!important;
  border-top:1px solid var(--line)!important;
  text-align:center;
}
.dpx-final__inner{
  max-width:720px;
  margin:0 auto;
  padding:0 var(--shell-pad);
}
.dpx-final h2,
.dpx-final h3{
  font-family:var(--font-display)!important;
  font-size:32px!important;
  font-weight:800!important;
  color:var(--ink)!important;
  margin:0 0 14px!important;
  letter-spacing:-.025em!important;
  font-style:normal!important;
}
.dpx-final p{
  color:var(--ink-3)!important;
  font-size:16px!important;
  line-height:1.55!important;
  margin:0 0 24px!important;
}
.dpx-final__actions{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
}

/* ─── dpx-view-toolbar ────────────────────────────────────────────── */
.dpx-view-toolbar{
  display:flex;
  gap:8px;
  align-items:center;
  padding:12px 0;
  font-family:var(--font-body);
}
.dpx-view-toolbar__label{
  font-size:12px;
  color:var(--ink-3);
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.dpx-view-toolbar__btn{
  padding:6px 12px!important;
  background:var(--bg)!important;
  border:1px solid var(--line-2)!important;
  color:var(--ink-2)!important;
  border-radius:var(--r2)!important;
  font-size:12.5px!important;
  font-weight:500!important;
  cursor:pointer;
  transition:all .15s;
}
.dpx-view-toolbar__btn:hover,
.dpx-view-toolbar__btn.is-active{
  background:var(--navy)!important;
  color:#fff!important;
  border-color:var(--navy)!important;
}

/* ─── dp-footer (legacy custom footer) ────────────────────────────── */
.dp-footer{
  background:var(--ink)!important;
  color:rgba(255,255,255,.75)!important;
  padding:48px 0 20px!important;
  margin-top:64px!important;
  border:0!important;
  position:relative;
  overflow:hidden;
}
.dp-footer-glow-bg,
.dp-glow,
.dp-glow-1,
.dp-glow-2{ display:none!important; }
.dp-footer-inner{
  max-width:var(--shell-max)!important;
  margin:0 auto!important;
  padding:0 var(--shell-pad)!important;
  display:grid;
  grid-template-columns:1.2fr repeat(3, 1fr);
  gap:32px;
}
@media (max-width:900px){ .dp-footer-inner{ grid-template-columns:1fr 1fr; } }
@media (max-width:540px){ .dp-footer-inner{ grid-template-columns:1fr; } }
.dp-footer-logo,
.dp-footer-brand{
  font-family:var(--font-display)!important;
  font-size:22px!important;
  font-weight:800!important;
  color:#fff!important;
  letter-spacing:-.02em!important;
  margin:0 0 8px!important;
}
.dp-footer-tagline,
.dp-footer-copy{
  color:rgba(255,255,255,.6)!important;
  font-size:13.5px!important;
  line-height:1.55!important;
  margin:0 0 14px!important;
}
.dp-footer-col-title{
  color:#fff!important;
  font-family:var(--font-body)!important;
  font-size:12px!important;
  font-weight:700!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
  margin:0 0 14px!important;
}
.dp-footer-list{
  list-style:none;
  padding:0;
  margin:0;
}
.dp-footer-list li{ margin:6px 0; }
.dp-footer-links,
.dp-footer-list a{
  color:rgba(255,255,255,.7)!important;
  font-size:13.5px!important;
  text-decoration:none!important;
  transition:color .15s;
}
.dp-footer-list a:hover{ color:var(--amber)!important; }
.dp-footer-cat-count{
  color:rgba(255,255,255,.5)!important;
  font-size:11px!important;
  margin-left:6px;
  font-variant-numeric:tabular-nums;
}
.dp-footer-badges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}
.dp-footer-badges .dp-badge-item{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:4px 10px;
  background:rgba(255,255,255,.08);
  border-radius:999px;
  font-size:11px;
  color:rgba(255,255,255,.8);
}
.dp-footer-bottom{
  border-top:1px solid rgba(255,255,255,.1)!important;
  padding-top:16px!important;
  margin-top:28px!important;
  max-width:var(--shell-max);
  margin-left:auto; margin-right:auto;
  padding-left:var(--shell-pad); padding-right:var(--shell-pad);
  font-size:12px!important;
  color:rgba(255,255,255,.5)!important;
}

/* ─── dp-cookie (GDPR banner, retail style) ───────────────────────── */
.dp-cookie,
[class^="dp-cookie"]{
  background:var(--bg)!important;
  border:1px solid var(--line-2)!important;
  border-radius:var(--r4)!important;
  box-shadow:var(--sh-3)!important;
  color:var(--ink-2)!important;
  font-family:var(--font-body)!important;
}
.dp-cookie__text{ color:var(--ink-2)!important; font-size:13.5px!important; line-height:1.55!important; }
.dp-cookie__more{ color:var(--blue-link)!important; }
.dp-cookie__btn{
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
  border:0!important;
  padding:8px 16px!important;
  border-radius:var(--r3)!important;
  font-weight:700!important;
  cursor:pointer;
  font-family:var(--font-body)!important;
  font-size:13px!important;
}
.dp-cookie__btn:hover{ background:var(--amber-2)!important; }
.dp-cookie__close{
  background:transparent!important;
  color:var(--ink-3)!important;
  border:1px solid var(--line-2)!important;
}

/* ─── dp-compare · product compare bar (fixed bottom) ─────────────── */
.dp-compare-bar{
  background:var(--ink)!important;
  color:#fff!important;
  border-top:3px solid var(--amber)!important;
  padding:12px 20px!important;
  font-family:var(--font-body)!important;
}
.dp-compare-bar__label{
  color:var(--amber)!important;
  font-size:11px!important;
  font-weight:700!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
}
.dp-compare-bar__chips .dp-chip{
  background:rgba(255,255,255,.1)!important;
  color:#fff!important;
  border:0!important;
}
.dp-compare-bar__cta{
  background:var(--amber)!important;
  color:var(--amber-ink)!important;
}
.dp-compare-bar__reset{
  background:transparent!important;
  color:rgba(255,255,255,.7)!important;
  border:1px solid rgba(255,255,255,.2)!important;
}
.dp-compare-modal__box{
  background:var(--bg)!important;
  border-radius:var(--r4)!important;
  box-shadow:var(--sh-3)!important;
}
.dp-compare-modal__title{
  font-family:var(--font-display)!important;
  font-weight:800!important;
  color:var(--ink)!important;
  font-style:normal!important;
}

/* ─── Fix stats spacing globally (strong+span concat fix) ─────────── */
.dpx-stat strong + span,
.dpx-hero__stats strong + span,
.dp-hero__stat strong + span{
  margin-left:0;
}

/* Force spacing between meta items on story cards (17 Avr 20263 min bug) */
.dpx-card__meta > *,
.dpv6-story-meta > *{ padding-right:0; }
.dpx-card__meta > * + *::before{
  content:"·";
  margin:0 6px 0 0;
  color:var(--ink-5);
}
.dpv6-story-meta > * + *::before{
  content:"·";
  margin:0 6px 0 0;
  color:var(--ink-5);
}

/* Dark mode dpx-* overrides */
[data-theme="dark"] .dpx-hero,
[data-theme="dark"] .dpx-section--ink,
[data-theme="dark"] .dpx-final{
  background:var(--bg-2)!important;
  border-color:var(--line)!important;
}
[data-theme="dark"] .dpx-card,
[data-theme="dark"] .dpx-editor-pick,
[data-theme="dark"] .dpx-method-item{
  background:var(--bg-2)!important;
  border-color:var(--line)!important;
}
[data-theme="dark"] .dpx-card:hover,
[data-theme="dark"] .dpx-editor-pick:hover{
  border-color:var(--navy)!important;
  box-shadow:0 8px 24px rgba(0,0,0,.4)!important;
}
[data-theme="dark"] .dpx-card__title,
[data-theme="dark"] .dpx-editor-pick__body h3,
[data-theme="dark"] .dpx-method-item h3,
[data-theme="dark"] .dpx-section__head h2{ color:var(--ink)!important; }
[data-theme="dark"] .dpx-card__excerpt,
[data-theme="dark"] .dpx-editor-pick__body p,
[data-theme="dark"] .dpx-method-item p,
[data-theme="dark"] .dpx-section__head p{ color:var(--ink-3)!important; }
[data-theme="dark"] .dpx-rubric-chip{
  background:var(--bg-3)!important;
  color:var(--ink-2)!important;
  border-color:var(--line-strong)!important;
}
[data-theme="dark"] .dpx-rubric-chip:hover{
  background:var(--navy)!important; color:#fff!important;
}
[data-theme="dark"] .dpx-btn--line{
  background:var(--bg-3)!important;
  color:var(--ink)!important;
  border-color:var(--line-strong)!important;
}
[data-theme="dark"] .dpx-newsletter,
[data-theme="dark"] .dpx-section--newsletter{
  background:linear-gradient(135deg, var(--bg-3) 0%, var(--bg-4) 100%)!important;
}
[data-theme="dark"] .dpx-newsletter__copy h2,
[data-theme="dark"] .dpx-newsletter__copy h3{ color:var(--ink)!important; }
[data-theme="dark"] .dpx-newsletter__copy p{ color:var(--ink-2)!important; }
[data-theme="dark"] .dp-footer{
  background:var(--bg)!important;
  border-top:1px solid var(--line)!important;
}

/* End V13 Retail */
