/* =========================================================
   ENERGIEVIELFALT — Premium Design System 2026
   Editorial · Ruhig · Handwerklich · Awwwards-Niveau
   ========================================================= */

/* -------- Design Tokens — Logo-basierte Palette ---------- */
:root{
    /* Brand — am Energievielfalt-Logo orientiert */
    --green-900:#1b5e20;   /* sattes CO2-Blatt */
    --green-700:#2e7d32;   /* Logo-Grün (Blatt) */
    --green-600:#388e3c;
    --green-500:#43a047;
    --green-400:#66bb6a;
    --green-50:#e8f5e9;

    /* Orange/Flamme aus Logo (Sonne + Feuer) */
    --orange-700:#e65100;
    --orange-500:#f57c00;
    --orange-300:#ffb74d;
    --orange-50:#fff3e0;

    /* Logo-Blau (Wärmepumpen-Bereich) */
    --sky-700:#1565c0;
    --sky-500:#1e88e5;
    --sky-300:#64b5f6;
    --sky-50:#e3f2fd;

    /* Ziegel-Rot (Dach aus Logo) */
    --brick-500:#c84a3c;

    /* Gold bleibt für feine Akzente in Rechtstexten */
    --gold-600:#c99329;
    --gold-500:#e8b547;
    --gold-300:#f2d38b;
    --gold-50:#fbf2dd;

    /* Neutrals */
    --ink-900:#121816;
    --ink-800:#1c2422;
    --ink-700:#2a3531;
    --ink-500:#5a6863;
    --ink-400:#8a9691;
    --ink-300:#c9d1ce;
    --ink-200:#e4e7e5;
    --ink-100:#eef0ee;

    --paper:#faf8f3;
    --paper-soft:#f4f1ea;
    --paper-edge:#e8e3d6;
    --white:#ffffff;

    /* Semantic */
    --bg: var(--paper);
    --bg-alt: var(--white);
    --text: var(--ink-900);
    --text-soft: var(--ink-500);
    --muted: var(--ink-400);
    --line: var(--ink-200);
    --primary: var(--green-700);
    --primary-hover: var(--green-900);
    --accent: var(--orange-500);
    --accent-hover: var(--orange-700);

    /* Typo */
    --font-serif: "Fraunces", "Cormorant Garamond", Georgia, serif;
    --font-sans: "Inter", "Helvetica Neue", system-ui, -apple-system, "Segoe UI", sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;

    /* Spacing scale */
    --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px;
    --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px; --s-11:160px;

    /* Radii */
    --r-xs:6px; --r-sm:10px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-2xl:40px; --r-full:999px;

    /* Shadow */
    --shadow-xs: 0 1px 2px rgba(13,15,14,.04);
    --shadow-sm: 0 4px 14px rgba(13,15,14,.06);
    --shadow-md: 0 14px 40px rgba(13,15,14,.08);
    --shadow-lg: 0 30px 80px rgba(13,15,14,.12);
    --shadow-glow: 0 10px 40px rgba(46,125,50,.22);
    --shadow-warm: 0 14px 40px rgba(245,124,0,.18);

    /* Layout */
    --container: 1280px;
    --container-narrow: 960px;
    --nav-h: 76px;

    /* Motion */
    --ease: cubic-bezier(.22,.61,.36,1);
    --ease-out: cubic-bezier(.16,1,.3,1);
    --dur-1: 180ms;
    --dur-2: 320ms;
    --dur-3: 520ms;
    --dur-4: 800ms;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:88px;}
body{
    font-family:var(--font-sans);
    font-size:16px;
    line-height:1.6;
    color:var(--text);
    background:var(--bg);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
    font-feature-settings:"ss01","ss02","cv11";
}

img,svg,video{display:block;max-width:100%;height:auto;}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:none;}
a{color:inherit;text-decoration:none;transition:color var(--dur-1) var(--ease);}
a:hover{color:var(--primary);}
ul,ol{list-style:none;}
input,select,textarea{font:inherit;color:inherit;}

::selection{background:var(--green-700);color:#fff;}

/* -------- Typography scale ------------------------------- */
.display-1{
    font-family:var(--font-serif);
    font-weight:300;
    font-size:clamp(2.75rem, 7.5vw + .5rem, 7.25rem);
    line-height:.98;
    letter-spacing:-.02em;
}
.display-2{
    font-family:var(--font-serif);
    font-weight:300;
    font-size:clamp(2.25rem, 5vw + .5rem, 5rem);
    line-height:1.02;
    letter-spacing:-.02em;
}
.display-3{
    font-family:var(--font-serif);
    font-weight:400;
    font-size:clamp(1.75rem, 3vw + .5rem, 3.25rem);
    line-height:1.08;
    letter-spacing:-.015em;
}
.eyebrow{
    font-family:var(--font-sans);
    font-size:.78rem;
    text-transform:uppercase;
    letter-spacing:.22em;
    font-weight:500;
    color:var(--primary);
    display:inline-flex;
    align-items:center;
    gap:10px;
}
.eyebrow::before{
    content:"";
    width:22px;height:1px;background:var(--primary);
}
.lead{font-size:clamp(1.05rem,1.4vw + .5rem,1.35rem);line-height:1.5;color:var(--text-soft);font-weight:400;}
.italic-serif{font-family:var(--font-serif);font-style:italic;font-weight:400;}

h1,h2,h3,h4{font-family:var(--font-serif);font-weight:400;letter-spacing:-.01em;}
h2{font-size:clamp(1.75rem,3vw + .5rem,3rem);line-height:1.1;}
h3{font-size:clamp(1.35rem,1.5vw + .5rem,1.75rem);line-height:1.2;}
h4{font-size:1.15rem;line-height:1.3;font-weight:500;}
p{max-width:62ch;}

/* -------- Layout utilities ------------------------------- */
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(20px,4vw,40px);}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 clamp(20px,4vw,40px);}
.section{padding:clamp(64px,10vw,144px) 0;position:relative;}
.section-tight{padding:clamp(48px,6vw,80px) 0;}
.section-dark{background:var(--ink-900);color:var(--paper);}
.section-dark .eyebrow{color:var(--orange-300);}
.section-dark .eyebrow::before{background:var(--orange-500);}
.section-dark .lead{color:rgba(255,255,255,.72);}

.grid{display:grid;gap:var(--s-6);}
.flex{display:flex;}
.between{display:flex;align-items:center;justify-content:space-between;gap:var(--s-4);}
.stack-1>*+*{margin-top:var(--s-2);}
.stack-2>*+*{margin-top:var(--s-4);}
.stack-3>*+*{margin-top:var(--s-5);}

