/* ════════════════════════════════════════════════════════
   DVhub Online — Hub Design System  (Direction A · Aurora Refined)
   DSGVO-konform: System-Fonts, keine externen Requests
   ════════════════════════════════════════════════════════ */

:root{
  /* brand / logo accents */
  --cyan:#34dbff;
  --blue:#1f8dff;
  --violet:#a78bff;
  --yellow:#ffd421;
  --green:#3ee0a0;
  --red:#ff5d5d;
  --aurora:linear-gradient(110deg,#34dbff 0%,#1f8dff 32%,#a78bff 64%,#ffd421 100%);

  --f-sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  --f-mono:ui-monospace,SFMono-Regular,Menlo,Consolas,'Liberation Mono',monospace;
  --maxw:1240px;

  /* dark (default) */
  --bg:#070b15;
  --bg-soft:#0c1322;
  --surface:rgba(255,255,255,.035);
  --surface-2:rgba(255,255,255,.06);
  --brd:rgba(140,180,255,.14);
  --brd-strong:rgba(140,180,255,.28);
  --text:#eef3fb;
  --text-2:#aab8d4;
  --text-dim:#6c7b9b;
  --header-bg:rgba(7,11,21,.72);
  --shadow:0 24px 60px -30px rgba(0,0,0,.8);
  --cat:var(--cyan);
}
[data-theme="light"]{
  --bg:#f6f8fc;
  --bg-soft:#eef2f8;
  --surface:rgba(15,40,90,.035);
  --surface-2:rgba(15,40,90,.06);
  --brd:rgba(20,50,100,.12);
  --brd-strong:rgba(20,50,100,.22);
  --text:#0e1a30;
  --text-2:#3c4a66;
  --text-dim:#6a778f;
  --header-bg:rgba(246,248,252,.82);
  --shadow:0 24px 60px -34px rgba(20,40,90,.3);
  /* darkened accents for contrast on light */
  --cyan:#0a8fb0;
  --blue:#1561c2;
  --violet:#6d4ed9;
  --yellow:#a87a00;
  --green:#1e8a5b;
  --red:#c43a3a;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--f-sans);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  overflow-x:hidden;
}
/* subtle aurora wash in the corners — much calmer than dvhub.de */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(60% 40% at 85% -5%, rgba(31,141,255,.14), transparent 60%),
    radial-gradient(50% 40% at 10% 0%, rgba(52,219,255,.10), transparent 60%),
    radial-gradient(55% 45% at 50% 110%, rgba(167,139,255,.08), transparent 60%);
}
[data-theme="light"] body::before{
  background:
    radial-gradient(60% 40% at 85% -5%, rgba(31,141,255,.10), transparent 60%),
    radial-gradient(50% 40% at 10% 0%, rgba(52,219,255,.08), transparent 60%),
    radial-gradient(55% 45% at 50% 110%, rgba(167,139,255,.06), transparent 60%);
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ───────────── HEADER ───────────── */
.site-header{position:sticky;top:0;z-index:50;background:var(--header-bg);backdrop-filter:blur(18px) saturate(1.3);border-bottom:1px solid var(--brd)}
.nav{max-width:var(--maxw);margin:0 auto;padding:13px 24px;display:flex;align-items:center;gap:20px}
.nav-logo{display:flex;align-items:center;gap:9px;flex-shrink:0}
.nav-logo img{height:30px;width:auto}
.online-badge{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);border:1px solid var(--brd-strong);background:var(--surface);padding:3px 8px;border-radius:999px}
.nav-links{display:flex;gap:4px;margin-left:8px}
.nav-links a{position:relative;padding:8px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text-2);transition:.15s}
.nav-links a:hover{color:var(--text);background:var(--surface)}
.nav-links a.active{color:var(--text)}
.nav-links a.active::after{content:'';position:absolute;left:12px;right:12px;bottom:2px;height:2px;border-radius:2px;background:var(--aurora)}
.nav-spacer{flex:1}
.nav-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:9px;border:1px solid var(--brd);background:var(--surface);color:var(--text-dim);font-size:13px;min-width:200px;transition:.15s;cursor:text}
.nav-search:focus-within,.nav-search:hover{border-color:var(--brd-strong);background:var(--surface-2)}
.nav-search svg{width:15px;height:15px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2}
.nav-search input{flex:1;background:none;border:0;outline:0;color:var(--text);font-family:var(--f-sans);font-size:13px;min-width:0}
.nav-search input::placeholder{color:var(--text-dim)}
.nav-search .kbd{font-family:var(--f-mono);font-size:10px;color:var(--text-dim);border:1px solid var(--brd);border-radius:4px;padding:1px 5px}
.btn{appearance:none;cursor:pointer;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--brd-strong);background:var(--surface);color:var(--text);font-family:var(--f-sans);font-size:13px;font-weight:500;padding:9px 14px;border-radius:9px;transition:.16s}
.btn:hover{background:var(--surface-2);border-color:var(--cyan);color:var(--cyan)}
.btn.primary{background:var(--aurora);border-color:transparent;color:#04101f;font-weight:600}
.btn.primary:hover{filter:brightness(1.07);color:#04101f}
.theme-toggle{display:inline-flex;align-items:center;gap:7px;padding:8px 11px;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--brd);background:var(--surface);color:var(--text-2);border-radius:9px;cursor:pointer;transition:.16s}
.theme-toggle:hover{color:var(--cyan);border-color:var(--brd-strong)}
.theme-toggle svg{width:14px;height:14px;color:var(--cyan)}
.nav-burger{display:none;background:none;border:0;color:var(--text);cursor:pointer;padding:6px}
@media (max-width:1080px){.nav-search{min-width:120px}.nav-search .kbd{display:none}}
@media (max-width:920px){.nav-links,.nav-search,.btn-desktop{display:none}.nav-burger{display:block}}

/* mobile nav */
.mnav{position:fixed;inset:60px 0 0 0;background:var(--bg);z-index:45;padding:24px;transform:translateY(-110%);transition:.3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:6px;overflow-y:auto}
.mnav.open{transform:translateY(0)}
.mnav a{padding:14px 16px;border-radius:10px;font-size:17px;font-weight:600;border:1px solid var(--brd);background:var(--surface)}
.mnav a:hover{background:var(--surface-2);color:var(--cyan)}

/* ───────────── HERO ───────────── */
.hub-hero{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:72px 24px 40px;text-align:center;display:flex;flex-direction:column;align-items:center}
.hub-eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:22px}
.hub-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.hub-hero h1{font-size:clamp(34px,5.6vw,58px);font-weight:700;line-height:1.06;letter-spacing:-.025em;max-width:900px;margin-bottom:20px;text-wrap:balance}
.hub-hero h1 .grad{background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.hub-hero .sub{font-size:clamp(16px,2vw,19px);color:var(--text-2);max-width:640px;margin-bottom:32px;line-height:1.6;text-wrap:pretty}
.hero-search{display:flex;align-items:center;gap:12px;width:min(640px,100%);padding:5px 5px 5px 18px;border-radius:14px;border:1px solid var(--brd-strong);background:var(--surface);box-shadow:var(--shadow);transition:.18s}
.hero-search:focus-within{border-color:var(--cyan)}
.hero-search svg{width:20px;height:20px;stroke:var(--text-dim);fill:none;stroke-width:2;flex-shrink:0}
.hero-search input{flex:1;background:none;border:0;outline:0;color:var(--text);font-family:var(--f-sans);font-size:16px;min-width:0}
.hero-search input::placeholder{color:var(--text-dim)}
.hero-search .btn{flex-shrink:0}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:18px}
.hero-tags a{font-size:12.5px;color:var(--text-2);padding:6px 12px;border-radius:999px;border:1px solid var(--brd);background:var(--surface);transition:.15s}
.hero-tags a:hover{border-color:var(--cyan);color:var(--cyan)}
.hero-stats{display:flex;flex-wrap:wrap;gap:28px;justify-content:center;margin-top:34px;padding-top:28px;border-top:1px solid var(--brd);width:min(720px,100%)}
.hero-stats .s{display:flex;flex-direction:column;gap:2px}
.hero-stats .s .v{font-size:26px;font-weight:700;letter-spacing:-.02em;line-height:1}
.hero-stats .s:nth-child(1) .v{color:var(--cyan)}
.hero-stats .s:nth-child(2) .v{color:var(--yellow)}
.hero-stats .s:nth-child(3) .v{color:var(--violet)}
.hero-stats .s:nth-child(4) .v{color:var(--green)}
.hero-stats .s .l{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);margin-top:6px}

