/* ============================================================
   modvio Docs — geteilte UI-Basis (Prototyp, on-brand)
   Tokens 1:1 aus vio-tokens.css / BRAND-GUIDELINE.md (Sapphire-Blau).
   ============================================================ */
@import url("https://fonts.googleapis.com/css2?family=Schibsted+Grotesk:wght@500;600;700;800;900&family=Hanken+Grotesk:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap");

:root{
  --paper:#FFFFFF; --paper-soft:#F6F8FC; --surface:#FFFFFF; --surface-2:#EEF1F8;
  --line:#E6E9F2; --line-strong:#D4D9E6;
  --ink:#0E1526; --ink-soft:#59617A; --ink-faint:#8A93A8;
  --accent:#2A50C8; --accent-strong:#1C3C99; --accent-ink:#FFFFFF;
  --accent-soft:#E7ECFB; --accent-glow:rgba(42,80,200,.16); --accent-line:rgba(42,80,200,.22);
  --success:#2E9E6B; --warn:#E6B24E; --danger:#EF6A52; --info:#4F9BE0;
  --mod-inv:#10B981; --mod-gastro:#E8703A; --mod-personal:#7C5CF0; --mod-whatsapp:#25A95A;
  --mod-social:#0A0A0A; --mod-kalender:#3AA0E0;
  --radius:16px; --radius-sm:12px; --radius-lg:26px; --radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(14,21,38,.06),0 6px 16px rgba(14,21,38,.06);
  --shadow-md:0 1px 2px rgba(14,21,38,.06),0 12px 32px rgba(14,21,38,.08);
  --shadow-lg:0 2px 4px rgba(14,21,38,.08),0 28px 64px rgba(14,21,38,.12);
  --fd:"Schibsted Grotesk",system-ui,sans-serif;
  --ft:"Hanken Grotesk",system-ui,sans-serif;
  --fm:"IBM Plex Mono",ui-monospace,monospace;
  --mx:min(1240px,94vw);
  --nav:264px; --toc:212px; --header-h:66px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ft);color:var(--ink);background:var(--paper);line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;display:flex;flex-direction:column}
/* Sticky-Footer: Content drückt den Footer nach unten → keine weiße Fläche unter dem Footer auf kurzen Seiten (siehe footer.df margin-top:auto) */
h1,h2,h3,h4{font-family:var(--fd);letter-spacing:-.025em;line-height:1.08;font-weight:800;text-wrap:balance;color:var(--ink)}
a{color:inherit;text-decoration:none}
img,svg{display:block}
::selection{background:var(--accent-soft)}

.mono{font-family:var(--fm);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}
.eyebrow{font-family:var(--fm);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent-strong);font-weight:500}
.wrap{width:var(--mx);margin:0 auto}

