/* ═══════════════════════════════════════════════════════════
   DM-FINANCE — Warm-Paper-Design (abgeleitet aus easyfin v7)
   Marke: DM-Rot / Anthrazit im warmen Papier-Umfeld
   Tokens zentral hier anpassen.
   ═══════════════════════════════════════════════════════════ */

:root {
  /* Papier & Holz */
  --cream:       #FBF6EC;
  --cream-2:     #F3EBDA;
  --cream-3:     #EADBC3;
  --wood-light:  #E5CBA3;
  --wood:        #C99A66;
  --wood-dark:   #8B5E34;

  /* Tinte */
  --ink:         #1E1B16;
  --ink-2:       #3A342B;
  --ink-3:       #5B5348;
  --ink-soft:    #8B7F6E;
  --rule:        #D9CDB7;
  --rule-soft:   #E8DFCC;

  /* DM-Marke: Rot / Anthrazit */
  --dm-red:       #B23A2E;
  --dm-red-2:     #C74B3C;
  --dm-red-deep:  #8E2B22;
  --dm-red-soft:  #F4DCD6;
  --dm-red-pale:  #FAEFEB;
  --anthracite:   #26231F;
  --anthracite-2: #33302A;

  /* Warme Nebenfarben */
  --sunrise:     #F4A261;
  --sunrise-soft:#FCE3CA;
  --honey:       #E9B84F;
  --honey-soft:  #FAEBBF;
  --sage:        #8FAE86;
  --sage-soft:   #DDE7D6;
  --plum:        #9C6B8E;
  --plum-soft:   #E8D7E0;
  --blue:        #4E7EA6;
  --blue-soft:   #DCE8F1;

  --green:       #6A9B5F;
  --white:       #FFFFFF;

  --sh-sm: 0 1px 2px rgba(90,62,30,.08), 0 1px 3px rgba(90,62,30,.06);
  --sh-md: 0 4px 16px rgba(90,62,30,.10), 0 2px 6px rgba(90,62,30,.06);
  --sh-lg: 0 20px 40px -12px rgba(90,62,30,.18), 0 8px 20px -8px rgba(90,62,30,.10);

  --r-sm: 10px; --r-md: 14px; --r-lg: 22px; --r-xl: 32px;
  --wrap: 1180px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:86px}
body{
  font-family:'Nunito',-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--cream);color:var(--ink);line-height:1.55;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;font-weight:400;
}
a{color:inherit;text-decoration:none}
img,svg,iframe{max-width:100%;display:block}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
:focus-visible{outline:3px solid var(--dm-red);outline-offset:3px;border-radius:4px}

/* ── Typografie ─────────────────────────────────────────── */
.display{font-family:'Akshar',sans-serif;font-weight:600;letter-spacing:-.02em;line-height:1.06;color:var(--ink)}
.display em{font-family:'Fraunces',serif;font-style:italic;font-weight:500;color:var(--dm-red);letter-spacing:0}
.display-xl{font-size:clamp(2.6rem,6vw,4.3rem)}
.display-lg{font-size:clamp(2rem,4.2vw,3rem)}
.display-md{font-size:clamp(1.5rem,2.8vw,2rem)}
.mono{font-family:'IBM Plex Mono',monospace}
.lead{font-size:1.11rem;color:var(--ink-3);max-width:62ch}

.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:'IBM Plex Mono',monospace;font-size:.78rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--dm-red);
}
.eyebrow-dot{width:8px;height:8px;border-radius:50%;background:var(--dm-red);flex:none}

/* ── Papierstruktur ─────────────────────────────────────── */
.paper-grain{position:relative}
.paper-grain::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(139,94,52,.05) 1px,transparent 1px);
  background-size:22px 22px;
}
.paper-grain>*{position:relative}

