:root{
    --accent:#61993b;        /* RAL 6018 Gelbgrün – sparsam */
    --accent-dark:#4e7d2f;
    --iron:#52595d;          /* RAL 7011 Eisengrau */
    --iron-light:#6b747a;
    --dark:#1a1a1a;
    --darker:#111111;
    --white:#ffffff;
    --gray-bg:#f5f6f8;
    --gray-line:#e4e7ea;
    --text:#3a4045;
    --head:'Archivo','Helvetica Neue',Arial,sans-serif;
    --body:'Inter','Helvetica Neue',Arial,sans-serif;
    --r:8px;
    --t:.25s ease;
  }
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--body);color:var(--text);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased}
  img{max-width:100%;height:auto;display:block}
  a{color:inherit;text-decoration:none}
  ul{list-style:none}
  h1,h2,h3,h4{font-family:var(--head);color:var(--dark);line-height:1.12;font-weight:800;letter-spacing:-.01em}
  h1{font-size:clamp(2.1rem,4.6vw,3.5rem)}
  h2{font-size:clamp(1.7rem,3vw,2.4rem)}
  h3{font-size:1.12rem}
  p{margin-bottom:1rem}
  p:last-child{margin-bottom:0}
  .container{max-width:1180px;margin:0 auto;padding:0 24px}
  .section{padding:84px 0}
  .label{font-family:var(--head);display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:.8rem}
  .lead{font-size:1.06rem;color:var(--iron)}

  /* buttons */
  .btn{font-family:var(--head);display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:var(--r);font-size:.82rem;font-weight:700;letter-spacing:.04em;transition:all var(--t);border:2px solid transparent;cursor:pointer}
  .btn--primary{background:var(--accent);color:#fff}
  .btn--primary:hover{background:var(--accent-dark);transform:translateY(-2px)}
  .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
  .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
  .btn--dark{background:transparent;color:var(--dark);border-color:var(--iron)}
  .btn--dark:hover{background:var(--dark);color:#fff;border-color:var(--dark)}

  /* header */
  .site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .3s ease}
  .site-header.scrolled{background:rgba(17,17,17,.95);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.06)}
  .header-inner{display:flex;align-items:center;justify-content:space-between;height:66px;max-width:1180px;margin:0 auto;padding:0 24px}
  .logo{font-family:var(--head);font-weight:800;font-size:1.05rem;letter-spacing:.02em;color:#fff;line-height:1.1}
  .logo span{display:block;font-family:var(--body);font-size:.58rem;font-weight:400;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:2px}
  .nav{display:flex;align-items:center;gap:26px}
  .nav a{font-family:var(--head);color:rgba(255,255,255,.8);font-size:.82rem;font-weight:600;letter-spacing:.03em;transition:color var(--t)}
  .nav a:hover{color:#fff}
  .nav .cta{background:var(--accent);color:#fff;padding:8px 16px;border-radius:var(--r)}
  .nav .cta:hover{background:var(--accent-dark)}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
  .burger span{width:24px;height:2px;background:#fff;border-radius:2px}

  /* hero */
  .hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--darker)}
  .hero-bg{position:absolute;inset:0}
  .hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.55}
  .hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(17,17,17,.55) 0%,rgba(17,17,17,.35) 45%,rgba(17,17,17,.96) 100%)}
  .hero-inner{position:relative;z-index:1;width:100%;padding:0 24px 72px;max-width:1180px;margin:0 auto}
  .crumb{font-size:.78rem;color:rgba(255,255,255,.5);margin-bottom:18px}
  .crumb a{color:var(--accent)}
  .hero h1{color:#fff;max-width:16ch;margin-bottom:18px}
  .hero p{color:rgba(255,255,255,.78);max-width:60ch;font-size:1.08rem;margin-bottom:30px}
  .chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px}
  .chip{font-family:var(--head);display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:100px;padding:6px 14px;font-size:.72rem;font-weight:600;color:#fff}
  .chip::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent)}
  .hero-actions{display:flex;gap:12px;flex-wrap:wrap}

  /* intro */
  .intro h2{margin-bottom:18px;max-width:20ch}
  .intro-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center}
  .intro-img{border-radius:12px;overflow:hidden;aspect-ratio:4/3;background:var(--gray-bg)}
  .intro-img img{width:100%;height:100%;object-fit:cover}

  /* leistungen */
  .grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .card{background:#fff;border:1px solid var(--gray-line);border-radius:12px;overflow:hidden;transition:all var(--t)}
  .card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(26,26,26,.09)}
  .card-img{aspect-ratio:16/10;overflow:hidden;background:var(--gray-bg)}
  .card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
  .card:hover .card-img img{transform:scale(1.04)}
  .card-body{padding:22px}
  .card h3{margin-bottom:7px}
  .card p{font-size:.9rem;color:var(--iron)}

  /* gallery */
  .gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:12px}
  .gal figure{overflow:hidden;border-radius:10px;background:var(--gray-bg)}
  .gal img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
  .gal figure:hover img{transform:scale(1.05)}
  .gal .big{grid-column:span 2;grid-row:span 2}
  .gal .wide{grid-column:span 2}

  /* trust */
  .trust{background:var(--gray-bg)}
  .trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .trust-item{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--gray-line);border-left:3px solid var(--accent);border-radius:10px;padding:20px}
  .trust-item .ic{font-size:1.2rem;line-height:1}
  .trust-item strong{font-family:var(--head);display:block;color:var(--dark);font-size:.95rem;margin-bottom:3px}
  .trust-item span{font-size:.86rem;color:var(--iron)}

  /* cta */
  .cta{background:linear-gradient(135deg,#1a1a1a,#0f1a0a);text-align:center;position:relative;overflow:hidden}
  .cta-in{position:relative;z-index:1;max-width:680px;margin:0 auto}
  .cta h2{color:#fff;margin-bottom:14px}
  .cta p{color:rgba(255,255,255,.65);font-size:1.05rem;margin-bottom:30px}
  .cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
  .cta-info{display:flex;gap:30px;justify-content:center;flex-wrap:wrap;margin-top:36px;padding-top:26px;border-top:1px solid rgba(255,255,255,.1);font-size:.88rem;color:rgba(255,255,255,.6)}
  .cta-info a{color:rgba(255,255,255,.8)}
  .cta-info a:hover{color:var(--accent)}

  /* footer */
  .foot{background:#0a0a0a;color:rgba(255,255,255,.5);padding:60px 0 26px;font-size:.88rem}
  .foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:44px;margin-bottom:40px}
  .foot h4{font-family:var(--head);color:#fff;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px}
  .foot a{color:rgba(255,255,255,.5)}
  .foot a:hover{color:var(--accent)}
  .foot li{margin-bottom:9px}
  .foot-brand{font-family:var(--head);font-weight:800;color:#fff;font-size:1rem}
  .foot-brand span{display:block;font-family:var(--body);font-size:.6rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:2px}
  .foot-bottom{border-top:1px solid #222;padding-top:20px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.78rem;color:rgba(255,255,255,.3)}

  @media(max-width:900px){
    .intro-grid{grid-template-columns:1fr;gap:32px}
    .grid3{grid-template-columns:repeat(2,1fr)}
    .trust-grid{grid-template-columns:1fr 1fr}
    .gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
    .gal .big{grid-column:span 2;grid-row:span 1}
    .foot-grid{grid-template-columns:1fr 1fr}
  }
  @media(max-width:600px){
    .section{padding:56px 0}
    .nav{display:none}
    .nav.open{display:flex;flex-direction:column;position:fixed;inset:0;background:var(--darker);justify-content:center;align-items:center;gap:28px}
    .nav.open a{font-size:1.3rem}
    .burger{display:flex}
    .grid3,.trust-grid{grid-template-columns:1fr}
    .gal{grid-template-columns:1fr 1fr}
    .foot-grid{grid-template-columns:1fr}
  }

/* ============ Startseiten-Bausteine ============ */
.block{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.block .txt h2{margin-bottom:16px}
.block-img{border-radius:12px;overflow:hidden;aspect-ratio:4/3;background:var(--gray-bg)}
.block-img img{width:100%;height:100%;object-fit:cover}
.block-imgs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.block-imgs figure{border-radius:10px;overflow:hidden;aspect-ratio:1;background:var(--gray-bg)}
.block-imgs img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.block-imgs figure:hover img{transform:scale(1.05)}
@media(max-width:900px){.block{grid-template-columns:1fr;gap:30px}.block.reverse .txt{order:2}}

.bullets{display:flex;flex-direction:column;gap:12px;margin:22px 0 28px}
.bullets li{display:flex;gap:12px;align-items:flex-start;font-size:.92rem;color:var(--iron)}
.bullets .b{width:30px;height:30px;flex-shrink:0;background:rgba(97,153,59,.1);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:1rem}
.bullets b{font-family:var(--head);color:var(--dark)}

/* statistik */
.stats{display:flex;gap:44px;flex-wrap:wrap;padding-top:28px;border-top:1px solid rgba(255,255,255,.1)}
.stats .n{font-family:var(--head);display:block;font-size:1.7rem;font-weight:900;color:var(--accent)}
.stats .l{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.5)}

/* teaser / banner */
.teaser{background:linear-gradient(100deg,#0f1a0a,#1a1a1a);border-top:1px solid rgba(97,153,59,.3);border-bottom:1px solid rgba(97,153,59,.3)}
.teaser-in{display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap;padding:26px 0}
.teaser h3{color:#fff;font-size:1.15rem;margin-bottom:4px}
.teaser p{color:rgba(255,255,255,.6);font-size:.9rem;margin:0}
.teaser .date{font-family:var(--head);color:var(--accent);font-weight:700}

/* kompetenz-block karten gross */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.duo .panel{position:relative;border-radius:14px;overflow:hidden;min-height:420px;display:flex;align-items:flex-end;color:#fff}
.duo .panel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.duo .panel::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(17,17,17,.15),rgba(17,17,17,.9))}
.duo .panel-in{position:relative;z-index:1;padding:30px}
.duo .panel h3{color:#fff;font-size:1.4rem;margin-bottom:8px}
.duo .panel p{color:rgba(255,255,255,.8);font-size:.92rem;margin-bottom:16px}
.duo .panel .more{font-family:var(--head);font-weight:700;font-size:.82rem;color:#fff;display:inline-flex;gap:6px;border-bottom:2px solid var(--accent);padding-bottom:2px}
@media(max-width:768px){.duo{grid-template-columns:1fr}.duo .panel{min-height:340px}}

/* ============ Formular ============ */
.form{display:grid;gap:18px;max-width:660px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:var(--head);font-size:.82rem;font-weight:600;color:var(--dark)}
.field input,.field select,.field textarea{font-family:var(--body);font-size:.95rem;color:var(--dark);background:#fff;border:1px solid var(--gray-line);border-radius:var(--r);padding:12px 14px;transition:border-color var(--t)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{min-height:140px;resize:vertical}
.check{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--iron)}
.check input{margin-top:3px;width:16px;height:16px;accent-color:var(--accent);flex-shrink:0}
.check a{color:var(--accent);text-decoration:underline}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.8rem;color:var(--iron-light);margin-top:4px}
@media(max-width:600px){.form .row{grid-template-columns:1fr}}

/* ============ einfache Inhaltsseite (Recht) ============ */
.doc{padding:130px 0 80px;background:#fff;min-height:60vh}
.doc .container{max-width:820px}
.doc h1{font-size:2rem;margin-bottom:8px}
.doc .sub{color:var(--iron);font-size:.92rem;margin-bottom:40px}
.doc section{border-top:1px solid var(--gray-line);padding:22px 0}
.doc h2{font-size:.82rem;font-family:var(--head);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;color:var(--dark)}
.doc p{font-size:.92rem;color:var(--iron);line-height:1.75}
.doc a{color:var(--accent)}
.note-box{background:#fff8e6;border:1px solid #f0e0a8;border-radius:10px;padding:14px 18px;font-size:.85rem;color:#7a6a2f;margin-bottom:28px}

/* contact split */
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:56px;align-items:start}
.contact-card{background:var(--gray-bg);border:1px solid var(--gray-line);border-radius:12px;padding:26px}
.contact-card h3{margin-bottom:14px}
.contact-card .line{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;font-size:.92rem;color:var(--iron)}
.contact-card a{color:var(--dark)}
.contact-card a:hover{color:var(--accent)}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:32px}}

/* page hero (kompakter als start-hero) */
.phero{position:relative;padding:150px 0 70px;background:var(--darker);overflow:hidden}
.phero .bg{position:absolute;inset:0}
.phero .bg img{width:100%;height:100%;object-fit:cover;opacity:.4}
.phero .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(17,17,17,.96) 40%,rgba(17,17,17,.55))}
.phero .in{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:0 24px}
.phero h1{color:#fff;max-width:18ch;margin-bottom:16px}
.phero p{color:rgba(255,255,255,.75);max-width:60ch;font-size:1.05rem}
.phero .crumb{font-size:.78rem;color:rgba(255,255,255,.5);margin-bottom:16px}
.phero .crumb a{color:var(--accent)}

/* aktiver Menüpunkt */
.nav a.active{color:var(--accent)}
