* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --bg:     #07080f;
  --s1:     #0c0e1a;
  --s2:     #111424;
  --s3:     #171a2e;
  --s4:     #1e2138;
  --border:  rgba(255,255,255,0.06);
  --border2: rgba(255,255,255,0.11);
  --cyan:   #2563eb;
  --cyan2:  #60a5fa;
  --green:  #00e5a0;
  --red:    #ff3d5a;
  --amber:  #ffb547;
  --purple: #b06eff;
  --text:   #dce4f5;
  --t2:     #7a85a3;
  --t3:     #3d4565;
  --mono:   'Space Grotesk', 'Roboto', monospace;
  --sans:   'Space Grotesk', 'Rethink Sans', sans-serif;
}

html, body { height: 100%; overflow: hidden; background: var(--bg); color: var(--text); font-family: var(--sans); }

/* ─── APP SHELL ─────────────────────────────────────────── */
.app { display: flex; height: 100vh; position: relative; }

/* ─── FLOATING PILL PANELS ──────────────────────────────── */
.pp-panels {
  position: fixed;
  left: 12px;
  top: 104px;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: calc(100vh - 120px);
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.08) transparent;
  padding-bottom: 16px;
  padding-right: 2px;
}
.pp-panels::-webkit-scrollbar { width: 3px; }
.pp-panels::-webkit-scrollbar-track { background: transparent; }
.pp-panels::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.pp-panels:hover::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.18); }

.pp-panel {
  background: rgba(12, 14, 26, 0.94);
  border: 1px solid var(--border2);
  border-radius: 20px;
  overflow: hidden;
  width: 228px;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: border-radius 0.2s ease;
}
.pp-panel.open { border-radius: 12px; }

.pp-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  cursor: pointer;
  user-select: none;
  transition: background 0.15s;
}
.pp-header:hover { background: rgba(255,255,255,0.03); }

.pp-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }

.pp-label {
  font-size: 9px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--t2); flex: 1;
}

.pp-arrow { font-size: 8px; color: var(--t3); }

.pp-badge {
  font-size: 8px; font-weight: 600; letter-spacing: 1px;
  padding: 1px 6px; border-radius: 10px;
  background: rgba(0,229,160,0.1); color: var(--green);
}

.pp-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.pp-panel.open .pp-content {
  max-height: 260px;
  height: 260px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--s3) transparent;
  border-top: 1px solid var(--border);
}
.pp-panel.open .pp-content::-webkit-scrollbar { width: 3px; }
.pp-panel.open .pp-content::-webkit-scrollbar-track { background: transparent; }
.pp-panel.open .pp-content::-webkit-scrollbar-thumb { background: var(--s3); border-radius: 2px; }

/* Mercati pill — always full height, no scroll */
#pp-markets.open .pp-content {
  height: auto !important;
  max-height: none !important;
  overflow: hidden !important;
}
.mkt-item { text-decoration: none; display: flex; align-items: center; justify-content: space-between; padding: 7px 14px; transition: background .15s; }
.mkt-item:hover { background: rgba(255,255,255,0.025); }
.mkt-tv-note {
  font-size: 8px; color: var(--t3); text-align: right;
  padding: 4px 14px 8px; letter-spacing: 0.5px;
}
.mkt-tv-note a { color: var(--t3); text-decoration: none; }
.mkt-tv-note a:hover { color: var(--t2); }

/* ─── CATEGORY FILTERS ─────────────────────────────────── */
.cat-btn {
  display: flex; align-items: center; gap: 10px; width: 100%;
  padding: 8px 14px; background: none; border: none;
  color: var(--t2); font-family: var(--sans); font-size: 12px;
  font-weight: 500; cursor: pointer; transition: all .15s; text-align: left;
}
.cat-btn:hover { color: var(--text); background: rgba(255,255,255,0.03); }
.cat-btn.active { color: var(--text); background: rgba(37,99,235,0.08); }
.cat-btn.active .cat-dot { opacity: 1; box-shadow: 0 0 6px currentColor; }
.cat-btn[onclick*="high-impact"].active { background: rgba(255,61,90,0.1); }
.cat-dot { width: 5px; height: 5px; border-radius: 50%; opacity: 0.35; flex-shrink: 0; transition: all .2s; }
.cat-count {
  margin-left: auto; font-family: var(--mono); font-size: 10px; color: var(--t3);
  background: var(--s3); padding: 1px 7px; border-radius: 20px;
  min-width: 24px; text-align: center;
}

/* ─── SOURCE TOGGLES ────────────────────────────────────── */
.src-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 5px 14px; cursor: pointer; gap: 8px;
}
.src-row:hover .src-label { color: var(--text); }
.src-left { display: flex; align-items: center; gap: 7px; min-width: 0; }
.src-status { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; transition: all .3s; }
.src-status.st-off     { background: var(--t3); }
.src-status.st-loading { background: var(--amber); animation: blink .8s infinite; }
.src-status.st-ok      { background: var(--green); box-shadow: 0 0 5px var(--green); }
.src-status.st-error   { background: var(--red); }
.src-label { font-size: 11px; color: var(--t2); transition: color .15s; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.src-toggle {
  width: 28px; height: 15px; border-radius: 20px; background: var(--s3);
  position: relative; transition: background .2s; border: 1px solid var(--border2); flex-shrink: 0;
}
.src-toggle.on { background: var(--cyan); border-color: var(--cyan); }
.src-toggle::after {
  content: ''; position: absolute; width: 11px; height: 11px; border-radius: 50%;
  background: #fff; top: 1px; left: 1px; transition: transform .2s;
}
.src-toggle.on::after { transform: translateX(13px); }
.src-locked { cursor: default; opacity: 0.85; }
.src-locked:hover .src-label { color: var(--t2); }
.src-lock { font-size: 10px; flex-shrink: 0; opacity: 0.5; }

/* Premium-censored sources */
.src-censored { cursor: pointer; }
.src-censored:hover { background: rgba(37,99,235,0.04); }
.src-label-blur { filter: blur(4px); user-select: none; pointer-events: none; font-size: 11px; color: var(--t2); }
.src-premium-tag {
  font-size: 8px; font-weight: 700; letter-spacing: 1px; white-space: nowrap;
  background: linear-gradient(135deg, rgba(37,99,235,0.15), rgba(176,110,255,0.15));
  border: 1px solid rgba(37,99,235,0.3); color: var(--cyan);
  padding: 2px 7px; border-radius: 10px; flex-shrink: 0;
}

/* Portfolio premium gate */
.pf-premium-gate {
  position: relative;
}
.pf-premium-blur {
  filter: blur(3px) brightness(0.5);
  pointer-events: none; user-select: none;
}
.pf-premium-overlay {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 14px;
  background: rgba(7,8,15,0.5); backdrop-filter: blur(2px);
  z-index: 10; padding: 24px; text-align: center;
}
.pf-premium-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(37,99,235,0.15), rgba(176,110,255,0.15));
  border: 1px solid rgba(37,99,235,0.3);
  display: flex; align-items: center; justify-content: center; font-size: 22px;
}
.pf-premium-title { font-size: 15px; font-weight: 700; color: var(--text); }
.pf-premium-desc { font-size: 12px; color: var(--t2); line-height: 1.6; max-width: 220px; }
.pf-premium-cta {
  background: linear-gradient(135deg, var(--cyan), #0099cc);
  border: none; color: #000; font-family: var(--sans); font-size: 12px; font-weight: 700;
  padding: 9px 20px; border-radius: 20px; cursor: pointer; transition: all .2s;
}
.pf-premium-cta:hover { opacity: 0.9; box-shadow: 0 6px 20px rgba(37,99,235,0.3); }

/* ─── MINI MARKETS (larger format) ─────────────────────── */
.mkt-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 14px; transition: background .15s;
}
.mkt-item:hover { background: rgba(255,255,255,0.025); }
.mkt-sym { font-family: var(--mono); font-size: 13px; color: var(--t2); font-weight: 500; }
.mkt-right { text-align: right; }
.mkt-price { font-family: var(--mono); font-size: 15px; font-weight: 700; color: var(--text); }
.mkt-chg { font-family: var(--mono); font-size: 11px; }
.up { color: var(--green); }
.dn { color: var(--red); }