/* -------- Buttons ---------------------------------------- */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:16px 28px;
    border-radius:var(--r-full);
    font-weight:500;
    font-size:.98rem;
    letter-spacing:.01em;
    line-height:1;
    transition:transform var(--dur-2) var(--ease), background var(--dur-2) var(--ease), color var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease);
    position:relative;
    overflow:hidden;
    cursor:pointer;
    white-space:nowrap;
    will-change:transform;
}
.btn i{font-size:.9em;}
.btn-primary{background:var(--ink-900);color:var(--paper);}
.btn-primary:hover{background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-glow);}
.btn-accent{background:var(--orange-500);color:#fff;}
.btn-accent:hover{background:var(--orange-700);color:#fff;transform:translateY(-2px);}
.btn-green{background:var(--primary);color:#fff;}
.btn-green:hover{background:var(--primary-hover);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-glow);}
.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary);}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-2px);}
.btn-ghost{background:transparent;color:currentColor;border:1px solid currentColor;}
.btn-ghost:hover{background:currentColor;color:var(--paper);transform:translateY(-2px);}
/* Hero-Ghost auf dunklem BG: Hover = weißer Grund, dunkler Text (sonst weiß auf weiß) */
.hero-ctas .btn-ghost,.cta-final .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55);}
.hero-ctas .btn-ghost:hover,.cta-final .btn-ghost:hover{background:#fff;color:var(--ink-900);border-color:#fff;}
.btn-lg{padding:20px 34px;font-size:1.04rem;}
.btn-sm{padding:11px 20px;font-size:.88rem;}

.link-arrow{
    display:inline-flex;align-items:center;gap:8px;
    font-weight:500;color:var(--ink-900);
    border-bottom:1px solid var(--ink-900);
    padding-bottom:2px;transition:gap var(--dur-2) var(--ease), color var(--dur-1) var(--ease);
}
.link-arrow:hover{gap:14px;color:var(--primary);border-color:var(--primary);}

/* -------- Navigation ------------------------------------- */
.nav{
    position:fixed;
    top:0;left:0;right:0;
    z-index:80;
    height:var(--nav-h);
    display:flex;align-items:center;
    color:var(--ink-900);
    background:rgba(250,248,243,.88);
    backdrop-filter:saturate(140%) blur(14px);
    -webkit-backdrop-filter:saturate(140%) blur(14px);
    transition:box-shadow var(--dur-2) var(--ease);
}
.nav.is-scrolled{
    box-shadow:0 1px 0 var(--line), 0 6px 20px rgba(13,15,14,.05);
}
.nav .container{width:100%;display:flex;align-items:center;justify-content:space-between;}
.nav-logo{display:flex;align-items:center;gap:12px;font-family:var(--font-serif);font-size:1.4rem;letter-spacing:-.01em;font-weight:500;}
.nav-logo img{height:44px;width:44px;border-radius:50%;object-fit:cover;box-shadow:0 2px 8px rgba(13,15,14,.12);}
.nav-links{display:flex;gap:var(--s-6);align-items:center;}
.nav-links a{font-size:.94rem;font-weight:500;position:relative;padding:8px 0;}
.nav-links a::after{
    content:"";position:absolute;left:0;right:100%;bottom:2px;
    height:1px;background:currentColor;transition:right var(--dur-2) var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{right:0;}
.nav-cta{display:inline-flex;}
.nav-burger{display:none;width:44px;height:44px;border-radius:var(--r-full);align-items:center;justify-content:center;background:rgba(13,15,14,.06);}
.nav.is-dark .nav-burger{background:rgba(255,255,255,.12);}
.nav-burger span{width:20px;height:1.5px;background:currentColor;position:relative;transition:transform var(--dur-2) var(--ease);}
.nav-burger span::before,.nav-burger span::after{content:"";position:absolute;left:0;width:20px;height:1.5px;background:currentColor;transition:transform var(--dur-2) var(--ease);}
.nav-burger span::before{top:-6px;}
.nav-burger span::after{top:6px;}
body.menu-open .nav-burger span{background:transparent;}
body.menu-open .nav-burger span::before{transform:translateY(6px) rotate(45deg);}
body.menu-open .nav-burger span::after{transform:translateY(-6px) rotate(-45deg);}

.mobile-menu{
    position:fixed;inset:0;z-index:70;
    background:var(--paper);color:var(--ink-900);
    padding:calc(var(--nav-h) + 24px) 24px 48px;
    transform:translateY(-100%);
    transition:transform var(--dur-3) var(--ease-out);
    overflow-y:auto;
}
body.menu-open .mobile-menu{transform:translateY(0);}
.mobile-menu a:not(.btn){font-family:var(--font-serif);font-size:2rem;display:block;padding:14px 0;border-bottom:1px solid var(--line);}
.mobile-menu a.btn{display:flex;width:100%;justify-content:center;margin-top:24px;font-family:var(--font-sans);font-size:1rem;border-bottom:0;}
.mobile-menu a.btn.btn-green{color:#fff;}

@media (max-width:900px){
    .nav-links,.nav-cta{display:none;}
    .nav-burger{display:flex;}
}
@media (max-width:768px){
    /* Hero auf Mobile: niedriger + Bildausschnitt mittig (Querformat sonst zu stark gecroppt) */
    .hero{min-height:auto;padding:calc(var(--nav-h) + 80px) 0 clamp(64px,16vw,120px);}
    .hero-bg{background-position:center center;transform:scale(1.04);}
    .hero.is-loaded .hero-bg{transform:scale(1);}
    /* dunkleren Verlauf unten für Lesbarkeit auf hellem Bildbereich */
    .hero::after{background:linear-gradient(180deg, rgba(13,15,14,.35) 0%, rgba(13,15,14,.35) 30%, rgba(13,15,14,.78) 80%, rgba(13,15,14,.94) 100%);}
}
@media (max-width:560px){
    /* Buttons auf schmalen Screens stapeln statt überlaufen (white-space:nowrap) */
    .hero-ctas{flex-direction:column;align-items:stretch;}
    .hero-ctas .btn{width:100%;}
    .cta-final-ctas .btn{width:100%;}
}

/* -------- Hero ------------------------------------------- */
.hero{
    position:relative;
    min-height:100svh;
    display:flex;
    align-items:flex-end;
    padding: calc(var(--nav-h) + 48px) 0 clamp(120px,18vw,220px);
    color:#fff;
    overflow:hidden;
    isolation:isolate;
}
.hero-bg{
    position:absolute;inset:0;z-index:-2;
    background-size:cover;
    background-position:center 65%;
    transform:scale(1.08);
    transition:transform 8s linear;
    will-change:transform;
}
.hero.is-loaded .hero-bg{transform:scale(1.02);}
.hero::after{
    content:"";position:absolute;inset:0;z-index:-1;
    background: linear-gradient(180deg, rgba(13,15,14,.25) 0%, rgba(13,15,14,.15) 35%, rgba(13,15,14,.7) 85%, rgba(13,15,14,.92) 100%);
}
.hero-grid{
    display:grid;grid-template-columns:1fr;gap:var(--s-7);
    align-items:end;
}
.hero-title{
    font-family:var(--font-serif);
    font-weight:300;
    font-size:clamp(2.75rem, 8vw, 8rem);
    line-height:.96;
    letter-spacing:-.025em;
    max-width:15ch;
}
.hero-title .word{display:inline-block;overflow:hidden;vertical-align:baseline;}
.hero-title .word-inner{display:inline-block;transform:translateY(110%);animation:hero-rise var(--dur-4) var(--ease-out) forwards;}
.hero-title .word:nth-child(1) .word-inner{animation-delay:.1s;}
.hero-title .word:nth-child(2) .word-inner{animation-delay:.18s;}
.hero-title .word:nth-child(3) .word-inner{animation-delay:.26s;}
.hero-title .word:nth-child(4) .word-inner{animation-delay:.34s;}
.hero-title .word:nth-child(5) .word-inner{animation-delay:.42s;}
.hero-title .word:nth-child(6) .word-inner{animation-delay:.5s;}
.hero-title .accent{font-style:italic;color:var(--orange-500);}
.hero-title .gradient-vielfalt{
    font-style:italic;
    background:linear-gradient(100deg,#f57c00 0%,#ffb74d 18%,#43a047 48%,#2e7d32 62%,#1e88e5 88%,#0d47a1 100%);
    background-size:200% 100%;
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    animation:hero-rise var(--dur-4) var(--ease-out) forwards,gradient-shift 9s ease-in-out 1.2s infinite;
    animation-delay:.26s,1.2s;
    filter:drop-shadow(0 2px 12px rgba(245,124,0,.18));
}
.hero-title .gradient-vielfalt em{font-style:italic;}
@keyframes gradient-shift{
    0%,100%{background-position:0% 50%;}
    50%{background-position:100% 50%;}
}
.hero-sub{
    max-width:46ch;
    font-size:clamp(1.05rem,1vw + .7rem,1.3rem);
    color:rgba(255,255,255,.82);
    opacity:0;transform:translateY(20px);
    animation:hero-fade var(--dur-3) var(--ease-out) .7s forwards;
}
.hero-ctas{display:flex;gap:var(--s-3);flex-wrap:wrap;opacity:0;animation:hero-fade var(--dur-3) var(--ease-out) .85s forwards;}
.hero-meta{
    display:flex;justify-content:space-between;align-items:end;gap:var(--s-6);flex-wrap:wrap;
    margin-top:var(--s-7);padding-top:var(--s-5);
    border-top:1px solid rgba(255,255,255,.22);
    opacity:0;animation:hero-fade var(--dur-3) var(--ease-out) 1s forwards;
}
.hero-meta-label{font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:6px;}
.hero-meta-item strong{font-family:var(--font-serif);font-size:1.5rem;font-weight:400;display:block;}
.hero-scroll{
    position:absolute;left:50%;bottom:28px;transform:translateX(-50%);
    display:flex;flex-direction:column;align-items:center;gap:10px;
    font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.6);
    z-index:2;
}
.hero-scroll-line{width:1px;height:44px;background:linear-gradient(180deg,rgba(255,255,255,.8),rgba(255,255,255,0));animation:scroll-pulse 2.2s ease-in-out infinite;}

@keyframes hero-rise{to{transform:translateY(0);}}
@keyframes hero-fade{to{opacity:1;transform:translateY(0);}}
@keyframes scroll-pulse{0%,100%{transform:scaleY(1);opacity:.7;}50%{transform:scaleY(.4);opacity:.3;}}

/* -------- Calc (Ersparnis-Rechner) ----------------------- */
.calc-wrap{
    position:relative;
    z-index:3;
    margin-top:clamp(-160px,-14vw,-100px);
    margin-bottom:var(--s-9);
}
.calc{
    background:#fff;
    border-radius:clamp(18px,2vw,28px);
    box-shadow:var(--shadow-lg);
    padding:clamp(28px,4vw,56px);
    position:relative;
    overflow:hidden;
}
.calc::before{
    content:"";position:absolute;top:0;left:0;right:0;height:3px;
    background:linear-gradient(90deg,var(--green-500),var(--orange-500));
    transform-origin:left;
    transform:scaleX(var(--progress,.2));
    transition:transform var(--dur-3) var(--ease-out);
}
.calc-head{
    display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-5);flex-wrap:wrap;
    margin-bottom:var(--s-6);
}
.calc-eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--primary);font-weight:500;}
.calc-title{font-family:var(--font-serif);font-size:clamp(1.6rem,2vw + .5rem,2.4rem);line-height:1.1;letter-spacing:-.01em;margin-top:10px;}
.calc-steps-label{color:var(--text-soft);font-size:.85rem;}
.calc-steps-label strong{color:var(--ink-900);font-weight:600;}

.calc-stage{position:relative;min-height:380px;}
.calc-step{
    display:none;
    animation:step-in var(--dur-2) var(--ease-out);
}
.calc-step.is-active{display:block;}
@keyframes step-in{from{opacity:0;transform:translateX(24px);}to{opacity:1;transform:translateX(0);}}
.calc-step.is-back{animation:step-in-back var(--dur-2) var(--ease-out);}
@keyframes step-in-back{from{opacity:0;transform:translateX(-24px);}to{opacity:1;transform:translateX(0);}}

.calc-q{font-family:var(--font-serif);font-size:clamp(1.3rem,1.5vw + .5rem,1.85rem);line-height:1.2;letter-spacing:-.01em;margin-bottom:6px;}
.calc-q-sub{color:var(--text-soft);margin-bottom:var(--s-5);}

.calc-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--s-3);}
.calc-option{
    display:flex;flex-direction:column;align-items:flex-start;gap:10px;
    padding:20px 22px;
    background:var(--paper);
    border:1.5px solid var(--line);
    border-radius:var(--r-md);
    cursor:pointer;
    text-align:left;
    transition:border-color var(--dur-1) var(--ease), background var(--dur-1) var(--ease), transform var(--dur-1) var(--ease);
    position:relative;
    min-height:110px;
}
.calc-option:hover{border-color:var(--primary);background:#fff;transform:translateY(-2px);}
.calc-option.is-selected{border-color:var(--primary);background:var(--green-50);}
.calc-option.is-selected::after{
    content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;
    position:absolute;top:14px;right:14px;
    width:24px;height:24px;border-radius:50%;
    background:var(--primary);color:#fff;
    display:flex;align-items:center;justify-content:center;font-size:.7rem;
}
.calc-option-icon{font-size:1.6rem;color:var(--primary);}
.calc-option-emoji{font-size:1.8rem;line-height:1;}
.calc-option-title{font-weight:600;font-size:1rem;}
.calc-option-desc{font-size:.82rem;color:var(--text-soft);}

.calc-field{margin-bottom:var(--s-4);}
.calc-field label{display:block;font-size:.85rem;font-weight:500;margin-bottom:8px;}
.calc-field .hint{color:var(--text-soft);font-size:.8rem;margin-top:6px;}
.calc-input,
.calc-select{
    width:100%;
    padding:14px 16px;
    border:1.5px solid var(--line);
    border-radius:var(--r-sm);
    background:#fff;
    font-size:1rem;
    transition:border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
}
.calc-input:focus,.calc-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(31,107,78,.12);}

.calc-slider-wrap{padding:6px 0 4px;}
.calc-slider-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;}
.calc-slider-val{font-family:var(--font-serif);font-size:1.6rem;}
.calc-slider-val small{color:var(--text-soft);font-size:1rem;font-family:var(--font-sans);margin-left:4px;}
.calc-slider{
    -webkit-appearance:none;appearance:none;
    width:100%;height:6px;border-radius:999px;
    background:linear-gradient(90deg,var(--primary) var(--val,0%),var(--ink-200) var(--val,0%));
    outline:none;
}
.calc-slider::-webkit-slider-thumb{
    -webkit-appearance:none;appearance:none;
    width:24px;height:24px;border-radius:50%;
    background:#fff;border:2px solid var(--primary);
    box-shadow:var(--shadow-sm);cursor:grab;
}
.calc-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;border:2px solid var(--primary);cursor:grab;}

.calc-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-3);}
@media (max-width:560px){.calc-row{grid-template-columns:1fr;}}

.calc-nav{display:flex;justify-content:space-between;gap:var(--s-3);margin-top:var(--s-6);}
.calc-back{background:transparent;color:var(--text-soft);padding:14px 20px;border-radius:var(--r-full);font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:color var(--dur-1) var(--ease);}
.calc-back:hover{color:var(--ink-900);}
.calc-back:disabled{opacity:0;pointer-events:none;}
.calc-next{padding:16px 28px;border-radius:var(--r-full);background:var(--primary);color:#fff;font-weight:500;display:inline-flex;align-items:center;gap:10px;transition:all var(--dur-2) var(--ease);}
.calc-next:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-glow);}
.calc-next:disabled{opacity:.4;cursor:not-allowed;}

/* Result step */
.calc-result{
    background:linear-gradient(135deg,var(--green-900),var(--ink-900));
    color:#fff;
    border-radius:var(--r-lg);
    padding:clamp(24px,3vw,40px);
    margin-bottom:var(--s-5);
}
.calc-result-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);}
@media (max-width:640px){.calc-result-row{grid-template-columns:1fr;}}
.calc-result-val{
    font-family:var(--font-serif);
    font-size:clamp(2rem,4vw + .5rem,3.5rem);
    line-height:1;font-weight:400;letter-spacing:-.02em;
    color:var(--orange-300);
}
.calc-result-label{font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:10px;}
.calc-result-note{color:rgba(255,255,255,.72);font-size:.85rem;margin-top:14px;}

