/* backlinkbrain — App-Stylesheet ("Neural Ink")
   Barrierearm nach WCAG 2.1 AA: sichtbarer Fokus, ausreichende Kontraste,
   reduzierte Bewegung respektiert, Status nie nur über Farbe. */

:root{
  --ink:#0E1230; --ink-soft:#3A3F66; --muted:#6C719B;
  --surface:#FFFFFF; --surface-alt:#F3F4FB; --line:#E1E2F0;
  --brand:#4B30D8; --brand-press:#3A23B0; --brand-2:#8B6CFF; --signal:#00A892;
  --green:#15803D; --amber:#B45309; --red:#C81E26;
  --green-bg:#E7F4EC; --amber-bg:#FBF1E0; --red-bg:#FBE9EA;
  --r:14px; --shadow:0 14px 40px -22px rgba(14,18,48,.40);
  --font-d:"Space Grotesk",system-ui,Arial,sans-serif;
  --font-b:"Inter",system-ui,Arial,sans-serif;
  --font-m:"Space Mono",ui-monospace,"Courier New",monospace;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-b);color:var(--ink);background:var(--surface-alt);
  line-height:1.55;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,.d{font-family:var(--font-d);letter-spacing:-.01em}
a{color:var(--brand)}
.wrap{max-width:1000px;margin:0 auto;padding:0 20px}
.mono{font-family:var(--font-m)}

/* Sichtbarer Tastatur-Fokus (WCAG 2.4.7) */
a:focus-visible,button:focus-visible,input:focus-visible,
[tabindex]:focus-visible,summary:focus-visible{
  outline:3px solid var(--brand-2);outline-offset:2px;border-radius:6px;
}
/* Skip-Link für Screenreader/Tastatur */
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;
  padding:10px 16px;z-index:100;border-radius:0 0 8px 0}
.skip:focus{left:0}

/* Header */
header.app{background:var(--surface);border-bottom:1px solid var(--line)}
header.app .bar{display:flex;align-items:center;gap:16px;padding:12px 20px;
  max-width:1000px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink)}
.brand .wm{font-family:var(--font-d);font-weight:600;font-size:20px}
.brand .wm .lo{color:var(--brand)}
header.app nav{margin-left:auto;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
header.app nav a,header.app nav button.linklike{
  font-size:14px;color:var(--ink-soft);text-decoration:none;padding:8px 12px;
  border-radius:9px;background:none;border:none;cursor:pointer;font-family:var(--font-b)}
header.app nav a:hover{background:var(--surface-alt)}
.lang{border:1px solid var(--line);border-radius:9px;font-family:var(--font-m);font-size:12px}

/* Hauptbereich */
main{padding:34px 0 70px}
.page-title{font-size:26px;font-weight:600;margin:0 0 6px}
.page-sub{color:var(--ink-soft);margin:0 0 26px;max-width:62ch}

/* Karten */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:22px;box-shadow:var(--shadow)}
.card + .card{margin-top:16px}

/* Auth-Layout (zentriert) */
.auth{min-height:72vh;display:flex;align-items:center;justify-content:center}
.auth .card{width:100%;max-width:420px}
.auth h1{font-size:22px;margin:0 0 18px}
.auth .alt{margin-top:16px;font-size:14px;color:var(--muted);text-align:center}

/* Formulare */
.field{margin-bottom:16px}
.field label{display:block;font-size:14px;font-weight:600;margin-bottom:6px}
.field input[type=text],.field input[type=email],.field input[type=password],
.field input[type=url]{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;
  font-size:15px;font-family:var(--font-b);background:#fff;color:var(--ink)}
.field .hint{font-size:13px;color:var(--muted);margin-top:6px}
.field input:focus{border-color:var(--brand)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-d);font-weight:600;font-size:15px;padding:11px 20px;
  border-radius:11px;border:1.5px solid transparent;background:var(--brand);
  color:#fff;cursor:pointer;text-decoration:none;line-height:1.2}
.btn:hover{background:var(--brand-press)}
.btn:active{transform:translateY(1px)}
.btn.full{width:100%}
.btn.ghost{background:transparent;color:var(--brand);border-color:var(--brand)}
.btn.ghost:hover{background:var(--surface-alt)}
.btn.sm{font-size:13px;padding:8px 14px}
.btn.danger{background:transparent;color:var(--red);border-color:var(--line)}
.btn.danger:hover{background:var(--red-bg)}
.btnrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}

/* Meldungen */
.flash{border-radius:11px;padding:12px 16px;margin-bottom:18px;font-size:14px;
  border:1px solid}
