/* ============================================================================
   Silverplay — style.css
   Archetyp: OPERA HOUSE — dramatischer High-Contrast-Serif + ruhiger Serif-Text,
   warmes Creme gegen tiefes Dunkel, nullte Radien, feine Programmheft-Doppellinien,
   keine Schatten, zentrierte Plakat-Titel, Akt-Nummerierung, Byline in Kapitälchen.
   Marken-Cyan (#06d1ff / #0595b8 / #5cbbd3 / #241919) als einziger edler Akzent.
   Prefix: dpp-
   ========================================================================== */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{margin:0}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit}
button{font:inherit;color:inherit}
h1,h2,h3,h4,p,ul,ol,dl,dd,figure,blockquote{margin:0}

:root{
  --dpp-wrap:1201px;
  --dpp-pad:clamp(16px,4vw,34px);

  /* warmes Creme — matte Flächen: surface heller als bg, ohne Schatten/Rahmen */
  --dpp-bg:#f3ecde;
  --dpp-surface:#faf5ea;
  --dpp-surface-2:#fffdf6;
  --dpp-ink:#1b1512;
  --dpp-ink-2:#473d36;
  --dpp-ink-3:#6e635b;
  --dpp-hairline:color-mix(in srgb, var(--dpp-ink) 16%, transparent);
  --dpp-hairline-2:color-mix(in srgb, var(--dpp-ink) 9%, transparent);
  --dpp-rule:color-mix(in srgb, var(--dpp-ink) 78%, transparent);

  /* Marken-Cyan-Familie (Pflicht-Hex) */
  --dpp-bright:#06d1ff;        /* Haupt-Markenakzent: Glow, Füllung, Fokus, Linien, Display */
  --dpp-accent:#0a6a85;        /* lesbare Tiefenstufe des Marken-Cyans: Text/Links/Icons (AA) */
  --dpp-accent-ink:#ffffff;
  --dpp-cta:#0595b8;           /* CTA-Füllung */
  --dpp-cta-ink:#241919;       /* dunkle Schrift auf Cyan-CTA (AA 4.9:1) */
  --dpp-head:#5cbbd3;          /* Marken-Masthead-Zone */
  --dpp-head-ink:#10303a;
  --dpp-dark:#133b47;          /* tiefe Teal-Kurtine: Footer/dunkle Zonen (Marken-Stufe) */
  --dpp-dark-ink:#eaf4f3;
  --dpp-badge:#241919;         /* zweiter Markenakzent / Badges */

  --dpp-tp-star:#06b277;       /* Trustpilot-Grün (Review-Part) */

  /* modulare Typo-Skala (1.25) */
  --dpp-step--1:.8125rem;
  --dpp-step-0:1rem;
  --dpp-step-1:1.25rem;
  --dpp-step-2:1.5625rem;
  --dpp-step-3:1.9531rem;
  --dpp-step-4:2.4414rem;
  --dpp-step-5:3.0518rem;

  --dpp-space:clamp(30px,4.4vw,46px);
  --dpp-gap:clamp(14px,2vw,22px);
  --dpp-r:0px;                 /* nullte Radien — Opera House */
  --dpp-col:280px;

  --dpp-ease:cubic-bezier(.2,.7,.2,1);
  --dpp-dur:.16s;

  --dpp-fdisplay:"Cormorant Garamond","Playfair Display",Georgia,"Times New Roman",serif;
  --dpp-ftext:"PT Serif","Spectral",Georgia,"Times New Roman",serif;
}

body.dpp-body{
  font-family:var(--dpp-ftext);
  font-size:1.0625rem;
  line-height:1.66;
  color:var(--dpp-ink);
  background:var(--dpp-bg);
  font-variant-numeric:tabular-nums lining-nums;
  -webkit-font-smoothing:antialiased;
}

