/* =========================================================================
   LetsJackpot — Paper & Salt
   Warm Swiss minimal: humanist sans, salt/paper/graphite, hairlines, 4px,
   flat at rest, depth only on hover, one warm amber accent.
   ========================================================================= */

:root {
  /* Surfaces — warm, salt-to-paper steps */
  --dbq-bg:        #faf7f1;
  --dbq-surface:   #f3eee3;
  --dbq-surface-2: #ebe4d6;
  --dbq-ink:       #211e18;
  --dbq-ink-2:     #4c473d;
  --dbq-ink-3:     #6d6759;
  --dbq-accent:    #b21e62;
  --dbq-accent-2:  #8c1349;
  --dbq-hairline:  color-mix(in oklab, var(--dbq-ink) 13%, transparent);
  --dbq-hairline-2:color-mix(in oklab, var(--dbq-ink) 8%, transparent);
  --dbq-accent-tint: color-mix(in oklab, var(--dbq-accent) 9%, transparent);

  /* Type scale — ratio 1.25, fluid via clamp() */
  --dbq-step--1: clamp(0.82rem, 0.79rem + 0.13vw, 0.88rem);
  --dbq-step-0:  1rem;
  --dbq-step-1:  clamp(1.12rem, 1.07rem + 0.24vw, 1.25rem);
  --dbq-step-2:  clamp(1.36rem, 1.27rem + 0.45vw, 1.6rem);
  --dbq-step-3:  clamp(1.64rem, 1.49rem + 0.74vw, 2rem);
  --dbq-step-4:  clamp(1.96rem, 1.72rem + 1.18vw, 2.6rem);
  --dbq-step-5:  clamp(2.2rem, 1.85rem + 1.7vw, 3.2rem);

  /* Spacing — compact density grid */
  --dbq-s1: 0.35rem;
  --dbq-s2: 0.6rem;
  --dbq-s3: 0.85rem;
  --dbq-s4: 1.1rem;
  --dbq-s5: 1.5rem;
  --dbq-s6: 2rem;
  --dbq-section-y: clamp(0.95rem, 0.7rem + 1.4vw, 1.7rem);

  --dbq-wrap: 1232px;
  --dbq-pad: clamp(1rem, 0.6rem + 1.6vw, 1.6rem);
  --dbq-r-sm: 3px;
  --dbq-r-md: 4px;

  --dbq-font-display: "Spline Sans", system-ui, "Segoe UI", sans-serif;
  --dbq-font-text: "IBM Plex Sans", system-ui, "Segoe UI", sans-serif;

  --dbq-shadow-hover: 0 6px 22px -12px color-mix(in oklab, var(--dbq-ink) 50%, transparent);
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body.dbq-body {
  margin: 0;
  background: var(--dbq-bg);
  color: var(--dbq-ink);
  font-family: var(--dbq-font-text);
  font-size: var(--dbq-step-0);
  line-height: 1.6;
  font-feature-settings: "tnum" 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--dbq-accent); text-decoration: none; }
a:hover { color: var(--dbq-accent-2); }

h1, h2, h3, h4 {
  font-family: var(--dbq-font-display);
  font-weight: 700;
  line-height: 1.12;
  color: var(--dbq-ink);
  margin: 0 0 var(--dbq-s3);
  text-wrap: balance;
  letter-spacing: -0.012em;
}

p { margin: 0 0 var(--dbq-s4); text-wrap: pretty; }

:focus-visible {
  outline: 2px solid var(--dbq-accent);
  outline-offset: 2px;
  border-radius: var(--dbq-r-sm);
}

::selection {
  background: color-mix(in oklab, var(--dbq-accent) 26%, transparent);
  color: var(--dbq-ink);
}

::-webkit-details-marker { display: none; }

/* ---- Container -------------------------------------------------------- */
.dbq-wrap {
  width: 100%;
  max-width: var(--dbq-wrap);
  margin-inline: auto;
  padding-inline: var(--dbq-pad);
}

/* ===========================  HEADER  ================================== */
.dbq-nav-toggle { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }

