/* =========================================================
   RUKNOVA – zentrale Stylesheet
   Aufbau:  1) Schriften (selbst gehostet)
            2) BASIS (global, auf allen Seiten gleich)
            3) Seiten-spezifisch, je unter einer Body-Klasse (.p-…)
   So bleibt die Optik identisch und nichts kollidiert.
   ========================================================= */

/* ---------- 1) Schriften (selbst gehostet, /fonts/) ---------- */
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/cormorant-garamond-500.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/cormorant-garamond-600.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/cormorant-garamond-700.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:600;font-display:swap;src:url('/assets/fonts/cormorant-garamond-600-italic.woff2') format('woff2')}
@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:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/jetbrains-mono-400.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/jetbrains-mono-500.woff2') format('woff2')}

/* ---------- 2) BASIS (global) ---------- */
:root{
  --bg:#0E0A16; --surface:#16111F; --surface2:#1C1629;
  --line:rgba(195,204,210,.13); --line-strong:rgba(195,204,210,.26);
  --text:#E9EAF1; --muted:#969DAB; --read:#C7CAD4;
  --violet:#4A2A78; --lavender:#9A7BE8; --platinum:#C3CCD2; --light:#EEEFF4;
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Inter',system-ui,sans-serif; --mono:'JetBrains Mono',monospace;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--lavender);outline-offset:3px;border-radius:3px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
html.js .reveal{opacity:0;transform:translateY(18px)}
html.js .reveal.in{opacity:1;transform:none;transition:opacity .7s ease,transform .7s ease}
@media (prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none}}

.eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 18px}
.eyebrow::before{content:"";width:3px;height:18px;background:var(--platinum);border-radius:2px}
h1,h2,h3,h4{font-family:var(--serif);color:var(--light);margin:0;font-weight:600;line-height:1.12}

header{position:sticky;top:0;z-index:50;background:rgba(14,10,22,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:13px}
.brand .wm{font-family:var(--serif);font-weight:600;font-size:23px;letter-spacing:.14em;padding-left:.14em;color:var(--platinum)}
.nav-links{display:flex;gap:30px;font-size:14px;color:var(--muted)}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--text)}
.btn{font-family:var(--sans);font-weight:500;font-size:14px;padding:11px 22px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:transform .15s ease,border-color .2s ease;display:inline-block}
.btn-primary{background:var(--platinum);color:#13101C}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--lavender)}
.menu-toggle{display:none;background:none;border:1px solid var(--line-strong);border-radius:8px;color:var(--text);width:42px;height:40px;font-size:20px;cursor:pointer}

footer{border-top:1px solid var(--line);padding:64px 0 40px;margin-top:90px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;margin-bottom:44px}
.fcol h5{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 16px;font-weight:400}
.fcol a{display:block;font-size:14px;color:var(--muted);padding:5px 0}
.fcol a:hover{color:var(--text)}
.fabout p{font-size:14px;color:var(--muted);max-width:32ch;margin:14px 0 0}
.fsocial{display:flex;gap:12px;margin-top:20px}
.fsocial a{width:38px;height:38px;border:1px solid var(--line-strong);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:color .2s ease,border-color .2s ease}
.fsocial a:hover{color:var(--lavender);border-color:var(--lavender)}
.fsocial svg{width:18px;height:18px}
.fbottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:26px;border-top:1px solid var(--line);font-family:var(--mono);font-size:12px;color:var(--muted)}

@media (max-width:920px){.fgrid{grid-template-columns:1fr 1fr}}
@media (max-width:760px){
  .nav-links{display:none}
  .menu-toggle{display:inline-block}
  .nav-links.open{display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:8px 28px 18px}
  .nav-links.open a{padding:12px 0;border-top:1px solid var(--line)}
  .fgrid{grid-template-columns:1fr}
  .header-cta{display:none}
}

/* ---------- 3a) STARTSEITE (.p-home) ---------- */
.p-home :is(h1,h2,h3,h4){line-height:1.08}
.p-home h2{font-size:clamp(30px,4.4vw,46px);letter-spacing:.01em}
.p-home .section{padding:88px 0;border-top:1px solid var(--line)}
.p-home .section-head{max-width:640px;margin-bottom:44px}
.p-home .section-head h2{margin-bottom:14px}
.p-home .section-head p{color:var(--muted);margin:0;font-size:17px}
.p-home .row-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.p-home .link{font-family:var(--mono);font-size:13px;color:var(--lavender);letter-spacing:.03em;white-space:nowrap}

