/* ============================================================
   COMPASS DIGITALAGENTUR — style.css
   Style: Minimalist Clean + Dark Mode (prefers-color-scheme)
   Brand: #1a5fa8 (blue) · #29c5d6 (cyan)
   Font: Inter (self-hosted, assets/fonts/)
   ============================================================ */

/* ─── @font-face ─────────────────────────────────────────── */
@font-face { font-family:'Inter'; font-style:normal; font-weight:400; font-display:swap; src:url('../assets/fonts/inter-400.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:500; font-display:swap; src:url('../assets/fonts/inter-500.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:600; font-display:swap; src:url('../assets/fonts/inter-600.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:700; font-display:swap; src:url('../assets/fonts/inter-700.woff2') format('woff2'); }
@font-face { font-family:'Inter'; font-style:normal; font-weight:800; font-display:swap; src:url('../assets/fonts/inter-800.woff2') format('woff2'); }

/* ─── Custom Properties: Light Mode ──────────────────────── */
:root {
  --blue:        #1a5fa8;
  --blue-d:      #134b86;
  --blue-l:      #2a7fd4;
  --cyan:        #29c5d6;
  --cyan-d:      #1faab9;
  --bg:          #ffffff;
  --bg-s:        #f8fafc;
  --bg-b:        #f1f5f9;
  --blue-tint:   #eff6ff;
  --text:        #0f172a;
  --text-s:      #475569;
  --text-xs:     #94a3b8;
  --border:      #e2e8f0;
  --border-s:    #cbd5e1;
  --radius:      10px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --shadow-sm:   0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);
  --shadow:      0 4px 16px rgba(0,0,0,.08);
  --shadow-md:   0 8px 32px rgba(0,0,0,.10);
  --shadow-blue: 0 8px 24px rgba(26,95,168,.20);
  --footer-bg:   #080d1a;
  --footer-s:    #0f1929;
  --nav-h:       72px;
  --font:        'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  --tr:          .25s cubic-bezier(.4,0,.2,1);
  /* ── Aliases for sub-pages ── */
  --nav-height:  72px;
  --text-muted:  #475569;
  --surface:     #f8fafc;
  --accent:      #1a5fa8;
  --accent-2:    #29c5d6;
  --space-xs:    .5rem;
  --space-sm:    1rem;
  --space-md:    1.75rem;
  --space-lg:    2.5rem;
  --space-xl:    5rem;
}

/* ─── Dark Mode ───────────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
  :root {
    --bg:#080d1a; --bg-s:#0f1929; --bg-b:#162035; --blue-tint:#0f1929;
    --text:#f1f5f9; --text-s:#94a3b8; --text-xs:#64748b;
    --border:#1e2d42; --border-s:#253550;
    --shadow-sm:0 1px 3px rgba(0,0,0,.3); --shadow:0 4px 16px rgba(0,0,0,.4); --shadow-md:0 8px 32px rgba(0,0,0,.5);
    --text-muted:#94a3b8; --surface:#0f1929;
  }
}

/* ─── Reset ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;font-family:var(--font)}
.container{max-width:1180px;margin:0 auto;padding:0 24px}

/* ─── Typography ──────────────────────────────────────────── */
h1{font-size:clamp(2.2rem,5vw,3.8rem);line-height:1.12;font-weight:800}
h2{font-size:clamp(1.75rem,3.2vw,2.6rem);line-height:1.2;font-weight:700}
h3{font-size:clamp(1.05rem,2vw,1.25rem);font-weight:600;line-height:1.35}
h4{font-size:.95rem;font-weight:600}
.section-label{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--blue);margin-bottom:12px}
.section-title{color:var(--text)}
.section-sub{color:var(--text-s);font-size:1.02rem;max-width:580px;margin:14px auto 0;line-height:1.7}
.text-center{text-align:center}

/* ─── Skip Nav ────────────────────────────────────────────── */
.skip-nav{position:absolute;top:-100px;left:20px;background:var(--blue);color:#fff;padding:10px 20px;border-radius:0 0 var(--radius) var(--radius);font-weight:600;font-size:.9rem;z-index:9999;transition:top .2s}
.skip-nav:focus{top:0;outline:3px solid var(--cyan);outline-offset:2px}

/* ─── Focus (WCAG AA) ─────────────────────────────────────── */
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px}
button:focus-visible,a:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:6px}

