/* RTSA – Koerting Institute CI. Dark-Mode-Default, Lime = Signal, Pink = Aktion.
   Tokens gemäß DESIGN-PRINCIPLES.md §5. CI-Werte nur hier als Custom Properties. */

:root {
  --lime:        #CDD500;
  --lime-bright: #DDE530;
  --pink:        #E6007E;
  --pink-bright: #FF2A99;
  --black:       #000000;
  --graphite:    #191919;
  --white:       #FFFFFF;

  --bg-0: #07070A; --bg-1: #0E0E12; --bg-2: #14141A; --bg-3: #1A1A22; --bg-4: #22222C;

  --text-100: #FFFFFF;
  --text-300: rgba(255,255,255,.72);
  --text-400: rgba(255,255,255,.55);
  --text-500: rgba(255,255,255,.40);
  --text-600: rgba(255,255,255,.28);

  --border-subtle: rgba(255,255,255,.06);
  --border-soft:   rgba(255,255,255,.10);
  --border-strong: rgba(255,255,255,.18);
  --border-active: rgba(205,213,0,.40);

  --status-green:  #4ADE80;
  --status-yellow: #FBBF24;
  --status-red:    #F87171;

  --grad-cta: linear-gradient(90deg, var(--lime) 0%, var(--pink) 100%);

  --space-xs: 4px; --space-sm: 8px; --space-md: 16px; --space-lg: 24px; --space-xl: 40px; --space-2xl: 64px;
  --r-sm: 10px; --r-md: 12px; --r-lg: 20px; --r-pill: 999px;

  --shadow-md: 0 8px 24px rgba(0,0,0,.45), 0 2px 6px rgba(0,0,0,.30);
  --glow-lime: 0 0 24px rgba(205,213,0,.40);

  --font: 'Effra','DM Sans','Inter',system-ui,-apple-system,sans-serif;
  --mono: 'JetBrains Mono','Consolas',ui-monospace,monospace;

  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --t-fast: .15s; --t: .25s;
  --container: 1000px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font);
  font-weight: 400;
  background: var(--bg-1);
  background-image:
    radial-gradient(60% 50% at 100% 0%, rgba(230,0,126,.10), transparent 70%),
    radial-gradient(50% 50% at 0% 0%, rgba(205,213,0,.08), transparent 70%);
  background-attachment: fixed;
  color: var(--text-300);
  line-height: 1.6;
  font-size: 15px;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

/* Calm hierarchy: weight comes from a few headings, not everywhere. */
h1, h2, h3, h4 { font-weight: 600; color: var(--text-100); }

.container { max-width: var(--container); margin: 0 auto; padding: var(--space-xl) var(--space-lg) var(--space-2xl); }

/* Header / wordmark */
.app-header { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-md); margin-bottom: var(--space-xl); flex-wrap: wrap; }
.wordmark { font-size: clamp(24px, 3.5vw, 34px); font-weight: 800; letter-spacing: -.02em; }
.wordmark .brace { color: var(--pink); font-weight: 500; }
.wordmark .brand-word {
  background: linear-gradient(135deg, var(--lime) 0%, var(--lime-bright) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  padding: 0 4px;
}
.subtitle { color: var(--text-400); font-size: 13px; }

/* Eyebrow */
.eyebrow { text-transform: uppercase; letter-spacing: .16em; font-size: 11px; font-weight: 700; color: var(--lime); margin-bottom: var(--space-sm); }

/* Cards */
.card {
  background: var(--bg-2);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-md);
  margin-bottom: var(--space-lg);
}
.card h2 { font-size: 18px; letter-spacing: -.01em; margin-bottom: var(--space-md); }