/* ─── EXTERNAL LINKS ────────────────────────────────────── */
.ext-link {
  display: flex; align-items: center; gap: 9px; padding: 7px 14px; cursor: pointer;
  color: var(--t2); font-size: 12px; font-weight: 500;
  transition: all .15s; text-decoration: none;
}
.ext-link:hover { color: var(--text); background: rgba(255,255,255,0.03); }
.ext-section-label {
  font-size: 8px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t3); padding: 6px 14px 2px; margin-top: 2px;
}

/* ─── AGENDA MACRO PILL ─────────────────────────────────── */
.agenda-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 7px 14px; border-bottom: 1px solid var(--border);
  transition: background .15s; cursor: default;
}
.agenda-item:last-child { border-bottom: none; }
.agenda-item:hover { background: rgba(255,255,255,0.02); }
.agenda-time { font-family: var(--mono); font-size: 10px; color: var(--t3); flex-shrink: 0; width: 38px; padding-top: 1px; }
.agenda-flag { font-size: 13px; flex-shrink: 0; line-height: 1.4; }
.agenda-body { flex: 1; min-width: 0; }
.agenda-name { font-size: 11px; color: var(--text); font-weight: 500; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.agenda-day  { font-size: 9px; color: var(--t3); letter-spacing: 0.3px; }
.agenda-impact { display: flex; gap: 2px; margin-top: 2px; }
.imp-dot { width: 5px; height: 5px; border-radius: 50%; }
.imp-1 .imp-dot:nth-child(1) { background: var(--amber); }
.imp-1 .imp-dot:nth-child(2), .imp-1 .imp-dot:nth-child(3) { background: var(--s3); }
.imp-2 .imp-dot:nth-child(1), .imp-2 .imp-dot:nth-child(2) { background: var(--amber); }
.imp-2 .imp-dot:nth-child(3) { background: var(--s3); }
.imp-3 .imp-dot { background: var(--red); }
.agenda-past { opacity: 0.45; }
.agenda-act {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  flex-shrink: 0; align-self: center; padding: 2px 5px;
  border-radius: 5px; background: var(--s3);
}

/* ─── USER BUTTON & DROPDOWN ────────────────────────────── */
.user-btn {
  display: flex; align-items: center; gap: 7px;
  background: var(--s2); border: 1px solid var(--border2);
  color: var(--text); font-family: var(--sans); font-size: 11px; font-weight: 600;
  padding: 5px 12px 5px 6px; border-radius: 20px; cursor: pointer;
  transition: all .2s; white-space: nowrap; position: relative;
}
.user-btn:hover { border-color: rgba(37,99,235,0.3); background: var(--s3); }
.user-avatar {
  width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; color: #000;
  background: linear-gradient(135deg, var(--cyan), #0099cc);
}
.user-avatar.guest { background: var(--s3); color: var(--t2); font-size: 13px; }
.user-premium-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--amber);
  box-shadow: 0 0 6px var(--amber); flex-shrink: 0;
}

.user-dropdown {
  position: absolute; top: calc(100% + 8px); right: 0;
  background: var(--s2); border: 1px solid var(--border2);
  border-radius: 14px; min-width: 200px; z-index: 200;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  overflow: hidden; display: none;
}
.user-dropdown.open { display: block; }
.ud-header {
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  background: linear-gradient(135deg, rgba(37,99,235,0.05), transparent);
}
.ud-name { font-size: 13px; font-weight: 700; color: var(--text); }
.ud-plan {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 9px; font-weight: 700; letter-spacing: 1px;
  padding: 2px 8px; border-radius: 10px; margin-top: 4px;
}
.ud-plan.free { background: var(--s3); color: var(--t2); }
.ud-plan.premium { background: rgba(255,181,71,0.15); color: var(--amber); border: 1px solid rgba(255,181,71,0.3); }
.ud-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px; font-size: 12px; color: var(--t2);
  cursor: pointer; transition: all .15s;
}
.ud-item:hover { background: rgba(255,255,255,0.04); color: var(--text); }
.ud-item.danger:hover { background: rgba(255,61,90,0.06); color: var(--red); }
.ud-sep { height: 1px; background: var(--border); margin: 2px 0; }

/* ─── LOGIN MODAL ───────────────────────────────────────── */
.lm-overlay {
  position: fixed; inset: 0; background: rgba(7,8,15,0.88);
  backdrop-filter: blur(10px); z-index: 9998;
  display: none; align-items: center; justify-content: center;
}
.lm-overlay.open { display: flex; }
.lm-modal {
  background: var(--s1); border: 1px solid var(--border2);
  border-radius: 20px; width: 100%; max-width: 380px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6);
  overflow: hidden;
}
.lm-header {
  padding: 20px 24px 0; text-align: center;
}
.lm-logo {
  font-size: 20px; font-weight: 700; letter-spacing: 3px; color: var(--text);
  margin-bottom: 4px;
}
.lm-logo span { color: var(--cyan); }
.lm-sub { font-size: 12px; color: var(--t2); margin-bottom: 20px; }
.lm-tabs {
  display: flex; border-bottom: 1px solid var(--border);
}
.lm-tab {
  flex: 1; padding: 10px; text-align: center; font-size: 12px; font-weight: 600;
  color: var(--t3); cursor: pointer; transition: all .15s;
  border-bottom: 2px solid transparent;
}
.lm-tab.active { color: var(--cyan); border-bottom-color: var(--cyan); }
.lm-body { padding: 24px; }
.lm-form { display: flex; flex-direction: column; gap: 14px; }
.lm-field { display: flex; flex-direction: column; gap: 6px; }
.lm-field label { font-size: 11px; font-weight: 600; color: var(--t2); letter-spacing: 0.3px; }
.lm-input {
  background: var(--s2); border: 1px solid var(--border2);
  color: var(--text); font-family: var(--sans); font-size: 13px;
  padding: 10px 14px; border-radius: 10px; outline: none; transition: border .15s; width: 100%;
}
.lm-input:focus { border-color: rgba(37,99,235,0.4); }
.lm-input::placeholder { color: var(--t3); }
.lm-btn {
  width: 100%; padding: 12px; border-radius: 12px;
  background: linear-gradient(135deg, var(--cyan), #0099cc);
  border: none; color: #000; font-family: var(--sans);
  font-size: 13px; font-weight: 700; cursor: pointer; transition: all .2s;
}
.lm-btn:hover { opacity: 0.9; box-shadow: 0 8px 24px rgba(37,99,235,0.3); }
.lm-error { font-size: 11px; color: var(--red); text-align: center; min-height: 16px; }
.lm-close-row {
  text-align: center; padding: 0 24px 20px;
}
.lm-close-link {
  font-size: 11px; color: var(--t3); cursor: pointer; transition: color .15s;
}
.lm-close-link:hover { color: var(--t2); }

.ext-icon {
  width: 20px; height: 20px; border-radius: 5px;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700; flex-shrink: 0;
}

/* ─── MAIN FEED ─────────────────────────────────────────── */
main { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-width: 0; }

.feed-header {
  height: 52px; padding: 0 24px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 14px;
  background: var(--s1); flex-shrink: 0;
}

.brand-inline {
  display: flex; align-items: center; gap: 8px; flex-shrink: 0; margin-right: 4px;
}
.brand-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--cyan);
  box-shadow: 0 0 8px var(--cyan); animation: blink 2s infinite; flex-shrink: 0;
}
@keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
.brand-name { font-size: 15px; font-weight: 700; letter-spacing: 1px; color: var(--text); }
.brand-name span { color: var(--cyan); }