/* WP-Ergebnis (kein Richtwert, persönliches Angebot) */
.calc-result-wp-title{
    font-family:var(--font-serif);font-weight:400;
    font-size:clamp(1.6rem,3vw + .5rem,2.4rem);
    line-height:1.15;color:#fff;margin:var(--s-4) 0 var(--s-3);
}
.calc-result-wp-lead{color:rgba(255,255,255,.82);line-height:1.65;margin-bottom:var(--s-4);}
.calc-result-wp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:var(--s-5);}
@media (max-width:640px){.calc-result-wp-steps{grid-template-columns:1fr;}}
.calc-result-wp-steps > div{
    display:flex;align-items:center;gap:12px;
    background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
    padding:14px 16px;border-radius:var(--r-md);color:rgba(255,255,255,.9);font-size:.92rem;
}
.calc-result-wp-steps .num{
    width:28px;height:28px;border-radius:50%;background:var(--orange-300);color:var(--ink-900);
    display:grid;place-items:center;font-weight:700;font-size:.92rem;flex-shrink:0;
}

.calc-contact-intro{font-family:var(--font-serif);font-size:1.2rem;margin-bottom:var(--s-4);}
.calc-checkbox{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--text-soft);cursor:pointer;}
.calc-checkbox input{margin-top:3px;width:18px;height:18px;accent-color:var(--primary);}

.calc-done{
    text-align:center;padding:40px 24px;
}
.calc-done-icon{
    width:72px;height:72px;margin:0 auto 20px;border-radius:50%;
    background:var(--green-50);color:var(--primary);
    display:flex;align-items:center;justify-content:center;font-size:1.8rem;
}

.honeypot{position:absolute;left:-10000px;opacity:0;pointer-events:none;}

/* Modal · Large Variant (Fördermittelrechner) */
.modal.modal-lg{max-width:780px;}

/* Fördermittelrechner · Ergebnis */
.rechner-result-header{
    background:linear-gradient(135deg, var(--primary) 0%, var(--green-900) 100%);
    color:#fff;padding:32px 28px;border-radius:var(--r-lg);text-align:center;
    position:relative;overflow:hidden;
}
.rechner-result-header::before{
    content:"";position:absolute;inset:0;
    background:radial-gradient(ellipse at 100% 0%, rgba(245,124,0,.24), transparent 55%);
    pointer-events:none;
}
.rechner-result-big{position:relative;z-index:1;display:flex;flex-direction:column;gap:4px;}
.rechner-result-big .result-label{font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;opacity:.78;}
.rechner-result-big .result-amount{font-family:var(--font-serif);font-weight:300;font-size:clamp(2.6rem,4.5vw + .5rem,3.8rem);line-height:1;letter-spacing:-.02em;margin:10px 0 6px;}
.rechner-result-big .result-percent{display:inline-block;padding:5px 14px;border-radius:999px;background:rgba(245,124,0,.32);color:#fff;font-size:.82rem;font-weight:600;letter-spacing:.04em;align-self:center;}

.rechner-result-details{margin-top:28px;}
.rechner-result-details h4{font-family:var(--font-serif);font-size:1.25rem;margin-bottom:14px;color:var(--ink-900);font-weight:400;}

.foerder-breakdown{background:var(--paper-soft);border-radius:var(--r-md);padding:20px 22px;margin-bottom:24px;}
.foerder-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(13,15,14,.06);gap:12px;}
.foerder-item:last-of-type{border-bottom:0;}
.foerder-item.total{border-top:2px solid var(--line);margin-top:6px;padding-top:14px;font-size:1.08rem;border-bottom:0;}
.foerder-item .foerder-label{display:flex;align-items:center;gap:10px;color:var(--text-soft);font-size:.95rem;}
.foerder-item .foerder-label i{color:var(--primary);width:18px;text-align:center;}
.foerder-item.bonus .foerder-label i{color:var(--orange-500);}
.foerder-item .foerder-value{color:var(--ink-900);font-weight:600;white-space:nowrap;}
.foerder-item.total .foerder-label,
.foerder-item.total .foerder-value{color:var(--primary);}
.foerder-item.total .foerder-value{font-size:1.18rem;}
.foerder-desc{font-size:.84rem;color:var(--text-soft);padding:2px 0 6px 30px;margin-top:-6px;line-height:1.5;}
.foerder-desc.hinweis{background:rgba(245,124,0,.08);border-left:3px solid var(--orange-500);padding:10px 14px;border-radius:6px;margin:10px 0 0 0;color:var(--ink-900);}
.foerder-desc.hinweis i{color:var(--orange-500);margin-right:6px;}

.rechner-kosten-uebersicht .kosten-tabelle{width:100%;border-collapse:collapse;}
.kosten-tabelle td{padding:12px 0;border-bottom:1px solid var(--line);font-size:.94rem;color:var(--text-soft);}
.kosten-tabelle td:last-child{text-align:right;color:var(--ink-900);}
.kosten-tabelle tr.highlight-row td.green{color:var(--primary);}
.kosten-tabelle tr.total-row td{border-top:2px solid var(--ink-900);border-bottom:0;padding-top:14px;font-size:1.05rem;color:var(--ink-900);}

.rechner-kredit-info{
    background:var(--green-50);border-radius:var(--r-md);
    padding:18px 22px;margin-top:22px;
    border-left:3px solid var(--primary);
}
.rechner-kredit-info h4{margin-bottom:6px;color:var(--green-900);font-family:var(--font-sans);font-size:1rem;font-weight:600;}
.rechner-kredit-info h4 i{color:var(--primary);margin-right:6px;}
.rechner-kredit-info p{font-size:.9rem;color:var(--text-soft);margin-bottom:8px;}
.rechner-kredit-info ul{margin:6px 0 0 0;padding-left:20px;font-size:.9rem;color:var(--text-soft);}
.rechner-kredit-info ul li{margin-bottom:4px;}

.rechner-hinweis{background:var(--paper-soft);border-radius:var(--r-md);padding:16px 18px;margin-top:22px;font-size:.88rem;color:var(--text-soft);line-height:1.6;}
.rechner-hinweis i{color:var(--primary);margin-right:4px;}
.rechner-hinweis strong{color:var(--ink-900);}

.rechner-cta{margin-top:24px;}

.modal-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width:560px){.modal-form .form-row{grid-template-columns:1fr;}}
.modal-form .field select{
    width:100%;padding:12px 14px;
    border:1.5px solid var(--line);border-radius:var(--r-sm);
    background:#fff;font-size:.98rem;font-family:var(--font-sans);color:var(--ink-900);
    transition:border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
    cursor:pointer;
}
.modal-form .field input[type="number"]{
    width:100%;padding:12px 14px;
    border:1.5px solid var(--line);border-radius:var(--r-sm);
    background:#fff;font-size:.98rem;font-family:var(--font-sans);color:var(--ink-900);
}
.modal-form .field input[type="number"]:focus,
.modal-form .field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(46,125,50,.14);}

/* -------- Manifesto / Darum ------------------------------ */
.manifesto{background:var(--paper);}
.manifesto-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:var(--s-9);align-items:center;}
@media (max-width:900px){.manifesto-grid{grid-template-columns:1fr;gap:var(--s-7);}}
.manifesto-title{font-family:var(--font-serif);font-size:clamp(2rem,4vw + .5rem,4rem);line-height:1.05;letter-spacing:-.02em;}
.manifesto-title em{font-style:italic;color:var(--primary);}
.manifesto-pillars{display:grid;gap:var(--s-4);}
.pillar{
    padding:22px 26px;
    border-left:2px solid var(--primary);
    background:#fff;
    border-radius:0 var(--r-md) var(--r-md) 0;
    box-shadow:var(--shadow-xs);
}
.pillar-title{font-family:var(--font-serif);font-size:1.25rem;margin-bottom:6px;}
.pillar-desc{color:var(--text-soft);font-size:.95rem;}

/* -------- Bento (Leistungen) ----------------------------- */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--s-4);}
.bento-card{
    position:relative;overflow:hidden;
    border-radius:var(--r-lg);
    background:var(--ink-900);color:#fff;
    aspect-ratio:1/1;
    isolation:isolate;
    transition:transform var(--dur-3) var(--ease);
}
.bento-card img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    z-index:-2;
    transition:transform 1.2s var(--ease-out);
}
.bento-card::after{
    content:"";position:absolute;inset:0;z-index:-1;
    background:linear-gradient(180deg,rgba(13,15,14,.1) 0%,rgba(13,15,14,.2) 50%,rgba(13,15,14,.85) 100%);
    transition:opacity var(--dur-2) var(--ease);
}
.bento-card:hover img{transform:scale(1.05);}
.bento-card-body{
    position:absolute;inset:0;padding:clamp(18px,2vw,32px);
    display:flex;flex-direction:column;justify-content:flex-end;
}
.bento-card-eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--orange-300);margin-bottom:8px;}
.bento-card-title{font-family:var(--font-serif);font-size:clamp(1.3rem,1.2vw + .5rem,2rem);line-height:1.1;margin-bottom:10px;font-weight:400;}
.bento-card-desc{font-size:.9rem;color:rgba(255,255,255,.78);max-width:36ch;margin-bottom:14px;
    max-height:0;overflow:hidden;opacity:0;transition:all var(--dur-3) var(--ease);
}
.bento-card:hover .bento-card-desc{max-height:100px;opacity:1;margin-bottom:14px;}
.bento-card-arrow{
    width:40px;height:40px;border-radius:50%;
    border:1px solid rgba(255,255,255,.4);
    display:inline-flex;align-items:center;justify-content:center;
    transition:all var(--dur-2) var(--ease);
}
.bento-card:hover .bento-card-arrow{background:var(--orange-500);border-color:var(--orange-500);color:#fff;transform:translateX(4px);}

/* Bento layout */
.bento-card.span-6{grid-column:span 6;}
.bento-card.span-4{grid-column:span 4;}
.bento-card.span-8{grid-column:span 8;}
.bento-card.span-12{grid-column:span 12;aspect-ratio:21/6;}
@media (max-width:900px){.bento-card.span-12{aspect-ratio:4/3;}}
.bento-card.row-2{grid-row:span 2;aspect-ratio:auto;min-height:420px;}
.bento-card.tall{aspect-ratio:3/4;}
.bento-card.wide{aspect-ratio:16/10;}

@media (max-width:980px){
    .bento-card,.bento-card.span-6,.bento-card.span-4,.bento-card.span-8{grid-column:span 6;}
    .bento-card.row-2{grid-row:span 1;min-height:0;}
}
@media (max-width:620px){
    .bento-card,.bento-card.span-6,.bento-card.span-4,.bento-card.span-8{grid-column:span 12;aspect-ratio:4/3;}
}

/* -------- Stats ------------------------------------------ */
.stats{background:var(--ink-900);color:#fff;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-6);}
@media (max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--s-5);}}
.stat-num{
    font-family:var(--font-serif);
    font-size:clamp(2.5rem,4vw + .5rem,4.5rem);
    line-height:1;font-weight:300;letter-spacing:-.02em;
    color:var(--orange-300);
}
.stat-num small{font-size:.5em;color:rgba(255,255,255,.5);}
.stat-label{margin-top:10px;font-size:.88rem;color:rgba(255,255,255,.7);max-width:22ch;}

