/* ═══════════════════════════════════════════════════════════════
   E-RECHNUNG KONFORM — globale Stilbasis (v12)
   Eine Datei für alle Seiten. Hier zentral ändern, gilt überall.
   ═══════════════════════════════════════════════════════════════ */

/* ── Lokale Schriften ───────────────────────────────────────── */
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:300; font-display:swap; src:url('/fonts/dm-sans-v17-latin-300.woff2') format('woff2'); }
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:400; font-display:swap; src:url('/fonts/dm-sans-v17-latin-regular.woff2') format('woff2'); }
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:500; font-display:swap; src:url('/fonts/dm-sans-v17-latin-500.woff2') format('woff2'); }
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:600; font-display:swap; src:url('/fonts/dm-sans-v17-latin-600.woff2') format('woff2'); }
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:700; font-display:swap; src:url('/fonts/dm-sans-v17-latin-700.woff2') format('woff2'); }
@font-face { font-family:'DM Sans'; font-style:italic; font-weight:400; font-display:swap; src:url('/fonts/dm-sans-v17-latin-italic.woff2') format('woff2'); }
@font-face { font-family:'DM Sans'; font-style:italic; font-weight:500; font-display:swap; src:url('/fonts/dm-sans-v17-latin-500italic.woff2') format('woff2'); }
@font-face { font-family:'Playfair Display'; font-style:normal; font-weight:400; font-display:swap; src:url('/fonts/playfair-display-v40-latin-regular.woff2') format('woff2'); }
@font-face { font-family:'Playfair Display'; font-style:normal; font-weight:500; font-display:swap; src:url('/fonts/playfair-display-v40-latin-500.woff2') format('woff2'); }
@font-face { font-family:'Playfair Display'; font-style:normal; font-weight:600; font-display:swap; src:url('/fonts/playfair-display-v40-latin-600.woff2') format('woff2'); }
@font-face { font-family:'Playfair Display'; font-style:italic; font-weight:400; font-display:swap; src:url('/fonts/playfair-display-v40-latin-italic.woff2') format('woff2'); }
@font-face { font-family:'Playfair Display'; font-style:italic; font-weight:500; font-display:swap; src:url('/fonts/playfair-display-v40-latin-500italic.woff2') format('woff2'); }

/* ── Tokens ─────────────────────────────────────────────────── */
:root {
    --white:#ffffff; --off-white:#FAFAF8; --sand:#F3F0EB; --sand-dark:#E8E3DB;
    --charcoal:#1A1A1A; --text:#2D2D2D; --text-mid:#5C5C5C; --text-soft:#8A8A8A;
    --accent:#C0713A; --accent-light:#FEF7F0; --accent-deep:#A35E2F; --accent-glow:rgba(192,113,58,0.08);
    --green:#3A7D5C; --green-light:#EDF5F0;
    --slate-dark:#252A30; --slate:#252A30;
    --warn:#B45309; --warn-bg:#FFFBEB;
    --red-soft:#B91C1C; --red:#B91C1C; --red-bg:#FEF2F2;
    --border:#E5E2DD;
    --radius:14px; --radius-sm:8px;
    --header-h:68px;
}

/* ── Reset & Basis ──────────────────────────────────────────── */
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
    font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
    color:var(--text); background:var(--off-white); line-height:1.7;
    -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
.container { max-width:1120px; margin:0 auto; padding:0 28px; }
img { max-width:100%; display:block; }

/* Icon-Strichstärke einheitlich (Logo/Illustration ausgenommen) */
.card-marker svg, .danach-icon svg, .header-link svg, .header-cta svg,
.btn-main svg, .btn-ghost svg, .btn svg, .prinzip-icon svg,
.deliver-list li svg, .faq summary svg, .header-back svg, .footer-back svg {
    stroke-width:1.75;
}

/* Sichtbarer Fokus für Tastaturnutzung */
a:focus-visible, button:focus-visible, summary:focus-visible,
input:focus-visible, textarea:focus-visible {
    outline:2px solid var(--accent); outline-offset:3px; border-radius:4px;
}

