/* ==========================================================================
   HTProtect.org – Joomla Security Info
   Designsystem im Stil des HTProtect-Dashboards
   Keine externen Schriften/CDNs – datenschutzfreundlich.
   ========================================================================== */

:root{
  /* Flächen */
  --bg-1:#eef3fb;
  --bg-2:#e4ecf6;
  --card:#ffffff;
  --card-soft:#f7f9fc;

  /* Text */
  --navy:#1e2b39;
  --ink:#21303f;
  --ink-soft:#3c4c5d;
  --muted:#64748b;
  --muted-2:#8a98a8;

  /* Linien */
  --line:#e7ecf3;
  --line-2:#eef2f7;

  /* Marke / Grün */
  --brand:#1a9e54;
  --brand-dark:#15823f;
  --brand-50:#eafaf1;
  --brand-100:#d4f3e0;
  --ok:#22c55e;

  /* Signal */
  --crit:#dc2626;
  --crit-50:#fdeded;
  --crit-100:#f9d7d7;
  --warn:#d97706;
  --warn-50:#fff6e9;
  --warn-100:#fbe6c4;
  --info:#2563eb;
  --info-50:#eaf1fe;

  --radius:16px;
  --radius-sm:11px;
  --radius-xs:8px;
  --shadow:0 1px 2px rgba(16,32,52,.05), 0 12px 30px rgba(16,32,52,.06);
  --shadow-sm:0 1px 2px rgba(16,32,52,.05), 0 5px 16px rgba(16,32,52,.05);
  --shadow-hover:0 2px 4px rgba(16,32,52,.06), 0 18px 40px rgba(16,32,52,.10);

  --maxw:1180px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
  --mono:"SFMono-Regular",ui-monospace,"Cascadia Code",Consolas,"Liberation Mono",Menlo,monospace;
}