/* -------- Partner marquee -------------------------------- */
.marquee{overflow:hidden;padding:var(--s-6) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-soft);}
.marquee-label{text-align:center;font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text-soft);margin-bottom:var(--s-5);}
.marquee-track{display:flex;gap:var(--s-8);animation:marquee 42s linear infinite;width:max-content;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-track img{height:40px;width:auto;opacity:.6;filter:grayscale(100%);transition:opacity var(--dur-2) var(--ease), filter var(--dur-2) var(--ease);}
.marquee-track img:hover{opacity:1;filter:grayscale(0);}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* -------- Förder Teaser ---------------------------------- */
.foerder-teaser{
    background:linear-gradient(135deg,var(--orange-50),var(--paper-soft));
    border-radius:var(--r-xl);
    padding:clamp(40px,5vw,80px);
    display:grid;grid-template-columns:1.6fr 1fr;gap:var(--s-7);align-items:center;
    position:relative;overflow:hidden;
}
.foerder-teaser::before{
    content:"";position:absolute;right:-80px;bottom:-80px;width:320px;height:320px;border-radius:50%;
    background:radial-gradient(circle,var(--orange-300),transparent 70%);opacity:.5;
}
@media (max-width:860px){.foerder-teaser{grid-template-columns:1fr;text-align:left;}}
.foerder-teaser h2{font-size:clamp(1.75rem,3vw + .3rem,2.75rem);line-height:1.1;}
.foerder-teaser-badge{
    display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;
    background:#fff;font-size:.78rem;font-weight:600;color:var(--orange-700);margin-bottom:16px;
    border:1px solid var(--orange-300);
}
.foerder-teaser-amount{
    font-family:var(--font-serif);font-size:clamp(3rem,6vw,5.5rem);line-height:1;color:var(--ink-900);
    letter-spacing:-.03em;font-weight:300;
}
.foerder-teaser-amount small{font-size:.3em;color:var(--text-soft);letter-spacing:.2em;text-transform:uppercase;display:block;margin-top:8px;font-family:var(--font-sans);font-weight:500;}

/* -------- Testimonials ----------------------------------- */
.testimonials{background:var(--paper-soft);}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);}
.testi-grid-2{grid-template-columns:repeat(2,1fr);max-width:820px;margin:0 auto;}
@media (max-width:900px){.testi-grid,.testi-grid-2{grid-template-columns:1fr;}}
.testi{
    background:#fff;padding:32px 30px;border-radius:var(--r-lg);
    box-shadow:var(--shadow-xs);
    display:flex;flex-direction:column;gap:var(--s-4);
    position:relative;
}
.testi-stars{color:var(--gold-500);font-size:1rem;}
.testi-icon{width:48px;height:48px;border-radius:14px;background:var(--green-50);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.25rem;}
.map-embed{border-radius:var(--r-lg,20px);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm,0 6px 24px rgba(0,0,0,.06));}
.map-embed iframe{filter:grayscale(.35) contrast(1.02);transition:filter var(--dur-2,.4s) var(--ease,ease);}
.map-embed:hover iframe{filter:grayscale(0);}
.testi-quote{font-family:var(--font-serif);font-size:1.15rem;line-height:1.4;color:var(--ink-800);flex:1;}
.testi-foot{display:flex;align-items:center;gap:12px;padding-top:14px;border-top:1px solid var(--line);}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:var(--green-50);color:var(--primary);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-weight:500;}
.testi-name{font-weight:600;font-size:.92rem;}
.testi-role{font-size:.78rem;color:var(--text-soft);}

/* -------- CTA Final -------------------------------------- */
.cta-final{
    background:var(--ink-900);color:#fff;
    border-radius:var(--r-2xl);
    padding:clamp(48px,6vw,96px);
    text-align:center;
    position:relative;overflow:hidden;
    margin-bottom:var(--s-8);
}
.cta-final::before{
    content:"";position:absolute;inset:0;
    background:radial-gradient(ellipse at center top, rgba(31,107,78,.35), transparent 60%);
}
.cta-final h2{position:relative;font-size:clamp(2rem,4vw + .5rem,4rem);line-height:1.05;max-width:18ch;margin:0 auto;}
.cta-final p{position:relative;max-width:52ch;margin:20px auto 36px;color:rgba(255,255,255,.72);}
.cta-final-ctas{position:relative;display:flex;gap:var(--s-3);justify-content:center;flex-wrap:wrap;}

/* -------- Footer ----------------------------------------- */
.footer{background:#0a0c0b;color:rgba(255,255,255,.72);padding:var(--s-8) 0 var(--s-5);}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:var(--s-7);margin-bottom:var(--s-7);}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}
.footer h4{color:#fff;font-family:var(--font-sans);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;margin-bottom:18px;}
.footer ul li{margin-bottom:10px;}
.footer ul a:hover{color:var(--orange-300);}
.footer-logo{font-family:var(--font-serif);font-size:1.6rem;color:#fff;margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.footer-logo img{height:36px;width:auto;}
.footer-brand p{font-size:.92rem;max-width:40ch;}
.footer-contact a{color:rgba(255,255,255,.85);}
.footer-bottom{
    border-top:1px solid rgba(255,255,255,.12);
    padding-top:var(--s-5);
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s-4);
    font-size:.82rem;color:rgba(255,255,255,.5);
}
.footer-bottom-links{display:flex;gap:var(--s-5);flex-wrap:wrap;}

/* -------- Förder Modal ----------------------------------- */
.modal-backdrop{
    position:fixed;inset:0;z-index:100;
    background:rgba(13,15,14,.6);backdrop-filter:blur(6px);
    display:flex;align-items:center;justify-content:center;
    padding:20px;opacity:0;pointer-events:none;
    transition:opacity var(--dur-2) var(--ease);
}
.modal-backdrop.is-open{opacity:1;pointer-events:auto;}
.modal{
    background:var(--paper);border-radius:var(--r-xl);
    width:100%;max-width:680px;max-height:92vh;overflow-y:auto;
    padding:clamp(28px,3vw,48px);
    position:relative;
    transform:translateY(20px);
    transition:transform var(--dur-3) var(--ease-out);
}
.modal-backdrop.is-open .modal{transform:translateY(0);}
.modal-close{
    position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:50%;
    background:rgba(13,15,14,.06);display:flex;align-items:center;justify-content:center;
    transition:background var(--dur-1) var(--ease);
}
.modal-close:hover{background:rgba(13,15,14,.12);}
.modal h2{font-family:var(--font-serif);font-size:clamp(1.5rem,2vw + .5rem,2.25rem);margin-bottom:12px;line-height:1.15;}
.modal-step{display:none;}
.modal-step.is-active{display:block;animation:step-in var(--dur-2) var(--ease-out);}

.modal-head{margin-bottom:var(--s-5);padding-right:48px;}
.modal-form{display:grid;gap:16px;}
.modal-form .field{display:block;}
.modal-form .field-label{display:block;font-size:.85rem;font-weight:500;color:var(--ink-900);margin-bottom:6px;}
.modal-form .field input[type="text"],
.modal-form .field input[type="email"],
.modal-form .field input[type="tel"],
.modal-form .field input[type="file"],
.modal-form .field textarea,
.modal-form .field select{
    width:100%;padding:12px 14px;
    border:1.5px solid var(--line);border-radius:var(--r-sm);
    background:#fff;font-size:.98rem;font-family:var(--font-sans);color:var(--ink-900);
    transition:border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
}
.modal-form .field textarea{resize:vertical;min-height:84px;}
.modal-form .field input:focus,
.modal-form .field textarea:focus,
.modal-form .field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(46,125,50,.14);}
.modal-form .field input[type="file"]{padding:10px 12px;background:var(--paper-soft);cursor:pointer;}

.check-row{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--text-soft);line-height:1.5;cursor:pointer;user-select:none;}
.check-row input[type="checkbox"]{width:18px;height:18px;margin-top:2px;flex-shrink:0;accent-color:var(--primary);cursor:pointer;}
.check-row a{color:var(--primary);text-decoration:underline;}

.hp{position:absolute !important;left:-9999px !important;width:1px !important;height:1px !important;opacity:0 !important;pointer-events:none;}

.btn-block{width:100%;justify-content:center;display:inline-flex;align-items:center;}

.form-status{display:none;padding:12px 16px;border-radius:var(--r-sm);font-size:.9rem;margin-top:4px;}
.form-status.is-loading{display:block;background:var(--paper-soft);color:var(--text-soft);}
.form-status.is-ok{display:block;background:var(--green-50);color:var(--green-900);border:1px solid var(--green-400);}
.form-status.is-err{display:block;background:#fde8e8;color:#7a1a1a;border:1px solid #e8a0a0;}

/* -------- Page Hero (sub-pages) -------------------------- */
.page-hero{
    padding: calc(var(--nav-h) + 64px) 0 var(--s-9);
    background:var(--ink-900);
    color:#fff;
    position:relative;overflow:hidden;
}
.page-hero::before{
    content:"";position:absolute;inset:0;
    background: radial-gradient(ellipse at 20% 100%, rgba(31,107,78,.35), transparent 55%),
                radial-gradient(ellipse at 100% 0%, rgba(232,181,71,.18), transparent 55%);
    pointer-events:none;
}
.page-hero-inner{position:relative;z-index:1;}
.page-hero h1{font-family:var(--font-serif);font-weight:300;font-size:clamp(2.5rem,5vw + .5rem,5.5rem);line-height:1;letter-spacing:-.02em;max-width:18ch;}
.page-hero .lead{color:rgba(255,255,255,.72);max-width:54ch;margin-top:var(--s-5);}
.crumb{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:var(--s-4);}

/* -------- Leistungen Tabs -------------------------------- */
.tabs{display:grid;grid-template-columns:280px 1fr;gap:var(--s-8);}
@media (max-width:960px){.tabs{grid-template-columns:1fr;}}
.tabs-nav{
    position:sticky;top:calc(var(--nav-h) + 24px);
    display:flex;flex-direction:column;gap:4px;
    padding-right:var(--s-4);border-right:1px solid var(--line);
    align-self:start;
}
@media (max-width:960px){
    .tabs-nav{position:static;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--line);padding:0 0 var(--s-4);gap:8px;margin:0 -20px;padding-left:20px;padding-right:20px;}
}
.tab-link{
    display:flex;align-items:center;gap:14px;
    padding:14px 18px;border-radius:var(--r-md);
    font-weight:500;font-size:.98rem;
    color:var(--text-soft);cursor:pointer;
    transition:all var(--dur-1) var(--ease);
    white-space:nowrap;
}
.tab-link i{width:20px;color:var(--primary);font-size:1rem;}
.tab-link:hover{color:var(--ink-900);background:var(--paper-soft);}
.tab-link.is-active{background:var(--ink-900);color:#fff;}
.tab-link.is-active i{color:var(--orange-300);}

.tab-panel{display:none;}
.tab-panel.is-active{display:block;animation:step-in var(--dur-3) var(--ease-out);}
.tab-hero{
    border-radius:var(--r-lg);overflow:hidden;
    aspect-ratio:16/7;background:var(--ink-300);
    margin-bottom:var(--s-6);position:relative;
}
.tab-hero img{width:100%;height:100%;object-fit:cover;}
.tab-hero-badge{position:absolute;top:20px;left:20px;background:rgba(255,255,255,.95);padding:8px 14px;border-radius:999px;font-size:.78rem;font-weight:600;}
.tab-body h2{font-family:var(--font-serif);font-size:clamp(1.75rem,3vw + .5rem,2.75rem);line-height:1.1;margin-bottom:var(--s-4);}
.tab-feats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-4);margin:var(--s-6) 0;}
@media (max-width:640px){.tab-feats{grid-template-columns:1fr;}}
.tab-feat{display:flex;gap:14px;padding:18px 20px;background:var(--paper-soft);border-radius:var(--r-md);}
.tab-feat i{color:var(--primary);font-size:1.1rem;margin-top:3px;}
.tab-feat strong{display:block;margin-bottom:4px;}
.tab-feat span{font-size:.88rem;color:var(--text-soft);}