.dbq-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in oklab, var(--dbq-bg) 92%, transparent);
  backdrop-filter: saturate(1.1);
  border-bottom: 1px solid var(--dbq-hairline);
}
.dbq-header__inner {
  display: flex;
  align-items: center;
  gap: var(--dbq-s4);
  min-height: 62px;
}
.dbq-logo { display: inline-block; line-height: 0; flex: none; }
.dbq-logo img { height: clamp(30px, 4vw, 40px); width: auto; }

.dbq-nav { margin-left: auto; }
.dbq-nav__list {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: clamp(0.5rem, 1.4vw, 1.35rem);
  list-style: none;
  margin: 0;
  padding: 0;
}
.dbq-nav__link {
  display: inline-block;
  white-space: nowrap;
  color: var(--dbq-ink-2);
  font-size: var(--dbq-step--1);
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: 6px 2px;
  transition: color 0.16s ease;
}
.dbq-nav__link:hover { color: var(--dbq-accent); }
.dbq-nav__link[aria-current="page"] {
  color: var(--dbq-ink);
  box-shadow: inset 0 -2px 0 var(--dbq-accent);
}
.dbq-header__cta { flex: none; }

/* Burger — two bars, hidden on desktop */
.dbq-burger {
  display: none;
  flex: none;
  width: 44px; height: 44px;
  margin-left: var(--dbq-s2);
  border: 1px solid var(--dbq-hairline);
  border-radius: var(--dbq-r-md);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  background: var(--dbq-surface);
}
.dbq-burger span {
  display: block;
  width: 19px; height: 2px;
  background: var(--dbq-ink);
  border-radius: 2px;
}
@media (max-width: 900px) {
  .dbq-burger { display: inline-flex; }
}

/* Bottom-sheet mobile menu */
.dbq-sheet__scrim {
  position: fixed; inset: 0;
  background: color-mix(in oklab, var(--dbq-ink) 42%, transparent);
  opacity: 0; visibility: hidden;
  transition: opacity 0.2s ease, visibility 0.2s ease;
  z-index: 60;
}
.dbq-sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 61;
  background: var(--dbq-bg);
  border-top: 1px solid var(--dbq-hairline);
  border-radius: 14px 14px 0 0;
  padding: var(--dbq-s3) var(--dbq-pad) calc(var(--dbq-s5) + env(safe-area-inset-bottom));
  transform: translateY(100%);
  transition: transform 0.24s ease;
  max-height: 80vh;
  overflow-y: auto;
}
.dbq-sheet__grip {
  display: block;
  width: 42px; height: 4px;
  border-radius: 4px;
  background: var(--dbq-hairline);
  margin: 0 auto var(--dbq-s3);
}
.dbq-sheet__list { list-style: none; margin: 0 0 var(--dbq-s3); padding: 0; }
.dbq-sheet__list li { border-bottom: 1px solid var(--dbq-hairline-2); }
.dbq-sheet__list a {
  display: block;
  padding: 13px 4px;
  color: var(--dbq-ink);
  font-family: var(--dbq-font-display);
  font-size: var(--dbq-step-1);
  font-weight: 600;
}
.dbq-sheet__cta .dbq-cta { width: 100%; }

#dbq-nav-toggle:checked ~ .dbq-sheet { transform: translateY(0); }
#dbq-nav-toggle:checked ~ .dbq-sheet__scrim { opacity: 1; visibility: visible; }