/* Container-Invariante: .dpp-main trägt selbst Breite + Zentrierung + Padding. */
.dpp-wrap{width:100%;max-width:var(--dpp-wrap);margin-inline:auto;padding-inline:var(--dpp-pad)}
.dpp-main{width:100%;max-width:var(--dpp-wrap);margin-inline:auto;padding-inline:var(--dpp-pad);padding-block:clamp(26px,4.5vw,52px)}
/* verschachtelte .dpp-wrap im Main nicht doppelt einrücken/begrenzen */
.dpp-main .dpp-wrap{max-width:none;margin-inline:0;padding-inline:0;width:100%}

.dpp-skip{position:absolute;left:-9999px;top:0;z-index:400;background:var(--dpp-accent);color:#fff;padding:10px 18px;font-weight:700}
.dpp-skip:focus{left:0}
:focus-visible{outline:2px solid var(--dpp-bright);outline-offset:2px}
::selection{background:color-mix(in srgb,var(--dpp-bright) 30%,transparent);color:var(--dpp-ink)}
::marker{color:var(--dpp-accent)}
html{accent-color:var(--dpp-cta)}

h1,h2,h3,h4{font-family:var(--dpp-fdisplay);color:var(--dpp-ink);line-height:1.08;font-weight:700;letter-spacing:-.01em;text-wrap:balance}
strong{font-weight:700;color:var(--dpp-ink)}

/* ========================= Kopf / Masthead ========================= */
.dpp-head{
  position:sticky;top:0;z-index:100;
  background:var(--dpp-head);
  color:var(--dpp-head-ink);
  border-bottom:3px double color-mix(in srgb,var(--dpp-head-ink) 55%,transparent);
}
.dpp-head__bar{display:flex;align-items:center;gap:20px;min-height:68px;flex-wrap:nowrap}
.dpp-logo{line-height:0;flex:0 0 auto}
.dpp-logo img{height:clamp(30px,3.6vw,42px);width:auto;filter:brightness(0) saturate(0)}
.dpp-nav{flex:1 1 auto;display:flex;justify-content:flex-end;align-items:center;min-width:0}
.dpp-nav__list{list-style:none;display:flex;flex-wrap:nowrap;align-items:center;gap:clamp(12px,1.7vw,28px);padding:0;margin:0}
.dpp-nav__item{margin:0}
.dpp-nav__list a{
  position:relative;display:inline-block;text-decoration:none;
  font-family:var(--dpp-fdisplay);font-weight:700;font-size:1.02rem;
  letter-spacing:.02em;white-space:nowrap;color:var(--dpp-head-ink);
  padding:8px 1px;transition:color var(--dpp-dur) var(--dpp-ease)}
.dpp-nav__list a::after{content:"";position:absolute;left:0;right:0;bottom:2px;height:2px;background:var(--dpp-bright);transform:scaleX(0);transform-origin:left;transition:transform var(--dpp-dur) var(--dpp-ease)}
.dpp-nav__list a:hover,.dpp-nav__list a:focus-visible{color:#0a2630}
.dpp-nav__list a:hover::after,.dpp-nav__list a[aria-current="page"]::after{transform:scaleX(1)}
.dpp-nav__list a[aria-current="page"]{color:#0a2630}

/* ========================= CTA (Duoton) ========================= */
.dpp-cta{
  --_bg:var(--dpp-cta);--_fg:var(--dpp-cta-ink);
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--dpp-fdisplay);font-weight:700;font-size:1.02rem;
  letter-spacing:.04em;text-decoration:none;text-align:center;
  background:var(--_bg);color:var(--_fg);
  border:2px solid var(--dpp-cta);border-radius:var(--dpp-r);
  padding:13px 26px;min-height:48px;white-space:nowrap;cursor:pointer;
  transition:transform .14s var(--dpp-ease),background-color var(--dpp-dur) var(--dpp-ease),color var(--dpp-dur) var(--dpp-ease)}
.dpp-cta:hover{background:var(--dpp-badge);border-color:var(--dpp-badge);color:#f5efe3}
.dpp-cta:hover,.dpp-cta:focus-visible{transform:scale(1.02)}
.dpp-cta:active{transform:scale(.99)}
.dpp-cta--ghost{background:transparent;color:var(--dpp-cta);border-color:var(--dpp-cta)}
.dpp-cta--ghost:hover{background:var(--dpp-cta);color:var(--dpp-cta-ink)}
/* Kopf-CTA: dunkle Schrift auf Cyan-Masthead lesbar lassen */
.dpp-head__bar>.dpp-cta{flex:0 0 auto}

/* CTA im Fließtext immer zentriert — auf jeder Tiefe */
.dpp-ctarow{display:flex;justify-content:center;margin:1.6em 0}
.dpp-main>.dpp-cta,
.dpp-main :not(.dpp-hero__cta):not(.dpp-nav__cta)>.dpp-cta{display:flex;width:fit-content;margin:1.6em auto}

/* ========================= Burger (Vollbild-Overlay) ========================= */
.dpp-burger{color:var(--dpp-head-ink);background:none}
.dpp-burger s{transition:transform var(--dpp-dur) var(--dpp-ease),opacity var(--dpp-dur) var(--dpp-ease)}
@media(max-width:900px){
  .dpp-burger{display:inline-flex;align-items:center;justify-content:center;order:3;margin-left:auto;z-index:160}
  .dpp-nav{flex:0 0 auto;justify-content:flex-end}
  .dpp-nav__list{
    position:fixed;inset:0;z-index:150;display:none;max-width:100vw;
    flex-direction:column;align-items:center;justify-content:center;gap:30px;
    padding:90px 24px;background:var(--dpp-dark);color:var(--dpp-dark-ink)}
  .dpp-nav.is-open .dpp-nav__list{display:flex}
  .dpp-nav__list a{color:var(--dpp-dark-ink);font-size:clamp(1.6rem,7vw,2.2rem);letter-spacing:0}
  .dpp-nav__list a::after{background:var(--dpp-bright)}
  .dpp-nav__list a:hover,.dpp-nav__list a[aria-current="page"]{color:var(--dpp-bright)}
  .dpp-nav.is-open .dpp-burger{position:fixed;top:16px;right:18px;border-color:var(--dpp-dark-ink);color:var(--dpp-dark-ink)}
  .dpp-nav.is-open .dpp-burger s:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .dpp-nav.is-open .dpp-burger s:nth-child(2){opacity:0}
  .dpp-nav.is-open .dpp-burger s:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
}

/* ========================= Hero (Ledger / Plakat) ========================= */
.dpp-hero{
  padding-block:clamp(24px,3.4vw,40px);
  background:
    linear-gradient(180deg,color-mix(in srgb,var(--dpp-bright) 7%,transparent),transparent 62%),
    var(--dpp-bg);
  border-bottom:3px double var(--dpp-rule);
}
.dpp-hero__inner{
  display:grid;align-items:center;
  gap:clamp(20px,3vw,40px);
  grid-template-columns:minmax(0,.82fr) minmax(0,1fr);
  grid-template-areas:"media center" "facts facts";
}
.dpp-hero__media{grid-area:media;position:relative;isolation:isolate;margin-inline:auto;width:100%;max-width:440px}
.dpp-hero__media::before{
  content:"";position:absolute;inset:-9% 0;z-index:0;
  background:radial-gradient(60% 60% at 50% 45%,color-mix(in srgb,var(--dpp-bright) 38%,transparent),transparent 70%);
  filter:blur(34px)}
.dpp-hero__media img{
  position:relative;z-index:1;width:100%;aspect-ratio:1/1;object-fit:cover;
  border-radius:var(--dpp-r);border:1px solid var(--dpp-hairline)}

.dpp-hero__center{grid-area:center;display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(12px,1.6vw,18px)}
.dpp-hero__kicker{
  font-family:var(--dpp-fdisplay);font-weight:700;font-size:.96rem;
  text-transform:uppercase;letter-spacing:.22em;color:var(--dpp-accent);
  display:block;padding-bottom:2px;border-bottom:1px solid var(--dpp-hairline)}
.dpp-hero__h1{font-size:clamp(2.1rem,5.4vw,3.7rem);margin:0;line-height:1.04;max-width:18ch}
.dpp-hero__lead{font-size:clamp(1.06rem,1.7vw,1.28rem);line-height:1.55;color:var(--dpp-ink-2);max-width:52ch;text-wrap:pretty}
.dpp-hero__cta{margin:.2em 0 0}
.dpp-hero__cta.dpp-ctarow{margin:.2em 0 0}

/* Fakten-Band: volle Breite unter den Spalten, Markenzone */
.dpp-hero__facts{
  grid-area:facts;display:grid;gap:0;margin-top:clamp(6px,1.2vw,12px);
  grid-template-columns:repeat(4,minmax(0,1fr));
  background:var(--dpp-head);color:var(--dpp-head-ink);
  border-block:3px double color-mix(in srgb,var(--dpp-head-ink) 50%,transparent)}
.dpp-hero__fact{
  padding:16px 18px;text-align:center;
  border-left:1px solid color-mix(in srgb,var(--dpp-head-ink) 22%,transparent)}
.dpp-hero__fact:first-child{border-left:0}
.dpp-hero__fact dt{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700;color:#0c2a33;opacity:.9}
.dpp-hero__fact dd{font-family:var(--dpp-fdisplay);font-weight:700;font-size:1.5rem;line-height:1.1;margin-top:3px;color:#0a2630}

/* ========================= Seitentitel (Plakat-Variante) ========================= */
.dpp-pagetitle{padding-block:clamp(26px,4vw,46px);background:linear-gradient(180deg,color-mix(in srgb,var(--dpp-bright) 6%,transparent),transparent 70%)}
.dpp-pagetitle__inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding-block:clamp(14px,2vw,22px);border-block:3px double var(--dpp-rule)}
.dpp-pagetitle__h1{font-size:clamp(1.9rem,4.4vw,3rem);margin:0;line-height:1.06;max-width:24ch}
.dpp-pagetitle__kicker{order:-1;font-family:var(--dpp-fdisplay);text-transform:uppercase;letter-spacing:.24em;font-size:.82rem;font-weight:700;color:var(--dpp-accent)}
.dpp-pagetitle__lead{font-size:clamp(1.02rem,1.5vw,1.18rem);color:var(--dpp-ink-2);max-width:60ch;line-height:1.55;text-wrap:pretty}

/* ========================= Breadcrumbs ========================= */
.dpp-crumbs{padding-block:12px}
.dpp-crumbs__list{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:0;margin:0;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--dpp-ink-3)}
.dpp-crumbs__item{display:flex;align-items:center;gap:8px}
.dpp-crumbs__item+.dpp-crumbs__item::before{content:"·";color:var(--dpp-ink-3)}
.dpp-crumbs__item a{text-decoration:none;color:var(--dpp-accent)}
.dpp-crumbs__item a:hover{text-decoration:underline;text-underline-offset:2px}
.dpp-crumbs__item [aria-current="page"]{color:var(--dpp-ink-2);font-weight:700}

/* ========================= Byline (Kapitälchen, Datum-Grid) ========================= */
.dpp-byline{display:flex;gap:16px;align-items:center;padding-block:16px;border-top:1px solid var(--dpp-hairline);border-bottom:1px solid var(--dpp-hairline)}
.dpp-byline__photo{flex:0 0 auto;width:56px;height:56px;object-fit:cover;border-radius:var(--dpp-r);border:1px solid var(--dpp-hairline)}
.dpp-byline__meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px 18px;flex:1 1 auto;min-width:0}
.dpp-byline__names{display:flex;flex-direction:column;gap:2px;min-width:0}
.dpp-byline__author{font-family:var(--dpp-fdisplay);font-weight:700;font-size:1.12rem;text-decoration:none;color:var(--dpp-ink)}
.dpp-byline__author:hover{color:var(--dpp-accent)}
.dpp-byline__role{font-size:.78rem;text-transform:uppercase;letter-spacing:.13em;color:var(--dpp-ink-3)}
.dpp-byline__rev{font-size:.82rem;color:var(--dpp-ink-3)}
.dpp-byline__rev a{color:var(--dpp-accent);text-decoration:none}
.dpp-byline__rev a:hover{text-decoration:underline}
.dpp-byline__dates{display:grid;grid-template-columns:repeat(2,auto);gap:4px 22px}
.dpp-byline__date{display:flex;flex-direction:column}
.dpp-byline__date-k{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--dpp-ink-3)}
.dpp-byline__date-v{font-weight:700;font-size:.92rem;color:var(--dpp-ink-2)}

/* ========================= Fließtext / Prosa ========================= */
.dpp-prose{max-width:none}
.dpp-doc{max-width:none}
.dpp-doc p,.dpp-doc .dpp-authorpage{max-width:none}
.dpp-authorpage p{max-width:none}

.dpp-prose p{margin-top:1em;color:var(--dpp-ink-2);line-height:1.7;text-wrap:pretty}
.dpp-prose>p:first-child{margin-top:0}
.dpp-prose h2{font-size:var(--dpp-step-3);margin-top:1.7em;line-height:1.1;color:var(--dpp-ink)}
.dpp-prose h3{font-size:var(--dpp-step-1);margin-top:1.3em;color:var(--dpp-ink);font-weight:700}
.dpp-prose h2+p,.dpp-prose h3+p{margin-top:.6em}

/* Akt-Nummerierung — Opera-House-Signatur (nur inhaltliche Sektionen ohne Klasse) */
.dpp-prose{counter-reset:dpp-act}
.dpp-prose>section{margin-top:var(--dpp-space)}
.dpp-prose>section:not([class]){counter-increment:dpp-act}
.dpp-prose>section:not([class])>h2{margin-top:0}
.dpp-prose>section:not([class])>h2::before{
  content:"Akt " counter(dpp-act,upper-roman);
  display:block;font-family:var(--dpp-fdisplay);font-size:.82rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.24em;color:var(--dpp-accent);margin-bottom:.5em}
.dpp-prose section[id],.dpp-prose [id]{scroll-margin-top:90px}

/* Links im Fließtext — verfeinerte Unterstreichung, Akzent */
.dpp-prose a:not(.dpp-cta){
  color:var(--dpp-accent);text-decoration:underline;
  text-decoration-thickness:1px;text-underline-offset:2px;
  text-decoration-color:color-mix(in srgb,var(--dpp-accent) 45%,transparent);
  transition:color var(--dpp-dur) var(--dpp-ease),text-decoration-color var(--dpp-dur) var(--dpp-ease)}
.dpp-prose a:not(.dpp-cta):hover{color:var(--dpp-cta);text-decoration-color:var(--dpp-cta)}

/* Lead / Lede */
.dpp-lede,.dpp-lead{font-size:clamp(1.12rem,1.7vw,1.32rem);line-height:1.55;color:var(--dpp-ink);margin-top:1em;font-style:italic}
.dpp-lede strong,.dpp-lead strong{font-style:normal}

/* Listen */
.dpp-prose ul,.dpp-prose ol{margin-top:1em;padding:0;list-style:none}
.dpp-prose ul>li{position:relative;padding-left:1.6em;margin-top:.5em;line-height:1.65;color:var(--dpp-ink-2)}
.dpp-prose ul>li::before{content:"";position:absolute;left:.15em;top:.62em;width:8px;height:8px;background:var(--dpp-accent);transform:rotate(45deg)}
.dpp-prose ol{counter-reset:dpp-li}
.dpp-prose ol>li{position:relative;padding-left:2.6em;margin-top:.7em;line-height:1.65;color:var(--dpp-ink-2);counter-increment:dpp-li}
.dpp-prose ol>li::before{content:counter(dpp-li);position:absolute;left:0;top:.05em;width:1.85em;text-align:center;font-family:var(--dpp-fdisplay);font-weight:700;font-size:1rem;color:var(--dpp-accent);border-right:2px solid var(--dpp-accent);padding-right:.35em;line-height:1.4}
.dpp-prose li strong{color:var(--dpp-ink)}

/* Bilder / Figuren — vollständig, mittig, gekappt */
.dpp-prose figure,.dpp-figure{width:min(72%,760px);margin:1.6em auto;text-align:center}
.dpp-prose figure img,.dpp-figure img,.dpp-img{width:100%;height:auto;border:1px solid var(--dpp-hairline);border-radius:var(--dpp-r)}
.dpp-prose figcaption,.dpp-figure figcaption{margin-top:.7em;font-size:.86rem;color:var(--dpp-ink-3);line-height:1.5;font-style:italic}

/* Autorenseite — Porträt links, fixe Größe (über .dpp-prose img) */
.dpp-authorpage::after{content:"";display:block;clear:both}
.dpp-authorpage__photo{width:200px;height:auto;aspect-ratio:3/4;object-fit:cover;float:left;margin:6px 26px 14px 0;border:1px solid var(--dpp-hairline);border-radius:var(--dpp-r)}
.dpp-authorpage h2{margin-top:1.5em}

/* ========================= Tabellen (Programmheft) ========================= */
.dpp-tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.6em 0}
.dpp-prose table,.dpp-main table,table{
  width:100%;border-collapse:collapse;background:var(--dpp-surface);
  font-size:.97rem;line-height:1.45;
  border-top:3px double var(--dpp-rule);border-bottom:3px double var(--dpp-rule)}
