/* =====================================================================
   ProMedia24 — Startseite (Marken-Konsolidierung)
   Warmes, freundliches System in Anlehnung an Calendly / cloud86.
   Keine Cyan-Gradients, kein Glasmorphismus, keine aggressiven Lifts.
   Fonts: Bricolage Grotesque (Display) + Hanken Grotesk (Text).
   -> Im Produktivbetrieb SELBST HOSTEN (DSGVO, kein Google-CDN!).
   ===================================================================== */

:root {
  /* Warme Grundtöne */
  /* Standard-Basis: Leinen (vom Nutzer gewählt). Tweaks kann live umschalten. */
  --cream:        #FDFCFA;   /* Hauptgrund: fast reinweiß, ruhig */
  --cream-2:      #ECE9E2;   /* ruhiges Panel */
  --sand:         #F3EFE7;   /* Trust-Fläche: neutraler, weniger gelb */
  --paper:        #FFFFFF;
  --paper-warm:   #FFFFFF;

  /* Tinte */
  --ink:          #251F1A;
  --ink-2:        #5E5347;   /* gedämpfter Text */
  --ink-3:        #9A8E80;   /* sehr leise */

  /* Linien */
  --line:         #E3E0D8;
  --line-2:       #D5D1C7;

  /* Akzente — warmes, gedämpftes Terrakotta (entsättigt, weniger Signal) */
  --orange:       #B85A33;
  --orange-deep:  #9C4826;   /* Hover */
  --orange-soft:  #D99A6E;
  --orange-tint:  #F1E5DD;   /* sehr helle Fläche */
  --orange-tint2: #E6D4C7;

  /* Ruhiger Begleitton + dezenter dritter Akzent (Tannengrün, sehr sparsam) */
  --teal:         #2C4A52;
  --teal-soft:    #5C7E84;
  --ok:           #3E8E5A;   /* Verfügbarkeit / Häkchen */
  --pine:         #385A47;   /* 3. Akzent: gedecktes Tannengrün (Links-Hover, Tags) */
  --pine-tint:    #E7EEE8;

  /* Form */
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 22px;
  --pill: 999px;

  --shadow-sm: 0 1px 2px rgba(60,40,20,.04);
  --shadow:    0 2px 6px -2px rgba(60,40,20,.06), 0 10px 24px -16px rgba(70,45,20,.18);
  --shadow-lg: 0 4px 10px -4px rgba(60,40,20,.05), 0 22px 48px -28px rgba(70,45,20,.24);

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 64px);

  --f-display: "Bricolage Grotesque", "Hanken Grotesk", system-ui, sans-serif;
  --f-text:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --f-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

/* Zahlen durchgängig tabellarisch */
.statband .n, .price, .tariff .price, .glance .big, .pcard .price, .cmp td, .mstep .mno { font-variant-numeric: tabular-nums; }

/* Mono-Akzent: Preise, Specs, Trust-Sublabels, Schritt-Nummern */
.svc .price, .tariff .price span, .pcard .price span, .tld .p, .trustline .ti span, .mstep .mno, .price-jump a, .glance .big span { font-family: var(--f-mono); }
.svc .price { letter-spacing: -.02em; font-size: .8rem; }
.trustline .ti span { letter-spacing: -.01em; font-size: .82rem; }
.mstep .mno { letter-spacing: -.04em; }

/* Mono-Sektionsnummer (diszipliniert, an Eyebrow gekoppelt) */
.eyebrow .secnum { font-family: var(--f-mono); font-weight: 700; color: var(--ink-3); margin-right: 2px; letter-spacing: -.02em; }

/* 3. Akzent Tannengrün – „inklusive/sicher": Häkchen in Listen + Tarif-Tags */
.svc .more .arr { color: var(--orange); }
.tariff .feats svg, .pcard li svg, .incl .it svg, .glance li svg, .hero-card li svg, .chip svg { color: var(--pine); }
.tariff .tag, .pcard .tag { background: var(--pine); }
.tariff.popular { border-color: var(--orange); }