/* ============================  CTA  =================================== */
.dbq-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  background: var(--dbq-accent);
  color: #fff7ec;
  font-family: var(--dbq-font-display);
  font-weight: 600;
  font-size: var(--dbq-step-0);
  line-height: 1.1;
  text-align: center;
  padding: 0.8em 1.3em;
  border: 1px solid var(--dbq-accent-2);
  border-radius: var(--dbq-r-md);
  white-space: nowrap;
  transition: transform 0.14s ease, background-color 0.14s ease, color 0.14s ease;
}
.dbq-cta:hover { background: var(--dbq-accent-2); color: #fff7ec; transform: scale(1.02); }
.dbq-cta:active { transform: scale(0.99); }
.dbq-cta__ico { flex: none; }
.dbq-cta--sm { padding: 0.55em 0.95em; font-size: var(--dbq-step--1); }

.dbq-ctarow {
  display: flex;
  justify-content: center;
  margin: var(--dbq-s5) 0;
}

/* ============================  HERO  ================================== */
.dbq-hero {
  position: relative;
  border-bottom: 1px solid var(--dbq-hairline);
  background:
    radial-gradient(90% 130% at 100% -10%, var(--dbq-accent-tint), transparent 55%),
    linear-gradient(180deg, color-mix(in oklab, var(--dbq-accent-tint) 55%, transparent), transparent 62%);
}
.dbq-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(216px, 27%, 300px);
  align-items: center;
  column-gap: clamp(var(--dbq-s4), 5vw, 3rem);
  row-gap: var(--dbq-s4);
  padding-block: clamp(2.2rem, 1.4rem + 3.4vw, 4.4rem);
}
.dbq-hero__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--dbq-s3);
  min-width: 0;
}
.dbq-hero__kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: var(--dbq-step--1);
  font-weight: 600;
  color: var(--dbq-accent-2);
}
.dbq-hero__kicker::before {
  content: "";
  width: 1.8em;
  height: 2px;
  background: var(--dbq-accent);
  border-radius: 2px;
}
.dbq-hero__title {
  margin: 0;
  font-family: var(--dbq-font-display);
  font-size: clamp(2.2rem, 1.3rem + 3.6vw, 3.9rem);
  line-height: 1.03;
  letter-spacing: -0.022em;
  max-width: 16ch;
  text-wrap: balance;
}
.dbq-hero__lead {
  margin: 0;
  max-width: 48ch;
  color: var(--dbq-ink-2);
  font-size: clamp(1.02rem, 0.96rem + 0.4vw, 1.22rem);
  line-height: 1.55;
}
.dbq-hero__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--dbq-s3) var(--dbq-s4);
  margin-top: var(--dbq-s2);
}
.dbq-hero__2nd {
  font-weight: 600;
  font-size: var(--dbq-step-0);
  color: var(--dbq-ink-2);
  border-bottom: 1px solid var(--dbq-hairline);
  padding-bottom: 1px;
}
.dbq-hero__2nd::after { content: " \2192"; transition: none; }
.dbq-hero__2nd:hover { color: var(--dbq-accent); }
.dbq-hero__score {
  align-self: center;
  display: flex;
  flex-direction: column;
  gap: var(--dbq-s2);
  padding: var(--dbq-s4);
  border: 1px solid var(--dbq-hairline);
  border-top: 3px solid var(--dbq-accent);
  border-radius: var(--dbq-r-md);
  background: var(--dbq-surface);
  box-shadow: 0 24px 60px -34px color-mix(in oklab, var(--dbq-ink) 55%, transparent);
}
.dbq-hero__score-label {
  margin: 0;
  font-size: var(--dbq-step--1);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--dbq-ink-3);
}
.dbq-hero__score-num {
  margin: 0;
  display: flex;
  align-items: baseline;
  font-family: var(--dbq-font-display);
  font-weight: 800;
  font-size: clamp(2.6rem, 2rem + 2vw, 3.4rem);
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--dbq-accent);
  font-variant-numeric: tabular-nums lining-nums;
}
.dbq-hero__score-of {
  font-size: 0.42em;
  font-weight: 600;
  color: var(--dbq-ink-3);
  margin-left: 0.18em;
}
.dbq-hero__score-bar {
  display: block;
  height: 6px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--dbq-ink) 12%, transparent);
  overflow: hidden;
}
.dbq-hero__score-fill {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: var(--dbq-accent);
}
.dbq-hero__score-note {
  margin: 0;
  font-size: var(--dbq-step--1);
  color: var(--dbq-ink-3);
  line-height: 1.4;
}
.dbq-hero__facts {
  grid-column: 1 / -1;
  list-style: none;
  margin: var(--dbq-s2) 0 0;
  padding: var(--dbq-s4) 0 0;
  border-top: 1px solid var(--dbq-hairline);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--dbq-s2) var(--dbq-s4);
}
.dbq-hero__fact { display: inline-flex; align-items: baseline; gap: 0.4em; min-width: 0; }
.dbq-hero__fact + .dbq-hero__fact::before {
  content: "\00B7";
  margin-right: var(--dbq-s3);
  color: var(--dbq-ink-3);
}
.dbq-hero__fact-k {
  font-size: var(--dbq-step--1);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--dbq-ink-3);
}
.dbq-hero__fact-v {
  font-weight: 600;
  font-variant-numeric: tabular-nums lining-nums;
}