.flash.error{background:var(--red-bg);border-color:#F0C7C9;color:#8E1318}
.flash.info{background:var(--surface-alt);border-color:var(--line);color:var(--ink-soft)}

/* Stepper (Signatur) */
.stepper{display:flex;align-items:flex-start;margin-bottom:30px}
.step{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;
  position:relative;min-width:0;text-decoration:none}
.step .bar{position:absolute;top:22px;left:-50%;width:100%;height:3px;
  background:var(--line);z-index:0}
.step:first-child .bar{display:none}
.step.done .bar,.step.active .bar{background:linear-gradient(90deg,var(--signal),var(--brand))}
.node{width:46px;height:46px;border-radius:13px;background:#fff;border:2px solid var(--line);
  display:flex;align-items:center;justify-content:center;position:relative;z-index:1;
  color:var(--muted);font-family:var(--font-d);font-weight:600}
.step.done .node{background:var(--signal);border-color:var(--signal);color:#fff}
.step.active .node{background:var(--brand);border-color:var(--brand);color:#fff;
  box-shadow:0 0 0 5px rgba(75,48,216,.16)}
.step .lbl{margin-top:9px;font-family:var(--font-d);font-size:12.5px;font-weight:600;
  color:var(--ink-soft)}
.step.active .lbl{color:var(--brand)}
.step.locked{cursor:not-allowed;opacity:.65}

/* Projektliste */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.proj{display:flex;flex-direction:column;gap:8px}
.proj .pdomain{font-family:var(--font-m);font-size:13px;color:var(--ink-soft);
  word-break:break-all}
.proj .pname{font-family:var(--font-d);font-weight:600;font-size:18px}
.proj .pactions{margin-top:auto;display:flex;gap:8px;padding-top:8px}
.plan-badge{display:inline-block;font-family:var(--font-m);font-size:12px;
  background:var(--surface-alt);border:1px solid var(--line);border-radius:999px;
  padding:4px 12px;color:var(--ink-soft)}

/* Quellen-Auswahl (Step 2) */
.sources{display:grid;gap:12px;margin-bottom:22px}
.src{display:flex;gap:14px;align-items:flex-start;border:1.5px solid var(--line);
  border-radius:12px;padding:14px 16px;cursor:pointer;background:#fff}
.src:hover{border-color:var(--brand-2)}
.src input{margin-top:3px;width:18px;height:18px;accent-color:var(--brand)}
.src .stitle{font-family:var(--font-d);font-weight:600}
.src .sdesc{font-size:13px;color:var(--muted)}
.dropzone{border:2px dashed var(--line);border-radius:12px;padding:28px;text-align:center;
  color:var(--muted);background:var(--surface-alt);font-size:14px}

/* Hilfe (details/summary) */
details.help{margin:18px 0 0;border:1px solid var(--line);border-radius:11px;
  background:var(--surface-alt)}
details.help summary{cursor:pointer;padding:12px 16px;font-weight:600;font-size:14px;
  font-family:var(--font-d);list-style:none;display:flex;align-items:center;gap:8px}
details.help summary::-webkit-details-marker{display:none}
details.help summary::before{content:"?";display:inline-flex;width:20px;height:20px;
  border-radius:50%;background:var(--brand);color:#fff;align-items:center;
  justify-content:center;font-size:13px;flex:0 0 auto}
details.help .hbody{padding:0 16px 14px 44px;font-size:14px;color:var(--ink-soft)}

/* Kennzahlen + Tabelle (Step 3) */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px}
.kpi{border:1px solid var(--line);border-radius:12px;padding:14px;background:var(--surface-alt)}
.kpi .k{font-family:var(--font-m);font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted)}
.kpi .v{font-family:var(--font-d);font-size:24px;font-weight:700;margin-top:2px}
.kpi .v.amber{color:var(--amber)} .kpi .v.green{color:var(--green)} .kpi .v.red{color:var(--red)}
table.tbl{width:100%;border-collapse:collapse;font-size:14px}
table.tbl th{text-align:left;font-family:var(--font-m);font-size:11px;letter-spacing:.05em;
  text-transform:uppercase;color:var(--muted);padding:10px 12px;border-bottom:1px solid var(--line)}
table.tbl td{padding:11px 12px;border-bottom:1px solid var(--line)}
.chip{display:inline-block;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;
  font-family:var(--font-d)}
.chip.ok{background:var(--green-bg);color:var(--green)}
.chip.low{background:var(--amber-bg);color:var(--amber)}
.chip.bad{background:var(--red-bg);color:var(--red)}

/* Download-Kacheln (Step 4) */
.dl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.dl{border:1px solid var(--line);border-radius:12px;padding:18px;background:#fff;
  display:flex;flex-direction:column;gap:10px}
.dl .dlname{font-family:var(--font-d);font-weight:600}
.dl .done{font-size:13px;color:var(--green);font-weight:600}

/* Verarbeitungs-Zustand */
.proc{text-align:center;padding:30px 0}
.spinner{width:46px;height:46px;border-radius:50%;border:4px solid var(--line);
  border-top-color:var(--brand);margin:0 auto 20px;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* Fortschrittsbalken (Verarbeitungs-Seite) */
.pbar{height:10px;border-radius:999px;background:var(--surface-alt);
  border:1px solid var(--line);overflow:hidden;margin:18px auto 8px;max-width:420px}
.pbar > i{display:block;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--brand),var(--signal));
  transition:width .4s ease}
.pcount{font-family:var(--font-m);font-size:13px;color:var(--ink-soft);margin:0}
.pphase{font-size:13px;color:var(--muted);margin:4px 0 0}

/* Footer */
footer.app{border-top:1px solid var(--line);padding:26px 0;color:var(--muted);
  font-size:13px;text-align:center}

@media(max-width:680px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .step .lbl{font-size:11px}
  .node{width:40px;height:40px}
  .page-title{font-size:22px}
}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
}

/* Nerd-Smiley im Footer (Noto, Apache-2.0) — als Grafik statt Text */
.footer-emoji{display:inline-block;vertical-align:-4px;margin-left:2px}