/* Status banner */
.status-banner {
  display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap;
  border-radius: var(--r-md); padding: var(--space-md) var(--space-lg); margin-bottom: var(--space-lg);
  border: 1px solid var(--border-soft); background: var(--bg-2);
}
.dot { width: 10px; height: 10px; border-radius: 50%; flex: none; }
.dot--on { background: var(--status-green); box-shadow: 0 0 10px rgba(74,222,128,.7); }
.dot--off { background: var(--status-red); }
.dot--pulse { animation: pulse 2s var(--ease) infinite; }
@keyframes pulse { 0%,100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.25); opacity: .5; } }
.status-text { flex: 1; min-width: 200px; color: var(--text-300); font-size: 14px; }

/* Forms */
label.field { display: block; margin-bottom: var(--space-md); }
.field-label { display: block; font-size: 13px; font-weight: 600; color: var(--text-300); margin-bottom: var(--space-xs); }
.field-hint { display: block; font-size: 12px; color: var(--text-500); margin-top: var(--space-xs); }
input[type="text"], input[type="password"], input[type="number"], input[type="url"], textarea, select {
  width: 100%; background: var(--bg-3); color: var(--text-100);
  border: 1px solid var(--border-soft); border-radius: var(--r-sm);
  padding: 12px 16px; font-family: var(--font); font-size: 14px;
  transition: border-color var(--t) var(--ease);
}
input::placeholder, textarea::placeholder { color: var(--text-600); }
input:focus, textarea:focus, select:focus { outline: none; border-color: var(--border-active); }
select { cursor: pointer; }
textarea { resize: vertical; min-height: 90px; line-height: 1.5; }
.row { display: flex; gap: var(--space-md); flex-wrap: wrap; align-items: flex-end; }
.row > * { flex: 1; min-width: 180px; }

.check { display: flex; align-items: center; gap: var(--space-sm); font-size: 14px; color: var(--text-300); cursor: pointer; }
.check input { width: 18px; height: 18px; accent-color: var(--pink); flex: none; }

/* Frame chips (multi-select) */
.frame-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--space-sm); }
.frame-chip {
  display: flex; align-items: center; gap: var(--space-sm);
  border: 1px solid var(--border-soft); border-radius: var(--r-md);
  padding: 10px 12px; background: var(--bg-3); cursor: pointer; font-size: 14px;
  transition: border-color var(--t) var(--ease), background var(--t) var(--ease);
}
.frame-chip:hover { border-color: var(--border-active); }
.frame-chip input { accent-color: var(--lime); width: 18px; height: 18px; flex: none; }
.frame-chip.selected { border-color: var(--border-active); background: rgba(205,213,0,.06); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm);
  font-family: var(--font); font-weight: 600; font-size: 14px; cursor: pointer;
  border: none; border-radius: var(--r-pill); padding: 12px 24px;
  transition: transform var(--t-fast) var(--ease), border-color var(--t) var(--ease), background var(--t) var(--ease);
}
.btn:focus-visible { outline: 2px solid rgba(205,213,0,.6); outline-offset: 2px; }
.btn:disabled { opacity: .4; cursor: not-allowed; }
.btn-cta { background: var(--grad-cta); color: var(--bg-0); }
.btn-cta:hover:not(:disabled) { transform: translateY(-2px); box-shadow: var(--glow-lime); }
.btn-secondary { background: var(--bg-3); color: var(--text-100); border: 1px solid var(--border-soft); }
.btn-secondary:hover:not(:disabled) { border-color: var(--border-active); }
.btn-ghost { background: transparent; color: var(--text-400); padding: 8px 12px; }
.btn-ghost:hover { color: var(--text-100); }

/* Questions */
.questions-list { list-style: none; display: flex; flex-direction: column; gap: var(--space-sm); }
.question-item {
  border-left: 4px solid var(--pink); background: var(--bg-3);
  border-radius: var(--r-sm); padding: 12px 16px; font-size: 15px; color: var(--text-100);
}
.question-num { color: var(--pink); font-weight: 700; font-family: var(--mono); margin-right: var(--space-sm); }

/* Content (verdeckt, collapsible) */
details.content-box { border: 1px solid var(--border-soft); border-radius: var(--r-md); background: var(--bg-2); padding: var(--space-md) var(--space-lg); }
details.content-box summary { cursor: pointer; color: var(--text-300); font-weight: 600; }
.content-md { margin-top: var(--space-md); color: var(--text-300); white-space: pre-wrap; font-size: 14px; line-height: 1.7; }

