/* ============================================================
   hortus — site-custom.css
   Layout skeleton: cinematic hero · bento sparten · vorher/nachher
   slider · projekt galerie/lightbox · reveals · sub-page heroes
   (MANDATORY — every *.html links this file)
   ============================================================ */

/* ---------------- Reveal system ---------------- */
/* gated behind .js so a failed/blocked script never leaves content invisible */
.js .reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in-view{opacity:1;transform:none}
.js .reveal-stagger>*{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal-stagger.in-view>*{opacity:1;transform:none}
.reveal-stagger.in-view>*:nth-child(2){transition-delay:.08s}
.reveal-stagger.in-view>*:nth-child(3){transition-delay:.16s}
.reveal-stagger.in-view>*:nth-child(4){transition-delay:.24s}
.reveal-stagger.in-view>*:nth-child(5){transition-delay:.32s}
.reveal-stagger.in-view>*:nth-child(6){transition-delay:.40s}

/* ================= CINEMATIC HERO ================= */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink-black)}
.hero-bg{position:absolute;inset:0;opacity:0;transition:opacity 2s ease-in-out;background-size:cover;background-position:center;will-change:transform,opacity}
.hero-bg.active{opacity:1}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(21,24,26,.5) 0%,rgba(21,24,26,.15) 35%,rgba(21,24,26,.62) 78%,rgba(21,24,26,.92) 100%),
  linear-gradient(90deg,rgba(21,24,26,.55),transparent 55%)}
@keyframes kenburns{0%{transform:scale(1.06) translate(0,0)}100%{transform:scale(1.18) translate(-1.5%,-2%)}}
.hero-bg.active{animation:kenburns 22s ease-in-out infinite alternate}
.hero-haze{position:absolute;inset:0;background:radial-gradient(60% 50% at 18% 12%,rgba(201,138,46,.22),transparent 70%);mix-blend-mode:screen;pointer-events:none}
.hero-dust{position:absolute;inset:0;pointer-events:none;opacity:.5;background-image:
  radial-gradient(1.5px 1.5px at 12% 30%,rgba(255,255,255,.5),transparent),
  radial-gradient(1.5px 1.5px at 38% 70%,rgba(255,255,255,.4),transparent),
  radial-gradient(1px 1px at 62% 22%,rgba(255,255,255,.5),transparent),
  radial-gradient(2px 2px at 78% 58%,rgba(255,255,255,.35),transparent),
  radial-gradient(1px 1px at 88% 38%,rgba(255,255,255,.45),transparent),
  radial-gradient(1.5px 1.5px at 50% 88%,rgba(255,255,255,.4),transparent);
  animation:dustdrift 26s linear infinite}
@keyframes dustdrift{0%{transform:translateY(0)}100%{transform:translateY(-40px)}}
.hero-letterbox{position:absolute;left:0;right:0;height:clamp(28px,6vh,64px);background:var(--ink-black);z-index:4;pointer-events:none}
.hero-letterbox.top{top:0}.hero-letterbox.bottom{bottom:0}

.hero-inner{position:relative;z-index:6;padding-bottom:clamp(4rem,9vh,8rem);padding-top:clamp(8rem,12vh,11rem);width:100%}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--f-display);font-weight:600;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--amber-light);margin-bottom:1.4rem;opacity:0;animation:fadeUp 1s var(--ease) .3s forwards}
.hero-eyebrow::before{content:"";width:30px;height:1px;background:var(--amber-light)}
.hero-title{font-family:var(--f-mega);font-weight:800;font-size:clamp(2.5rem,8.2vw,7.2rem);line-height:.96;color:var(--cream);text-shadow:0 2px 30px rgba(0,0,0,.4);max-width:16ch;overflow-wrap:break-word;hyphens:none}
.hero-title .hword{display:inline-block;white-space:nowrap}
.hero-title .char{display:inline-block;opacity:0;transform:translateY(46px) rotateX(-40deg);filter:blur(8px);transition:opacity .8s var(--ease),transform .8s var(--ease),filter .8s var(--ease)}
.hero.in-view .hero-title .char{opacity:1;transform:none;filter:blur(0)}
.hero-sub{margin-top:1.7rem;max-width:54ch;font-size:clamp(1.02rem,1.4vw,1.22rem);color:var(--cream-soft);line-height:1.65;opacity:0;animation:fadeUp 1s var(--ease) .9s forwards}
.hero-actions{margin-top:2.3rem;display:flex;flex-wrap:wrap;gap:1rem;opacity:0;animation:fadeUp 1s var(--ease) 1.1s forwards}
@keyframes fadeUp{to{opacity:1;transform:none}}