.p-home .hero{border-top:none}
.p-home .hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;padding:92px 0 84px}
.p-home .hero h1{font-size:clamp(44px,6.6vw,78px);font-weight:600;letter-spacing:.005em;margin:6px 0 24px}
.p-home .hero h1 em{font-style:italic;color:var(--lavender)}
.p-home .hero .sub{font-size:clamp(17px,2vw,20px);color:var(--text);max-width:54ch;margin:0 0 36px}
.p-home .hero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.p-home .trust{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.p-home .trust .d{width:4px;height:4px;border-radius:50%;background:var(--violet)}
.p-home .hero-art{display:flex;justify-content:center}
.p-home .hero-art svg{width:100%;max-width:440px;height:auto}

.p-home .cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.p-home .svc{background:var(--bg);padding:28px 24px;transition:background .25s ease}
.p-home .svc:hover{background:var(--surface)}
.p-home .ico{color:var(--lavender);margin-bottom:16px;height:26px}
.p-home .ico svg{width:26px;height:26px;stroke:currentColor;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.p-home .svc h3{font-size:21px;margin-bottom:8px}
.p-home .svc p{font-size:14px;color:var(--muted);margin:0;line-height:1.55}

.p-home .partner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.p-home .partner .hl{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}
.p-home .partner .hl span{font-family:var(--mono);font-size:12px;color:var(--text);border:1px solid var(--line);border-radius:999px;padding:7px 15px}
.p-home .scale-panel{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:36px 34px}
.p-home .scale-bar{height:12px;border-radius:999px;background:linear-gradient(90deg,#3A2363,#4A2A78,#9A7BE8)}
.p-home .scale-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:14px}
.p-home .scale-cap{font-family:var(--serif);font-size:26px;color:var(--light);margin:26px 0 0;line-height:1.2}

.p-home .why{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start}
.p-home .vals{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.p-home .val{background:var(--bg);padding:22px 24px}
.p-home .val h4{font-family:var(--sans);font-weight:500;font-size:15px;color:var(--text);margin-bottom:6px}
.p-home .val p{font-size:14px;color:var(--muted);margin:0}

.p-home .posts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.p-home .post{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px 24px;display:flex;flex-direction:column;transition:transform .18s ease,border-color .2s ease}
.p-home .post:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.p-home .post .cat{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--lavender);text-transform:uppercase;margin-bottom:14px;display:flex;justify-content:space-between}
.p-home .post .cat .date{color:var(--muted)}
.p-home .post h3{font-size:21px;line-height:1.2;margin-bottom:12px}
.p-home .post p{font-size:14px;color:var(--muted);margin:0 0 18px;flex:1}
.p-home .post .more{font-family:var(--mono);font-size:12px;color:var(--text)}

.p-home .band{background:var(--surface2);border:1px solid var(--line);border-radius:20px;padding:56px 48px;text-align:center;position:relative;overflow:hidden}
.p-home .band::after{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:420px;height:300px;background:radial-gradient(circle,rgba(154,123,232,.18),rgba(154,123,232,0) 65%);pointer-events:none}
.p-home .band h2{margin-bottom:12px;position:relative}
.p-home .band p{color:var(--muted);max-width:52ch;margin:0 auto 28px;font-size:17px;position:relative}
.p-home .band .btn{position:relative}

.p-home footer{margin-top:8px}

@media (max-width:920px){
  .p-home .hero-inner{grid-template-columns:1fr;gap:24px}
  .p-home .hero-art{order:2;max-width:360px;margin:6px auto 0}
  .p-home .cards{grid-template-columns:repeat(2,1fr)}
  .p-home .partner,.p-home .why{grid-template-columns:1fr;gap:28px}
}
@media (max-width:760px){
  .p-home .posts{grid-template-columns:1fr}
  .p-home .section{padding:64px 0}
  .p-home .band{padding:40px 24px}
}

/* ---------- 3b) LEISTUNGEN (.p-leistungen) ---------- */
.p-leistungen .page-hero{padding:74px 0 26px}
.p-leistungen .page-hero h1{font-size:clamp(40px,6vw,70px);margin:6px 0 18px;line-height:1.04}
.p-leistungen .page-hero p{color:var(--muted);font-size:18px;max-width:62ch;margin:0}
.p-leistungen .page-hero .tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px;font-family:var(--mono);font-size:12px;color:var(--muted)}
.p-leistungen .page-hero .tags span{border:1px solid var(--line);border-radius:999px;padding:7px 14px}
.p-leistungen .svcs{padding:34px 0 10px}
.p-leistungen .svc{display:grid;grid-template-columns:210px 1fr;gap:42px;padding:48px 0;border-top:1px solid var(--line)}
.p-leistungen .svc-rail{display:flex;flex-direction:column;gap:16px}
.p-leistungen .svc-ico{width:56px;height:56px;border:1px solid var(--line-strong);border-radius:15px;display:flex;align-items:center;justify-content:center;color:var(--platinum);background:var(--surface)}
.p-leistungen .svc-idx{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.12em}
.p-leistungen .svc h2{font-size:29px;margin-bottom:13px}
.p-leistungen .svc>div>p{color:var(--muted);font-size:15.5px;margin:0 0 22px;max-width:60ch}
.p-leistungen .umfang{display:grid;grid-template-columns:1fr 1fr;gap:11px 28px}
.p-leistungen .umfang div{position:relative;padding-left:22px;font-size:14px;color:var(--read)}
.p-leistungen .umfang div::before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;background:var(--platinum);border-radius:1.5px;transform:rotate(45deg)}
.p-leistungen .proc{padding:72px 0 10px;border-top:1px solid var(--line);margin-top:30px}
.p-leistungen .proc .lead{max-width:58ch;color:var(--muted);font-size:17px;margin:14px 0 0}
.p-leistungen .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:38px}
.p-leistungen .step{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px 24px}
.p-leistungen .step .n{font-family:var(--serif);font-size:34px;color:var(--lavender);line-height:1;margin-bottom:14px}
.p-leistungen .step h3{font-size:19px;margin-bottom:9px}
.p-leistungen .step p{font-size:13.5px;color:var(--muted);margin:0}
.p-leistungen .cta-band{margin:80px 0 0;background:linear-gradient(135deg,rgba(74,42,120,.42),rgba(28,22,41,.42));border:1px solid var(--line-strong);border-radius:22px;padding:56px 44px;text-align:center}
.p-leistungen .cta-band h2{font-size:clamp(28px,3.4vw,40px);margin-bottom:14px}
.p-leistungen .cta-band p{color:var(--muted);max-width:52ch;margin:0 auto 26px;font-size:15.5px}
@media (max-width:860px){.p-leistungen .svc{grid-template-columns:1fr;gap:22px;padding:40px 0}.p-leistungen .svc-rail{flex-direction:row;align-items:center;gap:16px}.p-leistungen .steps{grid-template-columns:1fr 1fr}.p-leistungen .umfang{grid-template-columns:1fr}}
@media (max-width:760px){.p-leistungen .steps{grid-template-columns:1fr}.p-leistungen .cta-band{padding:42px 26px}}