/* ─── Buttons ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:var(--radius);font-size:.93rem;font-weight:600;border:2px solid transparent;transition:all var(--tr);white-space:nowrap;cursor:pointer}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-d);border-color:var(--blue-d);transform:translateY(-1px);box-shadow:var(--shadow-blue)}
.btn-outline{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-outline:hover{background:var(--blue);color:#fff;transform:translateY(-1px)}
.btn-white{background:#fff;color:var(--blue);border-color:rgba(255,255,255,.3)}
.btn-white:hover{background:var(--blue-tint);border-color:#fff}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}
.btn-lg{padding:14px 28px;font-size:1rem}
.btn-sm{padding:7px 14px;font-size:.82rem}

/* ─── Navigation ──────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:transparent;transition:background var(--tr),box-shadow var(--tr),backdrop-filter var(--tr)}
.nav.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--border),var(--shadow-sm)}
@media (prefers-color-scheme:dark){.nav.scrolled{background:rgba(8,13,26,.92);box-shadow:0 1px 0 var(--border)}}
.nav-inner{display:flex;align-items:center;height:var(--nav-h);gap:8px}
.nav-logo img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:auto}
.nav-links a{padding:6px 11px;border-radius:var(--radius);font-size:.875rem;font-weight:500;color:var(--text-s);transition:color var(--tr),background var(--tr)}
.nav-links a:hover{color:var(--blue);background:var(--blue-tint)}
.nav-links .nav-cta{background:var(--blue);color:#fff;font-weight:600;margin-left:6px}
.nav-links .nav-cta:hover{background:var(--blue-d);box-shadow:var(--shadow-blue)}
.nav-extras{display:flex;align-items:center;gap:6px;margin-left:8px}
.lang-btn{padding:5px 10px;border-radius:var(--radius);border:1.5px solid var(--border);background:transparent;color:var(--text-s);font-size:.78rem;font-weight:700;letter-spacing:.04em;transition:all var(--tr);cursor:pointer}
.lang-btn:hover,.lang-btn.active{border-color:var(--blue);color:var(--blue)}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:8px;background:transparent;border:none;border-radius:var(--radius);margin-left:auto;transition:background var(--tr)}
.nav-burger:hover{background:var(--bg-s)}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:transform .25s,opacity .25s}
.nav-burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.active span:nth-child(2){opacity:0}
.nav-burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);padding:16px 24px 24px;flex-direction:column;gap:4px;z-index:999;box-shadow:var(--shadow-md)}
.nav-mobile.open{display:flex}
.nav-mobile a{padding:12px 16px;border-radius:var(--radius);font-size:.95rem;font-weight:500;color:var(--text-s);transition:background var(--tr),color var(--tr)}
.nav-mobile a:hover{background:var(--blue-tint);color:var(--blue)}
.nav-mobile .mob-cta{background:var(--blue);color:#fff;font-weight:600;margin-top:8px;text-align:center;display:block}
.nav-mobile .mob-cta:hover{background:var(--blue-d)}
.mob-extras{display:flex;gap:8px;padding:8px 16px 0;flex-wrap:wrap}

/* ─── Hero ────────────────────────────────────────────────── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:#04080f}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.32}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(4,8,15,.9) 0%,rgba(8,15,30,.7) 55%,rgba(26,95,168,.2) 100%)}
.hero-content{position:relative;z-index:1;padding-top:calc(var(--nav-h) + 56px);padding-bottom:88px;max-width:780px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(26,95,168,.2);border:1px solid rgba(41,197,214,.3);color:var(--cyan);padding:6px 14px;border-radius:100px;font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:28px}
.hero-badge .dot{width:7px;height:7px;background:var(--cyan);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}
.hero h1{color:#fff;margin-bottom:22px}
.hero h1 .highlight{color:transparent;background:linear-gradient(90deg,var(--cyan),var(--blue-l));-webkit-background-clip:text;background-clip:text}
.typing-wrap{display:block;min-height:1.15em;color:rgba(255,255,255,.85)}
.cursor{display:inline-block;width:3px;height:.85em;background:var(--cyan);border-radius:2px;vertical-align:middle;margin-left:2px;animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-sub{color:rgba(255,255,255,.68);font-size:1.08rem;line-height:1.75;max-width:540px;margin-bottom:36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:52px}
.hero-stats{display:flex;gap:36px;flex-wrap:wrap;padding-top:32px;border-top:1px solid rgba(255,255,255,.12)}
.hero-stat strong{display:block;font-size:1.55rem;font-weight:800;color:#fff;line-height:1;margin-bottom:4px}
.hero-stat span{font-size:.78rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.05em}

/* ─── Trust Bar ───────────────────────────────────────────── */
.trust{background:var(--bg-s);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:16px 0}
.trust-inner{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.trust-label{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-xs);white-space:nowrap}
.trust-icons{display:flex;flex-wrap:wrap;gap:6px}
.trust-icon{padding:5px 11px;background:var(--bg);border:1px solid var(--border);border-radius:100px;font-size:.78rem;font-weight:500;color:var(--text-s)}

/* ─── USP Strip ───────────────────────────────────────────── */
.usp-strip{padding:88px 0}
.usp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.usp-item{padding:32px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);transition:border-color var(--tr),box-shadow var(--tr),transform var(--tr)}
.usp-item:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-4px)}
.usp-num{font-size:2.2rem;font-weight:800;color:var(--border-s);line-height:1;margin-bottom:16px;font-variant-numeric:tabular-nums}
.usp-item h3{margin-bottom:10px}
.usp-item p{color:var(--text-s);font-size:.9rem;line-height:1.65}