/* Hero dots (crossfade indicator) */
.hero-dots{position:absolute;bottom:clamp(1.4rem,4vh,2.6rem);right:clamp(1.4rem,5vw,3rem);z-index:6;display:flex;gap:.5rem}
.hero-dots button{width:30px;height:3px;border-radius:3px;background:rgba(237,230,216,.35);transition:background .35s}
.hero-dots button.active{background:var(--amber-light)}
.hero-scrollcue{position:absolute;bottom:clamp(1.4rem,4vh,2.6rem);left:50%;transform:translateX(-50%);z-index:6;color:var(--cream-soft);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.8}
.hero-scrollcue span{width:1px;height:34px;background:linear-gradient(var(--amber-light),transparent);animation:cuepulse 2s ease-in-out infinite}
@keyframes cuepulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-display);font-weight:600;font-size:.96rem;padding:.92rem 1.7rem;border-radius:999px;transition:transform .25s var(--ease),box-shadow .25s,background .25s}
.btn-primary{background:var(--amber);color:#fff;box-shadow:0 14px 32px -12px rgba(201,138,46,.75)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 40px -12px rgba(201,138,46,.85)}
.btn-ghost{background:rgba(237,230,216,.08);color:var(--cream);border:1px solid rgba(237,230,216,.3)}
.btn-ghost:hover{background:rgba(237,230,216,.16);transform:translateY(-3px)}
.btn-dark{background:var(--ink);color:var(--cream)}
.btn-dark:hover{background:var(--ink-deep);transform:translateY(-3px)}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Section primitives ---------- */
.section{padding:var(--pad-sec) 0}
.section-dark{background:var(--ink-deep);color:var(--cream)}
.section-dark h2,.section-dark h3{color:var(--cream)}
.section-paper{background:var(--paper-warm)}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--f-display);font-weight:600;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:1.1rem}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--amber)}
.section-dark .eyebrow{color:var(--amber-light)}
.section-dark .eyebrow::before{background:var(--amber-light)}
.h-sec{font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.02;margin-bottom:1.2rem;max-width:18ch}
.sec-lead{font-size:clamp(1.05rem,1.4vw,1.22rem);color:var(--ink);opacity:.85;max-width:60ch;line-height:1.7}
.section-dark .sec-lead{color:var(--cream-soft);opacity:1}

/* ---------- Stat strip ---------- */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.stat{background:var(--paper);padding:clamp(1.6rem,3vw,2.6rem) 1.4rem;text-align:center}
.section-dark .stat{background:var(--ink)}
.stat .num{font-family:var(--f-mega);font-weight:800;font-size:clamp(2.2rem,5vw,3.6rem);color:var(--amber);line-height:1;font-variant-numeric:tabular-nums}
.stat .lbl{margin-top:.6rem;font-size:.84rem;color:var(--ink);opacity:.7;font-weight:500}
.section-dark .stat .lbl{color:var(--cream-soft);opacity:.9}

/* ---------- Intro split ---------- */
.intro-split{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.intro-split .lead-big{font-family:var(--f-display);font-weight:600;font-size:clamp(1.5rem,2.8vw,2.2rem);line-height:1.25;color:var(--ink);letter-spacing:-.01em}
.intro-split .lead-big .amber{color:var(--amber)}
.intro-split p{margin-top:1.3rem;color:var(--ink);opacity:.82}

/* ================= SPARTEN — BENTO ================= */
.sparten-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,2.5vw,2rem)}
.sparte-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:clamp(440px,55vh,640px);display:flex;align-items:flex-end;color:var(--cream);box-shadow:var(--shadow);isolation:isolate}
.sparte-card .sp-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .9s var(--ease);filter:saturate(.85) brightness(.92);z-index:-2}
.sparte-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(21,24,26,.05) 0%,rgba(21,24,26,.35) 45%,rgba(21,24,26,.9) 100%)}
.sparte-card:hover .sp-img{transform:scale(1.06);filter:saturate(1.05) brightness(1)}
.sparte-inner{position:relative;padding:clamp(1.8rem,3.4vw,2.8rem);z-index:1;width:100%}
.sp-num{font-family:var(--f-display);font-weight:600;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--amber-light)}
.sp-title{font-family:var(--f-mega);font-weight:800;font-size:clamp(1.7rem,3.2vw,2.7rem);line-height:1.02;margin:.7rem 0 .5rem;color:#fff}
.sp-slogan{font-style:italic;color:var(--cream-soft);font-size:1.02rem;margin-bottom:1rem}
.sp-lead{font-size:.94rem;color:var(--cream-soft);line-height:1.6;max-width:46ch;max-height:0;opacity:0;overflow:hidden;transition:max-height .6s var(--ease),opacity .5s var(--ease),margin .5s}
.sparte-card:hover .sp-lead{max-height:200px;opacity:1;margin-bottom:1.1rem}
.sp-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1.2rem}
.sp-tags span{font-size:.74rem;font-weight:500;padding:.32rem .7rem;border-radius:999px;background:rgba(237,230,216,.14);border:1px solid rgba(237,230,216,.22);color:var(--cream)}
.sp-link{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-display);font-weight:600;font-size:.92rem;color:var(--amber-light)}
.sp-link .arrow{transition:transform .25s var(--ease)}
.sparte-card:hover .sp-link .arrow{transform:translateX(5px)}

