/* ===========================================================
   Reputano — Prototyp Styles
   Platzhalter-Marke. Farben/Name leicht austauschbar.
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@600;700&display=swap');

:root {
  --bg:        #f5eede;   /* warmes Papier-Creme */
  --bg-soft:   #ede3d0;
  --ink:       #251d12;   /* warmes Dunkelbraun statt kaltem Grün-Schwarz */
  --ink-soft:  #6c5d4c;
  --green:     #1c5e3b;
  --green-dk:  #123c27;
  --gold:      #d6982a;
  --gold-soft: #f4e4be;
  --terra:     #c45a36;   /* Terrakotta-Akzent für Leben */
  --line:      #e5dac4;
  --white:     #ffffff;
  --red:       #bb4630;
  --shadow:    0 16px 38px -20px rgba(40, 28, 12, .32);
  --radius:    18px;
  --maxw:      1120px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(214,152,42,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(28,94,59,.07), transparent 55%),
    var(--bg);
  line-height: 1.62;
  -webkit-font-smoothing: antialiased;
}

/* feine Papier-Körnung über allem — nimmt den flachen, sterilen Look */
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 9999; opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* kein horizontaler Überlauf durch gekippte Elemente (wichtig mobil) */
html, body { overflow-x: clip; max-width: 100%; }

h1, h2, h3 { font-family: "Fraunces", Georgia, serif; line-height: 1.12; letter-spacing: -0.01em; }

