/* ============================================================
   PRAXIS-STUDIO · LEISTUNGS-DETAILSEITEN — geteiltes Design-System
   Eine Quelle für alle 15 Leistungsseiten. Pro Leistung wird nur
   der Content getauscht, nicht dieses Stylesheet.
   Marke: Dark #050505 · Cream #F8F6F1 · EINE Akzentfarbe Vintage Port #6E2F3F
   Fonts: Syne (Display, uppercase) · Onest (Body)
   Guardrails: kein italic · Bilder scharf (kein radius/shadow) ·
   Headlines ohne finalen Punkt · keine Marquees · Buttons = Underline-Sweep
   ============================================================ */

:root {
  --paper: #050505;
  --cream: #F8F6F1;
  --moss: #F8F6F1;   /* Mikro-Labels = Cream; Hierarchie über Größe/Letter-Spacing (kein Grün, kein Grau) */
  --accent: #6E2F3F;
  --port-deep: #210C12;
  --panel: #0c0b0b;
  --panel-2: #100e0e;
  --line: rgba(248,246,241,0.12);
  --line-soft: rgba(248,246,241,0.07);
  --sec-pad: clamp(120px, 12vw, 180px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---- Base / dark theme (eine Definition, kein Kaskaden-Override) ---- */
html { background: #050505 !important; }
body { background: #050505; color: var(--cream); }
.svc-page { background: transparent; color: var(--cream); position: relative; }
.svc-page * { box-sizing: border-box; }
.svc-page section { font-family: 'Onest', 'Inter', system-ui, sans-serif; position: relative; }
.svc-page ::selection { background: var(--accent); color: var(--cream); }
.svc-page ::-moz-selection { background: var(--accent); color: var(--cream); }
.svc-page img, .svc-page picture, .svc-page figure { border-radius: 0 !important; box-shadow: none !important; }
.svc-page em, .svc-page i { font-style: normal; }

/* Intro-/Page-Loader neutralisieren (kein Yucca-Logo-Flash) */
.intro-loader, .page-loader { display: none !important; }
html.show-intro .intro-loader { display: none !important; }

/* ---- Wrapper / Rhythmus ---- */
.svc-wrap { max-width: 1440px; margin: 0 auto; padding: 0 40px; }
.svc-wrap-narrow { max-width: 1080px; margin: 0 auto; padding: 0 40px; }
@media (max-width: 768px) { .svc-wrap, .svc-wrap-narrow { padding: 0 24px; } }

/* ---- Reveal-on-Scroll (Default-Hidden auch defensiv per CSS) ---- */
.svc-page .reveal { opacity: 0; transform: translateY(48px); transition: opacity 1.05s var(--ease), transform 1.05s var(--ease); }
.svc-page .reveal.in { opacity: 1; transform: translateY(0); }
.svc-page .reveal-d1 { transition-delay: .10s; }
.svc-page .reveal-d2 { transition-delay: .20s; }
.svc-page .reveal-d3 { transition-delay: .32s; }
.svc-page .reveal-d4 { transition-delay: .44s; }
@media (prefers-reduced-motion: reduce) {
  .svc-page .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ---- Typo-Bausteine ---- */
.svc-kicker { font-family: 'Onest', sans-serif; font-size: 12px; font-weight: 400; letter-spacing: 0.26em; text-transform: uppercase; color: var(--moss); margin: 0; }
.svc-display { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; letter-spacing: -0.03em; word-spacing: 0.06em; line-height: 1.02; color: var(--cream); margin: 0; }
.svc-h2 { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; letter-spacing: -0.028em; word-spacing: 0.05em; line-height: 1.06; color: var(--cream); margin: 0; font-size: clamp(32px, 4.6vw, 72px); }
.svc-lead { font-family: 'Onest', sans-serif; font-weight: 300; font-size: clamp(18px, 1.5vw, 24px); line-height: 1.55; color: rgba(248,246,241,0.78); margin: 0; }
.svc-body { font-family: 'Onest', sans-serif; font-weight: 300; font-size: clamp(16px, 1.1vw, 18px); line-height: 1.65; color: rgba(248,246,241,0.72); margin: 0; }
.svc-rule { display: block; width: 200px; max-width: 100%; height: 2px; background: var(--accent); transform-origin: left center; }

/* Akzentlinie als Reveal (wächst beim Einscrollen) */
.svc-rule.reveal { opacity: 1; transform: scaleX(0); transition: transform 1s var(--ease) .15s; }
.svc-rule.reveal.in { transform: scaleX(1); }

/* ============================================================
   BUTTONS — Underline-Cinéma (kein Aurora/3D/Trail)
   ============================================================ */
.uu-btn { display: inline-flex; align-items: baseline; gap: 13px; padding: 10px 2px 13px; border: 0; border-radius: 0; background: transparent; font-family: 'Syne', system-ui, sans-serif; font-weight: 600; font-size: 15px; letter-spacing: 0.04em; text-transform: uppercase; word-spacing: 0.06em; text-decoration: none; position: relative; cursor: pointer; transition: color .55s ease; }
.uu-btn .uu-btn-label { position: relative; z-index: 2; line-height: 1.05; }
.uu-btn .uu-btn-arrow { position: relative; z-index: 2; display: inline-block; font-size: 15px; line-height: 1; transition: transform .5s cubic-bezier(.7,0,.2,1); }
.uu-btn::after, .uu-btn::before { content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px; pointer-events: none; }
.uu-btn::after { background: currentColor; opacity: 0.5; transform-origin: right center; transform: scaleX(1); transition: transform .55s cubic-bezier(.7,0,.2,1); }
.uu-btn::before { background: var(--accent); height: 2px; transform-origin: left center; transform: scaleX(0); transition: transform .6s cubic-bezier(.7,0,.2,1) .15s; z-index: 1; }
.uu-btn:hover .uu-btn-arrow { transform: translateX(11px); }
.uu-btn:hover::after { transform: scaleX(0); }
.uu-btn:hover::before { transform: scaleX(1); }
.uu-btn-dark, .uu-btn-light { color: var(--cream); }

/* Solid-Pill-Variante für den Haupt-CTA (premium, ruhig) */
.svc-cta-pill { display: inline-flex; align-items: center; gap: 12px; padding: 17px 30px; border: 1px solid var(--cream); border-radius: 999px; background: var(--cream); color: #0a0708; font-family: 'Syne', sans-serif; font-weight: 600; font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase; text-decoration: none; transition: background .5s var(--ease), color .5s var(--ease), border-color .5s var(--ease); }
.svc-cta-pill .svc-pill-arrow { display: inline-block; transition: transform .5s cubic-bezier(.7,0,.2,1); }
.svc-cta-pill:hover { background: transparent; color: var(--cream); border-color: var(--cream); }
.svc-cta-pill:hover .svc-pill-arrow { transform: translateX(7px); }
.svc-cta-ghost { display: inline-flex; align-items: center; gap: 12px; padding: 17px 30px; border: 1px solid var(--line); border-radius: 999px; background: transparent; color: var(--cream); font-family: 'Syne', sans-serif; font-weight: 600; font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase; text-decoration: none; transition: border-color .5s var(--ease), background .5s var(--ease); }
.svc-cta-ghost:hover { border-color: var(--cream); background: rgba(248,246,241,0.04); }
.svc-cta-row { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; }

/* ============================================================
   1 · HERO
   ============================================================ */
.svc-hero { min-height: 100vh; padding: 200px 0 110px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; }
.svc-breadcrumb { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; font-family: 'Onest', sans-serif; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--moss); margin: 0 0 64px; }
.svc-breadcrumb a { color: var(--moss); text-decoration: none; transition: color .35s ease; }
.svc-breadcrumb a:hover { color: var(--cream); }
.svc-breadcrumb .svc-bc-sep { width: 14px; height: 1px; background: rgba(112,119,103,0.5); display: inline-block; }
.svc-breadcrumb .svc-bc-current { color: var(--cream); }
.svc-hero-grid { display: grid; grid-template-columns: 1.45fr 1fr; gap: 80px; align-items: end; }
.svc-hero h1 { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; font-size: clamp(36px, 9vw, 150px); line-height: 0.9; letter-spacing: -0.035em; color: var(--cream); margin: 0 0 40px; }
.svc-hero .svc-hero-sub { font-family: 'Onest', sans-serif; font-weight: 300; font-size: clamp(19px, 1.6vw, 26px); line-height: 1.5; color: rgba(248,246,241,0.8); margin: 0 0 48px; max-width: 640px; }
.svc-hero-aside { position: relative; padding-bottom: 8px; }
.svc-hero-meta { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--line); }
.svc-hero-meta li { display: flex; justify-content: space-between; gap: 20px; padding: 18px 0; border-bottom: 1px solid var(--line-soft); font-family: 'Onest', sans-serif; }
.svc-hero-meta .svc-meta-k { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--moss); }
.svc-hero-meta .svc-meta-v { font-size: 14px; font-weight: 300; color: var(--cream); text-align: right; }
.svc-hero-mark { position: absolute; top: -150px; right: 0; width: clamp(150px, 16vw, 230px); height: auto; color: rgba(110,47,63,0.85); opacity: 0.9; pointer-events: none; }
.svc-hero-mark .svc-ring-spin { transform-box: fill-box; transform-origin: center; animation: svc-spin 38s linear infinite; }
@keyframes svc-spin { to { transform: rotate(360deg); } }
.svc-scroll-cue { display: inline-flex; align-items: center; gap: 16px; margin-top: 56px; font-family: 'Onest', sans-serif; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--moss); }
.svc-scroll-cue .svc-cue-line { width: 46px; height: 1px; background: var(--accent); display: inline-block; transform-origin: left; animation: svc-pulse 2.6s ease-in-out infinite; }
@keyframes svc-pulse { 0%,100% { transform: scaleX(.6); opacity: .5; } 50% { transform: scaleX(1.3); opacity: 1; } }
@media (max-width: 1024px) {
  .svc-hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .svc-hero-mark { position: static; margin-bottom: 28px; }
}
@media (max-width: 768px) { .svc-hero { padding: 150px 0 80px; min-height: auto; } .svc-breadcrumb { margin-bottom: 40px; } }

/* ============================================================
   2 · MANIFEST (warum es zählt) + Aura-Bloom
   ============================================================ */
.svc-manifest { padding: var(--sec-pad) 0; text-align: center; overflow: hidden; }
.svc-manifest .svc-manifest-body { position: relative; z-index: 2; font-family: 'Onest', sans-serif; font-weight: 300; font-size: clamp(26px, 3.2vw, 52px); line-height: 1.18; letter-spacing: -0.012em; color: var(--cream); margin: 0 auto; max-width: 1080px; }
.svc-manifest .svc-manifest-body .svc-dim { color: var(--moss); }
.svc-bloomwrap { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.svc-bloom { position: absolute; top: 50%; left: 50%; width: 45vmin; height: 45vmin; margin: -22.5vmin 0 0 -22.5vmin; border-radius: 50%; background: radial-gradient(circle, rgba(110,47,63,.9) 0%, rgba(110,47,63,.4) 38%, transparent 72%); transform: scale(.04); opacity: 0; animation: svc-bloom 6s ease-out infinite; animation-play-state: paused; will-change: transform, opacity; }
.svc-bloom-ring { position: absolute; top: 50%; left: 50%; border-radius: 50%; border: 1px solid rgba(248,246,241,.13); transform: translate(-50%,-50%); animation-play-state: paused; }
.svc-bloom-ring.r1 { width: 42vmin; height: 42vmin; border-style: dashed; animation: svc-ring-spin 56s linear infinite; }
.svc-bloom-ring.r2 { width: 72vmin; height: 72vmin; border-color: rgba(248,246,241,.07); animation: svc-ring-spin 84s linear infinite reverse; }
.is-bloom .svc-bloom, .is-bloom .svc-bloom-ring { animation-play-state: running; }
@keyframes svc-bloom { 0% { transform: scale(.04); opacity: 0; } 9% { opacity: 1; } 55% { opacity: .55; } 100% { transform: scale(2.9); opacity: 0; } }
@keyframes svc-ring-spin { to { transform: translate(-50%,-50%) rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .svc-bloom { animation: none; transform: scale(1.4); opacity: .16; } .svc-bloom-ring { animation: none; } }

/* ============================================================
   Section-Head (wiederverwendbar)
   ============================================================ */
.svc-sec { padding: var(--sec-pad) 0; }
.svc-sec-head { max-width: 1080px; margin: 0 0 80px; }
.svc-sec-head .svc-kicker { margin-bottom: 26px; }
.svc-sec-head .svc-h2 { margin-bottom: 28px; }
.svc-sec-head .svc-lead { max-width: 720px; }

/* ============================================================
   3 · WERTE / KERNNUTZEN (3er-Grid)
   ============================================================ */
.svc-values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--line); }
.svc-value { padding: 56px 44px 56px 0; border-bottom: 1px solid var(--line); }
.svc-value + .svc-value { padding-left: 44px; border-left: 1px solid var(--line); }
.svc-value-num { font-family: 'Syne', sans-serif; font-weight: 600; font-size: 13px; letter-spacing: 0.12em; color: var(--accent); margin: 0 0 28px; }
.svc-value h3 { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; font-size: clamp(22px, 1.9vw, 30px); line-height: 1.1; letter-spacing: -0.02em; color: var(--cream); margin: 0 0 20px; }
.svc-value p { font-family: 'Onest', sans-serif; font-weight: 300; font-size: 16px; line-height: 1.62; color: rgba(248,246,241,0.7); margin: 0; }
@media (max-width: 900px) {
  .svc-values-grid { grid-template-columns: 1fr; }
  .svc-value, .svc-value + .svc-value { padding: 40px 0; border-left: 0; }
}

/* ============================================================
   4 · LEISTUNGSUMFANG / DELIVERABLES
   ============================================================ */
.svc-deliver { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 80px; align-items: start; }
.svc-deliver-list { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--line); }
.svc-deliver-list li { display: grid; grid-template-columns: 28px 1fr; gap: 18px; align-items: start; padding: 24px 0; border-bottom: 1px solid var(--line-soft); }
.svc-deliver-list .svc-check { width: 22px; height: 22px; margin-top: 2px; flex-shrink: 0; }
.svc-deliver-list .svc-check svg { width: 100%; height: 100%; display: block; color: var(--accent); }
.svc-deliver-list .svc-d-title { display: block; font-family: 'Onest', sans-serif; font-weight: 500; font-size: clamp(16px, 1.15vw, 19px); color: var(--cream); margin: 0 0 5px; }
.svc-deliver-list .svc-d-desc { display: block; font-family: 'Onest', sans-serif; font-weight: 300; font-size: 14.5px; line-height: 1.55; color: rgba(248,246,241,0.62); margin: 0; }
@media (max-width: 900px) { .svc-deliver { grid-template-columns: 1fr; gap: 44px; } }

/* ============================================================
   5 · PROZESS / ABLAUF
   ============================================================ */
.svc-process-steps { border-top: 1px solid var(--line); }
.svc-step { display: grid; grid-template-columns: 140px 1fr; gap: 48px; padding: 52px 0; border-bottom: 1px solid var(--line); align-items: start; }
.svc-step-num { font-family: 'Syne', sans-serif; font-weight: 600; font-size: clamp(40px, 5vw, 76px); line-height: 0.9; letter-spacing: -0.04em; color: transparent; -webkit-text-stroke: 1.3px rgba(248,246,241,0.4); }
.svc-step-body h3 { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; font-size: clamp(22px, 2.1vw, 34px); line-height: 1.08; letter-spacing: -0.02em; color: var(--cream); margin: 0 0 8px; }
.svc-step-body .svc-step-rule { display: block; width: 90px; height: 2px; background: var(--accent); transform-origin: left; margin: 0 0 22px; transform: scaleX(0); transition: transform .9s var(--ease) .1s; }
.svc-step-body.in .svc-step-rule, .svc-step.in .svc-step-rule { transform: scaleX(1); }
.svc-step-body p { font-family: 'Onest', sans-serif; font-weight: 300; font-size: clamp(15px, 1.1vw, 18px); line-height: 1.62; color: rgba(248,246,241,0.7); margin: 0; max-width: 680px; }
.svc-process-foot { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 32px; padding-top: 44px; }
.svc-process-foot .svc-timeline { display: inline-flex; align-items: center; gap: 12px; font-family: 'Onest', sans-serif; font-size: 13px; letter-spacing: 0.06em; color: rgba(248,246,241,0.72); }
.svc-process-foot .svc-timeline .svc-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); flex-shrink: 0; animation: svc-blink 2.3s ease-in-out infinite; }
@keyframes svc-blink { 0%,100% { opacity: .5; } 50% { opacity: 1; } }
@media (max-width: 768px) { .svc-step { grid-template-columns: 1fr; gap: 14px; padding: 40px 0; } }