/* -------- Leistungen — erweiterte Content-Blöcke -------- */
.tab-section{margin:var(--s-6) 0;padding-top:var(--s-5);border-top:1px solid var(--line);}
.tab-section h3{font-family:var(--font-serif);font-size:1.35rem;line-height:1.25;margin-bottom:12px;color:var(--ink-900);}
.tab-section p{color:var(--text-soft);line-height:1.7;margin-bottom:10px;}
.tab-ul{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:8px;}
.tab-ul li{position:relative;padding-left:26px;color:var(--text-soft);line-height:1.55;}
.tab-ul li::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:2px;background:var(--primary);border-radius:2px;}
.tab-ul li strong{color:var(--ink-900);}

.tab-split{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4);margin-top:var(--s-5);}
@media (max-width:720px){.tab-split{grid-template-columns:1fr;}}
.tab-card{border-radius:var(--r-md);padding:22px 24px;background:var(--paper-soft);border:1px solid var(--line);}
.tab-card h4{font-family:var(--font-serif);font-size:1.1rem;line-height:1.2;margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.tab-card h4 i{font-size:.95em;}
.tab-card p{color:var(--text-soft);line-height:1.6;margin-bottom:10px;font-size:.95rem;}
.tab-card ul{list-style:none;padding:0;margin:0;display:grid;gap:6px;}
.tab-card ul li{padding-left:18px;position:relative;color:var(--text-soft);line-height:1.55;font-size:.95rem;}
.tab-card ul li::before{content:"•";position:absolute;left:4px;top:0;color:var(--primary);font-weight:700;}
.tab-card ul li strong{color:var(--ink-900);}
.tab-card-green{background:linear-gradient(180deg,rgba(24,87,63,.04),rgba(24,87,63,.01));border-color:rgba(24,87,63,.18);}
.tab-card-green h4{color:var(--primary);}
.tab-card-green h4 i{color:var(--primary);}
.tab-card-orange{background:linear-gradient(180deg,rgba(245,124,12,.05),rgba(245,124,12,.01));border-color:rgba(245,124,12,.25);}
.tab-card-orange h4{color:var(--orange-500);}
.tab-card-orange h4 i{color:var(--orange-500);}
.tab-card-orange ul li::before{color:var(--orange-500);}

/* CTA-Abstand: damit die Buttons unten immer Luft zum Text haben */
.tab-body > .btn{margin-top:var(--s-7);}
.tab-body > .btn + .btn{margin-left:12px;}
@media (max-width:540px){
    .tab-body > .btn{display:block;width:100%;text-align:center;}
    .tab-body > .btn + .btn{margin-left:0;margin-top:12px;}
}

/* -------- Vor-/Nachteile-Vergleich -------------------- */
.compare-section{padding:var(--s-9) 0;background:var(--paper-soft);}
.compare-head{text-align:center;max-width:66ch;margin:0 auto var(--s-7);}
.compare-head h2{font-family:var(--font-serif);font-size:clamp(1.8rem,3vw + .5rem,2.8rem);line-height:1.15;}
.compare-head p{color:var(--text-soft);margin-top:14px;font-size:1.05rem;}
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);max-width:1100px;margin:0 auto;}
@media (max-width:860px){.compare-grid{grid-template-columns:1fr;}}
.compare-col{background:#fff;border-radius:var(--r-lg);padding:var(--s-6) var(--s-5);border:1px solid var(--line);box-shadow:var(--shadow-sm);}
.compare-col.col-pos{border-top:4px solid var(--primary);}
.compare-col.col-neg{border-top:4px solid var(--ink-300);background:var(--paper);}
.compare-head-row{display:flex;align-items:center;gap:14px;padding-bottom:var(--s-4);margin-bottom:var(--s-4);border-bottom:1px solid var(--line);}
.compare-head-row .col-ico{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:1.35rem;flex-shrink:0;}
.col-pos .col-ico{background:rgba(24,87,63,.1);color:var(--primary);}
.col-neg .col-ico{background:rgba(0,0,0,.06);color:var(--text-soft);}
.compare-head-row h3{font-family:var(--font-serif);font-size:1.35rem;line-height:1.2;margin:0;}
.col-pos .compare-head-row h3{color:var(--primary);}
.col-neg .compare-head-row h3{color:var(--text-soft);}
.compare-item{padding:14px 0;border-bottom:1px solid var(--line);}
.compare-item:last-child{border-bottom:0;}
.compare-item-title{display:flex;align-items:flex-start;gap:12px;margin-bottom:6px;}
.compare-item-title i{font-size:.95rem;margin-top:4px;flex-shrink:0;}
.col-pos .compare-item-title i{color:var(--primary);}
.col-neg .compare-item-title i{color:#b94a4a;opacity:.8;}
.compare-item-title h4{font-family:var(--font-sans);font-size:1rem;font-weight:600;line-height:1.3;color:var(--ink-900);margin:0;}
.compare-item p{color:var(--text-soft);font-size:.92rem;line-height:1.55;margin:0 0 0 26px;}


/* -------- Über Uns -------------------------------------- */
.about-hero-portrait{
    display:grid;grid-template-columns:minmax(0,.75fr) 1.25fr;gap:var(--s-8);align-items:center;
    margin-bottom:var(--s-9);
}
@media (max-width:860px){.about-hero-portrait{grid-template-columns:1fr;}}
.about-portrait-img{
    border-radius:var(--r-xl);overflow:hidden;
    aspect-ratio:4/5;background:var(--ink-200);
    max-width:340px;justify-self:start;width:100%;
}
@media (max-width:860px){.about-portrait-img{max-width:280px;margin:0 auto;}}
.about-portrait-img img{width:100%;height:100%;object-fit:cover;object-position:center 20%;}
.about-name{font-family:var(--font-serif);font-size:clamp(2.25rem,4vw + .5rem,4rem);line-height:1;letter-spacing:-.02em;}
.about-role{color:var(--primary);font-weight:500;margin:8px 0 var(--s-4);letter-spacing:.06em;text-transform:uppercase;font-size:.82rem;}
.about-bio p{font-size:1.05rem;line-height:1.7;margin-bottom:var(--s-3);}

.about-story{max-width:720px;margin:0 auto;}
.about-story p{font-size:1.08rem;line-height:1.75;margin-bottom:var(--s-4);}
.about-story p:first-child::first-letter{
    font-family:var(--font-serif);font-size:4.2rem;float:left;line-height:.9;
    margin:4px 12px 0 -4px;color:var(--primary);font-weight:400;
}

/* -------- Contact Form ---------------------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-8);}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr;}}
.form{display:grid;gap:var(--s-4);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-3);}
@media (max-width:560px){.form-row{grid-template-columns:1fr;}}
.form-field label{font-size:.82rem;font-weight:500;display:block;margin-bottom:6px;}
.form-field input,.form-field textarea,.form-field select{
    width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:var(--r-sm);
    background:#fff;font-size:1rem;transition:border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(31,107,78,.12);}
.form-field textarea{min-height:140px;resize:vertical;}
.form-info{background:var(--paper-soft);padding:clamp(28px,3vw,40px);border-radius:var(--r-lg);}
.info-row{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);}
.info-row:last-child{border-bottom:0;}
.info-icon{width:42px;height:42px;border-radius:50%;background:var(--green-50);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.info-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-soft);margin-bottom:2px;}

.form-msg{padding:14px 18px;border-radius:var(--r-sm);font-size:.92rem;display:none;}
.form-msg.is-visible{display:block;}
.form-msg.is-success{background:var(--green-50);color:var(--green-900);border:1px solid var(--green-400);}
.form-msg.is-error{background:#fde8e8;color:#7a1a1a;border:1px solid #e8a0a0;}

/* -------- Cookie Banner ---------------------------------- */
.cookie-banner{
    position:fixed;bottom:20px;left:20px;right:20px;z-index:90;
    background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
    padding:24px 28px;
    display:none;
    max-width:560px;margin:0 auto;
    border:1px solid var(--line);
}
.cookie-banner.is-visible{display:block;animation:cookie-in .4s var(--ease-out);}
@keyframes cookie-in{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.cookie-banner h4{font-family:var(--font-sans);font-size:1rem;margin-bottom:6px;}
.cookie-banner p{font-size:.86rem;color:var(--text-soft);margin-bottom:16px;}
.cookie-btns{display:flex;gap:10px;flex-wrap:wrap;}
.cookie-btn{padding:10px 18px;border-radius:999px;font-size:.86rem;font-weight:500;}
.cookie-btn.primary{background:var(--ink-900);color:#fff;}
.cookie-btn.primary:hover{background:var(--primary);}
.cookie-btn.ghost{background:transparent;border:1px solid var(--line);}
.cookie-btn.ghost:hover{border-color:var(--ink-900);}

/* -------- Reveal animations ------------------------------ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 900ms var(--ease-out), transform 900ms var(--ease-out);}
.reveal.is-in{opacity:1;transform:translateY(0);}
.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity 700ms var(--ease-out), transform 700ms var(--ease-out);}
.reveal-stagger.is-in>*{opacity:1;transform:translateY(0);}
.reveal-stagger.is-in>*:nth-child(1){transition-delay:0ms;}
.reveal-stagger.is-in>*:nth-child(2){transition-delay:80ms;}
.reveal-stagger.is-in>*:nth-child(3){transition-delay:160ms;}
.reveal-stagger.is-in>*:nth-child(4){transition-delay:240ms;}
.reveal-stagger.is-in>*:nth-child(5){transition-delay:320ms;}
.reveal-stagger.is-in>*:nth-child(6){transition-delay:400ms;}

/* -------- Rechtstexte ------------------------------------ */
.legal{background:var(--paper);padding:calc(var(--nav-h) + 80px) 0 var(--s-9);}
.legal-content{max-width:800px;margin:0 auto;}
.legal-content h1{font-family:var(--font-serif);font-size:clamp(2rem,3vw + .5rem,3rem);line-height:1.1;margin-bottom:var(--s-5);}
.legal-content h2{font-family:var(--font-serif);font-size:1.5rem;margin-top:var(--s-7);margin-bottom:var(--s-3);}
.legal-content h3{font-family:var(--font-sans);font-size:1.05rem;font-weight:600;margin-top:var(--s-4);margin-bottom:var(--s-2);}
.legal-content p,.legal-content li{color:var(--text-soft);font-size:.98rem;line-height:1.7;}
.legal-content ul,.legal-content ol{margin:var(--s-3) 0 var(--s-3) var(--s-5);}
.legal-content ul li,.legal-content ol li{list-style:disc;margin-bottom:6px;}
.legal-content ol li{list-style:decimal;}
.legal-content strong{color:var(--ink-900);font-weight:600;}
.legal-content a{color:var(--primary);text-decoration:underline;}
.legal-content hr{border:0;border-top:1px solid var(--line);margin:var(--s-5) 0;}

/* -------- Partner page grid ------------------------------ */
.partner-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--s-3);}
.partner-card{
    background:#fff;padding:32px 20px;border-radius:var(--r-md);
    display:flex;align-items:center;justify-content:center;
    border:1px solid var(--line);
    aspect-ratio:3/2;
    transition:all var(--dur-2) var(--ease);
}
.partner-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:var(--shadow-sm);}
.partner-card img{max-height:70px;max-width:70%;width:auto;filter:grayscale(100%);opacity:.7;transition:all var(--dur-2) var(--ease);}
.partner-card:hover img{filter:grayscale(0);opacity:1;}

/* -------- Karriere --------------------------------------- */
.job-card{
    background:#fff;padding:32px;border-radius:var(--r-lg);
    display:flex;justify-content:space-between;align-items:center;gap:var(--s-5);
    border:1px solid var(--line);transition:all var(--dur-2) var(--ease);
    margin-bottom:var(--s-3);flex-wrap:wrap;
}
.job-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);}
.job-title{font-family:var(--font-serif);font-size:1.4rem;margin-bottom:6px;}
.job-tags{display:flex;gap:8px;flex-wrap:wrap;}
.job-tag{font-size:.78rem;padding:4px 10px;background:var(--paper-soft);border-radius:999px;color:var(--text-soft);}