/* ── Layout ─────────────────────────────────────────────── */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.sec{padding:clamp(64px,9vw,110px) 0}
.sec-cream2{background:var(--cream-2)}
.sec-head{max-width:720px;margin-bottom:clamp(36px,5vw,56px)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head .eyebrow{margin-bottom:14px}
.sec-head .lead{margin-top:14px}
.sec-head.center .lead{margin-left:auto;margin-right:auto}

/* ── Navigation ─────────────────────────────────────────── */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:60;
  background:rgba(251,246,236,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;transition:border-color .25s,background .25s;
}
.nav.scrolled{border-bottom-color:var(--rule-soft);background:rgba(251,246,236,.95)}
.nav-inner{max-width:var(--wrap);margin:0 auto;padding:14px 24px;display:flex;align-items:center;gap:28px}
.nav-logo{display:flex;align-items:center;gap:12px;font-family:'Akshar',sans-serif;font-weight:600;font-size:1.25rem;letter-spacing:-.01em}
.nav-logo-mark{
  width:40px;height:40px;border-radius:12px;background:var(--dm-red);color:var(--cream);
  display:grid;place-items:center;font-size:1rem;letter-spacing:.02em;box-shadow:var(--sh-sm);flex:none;
}
.nav-logo small{display:block;font-family:'IBM Plex Mono',monospace;font-size:.62rem;font-weight:500;letter-spacing:.14em;color:var(--ink-soft);text-transform:uppercase}
.nav-links{display:flex;gap:6px;margin-left:auto}
.nav-link{padding:9px 14px;border-radius:999px;font-weight:600;font-size:.95rem;color:var(--ink-2);transition:background .18s,color .18s}
.nav-link:hover{background:var(--cream-2);color:var(--ink)}
.nav-link.active{background:var(--dm-red-pale);color:var(--dm-red-deep)}
.nav-cta{
  padding:11px 20px;border-radius:999px;background:var(--dm-red);color:#fff;
  font-weight:700;font-size:.95rem;box-shadow:var(--sh-sm);transition:background .18s,transform .18s;flex:none;
}
.nav-cta:hover{background:var(--dm-red-deep);transform:translateY(-1px)}
.nav-burger{display:none;margin-left:auto;width:44px;height:44px;border-radius:12px;place-items:center;color:var(--ink)}
.nav-burger svg{width:26px;height:26px}

/* ── Buttons ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;padding:15px 28px;border-radius:999px;
  font-weight:700;font-size:1rem;transition:transform .18s,box-shadow .18s,background .18s;
}
.btn-arrow{width:19px;height:19px;transition:transform .18s}
.btn:hover .btn-arrow{transform:translateX(3px)}
.btn-primary{background:var(--dm-red);color:#fff;box-shadow:var(--sh-md)}
.btn-primary:hover{background:var(--dm-red-deep);transform:translateY(-2px)}
.btn-secondary{background:var(--white);color:var(--ink);border:1.5px solid var(--rule);box-shadow:var(--sh-sm)}
.btn-secondary:hover{border-color:var(--wood);transform:translateY(-2px)}
.btn-ghost{padding:12px 4px;color:var(--dm-red);font-weight:700}
.btn-ghost:hover .btn-arrow{transform:translateX(4px)}

/* ── Hero ───────────────────────────────────────────────── */
.hero{padding:clamp(130px,16vw,190px) 0 clamp(64px,8vw,100px)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:clamp(36px,5vw,72px);align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:'IBM Plex Mono',monospace;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);background:var(--white);border:1px solid var(--rule-soft);border-radius:999px;padding:8px 16px;box-shadow:var(--sh-sm);margin-bottom:26px}
.hero-eyebrow-dot{width:8px;height:8px;border-radius:50%;background:var(--dm-red)}
.hero-headline{margin-bottom:22px}
.hero-underline{position:relative;white-space:nowrap}
.hero-underline svg{position:absolute;left:0;right:0;bottom:-.12em;width:100%;height:.34em;color:var(--dm-red);opacity:.9}
.hero-sub{font-size:1.15rem;color:var(--ink-3);max-width:56ch;margin-bottom:32px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:44px}
.hero-stats{display:flex;gap:clamp(24px,4vw,48px);flex-wrap:wrap}
.hero-stat-num{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:1.7rem;color:var(--dm-red-deep)}
.hero-stat-lbl{font-size:.88rem;color:var(--ink-soft);font-weight:600}

