/* ==========================================================================
   Aktavo – Basis-Stylesheet (Design-Tokens + Komponenten)
   Marke: „Serife + Blau". Tokens zentral als CSS-Variablen, damit sie später
   1:1 in die SPA übernommen werden können. Reine Styling-Schicht – die
   Klassennamen entsprechen den bestehenden Templates.
   ========================================================================== */

/* --- Selbst gehostete Fonts (woff2, Latin-Subset inkl. ä/ö/ü/ß) -----------
   DSGVO: kein Google-CDN; OFL-lizenziert (Inter, Source Serif 4). */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/inter-700.woff2') format('woff2')}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/source-serif-4-400.woff2') format('woff2')}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/source-serif-4-600.woff2') format('woff2')}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/source-serif-4-700.woff2') format('woff2')}

:root{
  /* Akzent / Primär (Aktionen, Links, aktive Nav, Logo) */
  --accent:#185FA5; --accent-hover:#0C447C; --accent-tint:#E6F1FB;
  /* Ink (Überschriften, Wortmarke, Text) */
  --ink:#14253D; --ink-2:#5B6472; --ink-3:#8A8F99;
  /* Status */
  --green:#1F6E56; --green-tint:#E1F5EE;     /* sicher / freigegeben */
  --amber:#BA7517; --amber-tint:#FAEEDA;     /* ausstehend */
  --danger:#B23A2E; --danger-tint:#FBEAE7;
  /* Flächen */
  --page:#FAFAF8; --card:#FFFFFF; --line:#E7E6E1;
  --radius:8px; --radius-card:12px;
  /* Typografie */
  --font-serif:'Source Serif 4', Georgia, 'Times New Roman', serif;
  --font-sans:'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  /* Rückwärtskompatible Aliase (vereinzelte Altnutzung) */
  --bg:var(--page); --muted:var(--ink-3); --primary:var(--accent);
  --primary-d:var(--accent-hover); --chip:var(--accent-tint);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--page); color:var(--ink);
  font-family:var(--font-sans); font-size:15px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:var(--accent); text-decoration:none}
a:hover{text-decoration:underline}

/* --- Typografie ---------------------------------------------------------- */
h1{font-family:var(--font-serif); font-weight:600; font-size:26px; line-height:1.25;
   color:var(--ink); margin:0 0 6px; letter-spacing:-.01em}
h2{font-family:var(--font-serif); font-weight:600; font-size:19px; line-height:1.3;
   color:var(--ink); margin:0 0 14px}
.muted{color:var(--ink-3); font-size:13px}
.backlink{display:inline-block; font-size:13px; color:var(--ink-3); margin-bottom:4px}
.backlink:hover{color:var(--accent); text-decoration:none}

/* --- Top-Bar ------------------------------------------------------------- */
header.topbar{
  background:var(--card); border-bottom:1px solid var(--line);
  padding:0 24px; height:60px;
  display:flex; align-items:center; justify-content:space-between;
}
header.topbar .brand{display:flex; align-items:center; gap:10px}
header.topbar .brand:hover{text-decoration:none}
.wordmark{font-family:var(--font-serif); font-weight:700; font-size:21px;
  color:var(--ink); letter-spacing:.01em}
header.topbar nav{display:flex; align-items:center; gap:18px}
header.topbar nav a{color:var(--ink-2); font-size:14px; font-weight:500}
header.topbar nav a:hover{color:var(--accent); text-decoration:none}
.role-chip{
  background:var(--accent-tint); border:1px solid var(--line); color:var(--accent);
  padding:3px 10px; border-radius:999px; font-size:12px; font-weight:600;
}
/* Benachrichtigungs-Glocke (Umriss / gefüllt + Zähler-Badge) */
.bell{position:relative; display:inline-flex; align-items:center; color:var(--ink-2)}
.bell:hover{color:var(--accent)}
.ic-bell{display:block}
.bell-badge{position:absolute; top:-6px; right:-7px; min-width:15px; height:15px; padding:0 3px;
  border-radius:999px; background:var(--danger); color:#fff; font-size:10px; font-weight:700;
  line-height:15px; text-align:center}

/* --- Layout -------------------------------------------------------------- */
.wrap{max-width:1080px; margin:28px auto; padding:0 20px;
  min-height:calc(100vh - 60px - 130px)}
.card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius-card);
  padding:24px; margin-bottom:18px; box-shadow:0 1px 2px rgba(20,37,61,.04);
}

/* --- Tabellen ------------------------------------------------------------ */
table{width:100%; border-collapse:collapse}
th,td{text-align:left; padding:11px 10px; border-bottom:1px solid var(--line); vertical-align:middle}
th{font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-3)}
tbody tr:hover{background:var(--page)}