/* ---------- 3c) ÜBER UNS (.p-ueber) ---------- */
.p-ueber .narrow{max-width:780px}
.p-ueber .page-hero{padding:78px 0 30px}
.p-ueber .page-hero h1{font-size:clamp(40px,6vw,68px);margin:6px 0 20px;line-height:1.05}
.p-ueber .page-hero p{color:var(--muted);font-size:19px;max-width:60ch;margin:0}
.p-ueber .block{padding:60px 0;border-top:1px solid var(--line)}
.p-ueber .block h2{font-size:clamp(28px,3.8vw,44px);margin-bottom:8px}
.p-ueber .block .body{font-size:17px;color:var(--read)}
.p-ueber .block .body p{margin:20px 0;max-width:68ch}
.p-ueber .pull{font-family:var(--serif);font-size:clamp(24px,3.2vw,34px);color:var(--light);border-left:3px solid var(--lavender);border-radius:0;padding:6px 0 6px 24px;margin:30px 0;line-height:1.25}
.p-ueber .values{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:34px}
.p-ueber .value{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:28px 26px}
.p-ueber .value .vi{width:46px;height:46px;border:1px solid var(--line-strong);border-radius:13px;display:flex;align-items:center;justify-content:center;color:var(--platinum);background:var(--surface2);margin-bottom:18px}
.p-ueber .value h3{font-size:21px;margin-bottom:9px}
.p-ueber .value p{font-size:14px;color:var(--muted);margin:0}
.p-ueber .founder{display:grid;grid-template-columns:260px 1fr;gap:48px;align-items:start;margin-top:36px}
.p-ueber .fcard{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}
.p-ueber .avatar{width:130px;height:130px;border-radius:50%;background:var(--surface2);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:48px;color:var(--platinum);letter-spacing:.03em}
.p-ueber .fname{font-family:var(--serif);font-size:26px;color:var(--light)}
.p-ueber .frole{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--lavender)}
.p-ueber .fbio{font-size:16.5px;color:var(--read)}
.p-ueber .fbio p{margin:0 0 18px;max-width:64ch}
.p-ueber .quote{border-left:3px solid var(--lavender);border-radius:0;padding:8px 0 8px 24px;margin:26px 0 0}
.p-ueber .quote p{font-family:var(--serif);font-size:23px;line-height:1.32;color:var(--light);margin:0 0 10px;max-width:58ch}
.p-ueber .quote .by{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.04em}
.p-ueber .cta-band{margin:74px 0 0;background:linear-gradient(135deg,rgba(74,42,120,.42),rgba(28,22,41,.42));border:1px solid var(--line-strong);border-radius:22px;padding:56px 44px;text-align:center}
.p-ueber .cta-band h2{font-size:clamp(28px,3.4vw,40px);margin-bottom:14px;border:0;padding:0}
.p-ueber .cta-band p{color:var(--muted);max-width:52ch;margin:0 auto 26px;font-size:15.5px}
@media (max-width:860px){.p-ueber .values{grid-template-columns:1fr 1fr}.p-ueber .founder{grid-template-columns:1fr;gap:30px;justify-items:center;text-align:center}.p-ueber .fbio p{margin-left:auto;margin-right:auto}.p-ueber .quote{text-align:left}}
@media (max-width:760px){.p-ueber .values{grid-template-columns:1fr}.p-ueber .cta-band{padding:42px 26px}}