/* ----- Reset / Basis ----- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:88px;overflow-x:clip}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  line-height:1.62;
  font-size:16px;
  background:linear-gradient(180deg,var(--bg-1) 0%, var(--bg-2) 100%) fixed;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img,svg{max-width:100%;display:block}
a{color:var(--brand-dark);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{color:var(--navy);line-height:1.25;margin:0 0 .5em;font-weight:780;letter-spacing:-.01em}
h1{font-size:clamp(1.55rem,1.1rem + 1.9vw,2.1rem)}
h2{font-size:1.32rem}
h3{font-size:1.08rem}
p{margin:0 0 1em}
ul,ol{margin:0 0 1em;padding-left:1.25em}
li{margin:.25em 0}
strong{color:var(--navy);font-weight:680}
hr{border:0;border-top:1px solid var(--line);margin:1.5em 0}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ============================ App-Bar ============================ */
.appbar{background:var(--navy);color:#cdd8e4}
.appbar-in{max-width:var(--maxw);margin:0 auto;padding:8px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:.82rem}
.appbar-brand{font-weight:700;color:#fff;letter-spacing:.2px}
.appbar-brand span{color:#7fd6a3}
.appbar-note{color:#9fb0c2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ============================ Brand-Header ============================ */
.brandbar{background:rgba(255,255,255,.78);backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.brandbar-in{max-width:var(--maxw);margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand:hover{text-decoration:none}
.brand-mark{width:42px;height:auto;flex:none;filter:drop-shadow(0 4px 8px rgba(26,158,84,.18))}
.brand-word{font-size:1.6rem;font-weight:820;letter-spacing:-.02em;line-height:1}
.brand-word .b1{color:var(--navy)}
.brand-word .b2{color:var(--brand)}
.brand-badge{align-self:center;margin-left:6px;font-size:.62rem;font-weight:800;letter-spacing:.12em;color:var(--brand-dark);background:var(--brand-50);border:1px solid var(--brand-100);padding:4px 9px;border-radius:999px}
.brandbar-right{text-align:right;line-height:1.3}
.brandbar-dom{display:block;font-weight:750;color:var(--navy)}
.brandbar-sub{display:block;font-size:.8rem;color:var(--muted)}

/* ============================ Layout ============================ */
.layout{display:grid;grid-template-columns:250px minmax(0,1fr);gap:24px;padding:26px 0 10px;align-items:start}
.layout>*{min-width:0;max-width:100%}

/* ----- Sidebar ----- */
.sidebar{position:sticky;top:84px;min-width:0;max-width:100%}
.nav{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:10px}
.nav-i{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-xs);color:var(--ink-soft);font-weight:550;font-size:.94rem;transition:background .15s,color .15s}
.nav-i:hover{background:#f1f5f9;color:var(--navy);text-decoration:none}
.nav-i.is-active{background:var(--brand);color:#fff;box-shadow:0 7px 16px rgba(26,158,84,.30)}
.nav-i svg{width:18px;height:18px;flex:none;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;opacity:.92}
.nav-i.is-active svg{opacity:1}
.nav-i span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-sep{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-weight:750;padding:14px 12px 6px}
.nav-side-cta{margin-top:12px;background:linear-gradient(160deg,#21384a,#172533);color:#dbe6f0;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm)}
.nav-side-cta h4{color:#fff;font-size:.95rem;margin:0 0 6px}
.nav-side-cta p{color:#aebccb;font-size:.82rem;margin:0 0 10px}
.nav-side-cta a{display:inline-flex;align-items:center;gap:6px;color:#8be0ac;font-weight:650;font-size:.85rem}

/* ----- Burger / Off-Canvas (mobil) ----- */
.navtoggle{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;opacity:0;pointer-events:none;clip:rect(0 0 0 0);overflow:hidden}
.burger{display:none;width:46px;height:46px;flex:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-sm);cursor:pointer;-webkit-tap-highlight-color:transparent}
.burger:hover{border-color:#cdd9e6}
.burger span{display:block;width:21px;height:2px;border-radius:2px;background:var(--navy);transition:transform .26s ease,opacity .2s ease}
.navtoggle:checked~.brandbar .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.navtoggle:checked~.brandbar .burger span:nth-child(2){opacity:0}
.navtoggle:checked~.brandbar .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-head{display:none;align-items:center;justify-content:space-between;padding:2px 2px 14px;margin-bottom:8px;border-bottom:1px solid var(--line)}
.nav-head-t{font-weight:780;color:var(--navy);font-size:1.05rem;letter-spacing:-.01em}
.nav-close{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--muted);cursor:pointer;-webkit-tap-highlight-color:transparent}
.nav-close:hover{color:var(--navy);background:var(--card-soft)}
.nav-close svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.3}
.nav-scrim{display:none}

/* ----- Content ----- */
.content{min-width:0}
.content>section,.content>.card{margin-bottom:22px}

/* ============================ Cards / Sections ============================ */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px 28px}
.card-pad-lg{padding:30px 32px}
.card h2:first-child,.card h1:first-child,.card h3:first-child{margin-top:0}
.eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;font-weight:800;color:var(--brand-dark);margin-bottom:10px}
.lead{font-size:1.06rem;color:var(--ink-soft)}
.muted{color:var(--muted)}
.tiny{font-size:.82rem}

/* ----- Breadcrumb ----- */
.crumbs{font-size:.84rem;color:var(--muted);margin:0 0 14px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--brand-dark)}
.crumbs .sep{opacity:.5}

/* ============================ Hero ============================ */
.hero{background:
   radial-gradient(1100px 280px at 88% -40%, rgba(26,158,84,.10), transparent 60%),
   linear-gradient(180deg,#ffffff,#fbfdff);
  border:1px solid var(--line)}
.hero h1{margin-bottom:.35em}
.hero .lead{max-width:62ch}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}

/* ============================ Badges ============================ */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:750;line-height:1;padding:6px 11px;border-radius:999px;border:1px solid transparent;white-space:nowrap}
.badge svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.1}
.badge-crit{color:#fff;background:var(--crit);border-color:var(--crit)}
.badge-crit-soft{color:#b3211b;background:var(--crit-50);border-color:var(--crit-100)}
.badge-warn{color:#9a5800;background:var(--warn-50);border-color:var(--warn-100)}
.badge-exploit{color:#fff;background:#b3211b;border-color:#b3211b}
.badge-ok{color:#0f7a39;background:var(--brand-50);border-color:var(--brand-100)}
.badge-cve{color:#1f3a8a;background:var(--info-50);border-color:#d4e0fb;font-family:var(--mono);font-size:.72rem;letter-spacing:0}
.badge-neutral{color:var(--muted);background:#f1f5f9;border-color:var(--line)}
.badge-row{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 2px}

/* ============================ Summary-Grid ("Auf einen Blick") ============================ */
.summary{border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:var(--card)}
.sm-row{display:grid;grid-template-columns:210px minmax(0,1fr);gap:14px;padding:13px 16px;border-top:1px solid var(--line-2)}
.sm-row:first-child{border-top:0}
.sm-row:nth-child(odd){background:var(--card-soft)}
.sm-k{color:var(--muted);font-weight:600;font-size:.9rem}
.sm-v{color:var(--ink);font-weight:560;min-width:0;overflow-wrap:break-word}
.sm-v.is-hl{color:var(--brand-dark);font-weight:760}
.sm-v code{font-size:.92em}

/* ============================ Status-Ampel (Startseite) ============================ */
.ampel{list-style:none;margin:0;padding:0}
.ampel li{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:15px 4px;border-top:1px solid var(--line-2)}
.ampel li:first-child{border-top:0}
.dot{width:11px;height:11px;border-radius:50%;flex:none;margin-top:2px;box-shadow:0 0 0 4px rgba(220,38,38,.12)}
.dot-crit{background:var(--crit)}
.dot-warn{background:var(--warn);box-shadow:0 0 0 4px rgba(217,119,6,.12)}
.dot-ok{background:var(--ok);box-shadow:0 0 0 4px rgba(34,197,94,.14)}
.ampel-main{min-width:0}
.ampel-main a.t{font-weight:730;color:var(--navy)}
.ampel-main a.t:hover{color:var(--brand-dark)}
.ampel-line{color:var(--ink-soft);font-size:.93rem}
.ampel-meta{font-size:.8rem;color:var(--muted);margin-top:3px}
.ampel-meta code{font-family:var(--mono);font-size:.92em;color:var(--ink-soft)}
.ampel-go{font-weight:650;font-size:.86rem;white-space:nowrap;color:var(--brand-dark);display:inline-flex;align-items:center;gap:5px}
.ampel-go svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.2}

/* ============================ Vuln-Karten (Startseite, 6 Absätze) ============================ */
.vuln-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.vcard{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px 22px 18px;transition:transform .16s,box-shadow .16s,border-color .16s}
.vcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);border-color:#dbe6f0}
.vcard-h{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.vcard-ic{width:42px;height:42px;border-radius:11px;flex:none;display:grid;place-items:center;background:var(--brand-50);color:var(--brand-dark)}
.vcard-ic svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8}
.vcard-t{font-weight:760;color:var(--navy);font-size:1.04rem;line-height:1.2}
.vcard-sub{font-size:.78rem;color:var(--muted)}
.vcard p{font-size:.93rem;color:var(--ink-soft);margin:0 0 14px}
.vcard-foot{margin-top:auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}
.vcard-go{font-weight:680;font-size:.88rem;color:var(--brand-dark);display:inline-flex;align-items:center;gap:6px}
.vcard-go svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.2;transition:transform .15s}
.vcard:hover .vcard-go svg{transform:translateX(3px)}

/* ============================ Schritt-für-Schritt ============================ */
.steps{list-style:none;counter-reset:st;margin:6px 0 0;padding:0}
.steps>li{counter-increment:st;position:relative;padding:0 0 18px 50px;min-height:34px}
.steps>li::before{content:counter(st);position:absolute;left:0;top:-2px;width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;font-weight:760;font-size:.95rem;display:grid;place-items:center;box-shadow:0 6px 14px rgba(26,158,84,.28)}
.steps>li::after{content:"";position:absolute;left:16px;top:34px;bottom:6px;width:2px;background:var(--brand-100)}
.steps>li:last-child{padding-bottom:0}
.steps>li:last-child::after{display:none}
.steps .st-h{font-weight:680;color:var(--navy);display:block;margin-bottom:1px}
.steps p{margin:.2em 0 0;color:var(--ink-soft);font-size:.95rem}

/* Pfad-Brotkrumen in Anleitungen (Menü → Pfad) */
.path{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px;font-weight:620;color:var(--navy);background:var(--card-soft);border:1px solid var(--line);border-radius:8px;padding:3px 9px;font-size:.9em;line-height:1.7}
.path .sep{color:var(--brand);font-weight:800}
code{font-family:var(--mono);background:#f1f5f9;border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-size:.86em;color:#334155;overflow-wrap:anywhere}
kbd{font-family:var(--mono);background:#fff;border:1px solid #cbd5e1;border-bottom-width:2px;border-radius:6px;padding:1px 7px;font-size:.82em;color:var(--navy)}

/* ============================ Callouts ============================ */
.callout{display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px;border-radius:var(--radius-sm);padding:16px 18px;border:1px solid var(--line);background:var(--card-soft);margin:0 0 14px}
.callout:last-child{margin-bottom:0}
.callout .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none}
.callout .ic svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.1}
.callout .ct{font-weight:730;color:var(--navy);margin:1px 0 3px}
.callout .cb{font-size:.94rem;color:var(--ink-soft);min-width:0;overflow-wrap:break-word}
.callout .cb :last-child{margin-bottom:0}
.callout.c-danger{background:var(--crit-50);border-color:var(--crit-100)}
.callout.c-danger .ic{background:var(--crit)}
.callout.c-danger .ct{color:#a51d1d}
.callout.c-warn{background:var(--warn-50);border-color:var(--warn-100)}
.callout.c-warn .ic{background:var(--warn)}
.callout.c-warn .ct{color:#92520a}
.callout.c-info{background:var(--info-50);border-color:#d4e0fb}
.callout.c-info .ic{background:var(--info)}
.callout.c-info .ct{color:#1d3a8a}
.callout.c-tip{background:var(--brand-50);border-color:var(--brand-100)}
.callout.c-tip .ic{background:var(--brand)}
.callout.c-tip .ct{color:var(--brand-dark)}

/* ============================ Buttons ============================ */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:680;font-size:.95rem;padding:11px 18px;border-radius:var(--radius-xs);border:1px solid transparent;cursor:pointer;transition:transform .12s,box-shadow .15s,background .15s}
.btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2.1}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 8px 18px rgba(26,158,84,.28)}
.btn-primary:hover{background:var(--brand-dark);color:#fff}
.btn-ghost{background:#fff;color:var(--navy);border-color:var(--line)}
.btn-ghost:hover{border-color:#cdd9e6;background:var(--card-soft);color:var(--navy)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:#16222e;color:#fff}
.btn-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}
.dl-inline{display:inline-flex;align-items:center;gap:4px;font-weight:650;white-space:nowrap}
.dl-inline svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.1}
.vcard-dl{display:inline-flex;align-items:center;gap:5px;font-weight:650;font-size:.84rem;color:var(--brand-dark);white-space:nowrap}
.vcard-dl svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.1}

/* ============================ Quellen-Liste ============================ */
.sources{list-style:none;margin:0;padding:0}
.sources li{display:flex;gap:11px;align-items:flex-start;padding:11px 0;border-top:1px solid var(--line-2)}
.sources li:first-child{border-top:0}
.sources .src-ic{width:18px;height:18px;flex:none;margin-top:3px;stroke:var(--brand);fill:none;stroke-width:2}
.sources a{font-weight:640;color:var(--navy)}
.sources a:hover{color:var(--brand-dark)}
.sources .src-note{display:block;font-size:.84rem;color:var(--muted);font-weight:400}

/* ============================ HTProtect-Sektion ============================ */
.ht-wrap{background:
   radial-gradient(900px 300px at 100% 0%, rgba(26,158,84,.16), transparent 55%),
   linear-gradient(165deg,#22384a 0%, #182531 100%);
  color:#dde7f0;border:1px solid #2b3f52;border-radius:var(--radius);box-shadow:var(--shadow);padding:32px 34px;overflow:hidden;position:relative}
.ht-wrap h2,.ht-wrap h3{color:#fff}
.ht-wrap strong{color:#ffffff}
.ht-wrap em{color:#cfeede;font-style:normal;font-weight:650}
.ht-wrap code{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);color:#e8f3ec}
.ht-wrap .eyebrow{color:#7fe0a6}
.ht-head{display:flex;align-items:center;gap:14px;margin-bottom:4px}
.ht-mark{width:46px;height:auto;flex:none}
.ht-word{font-size:1.5rem;font-weight:820;letter-spacing:-.02em}
.ht-word .b1{color:#fff}.ht-word .b2{color:#5fd391}
.ht-lead{color:#bccbd9;max-width:64ch}
.ht-meta{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 22px}
.ht-meta .badge{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.16);color:#d7e6f1}
.feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 22px}
.feat{display:flex;gap:12px}
.feat-ic{width:30px;height:30px;border-radius:9px;flex:none;display:grid;place-items:center;background:rgba(95,211,145,.16);border:1px solid rgba(95,211,145,.28)}
.feat-ic svg{width:17px;height:17px;stroke:#7fe0a6;fill:none;stroke-width:2.1}
.feat-t{font-weight:680;color:#fff;font-size:.96rem;line-height:1.3}
.feat-d{font-size:.85rem;color:#aebccb;margin-top:1px}
.ht-foot{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px}
.ht-disc{font-size:.85rem;color:#9fb1c2;max-width:60ch}
.ht-wrap .btn-primary{box-shadow:0 8px 20px rgba(0,0,0,.25)}
.ht-wrap .btn-ghost{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.22);color:#fff}
.ht-wrap .btn-ghost:hover{background:rgba(255,255,255,.12)}

/* ============================ Unterstützer ============================ */
.supporters{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.sup{display:flex;gap:16px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px;transition:transform .16s,box-shadow .16s}
.sup:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.sup-logo{width:172px;height:86px;flex:none;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;box-shadow:var(--shadow-sm);overflow:hidden}
.sup-logo picture{display:block;width:100%;height:100%}
.sup-logo img{display:block;width:100%;height:100%;object-fit:contain;object-position:center}
.sup-name{font-weight:760;color:var(--navy);font-size:1.05rem}
.sup-role{font-size:.78rem;font-weight:650;color:var(--brand-dark);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.sup-d{font-size:.9rem;color:var(--ink-soft);margin:0 0 10px}
.sup-link{font-weight:650;font-size:.88rem;display:inline-flex;align-items:center;gap:5px}
.sup-link svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.2}
.sup-cta{margin-top:18px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px 22px;background:linear-gradient(150deg,var(--brand-50),#f1fbf5);border:1px solid var(--brand-100);border-radius:var(--radius);padding:20px 24px}
.sup-cta-text{min-width:0}
.sup-cta h3{margin:0 0 4px;font-size:1.1rem}
.sup-cta p{margin:0;color:var(--ink-soft);font-size:.93rem;max-width:64ch}
.sup-cta .btn{flex:none}
@media (max-width:600px){.sup-cta{flex-direction:column;align-items:flex-start}.sup-cta .btn{width:100%;justify-content:center}}

/* ============================ Tabelle (Versionsübersicht) ============================ */
.tbl{width:100%;border-collapse:collapse;font-size:.92rem;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.tbl th,.tbl td{text-align:left;padding:10px 14px;border-top:1px solid var(--line-2)}
.tbl thead th{background:var(--card-soft);color:var(--muted);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;border-top:0}
.tbl tbody tr:hover{background:var(--card-soft)}
.tbl code{white-space:nowrap}
.tbl-wrap{overflow-x:auto}

/* ============================ Footer ============================ */
.site-footer{background:var(--navy);color:#aebccb;margin-top:34px;padding:40px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:30px;padding-bottom:26px;border-bottom:1px solid rgba(255,255,255,.10)}
.foot-brand .brand-word{font-size:1.45rem}
.foot-brand .brand-word .b1{color:#fff}
.foot-brand .brand-mark{width:40px}
.foot-tag{color:#7fd6a3;font-weight:600;font-size:.9rem;margin:10px 0 8px}
.foot-desc{font-size:.86rem;color:#94a6b8;max-width:42ch;margin:0}
.foot-col h4{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px}
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-col li{margin:7px 0}
.foot-col a{color:#aebccb;font-size:.9rem}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;padding-top:20px;font-size:.83rem;color:#8497a9}
.foot-legal a{color:#aebccb}
.foot-legal a:hover{color:#fff}

/* ============================ Utilities ============================ */
.stack-sm>*+*{margin-top:.6em}
.mt0{margin-top:0}.mb0{margin-bottom:0}
.text-c{text-align:center}
.divider{height:1px;background:var(--line);margin:20px 0}
.note-inline{font-size:.85rem;color:var(--muted)}

/* ============================ Responsive ============================ */
@media (max-width:960px){
  .layout{grid-template-columns:minmax(0,1fr);gap:16px}
  .brandbar-right{display:none}
  .burger{display:flex}
  .nav-head{display:flex}
  .nav-scrim{display:block;position:fixed;inset:0;background:rgba(15,23,42,.5);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:115}
  .navtoggle:checked~.nav-scrim{opacity:1;visibility:visible}
  .sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:min(86vw,340px);transform:translateX(-100%);transition:transform .33s cubic-bezier(.4,0,.2,1);z-index:120;background:#fff;box-shadow:10px 0 44px rgba(15,23,42,.24);overflow-y:auto;padding:18px 16px;border-radius:0 18px 18px 0}
  .navtoggle:checked~.container .sidebar{transform:translateX(0)}
  .nav{display:block;background:transparent;border:0;box-shadow:none;border-radius:0;padding:0;overflow:visible}
  .nav-i{font-size:.97rem;padding:11px 12px}
  .nav-side-cta{display:block;margin-top:16px}
  .feature-grid{grid-template-columns:1fr}
  html:has(.navtoggle:checked){overflow:hidden}
}
@media (max-width:720px){
  .vuln-grid{grid-template-columns:1fr}
  .supporters{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:24px}
  .foot-brand{grid-column:1 / -1}
  .card{padding:22px 20px}
  .card-pad-lg,.ht-wrap{padding:24px 20px}
  .brand-badge{display:none}
  .brandbar-right{display:none}
}
@media (max-width:560px){
  body{font-size:15.5px}
  .sm-row{grid-template-columns:1fr;gap:2px;padding:11px 14px}
  .sm-k{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
  .ampel li{grid-template-columns:auto 1fr;gap:11px}
  .ampel-go{grid-column:2;justify-self:start;margin-top:2px}
  .foot-grid{grid-template-columns:1fr}
  .appbar-note{display:none}
  .ht-foot .btn,.btn-row .btn{width:100%;justify-content:center}
  .sup{flex-direction:column}
  .sup-logo{width:100%;max-width:240px;height:78px}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;transition:none !important;animation:none !important}
}