/* ═══════════════ HEADER (von site.js eingesetzt) ═══════════════ */
header.site-header {
    position:sticky; top:0; z-index:200; min-height:var(--header-h);
    background:rgba(250,250,248,0.9);
    backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid rgba(0,0,0,0.06);
}
.header-inner {
    display:flex; justify-content:space-between; align-items:center;
    height:var(--header-h); max-width:1120px; margin:0 auto; padding:0 28px;
}
.logo {
    font-size:1.05rem; font-weight:600; color:var(--charcoal);
    text-decoration:none; display:flex; align-items:center; gap:10px;
    letter-spacing:-0.01em;
}
.logo-icon { width:34px; min-width:34px; height:34px; display:flex; align-items:center; justify-content:center; }

.header-nav { display:flex; align-items:center; gap:4px; }
.header-link {
    font-size:0.88rem; font-weight:500; color:var(--text-mid);
    text-decoration:none; padding:7px 14px; border-radius:6px;
    transition:color .2s, background .2s;
}
.header-link:hover { color:var(--charcoal); background:rgba(0,0,0,0.03); }
.header-link.is-check { color:var(--accent); font-weight:600; }
.header-link[aria-current="page"] { color:var(--charcoal); background:var(--sand); }
.header-cta {
    font-size:0.85rem; font-weight:600; background:var(--accent); color:var(--white);
    padding:9px 20px; border-radius:50px; text-decoration:none;
    transition:background .2s, transform .2s;
    display:inline-flex; align-items:center; gap:6px; margin-left:6px;
}
.header-cta:hover { background:var(--accent-deep); transform:translateY(-1px); }
.header-cta svg { width:14px; height:14px; }

/* Minimal-Header (Check-Funnel) */
.header-back {
    font-size:0.85rem; color:var(--text-mid); text-decoration:none;
    display:inline-flex; align-items:center; gap:6px; transition:color .2s;
}
.header-back:hover { color:var(--charcoal); }
.header-back svg { width:14px; height:14px; }

.mobile-menu-btn { display:none; background:none; border:none; cursor:pointer; padding:6px; color:var(--charcoal); }
.mobile-menu-btn svg { width:22px; height:22px; }
.mobile-menu {
    display:none; position:fixed; top:var(--header-h); left:0; right:0;
    background:var(--white); border-bottom:1px solid var(--border);
    box-shadow:0 12px 40px rgba(0,0,0,0.10); z-index:199;
    padding:12px 20px 20px; flex-direction:column; gap:4px;
}
.mobile-menu.open { display:flex; }
.mobile-menu a {
    display:block; padding:14px 16px; font-size:0.95rem; font-weight:500;
    color:var(--text); text-decoration:none; border-radius:8px;
}
.mobile-menu a:hover { background:var(--sand); }
.mobile-menu a.is-check { color:var(--accent); font-weight:600; }
.mobile-menu a.mobile-cta {
    background:var(--accent); color:var(--white); text-align:center;
    font-weight:600; margin-top:8px; border-radius:50px; padding:14px;
}
.mobile-menu a.mobile-cta:hover { background:var(--accent-deep); }
.mobile-menu .mobile-divider { height:1px; background:var(--border); margin:4px 0; }

/* ═══════════════ BUTTONS ═══════════════ */
.btn-main {
    font-family:inherit; font-size:0.95rem; font-weight:600;
    background:var(--accent); color:var(--white);
    padding:14px 28px; border-radius:50px; border:none; cursor:pointer;
    text-decoration:none; display:inline-flex; align-items:center; gap:8px;
    transition:background .25s, transform .25s, box-shadow .25s;
    box-shadow:0 3px 12px rgba(192,113,58,0.18);
}
.btn-main:hover { background:var(--accent-deep); transform:translateY(-2px); box-shadow:0 8px 24px rgba(192,113,58,0.22); }
.btn-main svg { width:16px; height:16px; }
.btn-ghost {
    font-family:inherit; font-size:0.92rem; font-weight:500;
    color:var(--text-mid); text-decoration:none; padding:14px 8px;
    transition:color .2s; display:inline-flex; align-items:center; gap:6px;
}
.btn-ghost:hover { color:var(--charcoal); }
.btn-ghost svg { width:14px; height:14px; transition:transform .2s; }
.btn-ghost:hover svg { transform:translateX(3px); }
.btn {
    font-family:inherit; font-size:0.95rem; font-weight:600;
    background:var(--accent); color:var(--white); padding:14px 28px;
    border-radius:50px; border:none; cursor:pointer; text-decoration:none;
    display:inline-flex; align-items:center; gap:8px;
    transition:background .25s, transform .25s, box-shadow .25s;
    box-shadow:0 3px 12px rgba(192,113,58,0.18);
}
.btn:hover { background:var(--accent-deep); transform:translateY(-2px); }
.btn svg { width:16px; height:16px; }

