/*
Theme Name: DüsenPils
Theme URI: https://example.com/
Author: G-vent
Author URI: https://example.com/
Description: Custom WordPress Theme für DüsenPils (Startseite + Scrollpages Trinken/Ausschenken + Kontakt).
Version: 1.2.6
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dusenpils
*/

/* Base variables */
:root{
  --dusen-yellow:#fff200;
  --dusen-gray:#231f20;
  --ink:#000000;
  --muted:#b9b9b9;
  --muted2:#d6d6d6;
  --white:#ffffff;

  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-sm: 10px;

  --container: 1120px;
  --shadow: 0 16px 50px rgba(0,0,0,.15);
  --stroke: 2px;
  --header-gap: 14px;
}

/* Typography */
html,body{height:100%;}
body{
  margin:0;
  font-family: Helvetica, "Helvetica Neue", Arial, sans-serif;
  color: var(--dusen-gray);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
*{box-sizing:border-box;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
.sr-only{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}

.container{
  width: min(var(--container), calc(100% - 2*24px));
  margin: 0 auto;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 14px 18px;
  border: 2px solid var(--ink);
  background: var(--dusen-yellow);
  color: var(--dusen-gray);
  font-weight: 700;
  letter-spacing:.01em;
  cursor:pointer;
  transition: transform .12s ease, opacity .12s ease, background .12s ease, border-color .12s ease;
  user-select:none;
}
.btn:active{transform: translateY(1px);}
.btn--square{border-radius:0;}
.btn--rounded{border-radius:999px;}
.btn--outline{
  background: transparent;
  border-color: var(--dusen-yellow);
  color: var(--dusen-yellow);
}
.btn--dark{
  background: var(--dusen-gray);
  border-color: var(--dusen-gray);
  color: var(--dusen-yellow);
}
.btn--ghost{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.15);
  color: var(--white);
}

/* Headings */
h1,h2,h3{margin:0;}
.kicker{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--dusen-yellow);
  color: var(--ink);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.headline{
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: .95;
}
.headline--xl{font-size: clamp(38px, 5vw, 76px);}
.headline--lg{font-size: clamp(30px, 4vw, 56px);}
.headline--md{font-size: clamp(24px, 3vw, 40px);}

.outline-yellow{
  color: var(--dusen-yellow);
  -webkit-text-stroke: var(--stroke) var(--ink);
  text-stroke: var(--stroke) var(--ink);
  /* fallback */
  text-shadow:
    -1px -1px 0 var(--ink),
    1px -1px 0 var(--ink),
    -1px 1px 0 var(--ink),
    1px 1px 0 var(--ink);
}

/* Section spacing */
.section{padding: 40px 0;}
.section--tight{padding: 64px 0;}
.section--dark{background: var(--dusen-gray); color: var(--white);}
.section--yellow{background: var(--dusen-yellow); color: var(--ink);}
.muted{color: var(--muted);}
.muted2{color: var(--muted2);}

/* Age gate */
.age-gate{
  position:fixed; inset:0; z-index:9999;
  display:none;
  background: var(--dusen-gray);
  color: var(--white);
}
.age-gate.is-open{display:flex;}
.age-gate__inner{
  margin:auto;
  width: min(760px, calc(100% - 2*24px));
  text-align:center;
  padding: 44px 24px;
}
.age-gate__logo{width:min(360px, 70vw); margin: 0 auto 18px;}
.age-gate__question{
  font-size: clamp(34px, 5vw, 56px);
  font-weight: 900;
  color: var(--dusen-yellow);
  margin: 10px 0 10px;
  letter-spacing: -0.02em;
}
.age-gate__text{
  margin: 0 auto 22px;
  color: var(--muted2);
  max-width: 44ch;
  font-size: 16px;
  line-height: 1.45;
}
.age-gate__actions{
  display:flex;
  justify-content:center;
  gap: 14px;
  flex-wrap:wrap;
}
.age-gate__underage{
  margin-top: 16px;
  display:none;
  color: var(--muted2);
  font-size: 14px;
}
.age-gate__underage.is-visible{display:block;}

/* Hero */
.hero{
  position: relative;
  min-height: 92vh;
  display:grid;
  align-items:center;
  overflow:hidden;
  background: #111;
  color: var(--white);
}
.hero__media{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover;
  transform: scale(1.02);
}
.hero__overlay{
  position:absolute; inset:0;
  background: rgba(35,31,32,.60);
}
.hero__pattern{
  position:absolute;
  right:-32px; bottom:-32px;
  width: min(560px, 75vw);
  height: min(560px, 75vw);
  object-fit: cover;
  object-position: bottom right;
  opacity: .9;
  pointer-events:none;
  filter: drop-shadow(0 18px 55px rgba(0,0,0,.25));
}
.hero__content{
  position:relative;
  z-index:2;
  text-align:center;
  padding: 72px 0 104px;
}
.hero__logo{width: min(600px, 95vw); margin: 0 auto 20px;}
.hero__claim{
  font-size: clamp(20px, 2.2vw, 34px);
  font-weight: 1000;
  margin: 0 0 22px;
}
.hero__cta{margin-top: 10px;}
.hero__scroll{
  position:absolute;
  left:50%;
  transform: translateX(-50%);
  bottom: calc(28px + env(safe-area-inset-bottom));
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  width: 44px; height: 44px;
  background: transparent;
  border: none;
}
.hero__scroll svg{width:34px;height:34px;}
.hero__scroll .bounce{
  animation: bounce 1.4s ease-in-out infinite;
  transform-origin:center;
}
@keyframes bounce{
  0%,100%{transform: translateY(-2px);}
  50%{transform: translateY(8px);}
}

/* Header */
.site-header{
  position: fixed;
  top: var(--header-gap);
  left: 0; right: 0;
  z-index: 2000;
  pointer-events:none;
  opacity:0;
  transform: translateY(-8px);
  transition: opacity .18s ease, transform .18s ease;
}
.site-header.is-visible{
  opacity:1;
  transform: translateY(0);
  pointer-events:auto;
}
.site-header__bar{
  width: min(var(--container), calc(100% - 2*24px));
  margin: 0 auto;
  background: rgba(35,31,32,.86);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  padding: 12px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
}
.brand{
  display:flex; align-items:center; gap: 10px;
  min-width: 180px;
}
.brand img{width: 150px; height:auto;}
.nav{
  display:flex; align-items:center; gap: 18px;
}
.nav a, .nav button{
  background:none; border:none;
  color: var(--white);
  font-weight: 800;
  font-size: 17px;
  padding: 10px 10px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap: 8px;
}
.nav .caret{
  width: 10px; height: 10px;
  display:inline-block;
  transform: translateY(1px);
  opacity:.9;
}

.dropdown{position:relative;}
/* bridge the hover gap between toggle and panel so the menu doesn't collapse while moving into the submenu */
.dropdown::after{
  content:'';
  position:absolute;
  left:0; right:0;
  top:100%;
  height: 12px;
}
.dropdown__panel{
  position:absolute;
  top: calc(100% + 10px);
  right:0;
  min-width: 240px;
  background: rgba(35,31,32,.96);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow);
  padding: 10px;
  display:none;
}
.dropdown.is-open .dropdown__panel{display:block;}
.dropdown__panel a{
  display:block;
  padding: 10px 12px;
  border-radius: 10px;
  color: rgba(255,255,255,.92);
  font-weight: 700;
}
.dropdown__panel a:hover{background: rgba(255,255,255,.08);}