/* Warmer Foto-Grade: klammert Fotos an Wally/Cream */
.media-band img, .ms-img img, .portrait.has-photo img { filter: saturate(.92) sepia(.06) brightness(1.01) contrast(1.01); }

/* Referenz-Platzhalter ruhiger (neutraler statt auffällige Streifen) */
.ref-ph, .uc > div[style*="repeating-linear-gradient"] { background: var(--cream-2) !important; }

/* Dezente Papier-Textur (handwerklicher Charakter, ~3,5 %) */
body::after {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: .035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* 3. Akzent (Tannengrün) – sehr sparsam: Inline-Links im Fließtext */
.prose a, .press-foot a, .press-line a, .faq .ans a, .tariffs-note a, .pnote a { color: var(--orange-deep); text-decoration: underline; text-decoration-color: color-mix(in srgb, var(--orange) 35%, transparent); text-underline-offset: 3px; text-decoration-thickness: 1.5px; transition: color .15s ease, text-decoration-color .15s ease; }
.prose a:hover, .press-foot a:hover, .press-line a:hover, .faq .ans a:hover, .tariffs-note a:hover, .pnote a:hover { color: var(--pine); text-decoration-color: var(--pine); }
/* Buttons in Prosa nicht wie Textlinks behandeln */
.prose a.btn { text-decoration: none; }
.prose a.btn-primary, .prose a.btn-on-orange { color: #fff; text-decoration: none; }
.prose a.btn-primary:hover, .prose a.btn-on-orange:hover { color: #fff; }

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--f-text);
  background:
    radial-gradient(120% 60% at 50% 100%, var(--sand) 0%, transparent 60%),
    var(--cream);
  background-attachment: fixed;
  color: var(--ink);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
:focus-visible { outline: 3px solid var(--orange); outline-offset: 3px; border-radius: 4px; }

/* ---------- Layout-Helfer ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.section { padding-block: clamp(64px, 9vw, 116px); position: relative; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--f-text); font-weight: 700;
  font-size: .74rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--orange-deep);
}
.eyebrow::before {
  content: ""; width: 22px; height: 2px; background: var(--orange); border-radius: 2px;
}
h1, h2, h3 { font-family: var(--f-display); font-weight: 700; line-height: 1.04; letter-spacing: -.022em; color: var(--ink); }
h2 { font-size: clamp(2.05rem, 4.5vw, 3.3rem); }
h3 { font-size: 1.32rem; line-height: 1.16; letter-spacing: -.012em; }
.lead { font-size: clamp(1.06rem, 1.7vw, 1.3rem); color: var(--ink-2); line-height: 1.6; text-wrap: pretty; max-width: 62ch; }
em.mark { font-style: normal; color: var(--orange); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 14px 26px; border-radius: var(--pill);
  font-family: var(--f-text); font-weight: 700; font-size: 1rem; letter-spacing: -.01em;
  border: 1.5px solid transparent; transition: color .18s ease, border-color .18s ease, transform .18s ease, box-shadow .18s ease;
  white-space: nowrap;
}
.btn .arr { transition: transform .2s ease; }
.btn:hover .arr { transform: translateX(3px); }
.btn-primary { background-color: var(--orange); color: #fff; box-shadow: var(--shadow-sm); }
.btn-primary:hover { background-color: var(--orange-deep); }
.btn-ghost { background-color: var(--paper); color: var(--ink); border-color: var(--line-2); }
.btn-ghost:hover { border-color: var(--ink); background-color: var(--paper-warm); }
.btn-lg { padding: 17px 32px; font-size: 1.06rem; }

/* ---------- Chips / Trust ---------- */
.chips { display: flex; flex-wrap: wrap; gap: 10px 12px; align-items: center; }
.chip {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .9rem; font-weight: 600; color: var(--ink-2);
}
.chip svg { width: 18px; height: 18px; color: var(--ok); flex: none; }
.chip + .chip::before { content: none; }

/* =====================================================================
   TOPBAR + HEADER
   ===================================================================== */
.topbar {
  background: var(--teal); color: #EAF0F0;
  font-size: .85rem;
}
.topbar .wrap { display: flex; gap: 18px; align-items: center; justify-content: center; flex-wrap: wrap; padding-block: 9px; }
.topbar a, .topbar span:not(.dot) { white-space: nowrap; }
.topbar a { color: #EAF0F0; font-weight: 600; }
.topbar a:hover { color: #fff; text-decoration: underline; text-underline-offset: 3px; }
.topbar .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--teal-soft); }

header.site {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--cream) 88%, transparent);
  backdrop-filter: saturate(1.1) blur(8px);
  border-bottom: 1px solid transparent;
  transition: border-color .2s ease, background .2s ease;
}
header.site.scrolled { border-bottom-color: var(--line); background: color-mix(in srgb, var(--cream) 96%, transparent); }
header.site .wrap { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-block: 15px; }

