/* =========================================================
   Kurssignale — UX-Wireframe (Low-Fi, kein visuelles Design)
   Bewusst graustufig: States über Form/Füllung/Text, NICHT Farbe.
   ========================================================= */
:root{
  --ink:#1d1d1f; --muted:#6b6b70; --faint:#9a9aa0;
  --line:#bcbcc2; --line-strong:#1d1d1f;
  --fill:#e9e9ec; --fill-2:#f1f1f3; --canvas:#f6f6f7; --paper:#ffffff;
  --note:#5a5a5f;
  --r:8px;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{margin:0;background:var(--canvas);color:var(--ink);
  font-family:ui-sans-serif,system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-size:15px;}
button{font-family:inherit;cursor:pointer}
em{color:var(--faint);font-style:normal}

/* ===== Tool-Chrome ===== */
.toolbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:14px;
  background:var(--ink);color:#fff;padding:10px 16px;font-size:13px}
.toolbar__brand{font-weight:600}
.toolbar__brand em{color:#9a9aa0;font-style:italic;font-weight:400}
.toolbar__spacer{flex:1}
.toolbar__group{display:flex;align-items:center;gap:6px}
.toolbar__label{color:#b9b9bf;margin-right:2px}
.tg{background:transparent;color:#fff;border:1px solid #55555b;border-radius:6px;padding:5px 11px;font-size:13px}
.tg.is-active{background:#fff;color:var(--ink);border-color:#fff;font-weight:600}

/* ===== Bühne / Frame ===== */
.stage{position:relative;min-height:calc(100vh - 41px)}
.frame{background:var(--paper);border:1px solid var(--line);margin:24px auto}
body.mode-app .frame{width:392px;border-radius:26px;min-height:780px;overflow:hidden}
body.mode-web .frame{width:min(1080px,calc(100% - 48px));border-radius:10px;min-height:660px}

/* ===== App-Bar ===== */
.appbar{display:flex;align-items:center;gap:10px;padding:16px 16px 10px;border-bottom:1px solid var(--fill)}
.appbar__title{font-size:18px;margin:0;font-weight:700}
.appbar__actions{margin-left:auto;display:flex;gap:8px}
.ico{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:7px 11px;font-size:13px;color:var(--ink)}
.ico--primary{border-color:var(--line-strong);font-weight:600}
body.mode-app .appbar__actions .ico{font-size:12px;padding:7px 9px}

/* ===== Filter ===== */
.filters{display:flex;align-items:center;gap:8px;padding:12px 16px;flex-wrap:wrap}
.chip{background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:6px 13px;font-size:13px;color:var(--muted)}
.chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink);font-weight:600}
.sort-label{margin-left:auto;color:var(--faint);font-size:12px}
body.mode-app .sort-label{display:none}

/* ===== Übersicht ===== */
#overview{padding:6px 16px 28px}
.group{margin-bottom:18px}
.group__head{display:flex;align-items:center;gap:8px;margin:8px 2px 10px;font-size:13px;color:var(--muted);font-weight:700}
.group__head .marker{width:14px;height:14px;border:1.5px solid var(--ink);display:inline-grid;place-items:center;font-size:9px;border-radius:3px}
.group__head .count{margin-left:auto;border:1px solid var(--line);border-radius:999px;padding:0 8px;color:var(--muted);font-weight:500}
.group__items{display:grid;gap:10px}
body.mode-web .group__items{grid-template-columns:1fr 1fr}

.scard{border:1px solid var(--line);border-radius:var(--r);padding:13px 14px;background:var(--paper);position:relative}
.scard.is-triggered{border:2px solid var(--ink)}
.scard.is-paused{background:var(--fill-2)}
.scard__row{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.scard__name{font-weight:700}
.scard__isin{font-size:12px;color:var(--muted);margin-top:1px}
.scard__dir{font-size:13px;color:var(--muted)}
.scard__thr{font-weight:700;white-space:nowrap}
.badge{display:inline-block;border:1px solid var(--ink);border-radius:4px;padding:1px 7px;font-size:11px;font-weight:700;letter-spacing:.3px}
.badge--fill{background:var(--ink);color:#fff}
.prox{margin-top:11px}
.prox__track{height:10px;border:1px solid var(--line);border-radius:3px;background:var(--paper);overflow:hidden;position:relative}
.prox__fill{position:absolute;inset:0 auto 0 0;background:repeating-linear-gradient(90deg,var(--ink) 0 6px,#444 6px 8px)}
.prox__fill--solid{background:var(--ink)}
.prox__fill--hatch{background:repeating-linear-gradient(45deg,var(--muted) 0 4px,transparent 4px 8px)}
.prox__meta{display:flex;justify-content:space-between;margin-top:7px;font-size:12px;color:var(--muted)}
.prox__meta b{color:var(--ink)}

.empty{border:1.5px dashed var(--line);border-radius:var(--r);padding:34px 20px;text-align:center;color:var(--muted)}
.empty .btn{margin-top:14px;display:inline-block;width:auto}

/* ===== Editor (Overlay) ===== */
.overlay{position:absolute;inset:0;background:rgba(20,20,22,.22);display:flex;z-index:30}
body.mode-app .overlay{align-items:flex-end;justify-content:center}
body.mode-web .overlay{align-items:center;justify-content:center}
.editor{background:var(--paper);border:1px solid var(--line-strong);display:flex;flex-direction:column;max-height:92%}
body.mode-app .editor{width:392px;border-radius:18px 18px 0 0;max-height:88%}
body.mode-web .editor{width:600px;border-radius:12px;box-shadow:0 18px 60px rgba(0,0,0,.25)}
.editor__top{display:flex;align-items:center;gap:10px;padding:13px 14px;border-bottom:1px solid var(--fill)}
.editor__title{margin:0;font-size:16px;font-weight:700}
.editor__top .ico--primary{margin-left:auto}
.editor__top #ed-close{order:-1}
.editor__scroll{overflow-y:auto;padding:4px 16px 22px}
body.mode-web .editor__scroll{padding:4px 22px 24px}

.block{padding:16px 0;border-bottom:1px solid var(--fill)}
.field{padding:16px 0;border-bottom:1px solid var(--fill)}
.field:last-of-type{border-bottom:none}
.tag{display:inline-block;border:1px solid var(--line);border-radius:5px;padding:2px 8px;font-size:11px;color:var(--muted)}
.instr-name{font-size:22px;font-weight:800;margin-top:6px}
.instr-sub{font-size:12px;color:var(--muted);margin-top:2px}
.price-row{display:flex;align-items:baseline;gap:10px;margin-top:12px;flex-wrap:wrap}
.price{font-size:24px;font-weight:800}
.price-delta{border:1px solid var(--line);border-radius:5px;padding:2px 8px;font-size:13px;color:var(--muted)}
.live-dot{font-size:11px;color:var(--muted);border:1px dashed var(--line);border-radius:999px;padding:1px 8px}

.label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);font-weight:600;margin-bottom:9px}
.hint{font-size:12px;color:var(--muted);margin-top:8px}
.info{background:transparent;border:1px solid var(--line);border-radius:5px;padding:2px 7px;font-size:12px;color:var(--ink)}

.select{position:relative}
.select select{width:100%;appearance:none;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:12px 36px 12px 12px;font-size:15px;color:var(--ink)}
.select::after{content:"▾";position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}

.seg{display:flex;gap:6px;border:1px solid var(--line);border-radius:var(--r);padding:4px;background:var(--fill-2)}
.seg__btn{flex:1;background:transparent;border:1px solid transparent;border-radius:6px;padding:10px 6px;font-size:14px;font-weight:600;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:1px}
.seg__btn small{font-size:10px;font-weight:500;opacity:.8}
.seg__btn.is-active{background:var(--paper);border-color:var(--ink);color:var(--ink)}

.explain{margin-top:9px;border:1px dashed var(--line);border-radius:var(--r);padding:11px 13px;font-size:13px;color:var(--muted);line-height:1.5;background:var(--fill-2)}
.explain b{color:var(--ink)}

/* ===== Preis-Skala (Herzstück) ===== */
.scale{padding:30px 6px 2px}
.scale__track{position:relative;height:6px;background:var(--fill);border:1px solid var(--line);border-radius:4px;margin:28px 6px}
.scale__zone{position:absolute;top:-7px;bottom:-7px;background:repeating-linear-gradient(45deg,var(--line) 0 5px,transparent 5px 10px);border:1px dashed var(--muted);border-radius:5px;pointer-events:none}
.scale__bar{position:absolute;top:0;bottom:0;background:var(--ink);border-radius:4px}
.scale__anchor{position:absolute;top:-8px;bottom:-8px;width:2px;background:var(--ink);left:50%;transform:translateX(-50%)}
.scale__anchor-lbl{position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--muted);white-space:nowrap}
.scale__handle{position:absolute;top:50%;left:50%;width:24px;height:24px;border-radius:50%;background:var(--paper);border:2px solid var(--ink);transform:translate(-50%,-50%);cursor:grab;touch-action:none}
.scale__handle:active{cursor:grabbing}
.scale__handle:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
.scale__flag{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);border:1px solid var(--ink);background:var(--paper);border-radius:5px;padding:2px 8px;font-size:12px;font-weight:700;white-space:nowrap}
.scale__ends{display:flex;justify-content:space-between;font-size:11px;color:var(--faint);margin:24px 6px 0}

/* Dual-Handle Korridor */
.scale__handle.is-off,.scale__zone.is-off{display:none}
.scale__flag{pointer-events:none}
#handle-lower{border-style:solid}
.scale__ends span{font-variant-numeric:tabular-nums}

.limit-row{display:grid;grid-template-columns:auto 1fr auto;gap:9px 10px;align-items:center;
  border:1px solid var(--line);border-radius:var(--r);padding:10px 11px;margin-top:10px}
.limit-row.is-off{opacity:.5}
.limit-tgl{grid-row:1;grid-column:1;width:26px;height:26px;border:1px solid var(--ink);background:var(--paper);
  border-radius:5px;font-size:13px;color:var(--ink);line-height:1}
.limit-tgl.is-on{background:var(--ink);color:#fff}
.limit-dir{grid-row:1;grid-column:2;font-weight:600;font-size:14px}
.limit-pct{grid-row:1;grid-column:3;font-weight:700;font-size:14px;text-align:right}
.limit-step{grid-row:2;grid-column:1 / -1;display:flex;align-items:center;gap:8px;
  border:1px solid var(--line);border-radius:var(--r);padding:5px}
.limit-step .thr__inp{flex:1;font-size:18px}
.limit-row.is-off .limit-step{pointer-events:none}
.btn:disabled{opacity:.4;cursor:not-allowed}

.thr{display:flex;align-items:center;gap:8px;margin-top:20px;border:1px solid var(--line);border-radius:var(--r);padding:6px}
.step{width:38px;height:38px;border:1px solid var(--line);border-radius:6px;background:var(--paper);font-size:20px;color:var(--ink)}
.thr__inp{flex:1;min-width:0;border:none;outline:none;text-align:center;font-size:20px;font-weight:800;color:var(--ink);background:transparent}
.thr__cur{color:var(--muted);font-size:13px;font-weight:700}
.dist{text-align:center;margin-top:11px;font-size:15px;font-weight:700}
.warn{margin-top:11px;border:1.5px solid var(--ink);border-radius:var(--r);padding:10px 13px;font-size:13px;background:var(--fill);line-height:1.45}
.warn::before{content:"⚠ ";font-weight:700}

.toggles{display:flex;gap:10px}
.tgl{flex:1;border:1px solid var(--line);border-radius:var(--r);padding:12px;font-size:14px;font-weight:600;color:var(--muted);background:var(--paper)}
.tgl.is-on{border-color:var(--ink);color:var(--ink)}

.cta{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.btn{width:100%;border-radius:var(--r);padding:14px;font-size:15px;font-weight:700;border:1px solid var(--ink)}
.btn--primary{background:var(--ink);color:#fff}
.btn--ghost{background:var(--paper);color:var(--ink);border-style:dashed}

/* ===== Toast ===== */
.toast{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);background:var(--ink);color:#fff;border-radius:var(--r);padding:12px 16px;display:flex;gap:16px;align-items:center;font-size:13px;z-index:40}
.toast button{background:transparent;border:none;color:#fff;text-decoration:underline;font-weight:600}

/* ===== UX-Notizen (ein/aus) ===== */
.note{margin:10px 0 0;border-left:3px solid var(--note);background:var(--fill-2);color:var(--note);
  font-size:12px;line-height:1.5;padding:8px 11px;border-radius:0 6px 6px 0;font-style:italic}
.note--block{margin:0 16px 4px}
.note::before{content:"UX · ";font-style:normal;font-weight:700}
body:not(.show-notes) .note{display:none}