/* Mobile menu */
.burger{display:none;}
.burger button{
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  color: var(--white);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 800;
  cursor:pointer;
}
.mobile-panel{
  display:none;
  width: min(var(--container), calc(100% - 2*24px));
  margin: 10px auto 0;
  background: rgba(35,31,32,.92);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-lg);
  padding: 10px;
  box-shadow: var(--shadow);
}
.mobile-panel.is-open{display:block;}
.mobile-panel a{
  display:block;
  padding: 12px 12px;
  color: var(--white);
  font-weight: 800;
  border-radius: 12px;
}
.mobile-panel a:hover{background: rgba(255,255,255,.08);}

/* Layout blocks */
.grid-2{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 44px;
  align-items:center;
}
.card-row{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 26px;
}
.glass-card{
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--radius-lg);
  padding: 22px 20px;
  min-height: 220px;
}
.glass-card__icon{
  width: 56px; height: 56px;
  border-radius: 14px;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.22);
  margin-bottom: 14px;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.glass-card__icon img{width:100%;height:100%;object-fit:cover;}
.glass-card h3{
  font-size: 18px;
  margin: 0 0 8px;
  color: var(--white);
  font-weight: 900;
  letter-spacing: -0.01em;
}
.glass-card p{margin:0; color: rgba(255,255,255,.78); line-height: 1.5;}