/* Hero-Karte (Porträt) */
.hero-card{
  background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-xl);
  box-shadow:var(--sh-lg);overflow:hidden;transform:rotate(1.5deg);
}
.hero-card-img{aspect-ratio:4/5;background:linear-gradient(160deg,var(--cream-2),var(--cream-3));position:relative;overflow:hidden}
.hero-card-img img{width:100%;height:100%;object-fit:cover}
.avatar-fallback{position:absolute;inset:0;display:grid;place-items:center}
.avatar-fallback span{width:120px;height:120px;border-radius:50%;background:var(--dm-red);color:var(--cream);display:grid;place-items:center;font-family:'Akshar',sans-serif;font-size:2.6rem;font-weight:600;box-shadow:var(--sh-md)}
.hero-card-body{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.hero-card-name{font-family:'Akshar',sans-serif;font-weight:600;font-size:1.15rem}
.hero-card-role{font-size:.85rem;color:var(--ink-soft);font-weight:600}
.hero-card-badge{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;background:var(--dm-red-pale);color:var(--dm-red-deep);border-radius:999px;padding:7px 13px;font-weight:600;flex:none}

/* ── Karten-Raster (Leistungen etc.) ───────────────────── */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.card{
  background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-lg);
  padding:28px;box-shadow:var(--sh-sm);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;gap:12px;
}
a.card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.card h3{font-family:'Akshar',sans-serif;font-weight:600;font-size:1.28rem;letter-spacing:-.01em}
.card p{color:var(--ink-3);font-size:.98rem;flex:1}
.card-link{display:inline-flex;align-items:center;gap:.45rem;color:var(--dm-red);font-weight:700;font-size:.95rem}
.card-link svg{width:17px;height:17px;transition:transform .18s}
a.card:hover .card-link svg{transform:translateX(3px)}
.chip{
  width:52px;height:52px;border-radius:16px;display:grid;place-items:center;flex:none;
}
.chip svg{width:26px;height:26px}
.chip-red{background:var(--dm-red-soft);color:var(--dm-red-deep)}
.chip-honey{background:var(--honey-soft);color:#8a6b1d}
.chip-sage{background:var(--sage-soft);color:#4c6a44}
.chip-plum{background:var(--plum-soft);color:#6d4a63}
.chip-sun{background:var(--sunrise-soft);color:#a35c1e}
.chip-blue{background:var(--blue-soft);color:#33607f}

/* ── Benefits / kleine Punkte ───────────────────────────── */
.benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.benefit{display:flex;gap:14px;background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-md);padding:18px 20px;box-shadow:var(--sh-sm)}
.benefit .chip{width:44px;height:44px;border-radius:13px}
.benefit .chip svg{width:22px;height:22px}
.benefit h4{font-family:'Akshar',sans-serif;font-weight:600;font-size:1.05rem;margin-bottom:2px}
.benefit p{color:var(--ink-3);font-size:.92rem}

/* ── Split (Über mich etc.) ─────────────────────────────── */
.split{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(36px,5vw,72px);align-items:center}
.split-media{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);border:1px solid var(--rule-soft);background:var(--cream-2);transform:rotate(-1.2deg)}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.checklist{list-style:none;display:grid;gap:12px;margin:22px 0 28px}
.checklist li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-2);font-weight:600}
.checklist svg{width:22px;height:22px;color:var(--green);flex:none;margin-top:2px}

/* ── Schritte ───────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-lg);padding:30px 28px;box-shadow:var(--sh-sm);position:relative}
.step::before{
  counter-increment:step;content:counter(step,decimal-leading-zero);
  font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:.95rem;color:var(--dm-red);
  display:inline-block;background:var(--dm-red-pale);border-radius:999px;padding:6px 14px;margin-bottom:16px;
}
.step h3{font-family:'Akshar',sans-serif;font-weight:600;font-size:1.25rem;margin-bottom:8px}
.step p{color:var(--ink-3);font-size:.97rem}

/* ── Tool-Karten (easyfin) ──────────────────────────────── */
.tool{background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-xl);box-shadow:var(--sh-md);overflow:hidden}
.tool-head{display:flex;align-items:center;gap:16px;padding:22px 26px;border-bottom:1px solid var(--rule-soft);background:var(--cream-2)}
.tool-head h3{font-family:'Akshar',sans-serif;font-weight:600;font-size:1.25rem}
.tool-head small{display:block;color:var(--ink-soft);font-weight:600;font-size:.86rem}
.tool-body{padding:10px;min-height:640px;background:var(--white)}
.tool-body iframe{width:100%;min-height:900px;border:0;border-radius:var(--r-md)}
.easyfin-embed{min-height:620px}
.tool-foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:16px 26px;border-top:1px solid var(--rule-soft);background:var(--cream-2)}
.tool-foot small{color:var(--ink-soft);font-weight:600}
.tool-fallback{display:inline-flex;align-items:center;gap:.4rem;color:var(--dm-red);font-weight:700;font-size:.92rem}
.tool-fallback svg{width:16px;height:16px}
.powered{display:inline-flex;align-items:center;gap:.45rem;font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.powered b{color:var(--ink-2)}

/* Rechner-Pills */
.pillbar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.pill{
  display:inline-flex;align-items:center;gap:.5rem;padding:11px 20px;border-radius:999px;
  background:var(--white);border:1.5px solid var(--rule);font-weight:700;font-size:.95rem;color:var(--ink-2);
  transition:border-color .18s,color .18s,transform .18s;box-shadow:var(--sh-sm);
}
.pill:hover{border-color:var(--dm-red);color:var(--dm-red-deep);transform:translateY(-2px)}

/* ── FAQ ────────────────────────────────────────────────── */
.faq{display:grid;gap:14px;max-width:860px;margin:0 auto}
.faq details{background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-md);box-shadow:var(--sh-sm);overflow:hidden}
.faq summary{cursor:pointer;padding:20px 24px;font-family:'Akshar',sans-serif;font-weight:600;font-size:1.08rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:'IBM Plex Mono',monospace;color:var(--dm-red);font-size:1.3rem;flex:none;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 24px 20px;color:var(--ink-3)}