/* ═══════════════ SECTIONS (gemeinsam) ═══════════════ */
.section { padding:100px 0; }
.section-eyebrow {
    font-size:0.75rem; font-weight:700; text-transform:uppercase;
    letter-spacing:0.12em; color:var(--accent); margin-bottom:16px;
}
.section-heading {
    font-family:'Playfair Display',Georgia,serif;
    font-size:clamp(1.7rem,3.2vw,2.4rem); font-weight:500; line-height:1.25;
    color:var(--charcoal); margin-bottom:16px;
}
.section-sub { font-size:1.02rem; color:var(--text-mid); max-width:560px; margin-bottom:50px; line-height:1.8; }

/* ═══════════════ HERO (Startseite) ═══════════════ */
.hero { padding:80px 0 60px; position:relative; overflow:hidden; }
.hero::before {
    content:''; position:absolute; top:-68px; left:-10%; right:-10%; bottom:0; z-index:-1;
    background:
        radial-gradient(ellipse 60% 50% at 20% 50%, rgba(192,113,58,0.04), transparent),
        radial-gradient(ellipse 40% 40% at 75% 30%, rgba(58,125,92,0.03), transparent),
        linear-gradient(180deg, var(--sand) 0%, var(--off-white) 100%);
}
.hero-grid { display:grid; grid-template-columns:1.15fr 0.85fr; gap:48px; align-items:center; }
.hero-badge {
    display:inline-flex; align-items:center; gap:10px;
    background:var(--warn-bg); color:var(--warn);
    padding:7px 16px; border-radius:50px; font-size:0.8rem; font-weight:700;
    margin-bottom:24px; border:1px solid rgba(180,83,9,0.15);
    animation:badge-glow 3s ease-in-out infinite;
}
@keyframes badge-glow { 0%,100%{box-shadow:0 0 0 0 rgba(180,83,9,0);} 50%{box-shadow:0 0 16px 2px rgba(180,83,9,0.08);} }
.badge-pulse { width:7px; height:7px; background:var(--warn); border-radius:50%; position:relative; }
.badge-pulse::after { content:''; position:absolute; inset:-3px; border-radius:50%; border:1.5px solid var(--warn); animation:ping 2s cubic-bezier(0,0,0.2,1) infinite; }
@keyframes ping { 0%{transform:scale(1);opacity:0.8;} 75%,100%{transform:scale(2.2);opacity:0;} }
.hero h1 {
    font-family:'Playfair Display',Georgia,serif;
    font-size:clamp(2.1rem,4.2vw,3rem); font-weight:500; line-height:1.18;
    color:var(--charcoal); margin-bottom:24px; letter-spacing:-0.02em;
}
.hero h1 em { font-style:italic; color:var(--accent); }
.hero-body { font-size:1.05rem; color:var(--text-mid); max-width:520px; margin-bottom:32px; line-height:1.85; }
.hero-actions { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.hero-note { font-size:0.82rem; color:var(--text-soft); margin-top:14px; display:flex; align-items:center; gap:6px; }
.hero-note svg { width:14px; height:14px; color:var(--green); }
.hero-visual { display:flex; justify-content:center; align-items:center; }
.hero-illustration { width:100%; max-width:400px; }

/* ═══════════════ FRISTEN-STREIFEN (4 Jahre) ═══════════════ */
.deadline-strip { background:var(--white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:42px 0; }
.deadline-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.deadline-item { text-align:center; padding:10px 22px; border-left:1px solid var(--border); }
.deadline-item:first-child { border-left:none; }
.deadline-year { font-family:'Playfair Display',Georgia,serif; font-size:1.55rem; font-weight:500; color:var(--charcoal); margin-bottom:6px; }
.deadline-item.active .deadline-year { color:var(--accent); }
.deadline-status { font-size:0.74rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; margin-bottom:8px; }
.deadline-item.active .deadline-status { color:var(--red-soft); }
.deadline-item.upcoming .deadline-status { color:var(--text-soft); }
.deadline-desc { font-size:0.84rem; color:var(--text-mid); line-height:1.55; }

/* ═══════════════ SITUATION ═══════════════ */
.situation-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.situation-card { padding:30px; border-radius:var(--radius); border:1px solid var(--border); background:var(--white); transition:border-color .3s, box-shadow .3s, transform .3s; }
.situation-card:hover { border-color:var(--sand-dark); box-shadow:0 8px 30px rgba(0,0,0,0.04); transform:translateY(-2px); }
.card-marker { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; margin-bottom:16px; background:var(--red-bg); color:var(--red-soft); }
.card-marker svg { width:18px; height:18px; }
.situation-card h3 { font-size:1.02rem; font-weight:700; margin-bottom:8px; color:var(--charcoal); line-height:1.4; }
.situation-card p { font-size:0.9rem; color:var(--text-mid); line-height:1.7; }

/* ═══════════════ DANACH ═══════════════ */
.danach-section { background:var(--slate-dark); color:var(--white); padding:100px 0; position:relative; overflow:hidden; }
.danach-section::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 10% 80%, rgba(192,113,58,0.08), transparent 50%), radial-gradient(ellipse at 85% 20%, rgba(58,125,92,0.06), transparent 50%); }
.danach-section .container { position:relative; z-index:1; }
.danach-section .section-eyebrow { color:rgba(255,255,255,0.5); }
.danach-section .section-heading { color:var(--white); max-width:600px; }
.danach-lead { font-size:1.08rem; color:rgba(255,255,255,0.6); max-width:560px; margin-bottom:56px; line-height:1.85; }
.danach-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.danach-card { padding:32px; border-radius:var(--radius); border:1px solid rgba(255,255,255,0.07); background:rgba(255,255,255,0.03); transition:background .3s, border-color .3s; }
.danach-card:hover { background:rgba(255,255,255,0.05); border-color:rgba(255,255,255,0.12); }
.danach-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.danach-icon svg { width:20px; height:20px; }
.danach-icon.pflicht { background:rgba(192,113,58,0.15); color:var(--accent); }
.danach-icon.besser { background:rgba(58,125,92,0.15); color:var(--green); }
.danach-card h3 { font-size:1rem; font-weight:700; color:var(--white); margin-bottom:10px; line-height:1.4; }
.danach-card p { font-size:0.88rem; color:rgba(255,255,255,0.5); line-height:1.7; }