/* ───────────── SECTION SCAFFOLD ───────────── */
.section{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:56px 24px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px;flex-wrap:wrap}
.sec-head .kick{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:9px;display:flex;align-items:center;gap:10px}
.sec-head .kick::before{content:'';width:22px;height:1px;background:var(--cyan)}
.sec-head h2{font-size:clamp(24px,3vw,33px);font-weight:700;letter-spacing:-.02em;line-height:1.12}
.sec-head .link{font-size:13.5px;font-weight:500;color:var(--cyan);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.sec-head .link:hover{gap:9px}

/* ───────────── AREA TILES (primary) ───────────── */
.area-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media (max-width:760px){.area-grid{grid-template-columns:1fr}}
.area{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:14px;padding:28px;border-radius:18px;border:1px solid var(--brd);background:var(--surface);transition:.22s;isolation:isolate;min-height:208px}
.area::before{content:'';position:absolute;inset:0;z-index:-1;opacity:0;transition:.25s;background:radial-gradient(120% 90% at 0% 0%,color-mix(in srgb,var(--cat) 16%,transparent),transparent 55%)}
.area:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--cat) 45%,var(--brd));box-shadow:var(--shadow)}
.area:hover::before{opacity:1}
.area .ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;color:var(--cat);background:color-mix(in srgb,var(--cat) 14%,transparent);border:1px solid color-mix(in srgb,var(--cat) 30%,transparent)}
.area .ic svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.area h3{font-size:21px;font-weight:700;letter-spacing:-.01em}
.area p{font-size:14px;color:var(--text-2);line-height:1.55;flex:1}
.area .routes{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.area .routes span{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);padding:4px 9px;border-radius:6px;background:var(--surface-2);border:1px solid var(--brd)}
.area .arrow{position:absolute;top:28px;right:28px;color:var(--text-dim);transition:.2s}
.area:hover .arrow{color:var(--cat);transform:translate(3px,-3px)}
.area.cyan{--cat:var(--cyan)} .area.yellow{--cat:var(--yellow)} .area.violet{--cat:var(--violet)} .area.green{--cat:var(--green)} .area.blue{--cat:var(--blue)} .area.red{--cat:var(--red)}