/* ── CTA-Band ───────────────────────────────────────────── */
.cta-band{
  background:var(--anthracite);color:var(--cream);border-radius:var(--r-xl);
  padding:clamp(40px,6vw,64px);text-align:center;box-shadow:var(--sh-lg);position:relative;overflow:hidden;
}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 85% -20%,rgba(178,58,46,.35),transparent)}
.cta-band>*{position:relative}
.cta-band h2{color:var(--cream);margin-bottom:12px}
.cta-band p{color:rgba(251,246,236,.75);max-width:52ch;margin:0 auto 28px;font-size:1.08rem}

/* ── Kontakt ────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(28px,4vw,56px);align-items:start}
.contact-list{display:grid;gap:14px}
.contact-item{display:flex;gap:14px;background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-md);padding:18px 20px;box-shadow:var(--sh-sm)}
.contact-item h4{font-family:'Akshar',sans-serif;font-weight:600;font-size:1rem;margin-bottom:2px}
.contact-item p,.contact-item a{color:var(--ink-3);font-weight:600}
.contact-item a:hover{color:var(--dm-red)}
.form{background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-lg);padding:30px;box-shadow:var(--sh-md);display:grid;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--rule);border-radius:var(--r-sm);
  background:var(--cream);font:inherit;color:var(--ink);transition:border-color .18s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--dm-red)}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--ink-3)}
.consent input{margin-top:3px;accent-color:var(--dm-red)}

/* ── Rechtstexte ────────────────────────────────────────── */
.legal{max-width:820px;margin:0 auto}
.legal h2{font-family:'Akshar',sans-serif;font-weight:600;font-size:1.4rem;margin:34px 0 10px}
.legal p,.legal li{color:var(--ink-2);margin-bottom:10px}
.legal ul{padding-left:20px}
.todo{color:var(--dm-red);font-weight:700}
.notice{background:var(--honey-soft);border:1px solid rgba(233,184,79,.5);border-radius:var(--r-md);padding:16px 20px;color:#6b5416;font-weight:600;margin-bottom:28px}

/* ── Seitenkopf (Unterseiten) ───────────────────────────── */
.pagehead{padding:clamp(130px,15vw,170px) 0 clamp(44px,6vw,64px)}
.crumbs{font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:18px}
.crumbs a:hover{color:var(--dm-red)}

/* ── Footer ─────────────────────────────────────────────── */
.footer{background:var(--anthracite);color:rgba(251,246,236,.8);margin-top:clamp(64px,8vw,100px)}
.footer-inner{max-width:var(--wrap);margin:0 auto;padding:56px 24px 30px}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:32px;padding-bottom:36px;border-bottom:1px solid rgba(251,246,236,.14)}
.footer .nav-logo{color:var(--cream)}
.footer .nav-logo-mark{background:var(--dm-red)}
.footer-about{margin-top:14px;font-size:.94rem;max-width:34ch;color:rgba(251,246,236,.65)}
.footer h5{font-family:'IBM Plex Mono',monospace;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(251,246,236,.5);margin-bottom:14px}
.footer ul{list-style:none;display:grid;gap:9px}
.footer ul a{font-weight:600;font-size:.95rem;transition:color .18s}
.footer ul a:hover{color:#fff}
.footer-base{display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;padding-top:22px;font-size:.85rem;color:rgba(251,246,236,.5)}

/* ── Reveal ─────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width:980px){
  .hero-grid,.split,.contact-grid{grid-template-columns:1fr}
  .hero-card{max-width:420px;margin:0 auto}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .split-media{order:-1;max-width:440px}
}
@media (max-width:760px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:grid}
  .nav.open .nav-links{
    display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;
    background:var(--cream);border-bottom:1px solid var(--rule-soft);padding:14px 20px 20px;gap:4px;box-shadow:var(--sh-md);
  }
  .grid-3,.grid-2,.benefits,.form-row{grid-template-columns:1fr}
  .tool-body{min-height:520px}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition:none!important;animation:none!important}
  .reveal{opacity:1;transform:none}
}

/* ── Logo-Bild ──────────────────────────────────────────── */
.nav-logo-mark{background:var(--white);overflow:hidden;padding:4px}
.nav-logo-mark img{width:100%;height:100%;object-fit:contain}
.footer .nav-logo-mark{background:var(--cream)}

/* ── Team ───────────────────────────────────────────────── */
.team-photo{border-radius:var(--r-md);overflow:hidden;aspect-ratio:1/1;background:var(--cream-2);margin-bottom:4px}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
a.team-card:hover .team-photo img{transform:scale(1.04)}
.team-role{font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dm-red);font-weight:600;flex:0!important}