.feed-title { font-size: 12px; font-weight: 600; color: var(--t2); letter-spacing: 0.5px; white-space: nowrap; }

.search-wrap { flex: 1; max-width: 320px; position: relative; }
.search-input {
  width: 100%; background: var(--s2); border: 1px solid var(--border);
  color: var(--text); font-family: var(--sans); font-size: 12px;
  padding: 6px 12px 6px 32px; border-radius: 8px; outline: none;
  transition: border .15s; height: 32px;
}
.search-input:focus { border-color: rgba(37,99,235,0.3); }
.search-icon {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  color: var(--t3); pointer-events: none; font-size: 12px;
}

.feed-meta { display: flex; align-items: center; gap: 10px; flex-shrink: 0; margin-left: auto; }
.feed-count { font-family: var(--mono); font-size: 11px; color: var(--t3); }
.brand-time { font-family: var(--mono); font-size: 10px; color: var(--t3); line-height: 1.35; text-align: right; }

.refresh-btn {
  display: flex; align-items: center; gap: 7px;
  background: rgba(0,229,160,0.1); border: 1px solid rgba(0,229,160,0.25);
  color: var(--green); font-family: var(--sans); font-size: 11px; font-weight: 600;
  padding: 6px 14px; border-radius: 20px; cursor: pointer;
  transition: all .2s; letter-spacing: 0.5px; white-space: nowrap;
}
.refresh-btn:hover { background: rgba(0,229,160,0.18); border-color: rgba(0,229,160,0.4); }
.refresh-btn:disabled { opacity: 0.4; cursor: default; }
.refresh-btn.spinning svg { animation: spin .8s linear infinite; }

.premium-refresh-btn {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(0,229,160,0.1); border: 1px solid rgba(0,229,160,0.3);
  color: var(--green); font-family: var(--sans); font-size: 11px; font-weight: 700;
  padding: 5px 12px; border-radius: 20px; cursor: pointer;
  transition: all .2s; letter-spacing: 0.4px; white-space: nowrap;
}
.premium-refresh-btn:hover { background: rgba(0,229,160,0.18); border-color: rgba(0,229,160,0.5); }
.premium-refresh-btn:disabled { opacity: 0.5; cursor: default; }

.premium-btn {
  display: flex; align-items: center; gap: 6px;
  background: linear-gradient(135deg, rgba(37,99,235,0.15), rgba(176,110,255,0.15));
  border: 1px solid rgba(37,99,235,0.35); color: var(--cyan);
  font-family: var(--sans); font-size: 11px; font-weight: 700;
  padding: 6px 14px; border-radius: 20px; cursor: pointer;
  transition: all .2s; letter-spacing: 0.5px; white-space: nowrap;
}
.premium-btn:hover { background: linear-gradient(135deg,rgba(37,99,235,0.25),rgba(176,110,255,0.25)); border-color: rgba(37,99,235,0.6); }
.premium-btn svg { fill: var(--amber); color: var(--amber); }

/* ─── FREE BANNER ───────────────────────────────────────── */
.free-banner {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 24px 7px 264px; background: rgba(255,181,71,0.06);
  border-bottom: 1px solid rgba(255,181,71,0.15);
  font-size: 11px; color: var(--amber); flex-shrink: 0;
}
.free-banner svg { flex-shrink: 0; opacity: 0.8; }
.free-banner span { flex: 1; }
.free-banner button {
  background: none; border: 1px solid rgba(255,181,71,0.3);
  color: var(--amber); font-family: var(--sans); font-size: 11px;
  font-weight: 600; padding: 3px 10px; border-radius: 20px;
  cursor: pointer; white-space: nowrap; transition: all .2s;
}
.free-banner button:hover { background: rgba(255,181,71,0.1); border-color: rgba(255,181,71,0.5); }

/* ─── PREMIUM MODAL ─────────────────────────────────────── */
.pm-overlay {
  position: fixed; inset: 0; background: rgba(7,8,15,0.85);
  backdrop-filter: blur(8px); z-index: 9999;
  display: none; align-items: center; justify-content: center;
  padding: 20px;
}
.pm-overlay.open { display: flex; }

.pm-modal {
  background: var(--s1); border: 1px solid var(--border2);
  border-radius: 20px; width: 100%; max-width: 740px;
  max-height: 90vh; overflow-y: auto; scrollbar-width: none;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(37,99,235,0.08);
  position: relative;
}
.pm-modal::-webkit-scrollbar { display: none; }

.pm-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px; border-bottom: 1px solid var(--border);
}
.pm-logo {
  display: flex; align-items: center; gap: 10px;
  font-size: 17px; font-weight: 700; letter-spacing: -0.3px; color: var(--text);
}
.pm-close {
  background: rgba(255,255,255,0.05); border: 1px solid var(--border2);
  color: var(--t2); width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .2s;
}
.pm-close:hover { background: rgba(255,255,255,0.1); color: var(--text); }

.pm-hero {
  padding: 36px 32px 28px; text-align: center;
  background: radial-gradient(ellipse at 50% 0%, rgba(37,99,235,0.06) 0%, transparent 65%);
}
.pm-hero-badge {
  display: inline-block; font-size: 9px; font-weight: 700; letter-spacing: 3px;
  color: var(--cyan); background: rgba(37,99,235,0.1); border: 1px solid rgba(37,99,235,0.2);
  padding: 4px 14px; border-radius: 20px; margin-bottom: 16px;
}
.pm-hero-title {
  font-size: 28px; font-weight: 700; line-height: 1.25;
  color: var(--text); margin-bottom: 10px;
}
.pm-hero-sub { font-size: 14px; color: var(--t2); max-width: 440px; margin: 0 auto; line-height: 1.6; }

