/* ========================================================================= components.css — wiederverwendbare Bausteine (Karten, KPIs, Listen, Forms) ========================================================================= */ /* ---- Karte (Grundbaustein) ---- */ .card{ background:var(--panel);border:1px solid var(--line);border-radius:var(--radius); padding:18px 20px; } .card-h{display:flex;align-items:center;gap:10px;margin:0 0 14px} .card-h h3{font-size:15px;font-weight:600;margin:0;flex:1;color:var(--tx)} .card-h .meta{font-family:var(--mono);font-size:12px;color:var(--mut)} .card-h .meta.ok{color:var(--on)} /* ---- Hero (Overview-Kopf) ---- */ .hero{ background: radial-gradient(120% 140% at 100% 0%,rgba(68,147,224,.10),transparent 60%), var(--panel); border:1px solid var(--line);border-radius:var(--radius); padding:26px 28px;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap; } .hero .eyebrow{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--mut)} .hero h1{font-size:26px;font-weight:650;margin:8px 0 6px} .hero p{margin:0;color:var(--mut);font-size:14px;max-width:60ch} .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-content:start} .mini{ min-width:128px;border:1px solid var(--line);border-radius:10px; padding:11px 14px;background:var(--bg2); } .mini .l{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--mut)} .mini .v{font-family:var(--mono);font-size:15px;margin-top:4px;color:var(--tx)} .mini .v b{color:var(--on);font-weight:600} /* ---- KPI-Kacheln ---- */ .kpi{ position:relative;border-radius:var(--radius);padding:18px 20px; border:1px solid var(--line);background:var(--panel);overflow:hidden; } .kpi .k-h{display:flex;align-items:flex-start;justify-content:space-between;gap:8px} .kpi .k-t{font-size:13.5px;color:var(--mut)} .kpi .k-ic{color:var(--mut);opacity:.85} .kpi .k-ic svg{width:20px;height:20px} .kpi .k-v{font-family:var(--mono);font-size:32px;font-weight:600;line-height:1.1;margin:14px 0 4px;color:var(--tx)} .kpi .k-v small{font-size:15px;color:var(--mut);font-weight:400} .kpi .k-s{font-size:12px;color:var(--mut)} /* Farb-Varianten */ .kpi.green {background:linear-gradient(160deg,var(--t-green),transparent 70%);border-color:var(--b-green)} .kpi.green .k-v,.kpi.green .k-ic{color:var(--on)} .kpi.blue {background:linear-gradient(160deg,var(--t-blue),transparent 70%);border-color:var(--b-blue)} .kpi.blue .k-v,.kpi.blue .k-ic{color:var(--act)} .kpi.purple{background:linear-gradient(160deg,var(--t-purple),transparent 70%);border-color:var(--b-purple)} .kpi.purple .k-v,.kpi.purple .k-ic{color:var(--purple)} .kpi.red {background:linear-gradient(160deg,var(--t-red),transparent 70%);border-color:var(--b-red)} .kpi.red .k-v,.kpi.red .k-ic{color:var(--err)} .kpi.muted .k-v{color:var(--dim)} /* ---- Key-Value-Liste (Health-Signale) ---- */ .kv{display:flex;flex-direction:column} .kv-row{display:flex;align-items:center;justify-content:space-between;gap:12px; padding:11px 2px;border-top:1px solid var(--line)} .kv-row:first-child{border-top:0} .kv-row .kv-k{color:var(--mut);font-size:13.5px} .kv-row .kv-v{font-family:var(--mono);font-size:13.5px;color:var(--tx)} .kv-v.ok{color:var(--on)} .kv-v.bad{color:var(--err)} .kv-v.na{color:var(--dim)} .bar{height:4px;border-radius:3px;background:var(--panel2);margin-top:8px;overflow:hidden} .bar > i{display:block;height:100%;background:var(--on);border-radius:3px;transition:width .4s} .bar.blue > i{background:var(--act)} .bar.warn > i{background:var(--warn)} /* ---- Listen-Items (Modelle / "Session Router") ---- */ .list{display:flex;flex-direction:column} .li{display:flex;align-items:center;gap:12px;padding:12px 4px;border-top:1px solid var(--line)} .li:first-child{border-top:0} .li .li-dot{width:9px;height:9px;border-radius:50%;background:var(--dim);flex:0 0 auto} .li .li-dot.on{background:var(--on)} .li .li-dot.load{background:var(--warn)} .li .li-main{flex:1;min-width:0} .li .li-id{font-family:var(--mono);font-size:13px;color:#e8eef5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis} .li .li-sub{font-size:12px;color:var(--mut);margin-top:2px} .li .li-right{text-align:right;flex:0 0 auto} .li .li-meta{font-family:var(--mono);font-size:12px;color:var(--mut)} .li .li-time{font-family:var(--mono);font-size:11.5px;color:var(--dim);margin-top:2px} /* ---- Tabelle ---- */ table{width:100%;border-collapse:collapse;font-size:14px} th{text-align:left;font-weight:500;color:var(--mut);font-size:11.5px;text-transform:uppercase; letter-spacing:.06em;padding:0 10px 10px} td{padding:12px 10px;border-top:1px solid var(--line)} .mid{font-family:var(--mono);font-size:13px;color:#e8eef5} .port{font-family:var(--mono);color:var(--mut);font-size:13px} /* ---- Badges ---- */ .badge{font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:6px;display:inline-block} .b-run{background:rgba(63,185,80,.14);color:var(--on)} .b-idle{background:rgba(139,151,165,.14);color:var(--mut)} .b-load{background:rgba(224,163,46,.16);color:var(--warn)} .b-err{background:rgba(229,83,75,.16);color:var(--err)} .b-ok{background:rgba(63,185,80,.14);color:var(--on)} /* ---- Empty-States ---- */ .empty{color:var(--mut);font-size:13.5px;padding:14px 4px} .empty-c{display:flex;flex-direction:column;align-items:center;justify-content:center; text-align:center;padding:44px 16px;color:var(--mut)} .empty-c .e-t{font-size:14px} .empty-c .e-s{font-size:12.5px;color:var(--dim);margin-top:6px} /* ---- Forms ---- */ label{display:block;font-size:12px;color:var(--mut);margin:0 0 5px} input,textarea,select{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--tx); border-radius:8px;padding:9px 11px;font-family:var(--mono);font-size:13px;margin-bottom:12px} input:focus,textarea:focus,select:focus{outline:none;border-color:var(--act)} textarea{resize:vertical;min-height:64px;font-family:var(--sans)} .row{display:flex;gap:10px}.row>div{flex:1} .hint{font-size:12px;color:var(--mut);margin:-4px 0 12px} .mono-sm{font-family:var(--mono);font-size:11.5px;color:var(--mut)} /* ---- Buttons ---- */ button{font-family:var(--sans);font-size:13.5px;font-weight:500;border:1px solid var(--line2); background:var(--panel2);color:var(--tx);border-radius:8px;padding:9px 15px;cursor:pointer;transition:.15s} button:hover{border-color:var(--act)} button.primary{background:var(--act);border-color:var(--act);color:#fff} button.primary:hover{filter:brightness(1.08)} button.danger{background:var(--err);border-color:var(--err);color:#fff} button.danger:hover{filter:brightness(1.08)} button.ghost{padding:6px 11px;font-size:12.5px} button:disabled{opacity:.5;cursor:not-allowed} .btn-row{display:flex;gap:10px;flex-wrap:wrap} /* ---- Reply / Log ---- */ .reply{margin-top:12px;background:var(--panel2);border:1px solid var(--line);border-radius:8px; padding:12px;white-space:pre-wrap;font-size:14px;min-height:20px;color:var(--tx)} .log{font-family:var(--mono);font-size:12px;line-height:1.65;background:var(--inset);border:1px solid var(--line); border-radius:8px;padding:12px;max-height:240px;overflow:auto;white-space:pre-wrap;color:#aeb9c4} .job{border:1px solid var(--line);border-radius:10px;margin-bottom:8px;overflow:hidden;background:var(--bg2)} .job-h{display:flex;align-items:center;gap:10px;padding:11px 13px;cursor:pointer} .job-h .mid{flex:1} /* ---- Toast ---- */ .toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--panel2); border:1px solid var(--line2);border-radius:10px;padding:11px 16px;font-size:13.5px; opacity:0;transition:.25s;pointer-events:none;max-width:90vw;z-index:50} .toast.show{opacity:1} .toast.err{border-color:var(--err);color:#ffb4ae} /* ---- Accordion (Guides) ---- */ .guide-acc { border-bottom: 1px solid var(--line); } .guide-acc:last-child { border-bottom: none; } .guide-acc summary { padding: 16px 20px; font-weight: 600; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; } .guide-acc summary::-webkit-details-marker { display: none; } .guide-acc summary::after { content: "▼"; font-size: 10px; color: var(--mut); transition: transform 0.2s; } .guide-acc[open] summary::after { transform: rotate(180deg); } .guide-acc .acc-body { padding: 0 20px 20px 20px; }