/* ═══════════════ PRINZIPIEN (neu) ═══════════════ */
.prinzip-section { background:var(--off-white); }
.prinzip-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.prinzip-card { padding:32px 30px; border-radius:var(--radius); border:1px solid var(--border); background:var(--white); }
.prinzip-icon { width:44px; height:44px; border-radius:11px; background:var(--accent-light); color:var(--accent); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.prinzip-icon svg { width:22px; height:22px; }
.prinzip-card h3 { font-size:1.05rem; font-weight:700; color:var(--charcoal); margin-bottom:10px; line-height:1.35; }
.prinzip-card p { font-size:0.9rem; color:var(--text-mid); line-height:1.7; }

/* ═══════════════ ABLAUF (mit Zeitrahmen + Ergebnis) ═══════════════ */
.process-track { display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; background:var(--white); }
.process-step { padding:38px 30px; border-right:1px solid var(--border); transition:background .3s; }
.process-step:last-child { border-right:none; }
.process-step:hover { background:var(--sand); }
.process-step-top { display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:16px; }
.process-step-num { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-soft); transition:color .3s; }
.process-step:hover .process-step-num { color:var(--accent); }
.process-step-time { font-size:0.72rem; font-weight:600; color:var(--accent); background:var(--accent-light); padding:3px 10px; border-radius:50px; white-space:nowrap; }
.process-step h3 { font-size:1.05rem; font-weight:700; color:var(--charcoal); margin-bottom:10px; line-height:1.35; }
.process-step p { font-size:0.88rem; color:var(--text-mid); line-height:1.7; margin-bottom:16px; }
.process-result { font-size:0.82rem; color:var(--text-mid); display:flex; gap:8px; align-items:flex-start; padding-top:14px; border-top:1px solid var(--border); }
.process-result svg { width:15px; height:15px; min-width:15px; color:var(--green); margin-top:2px; }
.process-footnote { text-align:center; margin-top:40px; font-size:0.9rem; }
.process-footnote a { color:var(--charcoal); text-decoration:none; border-bottom:1px solid var(--text-soft); padding-bottom:2px; font-weight:500; }
.process-footnote a:hover { border-bottom-color:var(--charcoal); }