/* ============================================================
   6 · BEISPIELE / SHOWCASE
   ============================================================ */
.svc-examples-group + .svc-examples-group { margin-top: 88px; }
.svc-examples-grouptitle { display: flex; align-items: baseline; gap: 16px; margin: 0 0 36px; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.svc-examples-grouptitle h3 { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; font-size: clamp(16px, 1.4vw, 21px); letter-spacing: 0.02em; color: var(--cream); margin: 0; }
.svc-examples-grouptitle .svc-eg-count { font-family: 'Onest', sans-serif; font-size: 12px; letter-spacing: 0.14em; color: var(--moss); }
.svc-examples-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.svc-logo-card { position: relative; background: var(--panel); border: 1px solid var(--line); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; padding: 40px; overflow: hidden; transition: border-color .5s var(--ease), background .5s var(--ease); }
.svc-logo-card:hover { border-color: rgba(248,246,241,0.28); background: var(--panel-2); }
.svc-logo-card img, .svc-logo-card svg { max-width: 72%; max-height: 60%; width: auto; height: auto; object-fit: contain; display: block; }
.svc-logo-card .svc-logo-cap { position: absolute; left: 18px; bottom: 16px; right: 18px; display: flex; justify-content: space-between; align-items: baseline; gap: 12px; opacity: 0; transform: translateY(8px); transition: opacity .45s ease, transform .45s ease; }
.svc-logo-card:hover .svc-logo-cap { opacity: 1; transform: translateY(0); }
.svc-logo-cap .svc-logo-name { font-family: 'Onest', sans-serif; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--cream); margin: 0; }
.svc-logo-cap .svc-logo-field { font-family: 'Onest', sans-serif; font-size: 11px; letter-spacing: 0.06em; color: var(--moss); margin: 0; }
/* Feature-Karte mit Kontext (1–2 pro Galerie) */
.svc-logo-card.is-wide { grid-column: span 2; aspect-ratio: auto; flex-direction: column; align-items: flex-start; justify-content: center; gap: 26px; padding: 48px; }
.svc-logo-card.is-wide .svc-logo-feature-mark { width: 100%; display: flex; align-items: center; justify-content: center; min-height: 160px; }
.svc-logo-card.is-wide img, .svc-logo-card.is-wide svg { max-width: 60%; max-height: 180px; }
.svc-logo-card.is-wide .svc-logo-context { font-family: 'Onest', sans-serif; font-weight: 300; font-size: 15px; line-height: 1.6; color: rgba(248,246,241,0.7); margin: 0; max-width: 560px; }
.svc-logo-card.is-wide .svc-logo-cap { position: static; opacity: 1; transform: none; }
@media (max-width: 900px) { .svc-examples-grid { grid-template-columns: repeat(2, 1fr); } .svc-logo-card.is-wide { grid-column: span 2; } }
@media (max-width: 560px) { .svc-examples-grid { grid-template-columns: 1fr; } .svc-logo-card.is-wide { grid-column: span 1; } }