a { color: inherit; text-decoration: none; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  color: var(--green); background: var(--gold-soft);
  padding: 7px 15px; border-radius: 999px; border: 1.5px solid rgba(28,94,59,.18);
  transform: rotate(-1deg);
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 600; font-size: 15px; letter-spacing: .005em;
  padding: 14px 24px; border-radius: 999px;
  border: 1px solid transparent; cursor: pointer; transition: transform .12s ease, box-shadow .12s ease, background .18s ease;
}
.btn-primary { background: var(--green); color: #fff; box-shadow: 0 4px 0 0 #0e3120, 0 14px 24px -14px rgba(18,60,39,.6); }
.btn-primary:hover { background: #1a6840; transform: translateY(-2px); box-shadow: 0 6px 0 0 #0e3120, 0 18px 28px -14px rgba(18,60,39,.6); }
.btn-primary:active { transform: translateY(2px); box-shadow: 0 1px 0 0 #0e3120; }
.btn-ghost { background: rgba(255,255,255,.6); color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--green); color: var(--green); transform: translateY(-1px); }
.btn-gold { background: var(--gold); color: #3a2c08; box-shadow: 0 4px 0 0 #ab7818, 0 14px 24px -14px rgba(171,120,24,.6); }
.btn-gold:hover { transform: translateY(-2px); box-shadow: 0 6px 0 0 #ab7818, 0 18px 28px -14px rgba(171,120,24,.6); }
.btn-gold:active { transform: translateY(2px); box-shadow: 0 1px 0 0 #ab7818; }

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: #fffdf8;
  border-bottom: 1px solid var(--line);
  box-shadow: 0 6px 20px -16px rgba(40,28,12,.4);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 84px; }
.nav .btn-primary { padding: 12px 22px; box-shadow: 0 3px 0 0 #0e3120; }
.nav .btn-primary:hover { transform: translateY(-1px); box-shadow: 0 4px 0 0 #0e3120; }
.logo { display: flex; align-items: center; gap: 11px; font-family: "Fraunces", serif; font-weight: 600; font-size: 23px; letter-spacing: -.02em; }
.nav .logo { margin-left: -2px; }   /* Logo-Position im Header */
.logo .star {
  display: inline-grid; place-items: center; width: 34px; height: 34px;
  border-radius: 11px; background: var(--gold); color: var(--green-dk);
  font-size: 17px; transform: rotate(-5deg);
  box-shadow: 0 3px 0 0 rgba(120,84,16,.5);
}
.nav-links { display: flex; gap: 30px; align-items: center; }
.nav-links a { font-size: 15px; color: var(--ink-soft); font-weight: 500; }
.nav-links a:hover { color: var(--green); }
.nav-links a.btn-primary, .nav-links a.btn-primary:hover { color: #fff; }

/* Hamburger (nur mobil sichtbar) */
.hamburger { display: none; background: none; border: none; cursor: pointer;
  width: 44px; height: 44px; flex-direction: column; justify-content: center; gap: 5px; padding: 10px; }
.hamburger span { display: block; height: 2.5px; width: 100%; background: var(--ink); border-radius: 2px; transition: .22s ease; }
.hamburger.open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

@media (max-width: 820px) {
  .nav-inner { position: relative; }
  .hamburger { display: flex; }
  .nav-cta { margin-left: auto; margin-right: 8px; }   /* so weit rechts wie möglich, Logo+Name bleibt links */
  .nav-links {
    position: absolute; top: calc(100% + 1px); left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: #fffdf8; border-bottom: 1px solid var(--line);
    box-shadow: 0 22px 30px -18px rgba(40,28,12,.4);
    padding: 6px 0; display: none;
  }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 15px 24px; font-size: 16px; color: var(--ink); }
  .nav-links a:hover { background: var(--bg-soft); color: var(--green); }
}

/* ---------- Hero ---------- */
.hero { padding: 72px 0 40px; position: relative; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .hero-grid { grid-template-columns: 1fr; gap: 36px; } }
.hero h1 { font-size: clamp(38px, 5vw, 60px); font-weight: 600; margin: 20px 0 18px; }
.hero h1 .hl {
  color: var(--ink);
  background-image: linear-gradient(118deg, rgba(214,152,42,0) 0%, rgba(214,152,42,.42) 6%, rgba(214,152,42,.55) 94%, rgba(214,152,42,0) 100%);
  background-repeat: no-repeat;
  background-size: 100% 40%;
  background-position: 0 82%;
  padding: 0 4px; margin: 0 -2px;
}
.hero h1 .hl:nth-of-type(2) {
  background-image: linear-gradient(118deg, rgba(196,90,54,0) 0%, rgba(196,90,54,.32) 6%, rgba(196,90,54,.42) 94%, rgba(196,90,54,0) 100%);
}
.hero p.lead { font-size: 19px; color: var(--ink-soft); max-width: 540px; margin-bottom: 30px; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 26px; }
.hero-trust { display: flex; align-items: center; gap: 14px; font-size: 14px; color: var(--ink-soft); }
.hero-trust .stars { color: var(--gold); letter-spacing: 2px; }

/* Hero card (fake Google card) */
.gcard {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 24px; max-width: 420px; margin-left: auto;
}
.gcard-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.gcard-rest { display: flex; align-items: center; gap: 12px; }
.gcard-logo { width: 44px; height: 44px; border-radius: 12px; background: var(--green); color:#fff; display:grid; place-items:center; font-family:"Fraunces",serif; font-size:20px; }
.gcard-rating { text-align: right; }
.gcard-rating b { font-size: 26px; font-family: "Fraunces", serif; }
.gcard-rating .stars { color: var(--gold); font-size: 14px; letter-spacing: 1px; }
.review-row { display: flex; gap: 12px; padding: 12px 0; border-top: 1px solid var(--line); }
.review-av { width: 34px; height: 34px; border-radius: 50%; flex: none; display:grid; place-items:center; font-size:13px; font-weight:600; color:#fff; }
.review-body { font-size: 13.5px; }
.review-body .name { font-weight: 600; }
.review-body .txt { color: var(--ink-soft); }
.tag { font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 999px; display:inline-block; }
.tag-deleted { background: #fbe9e4; color: var(--red); }
.tag-new { background: var(--gold-soft); color: #8a6a14; }
.tag-live { background: #e3f1e9; color: var(--green); }
.strike { text-decoration: line-through; opacity: .55; }

/* ---------- Sections ---------- */
section.block { padding: 76px 0; }
.section-head { text-align: left; max-width: 720px; margin: 0 0 44px; }
.section-head h2 { font-size: clamp(28px, 3.6vw, 44px); font-weight: 600; margin: 16px 0 14px; }
.section-head h2::after {
  content: ""; display: block; width: 56px; height: 7px; margin-top: 16px; border-radius: 6px;
  background: var(--gold); transform: rotate(-1.2deg);
  box-shadow: 14px 3px 0 -1px var(--terra);
}
.section-head p { font-size: 18px; color: var(--ink-soft); }

.bg-soft { background: #fffdf8; box-shadow: inset 0 1px 0 var(--line), inset 0 -1px 0 var(--line); }
.bg-dark { background: var(--green-dk); color: #f3efe6; }
.bg-dark .section-head p { color: #c4d3c9; }
.bg-dark .eyebrow { background: rgba(224,169,59,.18); color: var(--gold); }

/* Gallery band */
.gallery-band { padding: 8px 0 8px; }
.gallery { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; padding:10px 0; }
.g-img { height:200px; border-radius:14px; background-size:cover; background-position:center;
  box-shadow:var(--shadow); border:5px solid #fff; transition:transform .28s ease, box-shadow .28s ease; }
.g-img:nth-child(2n)   { transform: rotate(1.6deg); }
.g-img:nth-child(2n+1) { transform: rotate(-1.6deg); }
.g-img:hover { transform: rotate(0) scale(1.035); box-shadow:0 26px 46px -20px rgba(40,28,12,.45); z-index:2; }
.gallery-cap { text-align:center; color:var(--green); font-family:'Caveat',cursive; font-size:30px; line-height:1.25; margin-top:22px; transform:rotate(-1deg); }
@media (max-width:600px){ .gallery-cap { font-size:30px; padding:0 6px; } }

/* Pillar image */
.pillar { overflow:hidden; }
.pillar-img { height:190px; margin:-34px -34px 22px; background-size:cover; background-position:center; filter:saturate(1.05); }

/* Leben: Karten heben sich beim Hover, leicht versetzt */
.stat, .step, .pillar, .qa { transition: transform .2s ease, box-shadow .2s ease; box-shadow: 0 12px 28px -22px rgba(40,28,12,.4); }
.stat:hover, .step:hover, .pillar:hover, .qa:hover {
  transform: translateY(-4px) rotate(-.35deg);
  box-shadow: 0 24px 44px -24px rgba(40,28,12,.45);
}
.pillar:hover { transform: translateY(-4px); }

/* Problem strip */
.problem { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
@media (max-width: 820px){ .problem { grid-template-columns: 1fr; } }
.stat { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 28px; }
.stat .big { font-family:"Fraunces",serif; font-size: 44px; color: var(--green); font-weight:600; }
.stat p { color: var(--ink-soft); margin-top: 6px; }

/* Steps */
.steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
@media (max-width: 820px){ .steps { grid-template-columns: 1fr; } }
.step { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 30px; position: relative; }
.step .num { width: 42px; height: 42px; border-radius: 12px; background: var(--gold-soft); color: #8a6a14; display:grid; place-items:center; font-family:"Fraunces",serif; font-weight:600; font-size:20px; margin-bottom: 16px; }
.step h3 { font-size: 21px; font-weight: 600; margin-bottom: 8px; }
.step p { color: var(--ink-soft); font-size: 15.5px; }

/* Pillars */
.pillars { display:grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 820px){ .pillars { grid-template-columns: 1fr; } }
.pillar { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 34px; }
.pillar .ico { font-size: 30px; margin-bottom: 14px; }
.pillar h3 { font-size: 24px; font-weight: 600; margin-bottom: 10px; }
.pillar ul { list-style: none; margin-top: 16px; }
.pillar li { display:flex; gap:10px; padding: 7px 0; color: var(--ink-soft); font-size: 15.5px; }
.pillar li::before { content:"✓"; color: var(--green); font-weight: 700; }

/* Dashboard teaser */
.teaser { display:grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items:center; }
@media (max-width: 900px){ .teaser { grid-template-columns: 1fr; } }
.teaser-img { border-radius: var(--radius); overflow:hidden; border:1px solid rgba(255,255,255,.15); box-shadow: var(--shadow); }
.teaser h2 { color: #fff; font-size: clamp(28px,3.4vw,40px); font-weight:600; margin-bottom: 16px; }
.teaser ul { list-style:none; margin: 22px 0; }
.teaser li { display:flex; gap:12px; padding: 8px 0; color:#d6e2da; }
.teaser li::before { content:"→"; color: var(--gold); }

.mini-dash { background:#fff; border-radius: 14px; padding: 18px; color: var(--ink); }
.mini-dash .md-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.mini-dash .md-cards { display:grid; grid-template-columns: repeat(3,1fr); gap:10px; margin-bottom:14px; }
.md-card { background: var(--bg); border:1px solid var(--line); border-radius:10px; padding:12px; }
.md-card .k { font-size: 11px; color: var(--ink-soft); text-transform:uppercase; letter-spacing:.05em; }
.md-card .v { font-family:"Fraunces",serif; font-size: 24px; color: var(--green); font-weight:600; }

/* FAQ */
.faq { max-width: 760px; margin: 0 auto; }
.qa { background:#fff; border:1px solid var(--line); border-radius: 14px; padding: 22px 24px; margin-bottom: 14px; }
.qa h3 { font-size: 18px; font-weight: 600; margin-bottom: 8px; display:flex; gap:10px; }
.qa p { color: var(--ink-soft); font-size: 15.5px; }

/* Final CTA */
.cta-final { text-align:center; }
.cta-final h2 { color:#fff; font-size: clamp(30px,4vw,46px); font-weight:600; margin-bottom: 16px; }
.cta-final p { color:#c4d3c9; font-size: 18px; max-width: 560px; margin: 0 auto 28px; }

/* Footer */
footer { background: var(--ink); color:#b9c6bd; padding: 48px 0 30px; font-size: 14px; }
.foot-grid { display:flex; justify-content:space-between; flex-wrap:wrap; gap: 24px; margin-bottom: 28px; }
.foot-grid a { color:#b9c6bd; display:block; padding: 4px 0; }
.foot-grid a:hover { color: var(--gold); }
.foot-bottom { border-top:1px solid rgba(255,255,255,.1); padding-top: 18px; color:#7f9088; }
.disclaimer { font-size: 12.5px; color:#7f9088; max-width: 720px; margin-top: 10px; }

/* ============== DASHBOARD ============== */
.app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }
.side { background: var(--green-dk); color:#cfded5; padding: 24px 18px; }
.side .logo { color:#fff; margin-bottom: 30px; }
.side nav a { display:flex; align-items:center; gap:12px; padding: 11px 14px; border-radius: 10px; color:#bcd0c4; font-size: 15px; font-weight:500; margin-bottom: 4px; }
.side nav a.active, .side nav a:hover { background: rgba(255,255,255,.08); color:#fff; }
.side nav a .dot { width:8px;height:8px;border-radius:50%; }
.side-foot { margin-top: 30px; padding: 16px; background: rgba(255,255,255,.06); border-radius: 12px; font-size: 13px; color:#bcd0c4; }

.main { background: var(--bg); padding: 0; }
.topbar { display:flex; justify-content:space-between; align-items:center; padding: 20px 36px; border-bottom:1px solid var(--line); background:#fff; }
.topbar .rest { display:flex; align-items:center; gap:12px; }
.topbar .rest .gcard-logo { width:40px; height:40px; font-size:18px; }
.topbar .gpill { display:flex; align-items:center; gap:10px; background: var(--bg-soft); border:1px solid var(--line); padding:8px 16px; border-radius:999px; }
.topbar .gpill b { font-family:"Fraunces",serif; font-size:18px; }
.topbar .gpill .stars { color: var(--gold); }

.content { padding: 32px 36px; max-width: 1100px; }
.kpis { display:grid; grid-template-columns: repeat(4,1fr); gap:18px; margin-bottom: 28px; }
@media (max-width: 900px){ .kpis { grid-template-columns: 1fr 1fr; } }
.kpi { background:#fff; border:1px solid var(--line); border-radius:14px; padding: 20px; }
.kpi .k { font-size:12px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); }
.kpi .v { font-family:"Fraunces",serif; font-size: 34px; font-weight:600; margin: 4px 0; }
.kpi .v.green { color: var(--green); }
.kpi .v.gold { color: var(--gold); }
.kpi .v.red { color: var(--red); }
.kpi .sub { font-size:13px; color:var(--ink-soft); }

.panel { background:#fff; border:1px solid var(--line); border-radius:16px; padding: 24px; margin-bottom: 24px; }
.panel h2 { font-family:"Fraunces",serif; font-size: 22px; font-weight:600; margin-bottom: 4px; }
.panel .sub { color:var(--ink-soft); font-size:14px; margin-bottom: 18px; }

.rev { display:flex; gap:14px; padding:16px 0; border-top:1px solid var(--line); align-items:flex-start; }
.rev:first-of-type { border-top:none; }
.rev .av { width:40px;height:40px;border-radius:50%;flex:none;display:grid;place-items:center;color:#fff;font-weight:600;font-size:14px; }
.rev .meta { flex:1; }
.rev .meta .name { font-weight:600; }
.rev .meta .rstars { color:var(--gold); font-size:13px; letter-spacing:1px; }
.rev .meta .txt { color:var(--ink-soft); font-size:14.5px; margin-top:4px; }
.rev .act { flex:none; display:flex; flex-direction:column; gap:8px; align-items:flex-end; }

.bars { display:flex; align-items:flex-end; gap:10px; height: 140px; margin-top: 10px; }
.bar { flex:1; background: linear-gradient(var(--green), #2c8f5e); border-radius:8px 8px 0 0; position:relative; }
.bar span { position:absolute; top:-22px; left:0; right:0; text-align:center; font-size:12px; color:var(--ink-soft); }
.bar small { position:absolute; bottom:-22px; left:0; right:0; text-align:center; font-size:11px; color:var(--ink-soft); }

.banner { background: var(--gold-soft); border:1px solid #ecd9a8; border-radius:14px; padding: 18px 22px; display:flex; justify-content:space-between; align-items:center; gap:16px; margin-bottom:24px; }
.banner .t { font-weight:600; }
.banner .s { font-size:14px; color:#7a5e12; }
@media (max-width:700px){
  .app{ grid-template-columns:1fr; }
  .side{ position:sticky; top:0; z-index:30; }
  .side .logo{ margin-bottom:14px; }
  .side nav{ display:flex; gap:6px; overflow-x:auto; padding-bottom:4px; -webkit-overflow-scrolling:touch; }
  .side nav a{ white-space:nowrap; margin-bottom:0; flex:none; }
  .side nav a .badge{ margin-left:6px; }
  .side .side-foot{ display:none; }
}

/* ============== ANALYZER WIDGET ============== */
.analyzer {
  background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 26px; max-width: 460px; margin-left:auto; width:100%;
}
.analyzer .az-head { display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.analyzer .az-head .dotlive { width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(31,107,70,.15); }
.analyzer .az-head b { font-family:"Fraunces",serif; font-size:19px; font-weight:600; }
.analyzer .az-sub { font-size:13.5px; color:var(--ink-soft); margin-bottom:16px; }
.az-form { display:flex; flex-direction:column; gap:10px; }
.az-input {
  width:100%; padding:13px 16px; border:1px solid var(--line); border-radius:12px;
  font-size:15px; font-family:inherit; background:var(--bg); color:var(--ink);
}
.az-input:focus { outline:none; border-color:var(--green); background:#fff; }
.az-form .btn { justify-content:center; width:100%; }
.az-erfolg { display:flex; align-items:center; gap:8px; justify-content:center; font-size:13px; color:var(--green); font-weight:600; margin-top:4px; }

/* loading */
.az-loading { text-align:center; padding:26px 10px; }
.spinner {
  width:42px;height:42px;border-radius:50%;
  border:4px solid var(--gold-soft); border-top-color:var(--green);
  margin:0 auto 14px; animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.az-loading .step-txt { font-size:14px; color:var(--ink-soft); min-height:20px; }

/* results */
.az-results { animation: fade .4s ease; }
@keyframes fade { from { opacity:0; transform:translateY(8px);} to {opacity:1;transform:none;} }
.az-score { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 0; border-bottom:1px solid var(--line); }
.az-score .now { text-align:center; }
.az-score .now .lbl { font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft); }
.az-score .now .num { font-family:"Fraunces",serif; font-size:36px; font-weight:600; }
.az-score .now .num.bad { color:var(--red); }
.az-score .now .num.good { color:var(--green); }
.az-score .arrow { font-size:26px; color:var(--gold); }
.az-line { display:flex; gap:12px; padding:14px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.az-line .ic { width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;font-size:16px; }
.az-line .ic.del { background:#fbe9e4; }
.az-line .ic.add { background:var(--gold-soft); }
.az-line .body b { font-size:15px; }
.az-line .body .big { font-family:"Fraunces",serif; color:var(--green); font-weight:600; }
.az-line .body p { font-size:13px; color:var(--ink-soft); }
.az-cta-row { margin-top:18px; }
.az-cta-row .btn { width:100%; justify-content:center; }
.az-badge-erfolg {
  background:var(--gold-soft); border:1px solid #ecd9a8; border-radius:12px;
  padding:12px 14px; margin-top:14px; font-size:13.5px; color:#7a5e12; text-align:center;
}
.az-badge-erfolg b { color:#5f4a0e; }
.az-meta { font-size:12px; color:var(--ink-soft); text-align:center; margin-top:10px; }
.az-facts { font-size:13px; color:var(--ink-soft); margin-bottom:14px; }
.az-facts b { color:var(--ink); }
.az-example { background:#fbf6ee; border:1px dashed #e3cd9a; border-radius:12px; padding:12px 14px; margin-top:14px; }
.az-example .ex-h { font-size:12px; font-weight:600; color:#8a6a14; text-transform:uppercase; letter-spacing:.04em; margin-bottom:6px; }
.az-example .ex-stars { color:var(--red); font-size:12px; letter-spacing:1px; }
.az-example .ex-txt { font-size:13.5px; color:var(--ink-soft); font-style:italic; }
.az-error { text-align:center; padding:20px 6px; }
.az-error b { font-family:"Fraunces",serif; font-size:18px; }
.az-error p { color:var(--ink-soft); font-size:14px; margin:8px 0 16px; }
.az-map { margin:6px 0 14px; border-radius:12px; overflow:hidden; border:1px solid var(--line); box-shadow:0 8px 20px -16px rgba(40,28,12,.4); }
.az-map iframe { width:100%; height:150px; border:0; display:block; filter:saturate(.92); }

/* ============== REPORT ONEPAGER ============== */
.rep-wrap { max-width: 940px; margin: 0 auto; padding: 0 24px; }
.rep-top { border-bottom:1px solid var(--line); background:rgba(250,248,243,.9); backdrop-filter:blur(10px); position:sticky; top:0; z-index:40; }
.rep-top-inner { max-width:940px; margin:0 auto; padding:16px 24px; display:flex; justify-content:space-between; align-items:center; }

/* loading overlay */
.rep-loading { min-height:80vh; display:grid; place-items:center; text-align:center; }
.rep-loading .spinner { width:54px;height:54px;border-width:5px; }
.rep-loading h2 { font-family:"Fraunces",serif; font-weight:600; font-size:26px; margin:18px 0 6px; }
.rep-loading .step-txt { color:var(--ink-soft); font-size:15px; min-height:22px; }

/* header card */
.rep-hero { background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:32px; margin:32px 0; }
.rep-hero-grid { display:grid; grid-template-columns:1fr auto; gap:28px; align-items:center; }
@media(max-width:760px){ .rep-hero-grid{ grid-template-columns:1fr; } }
.rep-hero h1 { font-family:"Fraunces",serif; font-weight:600; font-size:clamp(26px,4vw,38px); margin-bottom:6px; }
.rep-hero .sub { color:var(--ink-soft); font-size:15px; }
.rep-hero .scorebox { text-align:center; padding-left:28px; border-left:1px solid var(--line); }
@media(max-width:760px){ .rep-hero .scorebox{ border-left:none; padding-left:0; border-top:1px solid var(--line); padding-top:18px; } }
.rep-hero .scorebox .big { font-family:"Fraunces",serif; font-size:54px; font-weight:600; color:var(--green); line-height:1; }
.rep-hero .scorebox .stars { color:var(--gold); letter-spacing:2px; }
.rep-hero .scorebox .cnt { font-size:13px; color:var(--ink-soft); }

/* distribution bars */
.rep-dist { margin-top:24px; }
.dist-row { display:flex; align-items:center; gap:12px; margin:6px 0; font-size:13px; }
.dist-row .lab { width:42px; color:var(--ink-soft); }
.dist-row .track { flex:1; height:10px; background:var(--bg-soft); border-radius:99px; overflow:hidden; }
.dist-row .fill { height:100%; border-radius:99px; }
.dist-row .fill.good { background:var(--green); }
.dist-row .fill.bad  { background:var(--red); }
.dist-row .val { width:90px; text-align:right; color:var(--ink-soft); }

/* sections */
.rep-sec { margin:34px 0; }
.rep-sec > h2 { font-family:"Fraunces",serif; font-weight:600; font-size:26px; margin-bottom:6px; }
.rep-sec > .lead { color:var(--ink-soft); margin-bottom:18px; }

/* theme chips */
.themes { display:flex; flex-wrap:wrap; gap:10px; }
.chip { background:#fff; border:1px solid var(--line); border-radius:999px; padding:8px 16px; font-size:14px; display:flex; align-items:center; gap:8px; }
.chip b { font-family:"Fraunces",serif; color:var(--green); }
.chip.warn { background:#fdf3ea; border-color:#ecd1aa; }
.chip.warn b { color:#b06a18; }

/* insight strip */
.insights { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin:8px 0 4px; }
@media(max-width:700px){ .insights{ grid-template-columns:1fr; } }
.ins { background:#fff; border:1px solid var(--line); border-radius:14px; padding:20px; }
.ins .v { font-family:"Fraunces",serif; font-size:32px; font-weight:600; color:var(--green); }
.ins .v.red { color:var(--red); }
.ins .k { font-size:13.5px; color:var(--ink-soft); margin-top:2px; }

/* review cards */
.rcard { background:#fff; border:1px solid var(--line); border-radius:16px; padding:22px; margin-bottom:16px; }
.rcard.flag { border-color:#ecd1aa; box-shadow:0 0 0 3px #fdf3ea; }
.rcard-top { display:flex; gap:14px; align-items:flex-start; margin-bottom:10px; }
.rcard .av { width:42px;height:42px;border-radius:50%;flex:none;display:grid;place-items:center;color:#fff;font-weight:600; background:#8a9a90; }
.rcard .who { flex:1; }
.rcard .who .nm { font-weight:600; }
.rcard .who .mt { font-size:12.5px; color:var(--ink-soft); display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.rcard .rstars { color:var(--red); font-size:14px; letter-spacing:1px; flex:none; }
.rcard .txt { font-size:15px; color:#33403a; line-height:1.55; }
.rcard-foot { display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-top:14px; padding-top:14px; border-top:1px solid var(--line); }
.lg-badge { font-size:11px; font-weight:600; background:#eef3f9; color:#3a5a85; padding:2px 8px; border-radius:999px; }
.vd { font-size:13px; font-weight:600; padding:6px 12px; border-radius:999px; display:inline-flex; gap:7px; align-items:center; }
.vd.rm  { background:#fbe9e4; color:var(--red); }
.vd.gz  { background:var(--gold-soft); color:#8a6a14; }
.vd.keep{ background:#e3f1e9; color:var(--green); }
.ins .v.big-hl { font-size:38px; }
.ins.hl { background:#f0f7f2; border-color:#c7e3d3; }
.owner { font-size:12.5px; color:var(--ink-soft); }

/* plan */
.rep-plan { background:var(--green-dk); color:#eef3ef; border-radius:var(--radius); padding:34px; }
.rep-plan h2 { color:#fff; font-family:"Fraunces",serif; font-weight:600; font-size:28px; margin-bottom:18px; }
.plan-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:22px; }
@media(max-width:700px){ .plan-grid{ grid-template-columns:1fr; } }
.plan-card { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); border-radius:14px; padding:22px; }
.plan-card .ic { font-size:24px; }
.plan-card h3 { font-family:"Inter",sans-serif; font-size:17px; font-weight:600; margin:8px 0 6px; color:#fff; }
.plan-card .big { font-family:"Fraunces",serif; font-size:30px; color:var(--gold); font-weight:600; }
.plan-card p { color:#c4d3c9; font-size:14px; margin-top:6px; }
.rep-plan .erfolg { background:rgba(224,169,59,.16); border:1px solid rgba(224,169,59,.3); border-radius:12px; padding:14px 18px; color:#f1d9a3; font-size:14.5px; margin-bottom:20px; }
.rep-plan .btn { width:100%; justify-content:center; }

/* Sterne-Reise */
.journey { display:flex; align-items:center; justify-content:center; gap:24px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:16px; padding:26px 20px; margin-bottom:22px; }
.journey .j-lbl { font-size:12px; text-transform:uppercase; letter-spacing:.07em; color:#a9c0b2; text-align:center; }
.journey .j-num { font-family:"Fraunces",serif; font-size:clamp(38px,7vw,56px); font-weight:600; line-height:1; text-align:center; }
.journey .j-from .j-num { color:#e7d4a6; }
.journey .j-to .j-num { color:var(--gold); }
.journey .j-arrow { text-align:center; color:#a9c0b2; font-size:12px; }
.journey .j-arrow .j-line { font-size:30px; color:var(--gold); line-height:1.1; }

/* Warum-Box */
.why { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:24px; margin-bottom:20px; }
.why h3 { font-family:"Fraunces",serif; font-weight:600; font-size:20px; color:#fff; margin-bottom:10px; }
.why p { color:#c4d3c9; font-size:15px; }
.why-stat { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:18px; }
@media(max-width:600px){ .why-stat{ grid-template-columns:1fr; gap:12px; } }
.why-stat .ws-num { font-family:"Fraunces",serif; font-size:34px; font-weight:600; color:var(--gold); }
.why-stat .ws-k { font-size:13.5px; color:#c4d3c9; }

/* Demo-Hinweisleiste */
.demo-bar { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap;
  background:var(--green-dk); color:#eef3ef; padding:11px 20px; font-size:14.5px; text-align:center; }
.demo-bar b { color:var(--gold); }
.demo-bar .btn { padding:9px 16px; font-size:13.5px; }

/* ============== DASHBOARD: interaktive Views ============== */
.side nav a { cursor:pointer; }
.side nav a .badge { margin-left:auto; background:var(--gold); color:#2a2208; font-size:11px; font-weight:700; padding:1px 8px; border-radius:999px; }
.view { display:none; }
.view.active { display:block; animation: fade .35s ease; }
.page-h { font-family:"Fraunces",serif; font-size:26px; font-weight:600; margin-bottom:2px; }
.page-sub { color:var(--ink-soft); margin-bottom:22px; }

.dtable { width:100%; border-collapse:collapse; }
.dtable th { text-align:left; font-size:11.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); padding:10px 12px; border-bottom:1px solid var(--line); }
.dtable td { padding:14px 12px; border-bottom:1px solid var(--line); font-size:14px; vertical-align:middle; }
.dtable tr:last-child td { border-bottom:none; }
.dtable tr:hover td { background:var(--bg-soft); }
.dtable .rstars { color:var(--gold); letter-spacing:1px; white-space:nowrap; }
.dtable .rstars.bad { color:var(--red); }

.pill { font-size:12px; font-weight:600; padding:4px 11px; border-radius:999px; display:inline-block; white-space:nowrap; }
.pill.green{ background:#e3f1e9; color:var(--green); }
.pill.red  { background:#fbe9e4; color:var(--red); }
.pill.gold { background:var(--gold-soft); color:#8a6a14; }
.pill.blue { background:#eaf1f8; color:#37597f; }
.pill.grey { background:#ececec; color:#666; }

.fchips { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.fchip { padding:8px 16px; border-radius:999px; border:1px solid var(--line); background:#fff; font-size:14px; cursor:pointer; font-weight:500; transition:.15s; }
.fchip:hover { border-color:var(--green); }
.fchip.active { background:var(--green); color:#fff; border-color:var(--green); }

/* Segment-Filter */
.segbar { display:inline-flex; background:var(--bg-soft); border:1px solid var(--line); border-radius:13px; padding:4px; gap:4px; flex-wrap:wrap; margin-bottom:18px; max-width:100%; }
.segbar .seg { padding:9px 16px; border-radius:9px; font-size:14px; font-weight:500; cursor:pointer; color:var(--ink-soft); border:none; background:transparent; display:flex; align-items:center; gap:8px; transition:.15s; white-space:nowrap; }
.segbar .seg:hover { color:var(--ink); }
.segbar .seg.active { background:#fff; color:var(--green); box-shadow:0 1px 3px rgba(20,61,41,.12); font-weight:600; }
.segbar .seg .cnt { font-size:12px; font-weight:600; color:var(--ink-soft); background:rgba(20,40,27,.06); padding:1px 8px; border-radius:999px; }
.segbar .seg.active .cnt { background:var(--gold-soft); color:#8a6a14; }
@media(max-width:600px){ .segbar{ display:flex; overflow-x:auto; } }

.btn-sm { padding:8px 14px; font-size:13px; }

.toast { position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(24px); background:var(--green-dk); color:#fff; padding:14px 22px; border-radius:12px; box-shadow:var(--shadow); opacity:0; pointer-events:none; transition:.3s ease; z-index:200; font-size:14.5px; font-weight:500; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

.toggle { width:46px; height:26px; border-radius:999px; background:#cfcfc7; position:relative; cursor:pointer; transition:.2s; flex:none; }
.toggle.on { background:var(--green); }
.toggle::after { content:""; position:absolute; width:20px; height:20px; border-radius:50%; background:#fff; top:3px; left:3px; transition:.2s; box-shadow:0 1px 3px rgba(0,0,0,.2); }
.toggle.on::after { left:23px; }
.setrow { display:flex; justify-content:space-between; align-items:center; padding:18px 0; border-bottom:1px solid var(--line); gap:16px; }
.setrow:last-child { border-bottom:none; }
.setrow .st b { font-size:15px; }
.setrow .st p { font-size:13px; color:var(--ink-soft); }
.field { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.field label { font-size:13px; font-weight:600; color:var(--ink-soft); }
.field input { padding:11px 14px; border:1px solid var(--line); border-radius:10px; font-size:14px; font-family:inherit; background:var(--bg); }

/* Löschantrag-Timeline */
.tl { list-style:none; margin-top:6px; }
.tl li { display:flex; gap:12px; padding:0 0 18px; position:relative; }
.tl li::before { content:""; position:absolute; left:9px; top:22px; bottom:0; width:2px; background:var(--line); }
.tl li:last-child::before { display:none; }
.tl .dot { width:20px; height:20px; border-radius:50%; flex:none; display:grid; place-items:center; font-size:11px; color:#fff; z-index:1; }
.tl .dot.done { background:var(--green); }
.tl .dot.now  { background:var(--gold); }
.tl .dot.wait { background:#cfcfc7; }
.tl .tt b { font-size:14.5px; }
.tl .tt p { font-size:13px; color:var(--ink-soft); }

/* Plättchen / QR */
.plaque-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:16px; }
.plaque { background:#fff; border:1px solid var(--line); border-radius:14px; padding:20px; text-align:center; }
.plaque .qr { width:150px; height:150px; margin:0 auto 12px; border-radius:10px; background:#fff; padding:6px; border:1px solid var(--line); }
.plaque .tno { font-weight:600; }
.plaque .scans { font-size:13px; color:var(--ink-soft); }

/* Abrechnung */
.bill-hero { display:grid; grid-template-columns:1.3fr 1fr; gap:18px; margin-bottom:24px; }
.bill-card { background:#fff; border:1px solid var(--line); border-radius:16px; padding:24px; }
.bill-card.dark { background:var(--green-dk); color:#eef3ef; }
.bill-card.dark .lbl { color:#a9c0b2; }
.bill-card .lbl { font-size:12px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); }
.bill-card .amt { font-family:"Fraunces",serif; font-size:38px; font-weight:600; margin:4px 0; }
.bill-card.dark .amt { color:#fff; }

/* Info-Hinweis (automatische Entfernung) */
.info-note { background:#eef6f0; border:1px solid #cfe6d8; border-radius:12px; padding:14px 16px; font-size:14px; color:#2c5a41; margin-bottom:16px; line-height:1.5; }

/* Auswahl-Checkbox + Aktionsleiste */
.rcheck { width:18px; height:18px; cursor:pointer; accent-color: var(--green); }
.selbar { position:sticky; bottom:14px; display:flex; justify-content:space-between; align-items:center; gap:14px;
  background:var(--green-dk); color:#fff; padding:14px 20px; border-radius:14px; box-shadow:var(--shadow); margin-top:16px; }

/* Bundles */
.bundle-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
@media(max-width:700px){ .bundle-grid{ grid-template-columns:1fr; } }
.bundle { position:relative; background:var(--bg); border:1px solid var(--line); border-radius:14px; padding:20px; text-align:center; }
.bundle.hot { border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-soft); }
.bundle .bhot { position:absolute; top:-11px; left:50%; transform:translateX(-50%); background:var(--gold); color:#3a2c08; font-size:11px; font-weight:700; padding:3px 12px; border-radius:999px; }
.bundle .bt { font-size:14px; color:var(--ink-soft); }
.bundle .bp { font-family:"Fraunces",serif; font-size:32px; font-weight:600; color:var(--green); margin:4px 0; }
.bundle .bs { font-size:13px; color:var(--ink-soft); }

/* Modal (Admin Plättchen-Verwaltung) */
.modal { position:fixed; inset:0; background:rgba(20,30,20,.45); display:flex; align-items:center; justify-content:center; z-index:200; padding:20px; }
.modal-card { background:#fff; border-radius:16px; padding:24px; max-width:580px; width:100%; max-height:85vh; overflow:auto; box-shadow:var(--shadow); }
.pm-row { display:grid; grid-template-columns:1fr 1.5fr auto; gap:8px; margin-bottom:8px; align-items:center; }
.pm-row input { padding:9px 11px; border:1px solid var(--line); border-radius:9px; font-size:14px; font-family:inherit; background:var(--bg); width:100%; }
@media(max-width:560px){ .pm-row{ grid-template-columns:1fr auto; } }

/* ============================================================
   MOBILE-OPTIMIERUNG
   ============================================================ */
@media (max-width: 820px) {
  .gallery { grid-template-columns:repeat(2,1fr); }
  .g-img { height:150px; }
}

@media (max-width: 600px) {
  .wrap, .rep-wrap { padding:0 18px; }
  .nav-inner { height:64px; }
  .logo { font-size:19px; }
  .logo .star { width:30px; height:30px; font-size:14px; }
  .logo { font-size:17px; gap:8px; }
  .nav .btn-primary { padding:9px 13px; font-size:12.5px; }
  .section-head h2::after { width:46px; height:6px; }

  section.block { padding:48px 0; }
  .hero { padding:34px 0 18px; }
  .section-head { margin-bottom:30px; }
  .section-head h2, .rep-sec > h2 { font-size:25px; }

  /* Hero / Analyzer */
  .hero-grid { gap:26px; }
  .analyzer { margin:0 auto; padding:20px; max-width:100%; }
  .hero p.lead { font-size:17px; }
  .eyebrow { font-size:12px; }

  /* Buttons komfortabel antippbar */
  .btn { padding:14px 20px; }
  .hero-cta .btn, .az-form .btn { width:100%; justify-content:center; }

  /* Gallery */
  .g-img { height:130px; border-radius:13px; }
  .gallery { gap:10px; }
  .gallery-cap { font-size:29px; }

  /* Karten-Grids einspaltig */
  .problem, .steps, .pillars, .kpis, .insights, .plan-grid, .why-stat { grid-template-columns:1fr; }
  .pillar-img { margin:-34px -34px 20px; height:160px; }

  /* Dashboard-Teaser */
  .teaser { gap:28px; }
  .mini-dash .md-cards { gap:8px; }

  /* Report */
  .rep-hero { padding:24px; margin:22px 0; }
  .rep-hero h1 { font-size:26px; }
  .rep-hero .scorebox .big { font-size:46px; }
  .rep-sec { margin:28px 0; }
  .rep-plan { padding:24px; }
  .journey { gap:14px; padding:20px 12px; }
  .journey .j-num { font-size:40px; }
  .rcard { padding:18px; }
  .rcard-top { gap:10px; }
  .rcard .txt { font-size:14.5px; }
  .dist-row .val { width:74px; font-size:12px; }
  .rep-top-inner { padding:14px 18px; }

  /* Dashboard-App: Sidebar weg, mobil gestapelt */
  .topbar { padding:16px 18px; flex-wrap:wrap; gap:10px; }
  .content { padding:22px 18px; }
}

/* sehr kleine Geräte */
@media (max-width: 380px) {
  .journey { flex-direction:column; gap:6px; }
  .journey .j-arrow .j-line { transform:rotate(90deg); }
}

/* ============================================================
   DEKO — mehr Leben / "Hook" (greift auch mobil)
   ============================================================ */

/* faint Stern-Watermark hinter jeder Section-Überschrift (on-brand) */
.section-head { position: relative; }
.section-head::before {
  content: "★"; position: absolute; left: -8px; top: -56px;
  font-family: "Fraunces", serif; font-size: 116px; line-height: 1;
  color: rgba(214,152,42,.13); z-index: 0; pointer-events: none;
}
.section-head > * { position: relative; z-index: 1; }

/* weicher Farbblob im Hero */
.hero { position: relative; }
.hero::after {
  content: ""; position: absolute; width: 440px; height: 440px;
  right: -150px; top: -130px; border-radius: 50%;
  background: radial-gradient(circle, rgba(214,152,42,.18), transparent 70%);
  pointer-events: none; z-index: 0;
}
.hero-grid { position: relative; z-index: 1; }

/* Bild-Header oben (vor allem mobil) */
.hero-banner { display: none; }
@media (max-width: 900px) {
  .hero-banner {
    display: flex; align-items: flex-end; position: relative; z-index: 1;
    height: 200px; border-radius: 18px; margin-bottom: 26px; padding: 16px 18px;
    background-size: cover; background-position: center;
    border: 5px solid #fff; box-shadow: var(--shadow);
  }
  .hero-banner-tag { color: #fff; font-weight: 600; font-size: 15px; text-shadow: 0 1px 8px rgba(0,0,0,.35); }

  /* Reihenfolge: Überschrift zuerst (unter dem Bild), Eyebrow + Beschreibung darunter */
  .hero-copy { display: flex; flex-direction: column; align-items: flex-start; }
  .hero-copy h1        { order: 1; margin-top: 0; }
  .hero-copy .eyebrow  { order: 2; margin: 14px 0 0; }
  .hero-copy .lead     { order: 3; margin-top: 14px; }
  .hero-copy .hero-trust { order: 4; }
}

/* feine Punkt-Textur auf den weißen Splitter-Sektionen */
.bg-soft {
  background-color: #fffdf8;
  background-image: radial-gradient(rgba(28,94,59,.05) 1.3px, transparent 1.3px);
  background-size: 24px 24px;
}

/* dezenter Farbverlauf-Streifen oben an dunklen Sektionen */
.bg-dark { position: relative; }

@media (max-width: 600px) {
  /* mobil etwas kleinere Watermark, damit's nicht überlagert */
  .section-head::before { font-size: 84px; top: -40px; left: -4px; }
  .hero::after { width: 300px; height: 300px; right: -110px; top: -80px; }
}

/* ===== Glückwunsch-Box (Analyzer, ≥ 4,7 ★) ===== */
.az-congrats { text-align: center; padding: 16px 4px 6px; }
.az-congrats .cg-emoji { font-size: 46px; line-height: 1; }
.az-congrats h3 { font-family: "Fraunces", serif; font-size: 24px; font-weight: 600; margin: 8px 0 10px; color: var(--green); }
.az-congrats p { font-size: 14.5px; color: var(--ink-soft); margin-bottom: 10px; }
.az-congrats .cg-soft { background: var(--gold-soft); border: 1px solid #ecd9a8; border-radius: 12px; padding: 12px 14px; color: #7a5e12; margin-top: 4px; }

/* ===== Dashboard & Admin: Mobil-Feinschliff ===== */
.formrow { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:760px){
  .dtable { min-width:520px; }                 /* Tabellen horizontal scrollbar statt zerquetscht */
  .bill-hero { grid-template-columns:1fr; }
  .formrow { grid-template-columns:1fr; }
  .selbar { flex-direction:column; align-items:stretch; text-align:center; gap:10px; }
  .topbar { flex-wrap:wrap; gap:10px; padding:13px 16px; }
  .topbar .gpill { font-size:12px; padding:6px 12px; gap:6px; }
  .topbar .gpill .stars { font-size:11px; }
  .content { padding:18px 14px; }
  .page-h { font-size:22px; }
  .kpi .v { font-size:28px; }
  .modal-card { padding:18px; }
  .plaque-grid { grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); }
}

/* ===== Cookie-Consent ===== */
.cc-banner {
  position:fixed; left:16px; right:16px; bottom:16px; z-index:300;
  max-width:880px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap;
  background:#fffdf8; border:1px solid var(--line); border-radius:16px;
  box-shadow:0 20px 50px -18px rgba(40,28,12,.5); padding:16px 20px;
}
.cc-banner .cc-text { font-size:14px; color:var(--ink-soft); flex:1; min-width:240px; line-height:1.5; }
.cc-banner .cc-text a { color:var(--green); font-weight:600; }
.cc-actions { display:flex; gap:10px; flex-wrap:wrap; }
.cc-btn { font-weight:600; font-size:14px; padding:11px 18px; border-radius:999px; border:1px solid transparent; cursor:pointer; }
.cc-btn.cc-primary { background:var(--green); color:#fff; box-shadow:0 3px 0 0 #0e3120; }
.cc-btn.cc-primary:hover { background:#1a6840; }
.cc-btn.cc-ghost { background:#fff; color:var(--ink); border-color:var(--line); }
.cc-btn.cc-ghost:hover { border-color:var(--green); color:var(--green); }

.cc-modal { position:fixed; inset:0; background:rgba(20,30,20,.45); display:flex; align-items:center; justify-content:center; z-index:310; padding:20px; }
.cc-card { background:#fff; border-radius:16px; padding:24px; max-width:480px; width:100%; box-shadow:var(--shadow); }
.cc-card h3 { font-family:"Fraunces",serif; font-size:22px; font-weight:600; margin-bottom:14px; }
.cc-row { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0; border-top:1px solid var(--line); }
.cc-row .cc-info b { font-size:15px; }
.cc-row .cc-info p { font-size:13px; color:var(--ink-soft); margin-top:2px; }
.cc-always { font-size:12px; font-weight:600; color:var(--green); background:#e3f1e9; padding:5px 12px; border-radius:999px; white-space:nowrap; }
.cc-switch { width:46px; height:26px; border-radius:999px; background:#cfcfc7; position:relative; cursor:pointer; border:none; flex:none; transition:.2s; }
.cc-switch.on { background:var(--green); }
.cc-switch::after { content:""; position:absolute; width:20px; height:20px; border-radius:50%; background:#fff; top:3px; left:3px; transition:.2s; }
.cc-switch.on::after { left:23px; }
.cc-foot { display:flex; justify-content:flex-end; gap:10px; margin-top:18px; }

@media (max-width:600px){
  .cc-banner { flex-direction:column; align-items:stretch; gap:12px; }
  .cc-actions { justify-content:stretch; }
  .cc-actions .cc-btn { flex:1; }
}

/* Karte erst nach funktionaler Zustimmung */
.az-map-off { height:120px; display:flex; align-items:center; justify-content:center; text-align:center;
  background:var(--bg-soft); color:var(--ink-soft); font-size:13.5px; cursor:pointer; padding:0 14px; }

/* ===== Rechtsseiten (Impressum/Datenschutz) ===== */
.legal h2 { font-family:"Fraunces",serif; font-size:21px; font-weight:600; margin:28px 0 8px; }
.legal p, .legal li { font-size:15px; color:var(--ink-soft); line-height:1.65; }
.legal ul { margin:8px 0 8px 20px; }
.legal li { margin-bottom:6px; }
.legal a { color:var(--green); font-weight:500; }
.legal-box { background:var(--gold-soft); border:1px solid #ecd9a8; border-radius:12px; padding:14px 16px; font-size:14px; color:#7a5e12; margin-bottom:24px; }

/* ===== Lead-/Kontaktformular ===== */
.lead-form { display:flex; flex-direction:column; gap:12px; }
.lead-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:560px){ .lead-row{ grid-template-columns:1fr; } }
.lead-in { width:100%; padding:13px 15px; border-radius:12px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.07); color:#fff; font-size:15px; font-family:inherit; }
.lead-in::placeholder { color:#a9c0b2; }
.lead-in:focus { outline:none; border-color:var(--gold); background:rgba(255,255,255,.12); }
select.lead-in option { color:#222; }
.lead-hp { position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.lead-status { font-size:14px; min-height:18px; color:#ffd2c4; }
.lead-done { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.22); border-radius:14px; padding:22px; color:#fff; text-align:center; font-size:16px; }