.photo-frame{
  position:relative;
  border-radius: var(--radius-lg);
  overflow:hidden;
  box-shadow: var(--shadow);
  border: 1px solid rgba(0,0,0,.08);
}
.photo-frame img{width:100%;height:100%;object-fit:cover;}
.photo-frame__pattern{
  position:absolute;
  right:-34px; top:-34px;
  width: min(360px, 60%);
  opacity: .9;
  pointer-events:none;
  mix-blend-mode:multiply;
  filter: drop-shadow(0 10px 28px rgba(0,0,0,.18));
}

.placeholder{
  border: 2px dashed rgba(0,0,0,.18);
  border-radius: var(--radius-lg);
  padding: 26px;
  color: rgba(0,0,0,.55);
  background: rgba(0,0,0,.02);
}

/* Instagram tag */
.tag-link{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 2px solid rgba(0,0,0,.12);
  background: rgba(0,0,0,.03);
  font-weight: 800;
  margin-top: 16px;
}

/* CTA section */
.cta-grid{
  display:flex;
  gap: 14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top: 22px;
}

/* Footer */
.site-footer{
  background: var(--dusen-gray);
  color: var(--white);
  padding: 54px 0;
}
.footer-grid{
  display:grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 22px;
  align-items:start;
}
.footer-title{
  color: var(--dusen-yellow);
  font-weight: 900;
  margin: 0 0 10px;
  letter-spacing: -0.01em;
}
.footer-links a{
  display:block;
  padding: 6px 0;
  color: rgba(255,255,255,.78);
  font-weight: 700;
}
.footer-links a:hover{color: rgba(255,255,255,.95);}
.footer-links--icons a{
  display:flex;
  align-items:center;
  gap: 10px;
}
.footer-icon{
  display:inline-flex;
  color: var(--dusen-yellow);
}
.footer-icon .dusen-icon{display:block;}
.footer-brand img{width: 160px; margin-bottom: 12px;}

/* Responsive */
@media (max-width: 900px){
  .grid-2{grid-template-columns: 1fr; gap: 24px;}
  .card-row{grid-template-columns: 1fr; }
  .nav{display:none;}
  .burger{display:block;}
  .brand img{width: 120px;}
  .section{padding: 70px 0;}
  .hero__content{padding: 64px 0 110px;}
  .footer-grid{grid-template-columns: 1fr; }
}

/* Nur typische Content-Blöcke begrenzen, nicht Layout-Wrapper/Sections */
.entry-content > :where(p, ul, ol, h1, h2, h3, h4, h5, h6, blockquote, figure){
  max-width: var(--container);
  margin-left: auto;
  margin-right: auto;
}

/* Sections dürfen volle Breite */
.entry-content > .section,
.entry-content > .wp-block-group.section{
  max-width: none;
}

