:root{
  --bg:#0b0f17; --bg2:#121826; --card:#151c2c; --line:#222c40;
  --txt:#e6ebf5; --muted:#8b97ad; --accent:#4c8dff; --accent2:#22c55e;
  --red:#ef4444; --green:#22c55e; --amber:#f59e0b; --radius:12px;
}
*{box-sizing:border-box}
/* hidden muss IMMER gewinnen — sonst überschreiben display:grid/flex-Klassen
   (z. B. .boot, .layout) das hidden-Attribut und der Overlay blockiert Klicks. */
[hidden]{display:none !important}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--txt); font-size:14px; line-height:1.5;
}
h1{font-size:22px;margin:0 0 4px} h3{font-size:14px;margin:0 0 10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.muted{color:var(--muted)} a{color:inherit;cursor:pointer}
.boot{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted)}

/* Layout */
.layout{display:grid;grid-template-columns:240px 1fr;height:100vh}
.sidebar{background:var(--bg2);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px}
.brand{font-weight:700;font-size:16px;margin-bottom:22px;display:flex;gap:8px;align-items:center}
.nav{display:flex;flex-direction:column;gap:4px;flex:1}
.nav-item{padding:10px 12px;border-radius:8px;color:var(--muted);font-weight:500}
.nav-item:hover{background:var(--card);color:var(--txt)}
.nav-item.active{background:var(--accent);color:#fff}
.sidebar-foot{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--line);padding-top:12px}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--muted);padding:7px;border-radius:8px;cursor:pointer}
.btn-ghost:hover{color:var(--txt);border-color:var(--accent)}

.main{display:flex;flex-direction:column;overflow:hidden}
.topbar{display:flex;align-items:center;gap:16px;padding:14px 22px;border-bottom:1px solid var(--line);background:var(--bg2)}
.search{position:relative;display:flex;gap:8px;flex:1;max-width:640px}
.search select,.search input{background:var(--card);border:1px solid var(--line);color:var(--txt);padding:9px 11px;border-radius:8px}
.search input{flex:1}
.search-results{position:absolute;top:44px;left:0;right:0;background:var(--card);border:1px solid var(--line);border-radius:8px;max-height:320px;overflow:auto;z-index:20}
.search-results .res{padding:10px 12px;border-bottom:1px solid var(--line);cursor:pointer}
.search-results .res:hover{background:var(--bg2)}
.current-instrument{font-weight:600;white-space:nowrap}

.content{padding:22px;overflow:auto}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:14px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-top:14px}
.chart-card{height:320px}
.chart-card canvas{width:100%!important;height:100%!important}

/* Watch cards */
.wcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .15s}
.wcard:hover{border-color:var(--accent)}
.wcard .sym{font-weight:700;font-size:16px} .wcard .typ{font-size:11px;color:var(--muted);text-transform:uppercase}
.wcard .px{font-size:22px;font-weight:700;margin-top:8px}
.up{color:var(--green)} .down{color:var(--red)} .flat{color:var(--amber)}

.explorer-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.quote-line{font-size:18px;font-weight:600;margin-top:4px}
.tf-switch{display:flex;gap:4px} .tf-switch button{background:var(--card);border:1px solid var(--line);color:var(--muted);padding:6px 12px;border-radius:7px;cursor:pointer}
.tf-switch button.active{background:var(--accent);color:#fff;border-color:var(--accent)}

.kv{display:grid;grid-template-columns:auto 1fr;gap:6px 14px}
.kv .k{color:var(--muted)} .kv .v{text-align:right;font-variant-numeric:tabular-nums}

.news-list .nitem{padding:12px 0;border-bottom:1px solid var(--line)}
.news-list .nitem a{font-weight:600} .news-list .meta{font-size:12px;color:var(--muted);margin-top:3px}
.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:12px;font-weight:600}
.badge.bull{background:rgba(34,197,94,.15);color:var(--green)}
.badge.bear{background:rgba(239,68,68,.15);color:var(--red)}
.badge.neutral{background:rgba(245,158,11,.15);color:var(--amber)}

/* Analyse-View */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:760px){.grid-2{grid-template-columns:1fr}}
.signal-badge{padding:10px 18px;border-radius:10px;font-weight:700;font-size:18px;white-space:nowrap}
.signal-badge.bull{background:rgba(34,197,94,.15);color:var(--green)}
.signal-badge.bear{background:rgba(239,68,68,.15);color:var(--red)}
.signal-badge.neutral{background:rgba(245,158,11,.15);color:var(--amber)}
.gauge{display:flex;height:26px;border-radius:8px;overflow:hidden;margin:6px 0 10px;background:var(--bg2)}
.gauge .seg{display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#06210f;min-width:0}
.gauge .seg.up{background:var(--green)} .gauge .seg.down{background:var(--red);color:#2a0a0a} .gauge .seg.flat{background:var(--amber);color:#241a04}
.frows{display:flex;flex-direction:column;gap:2px}
.frow{display:grid;grid-template-columns:12px 110px 1fr;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--line)}
.frow .dot{width:9px;height:9px;border-radius:50%} .frow .dot.up{background:var(--green)} .frow .dot.down{background:var(--red)} .frow .dot.flat{background:var(--amber)}
.frow .fname{color:var(--muted);font-size:13px} .frow .flabel{text-align:right;font-size:13px;font-weight:500}
.mtf{display:flex;flex-direction:column;gap:2px}
.mtf-h,.mtf-r{display:grid;grid-template-columns:50px 50px 40px 50px 1fr;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--line)}
.mtf-h{color:var(--muted);font-size:12px;text-transform:uppercase}
.mtf-r .badge{justify-self:end}
.prob-bars{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.prob{display:grid;grid-template-columns:60px 1fr 48px;align-items:center;gap:10px}
.prob .track{height:10px;background:var(--bg2);border-radius:99px;overflow:hidden}
.prob .fill{height:100%}

/* Login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:32px;width:320px;display:flex;flex-direction:column;gap:12px}
.login-logo{font-size:20px;font-weight:700;text-align:center}
.login-sub{text-align:center;color:var(--muted);margin:0 0 8px}
.login-card label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted)}
.login-card input{background:var(--bg2);border:1px solid var(--line);color:var(--txt);padding:10px;border-radius:8px}
.login-card button{background:var(--accent);color:#fff;border:none;padding:11px;border-radius:8px;cursor:pointer;font-weight:600;margin-top:6px}
.login-error{color:var(--red);font-size:13px;min-height:18px;text-align:center}

@media(max-width:820px){
  .layout{grid-template-columns:1fr}
  .sidebar{flex-direction:row;align-items:center;overflow-x:auto}
  .nav{flex-direction:row} .sidebar-foot{flex-direction:row;border:none;padding-top:0}
}