/* Rating strip */
.dbq-rating {
  margin: 0;
  display: inline-flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.4em;
  font-size: var(--dbq-step-0);
  color: var(--dbq-ink-2);
}
.dbq-rating__val {
  font-family: var(--dbq-font-display);
  font-weight: 700;
  font-size: var(--dbq-step-2);
  color: var(--dbq-accent-2);
  font-variant-numeric: tabular-nums lining-nums;
}
.dbq-rating__of { color: var(--dbq-ink-3); }
.dbq-rating__note { color: var(--dbq-ink-3); }

/* =========================  PAGE TITLE  =============================== */
.dbq-pagetitle {
  border-bottom: 1px solid var(--dbq-hairline);
  padding-block: clamp(1.1rem, 0.8rem + 1.5vw, 2rem);
}
.dbq-pagetitle__kicker {
  margin: 0 0 var(--dbq-s2);
  text-transform: uppercase;
  letter-spacing: 0.13em;
  font-size: var(--dbq-step--1);
  font-weight: 600;
  color: var(--dbq-accent-2);
}
.dbq-pagetitle__h1 { margin: 0 0 var(--dbq-s3); font-size: var(--dbq-step-4); }
.dbq-pagetitle__lead { margin: 0; max-width: 70ch; color: var(--dbq-ink-2); font-size: var(--dbq-step-1); }

/* =========================  BREADCRUMBS  ============================== */
.dbq-crumbs { border-bottom: 1px solid var(--dbq-hairline-2); }
.dbq-crumbs__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem 0.55rem;
  list-style: none;
  margin: 0;
  padding: 0.6rem 0;
  font-size: var(--dbq-step--1);
  color: var(--dbq-ink-3);
}
.dbq-crumbs__item + .dbq-crumbs__item::before { content: "/"; margin-right: 0.55rem; color: var(--dbq-hairline); }
.dbq-crumbs__item a { color: var(--dbq-ink-3); }
.dbq-crumbs__item a:hover { color: var(--dbq-accent); }
.dbq-crumbs__item [aria-current="page"] { color: var(--dbq-ink); }

/* ===========================  BYLINE  ================================ */
.dbq-byline { border-bottom: 1px solid var(--dbq-hairline-2); }
.dbq-byline__inner {
  display: flex;
  align-items: center;
  gap: var(--dbq-s3);
  padding: var(--dbq-s3) var(--dbq-pad);
}
.dbq-byline__photo {
  width: 40px; height: 40px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--dbq-hairline);
  flex: none;
}
.dbq-byline__text { margin: 0; font-size: var(--dbq-step--1); color: var(--dbq-ink-3); }
.dbq-byline__name { font-weight: 600; }
.dbq-byline__role, .dbq-byline__date, .dbq-byline__rev { color: var(--dbq-ink-3); }

/* ===========================  PROSE  ================================= */
.dbq-main { padding-block: var(--dbq-section-y); }
.dbq-prose { font-size: var(--dbq-step-0); }
.dbq-prose > * { max-width: none; }
.dbq-prose p, .dbq-prose li { color: var(--dbq-ink); overflow-wrap: break-word; word-break: break-word; }
.dbq-prose h2 {
  font-size: var(--dbq-step-3);
  margin-top: var(--dbq-s6);
  margin-bottom: var(--dbq-s3);
  padding-top: var(--dbq-s2);
  scroll-margin-top: 84px;
}
.dbq-prose h3 { font-size: var(--dbq-step-2); margin-top: var(--dbq-s5); scroll-margin-top: 84px; }
.dbq-prose a:not(.dbq-cta) {
  color: var(--dbq-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-color: var(--dbq-hairline);
}
.dbq-prose a:not(.dbq-cta):hover { text-decoration-color: var(--dbq-accent); }

/* Numbered section index */
.dbq-sec-no {
  display: inline-block;
  font-family: var(--dbq-font-display);
  font-variant-numeric: tabular-nums;
  font-size: var(--dbq-step--1);
  color: var(--dbq-accent-2);
  letter-spacing: 0.06em;
  margin-right: 0.55em;
}

/* Lists with arrow markers */
.dbq-prose ul:not(.dbq-reset), .dbq-list {
  list-style: none;
  margin: 0 0 var(--dbq-s4);
  padding: 0;
}
.dbq-prose ul:not(.dbq-reset) li, .dbq-list li {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: 0.4em;
}
.dbq-prose ul:not(.dbq-reset) li::before, .dbq-list li::before {
  content: "\203A";
  position: absolute;
  left: 0; top: -0.02em;
  color: var(--dbq-accent);
  font-weight: 700;
}
.dbq-prose ol { padding-left: 1.3em; margin: 0 0 var(--dbq-s4); }
.dbq-prose ol li { margin-bottom: 0.4em; }

/* Callout */
.dbq-callout {
  background: var(--dbq-surface);
  border: 1px solid var(--dbq-hairline);
  border-left: 3px solid var(--dbq-accent);
  border-radius: var(--dbq-r-md);
  padding: var(--dbq-s4);
  margin: var(--dbq-s5) 0;
}
.dbq-callout > :last-child { margin-bottom: 0; }

/* Figures (content images, centred, capped) */
.dbq-figure {
  width: min(72%, 760px);
  margin: var(--dbq-s5) auto;
}
.dbq-figure img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: var(--dbq-r-md);
  border: 1px solid var(--dbq-hairline);
}
.dbq-figure figcaption {
  margin-top: var(--dbq-s2);
  font-size: var(--dbq-step--1);
  color: var(--dbq-ink-3);
  text-align: center;
}