/* ─── Services ────────────────────────────────────────────── */
.services{padding:96px 0;background:var(--bg-s)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-top:56px}
.service-card{background:var(--bg);padding:30px;transition:background var(--tr);position:relative}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--cyan));opacity:0;transition:opacity var(--tr)}
.service-card:hover{background:var(--blue-tint)}
.service-card:hover::before{opacity:1}
.service-num{font-size:.7rem;font-weight:700;color:var(--blue);letter-spacing:.12em;margin-bottom:14px;font-family:monospace}
.service-card h3{margin-bottom:10px}
.service-card p{color:var(--text-s);font-size:.875rem;line-height:1.65}

/* ─── Process ─────────────────────────────────────────────── */
.process{padding:96px 0}
.process-wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:56px}
.process-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.process-img img{width:100%;aspect-ratio:4/3;object-fit:cover}
.process-steps{display:flex;flex-direction:column}
.process-step{display:flex;gap:20px;padding:28px 0;border-bottom:1px solid var(--border)}
.process-step:first-child{border-top:1px solid var(--border)}
.process-num{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--blue);color:#fff;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:2px}
.process-step h3{margin-bottom:6px}
.process-step p{color:var(--text-s);font-size:.875rem;line-height:1.65}

/* ─── Statistics ──────────────────────────────────────────── */
.stats{padding:80px 0;background:var(--blue);position:relative;overflow:hidden}
.stats::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(41,197,214,.12),transparent);pointer-events:none}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center;position:relative;z-index:1}
.stat-item{}
.stat-num{font-size:clamp(2.2rem,4vw,3.2rem);font-weight:800;color:#fff;line-height:1;margin-bottom:8px}
.stat-suffix{font-size:clamp(1.6rem,3vw,2.4rem)}
.stat-label{font-size:.85rem;color:rgba(255,255,255,.65);font-weight:500}

/* ─── Portfolio ───────────────────────────────────────────── */
.portfolio{padding:96px 0;background:var(--bg-s)}
.portfolio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:56px}
.portfolio-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--bg);border:1px solid var(--border);transition:transform var(--tr),box-shadow var(--tr)}
.portfolio-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.portfolio-img{position:relative;overflow:hidden;aspect-ratio:16/10}
.portfolio-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.portfolio-card:hover .portfolio-img img{transform:scale(1.06)}
.portfolio-overlay{position:absolute;inset:0;background:rgba(4,8,15,.78);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--tr)}
.portfolio-card:hover .portfolio-overlay{opacity:1}
.portfolio-body{padding:18px}
.portfolio-tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
.portfolio-body h3{font-size:.95rem;margin-bottom:5px}
.portfolio-body p{font-size:.82rem;color:var(--text-s);line-height:1.55}

/* ─── CTA Banner ──────────────────────────────────────────── */
.cta-banner{position:relative;overflow:hidden;background:#04080f;padding:80px 0}
.cta-banner-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.22}
.cta-banner-content{position:relative;z-index:1;max-width:600px}
.cta-banner-content h2{color:#fff;margin-bottom:16px}
.cta-banner-content p{color:rgba(255,255,255,.68);margin-bottom:32px;font-size:1rem;line-height:1.75}
.cta-btns{display:flex;gap:14px;flex-wrap:wrap}

/* ─── Pricing ─────────────────────────────────────────────── */
.pricing{padding:96px 0}
.pricing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:56px;max-width:840px;margin-left:auto;margin-right:auto}
.pricing-card{border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;background:var(--bg);position:relative;transition:border-color var(--tr),box-shadow var(--tr)}
.pricing-card.featured{border-color:var(--blue);box-shadow:var(--shadow-blue)}
.pricing-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:.72rem;font-weight:700;padding:5px 16px;border-radius:100px;white-space:nowrap}
.pricing-name{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-xs);margin-bottom:14px}
.pricing-price{display:flex;align-items:flex-end;gap:3px;margin-bottom:8px;line-height:1}
.pricing-price .currency{font-size:1.3rem;font-weight:700;color:var(--blue);padding-bottom:6px}
.pricing-price .amount{font-size:3rem;font-weight:800;color:var(--text)}
.pricing-price .period{font-size:.88rem;color:var(--text-s);padding-bottom:8px}
.pricing-note{font-size:.85rem;color:var(--text-s);margin-bottom:24px;line-height:1.6}
.pricing-features{display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.pricing-features li{display:flex;gap:10px;font-size:.875rem;align-items:flex-start}
.pricing-features .check{color:var(--blue);font-weight:700;flex-shrink:0}
.hosting-box{background:var(--bg-s);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-top:20px}
.hosting-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-xs);margin-bottom:6px}
.hosting-price{font-size:1.25rem;font-weight:700;color:var(--blue);margin-bottom:10px}
.hosting-price span{font-size:.82rem;font-weight:400;color:var(--text-s)}
.hosting-includes{display:flex;flex-wrap:wrap;gap:5px}
.hosting-includes li{font-size:.74rem;padding:3px 9px;background:var(--bg);border:1px solid var(--border);border-radius:100px;color:var(--text-s)}