.pm-plans {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px; padding: 0 24px 28px;
}
.pm-plan {
  background: var(--s2); border: 1px solid var(--border);
  border-radius: 16px; padding: 24px; position: relative; overflow: hidden;
}
.pm-plan-featured {
  border-color: rgba(37,99,235,0.35);
  background: linear-gradient(145deg, rgba(37,99,235,0.04) 0%, var(--s2) 60%);
}
.pm-plan-glow {
  position: absolute; top: -40px; right: -40px;
  width: 140px; height: 140px; border-radius: 50%;
  background: radial-gradient(circle, rgba(37,99,235,0.12) 0%, transparent 70%);
  pointer-events: none;
}
.pm-plan-badge-top {
  display: inline-block; font-size: 8px; font-weight: 700; letter-spacing: 2px;
  color: #000; background: var(--cyan); padding: 3px 10px; border-radius: 20px;
  margin-bottom: 14px;
}
.pm-plan-name {
  font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t2); margin-bottom: 8px;
}
.pm-plan-price {
  font-size: 36px; font-weight: 700; color: var(--text); margin-bottom: 20px; line-height: 1;
}
.pm-plan-price span { font-size: 14px; font-weight: 400; color: var(--t2); margin-left: 2px; }
.pm-features { list-style: none; display: flex; flex-direction: column; gap: 9px; margin-bottom: 24px; }
.pm-feat {
  display: flex; align-items: center; gap: 9px;
  font-size: 12px; color: var(--t2);
}
.pm-feat.ok { color: var(--text); }
.pm-feat.no { color: var(--t3); }

.pm-plan-cta {
  width: 100%; padding: 12px; border-radius: 12px;
  background: linear-gradient(135deg, var(--cyan), #0099cc);
  border: none; color: #000; font-family: var(--sans);
  font-size: 13px; font-weight: 700; cursor: pointer;
  transition: all .2s; letter-spacing: 0.5px;
}
.pm-plan-cta:hover { opacity: 0.9; transform: translateY(-1px); box-shadow: 0 8px 24px rgba(37,99,235,0.3); }
.pm-plan-cta-ghost {
  width: 100%; padding: 12px; border-radius: 12px;
  border: 1px solid var(--border2); color: var(--t3);
  font-size: 12px; text-align: center; font-family: var(--sans);
}

/* Payment form */
.pm-payment { padding: 24px 28px 32px; }
.pm-back {
  display: flex; align-items: center; gap: 6px;
  background: none; border: none; color: var(--t2); font-family: var(--sans);
  font-size: 12px; cursor: pointer; margin-bottom: 20px; transition: color .15s; padding: 0;
}
.pm-back:hover { color: var(--text); }
.pm-pay-title {
  display: flex; align-items: center; gap: 8px;
  font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 14px;
}
.pm-pay-summary {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px; background: rgba(37,99,235,0.06);
  border: 1px solid rgba(37,99,235,0.15); border-radius: 12px; margin-bottom: 24px;
  font-size: 13px; color: var(--t2);
}
.pm-pay-amount { font-weight: 700; color: var(--cyan); font-family: var(--mono); }
.pm-pay-form { display: flex; flex-direction: column; gap: 14px; }
.pm-pay-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pm-pay-field { display: flex; flex-direction: column; gap: 6px; }
.pm-pay-field label { font-size: 11px; font-weight: 600; color: var(--t2); letter-spacing: 0.5px; }
.pm-pay-input-wrap { position: relative; }
.pm-pay-input {
  width: 100%; background: var(--s2); border: 1px solid var(--border2);
  color: var(--text); font-family: var(--mono); font-size: 13px;
  padding: 10px 14px; border-radius: 10px; outline: none; transition: border .15s;
}
.pm-pay-input:focus { border-color: rgba(37,99,235,0.4); }
.pm-pay-input::placeholder { color: var(--t3); }
.pm-card-icons { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); display: flex; gap: 5px; }
.pm-pay-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 14px; border-radius: 12px;
  background: linear-gradient(135deg, var(--cyan), #0099cc);
  border: none; color: #000; font-family: var(--sans);
  font-size: 14px; font-weight: 700; cursor: pointer;
  transition: all .2s; margin-top: 6px; letter-spacing: 0.3px;
}
.pm-pay-btn:hover { opacity: 0.9; box-shadow: 0 8px 28px rgba(37,99,235,0.35); }
.pm-pay-btn:disabled { opacity: 0.6; cursor: default; }
.pm-pay-note {
  font-size: 11px; color: var(--t3); line-height: 1.5; text-align: center;
}
.pm-pay-badges {
  display: flex; gap: 16px; justify-content: center;
  font-size: 10px; color: var(--t3); font-weight: 600; letter-spacing: 0.5px;
}

/* ─── NEWS LIST ─────────────────────────────────────────── */
.news-list {
  flex: 1; overflow-y: auto;
  padding: 18px 40px 18px 268px;
  scrollbar-width: thin; scrollbar-color: var(--s3) transparent;
}

/* ── NEW ARTICLES PILL ──────────────────────────────────── */
.news-pill {
  position: sticky; top: 8px; z-index: 50;
  display: flex; align-items: center; gap: 6px;
  margin: 0 auto 10px; width: fit-content;
  padding: 7px 16px; border-radius: 20px;
  background: var(--cyan); color: #000;
  font-size: 12px; font-weight: 700; font-family: var(--sans);
  cursor: pointer; user-select: none;
  box-shadow: 0 4px 20px rgba(37,99,235,0.35);
  animation: slideDown 0.25s ease;
}
.news-pill:hover { background: var(--cyan2); }
@keyframes slideDown { from { opacity:0; transform:translateY(-10px); } to { opacity:1; transform:translateY(0); } }
.news-list::-webkit-scrollbar { width: 4px; }
.news-list::-webkit-scrollbar-track { background: transparent; }
.news-list::-webkit-scrollbar-thumb { background: var(--s3); border-radius: 2px; }

/* ─── NEWS CARDS ────────────────────────────────────────── */
@keyframes cardIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.news-card {
  background: var(--s1); border: 1px solid var(--border);
  border-radius: 14px; padding: 13px 18px 10px; margin-bottom: 8px;
  transition: border-color .2s, background .2s, box-shadow .2s;
  position: relative; overflow: hidden;
  animation: cardIn .25s ease both;
}
.news-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; border-radius: 3px 0 0 3px;
}
.news-card:hover {
  border-color: var(--border2);
  background: var(--s2); box-shadow: 0 4px 24px rgba(0,0,0,0.25);
}
.card-markets::before { background: var(--cyan); }
.card-war::before     { background: var(--red); }
.card-macro::before   { background: var(--amber); }
.card-crypto::before  { background: var(--purple); }
.card-energy::before  { background: var(--green); }
.card-general::before { background: var(--t3); }

.card-top { display: flex; align-items: center; gap: 8px; margin-bottom: 7px; flex-wrap: wrap; }
.card-source { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--t2); }
.card-time { font-family: var(--mono); font-size: 10px; color: var(--t3); margin-left: auto; display: flex; align-items: center; gap: 6px; }
.card-datetime { color: var(--t2); font-size: 10px; }
.card-rel { color: var(--t3); font-size: 10px; }

.card-ext-link {
  display: flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 6px;
  border: 1px solid var(--border); color: var(--t3);
  text-decoration: none; transition: all .15s; flex-shrink: 0;
}
.card-ext-link:hover { color: var(--cyan); border-color: rgba(37,99,235,0.4); background: rgba(37,99,235,0.06); }