/* Full-bleed Sections (wie alignfull) */
.entry-content > .section{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}


/* Rundung + sauber abschneiden (auch für Overlay) */
.dusen-rounded,
.dusen-rounded a,
.dusen-rounded img,
.dusen-rounded [style*="background-image"] {
  border-radius: 12px !important;
}

.dusen-rounded,
.dusen-rounded a {
  overflow: hidden !important;
  display: block;
}

/* Hintergrund normal + Hover (transparent grau -> transparent #fff200) */
.dusen-hoverbg{
  background: rgba(46, 42, 43, 0.50); /* düsen-gray (#231f20) leicht transparent */
  transition: background-color 180ms ease, background 180ms ease;
}

.dusen-hoverbg:hover{
  background: rgba(255, 242, 0, 0.18); /* #fff200 leicht transparent */
}

/* Inhalt in Spalten nicht direkt am Rand */
.wp-block-column {
  padding: 25px;
}

/* Section: grauer Grund + Bild-Layer oben drauf */
.section--bgimg-layer{
  position: relative;
  overflow: hidden;
  background: #231f20; /* Düsen-Grau */
}

/* das Bild als "Hintergrund-Layer" */
.section--bgimg-layer .section__bgimg{
  position: absolute;
  inset: 0;
  margin: 0;
  max-width: none;
  z-index: 0;
  pointer-events: none;
}

.section--bgimg-layer .section__bgimg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Inhalt wieder nach vorn */
.section--bgimg-layer > .wp-block-group__inner-container,
.section--bgimg-layer > .wp-block-cover__inner-container{
  position: relative;
  z-index: 1;
}

/* --- Düsen: Mini-Hero für Unterseiten --- */
.wp-block-cover.dusen-mini-hero{
  min-height: 50vh;
  align-items: flex-end;
  justify-content: flex-start; /* ADDED: links statt mittig */
  padding: clamp(28px, 4vw, 64px);
  position: relative;
}

/* Mini-Hero: Inhalt wieder in den normalen Bereich zentrieren */
.wp-block-cover.dusen-mini-hero .wp-block-cover__inner-container{
  width: min(var(--container), calc(100% - 2*24px));
  margin-left: auto !important;
  margin-right: auto !important;
}


/* Ghost-Wort (wie im Screenshot) */
.dusen-mini-hero .dusen-hero-ghost{
  position: absolute;
  left: clamp(-18px, -2vw, 0px);              /* CHANGED */
  bottom: clamp(14px, 4vw, 60px);             /* CHANGED: hinter Titel */
  margin: 0;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;                       /* CHANGED */
  font-size: clamp(56px, 10vw, 140px);
  line-height: 0.9;
  color: rgba(255,242,0,.18);                  /* CHANGED: minimal stärker */
  pointer-events: none;
  user-select: none;
  z-index: 0;
  white-space: nowrap;
  transform: rotate(-8deg);                    /* ADDED */
  transform-origin: left bottom;               /* ADDED */
}

/* Headline */
.dusen-mini-hero .dusen-hero-title{
  position: relative;
  z-index: 1;
  margin: 0;
  font-weight: 800;
  line-height: 1.05;
  font-size: clamp(38px, 5vw, 64px);
  text-align: left;                            /* ADDED */
}

/* Subtitle */
.dusen-mini-hero .dusen-hero-subtitle{
  position: relative;
  z-index: 1;
  margin: 10px 0 0 0;
  font-size: clamp(16px, 2vw, 18px);
  opacity: .92;
  text-align: left;                            /* ADDED */
}

/* --- Seitentitel (vom Theme) ausblenden NUR auf Seiten mit Mini-Hero --- */
/* (robuste Selektoren, je nach WP/Theme-Markup) */
.page .dusen-mini-hero ~ * .entry-title,
.page .dusen-mini-hero ~ * .entry-header,
.page .dusen-mini-hero ~ * .wp-block-post-title{
  display: none !important;
}