/* -------- Utility ---------------------------------------- */
.text-center{text-align:center;}
.muted{color:var(--text-soft);}
.mt-4{margin-top:var(--s-4);} .mt-5{margin-top:var(--s-5);} .mt-6{margin-top:var(--s-6);} .mt-7{margin-top:var(--s-7);}
.mb-4{margin-bottom:var(--s-4);} .mb-5{margin-bottom:var(--s-5);} .mb-6{margin-bottom:var(--s-6);}
.hidden{display:none !important;}

/* -------- Reduced motion --------------------------------- */
@media (prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.001s !important;animation-delay:0s !important;transition-duration:.001s !important;scroll-behavior:auto !important;}
}

/* -------- Page transition -------------------------------- */
body{animation:page-enter 500ms var(--ease-out);}
@keyframes page-enter{from{opacity:0;}to{opacity:1;}}

/* -------- Partner / Karriere Content-Module -------------- */
.partner-feature{
    display:grid;grid-template-columns:1fr 1fr;gap:var(--s-8);align-items:center;
}
@media (max-width:900px){.partner-feature{grid-template-columns:1fr;gap:var(--s-6);}}
.partner-feature.reverse{direction:rtl;}
.partner-feature.reverse > *{direction:ltr;}
@media (max-width:900px){.partner-feature.reverse{direction:ltr;}}
.partner-feature-media img{
    width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow-md);display:block;
    aspect-ratio:4/3;object-fit:cover;
}
/* Karriere-Portrait (Melchiorre-Einzelbild) — 25% kleiner, bleibt zentriert */
.partner-feature.is-portrait{grid-template-columns:minmax(0,.78fr) 1.22fr;}
@media (max-width:900px){.partner-feature.is-portrait{grid-template-columns:1fr;}}
.partner-feature.is-portrait .partner-feature-media{max-width:320px;}
@media (max-width:900px){.partner-feature.is-portrait .partner-feature-media{max-width:260px;margin:0 auto;}}
.partner-feature.is-portrait .partner-feature-media img{aspect-ratio:4/5;}
.partner-feature-text h2,
.partner-feature-text h3{font-family:var(--font-serif);font-weight:400;line-height:1.15;letter-spacing:-.01em;}
.partner-feature-text h3{font-size:1.5rem;}
.partner-feature-text p{color:var(--text-soft);margin-top:14px;max-width:54ch;}

.criteria-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);
}
@media (max-width:980px){.criteria-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.criteria-grid{grid-template-columns:1fr;}}
.criteria-card{
    background:#fff;border-radius:var(--r-md);padding:28px 26px;
    border:1px solid var(--line);
    transition:transform var(--dur-2) var(--ease),box-shadow var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease);
}
.criteria-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--green-400);}
.criteria-icon{
    width:52px;height:52px;border-radius:14px;
    display:inline-flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--green-50),var(--orange-50));
    color:var(--primary);font-size:1.25rem;margin-bottom:16px;
    border:1px solid var(--line);
}
.criteria-card h3{font-family:var(--font-serif);font-size:1.25rem;font-weight:500;letter-spacing:-.01em;margin-bottom:10px;color:var(--ink-900);}
.criteria-card p{color:var(--text-soft);font-size:.94rem;line-height:1.55;}

.feature-rows{display:grid;gap:var(--s-5);}
.feature-row{
    display:grid;grid-template-columns:96px 1fr;gap:var(--s-5);align-items:start;
    background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
    padding:28px 32px;
    transition:border-color var(--dur-2) var(--ease),transform var(--dur-2) var(--ease);
}
.feature-row:hover{border-color:var(--primary);transform:translateX(4px);}
@media (max-width:640px){.feature-row{grid-template-columns:1fr;padding:22px;}}
.feature-row-icon{
    width:72px;height:72px;border-radius:18px;
    display:inline-flex;align-items:center;justify-content:center;
    background:var(--green-50);color:var(--primary);font-size:1.6rem;
}
.feature-row-body h3{font-family:var(--font-serif);font-size:1.5rem;font-weight:500;letter-spacing:-.01em;margin-bottom:10px;}
.feature-row-body p{color:var(--text-soft);max-width:62ch;}

.check-list{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:10px;}
.check-list li{position:relative;padding-left:28px;color:var(--text);}
.check-list li::before{
    content:"";position:absolute;left:0;top:6px;
    width:18px;height:18px;border-radius:50%;
    background:var(--green-50);
    box-shadow:inset 0 0 0 1.5px var(--primary);
}
.check-list li::after{
    content:"";position:absolute;left:5px;top:10px;
    width:8px;height:4px;border-left:1.5px solid var(--primary);border-bottom:1.5px solid var(--primary);
    transform:rotate(-45deg);
}

/* -------- Karriere: Stellenanzeige-Blocks ---------------- */
.stellen-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);margin-top:var(--s-6);
}
@media (max-width:980px){.stellen-grid{grid-template-columns:1fr;}}
.stellen-block{
    background:#fff;border-radius:var(--r-md);padding:28px 26px;border:1px solid var(--line);
    transition:box-shadow var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease);
}
.stellen-block:hover{box-shadow:var(--shadow-md);border-color:var(--primary);}
.stellen-block h3{
    font-family:var(--font-serif);font-size:1.2rem;font-weight:500;letter-spacing:-.01em;
    margin-bottom:14px;color:var(--ink-900);display:flex;gap:10px;align-items:center;
}
.stellen-block h3 i{color:var(--orange-500);font-size:1rem;}
.stellen-list{list-style:none;padding:0;display:grid;gap:10px;}
.stellen-list li{position:relative;padding-left:24px;color:var(--text-soft);font-size:.94rem;line-height:1.55;}
.stellen-list li i{position:absolute;left:0;top:5px;color:var(--primary);font-size:.85rem;}

.kooperation-highlight{
    background:linear-gradient(135deg,var(--green-900),var(--ink-900));
    color:#fff;padding:clamp(40px,5vw,72px);border-radius:var(--r-xl);
    position:relative;overflow:hidden;
}
.kooperation-highlight::before{
    content:"";position:absolute;top:-120px;right:-120px;width:400px;height:400px;border-radius:50%;
    background:radial-gradient(circle,rgba(245,124,0,.2),transparent 70%);
}
.kooperation-highlight h2{
    font-family:var(--font-serif);font-size:clamp(1.75rem,3vw + .3rem,2.75rem);line-height:1.1;
    font-weight:400;letter-spacing:-.01em;margin-bottom:var(--s-6);position:relative;z-index:1;
}
.kooperation-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);position:relative;z-index:1;
}
@media (max-width:900px){.kooperation-grid{grid-template-columns:1fr;}}
.kooperation-item{
    background:rgba(255,255,255,.05);backdrop-filter:blur(8px);
    border:1px solid rgba(255,255,255,.12);border-radius:var(--r-md);
    padding:22px 24px;
    transition:transform var(--dur-2) var(--ease),background var(--dur-2) var(--ease);
}
.kooperation-item:hover{transform:translateY(-4px);background:rgba(255,255,255,.1);}
.kooperation-item h4{font-family:var(--font-serif);font-weight:500;font-size:1.1rem;margin-bottom:8px;display:flex;gap:10px;align-items:center;}
.kooperation-item h4 i{color:var(--orange-300);}
.kooperation-item p{color:rgba(255,255,255,.78);font-size:.9rem;line-height:1.55;}

.process-steps{
    display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-6);margin-top:var(--s-6);
}
@media (max-width:900px){.process-steps{grid-template-columns:1fr;}}
.process-step{
    background:#fff;border-radius:var(--r-md);padding:32px 28px;border:1px solid var(--line);
    position:relative;
}
.step-number{
    font-family:var(--font-serif);font-weight:300;font-size:3rem;line-height:1;
    color:var(--orange-500);margin-bottom:14px;letter-spacing:-.03em;
}
.process-step h3{font-family:var(--font-serif);font-size:1.25rem;font-weight:500;margin-bottom:10px;}
.process-step p{color:var(--text-soft);font-size:.94rem;line-height:1.55;}
.process-step a{color:var(--primary);text-decoration:underline;}

.highlight-box{
    background:linear-gradient(135deg,var(--green-50),var(--orange-50));
    border-radius:var(--r-md);padding:28px 32px;margin-top:var(--s-6);
    border-left:4px solid var(--primary);
}
.highlight-box h3{font-family:var(--font-serif);font-size:1.2rem;font-weight:500;margin-bottom:10px;}

.intro-content{max-width:72ch;}
.intro-content p{color:var(--text-soft);margin-bottom:14px;font-size:1.02rem;line-height:1.7;}

/* ============================================================
   LEAD-FUNNEL  (5 Fragen + Kontakt) — klassischer Weiß-Look
   ============================================================ */