/* ── AVD-Rechner ────────────────────────────────────────── */
.avd-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:clamp(24px,3.5vw,44px)}
.avd-field{margin-bottom:22px}
.avd-field label{display:flex;justify-content:space-between;align-items:baseline;gap:12px;font-weight:700;font-size:.95rem;margin-bottom:8px}
.avd-field output{color:var(--dm-red-deep);font-weight:600;font-size:1.05rem}
.avd-field small{display:block;margin-top:6px;color:var(--ink-soft);font-size:.82rem}
.avd-field input[type=range]{width:100%;accent-color:var(--dm-red);height:6px;cursor:pointer}
.avd-kpi{background:var(--cream-2);border:1px solid var(--rule-soft);border-radius:var(--r-md);padding:16px 18px}
.avd-kpi span{display:block;font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:4px}
.avd-kpi strong{font-size:1.5rem;font-weight:600;color:var(--ink)}
.avd-kpi small{display:block;color:var(--ink-soft);font-size:.8rem;margin-top:3px}
.avd-kpi-hero{background:var(--anthracite);border-color:transparent;margin-bottom:14px}
.avd-kpi-hero span{color:rgba(251,246,236,.6)}
.avd-kpi-hero strong{color:var(--sunrise);font-size:2.2rem}
.avd-kpi-hero small{color:rgba(251,246,236,.7)}
.avd-kpi-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.avd-bars{background:var(--cream-2);border:1px solid var(--rule-soft);border-radius:var(--r-md);padding:18px}
.avd-bar-row{display:grid;grid-template-columns:1fr;gap:6px;margin-bottom:14px}
.avd-bar-row span{font-size:.85rem;font-weight:600;color:var(--ink-3)}
.avd-bar-row strong{font-size:1.05rem;color:var(--ink)}
.avd-bar{height:14px;border-radius:999px;background:var(--rule-soft);overflow:hidden}
.avd-bar i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--dm-red),var(--sunrise));width:0;transition:width .4s ease}
.avd-bar-ohne{background:var(--wood)!important}
.avd-plus{border-top:1px dashed var(--rule);padding-top:12px;font-weight:700;color:var(--ink-2)}
.avd-plus strong{color:var(--green);font-size:1.15rem}
@media (max-width:860px){.avd-grid{grid-template-columns:1fr}.avd-kpi-row{grid-template-columns:1fr}}