caption{caption-side:top;text-align:left;font-size:.86rem;color:var(--dpp-ink-3);padding-bottom:.6em;font-style:italic}
thead th{
  background:var(--dpp-surface-2);text-align:left;vertical-align:bottom;
  font-family:var(--dpp-fdisplay);font-weight:700;font-size:.86rem;
  text-transform:uppercase;letter-spacing:.06em;color:var(--dpp-ink);
  padding:12px 15px;border-bottom:2px solid var(--dpp-rule)}
th,td{padding:11px 15px;text-align:left;vertical-align:top}
tbody td{border-bottom:1px solid var(--dpp-hairline-2);color:var(--dpp-ink-2)}
tbody tr:last-child td{border-bottom:0}
tbody tr:nth-child(even){background:color-mix(in srgb,var(--dpp-ink) 3%,transparent)}
tbody tr:hover{background:color-mix(in srgb,var(--dpp-bright) 9%,transparent)}
tbody td:first-child{font-weight:700;color:var(--dpp-ink)}

/* ========================= Spiel-Showcase (Slots) ========================= */
.dpp-slots{padding-block:clamp(22px,3.4vw,40px)}
.dpp-slots__h{font-size:var(--dpp-step-3);margin-bottom:.8em;text-align:center}
.dpp-slots__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,154px),1fr));gap:14px}
.dpp-slot{
  display:block;text-decoration:none;color:inherit;min-width:0;
  background:var(--dpp-surface);border:1px solid var(--dpp-hairline);border-radius:var(--dpp-r);
  overflow:hidden;transition:border-color var(--dpp-dur) var(--dpp-ease)}