/* secondary tiles */
.subtile-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:16px}
@media (max-width:860px){.subtile-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:460px){.subtile-grid{grid-template-columns:1fr}}
.subtile{display:flex;flex-direction:column;gap:8px;padding:20px;border-radius:14px;border:1px solid var(--brd);background:var(--surface);transition:.2s}
.subtile:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--cat,var(--cyan)) 40%,var(--brd));background:var(--surface-2)}
.subtile .ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:var(--cat,var(--cyan));background:color-mix(in srgb,var(--cat,var(--cyan)) 12%,transparent)}
.subtile .ic svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.subtile h4{font-size:15px;font-weight:600;letter-spacing:-.005em}
.subtile p{font-size:12.5px;color:var(--text-2);line-height:1.5}
.subtile.cyan{--cat:var(--cyan)} .subtile.yellow{--cat:var(--yellow)} .subtile.violet{--cat:var(--violet)} .subtile.green{--cat:var(--green)} .subtile.blue{--cat:var(--blue)} .subtile.red{--cat:var(--red)}

/* ───────────── DAY-AHEAD SNAPSHOT ───────────── */
.da-card{border:1px solid var(--brd);border-radius:18px;background:var(--surface);padding:26px;display:grid;grid-template-columns:1.3fr .7fr;gap:30px}
@media (max-width:860px){.da-card{grid-template-columns:1fr;gap:22px}}
.da-main{display:flex;flex-direction:column}
.da-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.da-top .lbl{font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);display:flex;align-items:center;gap:8px;margin-bottom:5px}
.da-top .lbl .dot{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green)}
.da-top h3{font-size:19px;font-weight:700;letter-spacing:-.01em}
.da-top .avg{text-align:right;font-family:var(--f-mono);font-size:11px;color:var(--text-dim)}
.da-top .avg b{color:var(--cyan);font-size:17px;font-weight:700}
.da-bars{flex:1;display:flex;align-items:flex-end;gap:2px;min-height:150px;padding-bottom:22px;border-bottom:1px solid var(--brd);position:relative}
.da-bars .zero{position:absolute;left:0;right:0;border-top:1px dashed var(--brd-strong)}
.da-bars .zero span{position:absolute;left:0;top:-8px;font-family:var(--f-mono);font-size:8px;color:var(--text-dim);background:var(--bg);padding-right:5px}
.da-bar{flex:1;background:linear-gradient(180deg,var(--cyan),rgba(52,219,255,.35));border-radius:3px 3px 0 0;min-height:2px;transition:.15s}
.da-bar.neg{background:linear-gradient(0deg,var(--green),rgba(62,224,160,.4));border-radius:0 0 3px 3px}
.da-bar.peak{background:linear-gradient(180deg,var(--yellow),#ffb420)}
.da-bar.now{background:linear-gradient(180deg,#fff,var(--cyan));box-shadow:0 0 10px rgba(255,255,255,.5)}
.da-bar:hover{filter:brightness(1.25)}
.da-x{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:9px;color:var(--text-dim);margin-top:8px}
.da-side{display:flex;flex-direction:column;gap:12px}
.da-stat{padding:16px 18px;border:1px solid var(--brd);border-radius:13px;background:var(--surface-2);position:relative;overflow:hidden}
.da-stat::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent,var(--cyan))}
.da-stat:nth-child(1){--accent:var(--cyan)} .da-stat:nth-child(2){--accent:var(--yellow)} .da-stat:nth-child(3){--accent:var(--violet)}
.da-stat .l{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px}
.da-stat .v{font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--accent,var(--cyan));line-height:1}
.da-stat .v .u{font-size:11px;font-family:var(--f-mono);color:var(--text-dim);margin-left:4px}
.da-stat .d{font-size:12px;color:var(--text-2);margin-top:6px;line-height:1.4}

/* ───────────── NEWS ───────────── */
.news-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:980px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.news-grid{grid-template-columns:1fr}}
.news{display:flex;flex-direction:column;gap:10px;padding:18px;border-radius:14px;border:1px solid var(--brd);background:var(--surface);transition:.2s;--cat:var(--cyan)}
.news[data-cat="Solar"]{--cat:var(--yellow)} .news[data-cat="Speicher"]{--cat:var(--green)} .news[data-cat="Politik"],.news[data-cat="Regulierung"]{--cat:var(--red)} .news[data-cat="Hardware"]{--cat:var(--violet)} .news[data-cat="Markt"]{--cat:var(--cyan)}
.news:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--cat) 45%,var(--brd));box-shadow:var(--shadow)}
.news .meta{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase}
.news .meta .badge{color:var(--cat);border:1px solid color-mix(in srgb,var(--cat) 40%,var(--brd));padding:2px 7px;border-radius:999px}
.news .meta .src{color:var(--text-dim)}
.news h4{font-size:15px;font-weight:600;line-height:1.32;letter-spacing:-.005em;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.news p{font-size:12.5px;color:var(--text-2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news .foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;font-family:var(--f-mono);font-size:10px;color:var(--text-dim);padding-top:10px;border-top:1px solid var(--brd)}
.news .foot .go{color:var(--cat)}

/* ───────────── CTA STRIP ───────────── */
.cta{position:relative;z-index:1;max-width:var(--maxw);margin:40px auto 72px;padding:0 24px}
.cta-inner{border:1px solid var(--brd);border-radius:20px;padding:44px;text-align:center;background:
  radial-gradient(80% 120% at 80% 0%,rgba(52,219,255,.1),transparent 60%),
  radial-gradient(80% 120% at 20% 100%,rgba(167,139,255,.08),transparent 60%),var(--surface)}
.cta-inner h2{font-size:clamp(23px,3vw,32px);font-weight:700;letter-spacing:-.02em;margin-bottom:12px;text-wrap:balance}
.cta-inner h2 .grad{background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.cta-inner p{font-size:15px;color:var(--text-2);max-width:520px;margin:0 auto 22px;line-height:1.6}
.cta-inner .row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ───────────── FOOTER ───────────── */
.footer{position:relative;z-index:1;border-top:1px solid var(--brd);background:var(--bg-soft);padding:48px 24px 30px}
.footer-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
@media (max-width:720px){.footer-inner{grid-template-columns:1fr 1fr;gap:28px}}
.foot-brand img{height:34px;margin-bottom:14px}
.foot-brand p{font-size:13px;color:var(--text-dim);max-width:300px;line-height:1.6}
.foot-col h4{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text);margin-bottom:14px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-col a{font-size:13.5px;color:var(--text-2);transition:.15s}
.foot-col a:hover{color:var(--cyan)}
.footer-bottom{max-width:var(--maxw);margin:32px auto 0;padding-top:22px;border-top:1px solid var(--brd);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:var(--text-dim)}
.footer-bottom .links{display:flex;gap:18px}
.footer-bottom a:hover{color:var(--cyan)}

/* ───────────── PAGE (scaffold subpages) ───────────── */
.page-hero{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:56px 24px 28px}
.breadcrumb{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);margin-bottom:18px;display:flex;gap:9px;align-items:center}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb .sep{opacity:.5}
.page-hero h1{font-size:clamp(30px,4.6vw,48px);font-weight:700;letter-spacing:-.02em;line-height:1.08;margin-bottom:16px;max-width:820px}
.page-hero h1 .grad{background:var(--aurora);-webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero .lead{font-size:17px;color:var(--text-2);max-width:680px;line-height:1.6}

/* wip badge for scaffold */
.wip{display:inline-flex;align-items:center;gap:7px;font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--yellow);border:1px solid color-mix(in srgb,var(--yellow) 40%,var(--brd));background:color-mix(in srgb,var(--yellow) 10%,transparent);padding:5px 11px;border-radius:999px}

/* generic card grid for scaffolds */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.scard{display:flex;flex-direction:column;gap:9px;padding:22px;border-radius:14px;border:1px solid var(--brd);background:var(--surface);transition:.2s;--cat:var(--cyan)}
.scard:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--cat) 40%,var(--brd));background:var(--surface-2)}
.scard .tag{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--cat)}
.scard h3{font-size:17px;font-weight:600;letter-spacing:-.005em}
.scard p{font-size:13px;color:var(--text-2);line-height:1.55}
.scard .more{margin-top:auto;font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--cat);padding-top:8px}
.scard.cyan{--cat:var(--cyan)} .scard.yellow{--cat:var(--yellow)} .scard.violet{--cat:var(--violet)} .scard.green{--cat:var(--green)} .scard.blue{--cat:var(--blue)} .scard.red{--cat:var(--red)}