/* =========================================================
   DÜSEN – Mini Hero (clean + full width) + Fix für padding-top:140px
   ========================================================= */

/* Full width breakout für Gutenberg */
.entry-content > .alignfull,
.wp-block-post-content > .alignfull{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.wp-block-cover.alignfull{
  max-width: 100vw !important;
}

/* Mini-Hero immer volle Breite (auch ohne WP-Button) */
.dusen-mini-hero{
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  margin-top: 0 !important;
}
body{ overflow-x: hidden; }

/* Mini-Hero Layout */
.wp-block-cover.dusen-mini-hero{
  position: relative;
  min-height: 50vh !important;
  padding: clamp(28px, 4vw, 64px) !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
}

/* Inner Container über volle Höhe -> Ghost positioniert sich am Hero */
.wp-block-cover.dusen-mini-hero .wp-block-cover__inner-container{
  width: min(1100px, 100%);
  margin: 0 auto;
  height: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
}

/* Ghost hinter der Headline */
.dusen-mini-hero .dusen-hero-ghost{
  position: absolute;
  left: clamp(-18px, -2vw, 0px);
  bottom: 0 !important;
  transform: rotate(-8deg);
  transform-origin: left bottom;
  margin: 0 !important;

  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: clamp(56px, 9vw, 140px);
  line-height: .9;
  color: rgba(255,242,0,.18);

  z-index: 0;
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
}

/* Headline + Subtitle über Ghost */
.dusen-mini-hero .dusen-hero-title,
.dusen-mini-hero .dusen-hero-subtitle{
  position: relative;
  z-index: 1;
  text-align: left !important;
}

.dusen-mini-hero .dusen-hero-title{
  margin: 0 !important;
  font-weight: 900;
  line-height: 1.05;
  font-size: clamp(38px, 5vw, 64px);
}

.dusen-mini-hero .dusen-hero-subtitle{
  margin: 10px 0 0 0 !important;
  font-size: clamp(16px, 2vw, 18px);
  opacity: .92;
}

/* Seitentitel ausblenden (nur wenn Mini-Hero genutzt wird) */
.page .dusen-mini-hero ~ * .entry-title,
.page .dusen-mini-hero ~ * .entry-header,
.page .dusen-mini-hero ~ * .wp-block-post-title{
  display: none !important;
}

/* Der echte Übeltäter: inline padding-top:140px im Wrapper */
.section.section--tight[style*="padding-top"]{
  padding-top: 0 !important;
}


/* Texte links am Container statt zentriert */
.wp-block-cover.dusen-mini-hero{
  justify-content: flex-start !important;
}

.wp-block-cover.dusen-mini-hero .wp-block-cover__inner-container{
  margin-left: 0 !important;
  margin-right: auto !important;
}

/* ==== Mini-Hero: Text wirklich an den unteren Rand ==== */

/* 1) Bottom-Padding vom Cover weg (sonst bleibt immer Abstand) */
.wp-block-cover.dusen-mini-hero{
  padding-bottom: 0 !important;
}

/* 2) Standard-Margins der letzten Blöcke killen (WP gibt P/Headlines oft unten Margin) */
.wp-block-cover.dusen-mini-hero .wp-block-cover__inner-container > :last-child{
  margin-bottom: 0 !important;
}

/* optional: auch Titel/Subtitle unten sauber machen */
.dusen-mini-hero .dusen-hero-title{ margin-bottom: 0 !important; }
.dusen-mini-hero .dusen-hero-subtitle{
  margin-bottom: 0 !important;
}

/* 3) Wenn du trotzdem links/rechts “Luft” willst, aber unten 0:
      (optional – nur falls du unten komplett 0 willst, aber seitlich Padding behalten) */
.wp-block-cover.dusen-mini-hero{
  padding-left: clamp(28px, 4vw, 64px) !important;
  padding-right: clamp(28px, 4vw, 64px) !important;
  padding-top: clamp(28px, 4vw, 64px) !important;
}


/* Full-bleed für farbige Sections IM Content (weil Content im .container steckt) */
.wp-content > .section.section--dark,
.wp-content > .section.section--yellow{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* Innen wieder normale Lesebreite herstellen */
.wp-content > .section.section--dark > .container,
.wp-content > .section.section--yellow > .container{
  width: min(var(--container), calc(100% - 2*24px));
  margin: 0 auto;
}



/* === DÜSEN Pattern: Split "Für Gastro" === */

/* Full-bleed auch wenn the_content() im .container steckt */
.wp-content > .alignfull,
.wp-content > .dusen-fullbleed{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* Grid-Background */
.dusen-gridbg{
  background-color: var(--white);
  background-image:
    repeating-linear-gradient(0deg, rgba(35,31,32,.06) 0 1px, transparent 1px 40px),
    repeating-linear-gradient(90deg, rgba(35,31,32,.06) 0 1px, transparent 1px 40px);
}

/* Split Layout */
.dusen-split{
  gap: 56px;
}
@media (max-width: 900px){
  .dusen-split{ gap: 26px; }
}

/* Icon-Badge */
.dusen-iconbadge{
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--dusen-yellow);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom: 14px;
  box-shadow: 0 12px 30px rgba(0,0,0,.10);
}
.dusen-iconbadge svg{ width: 22px; height: 22px; display:block; }

/* Lead */
.dusen-lead{
  margin: 14px 0 14px;
  color: rgba(35,31,32,.78);
  font-weight: 700;
  line-height: 1.5;
}

/* Checklist */
.dusen-checklist{
  list-style:none;
  padding:0;
  margin: 12px 0 22px;
  display:grid;
  gap: 10px;
}
.dusen-checklist li{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  color: rgba(35,31,32,.86);
  font-weight: 700;
}
.dusen-check{
  width: 22px; height: 22px;
  flex: 0 0 22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top: 1px;
}
.dusen-check svg{ width: 22px; height: 22px; display:block; }

/* Photo-frame im hellen Kontext: Ecken wie im Screenshot */
.dusen-gridbg .photo-frame{
  border-radius: var(--radius-lg);
}

.dusen-iconlist{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}

.dusen-iconlist li{
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-weight: 700;
  color: rgba(35,31,32,.86);
}

.dusen-bullet{
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  color: var(--dusen-yellow);
  margin-top: 1px;
}

.dusen-bullet svg{
  width: 100%;
  height: 100%;
  display: block;
}


/* Variante: weiße Schrift */
.dusen-iconlist--white li{
  color: rgba(255,255,255,.92);
}

/* Icon bleibt Düsen-Gelb */
.dusen-iconlist--white .dusen-bullet{
  color: var(--dusen-yellow);
}


/* Icon-List (mehrzeilig, pro Zeile eigenes Icon) */
.dusen-infolist{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 18px;
}

.dusen-infolist li{
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  align-items: start;
}

/* Icon-Kachel */
.dusen-infolist .info-icon{
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--dusen-yellow);
  display: flex;
  align-items: center;
  justify-content: center;
}

.dusen-infolist .info-icon svg{
  width: 22px;
  height: 22px;
  display: block;
}

.dusen-infolist .info-icon img{
  width: 22px;
  height: 22px;
  object-fit: contain;
  display: block;
}

/* Text */
.dusen-infolist .info-title{
  font-weight: 900;
  margin: 0 0 4px;
}

.dusen-infolist .info-text{
  margin: 0;
  color: rgba(35,31,32,.80);
  font-weight: 700;
  line-height: 1.5;
}



/* --- DÜSEN Infolist: Dark Variante + Link-Style --- */
.dusen-infolist--white .info-title{
  color: rgba(255,255,255,.95);
}

.dusen-infolist--white .info-text{
  color: rgba(255,255,255,.82);
}

/* Links im Düsen-Look */
.dusen-infolist--white .info-text a{
  color: var(--dusen-yellow);
  font-weight: 500;
  text-decoration: none;
  padding-bottom: 1px;
  transition: border-color .14s ease, opacity .14s ease;
}

/* PNG Icons sauber */
.dusen-infolist .info-icon img{
  width: 24px;
  height: 24px;
  object-fit: contain;
  display: block;
}


/* =========================================================
   DÜSEN – Rechtliches (Impressum / Datenschutz)
   ========================================================= */
.dusen-legal{
  position: relative;
}

.dusen-legal__head{
  margin-bottom: 18px;
}

.dusen-legal__lead{
  margin-top: 14px;
  color: rgba(35,31,32,.78);
  font-weight: 700;
  line-height: 1.5;
  max-width: 70ch;
}

.dusen-legal__toc{
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
  margin-top: 16px;
}

/* kleine Pills wie Buttons, aber dezenter */
.dusen-legal__toc a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 2px solid var(--ink);
  background: rgba(0,0,0,.03);
  font-weight: 800;
  letter-spacing:.01em;
  transition: transform .12s ease, background .12s ease, opacity .12s ease;
}
.dusen-legal__toc a:hover{ background: var(--dusen-yellow); }
.dusen-legal__toc a:active{ transform: translateY(1px); }

