/* ============================================================
   FOUR-TWO-NINE marktwatch — Stylesheet
   vierzwoneun|media · Christian Hebrock · Köln
   ============================================================

   FARBANPASSUNGEN:
   ──────────────────────────────────────────────────────────
   AKZENTFARBE:
   --accent       Buttons, aktive Navigation, Links         #4f46e5

   TEXFARBEN:
   --text         Haupttext (dunkel auf hell)               #0f172a
   --text2        Sekundärtext                              #334155
   --text3        Labels, Metadaten                         #64748b

   HINTERGRÜNDE:
   --surface      Seitenhintergrund                         #f8fafc
   --card         Karten                                    #ffffff
   --paper2       Etwas dunkler                             #f1f5f9
   --paper3       Helle Karten-Flächen                      #e8edf2

   STATUSFARBEN:
   --green        Kaufen, Gewinn                            #059669
   --red          Verkaufen, Verlust                        #dc2626
   --amber        Halten, Vorsicht                          #d97706

   SIDEBAR:
   --ink          Sidebar-Hintergrund                       #0f172a

   SCHRIFTEN:
   Headlines      Plus Jakarta Sans (700/800)
   Body           Inter (400/500/600)
   Zahlen/Mono    JetBrains Mono (400/500)

   SCHRIFTGROSSEN:
   1em            Fließtext (=14px Basis)
   0.8em          Labels, Metadaten, kleine Texte
   ============================================================ */

@import url('https://fonts.bunny.net/css2?family=plus-jakarta-sans:wght@600;700;800&family=inter:wght@400;500;600&family=jetbrains-mono:wght@400;500&display=swap');

:root {
  /* Akzent */
  --accent:        #4f46e5;
  --accent-soft:   #eef2ff;
  --accent-mid:    #818cf8;
  --accent-dark:   #3730a3;

  /* Status */
  --green:         #059669;
  --green-soft:    #d1fae5;
  --green-bg:      rgba(5,150,105,.07);
  --green-bright:  #10b981;
  --red:           #dc2626;
  --red-soft:      #fee2e2;
  --red-bg:        rgba(220,38,38,.07);
  --amber:         #d97706;
  --amber-soft:    #fef3c7;
  --amber-bg:      rgba(217,119,6,.08);
  --blue:          #2563eb;
  --blue-bg:       rgba(37,99,235,.07);

  /* Gold (für Edelmetalle) */
  --gold:          #d97706;
  --gold2:         #b45309;
  --gold-dim:      rgba(217,119,6,.1);
  --gold-glow:     rgba(217,119,6,.2);

  /* Texte */
  --text:          #0f172a;
  --text2:         #334155;
  --text3:         #64748b;
  --text-dark:     #f1f5f9;
  --text2-dark:    rgba(241,245,249,.75);
  --text3-dark:    rgba(241,245,249,.45);

  /* Hintergründe */
  --ink:           #0f172a;
  --ink2:          #1e293b;
  --surface:       #f8fafc;
  --paper:         #f8fafc;
  --paper2:        #f1f5f9;
  --paper3:        #e8edf2;
  --card:          #ffffff;

  /* Rahmen */
  --border:        #e2e8f0;
  --border2:       #cbd5e1;
  --muted:         #64748b;
  --subtle:        #94a3b8;

  /* Schatten */
  --shadow:        0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.04);
  --shadow-lg:     0 4px 24px rgba(0,0,0,.08);

  /* Schriften */
  --sans:          'Inter', system-ui, sans-serif;
  --mono:          'JetBrains Mono', monospace;
  --serif:         'Plus Jakarta Sans', sans-serif;
  --display:       'Plus Jakarta Sans', sans-serif;

  /* Radien */
  --r:             12px;
  --r-sm:          8px;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 14px; }