/* 4er-Variante: 2×2-Galerie, großzügiger als das 3er-Raster */
.svc-examples-grid.is-quad { grid-template-columns: repeat(2, 1fr); gap: 26px; }
.svc-examples-grid.is-quad .svc-logo-card { aspect-ratio: 16/9; }
@media (max-width: 560px) { .svc-examples-grid.is-quad { grid-template-columns: 1fr; } }

/* ============================================================
   6b · ATMOSPHÄRISCHE BILD-BREATHER (monochrom getönt, full-bleed)
   Ruhige Studio-Fotos zwischen den Text-Sektionen. Immer grayscale
   → garantiert kein Farbstich (Brand-Regel: monochrom).
   ============================================================ */
.svc-figure { position: relative; width: 100%; margin: 0; overflow: hidden; background: #0a0908; }
.svc-figure img { width: 100%; height: 100%; object-fit: cover; display: block; filter: grayscale(1) brightness(0.64) contrast(1.05); transform: scale(1.03); transition: transform 1.3s var(--ease), filter 1.3s var(--ease); }
.svc-figure:hover img { transform: scale(1); filter: grayscale(1) brightness(0.72) contrast(1.05); }
.svc-figure::after { content: ''; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(180deg, rgba(5,5,5,0.52) 0%, rgba(5,5,5,0.12) 40%, rgba(5,5,5,0.6) 100%); }
.svc-figure-band { aspect-ratio: 24 / 9; }
.svc-figure-cap { position: absolute; left: clamp(24px, 5vw, 80px); bottom: clamp(20px, 3.5vw, 46px); z-index: 2; font-family: 'Onest', sans-serif; font-weight: 400; font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(248,246,241,0.74); margin: 0; }
@media (max-width: 700px) { .svc-figure-band { aspect-ratio: 4 / 3; } }

/* ============================================================
   7 · WARUM PRAXIS-STUDIO (Differenzierung + Vergleich)
   ============================================================ */
.svc-why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.svc-why-points { list-style: none; margin: 0; padding: 0; }
.svc-why-points li { padding: 30px 0; border-bottom: 1px solid var(--line-soft); }
.svc-why-points li:first-child { border-top: 1px solid var(--line); }
.svc-why-points h4 { font-family: 'Onest', sans-serif; font-weight: 500; font-size: clamp(17px, 1.3vw, 21px); color: var(--cream); margin: 0 0 8px; }
.svc-why-points p { font-family: 'Onest', sans-serif; font-weight: 300; font-size: 15px; line-height: 1.58; color: rgba(248,246,241,0.66); margin: 0; }
.svc-compare { border: 1px solid var(--line); background: var(--panel); }
.svc-compare-row { display: grid; grid-template-columns: 1fr 1fr; }
.svc-compare-col { padding: 34px 30px; }
.svc-compare-col + .svc-compare-col { border-left: 1px solid var(--line); }
.svc-compare-col.is-them { background: transparent; }
.svc-compare-col.is-us { background: rgba(110,47,63,0.10); }
.svc-compare-col .svc-cc-label { font-family: 'Onest', sans-serif; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; margin: 0 0 22px; }
.svc-compare-col.is-them .svc-cc-label { color: var(--moss); }
.svc-compare-col.is-us .svc-cc-label { color: var(--cream); }
.svc-compare-col ul { list-style: none; margin: 0; padding: 0; }
.svc-compare-col li { font-family: 'Onest', sans-serif; font-weight: 300; font-size: 14.5px; line-height: 1.5; color: rgba(248,246,241,0.7); padding: 11px 0 11px 22px; position: relative; }
.svc-compare-col li::before { content: ""; position: absolute; left: 0; top: 19px; width: 9px; height: 1px; background: currentColor; opacity: .5; }
.svc-compare-col.is-us li { color: rgba(248,246,241,0.92); }
@media (max-width: 900px) { .svc-why-grid { grid-template-columns: 1fr; gap: 48px; } }
@media (max-width: 560px) { .svc-compare-row { grid-template-columns: 1fr; } .svc-compare-col + .svc-compare-col { border-left: 0; border-top: 1px solid var(--line); } }

/* ============================================================
   8 · INVESTITION (value-framed, auf Anfrage)
   ============================================================ */
.svc-invest { padding: var(--sec-pad) 0; text-align: center; }
.svc-invest .svc-invest-inner { max-width: 920px; margin: 0 auto; }
.svc-invest .svc-invest-statement { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; font-size: clamp(26px, 3.2vw, 50px); line-height: 1.08; letter-spacing: -0.028em; color: var(--cream); margin: 0 0 36px; }
.svc-invest .svc-invest-statement .svc-dim { color: var(--moss); }
.svc-invest .svc-body { margin: 0 auto 44px; max-width: 680px; }
.svc-invest .svc-invest-factors { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin: 0 auto 52px; max-width: 760px; }
.svc-invest .svc-invest-factors span { font-family: 'Onest', sans-serif; font-size: 12.5px; letter-spacing: 0.04em; color: rgba(248,246,241,0.78); border: 1px solid var(--line); border-radius: 999px; padding: 9px 18px; }
.svc-invest .svc-cta-row { justify-content: center; }

/* ============================================================
   9 · FAQ (Accordion)
   ============================================================ */
.svc-faq-grid { display: grid; grid-template-columns: 0.7fr 1.3fr; gap: 72px; align-items: start; }
.svc-faq-list { border-top: 1px solid var(--line); }
.svc-faq-item { border-bottom: 1px solid var(--line); }
.svc-faq-q { width: 100%; text-align: left; background: transparent; border: 0; cursor: pointer; display: flex; align-items: flex-start; justify-content: space-between; gap: 28px; padding: 28px 0; font-family: 'Onest', sans-serif; font-weight: 400; font-size: clamp(17px, 1.4vw, 22px); line-height: 1.35; color: var(--cream); transition: color .35s ease; }
.svc-faq-q:hover { color: rgba(248,246,241,0.7); }
.svc-faq-icon { position: relative; width: 18px; height: 18px; flex-shrink: 0; margin-top: 6px; }
.svc-faq-icon::before, .svc-faq-icon::after { content: ""; position: absolute; background: var(--accent); transition: transform .4s var(--ease), opacity .4s ease; }
.svc-faq-icon::before { top: 50%; left: 0; width: 100%; height: 2px; transform: translateY(-50%); }
.svc-faq-icon::after { left: 50%; top: 0; width: 2px; height: 100%; transform: translateX(-50%); }
.svc-faq-item.is-open .svc-faq-icon::after { transform: translateX(-50%) scaleY(0); opacity: 0; }
.svc-faq-a { overflow: hidden; max-height: 0; transition: max-height .5s var(--ease); }
.svc-faq-a-inner { padding: 0 60px 30px 0; font-family: 'Onest', sans-serif; font-weight: 300; font-size: clamp(15px, 1.1vw, 17px); line-height: 1.65; color: rgba(248,246,241,0.7); }
.svc-faq-item.is-open .svc-faq-q { color: var(--cream); }
@media (max-width: 900px) { .svc-faq-grid { grid-template-columns: 1fr; gap: 40px; } .svc-faq-a-inner { padding-right: 20px; } }

/* ============================================================
   10 · FINAL-CTA + INLINE-FORMULAR
   ============================================================ */
.svc-cta { padding: var(--sec-pad) 0 calc(var(--sec-pad) * 0.7); text-align: center; overflow: hidden; }
.svc-cta .svc-cta-inner { position: relative; z-index: 2; max-width: 1080px; margin: 0 auto; }
.svc-cta h2 { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; font-size: clamp(30px, 4.4vw, 70px); line-height: 1.0; letter-spacing: -0.03em; color: var(--cream); margin: 0 0 26px; }
.svc-cta h2 .svc-dim { color: var(--moss); }
.svc-cta .svc-cta-sub { font-family: 'Onest', sans-serif; font-weight: 300; font-size: clamp(16px, 1.3vw, 20px); line-height: 1.55; color: rgba(248,246,241,0.74); margin: 0 auto 22px; max-width: 600px; }
.svc-cta .svc-trust-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px 22px; margin: 0 auto 56px; font-family: 'Onest', sans-serif; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--moss); }
.svc-cta .svc-trust-row span { display: inline-flex; align-items: center; gap: 9px; }
.svc-cta .svc-trust-row .svc-trust-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--accent); }