/* Card-Container wie bei euch: radius + shadow + clean stroke */
.dusen-legal-card{
  position: relative;
  background: rgba(0,0,0,.02);
  border: 1px solid rgba(0,0,0,.12);
  border-radius: var(--radius-lg);
  padding: clamp(18px, 2.6vw, 28px);
  box-shadow: 0 16px 50px rgba(0,0,0,.10);
  overflow: hidden;
  scroll-margin-top: 120px; /* wegen fixed header */
  margin-top: 18px;
}

/* gelbe Akzentkante links + "Düsen-Dot" oben rechts */
.dusen-legal-card::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width: 10px;
  background: var(--dusen-yellow);
}
.dusen-legal-card::after{
  content:"";
  position:absolute;
  right: 16px;
  top: 16px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: var(--dusen-yellow);
  box-shadow: 0 12px 26px rgba(0,0,0,.12);
}

/* Überschriften im Card-Look */
.dusen-legal-card h2{
  margin: 0 0 14px 0;
}
.dusen-legal-card h3{
  margin: 18px 0 8px 0;
  font-size: 18px;
}
.dusen-legal-card h4{
  margin: 14px 0 6px 0;
  font-size: 16px;
}

/* Links im Rechtlichen: wieder sichtbar (global ist bei euch "none") */
.dusen-legal a{
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

/* eure Infolist im hellen Kontext etwas „legal-clean“ */
.dusen-legal .dusen-infolist{
  margin-top: 16px;
}
.dusen-legal .dusen-infolist .info-text{
  color: rgba(35,31,32,.82);
}

/* FAQ/Details passend */
.dusen-legal details{
  margin-top: 16px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(0,0,0,.02);
  overflow: hidden;
}
.dusen-legal summary{
  cursor: pointer;
  padding: 12px 14px;
  font-weight: 900;
  list-style: none;
}
.dusen-legal summary::-webkit-details-marker{ display:none; }
.dusen-legal details > div{
  padding: 0 14px 14px 14px;
}

/* :target highlight wenn man per Sprungmarke landet */
.dusen-legal-card:target{
  outline: 3px solid rgba(255,242,0,.55);
  outline-offset: 2px;
}

@font-face{
  font-family: "InterVar";
  src: url("/wp-content/themes/dusenpils/assets/fonts/Inter-Variable.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root{ --font-sans: "InterVar", "Helvetica Neue", Helvetica, Arial, sans-serif; }

html, body, button, input, textarea{
  font-family: var(--font-sans);
}