/* ---------- Buttons ---------- */
.btn{font-family:var(--ft);font-weight:600;font-size:.95rem;border-radius:var(--radius-pill);padding:11px 20px;
  border:1px solid transparent;cursor:pointer;display:inline-flex;gap:8px;align-items:center;justify-content:center;
  transition:transform .14s ease,box-shadow .14s ease,background .14s,border-color .14s;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn--primary{background:linear-gradient(180deg,#3D69E8,var(--accent));color:var(--accent-ink);box-shadow:var(--shadow-md)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn--ghost{background:var(--accent-soft);color:var(--accent-strong);font-weight:700}
.btn--ghost:hover{background:#DBE3F7}
.btn--line{background:var(--surface);border-color:var(--line-strong);color:var(--ink-soft);font-weight:600}
.btn--line:hover{border-color:var(--accent);color:var(--accent-strong)}
.btn--sm{padding:8px 14px;font-size:.85rem}

/* ---------- Header ---------- */
header.dh{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.dh-in{height:var(--header-h);display:flex;align-items:center;gap:22px;width:var(--mx);margin:0 auto}
.dh-brand{display:flex;align-items:center;gap:10px;font-family:var(--fd);font-weight:800;font-size:1.12rem;letter-spacing:-.03em;flex:0 0 auto}
.dh-brand .mk{width:28px;height:28px;color:var(--ink)}
.dh-brand .docs-tag{font-family:var(--fm);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-strong);
  background:var(--accent-soft);padding:3px 8px;border-radius:var(--radius-pill);font-weight:600;margin-left:2px}
.dh-search{flex:1;max-width:440px;display:flex;align-items:center;gap:10px;height:40px;padding:0 10px 0 14px;
  background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-pill);color:var(--ink-faint);
  font-family:var(--ft);font-size:.92rem;text-align:left;cursor:pointer;transition:border-color .14s,background .14s}
.dh-search:hover{border-color:var(--line-strong);background:#E9EDF5}
.dh-search svg{width:17px;height:17px;color:var(--ink-faint);flex:0 0 auto}
.dh-search .ph{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kbd{margin-left:auto;display:inline-flex;gap:3px;align-items:center;flex:0 0 auto}
.kbd kbd{font-family:var(--fm);font-size:.64rem;line-height:1;color:var(--ink-soft);background:var(--surface);
  border:1px solid var(--line-strong);border-bottom-width:1px;border-radius:5px;padding:3px 5px;min-width:17px;text-align:center}
.dh-actions{display:flex;align-items:center;gap:12px;flex:0 0 auto;margin-left:auto}
.lang{display:inline-flex;border:1px solid var(--line);border-radius:var(--radius-pill);overflow:hidden;font-family:var(--fm);font-size:.7rem;letter-spacing:.06em}
.lang a,.lang span{padding:6px 11px;color:var(--ink-faint);cursor:pointer;transition:background .12s,color .12s}
.lang a:hover{color:var(--ink)}
.lang a.on,.lang span.on{background:var(--accent);color:#fff}
/* Mobile-Nav: Hamburger + Off-Canvas-Backdrop (DE/EN bleibt mobil sichtbar) */
.dh-burger{display:none;flex:0 0 auto;width:40px;height:40px;align-items:center;justify-content:center;padding:0;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);cursor:pointer}
.dh-burger svg{width:20px;height:20px}
.nav-backdrop{position:fixed;inset:var(--header-h) 0 0 0;background:rgba(12,26,24,.42);z-index:55;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}
body.nav-open .nav-backdrop{opacity:1;visibility:visible}
@media(max-width:920px){.dh-brand .docs-tag,.dh-search .kbd,.dh-search .ph{display:none}.dh-search{flex:0 0 auto;width:42px;max-width:none;padding:0;justify-content:center}.dh-in{gap:12px}}
@media(max-width:520px){.dh-brand{font-size:0;gap:0}.dh-actions .btn svg{display:none}.dh-actions{gap:8px}.dh-in{gap:10px}}

/* ---------- Doc shell (sidebar | main | toc) ---------- */
.shell{width:var(--mx);margin:0 auto;display:grid;grid-template-columns:var(--nav) minmax(0,1fr);gap:0;align-items:start}
.shell.with-toc{grid-template-columns:var(--nav) minmax(0,1fr) var(--toc)}

/* sidebar */
aside.dnav{position:sticky;top:var(--header-h);align-self:start;height:calc(100vh - var(--header-h));overflow:auto;
  padding:30px 26px 60px 2px;border-right:1px solid var(--line)}
/* Scrollbalken komplett ausblenden — scrollt weiter per Wheel/Trackpad, maximal clean. */
aside.dnav,aside.toc{scrollbar-width:none;-ms-overflow-style:none}
aside.dnav::-webkit-scrollbar,aside.toc::-webkit-scrollbar{width:0;height:0;display:none}
.dnav .grp{margin-bottom:26px}
.dnav .grp-h{display:flex;align-items:center;gap:9px;font-family:var(--fm);font-size:.68rem;letter-spacing:.13em;
  text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin-bottom:11px}
.dnav .grp-h .gi,.dnav .grp-h svg{width:16px;height:16px;flex:0 0 auto;color:var(--accent-strong)}
.dnav a{display:block;font-size:.91rem;color:var(--ink-soft);padding:6px 12px;border-radius:var(--radius-sm);
  font-weight:500;transition:background .12s,color .12s;line-height:1.4}
.dnav a:hover{background:var(--surface-2);color:var(--ink)}
.dnav a.on{background:var(--accent-soft);color:var(--accent-strong);font-weight:700}
@media(max-width:980px){
  .shell,.shell.with-toc{grid-template-columns:1fr}
  .dh-burger{display:inline-flex}
  aside.dnav{position:fixed;top:var(--header-h);left:0;width:min(84vw,330px);z-index:58;
    height:calc(100vh - var(--header-h));height:calc(100dvh - var(--header-h));overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;
    background:var(--paper);border-right:1px solid var(--line);box-shadow:0 24px 60px rgba(12,26,24,.28);
    transform:translateX(-104%);transition:transform .24s ease;padding:24px 22px 60px}
  body.nav-open aside.dnav{transform:translateX(0)}
}

/* main column */
main.dmain{padding:36px clamp(20px,4vw,56px) 90px}
.shell.with-toc main.dmain{padding-right:clamp(20px,3vw,40px)}

/* breadcrumb */
.crumb{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--ink-faint);margin-bottom:18px;flex-wrap:wrap}
.crumb a:hover{color:var(--accent-strong)}
.crumb .sep{opacity:.5}
.crumb .cur{color:var(--ink-soft);font-weight:600}

/* ---------- Prose ---------- */
.prose{max-width:720px}
.prose h1{font-size:clamp(2rem,4vw,2.7rem);margin-bottom:14px}
.prose>.lede{font-size:1.16rem;color:var(--ink-soft);margin-bottom:30px;line-height:1.55}
.prose h2{font-size:1.55rem;margin:44px 0 14px;scroll-margin-top:84px}
.prose h3{font-size:1.18rem;margin:30px 0 10px;scroll-margin-top:84px}
.prose p{margin-bottom:16px;color:var(--ink-soft);font-size:1.035rem}
.prose strong{color:var(--ink);font-weight:700}
.prose a.lnk{color:var(--accent-strong);font-weight:600;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--accent-line)}
.prose ul,.prose ol{margin:4px 0 18px 4px;display:grid;gap:9px;list-style:none}
.prose ul li,.prose ol li{position:relative;padding-left:26px;color:var(--ink-soft);font-size:1.02rem}
.prose ul li::before{content:"";position:absolute;left:6px;top:.62em;width:6px;height:6px;border-radius:2px;background:var(--accent)}
.prose ol{counter-reset:li}
.prose ol li{counter-increment:li}
.prose ol li::before{content:counter(li);position:absolute;left:0;top:.05em;width:19px;height:19px;border-radius:6px;
  background:var(--accent-soft);color:var(--accent-strong);font-family:var(--fm);font-size:.7rem;font-weight:600;
  display:grid;place-items:center}
kbd{font-family:var(--fm);font-size:.78rem;background:var(--surface-2);border:1px solid var(--line-strong);
  border-bottom-width:2px;border-radius:6px;padding:1px 7px;color:var(--ink);white-space:nowrap}
.prose code:not(pre code){font-family:var(--fm);font-size:.86em;background:var(--accent-soft);color:var(--accent-strong);
  padding:1px 6px;border-radius:6px}

/* code block */
.code{margin:8px 0 22px;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:#0E1526;box-shadow:var(--shadow-sm)}
.code .ctop{display:flex;align-items:center;gap:8px;padding:9px 14px;background:#141C30;border-bottom:1px solid rgba(255,255,255,.07)}
.code .ctop .ci{font-family:var(--fm);font-size:.7rem;letter-spacing:.08em;color:#8893b0}
.code .ctop .copy{margin-left:auto;font-family:var(--fm);font-size:.68rem;color:#aeb8d6;display:inline-flex;gap:6px;align-items:center;cursor:pointer}
.code pre{padding:16px 18px;overflow:auto;font-family:var(--fm);font-size:.84rem;line-height:1.7;color:#D8DEF0}
.code .t-key{color:#86A8FF}.code .t-str{color:#7FD1A8}.code .t-num{color:#E6B24E}.code .t-com{color:#5d6788}

/* callouts (kein KI-Randstreifen — Icon-Chip statt deko border-left) */
.cal{display:flex;gap:13px;margin:8px 0 24px;padding:16px 18px;border-radius:var(--radius);border:1px solid var(--line);background:var(--paper-soft)}
.cal .cic{flex:0 0 auto;width:30px;height:30px;border-radius:9px;display:grid;place-items:center}
.cal .cic svg{width:17px;height:17px}
.cal .cbody{font-size:.96rem;color:var(--ink-soft)}
.cal .cbody b{display:block;color:var(--ink);font-family:var(--fd);font-weight:700;font-size:.96rem;margin-bottom:2px}
.cal--tip{background:#EAF6EF;border-color:#CDEBDB}.cal--tip .cic{background:#D6F0E2;color:var(--success)}
.cal--info{background:var(--accent-soft);border-color:#D4DEFA}.cal--info .cic{background:#D7E0FB;color:var(--accent-strong)}
.cal--warn{background:#FDF6E7;border-color:#F2E4BF}.cal--warn .cic{background:#F7EACB;color:#B8860B}

/* steps */
.steps{display:grid;gap:0;margin:6px 0 26px;border-left:2px solid var(--line);padding-left:0}
.step{display:grid;grid-template-columns:34px 1fr;gap:14px;padding:0 0 22px 18px;margin-left:-1px;position:relative}
.step:last-child{padding-bottom:0}
.step .sn{width:30px;height:30px;border-radius:9px;background:var(--accent);color:#fff;font-family:var(--fd);font-weight:700;
  font-size:.92rem;display:grid;place-items:center;margin-left:-34px;box-shadow:0 0 0 4px var(--paper)}
.step h4{font-family:var(--fd);font-size:1.04rem;margin-bottom:4px}
.step p{font-size:.96rem;color:var(--ink-soft);margin:0}

/* Vio video embed */
.vio-embed{margin:14px 0 28px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);background:var(--surface)}
.vio-stage{position:relative;aspect-ratio:16/9;background:
  radial-gradient(120% 130% at 18% 12%,#EEE9FD 0%,#F4F2FE 42%,#FFFFFF 100%);display:grid;place-items:center;overflow:hidden}
.vio-stage::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 80% 90%,rgba(110,79,227,.10),transparent 70%)}
.vio-play{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:14px;cursor:pointer}
.vio-owl{width:96px;height:96px;filter:drop-shadow(0 12px 26px rgba(62,34,156,.28))}
.vio-pbtn{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);
  border:1px solid rgba(110,79,227,.22);border-radius:var(--radius-pill);padding:9px 18px 9px 14px;font-family:var(--fd);
  font-weight:700;font-size:.92rem;color:#3E229C;box-shadow:var(--shadow-md)}
.vio-pbtn .pi{width:26px;height:26px;border-radius:50%;background:linear-gradient(160deg,#6E4FE3,#3E229C);display:grid;place-items:center}
.vio-pbtn .pi svg{width:12px;height:12px;color:#fff;margin-left:1px}
.vio-cap{display:flex;align-items:center;gap:10px;padding:11px 16px;background:var(--surface);border-top:1px solid var(--line)}
.vio-cap .vchip{font-family:var(--fm);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:#3E229C;
  background:#EEE9FD;padding:3px 9px;border-radius:var(--radius-pill);font-weight:600}
.vio-cap .vt{font-size:.9rem;color:var(--ink-soft)}
.vio-cap .vdur{margin-left:auto;font-family:var(--fm);font-size:.74rem;color:var(--ink-faint)}

/* feedback + prev/next */
.fb{margin:48px 0 0;padding:22px 24px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper-soft);
  display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.fb .fq{font-family:var(--fd);font-weight:700;font-size:1.02rem}
.fb .fbtns{display:flex;gap:9px;margin-left:auto}
.pn{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px}
.pn a{border:1px solid var(--line);border-radius:var(--radius);padding:15px 18px;transition:border-color .14s,box-shadow .14s,transform .14s;background:var(--surface)}
.pn a:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.pn .pl{font-family:var(--fm);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:5px}
.pn .pt{font-family:var(--fd);font-weight:700;color:var(--ink);font-size:1rem}
.pn a.nx{text-align:right}
@media(max-width:560px){.pn{grid-template-columns:1fr}}

/* right TOC */
aside.toc{position:sticky;top:var(--header-h);align-self:start;padding:38px 0 40px 22px;font-size:.86rem}
aside.toc .th{font-family:var(--fm);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:13px}
aside.toc a{display:block;color:var(--ink-soft);padding:5px 0 5px 13px;border-left:2px solid var(--line);line-height:1.35;transition:color .12s,border-color .12s}
aside.toc a:hover{color:var(--ink)}
aside.toc a.on{color:var(--accent-strong);border-color:var(--accent);font-weight:600}
aside.toc a.sub{padding-left:24px;font-size:.82rem}
/* TOC ab ≤1180 ausblenden (auch mobil). Grid-Spalte aber NUR 981–1180 zweispaltig — darunter übernimmt die Mobile-Regel (Einspalter + Drawer). */
@media(max-width:1180px){aside.toc{display:none}}
@media(min-width:981px) and (max-width:1180px){.shell.with-toc{grid-template-columns:var(--nav) minmax(0,1fr)}}
/* Mobile „Auf dieser Seite" — aufklappbar oben im Artikel (rechter TOC ist mobil aus) */
.mtoc{display:none}
@media(max-width:1180px){.mtoc{display:block;margin:6px 0 24px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden}}
.mtoc>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:8px;padding:13px 16px;font-family:var(--fm);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.mtoc>summary::-webkit-details-marker{display:none}
.mtoc>summary svg{width:16px;height:16px;margin-left:auto;transition:transform .2s}
.mtoc[open]>summary svg{transform:rotate(180deg)}
.mtoc[open]>summary{border-bottom:1px solid var(--line)}
.mtoc nav{display:flex;flex-direction:column;padding:8px}
.mtoc nav a{padding:9px 12px;border-radius:var(--radius-sm);color:var(--ink-soft);font-size:.94rem;line-height:1.35}
.mtoc nav a:hover,.mtoc nav a:active{background:var(--surface-2);color:var(--ink)}
/* Anker-Sprünge nicht unter den Sticky-Header verstecken + sanftes Scrollen */
html{scroll-behavior:smooth}
.prose h1,.prose h2,.prose h3{scroll-margin-top:calc(var(--header-h) + 16px)}
/* Hintergrund nicht scrollen, solange der mobile Nav-Drawer offen ist */
@media(max-width:980px){body.nav-open{overflow:hidden}}

/* ---------- Footer ---------- */
footer.df{background:var(--ink);color:#9aa3bd;padding:54px 0 30px;margin-top:60px}
body>footer.df{margin-top:auto}
/* Immer Luft zwischen letztem Inhalt und Footer — margin-top:auto wird auf langen Seiten 0, sonst kleben die Karten am Footer. */
.sec:last-of-type,.msec:last-of-type{padding-bottom:84px}
footer.df a{color:#c3cce0}footer.df a:hover{color:#fff}
.df-in{width:var(--mx);margin:0 auto}
.df-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
.df-brand .b{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--fd);font-weight:800;font-size:1.1rem;margin-bottom:12px}
.df-brand .b .mk{width:26px;height:26px;color:#fff}
.df-brand p{font-size:.9rem;max-width:32ch;color:#8f99b5}
.df h5{font-family:var(--fm);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:#6f7997;margin-bottom:13px;font-weight:500}
.df nav{display:grid;gap:10px}.df nav a{font-size:.92rem}
.df-bot{margin-top:38px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;
  gap:14px;flex-wrap:wrap;font-size:.83rem;color:#7e88a6}
@media(max-width:780px){.df-top{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.df-top{grid-template-columns:1fr}}

:where(a,button,input,.btn):focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:8px}

/* ============ Home (Hub) ============ */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:radial-gradient(120% 90% at 50% -20%,#EFF3FE 0%,#FFFFFF 58%)}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px;-webkit-mask:radial-gradient(70% 60% at 50% 0%,#000 0%,transparent 72%);mask:radial-gradient(70% 60% at 50% 0%,#000 0%,transparent 72%);opacity:.5}
.hero-in{position:relative;width:var(--mx);margin:0 auto;padding:70px 0 64px;text-align:center}
.hero h1{font-size:clamp(2.4rem,5.4vw,3.7rem);max-width:18ch;margin:14px auto 16px}
.hero .lede{font-size:1.18rem;color:var(--ink-soft);max-width:54ch;margin:0 auto 30px}
.bigsearch{width:100%;max-width:600px;margin:0 auto;display:flex;align-items:center;gap:13px;height:60px;padding:0 14px 0 22px;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-pill);box-shadow:var(--shadow-lg);color:var(--ink-faint);font-family:var(--ft);font-size:1.05rem;text-align:left;cursor:pointer;transition:box-shadow .16s,border-color .16s}
.bigsearch:hover{border-color:var(--accent-line);box-shadow:0 2px 4px rgba(14,21,38,.08),0 30px 70px rgba(42,80,200,.16)}
.bigsearch svg{width:21px;height:21px;color:var(--accent);flex:0 0 auto}
.bigsearch .ph{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bigsearch .kbd kbd{font-size:.72rem;padding:4px 7px;min-width:22px}
.poptags{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin-top:20px}
.poptags span{font-family:var(--ft);font-size:.85rem;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);padding:6px 14px;border-radius:var(--radius-pill);cursor:pointer;transition:border-color .14s,color .14s}
.poptags span:hover{border-color:var(--accent);color:var(--accent-strong)}
.poptags .pl{font-family:var(--fm);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);align-self:center}
.sec{width:var(--mx);margin:0 auto;padding:58px 0 0}
.sec-h{display:flex;align-items:baseline;gap:14px;margin-bottom:24px}.sec-h h2{font-size:1.7rem}
.sec-h .more{margin-left:auto;font-family:var(--fd);font-weight:700;font-size:.9rem;color:var(--accent-strong);display:inline-flex;gap:6px;align-items:center}
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}@media(max-width:880px){.cats{grid-template-columns:1fr 1fr}}@media(max-width:560px){.cats{grid-template-columns:1fr}}
.cat{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px 22px 20px;box-shadow:var(--shadow-sm);transition:transform .16s,box-shadow .16s,border-color .16s}
.cat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent-line)}
.cat .ci{width:42px;height:42px;border-radius:12px;background:var(--accent-soft);display:grid;place-items:center;margin-bottom:15px}.cat .ci svg{width:22px;height:22px;color:var(--accent-strong)}
.cat h3{font-size:1.12rem;margin-bottom:6px}.cat p{font-size:.94rem;color:var(--ink-soft);line-height:1.5;margin-bottom:14px}
.cat .cn{font-family:var(--fm);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}
.pop{display:grid;grid-template-columns:1fr 1fr;gap:12px 30px}@media(max-width:680px){.pop{grid-template-columns:1fr}}
.pop a{display:flex;align-items:center;gap:13px;padding:14px 8px;border-bottom:1px solid var(--line);transition:padding .14s}.pop a:hover{padding-left:14px}.pop a:hover .pt{color:var(--accent-strong)}
.pop .pi{width:36px;height:36px;border-radius:10px;background:var(--surface-2);background:color-mix(in srgb,var(--pc,var(--accent)) 13%,#fff);display:grid;place-items:center;flex:0 0 auto}.pop .pi svg{width:18px;height:18px;color:var(--pc,var(--ink-soft))}
.pmeta{display:flex;flex-direction:column;min-width:0}
.pop .pt{font-weight:600;font-size:.98rem;line-height:1.25}.pop .pd{font-size:.8rem;color:var(--ink-faint);margin-top:2px}.pop .arr{margin-left:auto;color:var(--ink-faint);flex:0 0 auto}
.vteaser{width:var(--mx);margin:64px auto 80px;background:linear-gradient(120deg,#2A1670,#3E229C 55%,#2A50C8);border-radius:var(--radius-lg);padding:40px 44px;display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center;color:#fff;overflow:hidden;position:relative;box-shadow:var(--shadow-lg)}
.vteaser::after{content:"";position:absolute;right:-40px;top:-40px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(169,141,247,.4),transparent 65%)}
.vteaser .vt-eb{font-family:var(--fm);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:#C9B8FB;margin-bottom:10px}
.vteaser h2{color:#fff;font-size:1.85rem;max-width:18ch;margin-bottom:10px}.vteaser p{color:#D9D2F6;font-size:1.02rem;max-width:46ch;margin-bottom:20px}
.vteaser .vbtn{background:#fff;color:#3E229C;font-weight:700;border-radius:var(--radius-pill);padding:13px 22px;display:inline-flex;gap:9px;align-items:center;font-family:var(--fd);box-shadow:var(--shadow-md)}
.vteaser .vstage{position:relative;z-index:2;width:200px;height:150px;border-radius:var(--radius);background:radial-gradient(120% 120% at 30% 20%,rgba(255,255,255,.16),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;backdrop-filter:blur(2px)}
@media(max-width:780px){.vteaser{grid-template-columns:1fr}.vteaser .vstage{display:none}}

/* ============ Command-Palette (globales Such-Overlay) ============ */
.cmdk{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:12vh 20px 20px}
.cmdk[hidden]{display:none}
.cmdk-back{position:absolute;inset:0;background:rgba(14,21,38,.42);backdrop-filter:blur(3px);animation:cmdkFade .14s ease}
.cmdk-box{position:relative;width:min(620px,100%);background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:cmdkPop .16s cubic-bezier(.2,.7,.2,1)}
@keyframes cmdkFade{from{opacity:0}}
@keyframes cmdkPop{from{opacity:0;transform:translateY(-10px) scale(.98)}}
.cmdk-input{display:flex;align-items:center;gap:13px;padding:16px 16px 16px 20px;border-bottom:1px solid var(--line)}
.cmdk-input svg{width:21px;height:21px;color:var(--accent);flex:0 0 auto}
.cmdk-input input{flex:1;border:0;outline:0;background:transparent;font-family:var(--ft);font-size:1.12rem;font-weight:500;color:var(--ink)}
.cmdk-input input::placeholder{color:var(--ink-faint);font-weight:400}
.cmdk-esc{font-family:var(--fm);font-size:.66rem;color:var(--ink-faint);background:var(--surface-2);border:1px solid var(--line);border-radius:6px;padding:4px 8px;cursor:pointer}
.cmdk-esc:hover{color:var(--ink-soft);border-color:var(--line-strong)}
.cmdk-res{max-height:min(54vh,440px);overflow:auto;padding:6px}
.cmdk-row{display:flex;align-items:center;gap:13px;padding:11px 14px;border-radius:var(--radius-sm);text-decoration:none;cursor:pointer}
.cmdk-row.act{background:var(--accent-soft)}
.cmdk-row .ri{width:34px;height:34px;border-radius:9px;background:var(--surface-2);display:grid;place-items:center;flex:0 0 auto}
.cmdk-row.act .ri{background:#fff}
.cmdk-row .ri svg{width:17px;height:17px;color:var(--accent-strong)}
.cmdk-row .rt{display:flex;flex-direction:column;min-width:0;flex:1}
.cmdk-row .rt .t{font-weight:600;font-size:.98rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmdk-row .rt .t mark{background:rgba(42,80,200,.16);color:var(--accent-strong);padding:0 2px;border-radius:3px}
.cmdk-row .rt .d{font-size:.8rem;color:var(--ink-faint);margin-top:1px}
.cmdk-row .rk{margin-left:auto;font-family:var(--fm);font-size:.72rem;color:var(--ink-faint);background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:2px 7px;flex:0 0 auto;opacity:0}
.cmdk-row.act .rk{opacity:1}
.cmdk-empty{padding:30px 16px;text-align:center;color:var(--ink-faint);font-size:.95rem}
.cmdk-foot{display:flex;align-items:center;gap:16px;padding:11px 18px;background:var(--paper-soft);border-top:1px solid var(--line);font-family:var(--fm);font-size:.68rem;color:var(--ink-faint)}
.cmdk-foot .k{background:var(--surface);border:1px solid var(--line);border-radius:5px;padding:1px 6px;margin-right:4px}
@media(max-width:560px){.cmdk{padding:8vh 12px 12px}.cmdk-foot{display:none}}