/* ───────────── VARIANT SWITCH (design preview only) ───────────── */
.variant-switch{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:80;display:flex;align-items:center;gap:4px;padding:5px;border-radius:999px;border:1px solid var(--brd-strong);background:var(--header-bg);backdrop-filter:blur(16px);box-shadow:var(--shadow);font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase}
.variant-switch .vs-label{color:var(--text-dim);padding:0 8px 0 10px}
.variant-switch a{padding:7px 14px;border-radius:999px;color:var(--text-2);transition:.15s}
.variant-switch a:hover{color:var(--text)}
.variant-switch a.on{background:var(--aurora);color:#04101f;font-weight:700}
@media (max-width:520px){.variant-switch .vs-label{display:none}}

/* ── Widescreen-Responsivität (P9): breitere Content-Spalte + mehr Karten-Spalten auf großen
   Viewports. Stufung Mobile→Tablet→Desktop→Widescreen = 1→2→3→4. Karten-Optik unverändert,
   nur max-width + Spaltenzahl. .card-grid (auto-fill minmax 260) fließt mit der breiteren --maxw. ── */
@media (min-width:1280px){ .area-grid{grid-template-columns:repeat(3,1fr)} }
@media (min-width:1600px){ :root{--maxw:1520px} .area-grid{grid-template-columns:repeat(4,1fr)} .news-grid{grid-template-columns:repeat(5,1fr)} }
@media (min-width:2040px){ :root{--maxw:1820px} .news-grid{grid-template-columns:repeat(6,1fr)} }