/* ================= VORHER / NACHHER SLIDER ================= */
.ba-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16/9;max-width:1100px;margin-inline:auto;user-select:none;touch-action:pan-y;cursor:ew-resize;background:var(--ink-black)}
.ba-img{position:absolute;inset:0;background-size:cover;background-position:center}
.ba-after{z-index:1}
.ba-before{z-index:2;clip-path:inset(0 50% 0 0)}
.ba-label{position:absolute;bottom:1.1rem;z-index:3;font-family:var(--f-display);font-weight:600;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:rgba(21,24,26,.7);backdrop-filter:blur(6px);padding:.45rem .9rem;border-radius:999px}
.ba-label.left{left:1.1rem}
.ba-label.right{right:1.1rem;background:rgba(201,138,46,.85)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:4;transform:translateX(-50%);box-shadow:0 0 0 1px rgba(0,0,0,.15)}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px -6px rgba(0,0,0,.5);z-index:5}
.ba-knob svg{width:26px;height:26px;color:var(--ink)}
.ba-range{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:6;margin:0}

/* ================= PROJEKT GALERIE — BENTO ================= */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:clamp(.7rem,1.4vw,1.1rem)}
.gal-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;background:var(--ink);box-shadow:0 14px 30px -20px rgba(21,24,26,.5)}
.gal-item img{width:100%;height:100%;object-fit:cover;filter:grayscale(.55) contrast(1.04);transition:transform .7s var(--ease),filter .7s var(--ease)}
.gal-item:hover img{transform:scale(1.07);filter:grayscale(0) contrast(1.05)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(21,24,26,.78));opacity:.85;transition:opacity .4s}
.gal-item:hover::after{opacity:1}
.gal-cap{position:absolute;left:1rem;bottom:.9rem;z-index:2;color:#fff;transform:translateY(6px);opacity:.92;transition:transform .4s var(--ease)}
.gal-item:hover .gal-cap{transform:translateY(0)}
.gal-cap .cat{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--amber-light);font-weight:600;font-family:var(--f-display)}
.gal-cap .ttl{font-family:var(--f-display);font-weight:600;font-size:1rem}
.gal-item.wide{grid-column:span 2}
.gal-item.tall{grid-row:span 2}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:500;background:rgba(15,18,20,.95);display:none;align-items:center;justify-content:center;padding:clamp(1rem,4vw,3rem);opacity:0;transition:opacity .35s}
.lightbox.open{display:flex;opacity:1}
.lightbox img{max-width:92vw;max-height:82vh;border-radius:10px;box-shadow:var(--shadow-lg);transform:scale(.96);transition:transform .35s var(--ease)}
.lightbox.open img{transform:scale(1)}
.lb-cap{position:absolute;bottom:clamp(1rem,4vw,2.5rem);left:0;right:0;text-align:center;color:var(--cream-soft);font-family:var(--f-display);font-size:.95rem}
.lb-close,.lb-nav{position:absolute;background:rgba(237,230,216,.1);border:1px solid rgba(237,230,216,.2);color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;transition:background .25s}
.lb-close:hover,.lb-nav:hover{background:rgba(201,138,46,.6)}
.lb-close{top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem)}
.lb-nav.prev{left:clamp(.6rem,2vw,2rem);top:50%;transform:translateY(-50%)}
.lb-nav.next{right:clamp(.6rem,2vw,2rem);top:50%;transform:translateY(-50%)}

