/* =========================================================
   Multibrokerage — UX-Wireframe (App & Web teilen sich alles)
   Low-Fi, graustufig. Bedeutung über Form/Label/Position,
   nicht über Farbe (A11y). Hi-Fi-Mapping: Verkaufen=rot, Kaufen=grün.
   ========================================================= */

:root{
  --tool-bg:#17171a; --tool-fg:#e9e9ec; --tool-mut:#8e8e93; --tool-line:#2c2c2e; --accent:#a78bfa;
  --paper:#ffffff; --ink:#141416; --mut:#6b6b70; --line:#d3d3d8; --line-2:#e6e6ea;
  --fill:#1f1f22; --soft:#f3f3f5; --soft-2:#eaeaee; --radius:14px; --pill:999px;
}

*{box-sizing:border-box}
body{margin:0;font-family:ui-sans-serif,system-ui,"Segoe UI",Roboto,sans-serif;background:#0e0e10;color:var(--ink)}

/* ---------- Tool-Chrome ---------- */
.toolbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  background:var(--tool-bg);color:var(--tool-fg);padding:10px 16px;border-bottom:1px solid var(--tool-line)}
.toolbar__brand{font-size:13px;font-weight:700;letter-spacing:.2px}
.toolbar__brand em{color:var(--tool-mut);font-style:normal;font-weight:500}
.toolbar__spacer{flex:1}
.toolbar__group{display:flex;align-items:center;gap:6px}
.toolbar__label{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--tool-mut);margin-right:2px}
.tg{appearance:none;border:1px solid #3a3a3d;background:#222226;color:var(--tool-fg);font-size:12px;
  padding:6px 10px;border-radius:var(--pill);cursor:pointer;line-height:1}