/* Lange deutsche Komposita auf Mobil sauber trennen */
@media (max-width:560px){
  .display{hyphens:auto;overflow-wrap:break-word}
}

/* ── Maskottchen (Biber) ────────────────────────────────── */
.mascot-inline{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.mascot-inline img{width:clamp(120px,16vw,190px);height:auto;filter:drop-shadow(0 12px 22px rgba(38,35,31,.22));flex:none}
.mascot-speech{position:relative;background:var(--white);border:1px solid var(--rule-soft);border-radius:var(--r-lg);padding:20px 24px;box-shadow:var(--sh-sm);max-width:44ch}
.mascot-speech::before{content:"";position:absolute;left:-11px;top:34px;width:20px;height:20px;background:var(--white);border-left:1px solid var(--rule-soft);border-bottom:1px solid var(--rule-soft);transform:rotate(45deg)}
.mascot-speech h4{font-family:'Akshar',sans-serif;font-weight:600;font-size:1.15rem;margin-bottom:4px}
.mascot-speech p{color:var(--ink-3);font-size:.96rem}

/* Schwebender Helfer */
.biber-fab{position:fixed;left:22px;bottom:22px;z-index:70;display:none;align-items:flex-end;gap:12px;max-width:min(360px,86vw);
  opacity:0;transform:translateY(14px);transition:opacity .4s,transform .4s}
.biber-fab.show{display:flex;opacity:1;transform:none}
.biber-fab img{width:96px;height:auto;filter:drop-shadow(0 8px 16px rgba(38,35,31,.28));flex:none;cursor:pointer}
.biber-fab-bubble{position:relative;background:var(--white);border:1px solid var(--rule-soft);border-radius:18px 18px 18px 4px;
  box-shadow:var(--sh-lg);padding:15px 16px 15px 18px}
.biber-fab-bubble .eyebrow{font-size:.68rem;margin-bottom:5px}
.biber-fab-bubble p{font-size:.92rem;color:var(--ink-2);font-weight:600;margin-bottom:11px;line-height:1.4}
.biber-fab-bubble .btn{padding:9px 16px;font-size:.86rem}
.biber-close{position:absolute;top:-9px;right:-9px;width:26px;height:26px;border-radius:50%;background:var(--anthracite);color:#fff;
  display:grid;place-items:center;font-size:1rem;line-height:1;box-shadow:var(--sh-sm)}
.biber-close:hover{background:var(--dm-red)}
@media (max-width:600px){
  .biber-fab{left:12px;right:12px;bottom:12px;max-width:none}
  .biber-fab img{width:72px}
}

.nav-logo-img{height:44px;width:auto;display:block}

/* Header-Logo: DM-Monogramm als Marke */
.nav-logo .nav-logo-mark{width:auto!important;height:auto!important;background:none!important;border:0!important;border-radius:0!important;box-shadow:none!important;overflow:visible!important;display:flex;align-items:center}
.nav-logo .nav-logo-mark img{height:38px!important;width:auto!important;object-fit:contain;display:block}

.nav-logo .nav-logo-img{height:58px!important;width:auto!important;display:block}