/* ================= LEISTUNGEN cards ================= */
.leist-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2vw,1.6rem)}
.leist-card{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.leist-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.leist-card .lc-img{width:clamp(120px,16vw,190px);align-self:stretch;background-size:cover;background-position:center;filter:saturate(.92);transition:filter .5s}
.leist-card:hover .lc-img{filter:saturate(1.1)}
.leist-card .lc-body{padding:clamp(1.3rem,2.4vw,1.9rem) clamp(1.3rem,2.4vw,1.9rem) clamp(1.3rem,2.4vw,1.9rem) 0}
.leist-card h3{font-size:clamp(1.2rem,2vw,1.5rem);margin-bottom:.2rem}
.leist-card .slo{font-style:italic;color:var(--amber);font-size:.92rem;margin-bottom:.7rem}
.leist-card p{font-size:.92rem;color:var(--ink);opacity:.82;line-height:1.6}

/* ---------- Bereiche (3-col with image-top) ---------- */
.bereich-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.6rem)}
.bereich-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--paper);border:1px solid var(--line-soft);box-shadow:0 14px 34px -24px rgba(21,24,26,.5);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.bereich-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.bereich-card .bc-img{height:200px;background-size:cover;background-position:center;filter:grayscale(.3) saturate(.95);transition:filter .6s,transform .6s var(--ease)}
.bereich-card:hover .bc-img{filter:grayscale(0) saturate(1.08);transform:scale(1.04)}
.bereich-card .bc-body{padding:clamp(1.3rem,2.4vw,1.8rem)}
.bereich-card h3{font-size:1.4rem;margin-bottom:.15rem}
.bereich-card .slo{font-style:italic;color:var(--amber);font-size:.9rem;margin-bottom:.7rem}
.bereich-card p{font-size:.9rem;opacity:.82;line-height:1.6}

/* ================= BLEED STRIP (cinematic statement) ================= */
.bleed-strip{position:relative;height:clamp(420px,62vh,640px);overflow:hidden;display:flex;align-items:center;color:var(--cream)}
.bleed-strip>img{position:absolute;inset:0;width:100%;height:120%;object-fit:cover;will-change:transform;filter:brightness(.62) saturate(.95)}
.bleed-strip::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(21,24,26,.7),transparent 65%)}
.bleed-inner{position:relative;z-index:2}
.bleed-inner .quote{font-family:var(--f-mega);font-weight:800;font-size:clamp(2rem,5.4vw,4.2rem);line-height:1.02;max-width:18ch;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.bleed-inner .cite{margin-top:1rem;font-family:var(--f-display);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.8rem;color:var(--amber-light)}

/* ================= WERTE (about) ================= */
.werte-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2vw,1.6rem)}
.wert-card{background:var(--ink);border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.4rem);border-left:3px solid var(--amber);transition:transform .4s var(--ease)}
.wert-card:hover{transform:translateY(-4px)}
.wert-card .wt-tag{font-family:var(--f-display);font-weight:600;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber-light)}
.wert-card h3{font-size:1.5rem;color:var(--cream);margin:.5rem 0 .8rem}
.wert-card p{color:var(--cream-soft);font-size:.94rem;line-height:1.65}

.fakten-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-radius:var(--radius-lg);overflow:hidden}
.fakt{background:var(--paper);padding:clamp(1.3rem,2.6vw,2rem)}
.fakt .k{font-family:var(--f-display);font-weight:600;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);margin-bottom:.4rem}
.fakt .v{font-size:1.05rem;color:var(--ink);font-weight:500}

.badge-row{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2rem}
.badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-display);font-weight:600;font-size:.84rem;padding:.6rem 1.1rem;border-radius:999px;background:var(--amber-glow);border:1px solid rgba(201,138,46,.35);color:var(--amber)}
.section-dark .badge{background:rgba(217,155,60,.12);color:var(--amber-light)}
.badge::before{content:"●";font-size:.6rem;color:var(--amber)}