/* ─── Wizard (Angebotsanfrage) ────────────────────────────── */
.wizard-section{padding:96px 0;background:var(--bg-s)}
.wizard-wrap{max-width:720px;margin:56px auto 0;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow)}
.wizard-progress{height:4px;background:var(--border)}
.wizard-progress-bar{height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan));transition:width .4s ease;border-radius:4px}
.wizard-header{padding:32px 36px 0}
.wizard-step-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text-xs);margin-bottom:6px}
.wizard-header h3{font-size:1.35rem;margin-bottom:6px}
.wizard-header p{font-size:.875rem;color:var(--text-s)}
.wizard-body{padding:24px 36px}
.wizard-step{display:none}
.wizard-step.active{display:block}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.svc-card{border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 12px;cursor:pointer;transition:all var(--tr);text-align:center;background:var(--bg);user-select:none}
.svc-card:hover{border-color:var(--blue);background:var(--blue-tint)}
.svc-card.selected{border-color:var(--blue);background:var(--blue-tint);box-shadow:0 0 0 3px rgba(26,95,168,.12)}
.svc-icon{font-size:1.7rem;margin-bottom:7px;display:block}
.svc-label{font-size:.82rem;font-weight:600;color:var(--text)}

.opt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.opt-card{border:1.5px solid var(--border);border-radius:var(--radius);padding:13px 14px;cursor:pointer;transition:all var(--tr);background:var(--bg);user-select:none}
.opt-card:hover{border-color:var(--blue)}
.opt-card.selected{border-color:var(--blue);background:var(--blue-tint);box-shadow:0 0 0 3px rgba(26,95,168,.12)}
.opt-title{font-size:.875rem;font-weight:600;display:block;margin-bottom:2px}
.opt-sub{font-size:.76rem;color:var(--text-s)}

.wiz-field{margin-bottom:14px}
.wiz-field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:5px;color:var(--text)}
.wiz-field input,.wiz-field textarea,.wiz-field select{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:.9rem;background:var(--bg);color:var(--text);transition:border-color var(--tr),box-shadow var(--tr)}
.wiz-field input:focus,.wiz-field textarea:focus,.wiz-field select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,95,168,.1)}
.wiz-field textarea{min-height:100px;resize:vertical}
.wiz-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.wiz-sub{font-size:.76rem;color:var(--text-xs);margin-top:4px}
.opt-hint{font-size:.8rem;color:var(--text-s);margin-bottom:10px;font-style:italic}

.wizard-footer{display:flex;justify-content:space-between;align-items:center;padding:18px 36px 28px;border-top:1px solid var(--border);gap:12px}
.wiz-back{padding:9px 18px;border:1.5px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-s);font-size:.875rem;font-weight:500;transition:all var(--tr);cursor:pointer}
.wiz-back:hover{border-color:var(--text-s);color:var(--text)}
.wiz-back:disabled{opacity:.3;cursor:not-allowed}

.wizard-success{display:none;text-align:center;padding:56px 36px}
.ws-icon{font-size:3rem;margin-bottom:14px}
.wizard-success h3{margin-bottom:10px}
.wizard-success p{color:var(--text-s);font-size:.93rem}

/* ─── Blog ────────────────────────────────────────────────── */
.blog{padding:96px 0}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.blog-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg);transition:transform var(--tr),box-shadow var(--tr)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.blog-img-link{display:block;overflow:hidden;aspect-ratio:16/9}
.blog-img-link img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .blog-img-link img{transform:scale(1.04)}
.blog-body{padding:20px}
.blog-tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.blog-body h3{font-size:.95rem;margin-bottom:7px;line-height:1.4}
.blog-body h3 a{color:var(--text);transition:color var(--tr)}
.blog-body h3 a:hover{color:var(--blue)}
.blog-body p{font-size:.845rem;color:var(--text-s);line-height:1.6;margin-bottom:10px}
.blog-date{font-size:.74rem;color:var(--text-xs)}