/* ---------- 3d) KONTAKT (.p-kontakt) ---------- */
.p-kontakt .page-hero{padding:74px 0 18px}
.p-kontakt .page-hero h1{font-size:clamp(40px,6vw,66px);margin:6px 0 18px;line-height:1.05}
.p-kontakt .page-hero p{color:var(--muted);font-size:18px;max-width:56ch;margin:0}
.p-kontakt .cgrid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;padding:46px 0 0;align-items:start}
.p-kontakt .info .item{padding:20px 0;border-top:1px solid var(--line)}
.p-kontakt .info .item:first-child{border-top:0;padding-top:4px}
.p-kontakt .info .lab{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.p-kontakt .info .val{font-size:16px;color:var(--text)}
.p-kontakt .info .val a:hover{color:var(--lavender)}
.p-kontakt .info .val.addr{font-style:normal;line-height:1.6}
.p-kontakt .ph{color:var(--muted);border-bottom:1px dashed var(--line-strong)}
.p-kontakt .form-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:38px 36px}
.p-kontakt .note{padding:14px 16px;border-radius:10px;font-size:14px;margin-bottom:24px;line-height:1.5}
.p-kontakt .note.ok{background:rgba(154,123,232,.12);border:1px solid var(--lavender);color:#d3c2f5}
.p-kontakt .note.err{background:rgba(232,90,90,.10);border:1px solid rgba(232,120,120,.55);color:#eab6b6}
.p-kontakt .field{margin-bottom:18px}
.p-kontakt .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.p-kontakt label.fl{display:block;font-size:13px;color:var(--muted);margin-bottom:7px}
.p-kontakt .req{color:var(--lavender)}
.p-kontakt input,.p-kontakt textarea{width:100%;background:var(--surface2);border:1px solid var(--line-strong);border-radius:10px;padding:13px 15px;color:var(--text);font-family:var(--sans);font-size:15px;transition:border-color .2s ease}
.p-kontakt input:focus,.p-kontakt textarea:focus{border-color:var(--lavender);outline:none}
.p-kontakt textarea{min-height:150px;resize:vertical}
.p-kontakt .consent{display:flex;gap:11px;align-items:flex-start;margin:6px 0 22px;font-size:13.5px;color:var(--muted)}
.p-kontakt .consent input{width:18px;height:18px;margin-top:2px;flex:none;accent-color:var(--lavender)}
.p-kontakt .consent a{color:var(--lavender);text-decoration:underline;text-underline-offset:2px}
.p-kontakt .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.p-kontakt .submit-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.p-kontakt .submit-row .hint{font-size:12.5px;color:var(--muted)}
@media (max-width:860px){.p-kontakt .cgrid{grid-template-columns:1fr;gap:30px}}
@media (max-width:760px){.p-kontakt .row2{grid-template-columns:1fr}.p-kontakt .form-card{padding:28px 22px}}

/* ---------- 3e) IMPRESSUM + DATENSCHUTZ (.p-legal) ---------- */
.p-legal :is(h1,h2,h3,h4){line-height:1.14}
.p-legal .legal{max-width:800px;margin:0 auto;padding:60px 28px 0}
.p-legal .legal h1{font-size:clamp(36px,5vw,56px);margin-bottom:10px}
.p-legal .legal .sub{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.p-legal .legal h2{font-size:24px;margin:42px 0 10px;color:var(--light)}
.p-legal .legal h3{font-size:18px;margin:26px 0 8px;color:var(--light)}
.p-legal .legal p{font-size:15.5px;color:var(--read);margin:12px 0}
.p-legal .legal a{color:var(--lavender);text-decoration:underline;text-underline-offset:3px}
.p-legal .legal ul{margin:14px 0;padding-left:0;list-style:none}
.p-legal .legal li{position:relative;padding-left:24px;margin:9px 0;font-size:15.5px;color:var(--read)}
.p-legal .legal li::before{content:"";position:absolute;left:3px;top:10px;width:6px;height:6px;background:var(--platinum);border-radius:1.5px;transform:rotate(45deg)}
.p-legal .ph{color:var(--muted);font-style:italic;border-bottom:1px dotted var(--line-strong)}

/* ---------- 3f) IT-RATGEBER ÜBERSICHT (.p-ratgeber) ---------- */
.p-ratgeber :is(h1,h2,h3,h4){line-height:1.1}
.p-ratgeber .page-hero{padding:72px 0 36px}
.p-ratgeber .page-hero h1{font-size:clamp(40px,6vw,68px);margin:6px 0 18px}
.p-ratgeber .page-hero p{color:var(--muted);font-size:18px;max-width:60ch;margin:0}
.p-ratgeber .filters{display:flex;flex-wrap:wrap;gap:10px;padding:8px 0 40px}
.p-ratgeber .chip{font-family:var(--mono);font-size:12px;letter-spacing:.04em;padding:9px 16px;border:1px solid var(--line-strong);border-radius:999px;color:var(--muted);background:none;cursor:pointer;transition:color .2s,border-color .2s,background .2s}
.p-ratgeber .chip:hover{color:var(--text)}
.p-ratgeber .chip.active{color:#13101C;background:var(--platinum);border-color:var(--platinum)}
.p-ratgeber .featured{display:grid;grid-template-columns:1.1fr 1fr;gap:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;margin-bottom:40px}
.p-ratgeber .featured .ftxt{padding:40px 38px}
.p-ratgeber .featured .fvis{background:#0E0A16;position:relative;min-height:260px;overflow:hidden}
.p-ratgeber .featured .fvis::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 60% 40%,rgba(154,123,232,.30),rgba(154,123,232,0) 60%)}
.p-ratgeber .featured .fvis svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.p-ratgeber .cat{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--lavender);text-transform:uppercase;display:flex;justify-content:space-between;margin-bottom:14px}
.p-ratgeber .cat .date{color:var(--muted)}
.p-ratgeber .featured h2{font-size:clamp(26px,3vw,36px);line-height:1.15;margin-bottom:14px}
.p-ratgeber .featured p{color:var(--muted);margin:0 0 22px;font-size:15.5px}
.p-ratgeber .more{font-family:var(--mono);font-size:12px;color:var(--text)}
.p-ratgeber .posts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.p-ratgeber .post{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px 24px;display:flex;flex-direction:column;transition:transform .18s ease,border-color .2s ease}
.p-ratgeber .post:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.p-ratgeber .post h3{font-size:20px;line-height:1.22;margin-bottom:12px}
.p-ratgeber .post p{font-size:14px;color:var(--muted);margin:0 0 18px;flex:1}
.p-ratgeber .post.hide{display:none}
.p-ratgeber .empty{display:none;color:var(--muted);font-family:var(--mono);font-size:13px;padding:30px 0}
.p-ratgeber footer{margin-top:80px}
@media (max-width:920px){.p-ratgeber .posts{grid-template-columns:repeat(2,1fr)}.p-ratgeber .featured{grid-template-columns:1fr}.p-ratgeber .featured .fvis{min-height:200px;order:-1}}
@media (max-width:760px){.p-ratgeber .posts{grid-template-columns:1fr}}

/* ---------- 3g) IT-RATGEBER ARTIKEL (.p-artikel) ---------- */
.p-artikel :is(h1,h2,h3,h4){line-height:1.15}
.p-artikel .article{max-width:740px;margin:0 auto;padding:46px 28px 0}
.p-artikel .breadcrumb{font-family:var(--mono);font-size:12px;color:var(--muted);margin-bottom:34px;letter-spacing:.02em}
.p-artikel .breadcrumb a:hover{color:var(--text)}
.p-artikel .breadcrumb span{color:var(--line-strong)}
.p-artikel .a-meta{font-family:var(--mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--lavender);display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:20px}
.p-artikel .a-meta .sep{color:var(--line-strong)}
.p-artikel .a-meta .m{color:var(--muted)}
.p-artikel .article h1{font-size:clamp(32px,5vw,50px);line-height:1.08;margin-bottom:22px}
.p-artikel .byline{display:flex;align-items:center;gap:11px;padding-bottom:28px;margin-bottom:8px;border-bottom:1px solid var(--line);font-size:14px;color:var(--muted)}
.p-artikel .byline .av{width:34px;height:34px;border-radius:50%;background:var(--surface2);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center}
.p-artikel .tag-demo{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--muted);border:1px solid var(--line-strong);border-radius:999px;padding:6px 13px;margin:26px 0 4px}
.p-artikel .prose{font-size:17px;color:var(--read)}
.p-artikel .prose>p{margin:22px 0}
.p-artikel .lead{font-size:20px;color:var(--text);line-height:1.6}
.p-artikel .prose h2{font-size:30px;margin:46px 0 14px;color:var(--light)}
.p-artikel .prose h3{font-size:22px;margin:32px 0 10px;color:var(--light)}
.p-artikel .prose a{color:var(--lavender);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(154,123,232,.45)}
.p-artikel .prose a:hover{text-decoration-color:var(--lavender)}
.p-artikel .prose ul{margin:18px 0;padding-left:0;list-style:none}
.p-artikel .prose li{position:relative;padding-left:26px;margin:11px 0}
.p-artikel .prose li::before{content:"";position:absolute;left:4px;top:11px;width:7px;height:7px;background:var(--platinum);border-radius:2px;transform:rotate(45deg)}
.p-artikel .prose strong{color:var(--light);font-weight:600}
.p-artikel .callout{background:var(--surface);border-left:3px solid var(--lavender);border-radius:0;padding:24px 28px;margin:34px 0}
.p-artikel .callout h4{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--lavender);margin:0 0 12px}
.p-artikel .callout ul{margin:0}
.p-artikel .a-cta{margin:54px 0 8px;background:var(--surface2);border:1px solid var(--line-strong);border-radius:18px;padding:38px 34px}
.p-artikel .a-cta h3{font-size:26px;margin-bottom:10px}
.p-artikel .a-cta p{color:var(--muted);font-size:15px;margin:0 0 22px;max-width:52ch}
.p-artikel .a-cta .row{display:flex;gap:12px;flex-wrap:wrap}
.p-artikel .related{max-width:1140px;margin:78px auto 0;padding:0 28px}
.p-artikel .related .rh{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.p-artikel .rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.p-artikel .post{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:26px 24px;display:flex;flex-direction:column;transition:transform .18s ease,border-color .2s ease}
.p-artikel .post:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.p-artikel .post .cat{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--lavender);text-transform:uppercase;display:flex;justify-content:space-between;margin-bottom:14px}
.p-artikel .post .cat .date{color:var(--muted)}
.p-artikel .post h3{font-size:19px;line-height:1.22;margin-bottom:12px}
.p-artikel .post p{font-size:14px;color:var(--muted);margin:0 0 18px;flex:1}
.p-artikel .more{font-family:var(--mono);font-size:12px;color:var(--text)}
.p-artikel footer{margin-top:84px}
@media (max-width:920px){.p-artikel .rgrid{grid-template-columns:1fr}}