/* --- Buttons ------------------------------------------------------------- */
.btn{
  display:inline-block; background:var(--accent); color:#fff; border:1px solid var(--accent);
  padding:9px 15px; border-radius:var(--radius); font-size:14px; font-weight:600;
  font-family:inherit; cursor:pointer; text-decoration:none; line-height:1.3;
}
.btn:hover{background:var(--accent-hover); border-color:var(--accent-hover); color:#fff; text-decoration:none}
.btn.sec{background:var(--card); color:var(--ink); border-color:var(--line)}
.btn.sec:hover{background:var(--accent-tint); border-color:var(--accent); color:var(--accent)}
.btn.sm{padding:5px 11px; font-size:13px}
.btn.danger{background:var(--danger); border-color:var(--danger)}
.btn.danger:hover{background:#8f2c22; border-color:#8f2c22}

/* --- Formulare ----------------------------------------------------------- */
label{display:block; font-size:13px; font-weight:600; color:var(--ink-2); margin:14px 0 5px}
.input{
  width:100%; padding:10px 12px; border:1px solid var(--line); border-radius:var(--radius);
  font-size:14px; font-family:inherit; color:var(--ink); background:var(--card);
}
.input:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-tint)}

/* --- Breadcrumbs --------------------------------------------------------- */
.breadcrumbs{font-size:13px; color:var(--ink-3); margin-bottom:16px}
.breadcrumbs a{color:var(--ink-2)}
.breadcrumbs a:hover{color:var(--accent)}

/* --- Chips & Pills ------------------------------------------------------- */
.chip{display:inline-block; background:var(--accent-tint); color:var(--accent);
  padding:2px 9px; border-radius:6px; font-size:12px; font-weight:600}
.pill{display:inline-block; padding:2px 9px; border-radius:6px; font-size:12px; font-weight:600}
.pill.r{background:var(--accent-tint); color:var(--accent)}
.pill.d{background:var(--green-tint); color:var(--green)}
.pill.p{background:var(--amber-tint); color:var(--amber)}
.pill.x{background:var(--danger-tint); color:#7c2418}                 /* abgelaufen/Fehler */
.pill.n{background:var(--page); color:var(--ink-2); border:1px solid var(--line)}  /* neutral */

/* --- Meldungen ----------------------------------------------------------- */
.msg{padding:11px 14px; border-radius:var(--radius); margin-bottom:12px; font-size:14px; border:1px solid transparent}
.msg.success{background:var(--green-tint); color:#13503e; border-color:#bfe6d8}
.msg.error{background:var(--danger-tint); color:#7c2418; border-color:#f1cabf}
.msg.info{background:var(--accent-tint); color:var(--accent-hover); border-color:#cfe3f6}

/* --- Utilities ----------------------------------------------------------- */
.row{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.spacer{flex:1}
.toolbar{display:flex; gap:10px; align-items:center; margin-bottom:18px; flex-wrap:wrap}
.icon{font-size:16px}
.ic{vertical-align:-3px}        /* kleine Inline-SVG-Icons (Ordner/Dokument) */
.empty{color:var(--ink-3); padding:22px; text-align:center}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:18px}
@media(max-width:720px){.grid2{grid-template-columns:1fr}}
.searchbar{display:flex; gap:8px}
.searchbar input{flex:1}
code.path{font-family:ui-monospace,Consolas,monospace; font-size:12px; color:var(--ink-3)}

/* --- Vertrauens-Leiste (Footer; auf jeder Seite) ------------------------- */
footer.trustbar{
  max-width:1080px; margin:8px auto 28px; padding:14px 20px 0;
  border-top:1px solid var(--line);
  display:flex; flex-wrap:wrap; gap:8px 16px; align-items:center;
  font-size:12px; color:var(--ink-3);
}
footer.trustbar .ts{display:inline-flex; align-items:center; gap:6px}
footer.trustbar .ts b{color:var(--ink-2); font-weight:600}
footer.trustbar .sep{color:var(--line)}

/* --- Login-Lockup -------------------------------------------------------- */
.brand-lockup{display:flex; flex-direction:column; align-items:center; gap:10px; margin:48px 0 18px}
.brand-lockup .wordmark{font-size:30px}

/* --- Onboarding-Modal ---------------------------------------------------- */
.modal-overlay{position:fixed; inset:0; background:rgba(20,37,61,.45); z-index:50;
  display:flex; align-items:flex-start; justify-content:center; padding:48px 16px; overflow:auto}
.modal-box{position:relative; background:var(--card); border:1px solid var(--line);
  border-radius:var(--radius-card); padding:28px 30px; max-width:560px; width:100%;
  box-shadow:0 12px 34px rgba(20,37,61,.20)}
.modal-x{position:absolute; top:8px; right:10px; background:none; border:0; cursor:pointer;
  font-size:22px; line-height:1; color:var(--ink-3); padding:4px 8px}
.modal-x:hover{color:var(--ink)}
.onb-steps{margin:10px 0 0; padding-left:22px; line-height:1.85}
.onb-steps li{padding-left:4px}