body { font-family: var(--sans); background: var(--surface); color: var(--text); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
button { font-family: var(--sans); cursor: pointer; }
input, select, textarea { font-family: var(--sans); }

/* ── APP LAYOUT ── */
.app { display: grid; grid-template-columns: 256px 1fr; min-height: 100vh; }

/* ── SIDEBAR ── */
.sidebar {
  background: var(--ink);
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh;
  overflow-y: auto; border-right: none;
}
.sidebar::-webkit-scrollbar { width: 0; }

.brand { padding: 20px 18px 16px; border-bottom: 1px solid rgba(255,255,255,.06); }
.brand-name {
  font-family: var(--display); font-size: 1.2em; font-weight: 800;
  color: #fff; letter-spacing: .5px;
  display: flex; align-items: center; gap: 10px;
}
.brand-name::before {
  content: '';
  width: 26px; height: 26px; border-radius: 6px;
  background: var(--accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='22 7 13.5 15.5 8.5 10.5 2 17'/%3E%3Cpolyline points='16 7 22 7 22 13'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center;
  flex-shrink: 0;
}
.brand-sub { font-size: 1em; color: #f1f5f9; margin-top: 3px; padding-left: 36px; }
.brand-live { font-size: 1em; color: #64748b; margin-top: 2px; padding-left: 36px; display: flex; align-items: center; gap: 5px; }

.live-dot { width: 6px; height: 6px; border-radius: 50%; background: #10b981; animation: blink 2s ease-in-out infinite; flex-shrink: 0; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.nav { padding: 10px 0; flex: 1; }
.nav-sec { font-size: 1.2em; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: #fff; padding: 14px 18px 5px; }
.nav-item {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 18px; font-size: 1em; font-weight: 500;
  color: rgba(255,255,255,.45); cursor: pointer;
  border-left: 2px solid transparent;
  transition: all .15s; user-select: none;
}
.nav-item:hover { color: rgba(255,255,255,.8); background: rgba(255,255,255,.05); }
.nav-item.active { color: #fff; border-left-color: var(--accent-mid); background: rgba(99,102,241,.15); }
.nav-ico { font-size: 0.8em; opacity: .5; flex-shrink: 0; }
.nav-item.active .nav-ico { opacity: 1; }
.npill { font-size: 0.8em; font-weight: 700; padding: 1px 6px; border-radius: 4px; margin-left: auto; }
.np-g { background: rgba(16,185,129,.2); color: #6ee7b7; }
.np-r { background: rgba(239,68,68,.2); color: #fca5a5; }
.np-b { background: rgba(99,102,241,.2); color: #a5b4fc; }

.sidebar-foot { padding: 14px 18px; border-top: 1px solid rgba(255,255,255,.06); font-size: 0.8em; color: rgba(255,255,255,.18); line-height: 1.6; margin-top: auto; }
.sidebar-overlay { display: none; }

/* ── TOPBAR ── */
.topbar {
  background: var(--card); border-bottom: 1px solid var(--border);
  padding: .55rem 1.75rem; display: flex; align-items: center; gap: 1.25rem;
  overflow-x: auto; white-space: nowrap;
  position: sticky; top: 0; z-index: 100;
}
.topbar::-webkit-scrollbar { height: 0; }
.live-badge { font-size: 1em; font-weight: 700; padding: 2px 7px; border-radius: 4px; background: rgba(16,185,129,.12); color: var(--green); letter-spacing: 1px; flex-shrink: 0; }
.tick { display: flex; align-items: center; gap: 5px; font-size: 1em; font-family: var(--display);}
.t-lbl { color: #64748b; font-weight: bold; }
.t-val { color: var(--text); font-weight: 500; }
.t-chg { font-weight: 600; }
.up { color: var(--green); }
.tdn { color: var(--red); }
.mc { display: flex; align-items: center; gap: 8px; margin-left: auto; flex-shrink: 0; }
.mc-label { font-size: 0.8em; color: var(--text3); }
.mc-val { font-size: 0.8em; font-weight: 700; font-family: var(--mono); }
.mc-sub { font-size: 0.8em; color: var(--text3); }
.fg-label { font-size: 0.8em; color: var(--text3); }
.fg-num { font-family: var(--mono); font-weight: 700; color: var(--text); }

/* ── DISCLAIMER BAR ── */
.disclaimer-bar {
  background: #fffbeb; border-bottom: 1px solid #fde68a;
  padding: .4rem 1.75rem; font-size: 1em; color: #92400e; text-align: center;
}
.disclaimer-bar a { color: var(--accent); font-weight: 500; }

/* ── CONTENT ── */
.content { padding: 1.75rem 2rem; min-width: 0; max-width: 100%; background: var(--surface); }

/* ── PAGES ── */
.page { display: none; }
.page.active { display: block; }

.pg-head { font-size: 1em;margin-bottom: 1.5rem; }
.pg-title {
  font-family: var(--display); font-size: 2.5em; font-weight: 800;
  color: var(--text); letter-spacing: -.3px; line-height: 1.1;
}
.pg-sub { font-size: 1em; color: var(--text3); margin-top: .3rem; }

/* ── SOURCE BAR ── */
.source-bar { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; margin-bottom: 1.25rem; }
.src-label { font-size: 0.8em; color: var(--text3); }
.src-chip { font-size: 0.8em; padding: 2px 9px; border-radius: 20px; border: 1px solid var(--border); color: var(--text3); background: var(--card); }
.src-chip.live { border-color: rgba(5,150,105,.25); color: var(--green); background: var(--green-soft); }
.src-chip.delay { border-color: rgba(217,119,6,.25); color: var(--amber); background: var(--amber-soft); }
.src-chip a { color: inherit; }

/* ── SCORING WRAP ── */
.scoring-wrap {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 1.5rem;
  margin-bottom: 1.25rem; box-shadow: var(--shadow);
}
.scoring-header { display: flex; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; gap: 1rem; margin-bottom: 1.25rem; }
.scoring-title { font-family: var(--display); font-size: 1.5em; font-weight: 800; letter-spacing: .3px; color: var(--text); }
.scoring-sub { font-size: 1em; color: var(--text3); margin-top: .25rem; }
.scoring-mode { display: flex; gap: 5px; flex-wrap: wrap; }
.mode-btn { font-size: 0.8em; font-weight: 600; padding: 5px 12px; border-radius: 6px; border: 1px solid var(--border); background: var(--surface); color: var(--text2); transition: all .15s; }
.mode-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.mode-btn:hover:not(.active) { border-color: var(--accent); color: var(--accent); }
.scoring-input-row { display: flex; gap: .75rem; flex-wrap: wrap; align-items: flex-end; margin-bottom: 1rem; }
.score-input { padding: 9px 13px; font-size: 1em; font-family: var(--sans); border: 1.5px solid var(--border); border-radius: 8px; background: var(--card); color: var(--text); outline: none; transition: border-color .15s; flex: 1; min-width: 200px; }
.score-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(99,102,241,.1); }
.score-btn { font-size: 1em; font-weight: 600; padding: 9px 22px; background: var(--accent); color: #fff; border: none; border-radius: 8px; transition: all .15s; white-space: nowrap; }
.score-btn:hover { background: #4338ca; transform: translateY(-1px); }
.score-btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }
.btn { font-size: 0.8em; font-weight: 600; padding: 6px 13px; border-radius: 6px; border: 1px solid var(--border); background: var(--card); color: var(--text2); transition: all .15s; }
.btn:hover { border-color: var(--accent); color: var(--accent); }
.btn-gold { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn-gold:hover { background: #4338ca; }
.btn-sm { padding: 4px 10px; font-size: 0.8em; }

/* ── SCORE CIRCLE ── */
.score-circle-wrap { display: flex; align-items: center; gap: 1.25rem; margin-bottom: 1.25rem; }
.score-circle { width: 96px; height: 96px; border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; border: 3px solid var(--accent); background: var(--accent-soft); position: relative; flex-shrink: 0; }
.score-num { font-family: var(--display); font-size: 32px; font-weight: 800; color: var(--accent); line-height: 1; }
.score-max { font-size: 0.8em; color: var(--text3); }
.score-verdict { font-size: 0.8em; font-weight: 700; padding: 4px 12px; border-radius: 6px; letter-spacing: .3px; display: inline-block; margin-top: 6px; }
.score-mini { font-family: var(--display); font-size: 20px; font-weight: 800; color: var(--accent); }
.score-action { margin-top: .5rem; }

/* ── VERDICT BADGES ── */
.b-buy   { background: var(--green-soft); color: var(--green); border: 1px solid rgba(5,150,105,.25); }
.b-hold  { background: var(--amber-soft); color: var(--amber); border: 1px solid rgba(217,119,6,.25); }
.b-sell  { background: var(--red-soft);   color: var(--red);   border: 1px solid rgba(220,38,38,.25); }
.b-watch { background: var(--paper2);     color: var(--text3); border: 1px solid var(--border); }

/* ── SCORE GRID / FACTORS ── */
.score-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: 1rem; margin-bottom: 1.25rem; }
.score-factor { background: var(--paper2); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 1rem; }
.sf-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: .625rem; gap: 8px; }
.sf-label { font-size: 0.8em; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: .5px; line-height: 1.4; }
.sf-score { font-family: var(--mono); font-size: 1em; font-weight: 600; color: var(--text); white-space: nowrap; }
.sf-bar { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; margin-bottom: .625rem; }
.sf-fill { height: 100%; border-radius: 2px; }
.sf-text { font-size: 0.8em; color: var(--text2); line-height: 1.55; }
.score-bar { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; margin: .5rem 0; }
.score-fill { height: 100%; border-radius: 2px; background: var(--accent); }

/* ── SCORE DETAILS ── */
.score-details { padding: 1rem; background: var(--accent-soft); border: 1px solid #c7d2fe; border-radius: var(--r-sm); }
.sa-title { font-size: 0.8em; font-weight: 700; letter-spacing: .5px; color: var(--accent); text-transform: uppercase; margin-bottom: .5rem; }
.sa-text { font-size: 1em; color: var(--accent-dark); line-height: 1.7; }
.sa-buy { background: var(--green-soft); border-color: rgba(5,150,105,.25); }
.sa-buy .sa-title { color: var(--green); }
.sa-buy .sa-text { color: #065f46; }
.sa-hold { background: var(--amber-soft); border-color: rgba(217,119,6,.25); }
.sa-hold .sa-title { color: var(--amber); }
.sa-hold .sa-text { color: #78350f; }
.sa-sell { background: var(--red-soft); border-color: rgba(220,38,38,.2); }
.sa-sell .sa-title { color: var(--red); }
.sa-sell .sa-text { color: #7f1d1d; }
.sa-disclaimer { font-size: 0.8em; color: var(--text3); margin-top: .75rem; padding-top: .75rem; border-top: 1px solid var(--border); }

/* ── INFO BOX ── */
.info-box { background: var(--accent-soft); border: 1px solid #c7d2fe; border-radius: var(--r-sm); padding: .875rem 1.2rem; font-size: 0.8em; color: var(--accent-dark); line-height: 1.75; margin-bottom: 1rem; }

/* ── CARDS ── */
.card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; margin-bottom: 1.25rem; box-shadow: var(--shadow); }
.card-head { display: flex; align-items: center; justify-content: space-between; padding: .875rem 1.25rem; border-bottom: 1px solid var(--border); background: var(--paper2); }
.card-title { font-size: 1em; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--text2); }
.card-note { font-size: 0.8em; color: var(--text3); }

/* ── TABELLE ── */
table { width: 100%; border-collapse: collapse; font-size: 0.8em; }
th { text-align: left; padding: 10px 14px; font-size: 0.8em; font-weight: 600; color: var(--text3); border-bottom: 1px solid var(--border); background: var(--paper2); text-transform: uppercase; letter-spacing: .5px; }
td { padding: 12px 14px; border-bottom: 1px solid var(--border); color: var(--text); }
tr:last-child td { border-bottom: none; }
tbody tr:hover td { background: var(--paper2); }
.td-name { font-weight: 600; font-size: 1em; color: var(--text); }
.td-isin { font-size: 0.8em; color: var(--text3); font-family: var(--mono); margin-top: 2px; }
.td-mono { font-family: var(--mono); }

/* ── METRICS ── */
.metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap: 1rem; margin-bottom: 1.25rem; }
.mc { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 1rem; box-shadow: var(--shadow); }
.mc.g { border-top: 3px solid var(--green); }
.mc.a { border-top: 3px solid var(--amber); }
.mc.b { border-top: 3px solid var(--accent); }
.mc-label { font-size: 0.8em; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: .3px; margin-bottom: .375rem; }
.mc-val { font-family: var(--display); font-size: 24px; font-weight: 800; color: var(--text); line-height: 1; }
.mc-val.up { color: var(--green); }
.mc-val.gold { color: var(--gold); }
.mc-val.neu { color: var(--accent); }
.mc-sub { font-size: 0.8em; color: var(--text3); margin-top: .3rem; }
.mc-sub.up { color: var(--green); }
.mc-sub.dn { color: var(--red); }

/* ── BADGES ── */
.badge { font-size: 0.8em; font-weight: 700; padding: 2px 8px; border-radius: 4px; }
.bb-gold { background: var(--amber-soft); color: var(--amber); }

/* ── ALERTS ── */
.alert-list { padding: 0 1.25rem; }
.alert { display: grid; grid-template-columns: 38px 1fr; gap: 12px; align-items: flex-start; padding: 14px 0; border-bottom: 1px solid var(--border); }
.alert:last-child { border-bottom: none; }
.alert-ico { width: 36px; height: 36px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 1.1em; flex-shrink: 0; }
.a-buy  { background: var(--green-soft); color: var(--green); }
.a-sell { background: var(--red-soft);   color: var(--red); }
.a-warn { background: var(--amber-soft); color: var(--amber); }
.alert-title { font-size: 1em; font-weight: 600; color: var(--text); margin-bottom: 2px; }
.alert-title.g { color: var(--green); }
.alert-title.r { color: var(--red); }
.alert-title.a { color: var(--amber); }
.alert-desc { font-size: 0.8em; color: var(--text2); line-height: 1.55; }
.alert-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }
.alert-time { font-size: 0.8em; color: var(--text3); font-family: var(--mono); }
.alert-plain { font-size: 0.8em; color: var(--text2); }
.atag { font-size: 0.8em; font-weight: 600; padding: 2px 8px; border-radius: 4px; background: var(--paper2); border: 1px solid var(--border); color: var(--text2); }
.alert-body { margin-left: 50px; }

/* ── CHART ── */
.chart-box { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; margin-bottom: 1.25rem; box-shadow: var(--shadow); }
.chart-head { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .75rem; padding: 1rem 1.25rem; border-bottom: 1px solid var(--border); background: var(--paper2); }
.chart-title { font-family: var(--display); font-size: 1em; font-weight: 700; color: var(--text); }
.chart-ctrl { display: flex; gap: 4px; }
.chart-sel { font-size: 0.8em; font-family: var(--sans); padding: 5px 10px; border: 1px solid var(--border); border-radius: 6px; background: var(--card); color: var(--text); outline: none; }
.perbtn { font-size: 0.8em; font-weight: 500; padding: 5px 10px; border: 1px solid var(--border); border-radius: 6px; background: var(--card); color: var(--text2); }
.perbtn.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ── THINKING ── */
.thinking { display: none; align-items: center; gap: .75rem; padding: .875rem; white-space: nowrap; flex-wrap: nowrap; font-size: 0.8em; color: var(--text3); }
.thinking-dots { display: flex; gap: 4px; }
.thinking-dots span { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); animation: bounce 1.2s ease-in-out infinite; }
.thinking-dots span:nth-child(2) { animation-delay: .2s; }
.thinking-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes bounce { 0%,80%,100%{transform:scale(.6);opacity:.4} 40%{transform:scale(1);opacity:1} }

/* ── SENTIMENT ── */
.sent-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 1rem; margin-bottom: 1.25rem; }
.sent-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 1.25rem; box-shadow: var(--shadow); }
.sent-title { font-size: 0.8em; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--text3); margin-bottom: .75rem; }
.sm-ring { width: 56px; height: 56px; border-radius: 50%; border: 3px solid var(--accent); display: flex; align-items: center; justify-content: center; margin-bottom: .5rem; }
.sm-buy  { border-color: var(--green); }
.sm-hold { border-color: var(--amber); }
.sm-sell { border-color: var(--red); }
.sm-na   { border-color: var(--border); }

/* ── FG TRACK ── */
.fg-track { height: 8px; background: linear-gradient(to right, #dc2626, #d97706, #059669); border-radius: 4px; margin: .75rem 0; position: relative; }
.fg-thumb { width: 14px; height: 14px; background: var(--card); border: 2px solid var(--text); border-radius: 50%; position: absolute; top: -3px; transform: translateX(-50%); }

/* ── KS GRID ── */
.ks-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 1rem; margin-bottom: 1.25rem; }
.ks-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 1.25rem; box-shadow: var(--shadow); }
.ks-title { font-size: 0.8em; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--text3); margin-bottom: .5rem; }
.ks-divider { border: none; border-top: 1px solid var(--border); margin: .875rem 0; }
.ks-rule { font-size: 0.8em; color: var(--text2); margin-bottom: .375rem; display: flex; gap: .5rem; }
.ks-rule::before { content: '→'; color: var(--accent); flex-shrink: 0; }
.ks-sub { font-size: 0.8em; color: var(--text3); margin-top: .25rem; }

/* ── MACRO ── */
.mkt-txt {font-size: 1em; color: #fff; text-align: center; !important}
.mkt-row { display: flex; align-items: center; justify-content: space-between; padding: .625rem 0; border-bottom: 1px solid var(--border); }
.mkt-row:last-child { border-bottom: none; }
.mkt-d { font-size: 0.8em; font-weight: 700; font-family: var(--mono); }
.macro-row { display: flex; align-items: center; justify-content: space-between; padding: .5rem 0; border-bottom: 1px solid var(--border); }
.macro-row:last-child { border-bottom: none; }
.macro-label { font-size: 0.8em; color: var(--text2); }
.macro-val { font-size: 0.8em; font-family: var(--mono); font-weight: 600; color: var(--text); }

/* ── RSI BAR ── */
.rsibar { height: 8px; background: var(--border); border-radius: 4px; overflow: hidden; margin: .375rem 0; }
.rsifill { height: 100%; border-radius: 4px; background: var(--accent); }
.toggle { display: flex; gap: 4px; }

/* ── PORTFOLIO ── */
.port-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap: 1rem; margin-bottom: 1.25rem; }
.port-sc { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 1rem; box-shadow: var(--shadow); }
.port-sc-label { font-size: 0.8em; font-weight: 600; text-transform: uppercase; letter-spacing: .3px; color: var(--text3); margin-bottom: .375rem; }
.port-sc-val { font-family: var(--display); font-size: 20px; font-weight: 800; color: var(--text); line-height: 1; }
.port-add { display: flex; gap: .75rem; flex-wrap: wrap; align-items: flex-end; margin-bottom: 1rem; }
.port-add input { flex: 1; min-width: 120px; padding: 9px 13px; border: 1px solid var(--border); border-radius: 8px; font-size: 0.8em; color: var(--text); background: var(--card); outline: none; }
.port-add input:focus { border-color: var(--accent); }

/* ── BROKER ── */
.broker-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 1rem; }
.broker-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 1.25rem; box-shadow: var(--shadow); }
.broker-name { font-size: 1em; font-weight: 700; color: var(--text); margin-bottom: .375rem; }
.broker-type { font-size: 0.8em; color: var(--text3); margin-bottom: .625rem; }
.broker-stars { color: var(--amber); margin-bottom: .625rem; font-size: 0.8em; }
.broker-feats { margin-bottom: .875rem; }
.broker-feat { font-size: 0.8em; color: var(--text2); padding: 3px 0; display: flex; gap: .5rem; }
.broker-feat::before { content: '✓'; color: var(--green); flex-shrink: 0; }
.broker-badge { font-size: 0.8em; font-weight: 600; padding: 3px 8px; border-radius: 4px; background: var(--green-soft); color: var(--green); margin-bottom: .75rem; display: inline-block; }
.broker-cta { display: inline-block; font-size: 0.8em; font-weight: 600; padding: 8px 16px; background: var(--accent); color: #fff; border-radius: 8px; transition: background .15s; }
.broker-cta:hover { background: #4338ca; }

/* ── PUSH OPTS ── */
.push-opts { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 1rem; }
.push-opt { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 1.25rem; box-shadow: var(--shadow); transition: border-color .15s; }
.push-opt:hover { border-color: var(--accent); }
.push-label { font-size: 1em; font-weight: 600; color: var(--text); margin-bottom: .375rem; }
.push-desc { font-size: 0.8em; color: var(--text2); line-height: 1.5; }
.push-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 1.25rem; margin-bottom: .75rem; }
.push-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }

/* ── HOWTO ── */
.howto-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 1rem; margin-bottom: 1.25rem; }
.howto-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 1.25rem; box-shadow: var(--shadow); }

/* ── TK KLASSEN ── */
.tk-headline { font-family: var(--display); font-size: 20px; font-weight: 800; color: var(--text); line-height: 1.3; margin-bottom: .5rem; letter-spacing: -.3px; }
.tk-badge { display: inline-block; font-size: 0.8em; font-weight: 700; letter-spacing: .5px; padding: 3px 10px; border-radius: 5px; border: 1px solid; }
.tk-summary { font-size: 1em; color: var(--text2); line-height: 1.75; margin-bottom: 1rem; }
.tk-card-label { font-size: 0.8em; font-weight: 700; letter-spacing: 1px; color: var(--text3); text-transform: uppercase; margin-bottom: 5px; }
.tk-card-text { font-size: 0.8em; color: var(--text2); line-height: 1.55; }
.tk-risk-label { font-size: 0.8em; font-weight: 700; letter-spacing: .5px; color: var(--red); margin-bottom: 5px; }
.tk-chance-label { font-size: 0.8em; font-weight: 700; letter-spacing: .5px; color: var(--green); margin-bottom: 5px; }
.tk-tipp-label { color: var(--accent); }
.tk-tipp-text { font-size: 0.8em; color: var(--text2); }

/* ── MISC ── */
.scoring-output { min-height: 2rem; }
.clock { font-family: var(--mono); font-size: 2em; color: var(--text3);text-align: center }
.clock-sub { font-size: 1em; color: #64748b; text-align:center }
.test-row { display: flex; align-items: center; gap: 1rem; padding: .75rem 0; border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.tslider { width: 100%; accent-color: var(--accent); }
.hamburger { display: none; background: none; border: none; padding: .5rem; font-size: 1.25rem; color: rgba(255,255,255,.6); }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { display: none; position: fixed; left: 0; top: 0; z-index: 200; width: 256px; height: 100vh; }
  .sidebar.open { display: flex; }
  .sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 199; }
  .sidebar-overlay.open { display: block; }
  .hamburger { display: block; }
  .scoring-input-row { flex-direction: column; }
  .score-input, .score-btn { width: 100%; }
  th, td { padding: 8px 10px; }
  .source-bar { gap: 4px; }
  .port-summary { grid-template-columns: 1fr 1fr; }
  .port-add { flex-direction: column; }
  .port-add input { width: 100%; }
  .broker-grid { grid-template-columns: 1fr; }
  .sent-grid { grid-template-columns: 1fr; }
  .ks-grid { grid-template-columns: 1fr; }
  .howto-grid { grid-template-columns: 1fr; }
  .push-opts { grid-template-columns: 1fr; }
  .pg-title { font-size: 20px; }
}
@media(max-width:480px) {
  .metrics { grid-template-columns: 1fr 1fr; }
  .topbar { gap: .75rem; }
  .scoring-wrap { padding: 1rem; }
  .content { padding: 1rem; }
  .score-circle { width: 80px; height: 80px; }
  .score-num { font-size: 26px; }
  .port-summary { grid-template-columns: 1fr; }
}