.card-tag { font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 2px 8px; border-radius: 20px; }
.tag-bullish { background: rgba(0,229,160,0.12); color: var(--green); }
.tag-bearish { background: rgba(255,61,90,0.12); color: var(--red); }
.tag-neutral { background: rgba(37,99,235,0.1); color: var(--cyan); }
.tag-geo     { background: rgba(255,181,71,0.12); color: var(--amber); }
.tag-war     { background: rgba(255,61,90,0.18); color: #ff7090; }

.card-cat-pill {
  font-size: 9px; font-weight: 600; letter-spacing: 0.5px;
  text-transform: uppercase; padding: 2px 8px; border-radius: 20px; opacity: 0.75;
}
.pill-markets { background: rgba(37,99,235,0.1);    color: var(--cyan); }
.pill-war     { background: rgba(255,61,90,0.1);    color: var(--red); }
.pill-macro   { background: rgba(255,181,71,0.1);   color: var(--amber); }
.pill-crypto  { background: rgba(176,110,255,0.1);  color: var(--purple); }
.pill-energy  { background: rgba(0,229,160,0.1);    color: var(--green); }
.pill-general { background: rgba(255,255,255,0.05); color: var(--t2); }

.card-headline {
  font-size: 15px; font-weight: 600; line-height: 1.6;
  color: var(--text); margin-bottom: 10px;
  cursor: pointer; letter-spacing: -0.1px;
}
.card-headline:hover { color: var(--cyan); }

.card-body { cursor: pointer; }

.card-summary {
  font-size: 13px; color: var(--t2); line-height: 1.75;
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3;
  overflow: hidden; transition: all .25s ease;
}
.news-card.expanded .card-summary {
  display: block; overflow: visible; -webkit-line-clamp: unset;
}
.card-actions-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
}
.card-actions-row--bare {
  justify-content: flex-end;
  margin-top: 4px;
}

.card-expand-btn {
  display: inline-flex; align-items: center;
  font-family: var(--sans); font-size: 11px; font-weight: 600;
  color: var(--cyan); background: rgba(37,99,235,0.07);
  border: 1px solid rgba(37,99,235,0.2); border-radius: 20px;
  padding: 3px 12px; cursor: pointer; transition: all .15s;
}
.card-expand-btn:hover { background: rgba(37,99,235,0.14); border-color: rgba(37,99,235,0.4); }

.card-translate-btn {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--sans); font-size: 11px; font-weight: 600;
  color: var(--cyan); background: rgba(37,99,235,0.07);
  border: 1px solid rgba(37,99,235,0.2); border-radius: 20px;
  padding: 3px 10px; cursor: pointer; transition: all .15s;
  opacity: 0.55; flex-shrink: 0; line-height: 1;
}
.card-translate-btn:hover { opacity: 1; background: rgba(37,99,235,0.14); border-color: rgba(37,99,235,0.4); }
.card-translate-btn.translated {
  opacity: 1; background: rgba(37,99,235,0.15);
  border-color: rgba(37,99,235,0.5);
}
.card-translate-btn.loading { opacity: 0.6; cursor: wait; }
.card-translate-btn.loading svg { animation: spin 0.8s linear infinite; }

mark { background: rgba(37,99,235,0.2); color: var(--cyan); border-radius: 2px; }

/* ─── ARCHIVE NAV PANEL ──────────────────────────────────── */
#navpanel-archive { width: 520px; }

/* Pillola senza espansione interna (solo link al popup) */
.pp-panel-link { cursor: pointer; }
.pp-panel-link:hover { background: rgba(255,255,255,0.02); }
.pp-panel-link .pp-header { padding: 10px 14px; }

/* ─── HIGH-IMPACT CARDS ─────────────────────────────────── */
.news-card.high-impact {
  border-color: rgba(255,61,90,0.35);
  background: rgba(255,61,90,0.04);
}
.news-card.high-impact::before { background: var(--red) !important; box-shadow: 0 0 8px rgba(255,61,90,0.5); }
.news-card.high-impact:hover   { border-color: rgba(255,61,90,0.55); background: rgba(255,61,90,0.07); }

.tag-alert { background: rgba(255,61,90,0.2); color: var(--red); animation: blink 2s infinite; }

/* ─── LOADING / EMPTY ───────────────────────────────────── */
.feed-loading {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 14px; padding: 60px 0; color: var(--t3);
}
.spin {
  width: 28px; height: 28px; border: 2px solid var(--s3);
  border-top-color: var(--cyan); border-radius: 50%;
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.feed-loading p { font-size: 13px; color: var(--t2); }
.feed-status-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
  width: 100%; max-width: 380px; margin-top: 6px;
}
.fsg-item {
  background: var(--s2); border: 1px solid var(--border); border-radius: 8px;
  padding: 7px 11px; display: flex; align-items: center; gap: 7px; font-size: 11px;
}
.fsg-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.fsg-loading .fsg-dot { background: var(--amber); animation: blink .8s infinite; }
.fsg-ok .fsg-dot      { background: var(--green); }
.fsg-error .fsg-dot   { background: var(--red); }

/* ─── NAV TABS ──────────────────────────────────────────── */
.nav-tabs { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }

.nav-tab {
  display: flex; align-items: center; gap: 6px;
  background: none; border: 1px solid var(--border);
  color: var(--t2); font-family: var(--sans); font-size: 12px; font-weight: 500;
  padding: 6px 14px; border-radius: 20px; cursor: pointer;
  transition: all .2s; white-space: nowrap; letter-spacing: 0.3px;
}
.nav-tab:hover  { color: var(--text); border-color: var(--border2); background: rgba(255,255,255,0.04); }
.nav-tab.active { color: var(--cyan); border-color: rgba(37,99,235,0.4); background: rgba(37,99,235,0.08); }

/* ─── NAV PANELS ────────────────────────────────────────── */
.nav-panel {
  position: fixed; top: 52px; right: 0;
  width: 360px; height: calc(100vh - 52px);
  background: var(--s1); border-left: 1px solid var(--border2);
  display: flex; flex-direction: column;
  transform: translateX(100%); opacity: 0; pointer-events: none;
  transition: transform .28s cubic-bezier(.4,0,.2,1), opacity .28s;
  z-index: 200; box-shadow: -12px 0 40px rgba(0,0,0,0.4);
}
.nav-panel.open { transform: translateX(0); opacity: 1; pointer-events: all; }
.nav-panel-wide { width: 680px; }
.nav-panel-wide .navp-body { flex: 1; min-height: 0; }

.navp-header {
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  background: var(--s2); flex-shrink: 0;
}
.navp-title { font-size: 13px; font-weight: 600; letter-spacing: 0.5px; color: var(--text); }
.navp-close {
  background: none; border: none; color: var(--t2); font-size: 20px;
  cursor: pointer; width: 28px; height: 28px; border-radius: 6px;
  display: flex; align-items: center; justify-content: center; transition: all .15s;
}
.navp-close:hover { background: var(--s3); color: var(--text); }

.navp-body { flex: 1; overflow-y: auto; padding: 20px; }

.navp-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; height: 100%; text-align: center; color: var(--t3);
  padding: 40px 20px;
}
.navp-empty p { font-size: 14px; font-weight: 600; color: var(--t2); }
.navp-empty span { font-size: 12px; color: var(--t3); line-height: 1.6; max-width: 240px; }