/* Log */
.log { font-family: var(--mono); font-size: 12px; background: var(--bg-0); border: 1px solid var(--border-subtle); border-radius: var(--r-sm); padding: var(--space-md); max-height: 220px; overflow-y: auto; color: var(--text-400); }
.log .log-line { padding: 2px 0; }
.log .log-warn { color: var(--status-yellow); }
.log .log-error { color: var(--status-red); }

/* Pills / badges */
.pill { display: inline-flex; align-items: center; gap: 6px; border-radius: var(--r-pill); padding: 4px 12px; font-size: 12px; font-weight: 600; }
.pill-lime { background: rgba(205,213,0,.10); border: 1px solid rgba(205,213,0,.25); color: var(--lime); }
.pill-pink { background: rgba(230,0,126,.10); border: 1px solid rgba(230,0,126,.30); color: var(--pink); }
.pill-gray { background: var(--bg-3); border: 1px solid var(--border-soft); color: var(--text-400); }

/* Run history */
.run-row { display: flex; align-items: center; gap: var(--space-md); padding: 10px 0; border-bottom: 1px solid var(--border-subtle); font-size: 14px; }
.run-row:last-child { border-bottom: none; }
.run-row .run-label { flex: 1; color: var(--text-300); }
.run-row time { color: var(--text-500); font-size: 12px; font-family: var(--mono); }

/* Spinner */
.spinner { width: 18px; height: 18px; border: 3px solid var(--border-soft); border-top-color: var(--lime); border-right-color: var(--pink); border-radius: 50%; animation: spin .9s linear infinite; display: inline-block; vertical-align: middle; }
@keyframes spin { to { transform: rotate(360deg); } }

.summary-head { cursor: pointer; font-weight: 600; color: var(--text-100); font-size: 15px; }

/* Output-mode selector (step editor) */
.mode-group { display: flex; gap: var(--space-sm); flex-wrap: wrap; margin-top: var(--space-xs); }
.mode-opt {
  display: flex; align-items: center; gap: var(--space-xs);
  border: 1px solid var(--border-soft); border-radius: var(--r-md);
  padding: 10px 14px; cursor: pointer; font-size: 14px; color: var(--text-300);
  transition: border-color var(--t) var(--ease), color var(--t) var(--ease), background var(--t) var(--ease);
}
.mode-opt:hover { border-color: var(--border-active); }
.mode-opt input { accent-color: var(--pink); }
.mode-opt:has(input:checked) { border-color: var(--border-active); background: rgba(205,213,0,.06); color: var(--text-100); }

/* Run summary (read-only: what the selected step will do) */
.run-summary { font-size: 14px; line-height: 1.6; }
.run-summary .rs-line { display: flex; gap: var(--space-sm); padding: 3px 0; }
.run-summary .rs-label { color: var(--text-500); min-width: 130px; flex: none; }
.run-summary .rs-value { color: var(--text-200); }
.run-summary .rs-warn { color: var(--status-yellow); }

/* Step checklist (app, per session) */
.check-list { display: flex; flex-direction: column; gap: var(--space-xs); margin-top: var(--space-sm); }
.check-row {
  display: flex; align-items: center; gap: var(--space-md);
  padding: 10px 12px; border: 1px solid var(--border-subtle); border-radius: var(--r-md);
  background: var(--bg-3); cursor: pointer; transition: border-color var(--t) var(--ease), background var(--t) var(--ease);
}
.check-row:hover { border-color: var(--border-active); }
.check-row.selected { border-color: var(--border-active); background: rgba(205,213,0,.06); }
.check-row .status-icon { flex: none; width: 18px; text-align: center; font-size: 14px; }
.check-row .status-done { color: var(--status-green); }
.check-row .status-open { color: var(--text-600); }
.check-row .ck-key { font-family: var(--mono); color: var(--lime); font-size: 13px; min-width: 34px; flex: none; }
.check-row .ck-name { flex: 1; color: var(--text-100); min-width: 0; }
.check-row .ck-meta { color: var(--text-500); font-size: 12px; flex: none; }