/* ================= SUB-PAGE HERO ================= */
.subhero{position:relative;min-height:62vh;min-height:62svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink-black)}
.subhero .sh-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:kenburns 26s ease-in-out infinite alternate;filter:brightness(.72)}
.subhero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,24,26,.5),rgba(21,24,26,.35) 40%,rgba(21,24,26,.88))}
.subhero .hero-letterbox{height:clamp(20px,4vh,40px)}
.subhero-inner{position:relative;z-index:3;padding:clamp(7rem,12vh,10rem) 0 clamp(2.5rem,6vh,4.5rem);width:100%}
.subhero .hero-eyebrow{margin-bottom:1rem}
.subhero h1{font-family:var(--f-mega);font-weight:800;font-size:clamp(2.4rem,6.5vw,5.4rem);line-height:.98;color:var(--cream);max-width:18ch}
.subhero .sh-sub{margin-top:1.2rem;max-width:54ch;color:var(--cream-soft);font-size:clamp(1rem,1.3vw,1.18rem)}
.breadcrumb{position:absolute;top:clamp(5.5rem,10vh,7rem);z-index:3;font-size:.78rem;color:var(--cream-soft);letter-spacing:.04em}
.breadcrumb a{color:var(--amber-light)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--ink-deep);color:var(--cream);text-align:center;padding:clamp(3.5rem,7vw,6rem) 0}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 80% at 50% 0%,var(--amber-glow),transparent 70%)}
.cta-band .inner{position:relative;z-index:2}
.cta-band h2{font-size:clamp(1.9rem,4.4vw,3.4rem);margin-bottom:1rem;color:#fff}
.cta-band p{max-width:50ch;margin:0 auto 2rem;color:var(--cream-soft)}
.cta-band .hero-actions{justify-content:center;animation:none;opacity:1}

/* ---------- Contact layout ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3.5rem);align-items:start}
.contact-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:clamp(1.8rem,3.5vw,2.8rem);box-shadow:var(--shadow)}
.contact-line{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--line-soft);align-items:flex-start}
.contact-line:last-child{border-bottom:none}
.contact-line .ci{flex-shrink:0;width:42px;height:42px;border-radius:11px;background:var(--amber-glow);display:flex;align-items:center;justify-content:center;color:var(--amber)}
.contact-line .ci svg{width:20px;height:20px}
.contact-line .ck{font-family:var(--f-display);font-weight:600;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);opacity:.6}
.contact-line .cv{font-size:1.08rem;font-weight:500;color:var(--ink)}
.contact-line .cv a:hover{color:var(--amber)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--f-display);font-weight:600;font-size:.8rem;color:var(--ink);margin-bottom:.4rem}
.field input,.field textarea,.field select{width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:10px;background:#fff;font-family:var(--f-body);font-size:.98rem;color:var(--ink);transition:border-color .25s,box-shadow .25s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-glow)}
.field.two{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.einzug-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.einzug-tags span{font-size:.82rem;padding:.4rem .85rem;border-radius:999px;background:var(--paper-warm);border:1px solid var(--line-soft);color:var(--ink)}

/* ---------- Legal pages ---------- */
.legal{max-width:760px;margin-inline:auto;padding:clamp(7rem,12vh,9rem) clamp(1.2rem,4vw,2.4rem) 4rem}
.legal h1{font-size:clamp(2rem,5vw,3.2rem);margin-bottom:1.5rem}
.legal h2{font-size:1.3rem;margin:2.2rem 0 .8rem;color:var(--amber)}
.legal p,.legal li{color:var(--ink);opacity:.86;margin-bottom:.7rem;font-size:.96rem;line-height:1.7}
.legal ul{padding-left:1.2rem}
.legal .demo-banner{background:var(--amber-glow);border:1px solid rgba(201,138,46,.35);border-radius:var(--radius);padding:1.2rem 1.4rem;margin-bottom:2rem;font-size:.92rem;color:var(--ink)}
.legal a{color:var(--amber);text-decoration:underline}

/* ================= RESPONSIVE ================= */
@media (max-width:980px){
  .sparten-grid{grid-template-columns:1fr}
  .sparte-card .sp-lead{max-height:200px;opacity:1;margin-bottom:1rem}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .leist-grid,.werte-grid{grid-template-columns:1fr}
  .bereich-grid{grid-template-columns:1fr}
  .fakten-grid{grid-template-columns:1fr 1fr}
  .intro-split{grid-template-columns:1fr;gap:1.6rem}
  .contact-grid{grid-template-columns:1fr}
  .stat-strip{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .gallery{grid-template-columns:1fr;grid-auto-rows:200px}
  .gal-item.wide,.gal-item.tall{grid-column:auto;grid-row:auto}
  .leist-card{grid-template-columns:1fr}
  .leist-card .lc-img{width:100%;height:180px}
  .leist-card .lc-body{padding:1.3rem}
  .fakten-grid{grid-template-columns:1fr}
  .field.two{grid-template-columns:1fr}
  .ba-wrap{aspect-ratio:4/5}
  .hero-title{max-width:none}
}