.dpp-slot:hover,.dpp-slot:focus-visible{border-color:var(--dpp-accent)}
.dpp-slot__name{display:block;padding:10px 12px;font-family:var(--dpp-fdisplay);font-weight:700;font-size:.92rem;line-height:1.25;border-top:1px solid var(--dpp-hairline)}

/* ========================= 404 ========================= */
.dpp-404{text-align:center}
.dpp-404__top{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:1em}
.dpp-404__code{font-family:var(--dpp-fdisplay);font-weight:700;font-size:clamp(4rem,12vw,7rem);line-height:1;color:var(--dpp-accent)}
.dpp-404 h1{font-size:var(--dpp-step-3)}
.dpp-404 p{margin-inline:auto;max-width:48ch}
.dpp-404__nav{margin-top:1.4em}
.dpp-404__nav a{display:inline-flex;align-items:center;gap:.5em;font-family:var(--dpp-fdisplay);font-weight:700;text-decoration:none;color:var(--dpp-cta-ink);background:var(--dpp-cta);padding:13px 26px;min-height:48px;border:2px solid var(--dpp-cta);transition:background-color var(--dpp-dur) var(--dpp-ease),color var(--dpp-dur) var(--dpp-ease)}
.dpp-404__nav a:hover{background:var(--dpp-badge);border-color:var(--dpp-badge);color:#f5efe3}

/* ========================= Footer (Kurtine) ========================= */
.dpp-foot{background:var(--dpp-dark);color:var(--dpp-dark-ink);margin-top:clamp(40px,6vw,72px);padding-block:clamp(30px,4vw,48px);border-top:3px double color-mix(in srgb,var(--dpp-dark-ink) 45%,transparent)}
.dpp-foot__inner{display:grid;gap:clamp(18px,2.6vw,28px)}
.dpp-foot__top{display:flex;align-items:center;justify-content:space-between;gap:16px}
.dpp-foot__logo img{height:40px;width:auto}
.dpp-foot__age{flex:0 0 auto;font-family:var(--dpp-fdisplay);font-weight:700;border:2px solid currentColor;border-radius:var(--dpp-r);padding:2px 9px;letter-spacing:.02em}
.dpp-foot__disc{font-size:.86rem;line-height:1.6;color:color-mix(in srgb,var(--dpp-dark-ink) 80%,transparent);max-width:90ch}
.dpp-foot__cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,190px),1fr));gap:20px 24px}
.dpp-foot__col{min-width:0}
.dpp-foot__h{font-family:var(--dpp-fdisplay);font-size:.82rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:12px;color:var(--dpp-dark-ink);padding-bottom:8px;border-bottom:1px solid color-mix(in srgb,var(--dpp-dark-ink) 28%,transparent)}
.dpp-foot__list{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.dpp-foot__list a{text-decoration:none;color:color-mix(in srgb,var(--dpp-dark-ink) 84%,transparent);font-size:.9rem;transition:color var(--dpp-dur) var(--dpp-ease)}
.dpp-foot__list a:hover{color:var(--dpp-bright)}
.dpp-foot__bar{display:flex;flex-direction:column;gap:6px;padding-top:18px;border-top:1px solid color-mix(in srgb,var(--dpp-dark-ink) 24%,transparent)}
.dpp-foot__nap{font-size:.82rem;color:color-mix(in srgb,var(--dpp-dark-ink) 78%,transparent);line-height:1.55}
.dpp-foot__nap a{color:var(--dpp-bright);text-decoration:none}
.dpp-foot__nap a:hover{text-decoration:underline}
.dpp-foot__copy{font-size:.82rem;color:color-mix(in srgb,var(--dpp-dark-ink) 64%,transparent)}

/* ========================= Cookie-Banner ========================= */
.dpp-cookie{position:fixed;left:0;right:0;bottom:0;z-index:300;background:var(--dpp-ink);color:#f5efe3;padding:16px 0;border-top:3px double color-mix(in srgb,#f5efe3 40%,transparent)}
.dpp-cookie__inner{display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.dpp-cookie__txt{font-size:.88rem;line-height:1.5;flex:1 1 380px;min-width:0;margin:0}
.dpp-cookie__txt a{color:var(--dpp-bright);text-decoration:underline;text-underline-offset:2px}
.dpp-cookie__btns{display:flex;gap:10px;flex:0 0 auto;flex-wrap:wrap}
.dpp-cookie__btn{font-family:var(--dpp-fdisplay);font-weight:700;border:2px solid #f5efe3;background:transparent;color:#f5efe3;padding:10px 18px;min-height:46px;border-radius:var(--dpp-r);cursor:pointer;transition:background-color var(--dpp-dur) var(--dpp-ease),color var(--dpp-dur) var(--dpp-ease)}
.dpp-cookie__btn:hover{background:#f5efe3;color:var(--dpp-ink)}
.dpp-cookie__btn--ok{background:var(--dpp-cta);color:var(--dpp-cta-ink);border-color:var(--dpp-cta)}
.dpp-cookie__btn--ok:hover{background:var(--dpp-bright);border-color:var(--dpp-bright);color:var(--dpp-cta-ink)}

/* ========================= Reveal-Übergang (Framework setzt .revealed) ========================= */
html.dpp-js [data-dpp-reveal]{opacity:0;transform:translateY(20px)}
html.dpp-js [data-dpp-reveal].revealed{opacity:1;transform:none;transition:opacity .55s var(--dpp-ease),transform .55s var(--dpp-ease)}

/* ========================= Adaptiv ========================= */
@media(max-width:1020px){
  .dpp-hero__inner{grid-template-columns:minmax(0,.9fr) minmax(0,1fr)}
}
@media(max-width:860px){
  .dpp-hero__inner{grid-template-columns:minmax(0,1fr);grid-template-areas:"media" "center" "facts"}
  .dpp-hero__media{max-width:380px}
  .dpp-hero__h1{max-width:24ch}
}
@media(max-width:640px){
  body{overflow-x:hidden}
  .dpp-head__bar{min-height:60px;gap:12px}
  .dpp-head__bar>.dpp-cta{display:none}            /* CTA im Burger-Overlay erreichbar */

  /* CTA-Label darf auf schmalem Viewport umbrechen statt zu ueberlaufen */
  .dpp-cta{white-space:normal;max-width:100%}

  .dpp-hero{padding-block:clamp(16px,5vw,24px)}
  .dpp-hero__media{max-width:min(74vw,300px)}
  .dpp-hero__media img{aspect-ratio:1/1;object-fit:cover}  /* 1:1 bleibt, Quelle quadratisch -> kein Crop */
  .dpp-hero__h1{font-size:clamp(1.85rem,8vw,2.5rem);max-width:none}
  .dpp-hero__facts{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dpp-hero__fact{border-left:1px solid color-mix(in srgb,var(--dpp-head-ink) 22%,transparent);border-top:1px solid color-mix(in srgb,var(--dpp-head-ink) 22%,transparent);padding:13px 12px}
  .dpp-hero__fact:nth-child(odd){border-left:0}
  .dpp-hero__fact:nth-child(-n+2){border-top:0}
  .dpp-hero__fact dd{font-size:1.3rem}

  .dpp-byline{flex-wrap:wrap}
  .dpp-byline__meta{flex-direction:column;align-items:flex-start;gap:10px}
  .dpp-byline__dates{grid-template-columns:1fr 1fr;gap:4px 18px}

  .dpp-prose figure,.dpp-figure{width:100%;margin-inline:0}
  .dpp-authorpage__photo{width:150px;margin:2px 18px 10px 0}

  .dpp-prose h2{font-size:var(--dpp-step-2)}
  table{font-size:.92rem}
  th,td{padding:9px 11px}

  .dpp-slots__grid{grid-template-columns:repeat(auto-fill,minmax(min(50%,130px),1fr));gap:11px}

  .dpp-foot__cols{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
  .dpp-cookie__btns{flex:1 1 100%}
  .dpp-cookie__btn{flex:1 1 auto}
}
@media(max-width:420px){
  .dpp-foot__cols{grid-template-columns:1fr}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  html.dpp-js [data-dpp-reveal]{opacity:1!important;transform:none!important}
}