/* ─── About ───────────────────────────────────────────────── */
.about{padding:96px 0;background:var(--bg-s)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-img-wrap{position:relative}
.about-img-wrap img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius-lg)}
.about-tag{position:absolute;bottom:24px;left:24px;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-radius:var(--radius);padding:14px 20px;box-shadow:var(--shadow-md)}
@media (prefers-color-scheme:dark){.about-tag{background:rgba(15,25,41,.95)}}
.about-tag strong{display:block;font-size:1.6rem;font-weight:800;color:var(--blue)}
.about-tag span{font-size:.78rem;color:var(--text-s)}
.about-content .section-title{margin-bottom:14px}
.about-content > p{color:var(--text-s);line-height:1.75;margin-bottom:12px;font-size:.95rem}
.about-list{margin-top:24px;display:flex;flex-direction:column;gap:13px}
.about-list li{display:flex;gap:13px;align-items:flex-start}
.about-list .icon{flex-shrink:0;width:34px;height:34px;background:var(--blue-tint);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:.95rem;margin-top:2px}
.about-list li > div{font-size:.875rem;color:var(--text-s);line-height:1.6}
.about-list strong{color:var(--text)}

/* ─── FAQ ─────────────────────────────────────────────────── */
.faq{padding:96px 0}
.faq-list{max-width:720px;margin:56px auto 0}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:20px 0;cursor:pointer;font-weight:600;font-size:.97rem;gap:14px;color:var(--text);transition:color var(--tr);background:none;border:none;width:100%;text-align:left;user-select:none}
.faq-q:hover{color:var(--blue)}
.faq-q[aria-expanded="true"]{color:var(--blue)}
.faq-icon{flex-shrink:0;width:28px;height:28px;border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:all var(--tr)}
.faq-q[aria-expanded="true"] .faq-icon{background:var(--blue);border-color:var(--blue);color:#fff;transform:rotate(45deg)}
.faq-a{display:none;padding:0 0 20px;color:var(--text-s);font-size:.91rem;line-height:1.75;max-width:640px}
.faq-a.open{display:block}

/* ─── Contact ─────────────────────────────────────────────── */
.contact{padding:96px 0;background:var(--bg-s)}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:56px;margin-top:56px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:12px}
.contact-item{display:flex;gap:13px;align-items:flex-start;padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);transition:border-color var(--tr)}
.contact-item:hover{border-color:var(--blue)}
.contact-icon{flex-shrink:0;width:38px;height:38px;background:var(--blue-tint);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1rem}
.contact-item strong{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-xs);margin-bottom:3px}
.contact-item a,.contact-item span{color:var(--text-s);font-size:.875rem;transition:color var(--tr)}
.contact-item a:hover{color:var(--blue)}

.contact-form-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.contact-form-inner{padding:32px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.82rem;font-weight:600;margin-bottom:5px;color:var(--text)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:.9rem;background:var(--bg);color:var(--text);transition:border-color var(--tr),box-shadow var(--tr)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,95,168,.1)}
.form-group textarea{min-height:100px;resize:vertical}
.form-note{font-size:.75rem;color:var(--text-xs);margin-top:10px;line-height:1.5}
.form-note a{color:var(--blue)}
.form-success{display:none;text-align:center;padding:56px 32px}
.success-icon{font-size:2.8rem;margin-bottom:14px}
.form-success h3{margin-bottom:8px}
.form-success p{color:var(--text-s);font-size:.9rem}

.maps-wrap{margin-top:32px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border)}
.maps-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:44px 24px;background:var(--bg-s);gap:10px}
.maps-placeholder .mp-icon{font-size:2rem}
.maps-placeholder p{font-size:.84rem;color:var(--text-s);max-width:380px;line-height:1.55}
.maps-placeholder p a{color:var(--blue)}
.maps-load-btn{padding:9px 20px;background:var(--blue);color:#fff;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--tr)}
.maps-load-btn:hover{background:var(--blue-d)}
.maps-wrap iframe{display:none;width:100%;height:300px;border:0}
.maps-wrap iframe.loaded{display:block}
.maps-placeholder.hidden{display:none}

/* ─── Legal Pages ──────────────────────────────────────────── */
.legal-page{padding:calc(var(--nav-h) + 48px) 0 80px}
.legal-container{max-width:800px;margin:0 auto}
.legal-header{margin-bottom:36px}
.legal-back{display:inline-flex;align-items:center;gap:6px;color:var(--blue);font-size:.875rem;font-weight:500;margin-bottom:18px;transition:gap var(--tr)}
.legal-back:hover{gap:10px}
.legal-header h1{font-size:2rem;margin-bottom:6px}
.legal-updated{color:var(--text-xs);font-size:.82rem}
.legal-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 32px;margin-bottom:16px}
.legal-card h2{font-size:1.15rem;margin-bottom:14px;padding-bottom:11px;border-bottom:1px solid var(--border)}
.legal-card h3{font-size:.95rem;margin:18px 0 7px}
.legal-card p{color:var(--text-s);font-size:.875rem;line-height:1.75;margin-bottom:9px}
.legal-card a{color:var(--blue)}
.legal-card a:hover{text-decoration:underline}
.legal-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.legal-info-block h3{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-xs);margin:0 0 7px}
.legal-info-block p{font-size:.875rem;color:var(--text-s);line-height:1.7}
.legal-note{font-size:.8rem;color:var(--text-xs);margin-top:6px !important}
.legal-toc{margin-bottom:6px}
.legal-toc li{margin-bottom:5px}
.legal-toc a{color:var(--blue);font-size:.875rem}
.legal-table{width:100%;border-collapse:collapse;font-size:.82rem}
.legal-table th,.legal-table td{padding:9px 11px;text-align:left;border-bottom:1px solid var(--border)}
.legal-table th{font-weight:600;color:var(--text);background:var(--bg-s)}
.legal-table td{color:var(--text-s)}