/* Formular */
.svc-form { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; text-align: left; border: 1px solid var(--line); background: rgba(12,11,11,0.6); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); padding: clamp(28px, 4vw, 52px); }
.svc-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 32px; }
.svc-field { position: relative; margin-bottom: 30px; }
.svc-field.is-full { grid-column: 1 / -1; }
.svc-field label { display: block; font-family: 'Onest', sans-serif; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--moss); margin: 0 0 11px; }
.svc-field label .svc-req { color: var(--accent); }
.svc-field input, .svc-field textarea { width: 100%; background: transparent; border: 0; border-bottom: 1px solid var(--line); outline: none; padding: 10px 0; font-family: 'Onest', sans-serif; font-weight: 300; font-size: 16px; color: var(--cream); transition: border-color .4s ease; }
.svc-field textarea { resize: vertical; min-height: 90px; line-height: 1.55; }
.svc-field input::placeholder, .svc-field textarea::placeholder { color: rgba(248,246,241,0.3); }
.svc-field input:focus, .svc-field textarea:focus { border-color: var(--cream); }
.svc-field.is-invalid input, .svc-field.is-invalid textarea { border-color: var(--accent); }
.svc-field .svc-field-err { font-family: 'Onest', sans-serif; font-size: 12px; color: #c97a86; margin: 8px 0 0; display: none; }
.svc-field.is-invalid .svc-field-err { display: block; }
.svc-form-foot { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 22px; margin-top: 12px; }
.svc-form-consent { display: flex; align-items: flex-start; gap: 11px; font-family: 'Onest', sans-serif; font-weight: 300; font-size: 12.5px; line-height: 1.5; color: rgba(248,246,241,0.6); max-width: 420px; }
.svc-form-consent input { width: 16px; height: 16px; margin-top: 2px; accent-color: var(--accent); flex-shrink: 0; }
.svc-form-consent a { color: var(--cream); }
.svc-form-submit { display: inline-flex; align-items: center; gap: 12px; padding: 16px 32px; border: 0; border-radius: 999px; background: var(--cream); color: #0a0708; font-family: 'Syne', sans-serif; font-weight: 600; font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase; cursor: pointer; transition: background .45s var(--ease), color .45s var(--ease), opacity .3s ease; }
.svc-form-submit:hover { background: var(--accent); color: var(--cream); }
.svc-form-submit:disabled { opacity: 0.55; cursor: default; }
.svc-form-submit .svc-sub-arrow { transition: transform .45s cubic-bezier(.7,0,.2,1); }
.svc-form-submit:hover .svc-sub-arrow { transform: translateX(6px); }
.svc-form-status { font-family: 'Onest', sans-serif; font-size: 14px; line-height: 1.5; margin: 22px 0 0; min-height: 1px; }
.svc-form-status.is-ok { color: #9fc9a6; }
.svc-form-status.is-err { color: #c97a86; }
.svc-form.is-sent .svc-form-grid, .svc-form.is-sent .svc-form-foot { display: none; }
.svc-form-sent { display: none; text-align: center; padding: 20px 0; }
.svc-form.is-sent .svc-form-sent { display: block; }
.svc-form-sent h3 { font-family: 'Syne', sans-serif; font-weight: 600; text-transform: uppercase; font-size: clamp(22px, 2.4vw, 34px); color: var(--cream); margin: 0 0 14px; letter-spacing: -0.02em; }
.svc-form-sent p { font-family: 'Onest', sans-serif; font-weight: 300; font-size: 16px; line-height: 1.6; color: rgba(248,246,241,0.74); margin: 0 auto; max-width: 460px; }
@media (max-width: 640px) { .svc-form-grid { grid-template-columns: 1fr; } .svc-form-foot { flex-direction: column; align-items: stretch; } .svc-form-submit { justify-content: center; } }

/* ============================================================
   GRAIN · SCROLL-PROGRESS · CUSTOM CURSOR (global overlays)
   ============================================================ */
.uu-grain { position: fixed; inset: 0; pointer-events: none; z-index: 9996; opacity: 0.10; mix-blend-mode: screen; background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.7 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>"); }
.uu-scroll-progress { position: fixed; top: 0; left: 0; height: 2px; background: var(--accent); width: 0; z-index: 9999; transition: width 0.1s linear; pointer-events: none; }
@media (hover: hover) and (pointer: fine) {
  .uu-cursor-active .svc-page, .uu-cursor-active .svc-page * { cursor: none !important; }
  .uu-cursor { position: fixed; top: 0; left: 0; width: 8px; height: 8px; background: var(--cream); border-radius: 50%; pointer-events: none; z-index: 9999; transform: translate(-50%, -50%); transition: width .25s var(--ease), height .25s var(--ease), background .25s ease; mix-blend-mode: difference; }
  .uu-cursor-ring { position: fixed; top: 0; left: 0; width: 40px; height: 40px; border: 1px solid var(--cream); border-radius: 50%; pointer-events: none; z-index: 9998; transform: translate(-50%, -50%); transition: width .35s var(--ease), height .35s var(--ease), border-color .25s ease, opacity .25s ease; opacity: 0.5; mix-blend-mode: difference; }
  .uu-cursor.is-hover { width: 26px; height: 26px; }
  .uu-cursor-ring.is-hover { width: 78px; height: 78px; opacity: 1; }
}

/* ============================================================
   SPLIT-TEXT CASCADE (Hero / Closing Headlines, optional)
   ============================================================ */
.svc-split { display: inline-block; }
.svc-split .svc-word { display: inline-block; overflow: hidden; vertical-align: top; }
.svc-split .svc-word .svc-word-in { display: inline-block; transform: translateY(110%); transition: transform 1.05s var(--ease); }
.svc-split.in .svc-word .svc-word-in { transform: translateY(0); }
.svc-split .svc-word:nth-child(1) .svc-word-in { transition-delay: .05s; }
.svc-split .svc-word:nth-child(2) .svc-word-in { transition-delay: .12s; }
.svc-split .svc-word:nth-child(3) .svc-word-in { transition-delay: .19s; }
.svc-split .svc-word:nth-child(4) .svc-word-in { transition-delay: .26s; }
.svc-split .svc-word:nth-child(5) .svc-word-in { transition-delay: .33s; }
.svc-split .svc-word:nth-child(n+6) .svc-word-in { transition-delay: .40s; }

/* ============================================================
   FOOTER · AWARD EDITION (1:1 aus ueber-uns übernommen)
   ============================================================ */
.uu-footer { background: #210C12; color: var(--cream); padding: var(--sec-pad) 56px 40px; position: relative; overflow: hidden; font-family: 'Onest', 'Inter', sans-serif; }
.uu-footer::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(248,246,241,0.014) 1px, transparent 1px),
    linear-gradient(90deg, rgba(248,246,241,0.014) 1px, transparent 1px);
  background-size: 96px 96px; background-position: 0 0; pointer-events: none; z-index: 1;
  -webkit-mask-image: radial-gradient(ellipse at 50% 30%, rgba(0,0,0,0.4) 0%, transparent 72%);
          mask-image: radial-gradient(ellipse at 50% 30%, rgba(0,0,0,0.4) 0%, transparent 72%);
}
.uu-footer .uu-f-inner { max-width: 1440px; margin: 0 auto; position: relative; z-index: 2; }
.uu-footer .uu-f-top { display: flex; justify-content: space-between; align-items: flex-end; gap: 56px; padding: 4px 0 64px; text-align: left; flex-wrap: wrap; border-bottom: 1px solid rgba(248,246,241,0.08); }
.uu-footer .uu-f-top-left { display: flex; flex-direction: row; align-items: center; gap: 20px; }
.uu-footer .uu-f-top-right { display: flex; flex-direction: column; align-items: flex-end; text-align: right; gap: 26px; }
.uu-footer .uu-f-logo { display: inline-flex; flex-shrink: 0; }
.uu-footer .uu-f-logo-svg { width: clamp(46px, 4vw, 58px); height: clamp(46px, 4vw, 58px); color: var(--cream); display: block; overflow: visible; }
.uu-footer .uu-f-logo-needle { transform-box: fill-box; transform-origin: center; animation: uuFNeedleSpin 26s linear infinite; }
@keyframes uuFNeedleSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.uu-footer .uu-f-id { display: flex; flex-direction: column; gap: 7px; }
.uu-footer .uu-f-id-name { font-family: 'Onest', sans-serif !important; font-size: 14px; font-weight: 500 !important; letter-spacing: 0.12em; text-transform: uppercase; color: var(--cream); margin: 0; line-height: 1; }
.uu-footer .uu-f-top-eyebrow { font-family: 'Onest', sans-serif; font-size: 10px; font-weight: 300; letter-spacing: 0.32em; text-transform: uppercase; color: var(--cream); margin: 0; line-height: 1.2; }
.uu-footer .uu-f-cta-head { font-family: 'Syne', sans-serif !important; font-weight: 600 !important; font-size: clamp(22px, 2.4vw, 38px) !important; line-height: 1.04 !important; letter-spacing: -0.035em !important; text-transform: uppercase !important; color: var(--cream) !important; margin: 0 !important; }
.uu-footer .uu-f-top-right .uu-btn { font-size: 14px; }
@media (max-width: 820px) {
  .uu-footer .uu-f-top { flex-direction: column; align-items: flex-start; text-align: left; gap: 40px; padding-bottom: 48px; }
  .uu-footer .uu-f-top-right { align-items: flex-start; text-align: left; }
}
.uu-footer .uu-f-sitemap { display: grid; grid-template-columns: 1.45fr 1fr 1fr 1fr 1fr; gap: 64px; padding-top: 64px; }
.uu-footer .uu-f-col h5 { display: inline-block; font-family: 'Onest', sans-serif; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cream); margin: 0 0 26px; font-weight: 500; padding-bottom: 12px; border-bottom: 1px solid rgba(248,246,241,0.16); }
.uu-footer .uu-f-col address { font-family: 'Onest', sans-serif; font-size: clamp(15px, 1.05vw, 17px); line-height: 1.55; color: var(--cream); font-style: normal; margin: 0 0 24px; }
.uu-footer .uu-f-col .uu-f-contact { list-style: none; padding: 0; margin: 0 0 24px; }
.uu-footer .uu-f-col .uu-f-contact li { margin: 0 0 8px; }
.uu-footer .uu-f-col .uu-f-contact a { font-family: 'Onest', sans-serif; font-size: 15px; color: var(--cream); text-decoration: none; background-image: linear-gradient(currentColor, currentColor); background-size: 100% 1px; background-position: 0 100%; background-repeat: no-repeat; padding-bottom: 2px; transition: background-size .4s ease; }
.uu-footer .uu-f-col .uu-f-contact a:hover { background-size: 0% 1px; }
.uu-footer .uu-f-col .uu-f-hours { font-family: 'Onest', sans-serif; font-size: 13px; line-height: 1.6; color: var(--cream); margin: 24px 0 0; }
.uu-footer .uu-f-col ul.uu-f-nav { list-style: none; padding: 0; margin: 0; }
.uu-footer .uu-f-col ul.uu-f-nav li { margin: 0 0 12px; }
.uu-footer .uu-f-col ul.uu-f-nav li a { font-family: 'Onest', sans-serif; font-size: clamp(14px, 0.95vw, 16px); color: var(--cream); text-decoration: none; display: inline-flex; align-items: center; transition: color .3s ease, gap .35s var(--ease); }
.uu-footer .uu-f-col ul.uu-f-nav li a::before { content: ''; width: 0; height: 1px; background: var(--cream); transition: width .35s var(--ease), margin .35s var(--ease); margin: 0; flex-shrink: 0; }
.uu-footer .uu-f-col ul.uu-f-nav li a:hover::before { width: 18px; margin-right: 12px; }
.uu-footer .uu-f-news { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; padding: 96px 0; align-items: center; border-top: 1px solid rgba(248,246,241,0.08); border-bottom: 1px solid rgba(248,246,241,0.12); margin-top: 96px; }
.uu-footer .uu-f-news-text h3 { font-family: 'Syne', sans-serif; font-weight: 600; font-size: clamp(28px, 3.4vw, 52px); line-height: 1.05; letter-spacing: -0.025em; color: var(--cream); margin: 0 0 14px; text-transform: uppercase; }
.uu-footer .uu-f-news-text p { font-family: 'Onest', sans-serif; font-size: 15px; line-height: 1.6; color: var(--cream); margin: 0; max-width: 440px; }
.uu-footer .uu-f-news-form { display: flex; gap: 0; border-bottom: 1px solid rgba(248,246,241,0.35); padding-bottom: 14px; align-items: center; transition: border-color .3s ease; }
.uu-footer .uu-f-news-form:focus-within { border-color: var(--cream); }
.uu-footer .uu-f-news-form input { flex: 1; background: transparent; border: 0; outline: none; padding: 12px 0; font-family: 'Onest', sans-serif; font-size: clamp(16px, 1.3vw, 20px); color: var(--cream); min-width: 0; }
.uu-footer .uu-f-news-form input::placeholder { color: rgba(248,246,241,0.32); }
.uu-footer .uu-f-news-form button { background: transparent; border: 0; cursor: pointer; font-family: 'Onest', sans-serif; font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--cream); padding: 12px 0 12px 24px; display: inline-flex; align-items: center; gap: 10px; transition: gap .3s ease; white-space: nowrap; }
.uu-footer .uu-f-news-form button:hover { gap: 16px; }
.uu-footer .uu-f-news-meta { font-family: 'Onest', sans-serif; font-size: 11px; letter-spacing: 0.04em; color: var(--cream); margin: 16px 0 0; }
.uu-footer .uu-f-mark-wrap { width: 100%; overflow: visible; margin: 70px 0 44px; position: relative; cursor: default; text-align: center; padding: 0.42em 0 0.12em; }
.uu-footer .uu-f-mark { font-family: 'Syne', sans-serif; font-weight: 700; font-size: clamp(90px, 12.5vw, 200px); line-height: 1; letter-spacing: -0.03em; color: transparent; -webkit-text-stroke: 1.4px var(--cream); user-select: none; display: block; text-align: center; white-space: nowrap; margin: 0; padding: 0; }
.uu-footer .uu-f-mark .uu-f-l { display: inline-block; }
.uu-footer .uu-f-mark .uu-f-lc { display: inline-block; will-change: transform; }
.uu-footer .uu-f-mark .uu-f-space { display: inline-block; width: 0.30em; }
.uu-footer .uu-f-bottom { padding-top: 32px; border-top: 1px solid rgba(248,246,241,0.08); display: flex; justify-content: space-between; align-items: center; gap: 32px; flex-wrap: wrap; }
.uu-footer .uu-f-copy { font-family: 'Onest', sans-serif; font-size: 12px; letter-spacing: 0.04em; color: var(--cream); margin: 0; }
.uu-footer .uu-f-legal { display: flex; gap: 28px; justify-content: flex-end; flex-wrap: wrap; }
.uu-footer .uu-f-legal a { font-family: 'Onest', sans-serif; font-size: 12px; letter-spacing: 0.04em; color: var(--cream); text-decoration: none; transition: opacity .3s ease; }
.uu-footer .uu-f-legal a:hover { opacity: 0.6; }
@media (max-width: 1100px) {
  .uu-footer .uu-f-sitemap { grid-template-columns: 1fr 1fr 1fr; gap: 48px; }
  .uu-footer .uu-f-news { grid-template-columns: 1fr; gap: 36px; padding: 72px 0; }
}
@media (max-width: 700px) {
  .uu-footer { padding: 64px 20px 28px; }
  .uu-footer .uu-f-sitemap { grid-template-columns: 1fr 1fr; gap: 40px; }
  .uu-footer .uu-f-bottom { flex-direction: column; align-items: flex-start; gap: 20px; }
  .uu-footer .uu-f-legal { justify-content: flex-start; }
  .uu-footer .uu-f-mark { margin: 56px 0 40px; }
}

/* ============================================================
   ÜBERSICHT · Service-Cards (Kategorie-Übersichtsseiten)
   ============================================================ */
.svc-cat-block + .svc-cat-block { margin-top: 84px; }
.svc-cat-eyebrow { font-family:'Syne',sans-serif; font-weight:600; font-size:13px; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); margin:0 0 10px; }
.svc-cat-blurb { font-family:'Onest',sans-serif; font-weight:300; font-size:16px; line-height:1.6; color:rgba(248,246,241,0.62); max-width:640px; margin:0 0 30px; }
.svc-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.svc-svc-card { display:flex; flex-direction:column; gap:16px; padding:34px 30px 28px; background:var(--panel); border:1px solid var(--line); text-decoration:none; color:inherit; min-height:236px; transition:border-color .5s var(--ease), background .5s var(--ease), transform .5s var(--ease); }
.svc-svc-card:hover { border-color:rgba(248,246,241,0.28); background:var(--panel-2); transform:translateY(-4px); }
.svc-svc-card-icon { width:36px; height:36px; color:var(--accent); }
.svc-svc-card-icon svg { width:100%; height:100%; display:block; }
.svc-svc-card-title { font-family:'Syne',sans-serif; font-weight:600; text-transform:uppercase; font-size:19px; line-height:1.12; letter-spacing:-0.015em; color:var(--cream); }
.svc-svc-card-desc { font-family:'Onest',sans-serif; font-weight:300; font-size:14.5px; line-height:1.55; color:rgba(248,246,241,0.6); }
.svc-svc-card-more { margin-top:auto; padding-top:10px; display:inline-flex; align-items:center; gap:9px; font-family:'Syne',sans-serif; font-size:11px; font-weight:600; letter-spacing:0.14em; text-transform:uppercase; color:rgba(248,246,241,0.7); }
.svc-svc-card-more svg { width:17px; height:17px; transition:transform .45s var(--ease); }
.svc-svc-card:hover .svc-svc-card-more svg { transform:translateX(5px); }
.svc-svc-card:hover .svc-svc-card-more { color:var(--cream); }
@media (max-width:900px){ .svc-svc-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .svc-svc-grid{ grid-template-columns:1fr; } }

/* ============================================================
   PROSA · Rechtsseiten (Impressum/Datenschutz/AGB) + Formular-Seite
   ============================================================ */
.svc-prose { max-width: 760px; }
.svc-prose h2 { font-family:'Syne',sans-serif; font-weight:600; text-transform:uppercase; font-size:clamp(19px,1.6vw,25px); letter-spacing:-0.02em; color:var(--cream); margin:52px 0 16px; }
.svc-prose h2:first-child { margin-top:0; }
.svc-prose h3 { font-family:'Syne',sans-serif; font-weight:600; font-size:16px; letter-spacing:-0.01em; color:var(--cream); margin:30px 0 10px; }
.svc-prose p, .svc-prose li { font-family:'Onest',sans-serif; font-weight:300; font-size:16px; line-height:1.72; color:rgba(248,246,241,0.72); margin:0 0 15px; }
.svc-prose ul { padding-left:22px; margin:0 0 18px; list-style:disc; }
.svc-prose li { margin-bottom:7px; }
.svc-prose a { color:var(--cream); text-decoration:underline; text-underline-offset:3px; text-decoration-color:rgba(248,246,241,0.4); }
.svc-prose a:hover { text-decoration-color:var(--cream); }
.svc-prose strong { color:var(--cream); font-weight:500; }
.svc-prose .svc-prose-todo { font-size:13.5px; color:rgba(248,246,241,0.5); border-left:2px solid var(--accent); padding:4px 0 4px 14px; margin:6px 0 15px; font-style:normal; }
.svc-prose .svc-prose-updated { font-size:13px; color:rgba(248,246,241,0.4); margin-top:48px; padding-top:20px; border-top:1px solid var(--line); }
