/* Stay Awesome — Bürgschafts-Pitch. Solar-Punk-Look, Platzhalter-Palette.
   Brand-Farben bei Asset-Lieferung in :root + content.go anpassen. */
:root{
  --accent:#2f7d52;
  --accent-dark:#1f5638;
  --ink:#16241c;
  --muted:#5c6b62;
  --bg:#fbfaf5;
  --bg-alt:#eef2ec;
  --card:#ffffff;
  --line:#dfe5de;
  --radius:16px;
  --maxw:1040px;
  font-synthesis:none;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background:var(--bg);
  font-family:"Work Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-weight:700}
.hero h1{font-weight:800}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3{line-height:1.15;letter-spacing:-.01em}
h2{font-size:clamp(1.5rem,3.2vw,2.2rem);margin:0 0 .3em}
p{margin:.5em 0}
a{color:var(--accent-dark)}

/* Header */
.site-head{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:10}
.head-inner{display:flex;align-items:center;gap:16px;height:60px}
.logo{font-weight:800;font-size:1.15rem;color:var(--accent-dark)}
.claim{color:var(--muted);font-size:.9rem}

/* Hero */
.hero{padding:72px 0 56px;background:linear-gradient(160deg,#fff,var(--bg-alt))}
.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:700;color:var(--accent);margin:0 0 12px}
.hero h1{font-size:clamp(2rem,5.2vw,3.4rem);margin:0 0 .35em;max-width:18ch}
.lead{font-size:1.15rem;color:var(--muted);max-width:62ch}
.checks{list-style:none;padding:0;margin:24px 0;display:grid;gap:10px;max-width:60ch}
.checks li{padding-left:30px;position:relative}
.checks li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:800}

/* Buttons */
.btn{display:inline-block;background:var(--accent);color:#fff;text-decoration:none;
  padding:13px 24px;border-radius:999px;font-weight:700;border:0;cursor:pointer;font-size:1rem;margin:8px 8px 0 0}
.btn:hover{background:var(--accent-dark)}
.btn.ghost{background:transparent;color:var(--accent-dark);box-shadow:inset 0 0 0 2px var(--accent)}
.btn.big{padding:16px 34px;font-size:1.1rem}

/* Bands */
.band{padding:64px 0;border-top:1px solid var(--line)}
.band.alt{background:var(--bg-alt)}
.section-lead{font-size:1.1rem;color:var(--muted);max-width:60ch;margin-bottom:32px}

/* Flow / steps */
.flow{list-style:none;counter-reset:s;padding:0;margin:0;display:grid;gap:20px;grid-template-columns:repeat(4,1fr)}
.flow.four{grid-template-columns:repeat(4,1fr)}
.flow li{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.flow .num{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;
  background:var(--accent);color:#fff;font-weight:800;margin-bottom:10px}
.flow h3{margin:.2em 0;font-size:1.05rem}
.flow p{color:var(--muted);font-size:.95rem;margin:0}

/* Cards */
.cards{display:grid;gap:20px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.cards.two{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.card h3{margin:0 0 .4em;font-size:1.1rem}
.card p{color:var(--muted);margin:0}

/* Calculator */
.calc{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.calc-controls label{display:block;font-weight:700;margin-bottom:8px}
.calc-controls output{float:right;color:var(--accent-dark);font-size:1.3rem;font-weight:800}
#calc-range{width:100%;accent-color:var(--accent);height:6px}
.calc-laufzeit{margin-top:18px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.calc-laufzeit span{color:var(--muted);font-size:.9rem}
.lz{border:2px solid var(--line);background:#fff;border-radius:999px;padding:7px 16px;cursor:pointer;font-weight:600}
.lz.active{border-color:var(--accent);background:var(--accent);color:#fff}
.calc-out{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:26px}
.calc-card{border:1px solid var(--line);border-radius:var(--radius);padding:20px;text-align:center}
.calc-card.highlight{background:var(--accent);color:#fff;border-color:var(--accent)}
.calc-label{display:block;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;opacity:.85}
.calc-value{display:block;font-size:1.9rem;font-weight:800;margin:6px 0 2px}
.calc-sub{display:block;font-size:.82rem;opacity:.8}
.note{color:var(--muted);font-size:.85rem;margin-top:16px}

/* Gate */
.gate{background:var(--card);border:2px dashed var(--accent);border-radius:var(--radius);padding:32px;text-align:center}
.gate-lead{font-size:1.05rem;max-width:52ch;margin:0 auto 18px}
.gate-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.gate-form input{padding:13px 16px;border:1px solid var(--line);border-radius:999px;min-width:260px;font-size:1rem}
.gate-error{color:#b3261e;font-weight:600}

/* Haus grid (unlocked) */
.haus-grid{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.haus-row{display:grid;grid-template-columns:220px 1fr;gap:16px;padding:14px 22px;border-bottom:1px solid var(--line)}
.haus-row:last-child{border-bottom:0}
.haus-row span{color:var(--muted)}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center}
.kpi-val{display:block;font-size:1.7rem;font-weight:800;color:var(--accent-dark)}
.kpi-lab{display:block;color:var(--muted);font-size:.85rem;margin-top:4px}

/* Impact */
.band.impact{background:linear-gradient(160deg,var(--accent-dark),var(--accent));color:#fff}
.band.impact h2,.band.impact .lead{color:#fff}
.band.impact .lead{opacity:.95}
.tags{margin-top:20px;display:flex;gap:10px;flex-wrap:wrap}
.tag{background:rgba(255,255,255,.18);padding:7px 16px;border-radius:999px;font-size:.9rem}

/* CTA */
.band.cta{text-align:center;background:var(--bg-alt)}

/* Footer */
.site-foot{padding:28px 0;border-top:1px solid var(--line);background:#fff}
.site-foot .wrap{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;color:var(--muted);font-size:.85rem}

/* Responsive */
@media(max-width:860px){
  .flow,.flow.four,.cards.three,.cards.two,.calc-out{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(3,1fr)}
  .haus-row{grid-template-columns:1fr;gap:2px}
}

/* ---------- One-Pager (print) ---------- */
.onepager{background:#fff}
.op-sheet{max-width:820px;margin:0 auto;padding:32px}
.op-head{display:flex;justify-content:space-between;align-items:center;border-bottom:3px solid var(--accent);padding-bottom:12px;margin-bottom:18px}
.op-head .claim{margin-left:12px}
.op-tag{background:var(--accent);color:#fff;padding:5px 14px;border-radius:999px;font-size:.8rem;font-weight:700}
.op-h1{font-size:1.7rem;margin:.2em 0}
.op-sub{color:var(--muted);font-size:.95rem;margin:0 0 18px}
.op-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:18px}
.op-box h2{font-size:1.05rem;color:var(--accent-dark);border-bottom:1px solid var(--line);padding-bottom:4px;margin:0 0 8px}
.op-list{margin:0;padding-left:18px;font-size:.85rem;color:#2a3a31}
.op-list li{margin-bottom:6px}
.op-table{width:100%;border-collapse:collapse;font-size:.85rem}
.op-table td{padding:5px 6px;border-bottom:1px solid var(--line)}
.op-table td:first-child{color:var(--muted);width:42%}
.op-kpis{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;background:var(--bg-alt);border-radius:12px;padding:14px 18px;margin-bottom:16px;font-size:.85rem}
.op-kpis strong{color:var(--accent-dark);font-size:1.2rem;display:inline-block;margin-right:4px}
.op-foot{font-size:.78rem;color:var(--muted);border-top:1px solid var(--line);padding-top:10px;display:grid;gap:6px}
.op-foot .disclaimer{font-size:.7rem}
@media print{
  @page{margin:14mm}
  .op-sheet{padding:0;max-width:none}
  body{font-size:11pt}
}
.disclaimer{color:var(--muted)}

/* ===== Politur / Münster-Layout ===== */
.head-cta{margin-left:auto;background:var(--accent);color:#fff;text-decoration:none;padding:8px 18px;border-radius:999px;font-weight:700;font-size:.9rem}
.head-cta:hover{background:var(--accent-dark)}

/* Hero zweispaltig + Deal-Karte */
.hero{position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-160px;top:-160px;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle at center,rgba(47,125,82,.16),transparent 70%);pointer-events:none}
.hero-inner{display:grid;grid-template-columns:1.25fr 1fr;gap:48px;align-items:center;position:relative;z-index:1}
.hero-btns{margin-top:8px}
.hero-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;
  box-shadow:0 24px 60px -28px rgba(22,36,28,.35)}
.hero-card-eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:700;color:var(--muted)}
.hero-card-big{display:flex;align-items:baseline;gap:10px;margin:10px 0 18px;flex-wrap:wrap}
.hero-card-big strong{font-size:3rem;line-height:1;color:var(--accent-dark);font-weight:800}
.hero-card-big span{color:var(--muted);font-size:.9rem}
.hero-card dl{margin:0;display:grid;gap:10px}
.hero-card dl div{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:10px}
.hero-card dt{color:var(--muted);font-size:.9rem}
.hero-card dd{margin:0;font-weight:700}

/* Deal-Facts-Streifen */
.band.deal{padding:0;border-top:0}
.band.deal .wrap{transform:translateY(-32px)}
.facts{display:grid;grid-template-columns:repeat(6,1fr);gap:0;background:var(--accent-dark);
  border-radius:18px;overflow:hidden;box-shadow:0 20px 50px -30px rgba(22,36,28,.5)}
.fact{padding:20px 18px;border-right:1px solid rgba(255,255,255,.12);color:#fff}
.fact:last-child{border-right:0}
.fact-label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;opacity:.7}
.fact-value{display:block;font-size:1.5rem;font-weight:800;margin:4px 0 2px}
.fact-hint{display:block;font-size:.74rem;opacity:.8;line-height:1.35}

.kpi-val.small{font-size:1.15rem}

/* One-Pager Facts */
.op-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:var(--bg-alt);border-radius:12px;padding:14px;margin:0 0 18px}
.op-facts span{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.op-facts strong{font-size:1.1rem;color:var(--accent-dark)}

/* Rechte Hero-Spalte: Bild gestapelt über der Deal-Karte */
.hero-side{display:grid;gap:18px;align-content:center}
.hero-photo{border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 20px 50px -30px rgba(22,36,28,.4)}
.hero-photo img{display:block;width:100%;height:clamp(300px,32vw,400px);object-fit:cover;object-position:center bottom}

/* Lage / Karte */
.lage-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:28px;align-items:stretch}
.lage-list{list-style:none;margin:0;padding:0;display:grid;gap:14px;align-content:center}
.lage-list li{position:relative;padding-left:34px;font-size:1.05rem;font-weight:600}
.lage-list li::before{content:"📍";position:absolute;left:0;top:0}
.map{border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:0 18px 44px -30px rgba(22,36,28,.4);min-height:380px}
.map iframe{display:block;width:100%;height:100%;min-height:380px;border:0}

/* Logo + Riviera-Akzente */
.logo-img{height:34px;width:auto;display:block}
.hero-card-big strong{color:var(--riviera)}
.checks li::before{color:var(--riviera)}
.kpi-val{color:var(--accent)}

/* Foto/Video-Banner */
.banner{position:relative;overflow:hidden;color:#fff;padding:96px 0;text-align:center;border-top:1px solid var(--line);min-height:320px;display:flex;align-items:center}
.banner-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.banner-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(12,78,68,.25),rgba(12,78,68,.7))}
.banner-content{position:relative;z-index:2;width:100%}
.banner-claim{font-size:clamp(1.6rem,4vw,2.6rem);font-weight:800;margin:0;text-shadow:0 2px 18px rgba(0,0,0,.4)}
.banner-sub{font-size:1.05rem;opacity:.95;margin:.4em 0 0;text-shadow:0 1px 10px rgba(0,0,0,.4)}

/* Galerie */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery figure{margin:0;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:0 14px 36px -26px rgba(22,36,28,.4)}
.gallery img{display:block;width:100%;height:200px;object-fit:cover}
.gallery figcaption{padding:12px 14px;font-size:.85rem;color:var(--muted);font-weight:600}
.demo-note{display:inline-block;background:#fff7e6;border:1px solid #f0d9a8;color:#7a5a12;padding:8px 14px;border-radius:10px;margin-top:18px}

@media(max-width:860px){
  .hero-inner{grid-template-columns:1fr;gap:28px}
  .hero-card-big strong{font-size:2.4rem}
  .facts{grid-template-columns:repeat(2,1fr)}
  .fact{border-right:0;border-bottom:1px solid rgba(255,255,255,.12)}
  .op-facts{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .lage-grid{grid-template-columns:1fr}
}