/* ─── Footer ──────────────────────────────────────────────── */
.footer{background:var(--footer-bg);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:44px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-logo img{height:34px;filter:brightness(10)}
.footer-brand p{color:rgba(255,255,255,.45);font-size:.84rem;line-height:1.65;margin-top:14px;max-width:240px}
.footer-social{display:flex;gap:8px;margin-top:18px}
.social-link{width:34px;height:34px;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);transition:all var(--tr)}
.social-link:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(41,197,214,.08)}
.footer-col h4{color:rgba(255,255,255,.85);font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin-bottom:14px}
.footer-col ul{display:flex;flex-direction:column;gap:7px}
.footer-col a{color:rgba(255,255,255,.4);font-size:.845rem;transition:color var(--tr)}
.footer-col a:hover{color:rgba(255,255,255,.88)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:14px;flex-wrap:wrap}
.footer-bottom p{color:rgba(255,255,255,.25);font-size:.76rem}
.footer-legal{display:flex;gap:18px;flex-wrap:wrap}
.footer-legal a{color:rgba(255,255,255,.3);font-size:.76rem;transition:color var(--tr)}
.footer-legal a:hover{color:rgba(255,255,255,.78)}

/* ─── WhatsApp ─────────────────────────────────────────────── */
.wa-btn{position:fixed;bottom:28px;right:28px;z-index:900;width:52px;height:52px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(37,211,102,.4);transition:transform var(--tr),box-shadow var(--tr)}
.wa-btn:hover{transform:scale(1.1);box-shadow:0 6px 26px rgba(37,211,102,.55)}
.wa-btn svg{width:26px;height:26px;fill:#fff}
.wa-tooltip{position:absolute;right:62px;top:50%;transform:translateY(-50%);background:#111;color:#fff;font-size:.76rem;font-weight:500;padding:5px 11px;border-radius:var(--radius);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--tr)}
.wa-btn:hover .wa-tooltip{opacity:1}

/* ─── Cookie Banner ────────────────────────────────────────── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9000;background:var(--bg);border-top:1px solid var(--border);box-shadow:0 -4px 24px rgba(0,0,0,.1);padding:18px 0;display:none}
.cookie-banner.visible{display:block}
.cookie-inner{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.cookie-text{flex:1;min-width:260px}
.cookie-text h4{font-size:.95rem;margin-bottom:5px}
.cookie-text p{font-size:.79rem;color:var(--text-s);line-height:1.5}
.cookie-text a{color:var(--blue)}
.cookie-actions{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}
.ck-btn{padding:8px 16px;border-radius:var(--radius);font-size:.82rem;font-weight:600;border:1.5px solid transparent;transition:all var(--tr);cursor:pointer;font-family:var(--font)}
.ck-accept{background:var(--blue);color:#fff;border-color:var(--blue)}
.ck-accept:hover{background:var(--blue-d)}
.ck-decline{background:transparent;color:var(--text-s);border-color:var(--border)}
.ck-decline:hover{border-color:var(--text-s);color:var(--text)}
.ck-settings{background:transparent;color:var(--blue);border-color:var(--border)}
.ck-settings:hover{border-color:var(--blue)}

.cookie-overlay{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:9500;display:none;align-items:center;justify-content:center;padding:20px}
.cookie-overlay.open{display:flex}
.cookie-box{background:var(--bg);border-radius:var(--radius-xl);padding:32px;max-width:500px;width:100%;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-md)}
.cookie-box h3{margin-bottom:7px}
.cookie-box > p{font-size:.845rem;color:var(--text-s);margin-bottom:22px;line-height:1.55}
.ck-cat{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:16px 0;border-top:1px solid var(--border)}
.ck-cat:last-of-type{border-bottom:1px solid var(--border);margin-bottom:18px}
.ck-cat-info h4{font-size:.88rem;margin-bottom:3px}
.ck-cat-info p{font-size:.76rem;color:var(--text-s);line-height:1.45}
.ck-toggle{position:relative;flex-shrink:0}
.ck-toggle input{opacity:0;width:0;height:0;position:absolute}
.ck-slider{display:block;width:42px;height:22px;background:var(--border-s);border-radius:11px;cursor:pointer;transition:background var(--tr);position:relative}
.ck-slider::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform var(--tr);box-shadow:0 1px 3px rgba(0,0,0,.2)}
.ck-toggle input:checked + .ck-slider{background:var(--blue)}
.ck-toggle input:checked + .ck-slider::after{transform:translateX(20px)}
.ck-toggle input:disabled + .ck-slider{opacity:.5;cursor:not-allowed}
.ck-box-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}

/* ─── Scroll Reveal ────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ─── 404 ─────────────────────────────────────────────────── */
.not-found{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding-top:var(--nav-h)}
.not-found-num{font-size:clamp(6rem,15vw,10rem);font-weight:800;color:var(--blue);line-height:1;opacity:.15}
.not-found-content{position:relative;margin-top:-48px}
.not-found-content h1{margin-bottom:12px}
.not-found-content p{color:var(--text-s);margin-bottom:28px;font-size:1rem}

/* ─── Responsive ──────────────────────────────────────────── */
@media (max-width:1024px){
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:28px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .services-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .nav-links,.nav-extras{display:none}
  .nav-burger{display:flex}
  .usp-grid,.services-grid,.process-wrap,.blog-grid,.about-grid,.contact-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .form-row,.wiz-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr;gap:20px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .process-img{display:none}
  .about-img-wrap{display:none}
  .cookie-inner{flex-direction:column;align-items:stretch}
  .cookie-actions{flex-wrap:wrap}
  .wizard-header{padding:24px 22px 0}
  .wizard-body{padding:20px 22px}
  .wizard-footer{padding:16px 22px 24px}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .opt-grid{grid-template-columns:1fr}
  .contact-form-inner{padding:22px}
  .legal-info-grid{grid-template-columns:1fr}
  .hero-stats{gap:18px}
  .cta-btns{flex-direction:column;align-items:flex-start}
}
@media (max-width:480px){
  .container{padding:0 16px}
  .svc-grid{grid-template-columns:1fr}
  .pricing-card{padding:28px 22px}
  .hero-cta{flex-direction:column;align-items:flex-start}
}

/* ─── Page Hero (Unterseiten) ─────────────────────────────── */
.page-hero{padding:calc(var(--nav-h) + 5rem) 0 4rem;background:var(--bg);border-bottom:1px solid var(--border)}
.page-hero .section-label{display:block;margin-bottom:.5rem}
.page-hero h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.15;margin-bottom:1rem}
.page-hero p{color:var(--text-s);font-size:1.1rem;max-width:600px}

/* ─── Cookie-Toggle (button-basiert, ARIA) ────────────────── */
button.ck-toggle{position:relative;flex-shrink:0;width:42px;height:22px;background:var(--border-s);border-radius:11px;border:none;cursor:pointer;transition:background var(--tr);padding:0}
button.ck-toggle[aria-checked="true"]{background:var(--blue)}
button.ck-toggle.disabled{opacity:.5;cursor:not-allowed}
.ck-toggle-inner{position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform var(--tr);box-shadow:0 1px 3px rgba(0,0,0,.2);pointer-events:none}
button.ck-toggle[aria-checked="true"] .ck-toggle-inner{transform:translateX(20px)}
.ck-overlay-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}