.funnel-wrap{margin-top:-80px;position:relative;z-index:3;padding:0 var(--s-4);}
.funnel{
    background:#fff;
    color:var(--text,#1a1a1a);
    border-radius:var(--r-xl,28px);
    padding:clamp(24px,3vw,48px);
    box-shadow:0 24px 60px -24px rgba(0,0,0,.18),0 2px 6px rgba(0,0,0,.04);
    border:1px solid var(--ink-100,#e6e6e3);
    max-width:860px;margin:0 auto;
    position:relative;
}

/* Kopf / Progress */
.funnel-head{display:flex;flex-direction:column;gap:10px;margin-bottom:clamp(18px,2.5vw,28px);}
.funnel-progress-meta{
    font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
    color:var(--text-soft,#5f6a63);font-weight:500;
}
.funnel-progress-meta strong{color:var(--green-700,#1b5e20);font-weight:600;font-size:1rem;margin:0 2px;}
.funnel-progress-bar{
    height:6px;background:var(--ink-100,#eceae5);border-radius:99px;overflow:hidden;position:relative;
}
.funnel-progress-bar span{
    display:block;height:100%;border-radius:99px;
    background:linear-gradient(90deg,#43a047 0%,#1b5e20 100%);
    transition:width .45s cubic-bezier(.65,.05,.36,1);
}

/* Body */
.funnel-body{min-height:340px;}
.funnel-cat-tag{
    display:inline-block;padding:6px 14px;border-radius:99px;
    background:rgba(27,94,32,.08);color:var(--green-700,#1b5e20);
    font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
    margin-bottom:16px;
}
.funnel-h{
    font-family:var(--font-serif);font-weight:400;
    font-size:clamp(1.55rem,2vw + .7rem,2.4rem);line-height:1.2;
    color:var(--text,#1a1a1a);margin:0 0 8px;
}
.funnel-sub{
    color:var(--text-soft,#5f6a63);font-size:1rem;line-height:1.55;
    margin:0 0 clamp(18px,2vw,26px);max-width:52ch;
}

/* Option-Buttons */
.funnel-options{display:flex;flex-direction:column;gap:12px;margin-top:8px;}
.funnel-options.is-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;
}
.funnel-option{
    appearance:none;cursor:pointer;width:100%;text-align:left;
    background:#fff;
    border:1.5px solid var(--ink-100,#e6e6e3);
    color:var(--text,#1a1a1a);border-radius:16px;
    padding:18px 22px;
    font-family:inherit;font-size:1rem;
    display:flex;align-items:center;gap:14px;
    transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease;
    min-height:64px;
}
.funnel-option:hover,.funnel-option:focus-visible{
    background:var(--paper-soft,#faf8f3);
    border-color:var(--green-500,#43a047);
    transform:translateY(-2px);
    box-shadow:0 10px 24px -14px rgba(27,94,32,.3);
    outline:none;
}
.funnel-option:active{transform:translateY(0);}
.funnel-option-cat{flex-direction:column;align-items:flex-start;text-align:left;padding:22px 22px 20px;gap:10px;}
.funnel-opt-icon{
    width:44px;height:44px;border-radius:12px;
    display:inline-grid;place-items:center;
    background:rgba(27,94,32,.08);color:var(--green-700,#1b5e20);
    font-size:1.35rem;line-height:1;
    transition:background .18s ease,color .18s ease;
}
.funnel-option-cat:hover .funnel-opt-icon{background:var(--green-700,#1b5e20);color:#fff;}
.funnel-opt-title{font-size:1.12rem;font-weight:600;display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;}
.funnel-badge{
    display:inline-block;padding:2px 9px;border-radius:99px;
    background:var(--accent,#f57c00);color:#fff;
    font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
}
.funnel-opt-desc{font-size:.88rem;color:var(--text-soft,#5f6a63);line-height:1.45;}
.funnel-option-ans{justify-content:space-between;padding:20px 24px;}
.funnel-opt-label{font-weight:500;font-size:1.05rem;flex:1;color:var(--text,#1a1a1a);}
.funnel-opt-chev{color:var(--ink-300,#c4c1b8);transition:transform .2s ease,color .2s ease;}
.funnel-option-ans:hover .funnel-opt-chev{transform:translateX(4px);color:var(--green-700,#1b5e20);}

/* Kontaktformular */
.funnel-form{display:flex;flex-direction:column;gap:14px;margin-top:8px;}
.funnel-field{display:flex;flex-direction:column;gap:6px;}
.funnel-field > span{
    font-size:.85rem;color:var(--text,#1a1a1a);font-weight:500;
}
.funnel-field input{
    appearance:none;background:#fff;
    border:1.5px solid var(--ink-100,#e6e6e3);color:var(--text,#1a1a1a);
    padding:14px 16px;border-radius:12px;
    font-family:inherit;font-size:1rem;
    transition:border-color .2s ease,box-shadow .2s ease;
    min-height:52px;
}
.funnel-field input::placeholder{color:var(--ink-300,#b2afa6);}
.funnel-field input:focus{
    outline:none;border-color:var(--green-500,#43a047);
    box-shadow:0 0 0 4px rgba(67,160,71,.15);
}
.funnel-check{
    display:flex;gap:10px;align-items:flex-start;margin-top:6px;
    font-size:.92rem;color:var(--text-soft,#5f6a63);line-height:1.5;cursor:pointer;
}
.funnel-check input{flex-shrink:0;margin-top:3px;accent-color:var(--green-700,#1b5e20);width:18px;height:18px;}
.funnel-check a{color:var(--green-700,#1b5e20);text-decoration:underline;}
.funnel-hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;}
.funnel-submit{margin-top:10px;min-height:58px;font-size:1.05rem;font-weight:600;letter-spacing:.01em;}

.funnel-trust{
    list-style:none;padding:0;margin:18px 0 0;
    display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px 18px;
}
.funnel-trust li{
    font-size:.88rem;color:var(--text-soft,#5f6a63);display:flex;align-items:center;gap:8px;
}
.funnel-trust i{color:var(--green-500,#43a047);font-size:.85rem;}

.funnel-msg{min-height:22px;font-size:.92rem;color:var(--text-soft,#5f6a63);text-align:center;}
.funnel-msg.is-err{color:#c62828;}
.funnel-msg.is-ok{color:var(--green-700,#1b5e20);}
.funnel-msg.is-loading{color:var(--text-soft,#5f6a63);}

/* Fuß-Navigation */
.funnel-foot{margin-top:clamp(16px,2vw,24px);}
.funnel-back{
    appearance:none;background:transparent;border:none;
    color:var(--text-soft,#5f6a63);font-family:inherit;font-size:.92rem;cursor:pointer;
    display:inline-flex;align-items:center;gap:8px;padding:8px 0;
    transition:color .18s ease,transform .18s ease;
}
.funnel-back:hover:not(:disabled){color:var(--green-700,#1b5e20);transform:translateX(-3px);}
.funnel-back:disabled{opacity:.35;cursor:not-allowed;}

/* Mobile */
@media (max-width: 640px){
    .funnel-wrap{padding:0 12px;margin-top:-40px;}
    .funnel{padding:20px 16px 24px;border-radius:22px;}
    .funnel-body{min-height:300px;}
    .funnel-options.is-grid{grid-template-columns:1fr;}
    .funnel-option-cat{padding:18px 18px 16px;}
    .funnel-opt-icon{width:38px;height:38px;font-size:1.15rem;border-radius:10px;}
    .funnel-opt-title{font-size:1.02rem;}
    .funnel-option-ans{padding:16px 18px;min-height:60px;}
    .funnel-trust{grid-template-columns:1fr;}
    .funnel-h{font-size:1.45rem;}
}

/* ============================================================
   PRINCIPLES GRID (Über uns — Drei Prinzipien)
   ============================================================ */
.principles-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px);
}
.principle{
    background:#fff;border:1px solid var(--ink-100,#e6e6e3);
    border-radius:var(--r-lg,20px);
    padding:clamp(22px,2.4vw,32px);
    position:relative;
    transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.principle:hover{
    transform:translateY(-3px);
    box-shadow:0 14px 34px -18px rgba(27,94,32,.28);
    border-color:var(--green-500,#43a047);
}
.principle-n{
    font-family:var(--font-serif);font-weight:400;
    font-size:clamp(1.6rem,1.6vw + .8rem,2.1rem);line-height:1;
    color:var(--green-700,#1b5e20);
    margin-bottom:14px;letter-spacing:.04em;
}
.principle-title{
    font-weight:600;font-size:1.1rem;line-height:1.3;
    color:var(--text,#1a1a1a);margin-bottom:10px;
}
.principle-desc{
    font-size:.95rem;line-height:1.65;color:var(--text-soft,#5f6a63);
}
@media (max-width: 900px){
    .principles-grid{grid-template-columns:1fr;gap:14px;}
    .principle{padding:22px 20px;}
    .principle-title{font-size:1.05rem;}
}

/* ============================================================
   DANKE-SEITE
   ============================================================ */
.danke-wrap{padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(40px,5vw,80px);background:var(--paper-soft);}
.danke-card{
    background:#fff;border-radius:var(--r-xl,28px);
    padding:clamp(28px,4vw,56px);
    box-shadow:0 12px 40px -20px rgba(0,0,0,.18);
    text-align:center;
    border:1px solid var(--ink-100);
}
.danke-check{
    width:76px;height:76px;border-radius:50%;
    background:linear-gradient(135deg,var(--green-500),var(--green-700));
    color:#fff;font-size:2rem;
    margin:0 auto 22px;display:grid;place-items:center;
    box-shadow:0 12px 28px -12px rgba(46,125,50,.5);
    animation:pop-in .5s cubic-bezier(.34,1.56,.64,1) .1s both;
}
@keyframes pop-in{from{opacity:0;transform:scale(.6);}to{opacity:1;transform:scale(1);}}
.danke-title{
    font-family:var(--font-serif);font-weight:400;
    font-size:clamp(2rem,3vw + .5rem,3.2rem);line-height:1.1;
    margin:12px 0 18px;
}
.danke-lead{color:var(--text-soft);font-size:1.08rem;line-height:1.6;max-width:52ch;margin:0 auto 28px;}
.danke-next{
    display:inline-flex;flex-direction:column;gap:6px;align-items:center;
    background:var(--green-50);border:1px solid rgba(46,125,50,.2);
    padding:12px 22px;border-radius:14px;margin:0 auto 30px;
}
.danke-next-label{font-family:var(--font-serif);font-size:1.25rem;color:var(--primary);}

.danke-steps{margin:34px 0 26px;text-align:left;max-width:560px;margin-left:auto;margin-right:auto;}
.danke-steps h2{font-family:var(--font-serif);font-size:1.35rem;font-weight:500;margin-bottom:14px;text-align:center;}
.danke-steps ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;}
.danke-steps li{display:flex;gap:14px;align-items:flex-start;background:var(--paper);padding:16px 18px;border-radius:14px;border-left:3px solid var(--primary);}
.danke-steps li strong{display:block;color:var(--ink-900);margin-bottom:2px;}
.danke-steps li div{color:var(--text-soft);line-height:1.5;font-size:.95rem;flex:1;}
.danke-step-n{
    flex-shrink:0;width:30px;height:30px;border-radius:50%;
    background:var(--primary);color:#fff;display:grid;place-items:center;
    font-weight:600;font-size:.9rem;
}

.danke-trust{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px 18px;
    margin:28px 0 24px;padding:18px;background:var(--paper);border-radius:14px;
}
.danke-trust > div{display:flex;align-items:center;gap:10px;color:var(--text-soft);font-size:.93rem;}
.danke-trust i{color:var(--primary);}

.danke-ctas{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin:10px 0 18px;}
.danke-urgent{color:var(--text-soft);font-size:.92rem;margin-top:12px;}
.danke-urgent a{color:var(--primary);text-decoration:underline;font-weight:500;}

@media (max-width:640px){
    .danke-card{padding:24px 18px;}
    .danke-trust{grid-template-columns:1fr;}
    .danke-ctas .btn{width:100%;justify-content:center;}
}

/* ===================================================== */
/* ONLINE-TERMINBUCHUNG (termin.html) */
/* ===================================================== */
.booking{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg,20px);padding:clamp(20px,3vw,40px);box-shadow:0 6px 24px rgba(0,0,0,.04);}
.booking-progress{display:flex;gap:10px;margin-bottom:32px;overflow-x:auto;padding-bottom:4px;}
.booking-step{flex:1;min-width:120px;padding:12px 16px;border-radius:var(--r-md,12px);background:var(--paper-soft);color:var(--text-soft);font-size:.88rem;display:flex;align-items:center;gap:10px;border:1px solid transparent;transition:all .25s var(--ease);}
.booking-step .bs-n{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,.06);font-weight:600;font-size:.82rem;}
.booking-step.is-active{background:var(--primary);color:#fff;border-color:var(--primary);}
.booking-step.is-active .bs-n{background:rgba(255,255,255,.22);}
.booking-step.is-done{background:var(--green-50);color:var(--primary);border-color:var(--green-50);}
.booking-step.is-done .bs-n{background:var(--primary);color:#fff;}
.booking-head{margin-bottom:24px;}
.booking-h2{font-family:var(--font-serif);font-size:clamp(1.5rem,1.5vw + .8rem,2rem);line-height:1.2;margin-bottom:8px;color:var(--ink-900);}
.booking-themas{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
@media (max-width:768px){.booking-themas{grid-template-columns:repeat(2,1fr);} .booking-step{min-width:90px;font-size:.78rem;padding:10px 12px;}}
.booking-thema{position:relative;display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px 12px;background:#fff;border:2px solid var(--line);border-radius:var(--r-md,12px);cursor:pointer;text-align:center;font-family:var(--font-sans);font-size:.95rem;color:var(--ink-900);transition:all .2s var(--ease);}
.booking-thema > i{font-size:1.6rem;color:var(--primary);}
.booking-thema:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 6px 18px rgba(24,87,63,.08);}
.booking-thema.is-active{background:var(--green-50);border-color:var(--primary);}
.booking-thema.is-active > i{transform:scale(1.05);}
.booking-thema .bt-check{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--paper-soft);border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.6);transition:all .2s var(--ease);}
.booking-thema .bt-check i{font-size:.7rem;color:#fff;}
.booking-thema.is-active .bt-check{opacity:1;transform:scale(1);background:var(--primary);border-color:var(--primary);}
.booking-cal-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;flex-wrap:wrap;}
.booking-cal-arrow{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1px solid var(--line);border-radius:999px;cursor:pointer;font-size:.85rem;color:var(--ink-900);font-family:var(--font-sans);transition:all .2s var(--ease);}
.booking-cal-arrow:hover:not(:disabled){border-color:var(--primary);color:var(--primary);}
.booking-cal-arrow:disabled{opacity:.4;cursor:not-allowed;}
.booking-cal-range{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-serif);font-size:1rem;color:var(--ink-900);}
.booking-cal-range i{color:var(--primary);}
@media (max-width:560px){.booking-cal-arrow{font-size:.78rem;padding:8px 10px;} .booking-cal-range{font-size:.92rem;flex-basis:100%;justify-content:center;order:-1;}}
.booking-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:24px;}
@media (max-width:768px){.booking-cal{grid-template-columns:repeat(4,1fr);}}
.booking-day{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 6px;background:#fff;border:1px solid var(--line);border-radius:var(--r-md,12px);cursor:pointer;transition:all .2s var(--ease);color:var(--ink-900);}
.booking-day:hover:not(.is-disabled){border-color:var(--primary);transform:translateY(-1px);}
.booking-day.is-active{background:var(--primary);color:#fff;border-color:var(--primary);}
.booking-day.is-disabled{opacity:.35;cursor:not-allowed;}
.bd-dow{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;opacity:.7;}
.bd-num{font-family:var(--font-serif);font-size:1.6rem;line-height:1;margin:2px 0;}
.bd-mon{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;opacity:.7;}
.bd-slots{font-size:.68rem;margin-top:4px;opacity:.85;}
.booking-times{background:var(--paper-soft);border-radius:var(--r-md,12px);padding:20px;}
.booking-times-head{margin-bottom:14px;color:var(--ink-800);font-size:.95rem;}
.booking-times-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;}
.booking-time{padding:12px 8px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm,8px);cursor:pointer;font-weight:500;font-family:var(--font-sans);color:var(--ink-900);transition:all .2s var(--ease);}
.booking-time:hover{border-color:var(--primary);}
.booking-time.is-active{background:var(--primary);color:#fff;border-color:var(--primary);}
.booking-form{display:flex;flex-direction:column;gap:14px;}
.booking-summary{background:var(--paper-soft);border-radius:var(--r-md,12px);padding:24px;position:relative;}
.booking-summary dl{display:grid;grid-template-columns:auto 1fr;gap:10px 24px;margin-bottom:18px;}
.booking-summary dt{font-size:.85rem;color:var(--text-soft);}
.booking-summary dd{font-weight:500;color:var(--ink-900);}
.booking-foot{display:flex;justify-content:space-between;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--line);}
.booking-foot .btn{min-width:160px;}
.booking-loading{padding:32px;text-align:center;color:var(--text-soft);}
.booking-loading i{margin-right:8px;}
.booking-empty{margin-top:20px;padding:24px;background:var(--paper-soft);border-radius:var(--r-md,12px);text-align:center;color:var(--ink-800);}
.booking-empty i{color:var(--accent);margin-right:8px;}
.booking-empty a{color:var(--primary);text-decoration:underline;font-weight:600;}
.booking-success{text-align:center;padding:24px 16px;}
.booking-success-icon{font-size:3.2rem;color:var(--primary);margin-bottom:12px;}
.booking-success-card{background:var(--green-50);border-radius:var(--r-md,12px);padding:22px;margin:18px auto;max-width:420px;text-align:left;}
.bsc-thema{font-family:var(--font-serif);font-size:1.25rem;margin-bottom:10px;color:var(--ink-900);}
.bsc-when{display:flex;align-items:center;gap:10px;margin:4px 0;color:var(--ink-800);}
.bsc-when i{color:var(--primary);width:16px;}
.bsc-rep{margin-top:12px;padding-top:12px;border-top:1px solid rgba(0,0,0,.08);font-size:.92rem;color:var(--text-soft);}
.booking-trust{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-top:32px;padding-top:24px;color:var(--text-soft);font-size:.9rem;}
.trust-item{display:flex;align-items:center;gap:8px;}
.trust-item i{color:var(--primary);}
@media (max-width:560px){.booking-trust{gap:14px;font-size:.82rem;}}

/* Nav-CTA Aufmerksamkeit (Termin buchen) */
.nav-cta-pulse{position:relative;}
.nav-cta-pulse::after{content:"";position:absolute;inset:-2px;border-radius:999px;border:2px solid var(--orange-500);opacity:0;animation:cta-pulse 2.4s ease-out infinite;pointer-events:none;}
@keyframes cta-pulse{0%{opacity:.55;transform:scale(1);}80%{opacity:0;transform:scale(1.18);}100%{opacity:0;transform:scale(1.18);}}
@media (prefers-reduced-motion: reduce){.nav-cta-pulse::after{animation:none;}}

/* ===================================================== */
/* Sticky Mobile FAB (Anruf + Termin) */
/* ===================================================== */
.mobile-fab{position:fixed;right:14px;bottom:14px;z-index:90;display:none;flex-direction:column;gap:10px;align-items:flex-end;}
@media (max-width:768px){.mobile-fab{display:flex;}}
.mobile-fab .fab{display:inline-flex;align-items:center;gap:8px;padding:14px 18px;border-radius:999px;font-family:var(--font-sans);font-weight:600;font-size:.95rem;color:#fff;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.18);transform:translateY(0);transition:all .25s var(--ease,ease);will-change:transform;}
.mobile-fab .fab:hover,.mobile-fab .fab:focus{transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,0,0,.24);}
.mobile-fab .fab i{font-size:1rem;}
.mobile-fab .fab-call{background:var(--primary);}
.mobile-fab .fab-book{background:var(--orange-500);}
.mobile-fab .fab-call::after{content:"";position:absolute;inset:-4px;border-radius:999px;border:2px solid var(--primary);opacity:0;animation:fab-pulse 2.4s ease-out infinite;pointer-events:none;}
.mobile-fab .fab-call{position:relative;}
@keyframes fab-pulse{0%{opacity:.55;transform:scale(1);}80%{opacity:0;transform:scale(1.25);}100%{opacity:0;transform:scale(1.25);}}
@media (prefers-reduced-motion: reduce){.mobile-fab .fab-call::after{animation:none;}}
/* Verstecken auf Termin-Seite (redundant) und während Mobile-Menü offen */
body[data-page="termin"] .mobile-fab,body.menu-open .mobile-fab{display:none !important;}

/* ===================================================== */
/* Hero Live-Slot Anzeige (index.html) */
/* ===================================================== */
.hero-live-slot{display:inline-flex;align-items:center;gap:10px;margin-top:18px;padding:10px 16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:999px;color:#fff;font-size:.92rem;text-decoration:none;backdrop-filter:blur(8px);transition:all .25s var(--ease,ease);max-width:100%;}
.hero-live-slot:hover{background:rgba(255,255,255,.18);transform:translateY(-1px);border-color:#fff;}
.hero-live-slot .hls-dot{width:8px;height:8px;border-radius:50%;background:#62d27a;box-shadow:0 0 0 0 rgba(98,210,122,.6);animation:hls-pulse 2s ease-out infinite;}
@keyframes hls-pulse{0%{box-shadow:0 0 0 0 rgba(98,210,122,.6);}70%{box-shadow:0 0 0 10px rgba(98,210,122,0);}100%{box-shadow:0 0 0 0 rgba(98,210,122,0);}}
.hero-live-slot .hls-label{opacity:.85;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;}
.hero-live-slot .hls-when{font-weight:600;}
.hero-live-slot .hls-arrow{margin-left:4px;opacity:.8;}
.hero-live-slot.is-hidden{display:none;}

/* ===================================================== */
/* WhatsApp — Mobile FAB Farbe + Desktop dezenter Float */
/* ===================================================== */
.mobile-fab .fab-wa{background:#25D366;}
.wa-float{position:fixed;right:22px;bottom:22px;z-index:85;display:none;align-items:center;gap:10px;background:#25D366;color:#fff;padding:12px 18px;border-radius:999px;text-decoration:none;font-family:var(--font-sans);font-weight:600;font-size:.9rem;box-shadow:0 8px 24px rgba(37,211,102,.35);transition:all .25s var(--ease,ease);}
.wa-float i{font-size:1.4rem;}
.wa-float:hover,.wa-float:focus{transform:translateY(-2px);box-shadow:0 12px 30px rgba(37,211,102,.45);}
@media (min-width:769px){.wa-float{display:inline-flex;}}
/* dezent: auf Booking-Seite + Mobile-Menü-offen ausblenden */
body[data-page="termin"] .wa-float,body.menu-open .wa-float{display:none !important;}
.wa-float-label{display:inline;}
@media (max-width:1024px) and (min-width:769px){.wa-float-label{display:none;} .wa-float{padding:14px;}}

/* Cookie-Banner über FAB: FAB nach oben rutschen wenn Banner sichtbar */
body:has(.cookie-banner.is-visible) .mobile-fab{bottom:calc(14px + 180px);}
body:has(.cookie-banner.is-visible) .wa-float{bottom:calc(22px + 180px);}
/* Fallback für Browser ohne :has (Safari <15.4) */
.cookie-banner.is-visible ~ .mobile-fab{bottom:calc(14px + 180px);}
.cookie-banner.is-visible ~ .wa-float{bottom:calc(22px + 180px);}

/* Tap-Target Min 44x44 für Mobile (a11y) */
@media (max-width:768px){
    .nav-burger{min-width:44px;min-height:44px;}
    .booking-time,.booking-day{min-height:44px;}
    .footer-bottom-links a{min-height:44px;display:inline-flex;align-items:center;}
}

/* Mobile FAB: kleiner + icon-only auf Handy */
@media (max-width:768px){
    .mobile-fab{gap:10px;right:14px;bottom:14px;}
    .mobile-fab .fab{width:52px;height:52px;padding:0;border-radius:50%;justify-content:center;gap:0;font-size:0;line-height:0;}
    .mobile-fab .fab i{font-size:1.3rem;line-height:1;}
    .mobile-fab .fab-label{display:none;}
}

/* Booking-Kalender: Skeleton-Ladezustand (kein Flash/Sprung beim Wochenwechsel) */
#bkTerminStage{min-height:180px;}
.booking-day-skeleton{pointer-events:none;border-color:var(--line);background:linear-gradient(100deg,#f0f0ee 30%,#e4e4e0 50%,#f0f0ee 70%);background-size:200% 100%;animation:skel-shimmer 1.2s ease-in-out infinite;color:transparent;}
.booking-day-skeleton span{color:transparent !important;}
@keyframes skel-shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
.booking-cal.is-loading{opacity:.9;}
@media (prefers-reduced-motion: reduce){.booking-day-skeleton{animation:none;}}