/* TOC */
.dbq-toc {
  background: var(--dbq-surface);
  border: 1px solid var(--dbq-hairline);
  border-radius: var(--dbq-r-md);
  padding: var(--dbq-s3) var(--dbq-s4);
  margin: 0 0 var(--dbq-s5);
}
.dbq-toc > summary {
  cursor: pointer;
  font-family: var(--dbq-font-display);
  font-weight: 600;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.dbq-toc > summary::after { content: "+"; color: var(--dbq-accent); font-size: 1.2em; }
.dbq-toc[open] > summary::after { content: "\2212"; }
.dbq-toc ol { margin: var(--dbq-s3) 0 0; padding-left: 1.3em; }
.dbq-toc li { margin-bottom: 0.3em; }
.dbq-toc a { color: var(--dbq-ink-2); text-decoration: none; }
.dbq-toc a:hover { color: var(--dbq-accent); }

/* ============================  TABLES  =============================== */
.dbq-tablewrap { overflow-x: auto; margin: var(--dbq-s4) 0; }
table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--dbq-step-0);
  border: 1px solid var(--dbq-hairline);
  border-radius: var(--dbq-r-md);
  overflow: hidden;
}
caption { caption-side: top; text-align: left; color: var(--dbq-ink-3); font-size: var(--dbq-step--1); margin-bottom: var(--dbq-s2); }
thead th { background: var(--dbq-surface-2); }
th, td {
  text-align: left;
  padding: 0.65rem 0.85rem;
  border-bottom: 1px solid var(--dbq-hairline);
  vertical-align: top;
}
th { font-family: var(--dbq-font-display); font-weight: 600; color: var(--dbq-ink); }
td { color: var(--dbq-ink-2); }
tbody tr:nth-child(even) { background: color-mix(in oklab, var(--dbq-surface) 55%, transparent); }
tbody tr:hover { background: var(--dbq-accent-tint); }
tbody td:first-child { font-weight: 600; color: var(--dbq-ink); }
td:where([data-num]), th:where([data-num]) { text-align: right; font-variant-numeric: tabular-nums lining-nums; }
tr:last-child td { border-bottom: 0; }

/* ===========================  DETAILS / FAQ  ========================= */
details {
  border: 1px solid var(--dbq-hairline);
  border-radius: var(--dbq-r-md);
  background: var(--dbq-surface);
  padding: 0 var(--dbq-s4);
  margin-bottom: var(--dbq-s3);
}
details > summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--dbq-s3);
  padding: var(--dbq-s3) 0;
  font-family: var(--dbq-font-display);
  font-weight: 600;
  color: var(--dbq-ink);
}
details > summary::-webkit-details-marker { display: none; }
details > summary::after {
  content: "+";
  color: var(--dbq-accent);
  font-size: 1.3em;
  line-height: 1;
  flex: none;
}
details[open] > summary::after { content: "\2212"; }
details > summary + * { margin-top: 0; }
details > :not(summary) { padding-bottom: var(--dbq-s2); }
details p:last-child { margin-bottom: var(--dbq-s3); }