/* ─── Footer-Links (Alias für footer-col) ────────────────── */
.footer-links{color:inherit}
.footer-links h3{color:rgba(255,255,255,.85);font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin-bottom:14px}
.footer-links ul{display:flex;flex-direction:column;gap:7px}
.footer-links a{color:rgba(255,255,255,.4);font-size:.845rem;transition:color var(--tr)}
.footer-links a:hover{color:rgba(255,255,255,.88)}

/* ─── Legal Pages (Impressum / Datenschutz) ──────────────── */
.legal-page{padding-top:calc(var(--nav-h) + var(--space-xl));padding-bottom:var(--space-xl);min-height:100vh}
.legal-content{max-width:760px;margin:0 auto;padding:0 var(--space-md)}
.legal-content h1{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;margin-bottom:var(--space-lg)}
.legal-content h2{font-size:1.1rem;font-weight:700;margin-top:var(--space-lg);margin-bottom:var(--space-xs);color:var(--blue)}
.legal-content p,.legal-content address{font-style:normal;color:var(--text-s);line-height:1.8;margin-bottom:var(--space-sm)}
.legal-content a{color:var(--blue)}
.legal-content a:hover{text-decoration:underline}
.legal-content ul{padding-left:1.4rem;margin-bottom:var(--space-sm)}
.legal-content li{color:var(--text-s);line-height:1.8;margin-bottom:.3rem}
.legal-divider{border:none;border-top:1px solid var(--border);margin:var(--space-lg) 0}
.legal-updated{font-size:.85rem;color:var(--text-s);margin-top:var(--space-lg)}
.toc{background:var(--bg-s);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-lg)}
.toc h2{margin-top:0;font-size:1rem}
.toc ol{padding-left:1.4rem;margin:0}
.toc li{margin-bottom:.3rem}
.cookie-table{width:100%;border-collapse:collapse;margin:var(--space-md) 0;font-size:.9rem}
.cookie-table th{background:var(--bg-s);color:var(--text);font-weight:600;padding:.6rem .8rem;text-align:left;border:1px solid var(--border)}
.cookie-table td{padding:.55rem .8rem;border:1px solid var(--border);color:var(--text-s);vertical-align:top}