.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand .logo-bot { width: 38px; height: 38px; flex: none; }
.brand .wordmark { display: flex; flex-direction: column; line-height: 1; }
.brand .wm-name { font-family: var(--f-display); font-weight: 800; font-size: 1.32rem; letter-spacing: -.02em; color: var(--ink); }
.brand .wm-name b { color: var(--orange); font-weight: 800; }
.brand .wm-sub { font-size: .68rem; font-weight: 600; letter-spacing: .04em; color: var(--ink-3); margin-top: 3px; white-space: nowrap; }

nav.main { display: flex; align-items: center; gap: 2px; }
nav.main a {
  position: relative;
  padding: 8px 15px; font-weight: 600; font-size: .96rem; color: var(--ink-2);
  white-space: nowrap;
  transition: color .15s ease;
}
nav.main a::after {
  content: ""; position: absolute; left: 15px; right: 15px; bottom: 2px;
  height: 2px; border-radius: 2px; background: var(--orange);
  transform: scaleX(0); transform-origin: center; transition: transform .2s ease;
}
nav.main a:hover { color: var(--ink); }
nav.main a:hover::after { transform: scaleX(1); }

.header-cta { display: flex; align-items: center; gap: 14px; }
.header-cta::before { content: ""; width: 1px; height: 24px; background: var(--line-2); align-self: center; }
.kc-link { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: .95rem; color: var(--ink); padding: 8px 2px; transition: color .15s ease; }
.kc-link svg { width: 17px; height: 17px; color: var(--ink-3); transition: color .15s ease; }
.kc-link:hover { color: var(--orange-deep); }
.kc-link:hover svg { color: var(--orange-deep); }

.burger { display: none; width: 44px; height: 44px; border: 1.5px solid var(--line-2); border-radius: 12px; background: var(--paper); align-items: center; justify-content: center; }
.burger span, .burger span::before, .burger span::after { content: ""; display: block; width: 19px; height: 2px; background: var(--ink); border-radius: 2px; position: relative; }
.burger span::before { position: absolute; top: -6px; }
.burger span::after { position: absolute; top: 6px; }

/* =====================================================================
   HERO
   ===================================================================== */
.hero { position: relative; padding-top: clamp(40px, 6vw, 72px); padding-bottom: clamp(40px, 6vw, 64px); }
.hero-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: clamp(24px, 4vw, 56px); align-items: center; }
.hero h1 { font-size: clamp(2.7rem, 6vw, 4.7rem); }
.hero .lead { margin-top: 22px; max-width: 42ch; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 30px; }
.hero-trust { margin-top: 26px; }

/* Mascot-Bühne */
.hero-stage { position: relative; display: grid; place-items: center; min-height: 320px; }
.stage-disc {
  position: absolute; inset: auto; width: min(420px, 92%); aspect-ratio: 1; border-radius: 50%;
  background: var(--cream-2); border: 1px solid var(--line);
}
.hero-stage .mascot { position: relative; width: min(290px, 78%); filter: drop-shadow(0 26px 30px rgba(80,45,15,.18)); }
.float { animation: float 6s ease-in-out infinite; }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }

/* Mascot-Details */
.wave-arm { transform-origin: 205px 150px; animation: wave 5.5s ease-in-out infinite; }
@keyframes wave { 0%,82%,100% { transform: rotate(0deg); } 88% { transform: rotate(-9deg); } 94% { transform: rotate(-4deg); } }
.antenna-dot { animation: blip 2.4s ease-in-out infinite; }
@keyframes blip { 0%,100% { opacity: 1; } 50% { opacity: .45; } }

/* schwebende Mini-Karten um den Mascot */
.orbit { position: absolute; white-space: nowrap; background: var(--paper); border: 1px solid var(--line); border-radius: 14px; padding: 10px 13px; box-shadow: var(--shadow); display: flex; align-items: center; gap: 9px; font-size: .85rem; font-weight: 700; color: var(--ink); }
.orbit small { display: block; font-weight: 600; color: var(--ink-3); font-size: .72rem; }
.orbit .ic { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; flex: none; }
.orbit-1 { top: 8%; left: -4%; }
.orbit-2 { bottom: 12%; right: -6%; }
.orbit-3 { bottom: 30%; left: -8%; }

/* Statusband unter Hero */
.statband { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--sand); }
.statband .wrap { display: grid; grid-template-columns: repeat(4, 1fr); }
.statband .cell { padding: 24px 8px; text-align: center; border-left: 1px solid var(--line); }
.statband .cell:first-child { border-left: 0; }
.statband .n { font-family: var(--f-display); font-weight: 800; font-size: 1.6rem; color: var(--ink); letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.statband .n b { color: var(--orange); }
.statband .l { font-size: .82rem; color: var(--ink-2); font-weight: 600; margin-top: 2px; }

/* =====================================================================
   WELLEN-TRENNER
   ===================================================================== */
.wave { display: block; width: 100%; height: auto; color: var(--cream-2); }
.bg-warm { background: var(--cream-2); }

/* =====================================================================
   SERVICES
   ===================================================================== */
.sec-head { max-width: 640px; }
.sec-head .lead { margin-top: 16px; }

.svc-grid { margin-top: 46px; display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.svc {
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--r);
  padding: 28px 26px; position: relative; transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
  display: flex; flex-direction: column;
}
.svc:hover { border-color: var(--orange-soft); box-shadow: var(--shadow); transform: translateY(-2px); }
.svc-feature { grid-column: span 3; }
.svc-small { grid-column: span 2; }
.svc .num { font-family: var(--f-display); font-weight: 800; font-size: .9rem; color: var(--ink-3); letter-spacing: .04em; }
.svc .ic-wrap { width: 52px; height: 52px; border-radius: 14px; background: var(--orange-tint); color: var(--orange-deep); display: grid; place-items: center; margin-bottom: 16px; }
.svc .ic-wrap svg { width: 26px; height: 26px; }
.svc-feature .ic-wrap { background: var(--orange); color: #fff; }
.svc h3 { margin-bottom: 7px; }
.svc p { color: var(--ink-2); font-size: .96rem; flex: 1; }
.svc .price { position: absolute; top: 26px; right: 24px; margin: 0; font-weight: 700; font-size: .82rem; color: var(--orange-deep); background: var(--orange-tint); padding: 5px 11px; border-radius: var(--pill); }
.svc .more { margin-top: 16px; font-weight: 700; color: var(--ink); font-size: .94rem; display: inline-flex; align-items: center; gap: 7px; }
.svc .more .arr { transition: transform .2s ease; color: var(--orange); }
.svc:hover .more .arr { transform: translateX(4px); }

/* Domain-Check */
.domaincheck { margin-top: 52px; background: var(--teal); color: #fff; border-radius: var(--r-lg); padding: clamp(24px, 4vw, 40px); display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center; }
.domaincheck h3 { color: #fff; font-size: 1.6rem; }
.domaincheck p { color: #CFE0E1; margin-top: 6px; font-size: .98rem; }
.dc-form { display: flex; gap: 10px; background: #fff; border-radius: var(--pill); padding: 7px 7px 7px 20px; align-items: center; min-width: min(440px, 80vw); }
.dc-form .www { color: var(--ink-3); font-weight: 700; }
.dc-form input { flex: 1; border: 0; font: inherit; font-weight: 600; color: var(--ink); background: transparent; padding: 10px 0; }
.dc-form input:focus { outline: none; }
.dc-result { margin-top: 12px; font-weight: 700; font-size: .92rem; min-height: 1.2em; }
.dc-result.ok { color: #BFEFD2; }
.dc-result.no { color: #F7C9B6; }

/* =====================================================================
   WARUM UNS + PRESSE
   ===================================================================== */
.why-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(28px, 5vw, 72px); align-items: start; }
.why-list { margin-top: 28px; display: grid; gap: 4px; }
.why-item { display: flex; gap: 16px; padding: 18px 0; border-top: 1px solid var(--line); }
.why-item:first-child { border-top: 0; }
.why-item .wm-ic { width: 44px; height: 44px; flex: none; border-radius: 12px; background: var(--paper); border: 1px solid var(--line); display: grid; place-items: center; color: var(--orange-deep); }
.why-item .wm-ic svg { width: 22px; height: 22px; }
.why-item h3 { font-size: 1.1rem; }
.why-item p { color: var(--ink-2); font-size: .95rem; margin-top: 3px; }

/* Presse-Karte */
.press { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(24px, 3.5vw, 38px); box-shadow: var(--shadow-sm); }
.press .eyebrow { margin-bottom: 18px; }
.press-row { display: flex; align-items: baseline; gap: 14px; padding: 15px 0; border-top: 1px dashed var(--line-2); }
.press-row:first-of-type { border-top: 0; }
.press-name { font-family: var(--f-display); font-weight: 800; font-size: 1.15rem; color: var(--ink); flex: none; min-width: 92px; }
.press-name i { font-style: italic; }
.press-desc { color: var(--ink-2); font-size: .9rem; flex: 1; }
.press-date { color: var(--ink-3); font-size: .8rem; font-weight: 600; white-space: nowrap; }
.press-foot { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--line); font-size: .85rem; color: var(--ink-3); }

/* =====================================================================
   MASCOT-SEKTION
   ===================================================================== */
.mascot-sec { background: var(--teal); color: #EAF1F1; overflow: hidden; position: relative; }
.mascot-sec .wrap { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(28px, 5vw, 64px); align-items: center; }
.mascot-sec .eyebrow { color: var(--orange-soft); }
.mascot-sec .eyebrow::before { background: var(--orange-soft); }
.mascot-sec h2 { color: #fff; }
.mascot-sec .lead { color: #CFE0E1; }
.mascot-stage { position: relative; display: grid; place-items: center; }
.mascot-stage .disc { position: absolute; width: min(360px, 86%); aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle at 50% 45%, rgba(224,168,123,.16), transparent 68%); }
.mascot-stage .mascot { position: relative; left: -56px; width: min(300px, 78%); filter: drop-shadow(0 24px 28px rgba(0,0,0,.28)); }
.speech { position: absolute; top: 6%; right: -2%; background: #fff; color: var(--ink); border-radius: 16px 16px 16px 4px; padding: 13px 16px; font-weight: 600; font-size: .92rem; max-width: 210px; box-shadow: var(--shadow); line-height: 1.4; }
.mascot-facts { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.mascot-facts .mf { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); border-radius: var(--pill); padding: 8px 15px; font-weight: 600; font-size: .9rem; color: #EAF1F1; }
.mascot-facts .mf svg { width: 16px; height: 16px; color: var(--orange-soft); flex: none; }

/* =====================================================================
   REFERENZEN / PROJEKTE
   ===================================================================== */
.refs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 42px; }
.ref { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); padding: 26px; }
.ref .badge { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--orange-deep); }
.ref h3 { font-size: 1.18rem; margin: 10px 0 8px; }
.ref p { color: var(--ink-2); font-size: .94rem; }
.ref .link { margin-top: 14px; display: inline-flex; gap: 6px; font-weight: 700; font-size: .9rem; color: var(--ink); }

/* =====================================================================
   KONTAKT-CTA
   ===================================================================== */
.cta { position: relative; }
.cta-card {
  background: var(--orange); color: #fff; border-radius: var(--r-lg);
  padding: clamp(34px, 5vw, 64px); position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1.3fr .7fr; gap: 32px; align-items: center;
}
.cta-card::after { content: ""; position: absolute; right: -60px; bottom: -80px; width: 320px; height: 320px; border-radius: 50%; background: rgba(255,255,255,.10); }
.cta-card .eyebrow { color: #FFE3D3; }
.cta-card .eyebrow::before { background: #fff; }
.cta-card h2 { color: #fff; font-size: clamp(2rem, 3.6vw, 2.9rem); }
.cta-card p { color: #FFE9DD; margin-top: 14px; font-size: 1.08rem; max-width: 42ch; }
.cta-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.btn-on-orange { background-color: #fff; color: var(--orange-deep); }
.btn-on-orange:hover { background-color: var(--cream); }
.btn-outline-w { background: transparent; color: #fff; border-color: rgba(255,255,255,.6); }
.btn-outline-w:hover { border-color: #fff; background: rgba(255,255,255,.12); }
.cta-side { position: relative; z-index: 1; }
.cta-contact { background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22); border-radius: var(--r); padding: 22px; }
.cta-contact .row { display: flex; align-items: center; gap: 12px; padding: 9px 0; }
.cta-contact .row svg { width: 20px; height: 20px; flex: none; color: #FFE3D3; }
.cta-contact .row b { display: block; font-size: 1.05rem; }
.cta-contact .row small { color: #FFE9DD; }
.cta-note { display: inline-flex; align-items: center; gap: 8px; margin-top: 14px; font-size: .85rem; color: #FFE9DD; font-weight: 600; }

/* =====================================================================
   FOOTER
   ===================================================================== */
footer.site { background: var(--ink); color: #C9BEB1; padding-block: clamp(48px, 6vw, 72px) 28px; }
footer.site a { color: #C9BEB1; }
footer.site a:hover { color: #fff; }
.foot-top { display: grid; grid-template-columns: 2.3fr 1fr 1fr 1fr 1fr; gap: 36px 48px; }
.foot-brand .brand .wm-name { color: #fff; }
.foot-brand p { color: #978B7D; font-size: .92rem; margin-top: 16px; max-width: 34ch; }
.foot-addr { margin-top: 20px; list-style: none; padding: 0; display: grid; gap: 11px; max-width: 30ch; }
.foot-addr li { display: flex; gap: 11px; align-items: flex-start; font-size: .92rem; color: #C2B7A9; line-height: 1.5; }
.foot-addr li svg { width: 17px; height: 17px; flex: none; margin-top: 2px; color: var(--orange-soft); }
.foot-addr a { color: #C2B7A9; }
.foot-addr a:hover { color: #fff; }
.foot-col h4 { font-family: var(--f-text); font-weight: 700; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: #978B7D; margin-bottom: 14px; }
.foot-col ul { list-style: none; padding: 0; display: grid; gap: 9px; }
.foot-col a { font-size: .95rem; }
.foot-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.foot-badges .b { font-size: .78rem; font-weight: 600; color: #B5A99B; border: 1px solid #3A332D; border-radius: var(--pill); padding: 6px 12px; }
.foot-bottom { margin-top: 40px; padding-top: 22px; border-top: 1px solid #3A332D; display: flex; flex-wrap: wrap; gap: 12px 24px; align-items: center; justify-content: space-between; font-size: .85rem; color: #8C8073; }
.foot-bottom > span { white-space: nowrap; }
.foot-bottom nav { display: flex; gap: 8px 14px; flex-wrap: wrap; }
.foot-bottom nav .sep-strong { color: #5A5048; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1000px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-stage { min-height: 0; margin-top: 8px; }
  .why-grid { grid-template-columns: 1fr; }
  .mascot-sec .wrap { grid-template-columns: 1fr; }
  .mascot-stage { order: -1; }
  .cta-card { grid-template-columns: 1fr; }
  .svc-feature, .svc-small { grid-column: span 3; }
  .svc-grid { grid-template-columns: repeat(6, 1fr); }
  .refs { grid-template-columns: 1fr; }
  .foot-top { grid-template-columns: 1.4fr 1fr 1fr; }
  .foot-brand { grid-column: 1 / -1; }
  .domaincheck { grid-template-columns: 1fr; }
}
@media (max-width: 1000px) {
  nav.main, .kc-link, .header-cta::before { display: none; }
  .burger { display: flex; }
}
@media (max-width: 820px) {
  .statband .wrap { grid-template-columns: 1fr 1fr; }
  .statband .cell:nth-child(3) { border-left: 0; }
  .statband .cell:nth-child(odd) { border-left: 0; }
  .svc-feature, .svc-small { grid-column: span 6; }
  .speech { position: static; max-width: none; margin-bottom: 16px; }
}
@media (max-width: 540px) {
  .statband .wrap { grid-template-columns: 1fr; }
  .statband .cell { border-left: 0; border-top: 1px solid var(--line); }
  .statband .cell:first-child { border-top: 0; }
  .foot-top { grid-template-columns: 1fr 1fr; }
  .foot-brand { grid-column: 1 / -1; }
  .foot-bottom { flex-direction: column; align-items: flex-start; }
  .foot-bottom > span { white-space: normal; }
  .dc-form { min-width: 0; width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto !important; }
}

/* =====================================================================
   DESIGN-POLISH
   ===================================================================== */
/* Statband – sanftes Hover-Highlight */
.statband .cell { transition: background .2s ease; }
.statband .cell:hover { background: var(--cream-2); }

/* Service-Karten – edler Hover: Akzentkante oben füllt sich */
.svc { transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease; }
.svc::after { content: ""; position: absolute; left: 0; top: 0; height: 3px; width: 0; background: var(--orange); border-radius: var(--r) var(--r) 0 0; transition: width .3s ease; }
.svc:hover::after { width: 100%; }

/* =====================================================================
   TWEAKS-PANEL
   ===================================================================== */
.tweaks-panel {
  position: fixed; right: 18px; bottom: 18px; z-index: 200;
  width: 248px; background: var(--paper); color: var(--ink);
  border: 1px solid var(--line-2); border-radius: 16px;
  box-shadow: var(--shadow-lg); padding: 16px; font-family: var(--f-text);
}
.tweaks-panel[hidden] { display: none; }
.tw-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.tw-title { font-family: var(--f-display); font-weight: 800; font-size: 1.05rem; letter-spacing: -.01em; }
.tw-close { width: 28px; height: 28px; border: 0; background: var(--cream-2); border-radius: 8px; font-size: 1.2rem; line-height: 1; color: var(--ink-2); display: grid; place-items: center; }
.tw-close:hover { background: var(--orange-tint); color: var(--orange-deep); }
.tw-group { margin-bottom: 14px; }
.tw-label { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 9px; }
.tw-swatches { display: flex; gap: 9px; }
.tw-swatches button {
  width: 38px; height: 38px; border-radius: 11px; border: 2px solid var(--line-2);
  background: var(--sw); position: relative; transition: transform .12s ease, border-color .12s ease;
}
.tw-swatches button:hover { transform: translateY(-2px); }
.tw-swatches button[aria-pressed="true"] { border-color: var(--ink); }
.tw-swatches button[aria-pressed="true"]::after {
  content: "✓"; position: absolute; inset: 0; display: grid; place-items: center;
  color: #fff; font-size: .9rem; font-weight: 800; text-shadow: 0 1px 2px rgba(0,0,0,.4);
}
.tw-note { font-size: .74rem; color: var(--ink-3); font-weight: 600; }

/* =====================================================================
   PHASE 2 — Trust-Faktenleiste, Umzug-Schritte, kompakte Services
   ===================================================================== */
.trustline { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--sand); }
.trustline .wrap { display: grid; grid-template-columns: repeat(4, 1fr); }
.trustline .ti { padding: 22px 24px; border-left: 1px solid var(--line); }
.trustline .ti:first-child { border-left: 0; padding-left: 0; }
.trustline .ti b { display: block; font-family: var(--f-display); font-weight: 700; font-size: 1.02rem; color: var(--ink); letter-spacing: -.01em; }
.trustline .ti span { display: block; font-size: .86rem; color: var(--ink-2); margin-top: 3px; }
@media (max-width: 820px) {
  .trustline .wrap { grid-template-columns: 1fr 1fr; }
  .trustline .ti { border-left: 0; padding: 18px 0; border-top: 1px solid var(--line); }
  .trustline .ti:nth-child(-n+2) { border-top: 0; }
}
@media (max-width: 460px) { .trustline .wrap { grid-template-columns: 1fr; } .trustline .ti:nth-child(2) { border-top: 1px solid var(--line); } }

/* Umzug in 3 Schritten */
.moveflow { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 44px; }
.mstep { position: relative; padding-top: 6px; }
.mstep .mno { font-family: var(--f-display); font-weight: 800; font-size: 2.4rem; color: var(--orange); line-height: 1; letter-spacing: -.02em; display: block; }
.mstep h3 { font-size: 1.25rem; margin: 14px 0 8px; }
.mstep p { color: var(--ink-2); font-size: .97rem; max-width: 38ch; }
.mstep::before { content: ""; position: absolute; top: 14px; left: 64px; right: -22px; height: 1px; background: repeating-linear-gradient(90deg, var(--line-2) 0 7px, transparent 7px 13px); }
.mstep:last-child::before { display: none; }
.moveflow-cta { margin-top: 40px; }
@media (max-width: 820px) { .moveflow { grid-template-columns: 1fr; gap: 26px; } .mstep::before { display: none; } }

/* Services entdichtet: kleine Karten klar sekundär (kompakter, ruhiger) */
.svc-small { padding: 22px; }
.svc-small .ic-wrap { width: 42px; height: 42px; border-radius: 11px; margin-bottom: 13px; }
.svc-small .ic-wrap svg { width: 21px; height: 21px; }
.svc-small h3 { font-size: 1.12rem; }
.svc-small .price { background: transparent; padding: 0; color: var(--ink-3); font-weight: 700; }
.svc-small p { font-size: .92rem; }

/* Presse: Wortmarken-Reihe */
.press-marks { display: flex; flex-wrap: wrap; gap: 14px 26px; align-items: flex-end; margin: 20px 0 18px; }
.press-marks .pm { font-family: var(--f-display); font-weight: 800; font-size: 1.5rem; color: var(--ink); letter-spacing: -.01em; line-height: 1; display: inline-flex; flex-direction: column; gap: 4px; opacity: .85; transition: opacity .2s ease; }
.press-marks .pm:hover { opacity: 1; }
.press-marks .pm i { font-style: italic; }
.press-marks .pm b { color: var(--orange); }
.press-marks .pm small { font-family: var(--f-text); font-weight: 600; font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); }
.press-line { color: var(--ink-2); font-size: .95rem; line-height: 1.6; padding-top: 16px; border-top: 1px solid var(--line); }
.press-line a { color: var(--orange-deep); font-weight: 700; white-space: nowrap; }
/* Verlagshaus-Label in der Presse-Zeile */
.press-row .press-pub { font-family: var(--f-text); font-weight: 700; font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); white-space: nowrap; }
.press-foot a { color: var(--orange-deep); font-weight: 700; white-space: nowrap; }

/* Wally als Guide (Hilfe-/Anleitungs-Seiten) */
.wally-guide-stage { display: grid; place-items: center; }
.wally-guide { width: min(300px, 86%); filter: drop-shadow(0 20px 26px rgba(80,45,15,.14)); }
@media (max-width: 760px) { .wally-guide-stage { display: none; } }