/* =========================  SLOTS GRID  ============================== */
.dbq-slots { padding-block: var(--dbq-section-y); border-top: 1px solid var(--dbq-hairline-2); }
.dbq-slots__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--dbq-s3); flex-wrap: wrap; }
.dbq-slots__title { margin: 0; font-size: var(--dbq-step-3); }
.dbq-slots__all { font-weight: 600; font-size: var(--dbq-step--1); white-space: nowrap; }
.dbq-slots__all::after { content: " \2192"; display: inline-block; transition: transform 0.16s ease; }
.dbq-slots__all:hover::after { transform: translateX(3px); }
.dbq-slots__intro { margin: var(--dbq-s2) 0 var(--dbq-s4); color: var(--dbq-ink-2); }
.dbq-slots__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--dbq-s3);
}
.dbq-slots__cell { min-width: 0; }
.dbq-slot {
  display: block;
  color: inherit;
  text-decoration: none;
  transition: transform 0.16s ease;
}
.dbq-slot__shot {
  display: block;
  border-radius: var(--dbq-r-md);
  border: 1px solid var(--dbq-hairline);
  overflow: hidden;
  background: var(--dbq-surface-2);
}
.dbq-slot__shot img { width: 100%; height: auto; aspect-ratio: 1 / 1; object-fit: cover; }
.dbq-slot__name {
  display: block;
  margin-top: var(--dbq-s1);
  font-size: var(--dbq-step--1);
  font-weight: 500;
  color: var(--dbq-ink-2);
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dbq-slot:hover { transform: translateY(-3px); }
.dbq-slot:hover .dbq-slot__shot { border-color: var(--dbq-accent); box-shadow: var(--dbq-shadow-hover); }
.dbq-slot:hover .dbq-slot__name { color: var(--dbq-accent); }

/* ========================  AUTHOR CARD  ============================== */
.dbq-author {
  display: flex;
  gap: var(--dbq-s4);
  align-items: flex-start;
  max-width: 780px;
  margin: var(--dbq-s6) auto 0;
  padding: var(--dbq-s5);
  background: var(--dbq-surface);
  border: 1px solid var(--dbq-hairline);
  border-radius: var(--dbq-r-md);
}
.dbq-author__photo {
  width: 120px; height: 120px;
  border-radius: var(--dbq-r-md);
  object-fit: cover;
  border: 1px solid var(--dbq-hairline);
  flex: none;
}
.dbq-author__body { min-width: 0; }
.dbq-author__eyebrow {
  margin: 0 0 2px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: var(--dbq-step--1);
  color: var(--dbq-ink-3);
}
.dbq-author__name { margin: 0 0 2px; font-size: var(--dbq-step-2); }
.dbq-author__name a { color: var(--dbq-ink); }
.dbq-author__name a:hover { color: var(--dbq-accent); }
.dbq-author__role { margin: 0 0 var(--dbq-s2); color: var(--dbq-accent-2); font-weight: 600; font-size: var(--dbq-step--1); }
.dbq-author__bio { margin: 0 0 var(--dbq-s3); color: var(--dbq-ink-2); }
.dbq-author__rev { margin: 0 0 var(--dbq-s2); font-size: var(--dbq-step--1); color: var(--dbq-ink-3); }
.dbq-author__more { font-weight: 600; }
.dbq-author__more::after { content: " \2192"; display: inline-block; transition: transform 0.16s ease; }
.dbq-author__more:hover::after { transform: translateX(3px); }

/* Author profile portrait override (ProfilePage) */
.dbq-prose img.dbq-portrait {
  width: 220px;
  height: auto;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  float: none;
  margin: 0 0 var(--dbq-s4);
  border-radius: var(--dbq-r-md);
  border: 1px solid var(--dbq-hairline);
}

/* ===========================  FOOTER  =============================== */
.dbq-footer { margin-top: var(--dbq-s6); border-top: 1px solid var(--dbq-hairline); background: var(--dbq-surface); }
.dbq-footer__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 2fr);
  gap: var(--dbq-s6) var(--dbq-s5);
  padding-block: var(--dbq-s6);
}
.dbq-logo--foot img { height: 38px; }
.dbq-footer__note { margin: var(--dbq-s3) 0 var(--dbq-s3); color: var(--dbq-ink-2); font-size: var(--dbq-step--1); max-width: 46ch; }
.dbq-footer__age {
  display: inline-block;
  margin: 0;
  font-family: var(--dbq-font-display);
  font-weight: 700;
  font-size: var(--dbq-step--1);
  color: var(--dbq-ink);
  border: 1px solid var(--dbq-ink-3);
  border-radius: 999px;
  padding: 2px 9px;
}
.dbq-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--dbq-s5) var(--dbq-s4);
}
.dbq-footer__h {
  margin: 0 0 var(--dbq-s3);
  font-size: var(--dbq-step--1);
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--dbq-ink-3);
}
.dbq-footer__col ul { list-style: none; margin: 0; padding: 0; }
.dbq-footer__col li { margin-bottom: 0.4rem; }
.dbq-footer__col a { color: var(--dbq-ink-2); font-size: var(--dbq-step--1); }
.dbq-footer__col a:hover { color: var(--dbq-accent); }
.dbq-footer__legal { border-top: 1px solid var(--dbq-hairline); }
.dbq-footer__legal p { margin: 0; padding: var(--dbq-s3) 0; font-size: var(--dbq-step--1); color: var(--dbq-ink-3); }