.navp-add-btn {
  margin-top: 8px; padding: 8px 20px; border-radius: 20px;
  background: rgba(37,99,235,0.1); border: 1px solid rgba(37,99,235,0.25);
  color: var(--cyan); font-family: var(--sans); font-size: 12px; font-weight: 600;
  cursor: pointer; transition: all .2s;
}
.navp-add-btn:hover { background: rgba(37,99,235,0.18); border-color: rgba(37,99,235,0.4); }

.portfolio-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; background: var(--s2); border: 1px solid var(--border);
  border-radius: 10px; margin-bottom: 8px;
}
.pi-sym { font-family: var(--mono); font-size: 13px; font-weight: 600; color: var(--text); }
.pi-val { font-family: var(--mono); font-size: 12px; color: var(--t3); }

/* ─── SCROLLBAR ─────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--s3); border-radius: 2px; }

/* ─── PORTFOLIO PANEL ───────────────────────────────────── */
#navpanel-portfolio { width: 720px; }

/* Connection wizard */
.pf-hero {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 32px 28px 20px; gap: 10px;
}
.pf-hero-icon {
  width: 64px; height: 64px; border-radius: 18px;
  background: linear-gradient(135deg,rgba(37,99,235,0.15),rgba(37,99,235,0.05));
  border: 1px solid rgba(37,99,235,0.25);
  display: flex; align-items: center; justify-content: center; margin-bottom: 4px;
}
.pf-hero-title { font-size: 18px; font-weight: 800; color: var(--text); letter-spacing: -0.3px; }
.pf-hero-sub { font-size: 12px; color: var(--t2); line-height: 1.65; max-width: 400px; }
.pf-steps-row {
  display: grid; grid-template-columns: repeat(3,1fr);
  margin: 0 28px 20px; border: 1px solid var(--border); border-radius: 10px; overflow: hidden;
}
.pf-step {
  padding: 14px 10px; background: var(--s2); display: flex; flex-direction: column;
  align-items: center; gap: 7px; font-size: 10px; color: var(--t3);
  line-height: 1.4; text-align: center; border-right: 1px solid var(--border);
}
.pf-step:last-child { border-right: none; }
.pf-step-num {
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(37,99,235,0.1); border: 1px solid rgba(37,99,235,0.2);
  color: var(--cyan); font-size: 10px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.pf-form-section { padding: 0 28px 28px; }
.pf-form-title {
  font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t3); margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.pf-form-title::after { content:''; flex:1; height:1px; background:var(--border); }
.pf-security-note {
  display: flex; align-items: flex-start; gap: 8px;
  background: rgba(0,229,160,0.05); border: 1px solid rgba(0,229,160,0.15);
  border-radius: 8px; padding: 10px 12px; margin-bottom: 14px;
  font-size: 10px; color: var(--t2); line-height: 1.55;
}
.pf-security-note svg { flex-shrink: 0; color: var(--green); margin-top: 1px; }
.pf-field select {
  background: var(--s2); border: 1px solid var(--border2); color: var(--text);
  font-family: var(--sans); font-size: 13px; padding: 9px 32px 9px 12px;
  border-radius: 8px; outline: none; transition: border .15s; width: 100%;
  appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
}
.pf-field select:focus { border-color: rgba(37,99,235,0.35); }
.pf-field select option { background: #1a1f2e; }
.pf-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }

/* Dashboard layout */
.pf-acct-bar {
  padding: 12px 20px; background: var(--s2); border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 12px; flex-shrink: 0;
}
.pf-acct-broker {
  width: 36px; height: 36px; border-radius: 9px;
  background: rgba(37,99,235,0.1); border: 1px solid rgba(37,99,235,0.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 800; color: var(--cyan); flex-shrink: 0;
}
.pf-acct-info { flex: 1; }
.pf-acct-name   { font-size: 13px; font-weight: 700; color: var(--text); }
.pf-acct-server { font-size: 10px; color: var(--t3); font-family: var(--mono); margin-top: 1px; }
.pf-live-badge {
  display: flex; align-items: center; gap: 5px;
  font-size: 9px; font-weight: 700; color: var(--green); letter-spacing: 1px;
}
.pf-live-badge::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--green); animation: blink 1.5s infinite;
}
.pf-stats-row {
  display: grid; grid-template-columns: repeat(3,1fr);
  background: var(--border); gap: 1px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.pf-stat-cell { background: var(--s1); padding: 12px 16px; }
.pf-stat-cell-label {
  font-size: 8px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--t3); margin-bottom: 4px;
}
.pf-stat-cell-val { font-family: var(--mono); font-size: 15px; font-weight: 700; color: var(--text); }
.pf-stat-cell-val.pos { color: var(--green); }
.pf-stat-cell-val.neg { color: var(--red); }
.pf-stat-cell-sub { font-size: 9px; color: var(--t3); margin-top: 2px; font-family: var(--mono); }
.pf-dash-scroll { flex: 1; overflow-y: auto; padding: 18px 20px; }
.pf-section-hd {
  font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t3); margin: 0 0 10px; display: flex; align-items: center; gap: 8px;
}
.pf-section-hd::after { content:''; flex:1; height:1px; background:var(--border); }
.pf-equity-card {
  background: var(--s2); border: 1px solid var(--border); border-radius: 10px;
  padding: 14px 14px 8px; margin-bottom: 20px;
}
.pf-equity-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 10px; }
.pf-equity-main { font-family: var(--mono); font-size: 20px; font-weight: 700; color: var(--text); }
.pf-equity-gain { font-size: 11px; color: var(--green); font-family: var(--mono); margin-top: 3px; }
.pf-equity-period { font-size: 10px; color: var(--t3); }
.pf-adv-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 20px; }
.pf-adv-card {
  background: var(--s2); border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px;
}
.pf-adv-label {
  font-size: 8px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--t3); margin-bottom: 4px;
}
.pf-adv-val { font-family: var(--mono); font-size: 13px; font-weight: 700; color: var(--text); }
.pf-adv-val.pos { color: var(--green); }
.pf-adv-val.neg { color: var(--red); }
.pf-pf-table, .pf-table {
  width: 100%; border-collapse: collapse; font-size: 11px; margin-bottom: 20px;
}
.pf-table th {
  font-size: 8px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--t3); padding: 0 8px 8px; text-align: left; border-bottom: 1px solid var(--border);
}
.pf-table td {
  padding: 9px 8px; border-bottom: 1px solid var(--border); color: var(--t2);
  font-family: var(--mono); font-size: 11px;
}
.pf-table tr:last-child td { border-bottom: none; }
.pf-table .sym  { color: var(--text); font-weight: 600; }
.pf-table .buy  { color: var(--green); font-weight: 700; font-size: 9px; letter-spacing: 0.5px; }
.pf-table .sell { color: var(--red);   font-weight: 700; font-size: 9px; letter-spacing: 0.5px; }
.pf-table .pos  { color: var(--green); }
.pf-table .neg  { color: var(--red);   }
.pf-disc-btn {
  width: 100%; padding: 10px; border-radius: 8px;
  background: rgba(255,61,90,0.06); border: 1px solid rgba(255,61,90,0.2);
  color: var(--red); font-family: var(--sans); font-size: 11px; font-weight: 600;
  cursor: pointer; transition: all .2s;
}
.pf-disc-btn:hover { background: rgba(255,61,90,0.14); border-color: rgba(255,61,90,0.4); }