/* Tabs (Ebene navigation) */
.tabs { display: flex; gap: var(--space-xs); border-bottom: 1px solid var(--border-soft); margin-bottom: var(--space-lg); }
.tab {
  background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--text-400); font-family: var(--font); font-size: 14px; font-weight: 500;
  padding: 10px 16px; cursor: pointer; transition: color var(--t) var(--ease), border-color var(--t) var(--ease);
}
.tab:hover { color: var(--text-100); }
.tab.active { color: var(--lime); border-bottom-color: var(--lime); }
.tab:focus-visible { outline: 2px solid rgba(205,213,0,.6); outline-offset: 2px; }

/* Admin: steps list (flat, drag-orderable) */
.step-admin-row {
  display: flex; align-items: center; gap: var(--space-md);
  padding: 12px 14px; border: 1px solid var(--border-subtle); border-radius: var(--r-md);
  background: var(--bg-3); margin-bottom: var(--space-sm);
}
.step-admin-row.dragging { opacity: .45; border-color: var(--border-active); }
.drag-handle { cursor: grab; color: var(--text-500); font-size: 16px; flex: none; user-select: none; line-height: 1; }
.drag-handle:active { cursor: grabbing; }
.step-key { font-family: var(--mono); color: var(--lime); font-size: 13px; flex: none; min-width: 34px; }
.step-name-wrap { flex: 1; min-width: 0; }
.step-name-wrap .step-name { color: var(--text-100); }
.step-name-wrap .step-meta { color: var(--text-500); font-size: 12px; margin-top: 2px; }
.step-tags { display: flex; gap: var(--space-xs); flex: none; flex-wrap: wrap; }
.tag { font-size: 11px; color: var(--text-400); background: var(--bg-4); border: 1px solid var(--border-subtle); border-radius: var(--r-pill); padding: 2px 10px; }
.step-admin-actions { display: flex; gap: var(--space-xs); flex: none; }

/* Frame picker (admin editor) */
.frame-pool { display: flex; flex-wrap: wrap; gap: var(--space-xs); margin-bottom: var(--space-sm); }
.frame-pool:empty::after { content: 'Kein Referenz-Board geladen.'; color: var(--text-500); font-size: 13px; }
.frame-pick {
  border: 1px dashed var(--border-soft); background: transparent; color: var(--text-300);
  border-radius: var(--r-pill); padding: 5px 12px; font-size: 13px; cursor: pointer;
  font-family: var(--font); transition: border-color var(--t) var(--ease), color var(--t) var(--ease);
}
.frame-pick:hover { border-color: var(--border-active); color: var(--lime); }
.frame-pick:disabled { opacity: .35; cursor: default; }
.frame-chosen { display: flex; flex-wrap: wrap; gap: var(--space-xs); }
.frame-chosen:empty::after { content: 'Noch keine Rahmen gewählt.'; color: var(--text-600); font-size: 13px; }
.chosen-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(205,213,0,.08); border: 1px solid rgba(205,213,0,.25); color: var(--lime);
  border-radius: var(--r-pill); padding: 5px 6px 5px 12px; font-size: 13px;
}
.chosen-chip button { background: none; border: none; color: var(--lime); cursor: pointer; font-size: 15px; line-height: 1; padding: 0 4px; opacity: .7; }
.chosen-chip button:hover { opacity: 1; }

.hidden { display: none; }
.muted { color: var(--text-500); }
.error-text { color: var(--status-red); font-size: 14px; }

/* Login */
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: var(--space-lg); }
.login-card { width: 100%; max-width: 380px; }

@media (max-width: 640px) {
  .container { padding: var(--space-lg) var(--space-md) var(--space-xl); }
  .row > * { min-width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}