/* =======================  COOKIE CONSENT  =========================== */
.dbq-consent {
  position: fixed;
  right: clamp(0.6rem, 2vw, 1.2rem);
  bottom: clamp(0.6rem, 2vw, 1.2rem);
  z-index: 80;
  width: min(360px, calc(100vw - 1.2rem));
  background: var(--dbq-bg);
  border: 1px solid var(--dbq-hairline);
  border-radius: var(--dbq-r-md);
  box-shadow: 0 16px 44px -20px color-mix(in oklab, var(--dbq-ink) 60%, transparent);
  padding: var(--dbq-s4);
}
.dbq-consent[hidden] { display: none; }
.dbq-consent__txt { margin: 0 0 var(--dbq-s3); font-size: var(--dbq-step--1); color: var(--dbq-ink-2); }
.dbq-consent__btns { display: flex; gap: var(--dbq-s2); justify-content: flex-end; flex-wrap: wrap; }
.dbq-consent__btn {
  font-family: var(--dbq-font-display);
  font-weight: 600;
  font-size: var(--dbq-step--1);
  padding: 0.5em 0.9em;
  border-radius: var(--dbq-r-md);
  cursor: pointer;
  border: 1px solid var(--dbq-hairline);
  transition: background-color 0.14s ease, color 0.14s ease, transform 0.14s ease;
}
.dbq-consent__btn--ghost { background: transparent; color: var(--dbq-ink-2); }
.dbq-consent__btn--ghost:hover { background: var(--dbq-surface); }
.dbq-consent__btn--solid { background: var(--dbq-accent); color: #fff7ec; border-color: var(--dbq-accent-2); }
.dbq-consent__btn--solid:hover { background: var(--dbq-accent-2); transform: scale(1.02); }

/* ===========================  RESPONSIVE  =========================== */
@media (min-width: 901px) {
  .dbq-hero__inner { gap: var(--dbq-s4); }
}

@media (max-width: 900px) {
  .dbq-nav { display: none; }
  .dbq-header__cta { display: none; }
  .dbq-logo { margin-right: auto; }
}

@media (max-width: 760px) {
  .dbq-footer__inner { grid-template-columns: minmax(0, 1fr); }
}

@media (max-width: 640px) {
  /* Mobile hero (editorial, geen afbeelding): 1 kolom */
  .dbq-hero__inner { grid-template-columns: minmax(0, 1fr); }
  .dbq-hero__score { align-self: start; }
  .dbq-hero__title  { font-size: clamp(1.9rem, 8vw, 2.6rem); max-width: none; }
  .dbq-hero__actions{ flex-direction: column; align-items: stretch; width: 100%; }
  .dbq-hero__actions .dbq-cta { width: 100%; }
  .dbq-figure { width: 100%; }
  .dbq-author { flex-direction: column; align-items: center; text-align: center; }
  .dbq-footer__nav { grid-template-columns: minmax(0, 1fr); }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}