.pf-connect-wrap {
  display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center;
}
.pf-connect-icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: rgba(37,99,235,0.1); border: 1px solid rgba(37,99,235,0.2);
  display: flex; align-items: center; justify-content: center; margin-bottom: 4px;
}
.pf-connect-title { font-size: 16px; font-weight: 700; color: var(--text); }
.pf-connect-desc { font-size: 12px; color: var(--t2); line-height: 1.65; max-width: 340px; }
.pf-connect-desc strong { color: var(--text); }

.pf-form { width: 100%; display: flex; flex-direction: column; gap: 12px; margin-top: 8px; text-align: left; }
.pf-field { display: flex; flex-direction: column; gap: 5px; }
.pf-field label {
  font-size: 11px; font-weight: 600; color: var(--t2); letter-spacing: 0.5px;
  display: flex; align-items: center; gap: 6px;
}
.pf-label-note {
  font-size: 9px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase;
  background: rgba(0,229,160,0.12); color: var(--green); padding: 1px 6px; border-radius: 10px;
}
.pf-field input {
  background: var(--s2); border: 1px solid var(--border2); color: var(--text);
  font-family: var(--sans); font-size: 13px; padding: 9px 12px; border-radius: 8px;
  outline: none; transition: border .15s; width: 100%;
}
.pf-field input:focus { border-color: rgba(37,99,235,0.35); }
.pf-field input::placeholder { color: var(--t3); }
.pf-connect-btn {
  margin-top: 4px; padding: 11px; border-radius: 10px;
  background: linear-gradient(135deg, rgba(37,99,235,0.2), rgba(37,99,235,0.08));
  border: 1px solid rgba(37,99,235,0.35); color: var(--cyan);
  font-family: var(--sans); font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .2s; letter-spacing: 0.5px;
}
.pf-connect-btn:hover { background: linear-gradient(135deg, rgba(37,99,235,0.3), rgba(37,99,235,0.14)); border-color: rgba(37,99,235,0.5); }
.pf-disclaimer { font-size: 10px; color: var(--t3); line-height: 1.55; text-align: center; }

/* Dashboard */
.pf-account-bar {
  padding: 14px 20px; background: var(--s2); border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.pf-acc-left { display: flex; flex-direction: column; gap: 3px; }
.pf-acc-name { font-size: 14px; font-weight: 700; color: var(--text); }
.pf-acc-sub { font-size: 10px; color: var(--t2); font-family: var(--mono); }
.pf-connected-dot {
  display: flex; align-items: center; gap: 6px;
  font-size: 10px; font-weight: 600; color: var(--green); letter-spacing: 0.5px;
}
.pf-connected-dot::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 8px var(--green);
  animation: blink 2s infinite;
}

.pf-dash-body { flex: 1; overflow-y: auto; padding: 16px 20px; }

.pf-metrics {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; margin-bottom: 18px;
}
.pf-metric-card {
  background: var(--s2); border: 1px solid var(--border); border-radius: 10px;
  padding: 11px 12px;
}
.pf-metric-label {
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--t3); margin-bottom: 5px;
}
.pf-metric-val { font-family: var(--mono); font-size: 15px; font-weight: 700; color: var(--text); line-height: 1; }
.pf-metric-val.pos { color: var(--green); }
.pf-metric-val.neg { color: var(--red); }
.pf-metric-sub { font-size: 9px; color: var(--t3); margin-top: 4px; font-family: var(--mono); }

.pf-section-title {
  font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t3); margin-bottom: 10px; display: flex; align-items: center; gap: 8px;
}
.pf-section-title::after { content: ''; flex: 1; height: 1px; background: var(--border); }

.pf-chart-wrap {
  background: var(--s2); border: 1px solid var(--border); border-radius: 10px;
  padding: 12px 12px 6px; margin-bottom: 18px; overflow: hidden;
}
.pf-chart-wrap svg { width: 100%; height: auto; display: block; }

.pf-chart-labels {
  display: flex; justify-content: space-between;
  padding: 4px 2px 0; font-family: var(--mono); font-size: 9px; color: var(--t3);
}

.pf-trades { width: 100%; border-collapse: collapse; font-size: 11px; margin-bottom: 18px; }
.pf-trades th {
  font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--t3); padding: 0 6px 8px; text-align: left; border-bottom: 1px solid var(--border);
}
.pf-trades td {
  padding: 8px 6px; border-bottom: 1px solid var(--border);
  color: var(--t2); font-family: var(--mono); font-size: 11px;
}
.pf-trades tr:last-child td { border-bottom: none; }
.pf-trade-sym { color: var(--text) !important; font-weight: 600; }
.pf-trade-buy  { color: var(--green) !important; font-weight: 700; font-size: 9px; letter-spacing: 1px; }
.pf-trade-sell { color: var(--red) !important; font-weight: 700; font-size: 9px; letter-spacing: 1px; }

.pf-disconnect-btn {
  width: 100%; padding: 10px; border-radius: 8px;
  background: rgba(255,61,90,0.06); border: 1px solid rgba(255,61,90,0.2);
  color: var(--red); font-family: var(--sans); font-size: 12px; font-weight: 600;
  cursor: pointer; transition: all .2s; margin-bottom: 8px;
}
.pf-disconnect-btn:hover { background: rgba(255,61,90,0.14); border-color: rgba(255,61,90,0.4); }
.pf-add-btn {
  width: 100%; padding: 10px; border-radius: 8px;
  background: rgba(37,99,235,0.06); border: 1px solid rgba(37,99,235,0.2);
  color: var(--cyan); font-family: var(--sans); font-size: 12px; font-weight: 600;
  cursor: pointer; transition: all .2s; margin-bottom: 8px;
}
.pf-add-btn:hover { background: rgba(37,99,235,0.12); border-color: rgba(37,99,235,0.4); }

/* ─── REFRESH ICON BTN ──────────────────────────────────── */
.icon-btn {
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 8px;
  background: none; border: 1px solid var(--border);
  color: var(--t3); cursor: pointer; transition: all .18s; flex-shrink: 0;
}
.icon-btn:hover { color: var(--text); border-color: var(--border2); background: rgba(255,255,255,0.04); }
.icon-btn.spinning svg { animation: spin .7s linear infinite; }