/* ═══════════════ PROFIL ═══════════════ */
.profile-section { background:var(--white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.profile-layout { display:grid; grid-template-columns:240px 1fr; gap:56px; align-items:start; }
.profile-photo { width:100%; aspect-ratio:1/1.15; background:var(--sand); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; }
.profile-photo-placeholder { text-align:center; color:var(--text-soft); font-size:0.8rem; }
.profile-photo-placeholder svg { width:40px; height:40px; opacity:0.25; margin:0 auto 8px; display:block; }
.profile-body h3 { font-family:'Playfair Display',Georgia,serif; font-size:1.65rem; font-weight:500; margin-bottom:6px; }
.profile-role { font-size:0.88rem; color:var(--text-soft); margin-bottom:22px; font-weight:500; }
.profile-body p { font-size:0.98rem; color:var(--text-mid); margin-bottom:14px; line-height:1.85; }
.profile-quals { display:flex; flex-wrap:wrap; gap:8px; margin-top:24px; }
.profile-qual { font-size:0.78rem; font-weight:600; color:var(--text-mid); background:var(--sand); padding:5px 14px; border-radius:50px; border:1px solid var(--border); }

/* ═══════════════ FAQ (neu, native <details>) ═══════════════ */
.faq-section { background:var(--off-white); }
.faq-list { max-width:760px; margin-top:8px; }
.faq { border-bottom:1px solid var(--border); }
.faq summary { list-style:none; cursor:pointer; padding:24px 4px; display:flex; align-items:center; justify-content:space-between; gap:20px; font-size:1.02rem; font-weight:600; color:var(--charcoal); }
.faq summary::-webkit-details-marker { display:none; }
.faq summary svg { width:18px; min-width:18px; height:18px; color:var(--accent); transition:transform .25s; }
.faq[open] summary svg { transform:rotate(45deg); }
.faq-answer { padding:0 4px 26px; font-size:0.95rem; color:var(--text-mid); line-height:1.8; max-width:680px; }

/* ═══════════════ KONTAKT ═══════════════ */
.contact-section { background:var(--white); border-top:1px solid var(--border); padding:100px 0; }
.contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:64px; max-width:940px; margin:0 auto; align-items:start; }
.contact-left h2 { font-family:'Playfair Display',Georgia,serif; font-size:2rem; font-weight:500; margin-bottom:18px; line-height:1.25; }
.contact-left p { font-size:0.98rem; color:var(--text-mid); margin-bottom:14px; line-height:1.8; }
.contact-direct { margin-top:24px; display:flex; flex-direction:column; gap:8px; }
.contact-direct a { font-size:0.92rem; color:var(--charcoal); text-decoration:none; display:inline-flex; align-items:center; gap:10px; font-weight:500; }
.contact-direct a:hover { color:var(--accent); }
.contact-direct svg { width:16px; height:16px; color:var(--accent); }
.contact-note { margin-top:28px; padding-top:22px; border-top:1px solid var(--border); }
.contact-note p { font-size:0.82rem; color:var(--text-soft); margin-bottom:4px; }
.contact-form { display:flex; flex-direction:column; gap:16px; }
.field { display:flex; flex-direction:column; gap:5px; }
.field label { font-size:0.8rem; font-weight:600; color:var(--text-mid); }
.field input, .field textarea {
    padding:12px 15px; border:1.5px solid var(--border); border-radius:var(--radius-sm);
    font-family:inherit; font-size:0.92rem; color:var(--text); background:var(--off-white);
    transition:border-color .2s, box-shadow .2s, background .2s; resize:vertical;
}
.field input:focus, .field textarea:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-glow); background:var(--white); }
.field input::placeholder, .field textarea::placeholder { color:#bbb; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-btn { margin-top:4px; }
.form-btn .btn-main { width:100%; justify-content:center; padding:15px; }
.form-legal { font-size:0.78rem; color:var(--text-soft); margin-top:12px; line-height:1.6; }
.form-legal a { color:var(--accent); text-decoration:underline; }

/* ═══════════════ FOOTER (von site.js eingesetzt) ═══════════════ */
footer.site-footer { background:var(--charcoal); color:rgba(255,255,255,0.45); padding:48px 0 36px; }
.footer-grid { display:flex; justify-content:space-between; align-items:start; gap:40px; flex-wrap:wrap; }
.footer-brand .logo { color:var(--white); margin-bottom:12px; }
.footer-brand p { font-size:0.8rem; max-width:360px; line-height:1.7; }
.footer-nav { display:flex; gap:28px; flex-wrap:wrap; }
.footer-nav a { font-size:0.82rem; color:rgba(255,255,255,0.45); text-decoration:none; font-weight:500; transition:color .2s; }
.footer-nav a:hover { color:rgba(255,255,255,0.8); }
.footer-bottom { margin-top:28px; padding-top:20px; border-top:1px solid rgba(255,255,255,0.06); font-size:0.75rem; }
.footer-noscript { font-size:0.85rem; border-top:1px solid var(--border); }
.footer-noscript a { color:var(--accent); margin-right:18px; font-weight:500; }

/* ═══════════════ SUBPAGE-HERO (Unterseiten) ═══════════════ */
.page-hero { padding:80px 0 50px; background:linear-gradient(180deg,var(--sand) 0%,var(--off-white) 100%); }
.page-hero .ey { font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:0.12em; color:var(--accent); margin-bottom:16px; }
.page-hero h1 { font-family:'Playfair Display',Georgia,serif; font-size:clamp(2rem,4vw,2.8rem); font-weight:500; line-height:1.2; color:var(--charcoal); margin-bottom:20px; max-width:680px; }
.page-hero .lead { font-size:1.05rem; color:var(--text-mid); max-width:600px; line-height:1.85; }

/* Inhalts-Block (Gesetz-Seite) */
.cb { max-width:740px; }
.cb h2 { font-family:'Playfair Display',Georgia,serif; font-size:1.6rem; font-weight:500; color:var(--charcoal); margin:56px 0 16px; line-height:1.3; }
.cb h2:first-child { margin-top:0; }
.cb p { font-size:0.95rem; color:var(--text-mid); margin-bottom:16px; line-height:1.85; }
.cb strong { color:var(--text); }
.tl { margin:40px 0; display:flex; flex-direction:column; }
.tl-i { display:grid; grid-template-columns:100px 1fr; gap:24px; padding:28px 0; border-bottom:1px solid var(--border); }
.tl-i:last-child { border-bottom:none; }
.tl-y { font-family:'Playfair Display',Georgia,serif; font-size:1.6rem; font-weight:500; }
.tl-i.a .tl-y { color:var(--accent); }
.tl-i.u .tl-y { color:var(--text-soft); }
.tl-b { font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; margin-top:4px; }
.tl-i.a .tl-b { color:var(--red-soft); }
.tl-i.u .tl-b { color:var(--text-soft); }
.tl-p p { font-size:0.92rem; color:var(--text-mid); line-height:1.7; margin:0; }
.ic { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:28px; margin:24px 0; }
.ic h3 { font-size:1rem; font-weight:700; color:var(--charcoal); margin-bottom:8px; }
.ic p { font-size:0.9rem; color:var(--text-mid); line-height:1.7; margin:0; }
.fg { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:24px 0; }
.fc { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:24px; }
.fc h3 { font-size:1rem; font-weight:700; color:var(--charcoal); margin-bottom:6px; }
.fc p { font-size:0.88rem; color:var(--text-mid); line-height:1.7; margin:0; }
.ft { display:inline-block; font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; padding:3px 10px; border-radius:50px; margin-bottom:10px; }
.ft.y { background:var(--green-light); color:var(--green); }
.ft.n { background:var(--red-bg); color:var(--red-soft); }
.nb { background:var(--accent-light); border:1px solid rgba(192,113,58,0.12); border-radius:var(--radius); padding:28px 32px; margin-top:48px; }
.nb p { font-size:0.9rem; color:var(--text-mid); line-height:1.8; margin:0; }
.nb strong { color:var(--text); }
.cta-block { background:var(--slate-dark); border-radius:var(--radius); padding:56px; text-align:center; color:#fff; }
.cta-block h2 { font-family:'Playfair Display',Georgia,serif; font-size:1.8rem; font-weight:500; margin:0 0 14px; }
.cta-block p { font-size:0.98rem; color:rgba(255,255,255,0.55); max-width:460px; margin:0 auto 32px; line-height:1.8; }

/* Vorgehensweise-Phasen */
.phase { display:grid; grid-template-columns:64px 1fr; gap:28px; padding:44px 0; border-bottom:1px solid var(--border); }
.phase:last-of-type { border-bottom:none; }
.phase-num { font-family:'Playfair Display',Georgia,serif; font-size:2.2rem; font-weight:500; color:var(--accent); line-height:1; }
.phase-time { font-size:0.78rem; font-weight:600; color:var(--text-soft); margin-bottom:10px; }
.phase h2 { font-family:'Playfair Display',Georgia,serif; font-size:1.4rem; font-weight:500; color:var(--charcoal); margin-bottom:14px; line-height:1.3; }
.phase p { font-size:0.95rem; color:var(--text-mid); line-height:1.85; margin-bottom:14px; }
.deliver { margin-top:20px; background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:22px 26px; }
.deliver-title { font-size:0.78rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; color:var(--text-soft); margin-bottom:14px; }
.deliver-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
.deliver-list li { font-size:0.9rem; color:var(--text-mid); line-height:1.6; display:flex; gap:10px; align-items:flex-start; }
.deliver-list li svg { width:16px; min-width:16px; height:16px; color:var(--green); margin-top:3px; }

/* Über-mich-Kacheln */
.value-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:8px; }
.value-card { padding:28px; border:1px solid var(--border); border-radius:var(--radius); background:var(--white); }
.value-card h3 { font-size:1rem; font-weight:700; color:var(--charcoal); margin-bottom:8px; }
.value-card p { font-size:0.9rem; color:var(--text-mid); line-height:1.7; }

/* Rechtstext-Seiten (Impressum / Datenschutz) */
.legal { max-width:760px; }
.legal h2 { font-family:'Playfair Display',Georgia,serif; font-size:1.3rem; font-weight:500; color:var(--charcoal); margin:40px 0 12px; }
.legal h2:first-child { margin-top:0; }
.legal h3 { font-size:1rem; font-weight:700; color:var(--charcoal); margin:24px 0 8px; }
.legal p { font-size:0.93rem; color:var(--text-mid); line-height:1.8; margin-bottom:12px; }
.legal a { color:var(--accent); }
.legal .todo { background:var(--warn-bg); border:1px dashed rgba(180,83,9,0.35); border-radius:var(--radius-sm); padding:14px 18px; color:var(--warn); font-size:0.88rem; margin:10px 0; }

/* ═══════════════ RESPONSIVE ═══════════════ */
@media (max-width:900px) {
    .header-nav { display:none; }
    .mobile-menu-btn { display:block; }
    .hero { padding:50px 0 40px; }
    .hero-grid { grid-template-columns:1fr; gap:40px; }
    .hero-visual { order:-1; }
    .hero-illustration { max-width:300px; }
    .section { padding:64px 0; }
    .deadline-grid { grid-template-columns:1fr 1fr; gap:24px 0; }
    .deadline-item { padding:12px 16px; }
    .deadline-item:nth-child(odd) { border-left:none; }
    .situation-grid, .danach-grid, .prinzip-grid, .value-grid, .fg { grid-template-columns:1fr; }
    .process-track { grid-template-columns:1fr; }
    .process-step { border-right:none; border-bottom:1px solid var(--border); }
    .process-step:last-child { border-bottom:none; }
    .profile-layout { grid-template-columns:1fr; gap:32px; }
    .profile-photo { max-width:200px; }
    .contact-layout { grid-template-columns:1fr; gap:40px; }
    .form-row { grid-template-columns:1fr; }
    .footer-grid { flex-direction:column; }
    .page-hero { padding:50px 0 36px; }
    .tl-i { grid-template-columns:80px 1fr; gap:16px; }
    .cta-block { padding:36px 24px; }
    .phase { grid-template-columns:1fr; gap:14px; }
}
@media (max-width:480px) {
    .deadline-grid { grid-template-columns:1fr; }
    .deadline-item { border-left:none; }
    .hero h1 { font-size:1.85rem; }
    .hero-actions { flex-direction:column; align-items:stretch; }
    .hero-actions .btn-main, .hero-actions .btn-ghost { justify-content:center; }
}

/* Bewegung reduzieren, wenn vom System gewünscht */
@media (prefers-reduced-motion:reduce) {
    *, *::before, *::after { animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}