.tg:hover{border-color:var(--accent)}
.tg.is-active{background:var(--accent);border-color:var(--accent);color:#15101f;font-weight:700}
body.auth-in #variant-switch{opacity:.35;pointer-events:none}   /* Varianten nur ausgeloggt relevant */

/* ---------- Bühne & Frame ---------- */
.stage{position:relative;display:flex;justify-content:center;padding:28px 16px 80px;min-height:calc(100vh - 49px)}
.frame{position:relative;background:var(--paper);color:var(--ink);overflow:hidden}
body.mode-app .frame{width:390px;border-radius:30px;border:10px solid #111;min-height:760px;box-shadow:0 18px 60px rgba(0,0,0,.5)}
body.mode-web .frame{width:min(1100px,96vw);border-radius:12px;border:1px solid #2c2c2e;min-height:640px;box-shadow:0 18px 60px rgba(0,0,0,.4)}

/* ---------- generische Bausteine ---------- */
.muted{color:var(--mut)}
.row{display:flex;align-items:center;gap:8px}
.spread{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ico{appearance:none;border:1px solid var(--line);background:var(--paper);color:var(--ink);border-radius:var(--pill);
  font-size:13px;padding:6px 10px;cursor:pointer;line-height:1}
.ico:hover{border-color:var(--ink)}
.ico--primary{background:var(--fill);color:#fff;border-color:var(--fill)}
.chip{appearance:none;border:1px solid var(--line);background:var(--paper);color:var(--ink);border-radius:var(--pill);
  font-size:13px;padding:6px 12px;cursor:pointer}
.chip.is-active{background:var(--fill);color:#fff;border-color:var(--fill)}
.tag{display:inline-block;border:1px solid var(--line);border-radius:6px;font-size:11px;padding:1px 6px;color:var(--mut)}

/* ---------- UX-Notizen ---------- */
.note{font-size:12px;color:#4a4a50;background:var(--soft);border-left:3px solid var(--ink);
  padding:8px 10px;border-radius:0 8px 8px 0;line-height:1.45}
.note b{color:var(--ink)}
.note--block{margin:10px 14px}
body:not(.show-notes) .note{display:none}

/* =========================================================
   SNAPSHOT
   ========================================================= */
.snap{padding:0}
.appbar{display:flex;align-items:center;gap:8px;padding:14px 14px 8px}
.appbar__title{font-size:17px;font-weight:700;flex:1;text-align:center;margin:0}
.appbar__actions{display:flex;gap:6px}
.snap__tabs{display:flex;gap:8px;overflow-x:auto;padding:4px 14px 10px}
.snap__tabs .chip{white-space:nowrap}
.instr{padding:6px 14px 0;display:flex;align-items:center;gap:10px}
.instr__logo{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);display:grid;place-items:center;font-size:13px;color:var(--mut)}
.instr__name{font-size:18px;font-weight:700;line-height:1.1}
.instr__sub{font-size:12px;color:var(--mut)}
.price{padding:12px 14px 4px;display:flex;align-items:baseline;gap:10px}
.price__big{font-size:26px;font-weight:700}
.price__chg{font-size:13px;border:1px solid var(--line);border-radius:8px;padding:2px 8px;color:var(--mut)}
.chart{margin:8px 14px;height:150px;border:1px dashed var(--line);border-radius:10px;position:relative;background:
  repeating-linear-gradient(0deg,transparent,transparent 28px,var(--line-2) 28px,var(--line-2) 29px)}
.chart svg{position:absolute;inset:0;width:100%;height:100%}
.chart__wm{position:absolute;left:10px;top:8px;font-size:11px;color:#c2c2c8}
.ranges{display:flex;gap:6px;padding:2px 14px 10px;flex-wrap:wrap}
.ranges .chip{padding:5px 10px;font-size:12px}

/* --- Snapshot V/K Split-Button (Herzstück Surface 1) --- */
.vk-split{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 14px 4px}
.vk-split .vk{appearance:none;cursor:pointer;border-radius:10px;padding:12px 10px;text-align:center;line-height:1.2}
.vk-split .vk__price{font-size:15px;font-weight:700;display:block}
.vk-split .vk__act{font-size:12px;color:var(--mut);display:block;margin-top:2px}
.vk-sell{background:var(--paper);border:1.5px solid var(--ink)}                 /* Verkaufen = Outline (links) */
.vk-buy{background:var(--fill);border:1.5px solid var(--fill);color:#fff}        /* Kaufen = Fill (rechts) */
.vk-buy .vk__act{color:#cfcfd6}
.vk-hint{margin:4px 14px 12px}

.handelsdaten{margin:14px;padding:14px;border:1px dashed var(--line);border-radius:10px;color:var(--mut);font-size:13px}

/* App-Tabbar */
.tabbar{position:sticky;bottom:0;display:flex;justify-content:space-around;align-items:center;gap:4px;
  padding:8px 6px;border-top:1px solid var(--line);background:var(--paper)}
.tabbar .tab{font-size:11px;color:var(--mut);display:flex;flex-direction:column;align-items:center;gap:3px}
.tabbar .tab.is-active{color:var(--ink);font-weight:700}
.tabbar .tab .dot{width:20px;height:20px;border:1px solid var(--line);border-radius:6px}
body.mode-web .tabbar{display:none}

/* ---------- Web-Snapshot (onvista-Desktop-Layout, nachmodelliert) ---------- */
.ovbar{display:flex;align-items:center;gap:16px;padding:12px 18px;background:var(--paper);border-bottom:1px solid var(--line)}
.ovbar__logo{font-weight:800;font-size:20px;letter-spacing:-.3px;color:#7a5cd0}   /* Brand-Mark (einzige Farbe) */
.ovbar__nav{flex:1;display:flex;gap:12px;align-items:center;justify-content:center;font-size:14px}
.ovbar__pill{border:1px solid var(--line);border-radius:var(--pill);padding:8px 18px;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.ovbar__search{border:1px solid var(--line);border-radius:var(--pill);padding:7px 16px;color:var(--mut)}
.ovbar__user{width:30px;height:30px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--mut)}

.websnap{background:var(--soft);padding:18px;min-height:560px}
.crumb{font-size:12px;color:var(--mut);margin-bottom:14px}
.card{background:var(--paper);border:1px solid var(--line-2);border-radius:14px;padding:18px;margin-bottom:16px}
.ihead__row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin:4px 0 6px}
.ihead__title{font-size:28px;font-weight:800;display:flex;align-items:center;gap:12px}
.ihead__logo{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);display:grid;place-items:center;font-size:14px;color:var(--mut)}
.ihead__cta{display:flex;gap:8px;align-items:center;flex-shrink:0}
.ihead__ids{margin-bottom:8px}
.btnp{appearance:none;border:1px solid var(--ink);background:var(--paper);color:var(--ink);border-radius:var(--pill);padding:9px 18px;font-size:13px;font-weight:600;cursor:pointer}
.btnp--fill{background:var(--fill);color:#fff;border-color:var(--fill)}
.btnp--sm{padding:5px 12px;font-size:12px;border-color:var(--line);font-weight:500;color:var(--mut)}
.pricegrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:20px;padding:16px 0;border-top:1px solid var(--line-2)}
.up{font-size:14px;color:var(--mut);font-weight:600}            /* grau statt grün (A11y/Low-Fi) */
.gb__item{margin-bottom:14px}
.gb__cta{display:flex;align-items:center;gap:8px;margin-top:4px}
.vk-quote{appearance:none;cursor:pointer;border-radius:8px;padding:7px 12px;font-size:13px;line-height:1.1;white-space:nowrap}
.vk-quote b{font-weight:700}
.vk-quote--sell{background:var(--paper);border:1.5px solid var(--ink);color:var(--ink)}     /* Geld = Verkaufen (Outline) */
.vk-quote--buy{background:var(--fill);border:1.5px solid var(--fill);color:#fff}             /* Brief = Kaufen (Fill) */
.stats .spread{padding:5px 0;font-size:14px}
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;padding-top:16px;border-top:1px solid var(--line-2);font-size:15px;font-weight:700}
.small{font-size:12px}
.promo{background:var(--soft-2);border-radius:12px;padding:13px 18px;font-size:13px;margin-bottom:16px}
.promo a{text-decoration:underline;color:#7a5cd0;cursor:pointer}
.tabsnav{display:flex;gap:14px;overflow-x:auto;border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:16px;font-size:14px;color:var(--mut);white-space:nowrap}
.tabsnav .is-active{color:var(--ink);font-weight:700;background:var(--soft-2);border-radius:var(--pill);padding:4px 14px}
.cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.col__h{font-size:24px;font-weight:800;margin:0 0 12px}
.chart--web{height:240px;margin:0}
.chart__lo{position:absolute;left:10px;bottom:8px;font-size:11px;color:#c2c2c8}
.newslist{padding:4px 18px}
.news{padding:14px 0;border-bottom:1px solid var(--line-2)}
.news:last-child{border-bottom:0}
.news__t{font-weight:700;font-size:14px;margin-bottom:4px;line-height:1.35}
.websnap .vk-split{margin:0 0 4px}
.websnap .vk-hint{margin:4px 0 0}

/* =========================================================
   MUSTERDEPOT
   ========================================================= */
.md__head{display:flex;align-items:center;gap:8px;padding:14px 14px 6px}
.md__title{font-size:17px;font-weight:700;flex:1;text-align:center;margin:0}
.md__tabs{display:flex;gap:8px;overflow-x:auto;padding:4px 14px 10px}
.md__tabs .chip{white-space:nowrap}

/* App: Position-Cards */
.poscard{margin:8px 14px;border:1px solid var(--line);border-radius:var(--radius);padding:12px}
.poscard__top{display:flex;align-items:center;gap:8px}
.poscard__name{font-size:16px;font-weight:700}
.poscard__sub{font-size:12px;color:var(--mut)}
.poscard__grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px;margin-top:10px;font-size:13px}
.poscard__grid .lbl{color:var(--mut);font-size:11px}
.poscard__grid .r{text-align:right}

/* ---------- Surface 3: Profil (Broker-Verwaltung) ---------- */
.pf{padding:0 0 16px}
body.mode-web .pf{max-width:640px;margin:0 auto;padding-top:8px}
.pf-head{display:flex;align-items:center;gap:12px;padding:18px 16px;border-bottom:1px solid var(--line-2)}
.pf-avatar{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;font-size:18px;color:var(--mut);flex-shrink:0}
.pf-email{font-weight:700;font-size:15px;word-break:break-all}
.pf-menu{padding:6px 0;border-bottom:1px solid var(--line-2)}
.pf-link{padding:11px 16px;font-weight:600;cursor:pointer;color:#3a2f5e}
.pf-link:hover{background:var(--soft)}
.pf-link--sep{border-top:1px solid var(--line-2);color:var(--mut);font-weight:500}
.pf-h{font-size:18px;font-weight:800;margin:18px 16px 4px}
.pf-default{margin:6px 16px 12px;font-size:13px;border:1px solid var(--line);border-radius:10px;padding:10px 12px}
.pf-default.is-empty{color:var(--mut);border-style:dashed}
.pf-brokers{padding:0 16px}
.pf-broker{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:10px}
.pf-broker.is-connected{border-color:var(--ink)}
.pf-broker__main{flex:1;min-width:0}
.pf-broker__actions{display:flex;gap:8px;flex-shrink:0}
.pf-badge{font-size:10px;border:1px solid var(--ink);border-radius:6px;padding:1px 6px;font-weight:700;white-space:nowrap}
.ovbar__user{appearance:none;background:var(--paper);cursor:pointer}
.ovbar__user:hover{border-color:var(--ink)}

/* Musterdepot Login-Schranke (ausgeloggt) */
.md-gate{padding:36px 24px 48px;text-align:center;max-width:440px;margin:0 auto}
.md-gate .gate-ico{width:56px;height:56px;border:2px solid var(--ink);border-radius:14px;margin:6px auto 14px;display:grid;place-items:center;font-size:22px}
.md-gate__h{font-size:18px;font-weight:700;margin-bottom:6px}
.md-gate .btnp{margin-top:16px}
.md-gate__note{text-align:left;margin-top:24px}

/* V|K Micro-Toggle (Surface 2) */
.vk-mini{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.vk-mini button{appearance:none;border:0;background:var(--paper);color:var(--ink);width:26px;height:24px;
  font-size:12px;font-weight:700;cursor:pointer;line-height:1}
.vk-mini .mini-sell{border-right:1px solid var(--line)}              /* V = Verkaufen (links, outline-Stil) */
.vk-mini .mini-buy{background:var(--fill);color:#fff}                /* K = Kaufen  (rechts, fill) */
.vk-mini button:disabled{opacity:.3;cursor:not-allowed}

/* Web: Tabelle */
.md-table-wrap{overflow-x:auto}
.md-table{width:100%;min-width:760px;border-collapse:collapse;font-size:13px}
body.mode-app .md-table-wrap{display:none}     /* Tabelle nur Web */
body.mode-web .poscard{display:none}            /* Cards nur App */
body.mode-web .md__head{justify-content:flex-start}
.md-table th{font-size:11px;color:var(--mut);text-align:right;font-weight:600;padding:10px 12px;border-bottom:1px solid var(--line)}
.md-table th:first-child,.md-table td:first-child{text-align:left}
.md-table td{padding:12px;border-bottom:1px solid var(--line-2);vertical-align:top}
.md-table .nm{font-weight:700;color:#3a2f5e}
.md-table .sub{font-size:11px;color:var(--mut);font-weight:400}
.md-table .price-cell{display:flex;align-items:center;gap:10px;justify-content:flex-end}
.md-foot td{font-weight:700;background:var(--soft)}
.md-foot--first td{border-top:2px solid var(--line)}
.sig{font-size:11px;filter:grayscale(1);opacity:.7}
.minichart{width:46px;height:18px;border-bottom:1px solid var(--line)}

/* ---------- Erweiterte Snapshot-Sektionen (optional) ---------- */
.ext-sections{margin-top:22px}
.ext-sections .col__h{margin:20px 0 12px}
.ks-table{width:100%;border-collapse:collapse;font-size:13px;min-width:720px}
.ks-table th{font-size:11px;color:var(--mut);text-align:left;font-weight:600;padding:12px;border-bottom:1px solid var(--line)}
.ks-table th.r,.ks-table td.r{text-align:right}
.ks-table td{padding:12px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.ks-table tbody tr:last-child td{border-bottom:0}
.ks-ko{display:flex;align-items:center;gap:8px}
.ko-filter{display:flex;gap:8px;justify-content:center;margin-bottom:16px;flex-wrap:wrap}
.lk{color:#3a2f5e}
.dv-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}
.dv-card{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:12px}
.dv-card__top{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.dv-card__type{font-weight:700;color:#3a2f5e;line-height:1.25}
.dv-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;font-size:13px}
.dv-grid .r{text-align:right}
.dv-card__cta{display:flex;justify-content:flex-end}

/* ---------- Surface 4: Derivate-Finder ---------- */
.finder{padding:0 0 16px}
body.mode-web .finder{background:var(--soft)}
.finder__top{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:#f3effb}
.finder__title{font-size:22px;font-weight:800;color:#7a5cd0;margin:0}
.finder__filters{padding:14px 18px;background:var(--paper);border-bottom:1px solid var(--line-2)}
.finder__row1{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.finder__row2{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dropdown{appearance:none;border:1px solid var(--line);background:var(--soft);border-radius:var(--pill);padding:9px 16px;font-size:13px;font-weight:700;cursor:pointer}
.dropdown--sm{font-weight:500;background:var(--paper)}
.basiswert{display:flex;align-items:center;gap:8px;font-size:14px}
.basiswert__chip{border:1px solid var(--line);border-radius:var(--pill);padding:6px 14px;background:var(--paper);font-weight:700}
.radio{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;margin-right:8px}
.finder__count{padding:14px 18px;font-size:15px}
.finder__count u{cursor:pointer}
.finder__toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 18px 12px;gap:12px;flex-wrap:wrap}
.finder-wrap{padding:0 18px;overflow-x:auto}
.finder-table{min-width:940px}
/* App-Finder: kompakte Cards mit großen V/K-Buttons (kein Horizontal-Scroll) */
.finder-cards{padding:4px 0 8px}
.fcard{margin:8px 14px;border:1px solid var(--line);border-radius:var(--radius);padding:12px}
.fcard__top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:10px}
.fcard__wkn{font-size:16px;font-weight:700}
.fcard__grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;font-size:13px;margin-bottom:12px}
.fcard__grid .r{text-align:right}
.fcard__grid .muted{font-size:11px}
.fcard .vk-split{margin:0}

/* =========================================================
   FUNNEL-OVERLAYS (Connect / Order / Gate / Confirm)
   ========================================================= */
.overlay{position:fixed;inset:0;z-index:50;background:rgba(20,20,22,.45);
  display:none;align-items:center;justify-content:center;padding:20px}
.overlay:not([hidden]){display:flex}     /* fixed → immer im sichtbaren Bereich zentriert, über der Toolbar */
.sheet{background:var(--paper);color:var(--ink);width:min(520px,94%);max-height:86%;overflow:auto;
  display:flex;flex-direction:column;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
body.mode-app .sheet{width:min(390px,94%)}     /* App schmaler (phone-nah), Web breiter */
.sheet__top{position:sticky;top:0;background:var(--paper);display:flex;align-items:center;gap:8px;
  padding:14px 16px;border-bottom:1px solid var(--line-2);z-index:1}
.sheet__title{font-size:16px;font-weight:700;flex:1}
.sheet__body{padding:16px}
.sheet__foot{position:sticky;bottom:0;background:var(--paper);border-top:1px solid var(--line-2);padding:14px 16px;display:flex;gap:10px}
.btn{appearance:none;cursor:pointer;border-radius:10px;padding:12px 14px;font-size:14px;font-weight:700;border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);flex:1;text-align:center}
.btn--primary{background:var(--fill);color:#fff;border-color:var(--fill)}
.btn--ghost{flex:0 0 auto;font-weight:500;border-color:var(--line);color:var(--mut)}
.btn:disabled{opacity:.4;cursor:not-allowed}

/* Stepper (Funnel-Fortschritt) */
.steps{display:flex;gap:6px;align-items:center;font-size:11px;color:var(--mut);padding:0 16px 6px;flex-wrap:wrap}
.steps .s{border:1px solid var(--line);border-radius:var(--pill);padding:2px 8px}
.steps .s.is-on{background:var(--fill);color:#fff;border-color:var(--fill)}
.steps .s.is-done{border-color:var(--ink);color:var(--ink)}

/* Formularteile (Order-Ticket) */
.fld{margin-bottom:14px}
.fld>label{display:block;font-size:12px;color:var(--mut);margin-bottom:5px}
.fld input,.fld select{width:100%;font-size:14px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink)}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.seg button{appearance:none;border:0;background:var(--paper);color:var(--ink);padding:8px 14px;font-size:13px;cursor:pointer;border-right:1px solid var(--line)}
.seg button:last-child{border-right:0}
.seg button.is-active{background:var(--fill);color:#fff}
.seg--brokers{display:flex;flex-wrap:wrap}
.seg--brokers button{flex:1 1 auto}
.broker-single{padding:11px 12px;border:1px solid var(--line);border-radius:8px;font-weight:600;background:var(--soft)}
.kv2{display:flex;justify-content:space-between;font-size:13px;padding:6px 0;border-bottom:1px solid var(--line-2)}
.kv2 b{font-weight:700}
.preview{border:1px solid var(--line);border-radius:10px;padding:6px 12px;margin:10px 0}
.disclaimer{font-size:11px;color:var(--mut);background:var(--soft);border-radius:8px;padding:10px;margin-top:10px;line-height:1.45}
.badge-dir{border:1px solid var(--ink);border-radius:6px;font-size:12px;font-weight:700;padding:2px 8px}
.placeholder-flag{font-size:11px;color:#7a5cd0;border:1px dashed #b7a3ee;background:#f6f2ff;border-radius:8px;padding:8px 10px;margin-bottom:12px;line-height:1.4}

/* Broker-Liste */
.broker{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:10px;cursor:pointer}
.broker:hover{border-color:var(--ink)}
.broker.is-connected{border-color:var(--ink)}
.broker__logo{width:34px;height:34px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;font-size:11px;color:var(--mut)}
.broker__name{font-weight:700;font-size:14px}
.broker__state{font-size:12px;color:var(--mut)}
.broker__pick{margin-left:auto;font-size:12px;border:1px solid var(--line);border-radius:var(--pill);padding:4px 10px}

/* Gate (Registrierung) */
.gate-box{text-align:center;padding:8px 4px}
.gate-box .gate-ico{width:56px;height:56px;border:2px solid var(--ink);border-radius:14px;margin:6px auto 12px;display:grid;place-items:center;font-size:22px}
.gate-fields{margin-top:14px;text-align:left}

/* Confirm */
.confirm{text-align:center;padding:10px 4px}
.confirm .check{width:60px;height:60px;border:2px solid var(--ink);border-radius:50%;margin:6px auto 14px;display:grid;place-items:center;font-size:26px}
.confirm__ref{font-size:13px;color:var(--mut);margin-top:6px}

/* =========================================================
   EVENT-LOG
   ========================================================= */
.eventlog{position:fixed;right:14px;bottom:14px;z-index:40;width:320px;max-height:48vh;display:flex;flex-direction:column;
  background:#17171a;color:#e9e9ec;border:1px solid #2c2c2e;border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.eventlog[hidden]{display:none}     /* WICHTIG: [hidden] muss display:flex schlagen (sonst nicht abschaltbar) */
.eventlog__head{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid #2c2c2e;font-size:13px}
.eventlog__sub{color:#8e8e93;font-size:11px;flex:1}
.eventlog__head .ico{background:#222226;color:#e9e9ec;border-color:#3a3a3d;font-size:11px;padding:4px 8px}
.eventlog__list{list-style:none;margin:0;padding:8px 10px;overflow:auto;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px}
.eventlog__list li{padding:5px 0;border-bottom:1px dashed #2c2c2e;line-height:1.4}
.eventlog__list .et{color:#a78bfa;font-weight:700}
.eventlog__list .ep{color:#8e8e93}
.eventlog__empty{color:#6b6b70;font-style:italic}