/* ─── SETTINGS PANEL ────────────────────────────────────── */
.settings-profile {
  display: flex; align-items: center; gap: 14px;
  padding: 20px; background: linear-gradient(135deg, rgba(37,99,235,0.05), transparent);
  border-bottom: 1px solid var(--border);
}
.settings-avatar {
  width: 48px; height: 48px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 700; color: #000;
  background: linear-gradient(135deg, var(--cyan), #0099cc);
}
.settings-avatar.guest { background: var(--s3); color: var(--t2); font-size: 22px; }
.settings-name { font-size: 15px; font-weight: 700; color: var(--text); }
.settings-plan-badge {
  display: inline-flex; align-items: center; gap: 5px; margin-top: 4px;
  font-size: 9px; font-weight: 700; letter-spacing: 1px; padding: 2px 9px;
  border-radius: 10px;
}
.settings-plan-badge.free    { background: var(--s3); color: var(--t2); }
.settings-plan-badge.premium { background: rgba(255,181,71,0.15); color: var(--amber); border: 1px solid rgba(255,181,71,0.3); }

.settings-section {
  border-bottom: 1px solid var(--border); padding: 16px 20px 12px;
}
.settings-section-title {
  font-size: 9px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--t3); margin-bottom: 12px;
}
.settings-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 0; gap: 12px;
}
.settings-row-label { font-size: 12px; color: var(--t2); }
.settings-row-value { font-size: 12px; color: var(--text); font-weight: 600; font-family: var(--mono); }
.settings-row-value.ok   { color: var(--green); }
.settings-row-value.warn { color: var(--amber); }

.settings-plan-card {
  background: linear-gradient(135deg, rgba(37,99,235,0.06), rgba(176,110,255,0.04));
  border: 1px solid rgba(37,99,235,0.2); border-radius: 12px;
  padding: 14px 16px; margin-bottom: 12px;
}
.settings-plan-card-name { font-size: 13px; font-weight: 700; color: var(--cyan); margin-bottom: 2px; }
.settings-plan-card-price { font-size: 22px; font-weight: 700; color: var(--text); }
.settings-plan-card-price span { font-size: 12px; color: var(--t2); font-weight: 400; }
.settings-plan-card-next { font-size: 11px; color: var(--t3); margin-top: 4px; }

.settings-btn {
  width: 100%; padding: 10px; border-radius: 10px; font-family: var(--sans);
  font-size: 12px; font-weight: 600; cursor: pointer; transition: all .2s;
  border: 1px solid; margin-top: 6px;
}
.settings-btn.primary {
  background: linear-gradient(135deg, var(--cyan), #0099cc);
  border-color: transparent; color: #000;
}
.settings-btn.primary:hover { opacity: 0.88; }
.settings-btn.ghost {
  background: rgba(37,99,235,0.06); border-color: rgba(37,99,235,0.2); color: var(--cyan);
}
.settings-btn.ghost:hover { background: rgba(37,99,235,0.12); }
.settings-btn.danger {
  background: rgba(255,61,90,0.06); border-color: rgba(255,61,90,0.2); color: var(--red);
}
.settings-btn.danger:hover { background: rgba(255,61,90,0.12); }

.settings-toggle-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 9px 0;
}
.settings-toggle-label { font-size: 12px; color: var(--t2); }
.settings-toggle-sub   { font-size: 10px; color: var(--t3); }
.settings-toggle {
  width: 32px; height: 17px; border-radius: 20px; background: var(--s3);
  position: relative; transition: background .2s; border: 1px solid var(--border2);
  flex-shrink: 0; cursor: pointer;
}
.settings-toggle.on { background: var(--cyan); border-color: var(--cyan); }
.settings-toggle::after {
  content: ''; position: absolute; width: 13px; height: 13px; border-radius: 50%;
  background: #fff; top: 1px; left: 1px; transition: transform .2s;
}
.settings-toggle.on::after { transform: translateX(15px); }

/* ── AI FINANCE PANEL ───────────────────────── */
.ai-provider-toggle { display:flex; gap:6px; margin-bottom:16px; }

.ai-prov-btn {
  flex:1; padding:7px 0;
  border:1px solid var(--s3); background:var(--s2); color:var(--t2);
  border-radius:8px; font-size:12px; font-family:inherit;
  cursor:pointer; transition:all .15s;
}
.ai-prov-btn.active { border-color:var(--cyan); color:var(--cyan); background:rgba(37,99,235,0.08); }

.ai-no-key-banner {
  font-size:11px; color:var(--amber);
  background:rgba(255,179,0,0.08); border:1px solid rgba(255,179,0,0.2);
  border-radius:8px; padding:8px 12px; margin-bottom:16px; line-height:1.5;
}

.ai-section-title {
  font-size:11px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--t2); margin-bottom:10px; padding-bottom:6px; border-bottom:1px solid var(--s3);
}

.ai-no-portfolio {
  font-size:12px; color:var(--t2);
  padding:12px; background:var(--s2); border-radius:8px; margin-bottom:12px;
}

.ai-trade-table-wrap { overflow-x:auto; margin-bottom:10px; }
.ai-trade-table { width:100%; border-collapse:collapse; font-size:11px; }
.ai-trade-table th {
  color:var(--t3); font-weight:500; text-align:left;
  padding:4px 8px; border-bottom:1px solid var(--s3);
}
.ai-trade-table td {
  padding:5px 8px; color:var(--text);
  border-bottom:1px solid var(--s2);
  font-family:'IBM Plex Mono',monospace; font-size:11px;
}
.ai-trade-table .pos { color:var(--green); }
.ai-trade-table .neg { color:var(--red); }

.ai-instrument-list { display:flex; flex-direction:column; gap:4px; margin-bottom:10px; }
.ai-instrument-row {
  display:flex; align-items:center; gap:8px;
  padding:6px 8px; border-radius:7px; cursor:pointer;
  transition:background .12s; font-size:12px;
}
.ai-instrument-row:hover { background:var(--s2); }
.ai-instrument-row input[type="checkbox"] { accent-color:var(--cyan); }
.ai-instr-sym { font-family:'IBM Plex Mono',monospace; font-size:11px; color:var(--cyan); min-width:60px; }
.ai-instr-name { color:var(--t2); flex:1; }
.ai-instr-price { font-family:'IBM Plex Mono',monospace; font-size:11px; color:var(--t2); }

.ai-run-btn {
  width:100%; padding:9px; background:var(--cyan); color:#000;
  border:none; border-radius:8px; font-size:12px; font-weight:600;
  font-family:inherit; cursor:pointer; transition:opacity .15s; margin-bottom:16px;
}
.ai-run-btn:disabled { opacity:.35; cursor:not-allowed; }
.ai-run-btn:not(:disabled):hover { opacity:.85; }

.ai-result-box {
  background:var(--s2); border:1px solid var(--s3);
  border-radius:10px; overflow:hidden; margin-top:4px;
}
.ai-result-toolbar {
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 12px; border-bottom:1px solid var(--s3);
}
.ai-result-label {
  font-size:10px; font-weight:600; letter-spacing:.05em;
  text-transform:uppercase; color:var(--t3);
}
.ai-copy-btn {
  background:none; border:none; color:var(--t2);
  font-size:11px; cursor:pointer; padding:2px 6px;
  border-radius:4px; transition:color .15s;
}
.ai-copy-btn:hover { color:var(--text); }
.ai-result-content {
  padding:12px; font-size:12px; line-height:1.7; color:var(--text);
  white-space:pre-wrap; max-height:400px; overflow-y:auto;
  font-family:'IBM Plex Mono',monospace;
}
.ai-cursor {
  display:inline-block; width:2px; height:13px; background:var(--cyan);
  animation:blink 1s step-end infinite;
  vertical-align:text-bottom; margin-left:1px;
}
.ai-key-select {
  background:var(--s2); border:1px solid var(--s3); color:var(--text);
  border-radius:6px; padding:4px 8px; font-size:11px;
  font-family:inherit; cursor:pointer;
}