/* ─── Error Page (404) ────────────────────────────────────── */
.error-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:calc(var(--nav-h) + 2rem) var(--space-md) var(--space-xl);text-align:center}
.error-content{max-width:560px}
.error-code{font-size:clamp(6rem,20vw,12rem);font-weight:800;line-height:1;background:linear-gradient(135deg,var(--blue),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm)}
.error-title{font-size:clamp(1.4rem,4vw,2rem);font-weight:700;color:var(--text);margin-bottom:var(--space-sm)}
.error-desc{color:var(--text-s);font-size:1.05rem;line-height:1.7;margin-bottom:var(--space-lg)}
.error-actions{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap}

/* ─── Blog Übersicht – Filter ─────────────────────────────── */
.blog-filter-bar{padding:1.75rem 0;border-bottom:1px solid var(--border);background:var(--bg)}
.blog-filter-inner{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.blog-filter-btn{padding:.45rem 1.1rem;border-radius:100px;border:1.5px solid var(--border);font-size:.82rem;font-weight:600;color:var(--text-s);background:var(--bg);cursor:pointer;transition:all var(--tr)}
.blog-filter-btn:hover{border-color:var(--blue);color:var(--blue)}
.blog-filter-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}

/* ─── Blog Article (Einzelartikel) ───────────────────────── */
/* Hero-Bild direkt unter der Nav */
.article-hero{margin-top:var(--nav-h);overflow:hidden;max-height:480px;background:var(--bg-b)}
.article-hero img{width:100%;height:100%;object-fit:cover;display:block}

/* Artikel-Inhalt */
.article-body{max-width:760px;margin:0 auto;padding:var(--space-xl) var(--space-md)}

/* Breadcrumb ol.blog-nav */
ol.blog-nav{display:flex;gap:.4rem;flex-wrap:wrap;list-style:none;padding:0;margin-bottom:1.25rem;font-size:.82rem;color:var(--text-xs)}
ol.blog-nav li{display:flex;align-items:center;gap:.4rem}
ol.blog-nav li:not(:last-child)::after{content:'›';color:var(--text-xs)}
ol.blog-nav a{color:var(--blue);transition:opacity var(--tr)}
ol.blog-nav a:hover{opacity:.75}
ol.blog-nav li[aria-current="page"]{color:var(--text-s)}

/* Artikel-Metadaten */
.article-meta{margin-bottom:2rem}
.article-meta h1{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;line-height:1.2;margin:.75rem 0 .5rem}
.article-date{font-size:.85rem;color:var(--text-xs);margin-top:.25rem}

/* Lead-Absatz */
.article-content p.lead{font-size:1.15rem;font-weight:500;color:var(--text);line-height:1.75;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}

/* Fließtext */
.article-content h2{font-size:clamp(1.3rem,3vw,1.7rem);font-weight:700;margin:2.5rem 0 1rem;color:var(--text)}
.article-content h3{font-size:1.05rem;font-weight:600;margin:2rem 0 .75rem;color:var(--text)}
.article-content p{color:var(--text-s);line-height:1.85;margin-bottom:1.25rem;font-size:1rem}
.article-content ul,.article-content ol{padding-left:1.5rem;margin-bottom:1.25rem;color:var(--text-s);line-height:1.8}
.article-content li{margin-bottom:.4rem}
.article-content strong{color:var(--text);font-weight:600}
.article-content a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}

/* CTA-Box am Artikelende */
.article-cta{background:var(--bg-s);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;margin-top:3rem;text-align:center}
.article-cta h3{margin-bottom:.5rem}
.article-cta p{color:var(--text-s);font-size:.9rem;margin-bottom:1.25rem}

/* Weitere Artikel */
.article-more{margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--border)}
.article-more h3{font-size:1.15rem;font-weight:700;margin-bottom:1.5rem;color:var(--text)}
.article-more .blog-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}

/* Blog-Filter-Tags (für Kategorie-Chips im Artikel) */
.blog-nav-tag{padding:.4rem 1rem;border-radius:100px;border:1.5px solid var(--border);font-size:.8rem;font-weight:600;color:var(--text-s);transition:all var(--tr);cursor:pointer;background:var(--bg);display:inline-block}
.blog-nav-tag:hover,.blog-nav-tag.active{border-color:var(--blue);color:var(--blue);background:var(--blue-tint)}
