/* ============================================================================
   SENTRY - CSS Styles
   ============================================================================ */

:root {
  --bg: #ffffff; --bg-alt: #f5f5f5; --text: #555; --text-strong: #222; --text-strong-rgb: 34,34,34; --text-muted: #999;
  --text-10: rgba(85,85,85,0.1); --text-20: rgba(85,85,85,0.2);
  --border: #eee; --border-light: #f5f5f5; --chip-bg: transparent; --chip-border: #ddd;
  --green: #1a7a1a; --green-10: rgba(26,122,26,0.1);
  --red: #cc2222; --red-10: rgba(204,34,34,0.1);
  --blue: #2255bb; --blue-10: rgba(34,85,187,0.1);
  --purple: #7733aa; --purple-10: rgba(119,51,170,0.1);
  --amber: #996600; --amber-10: rgba(153,102,0,0.1);
  /* Font sizes */
  --fs: 14px; --fs-sm: 14px; --fs-xs: 14px; --fs-lg: 14px; --fs-xl: 14px;
}
[data-font-size="xsmall"] { --fs: 12px; --fs-sm: 12px; --fs-xs: 12px; --fs-lg: 12px; --fs-xl: 12px; }
[data-font-size="small"] { --fs: 13px; --fs-sm: 13px; --fs-xs: 13px; --fs-lg: 13px; --fs-xl: 13px; }
[data-font-size="large"] { --fs: 15px; --fs-sm: 15px; --fs-xs: 15px; --fs-lg: 15px; --fs-xl: 15px; }
[data-font-size="xlarge"] { --fs: 17px; --fs-sm: 17px; --fs-xs: 17px; --fs-lg: 17px; --fs-xl: 17px; }
[data-theme="dark"] {
  --bg: #0a0a0a; --bg-alt: #151515; --text: #888; --text-strong: #ddd; --text-strong-rgb: 221,221,221; --text-muted: #555;
  --text-10: rgba(136,136,136,0.1); --text-20: rgba(136,136,136,0.2);
  --border: #222; --border-light: #1a1a1a; --chip-bg: #151515; --chip-border: #333;
  --green: #4ade80; --green-10: rgba(74,222,128,0.1);
  --red: #ff4b4b; --red-10: rgba(248,113,113,0.1);
  --blue: #60a5fa; --blue-10: rgba(96,165,250,0.1);
  --purple: #a78bfa; --purple-10: rgba(167,139,250,0.1);
  --amber: #fbbf24; --amber-10: rgba(251,191,36,0.1);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* minimal scrollbars */
::-webkit-scrollbar { width: 1px; height: 1px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--text-muted); }
::-webkit-scrollbar-thumb:hover { background: var(--text); }
* { scrollbar-width: thin; scrollbar-color: var(--text-muted) transparent; }

.show-mobile { display: none; }
body {
  background: var(--bg); color: var(--text);
  font-family: 'SF Mono', 'Fira Code', monospace;
  font-size: var(--fs); -webkit-font-smoothing: antialiased;
}
[data-font="system"], [data-font="system"] * {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}
/* Text case - lowercase mode: force on all elements (buttons/inputs don't inherit) */
[data-case="lower"], [data-case="lower"] *,
[data-case="lower"] .modal label, [data-case="lower"] .beta-tag { text-transform: lowercase; }
/* Exempt signal content from lowercase */
[data-case="lower"] .sig-title, [data-case="lower"] .sig-summary,
[data-case="lower"] .ticker-tag, [data-case="lower"] .ticker-item,
[data-case="lower"] .tweet-tooltip, [data-case="lower"] .tweet-expand-content { text-transform: none; }
::selection { background: var(--bg-alt); color: var(--green); }
input::placeholder { color: var(--text-muted); }
button { font-family: inherit; cursor: pointer; touch-action: manipulation; }

.topbar {
  padding: 10px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.logo { display: flex; align-items: center; gap: 8px; }
.dot { width: 6px; height: 14px; background: var(--text-strong); }
.dot.loading { animation: blink 1s step-end infinite; }
@keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0; } }
.logo-text { font-size: var(--fs); font-weight: 500; color: var(--text-strong); }
.topbar-right { display: flex; align-items: center; gap: 8px; }
.top-btn { background: none; border: none; font-size: var(--fs); color: var(--text-muted); }
.top-btn:hover { color: var(--text); }

/* modal */
.modal-bg {
  display: none; position: fixed; inset: 0; background: rgba(0, 0, 0, 0.4); z-index: 100;
  align-items: stretch; justify-content: flex-end;
}
.modal-bg.open { display: flex; }
body.modal-open { overflow: hidden; }
.modal {
  background: var(--bg);
  padding: 10px; width: 100%; max-width: 480px; height: 100%; overflow-y: auto;
  position: relative; border-left: 1px solid var(--border);
}
.modal-close { position: absolute; top: 12px; right: 16px; background: none; border: none; color: var(--text-muted); font-size: var(--fs); cursor: pointer; z-index: 1; }
.modal-close:hover { color: var(--text-strong); }
.settings-header { font-size: var(--fs); color: var(--text-strong); margin-bottom: 10px; }
.modal-tabs { display: flex; gap: 0; margin: 0 -10px 0; padding: 0 10px 10px 10px; overflow-x: auto; -ms-overflow-style: none; scrollbar-width: none; flex-wrap: nowrap; }
.modal-tabs::-webkit-scrollbar { display: none; }
.modal-tab { background: none; border: none; border-bottom: none; font-size: var(--fs); color: var(--text-muted); margin-right: 16px; cursor: pointer; white-space: nowrap; flex-shrink: 0; }
.modal-tab:hover { color: var(--text); }
.modal-tab.active { color: var(--bg); border: none; background: var(--text-strong); }
.tab-content { display: none; }
.tab-content.active { display: block; }
.tab-content > :first-child { margin-top: 0; }
.modal h3 { font-size: var(--fs-xl); font-weight: 500; color: var(--text-strong); margin-bottom: 8px; }
.modal p { font-size: var(--fs); color: var(--text-muted); margin-bottom: 10px; }
.modal p a { color: var(--blue); text-decoration: none; }
.modal p a:hover { text-decoration: underline; }
.modal label { display: flex; align-items: center; font-size: var(--fs-sm); color: var(--text-muted); margin-bottom: 6px; margin-top: 10px; }
.modal label:first-of-type, .tab-content > label:first-of-type, .tab-content > p + label { margin-top: 0; }
.reset-prompt { background: none; border: none; color: var(--text-muted); font-size: var(--fs-sm); cursor: pointer; margin-left: auto; }
.reset-prompt:hover { color: var(--text-strong); }
/* Analyst cards */
.analyst-item { border-bottom: 1px solid var(--border-light); }
.analyst-item:first-child .analyst-header { padding-top: 0; }
.analyst-item:last-of-type { border-bottom: none; }
.analyst-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 0; cursor: pointer; gap: 8px;
}
.analyst-header:hover .analyst-name { color: var(--text-strong); }
.analyst-name { color: var(--text); font-size: var(--fs); flex: 1; }
.analyst-name::before { content: '▸ '; }
.analyst-item.open .analyst-name::before { content: '▾ '; }
.analyst-active-tag { font-size: var(--fs-xs); color: var(--green); background: var(--green-10); margin-left: 6px; }
.analyst-actions { display: flex; gap: 8px; }
.analyst-actions button { background: none; border: none; color: var(--text-muted); font-size: var(--fs-sm); cursor: pointer; padding: 0; }
.analyst-actions button:hover { color: var(--text-strong); }
.analyst-actions button.danger:hover { color: var(--red); }
.analyst-body { display: none; padding-bottom: 12px; }
.analyst-item.open .analyst-body { display: block; }
.analyst-body label { margin-top: 10px; }
.analyst-body label:first-child { margin-top: 0; }
.analyst-add { background: none; border: none; color: var(--text-muted); font-size: var(--fs); width: 100%; margin-top: 8px; cursor: pointer; text-align: left; }
.analyst-add:hover { border-color: var(--text-muted); color: var(--text-strong); }
.modal input:not([type="checkbox"]), .modal select, .modal textarea {
  width: 100%; border: none;
  font-family: inherit; font-size: inherit; color: var(--text-strong); outline: none;
  background: var(--bg-alt); resize: vertical;
}
.modal select {
  cursor: pointer;
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0 center;
}
[data-theme="dark"] .modal select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23999' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
}
.modal input:focus, .modal textarea:focus { border-color: var(--text-muted); }
.modal-actions { display: flex; gap: 8px; margin-top: 24px; justify-content: flex-end; }
.modal-actions button {
  background: none; border: none;
  font-size: var(--fs); color: var(--text);
}
.modal-actions button:hover { border-color: var(--text-muted); color: var(--text-strong); }
.modal-actions button:last-child { background: var(--text-strong); border-color: var(--text-strong); color: var(--bg); }
.modal-actions button:last-child:hover { opacity: 0.9; }
.modal-actions button.danger { color: var(--red); margin-right: auto; background: var(--red-10); }
.modal-actions button.danger:hover { border-color: var(--red); }
.modal-sm-btn { border: none; background: var(--bg-alt); font-size: var(--fs); color: var(--text); cursor: pointer; }
.modal-sm-btn:hover { border-color: var(--text-muted); color: var(--text-strong); }
.beta-tag { font-size: var(--fs-xs); color: var(--amber); background: var(--amber-10); padding: 1px 5px; margin-left: 6px; text-transform: uppercase; letter-spacing: 0.5px; }
.toggle-row { display: flex; align-items: flex-start; gap: 10px; }
.toggle-row input[type="checkbox"] {
  -webkit-appearance: none; appearance: none; margin: 0; margin-top: 2px;
  width: 15px; height: 15px; border: 1.5px solid var(--text-muted); border-radius: 3px;
  background: var(--bg); cursor: pointer; flex-shrink: 0; position: relative;
}
.toggle-row input[type="checkbox"]:checked {
  background: var(--text-strong); border-color: var(--text-strong);
}
.toggle-row input[type="checkbox"]:checked::after {
  content: ''; position: absolute; left: 4px; top: 1px;
  width: 4px; height: 8px; border: solid var(--bg); border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.toggle-desc { font-size: var(--fs); color: var(--text-muted); }
.preset-list { margin-top: 24px; border-top: 1px solid var(--border); padding-top: 16px; }
.preset-list-item {
  display: flex; align-items: center; justify-content: space-between; padding: 10px 0;
  border-bottom: 1px solid var(--border-light); font-size: var(--fs);
}
.preset-list-item:last-child { border-bottom: none; }
.preset-list-item span { color: var(--text-strong); }
.preset-list-item small { color: var(--text-muted); margin-left: 8px; font-size: var(--fs-sm); }
.preset-list-item.editing { background: var(--bg-alt); margin: 0 -10px; padding: 10px; }
.preset-list-actions { display: flex; gap: 8px; }
.preset-list-item button { background: none; border: none; color: var(--text-muted); font-size: var(--fs-sm); padding: 4px 0; }
.preset-list-item button:hover { color: var(--text-strong); }
.preset-list-item button.danger:hover { color: var(--red); }

.controls { padding: 10px; border-bottom: 1px solid var(--border); }
.input-row { display: flex; gap: 6px; align-items: center; margin-bottom: 10px; }
.input-row .at { color: var(--text-muted); font-size: var(--fs); }
.input-row input {
  flex: 1; background: transparent; border: none; outline: none;
  color: var(--text-strong); font-size: inherit; font-family: inherit;
}
.add-btn { background: none; border: none; color: var(--text-muted); font-size: var(--fs); display: none; }
.add-btn.vis { display: inline; }

.presets-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 10px; }
.preset-chip {
  background: var(--text-10); border: none;
  color: var(--text-muted); font-size: inherit;
  display: inline-flex; align-items: center; gap: 5px; cursor: pointer;
}
.preset-chip:hover { color: var(--text-strong); }
.preset-chip.selected { color: var(--bg-alt); background: var(--text-strong); }
.preset-chip .count { font-size: inherit; }
.preset-chip.selected .count { color: var(--bg-alt); }
.preset-manage { background: none; border: none; color: var(--text-muted); font-size: var(--fs); padding: 0; cursor: pointer; }
.preset-manage:hover { color: var(--text-strong); }

.suggested { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 10px; }
.suggested:empty { margin-bottom: 0; }
.sug { background: var(--text-10); border: none; color: var(--text-muted); font-size: var(--fs); }
.sug:hover { color: var(--text-strong); }
.sug.used { opacity: .35; cursor: default; }
.sug-label { color: var(--text-muted); font-size: var(--fs); }

.ranges { display: flex; gap: 8px; align-items: center; }
.rng {
  background: none; border: none;
  color: var(--text-muted); font-size: inherit;
}
.rng:hover { color: var(--text-strong); }
.rng.on { color: var(--bg); background: var(--text-strong); border-bottom-color: var(--text-strong); }

.clear-btn { background: none; border: none; color: var(--text-muted); font-size: var(--fs); }
.clear-btn:hover { color: var(--red); }
.scan-btns { margin-left: auto; display: flex; gap: 8px; }
.scan-btn {
  background: var(--text-strong); border: none; color: var(--bg); font-size: var(--fs);
}
.scan-btn:hover:not(:disabled) { opacity: .8; }
.scan-btn:disabled { opacity: .5; cursor: default; }
.cancel-btn { background: var(--red-10); border: none; color: var(--red); font-size: var(--fs); }
.cancel-btn:hover { opacity: 0.8; }

.notice { padding: 10px; font-size: var(--fs); border-bottom: 1px solid var(--border); }
.notice.err { color: var(--red); background: var(--red-10); }
.notice.warn { color: var(--amber); background: var(--amber-10); }
.notice.resume-banner {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  color: var(--blue); background: var(--blue-10);
}
.resume-btn {
  background: var(--blue); border: none; color: var(--bg);
  font-size: var(--fs); font-family: inherit; cursor: pointer;
}
.resume-btn:hover { opacity: 0.8; }
.dismiss-btn {
  background: none; border: none; color: var(--blue);
  font-size: var(--fs); font-family: inherit; cursor: pointer;
}
.dismiss-btn:hover { color: var(--text-strong); }
.notice.sched-banner {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  color: var(--green); background: var(--green-10);
}
.notice.sched-banner .resume-btn { background: var(--green); }
.notice.sched-banner .dismiss-btn { color: var(--green); }
.notice.sched-banner > span:nth-child(2) { margin-left: auto; }
.notice-btn {
  background: var(--amber); border: none; color: var(--bg);
  font-size: var(--fs); font-family: inherit; cursor: pointer;
}
.notice-btn:hover { opacity: 0.8; }
.notice.err .notice-btn { background: var(--red); }

.tweet-count { padding: 10px; font-size: var(--fs); color: var(--text-muted); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 12px; }
.tweet-count:empty { display: none; }
#tweetCount:empty, #notices:empty, #tickerBar:empty, #scanActions:empty, #filterBar:empty, #results:empty, #sharedBanner:empty { display: none; }
.tweet-count .status-actions { margin-left: auto; display: flex; gap: 12px; align-items: center; }
.dots::after { content: ''; animation: dots 1.2s steps(4, end) infinite; }
@keyframes dots { 0% { content: ''; } 25% { content: '.'; } 50% { content: '..'; } 75% { content: '...'; } }

.ticker-bar {
  padding: 10px; border-bottom: 1px solid var(--border);
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
}
.ticker-item { font-size: var(--fs); display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; text-decoration: none; }
.ticker-item:hover { opacity: .7; }
.ticker-cnt { font-size: var(--fs-sm); opacity: .6; }
.ticker-change { font-size: var(--fs-sm); font-weight: unset; }
.ticker-price { margin-right: 2px; }

.filter-bar {
  padding: 10px; border-bottom: 1px solid var(--border);
  display: flex; gap: 16px; align-items: center; flex-wrap: wrap;
}

.signal {
  padding: 10px; border-bottom: 1px solid var(--border);
}
.signal.hidden { display: none; }
.sig-top { font-size: calc(var(--fs) - 2px); color: var(--text-muted); margin-bottom: 8px; display: flex; justify-content: space-between; align-items: center; }
.sig-top a { color: var(--text-muted); text-decoration: none; }
.sig-top a:hover { color: var(--text-strong); }
.sig-tickers { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }
.ticker-tag { font-size: var(--fs); text-decoration: none; display: inline-flex; align-items: center; gap: 4px; }
.ticker-tag:hover { opacity: .7; }
.ticker-tag .a { display: none; }
.sig-title { font-size: var(--fs-lg); color: var(--text-strong); font-weight: 500; margin-bottom: 6px; }
.sig-summary { font-size: var(--fs); color: var(--text); line-height: 1.5; }
.sig-links { margin-top: 8px; display: flex; gap: 8px; flex-wrap: wrap; }
.ext-link { font-size: var(--fs); color: var(--text); text-decoration: none; background: var(--text-10); }
.ext-link:hover { background: var(--text-20); }
.sig-bottom { margin-top: 10px; font-size: var(--fs-sm); color: var(--text-muted); display: flex; align-items: center; gap: 6px; }
.sig-cat { color: inherit; }
.see-post { color: var(--text-muted); text-decoration: none; font-size: var(--fs); }
.see-post:hover { color: var(--text-strong); }
.see-post .arrow { display: none; }
.share-btn { background: none; border: none; color: var(--text-muted); font-size: var(--fs); cursor: pointer; padding: 0; }
.share-btn:hover { color: var(--text-strong); }
.share-btn.copied { color: var(--green); }
@media (max-width: 700px) {
  .see-post .text { display: none; }
  .see-post .arrow { display: inline; }
}
.tweet-tooltip {
  position: fixed; z-index: 1000; max-width: 320px; padding: 12px 14px;
  background: var(--text-strong); color: var(--bg); font-size: var(--fs);
  pointer-events: none; opacity: 0; border: 1px solid var(--text-strong);
}
.tweet-tooltip.vis { opacity: 1; }

/* Mobile tweet expand */
.tweet-expand { display: none; }
.tweet-expand-btn {
  background: none; border: none; color: var(--text-muted); font-size: var(--fs);
  cursor: pointer; padding: 0; margin-top: 10px;
}
.tweet-expand-btn:hover { color: var(--text-strong); }
.tweet-expand-content {
  display: none; margin-top: 8px; padding: 10px; line-height: 1.5;
  background: var(--bg-alt); font-size: var(--fs); color: var(--text);
}
.tweet-expand-content.open { display: block; }
.tweet-expand-author { color: var(--text-muted); margin-bottom: 6px; }
@media (max-width: 700px) {
  .tweet-expand { display: block; }
}

.empty-state { padding: 48px 15px; font-size: var(--fs); color: var(--text-muted); text-align: center; }

.shared-banner {
  padding: 10px; background: var(--blue-10);
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.shared-banner-text { font-size: var(--fs); color: var(--blue); }
.shared-banner a { color: var(--blue); font-size: var(--fs); text-decoration: none; }
.shared-banner a:hover { color: var(--text-strong); }

/* Shared view overrides */
[data-shared] .topbar { border-bottom: none; }
[data-shared] .live-btn { display: none; }
[data-shared] .signal { padding: 10px; }
[data-shared] .shared-banner, [data-shared] .shared-banner *,
[data-shared] .sig-top, [data-shared] .sig-cat, [data-shared] .see-post,
[data-shared] .footer, [data-shared] .footer * { text-transform: lowercase !important; }

.history:empty { display: none; }
.hist-item { padding: 10px 15px; border-bottom: 1px solid var(--border); }
.hist-item:last-child { border-bottom: none; }
.hist-item.open { padding-bottom: 0; }
.hist-header { display: flex; align-items: center; justify-content: space-between; }
.hist-toggle { background: none; border: none; color: var(--text-muted); font-size: var(--fs); padding: 0; cursor: pointer; }
.hist-toggle:hover { color: var(--text-strong); }
.hist-actions { display: flex; gap: 16px; }
.hist-actions button { background: none; border: none; color: var(--text-muted); font-size: var(--fs); cursor: pointer; }
.hist-actions button:hover { color: var(--text-strong); }
.hist-actions .delete:hover { color: var(--red); }
.hist-body { display: none; margin-left: 0; margin-top: 8px; }
.hist-meta { color: var(--text-muted); font-size: var(--fs); margin-bottom: 10px; }
.hist-cards .signal { margin-top: 0; padding-right: 0; border-left: 1px solid var(--border); }
.hist-cards .signal:last-child { border-bottom: none; }
.hist-item.open .hist-body { display: block; }

.scan-actions { padding: 12px 15px; border-bottom: 1px solid var(--border); display: flex; gap: 12px; align-items: center; }
.scan-actions .meta { font-size: var(--fs); color: var(--text-muted); flex: 1; }
.dl-btn {
  background: none; border: none;
  color: var(--text-muted); font-size: var(--fs); cursor: pointer;
}
.dl-btn:hover { color: var(--text-strong); }
.dl-btn.copied { color: var(--green); }

.footer { padding: 10px; font-size: var(--fs-sm); color: var(--text-muted); }
.footer:empty { display: none; }
.footer a { color: var(--text-muted); }
.footer a:hover { color: var(--text); }

@media (max-width: 700px) {
  .topbar, .controls, .notice, .tweet-count, .ticker-bar, .scan-actions, .filter-bar, .footer, .hist-item, .shared-banner {
    padding-left: 10px; padding-right: 10px;
  }
  .signal { padding: 10px; }
  [data-shared] .signal { padding: 10px; }
  .hide-mobile { display: none; }
  .show-mobile { display: inline; }
  .modal input, .modal textarea, .modal select, .input-row input { font-size: 16px !important; } /* prevent iOS zoom on focus */
  .modal-bg { align-items: flex-end; justify-content: stretch; }
  .modal { max-width: 100%; height: 70vh; border: none; border-top: 1px solid var(--border); border-left: none; }
  .modal-actions { flex-direction: row; margin-top: 16px; }
  .modal-actions button.danger { margin-right: auto; }
  .rng:hover { color: inherit; background: inherit; border-color: inherit; }
  .notice.sched-banner > span:nth-child(2) { margin-left: unset; }
}

/* Disable hover/active/focus states on touch devices */
@media (hover: none) {
  * { -webkit-tap-highlight-color: transparent; }
  .top-btn:hover, .live-btn:hover, .modal-close:hover, .modal-tab:hover, .reset-prompt:hover, .modal-actions button:hover,
  .modal-sm-btn:hover, .analyst-actions button:hover, .analyst-add:hover, .preset-list-item button:hover, .preset-manage:hover,
  .sug:hover, .rng:hover, .clear-btn:hover, .scan-btn:hover:not(:disabled), .cancel-btn:hover,
  .ticker-item:hover, .sig-top a:hover, .ticker-tag:hover, .ext-link:hover, .see-post:hover,
  .share-btn:hover, .tweet-expand-btn:hover, .shared-banner a:hover, .hist-toggle:hover,
  .hist-actions button:hover, .dl-btn:hover, .footer a:hover, .resume-btn:hover, .dismiss-btn:hover, .notice-btn:hover {
    color: inherit; opacity: inherit; background: inherit; border-color: inherit;
  }
  .preset-chip:hover { color: var(--text-muted); background: var(--text-10); }
  .preset-chip.selected:hover { color: var(--bg-alt); background: var(--text-strong); }
  .modal-actions button:last-child:hover { opacity: 1; }
  .ext-link:hover { background: var(--text-10); }
  .rng.on:hover { color: var(--bg); background: var(--text-strong); }
  .modal-tab.active:hover { color: var(--bg); background: var(--text-strong); }
}

/* ============================================================================
   LIVE FEED
   ============================================================================ */

.live-btn {
  background: none; border: none; font-size: var(--fs); color: var(--text-muted);
  display: none; align-items: center; gap: 6px; cursor: pointer;
}
.live-btn:hover { color: var(--text); }
.live-btn.active { color: var(--green); }
.live-btn .live-dot {
  width: 6px; height: 6px; border-radius: 50%; background: currentColor;
}
.live-btn.active .live-dot {
  animation: liveBlink 1s step-end infinite;
}
@keyframes liveBlink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}


/* New signal animation */
.signal.new {
  animation: signalSlideIn 0.4s ease-out;
}
@keyframes signalSlideIn {
  from { opacity: 0; transform: translateY(-12px); }
  to { opacity: 1; transform: translateY(0); }
}
.signal .new-badge {
  display: inline-block; font-size: var(--fs-xs); color: var(--green);
  background: var(--green-10); margin-right: 6px;
}

/* ============================================================================
   CHART PREVIEW (TradingView widget on ticker hover)
   ============================================================================ */

.chart-preview {
  display: none; position: fixed; z-index: 200;
  width: 320px; height: 200px;
  border: 1px solid var(--border); background: var(--bg);
  box-shadow: 0 8px 32px rgba(0,0,0,0.15);
  pointer-events: none; overflow: hidden;
}
@media (max-width: 700px) {
  .chart-preview { display: none !important; }
}

/* ============================================================================
   TICKER BAR (clickable for filtering)
   ============================================================================ */

.ticker-item {
  cursor: pointer; border: none;
  font-family: inherit;
}

/* ============================================================================
   UTILITIES — reusable patterns extracted from inline styles
   ============================================================================ */

/* Text */
.text-muted { color: var(--text-muted); font-size: var(--fs-sm); }
.text-muted-xs { color: var(--text-muted); font-size: var(--fs-xs); }
.text-strong { color: var(--text-strong); }
.text-strong-bold { color: var(--text-strong); }
.section-label { font-size: var(--fs-sm); color: var(--text-muted); }
.heading-lg { font-size: var(--fs-lg); color: var(--text-strong); margin-bottom: 8px; }
.heading-xl { font-size: var(--fs-xl); color: var(--text-strong); margin-bottom: 12px; font-weight: unset; }

/* Layout */
.flex-row { display: flex; align-items: center; gap: 8px; }
.flex-row-sm { display: flex; align-items: center; gap: 6px; }
.flex-row-lg { display: flex; align-items: center; gap: 12px; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.flex-wrap { display: flex; flex-wrap: wrap; gap: 8px; }
.flex-wrap-sm { display: flex; flex-wrap: wrap; gap: 4px; }
.flex-1 { flex: 1; }

/* Visual */
.divider { border-top: 1px solid var(--border); padding-top: 12px; }
.divider-section { border-top: 1px solid var(--border); margin-top: 12px; padding-top: 12px; }
.info-box { padding: 12px; background: var(--bg-alt); font-size: var(--fs-sm); }
.badge-green { font-size: var(--fs-xs); color: var(--green); background: var(--green-10); padding: 1px 5px; }
.btn-ghost { background: none; border: none; color: var(--text-muted); font-size: var(--fs-sm); cursor: pointer; }
.btn-ghost:hover { color: var(--text-strong); }
.btn-ghost-danger { background: none; border: none; color: var(--red); font-size: var(--fs); cursor: pointer; width: 100%; }
.msg-error { color: var(--red); font-size: var(--fs); margin-bottom: 8px; display: none; }
.msg-success { color: var(--green); font-size: var(--fs); margin-bottom: 8px; display: none; }
.progress-track { background: var(--border); margin-bottom: 10px; }
.progress-track.sm { height: 1px; }
.progress-track.md { height: 4px; margin-bottom: 8px; }
.progress-fill { height: 100%; transition: width 0.3s; }
.status-green { color: var(--green); font-size: var(--fs-sm); }
.status-red { color: var(--red); font-size: var(--fs-sm); }
.tooltip-header { opacity: .7; margin-bottom: 8px; }

/* Spacing */
.mb-4 { margin-bottom: 4px; }
.mb-8 { margin-bottom: 8px; }
.mb-10 { margin-bottom: 10px; }
.mb-12 { margin-bottom: 12px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.mt-8 { margin-top: 8px; }
.mt-12 { margin-top: 12px; }
.mt-16 { margin-top: 16px; }

/* ============================================================================
   SCHEDULE TAB
   ============================================================================ */

.sched-item { padding: 10px 0; border-bottom: 1px solid var(--border-light); }
.sched-item:first-child { padding-top: 0; }
.sched-row { display: flex; align-items: center; justify-content: space-between; }
.sched-check { accent-color: var(--green); width: 14px; height: 14px; cursor: pointer; }
.sched-time { color: var(--text-muted); }
.sched-time.enabled { color: var(--text-strong); }
.sched-status-label { font-size: var(--fs-sm); }
.sched-status-label.success { color: var(--green); }
.sched-status-label.error { color: var(--red); }
.sched-status-label.running { color: var(--green); }
.sched-presets { display: flex; align-items: center; gap: 6px; margin-top: 6px; flex-wrap: wrap; }
.sched-chip { padding: 0; font-size: var(--fs-sm); font-family: inherit; cursor: pointer; border: none; background: var(--bg-alt); color: var(--text-muted); }
.sched-chip.selected { background: var(--text-strong); color: var(--bg); }
.sched-status { font-size: var(--fs-sm); padding: 6px 0; }
.sched-status.running { color: var(--green); }
.sched-status.next { color: var(--text-muted); }
.hour-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px; }
.hour-btn { padding: 6px 0; font-size: var(--fs-sm); font-family: inherit; cursor: pointer; border: 1px solid transparent; background: var(--bg-alt); color: var(--text-muted); }
.hour-btn:hover { border-color: var(--chip-border); }
.hour-btn.active { background: var(--text-strong); color: var(--bg); }
.sched-dev-time { display: flex; gap: 6px; align-items: center; margin-top: 8px; }
.sched-dev-time input[type="time"] { font-family: inherit; font-size: var(--fs-sm); background: var(--bg-alt); color: var(--text); border: 1px solid var(--chip-border); padding: 4px 8px; }

/* ============================================================================
   ACCOUNT TAB
   ============================================================================ */

.acct-section { margin-bottom: 16px; }
.acct-credit-row { display: flex; justify-content: space-between; margin-bottom: 10px; }
.acct-divider-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-top: 1px solid var(--border); }
.acct-key-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--border-light); }
.acct-footer { display: flex; justify-content: space-between; align-items: center; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border); }
.acct-signed-out { padding-bottom: 10px; }
.acct-byok-label { font-size: var(--fs-sm); color: var(--text-muted); margin-bottom: 10px; }
.acct-promo { border-top: 1px solid var(--border); padding-top: 12px; }
.key-status-ok { color: var(--green); font-size: var(--fs-sm); }
.key-status-missing { color: var(--red); font-size: var(--fs-sm); }

/* ============================================================================
   PRICING MODAL
   ============================================================================ */

.pricing-pack {
  display: flex; align-items: center; gap: 10px;
  width: 100%; text-align: left;
  background: var(--bg-alt); border: none;
  padding: 10px; margin-bottom: 8px;
  cursor: pointer; font-size: var(--fs); color: var(--text-strong);
}
.pricing-pack.recommended { border: 1px solid var(--text-muted); }
.pricing-pack-name { display: flex; align-items: center; gap: 6px; }
.pricing-pack-details { font-size: var(--fs-sm); color: var(--text-muted); }
.pricing-savings { font-size: var(--fs-xs); color: var(--text-muted); }
.pricing-details { margin-top: 12px; }
.pricing-details summary { font-size: var(--fs-xs); color: var(--text-muted); cursor: pointer; }
.pricing-details-body { font-size: var(--fs-xs); color: var(--text-muted); padding: 10px 0 0 10px; }
.pricing-details-body .example { opacity: 0.6; margin-top: 4px; }
.pricing-footnote { font-size: var(--fs-xs); color: var(--text-muted); margin-top: 12px; }
.pricing-sign-in { font-size: var(--fs); color: var(--text-muted); margin-top: 12px; }

/* ============================================================================
   USER MENU MODAL
   ============================================================================ */

.user-credits-card { border: 1px solid var(--border); padding: 12px; margin-bottom: 12px; }
.user-credits-header { display: flex; justify-content: space-between; margin-bottom: 8px; }
.user-credits-detail { font-size: var(--fs-sm); color: var(--text-muted); margin-bottom: 10px; }
.user-free-tier { padding: 10px; background: var(--bg-alt); margin-bottom: 12px; font-size: var(--fs-sm); color: var(--text-muted); }
.user-signout-section { border-top: 1px solid var(--border); margin-top: 12px; padding-top: 12px; }

/* ============================================================================
   AUTH MODAL
   ============================================================================ */

.auth-divider { border-top: 1px solid var(--border); margin: 16px 0; padding-top: 16px; }
.auth-actions { display: flex; align-items: center; justify-content: space-between; margin-top: 24px; }
.auth-actions button#authSubmitBtn, .auth-actions button#resetPasswordBtn { background: var(--text-strong); border: 1px solid var(--text-strong); color: var(--bg); font-size: var(--fs); font-family: inherit; cursor: pointer; }
.auth-actions button#authSubmitBtn:hover, .auth-actions button#resetPasswordBtn:hover { opacity: 0.9; }
.auth-text-btn { background: none; border: none; color: var(--text-muted); font-size: var(--fs); cursor: pointer; }
.auth-footnote { font-size: var(--fs-sm); color: var(--text-muted); margin-top: 12px; }

/* ============================================================================
   SIGNALS — extra classes
   ============================================================================ */

.scheduled-label { padding: 10px; border-bottom: 1px solid var(--border); font-size: var(--fs-sm); color: var(--text-muted); }
.sig-top-actions { display: flex; gap: 12px; align-items: center; }
.chart-preview iframe { width: 100%; height: 100%; border: 0; pointer-events: none; }

/* Ranges */
.range-hint { color: var(--text-muted); font-size: var(--fs-sm); }
.range-hint.green { color: var(--green); }

/* Presets */
.preset-empty { color: var(--text-muted); font-size: var(--fs); margin-top: 8px; }
.analyst-prompt-input { height: 200px; }

/* Topbar */
.schedule-running { color: var(--green); }

/* ============================================================================
   ONBOARDING
   ============================================================================ */

#onboarding {
  display: none; position: fixed; inset: 0; z-index: 200;
  background: var(--bg); align-items: center; justify-content: center; padding: 16px;
}
.onboarding-content { width: 100%; max-width: 420px; }
.ob-progress { display: flex; align-items: center; gap: 6px; margin-bottom: 32px; }
.ob-dot { height: 1px; width: 6px;  background: rgba(var(--text-strong-rgb), 0.3); transition: all 0.3s; }
.ob-dot.done { background: rgba(var(--text-strong-rgb), 0.3); }
.ob-dot.current { width: 24px; background: var(--text-strong); }
.ob-logo { display: flex; align-items: center; gap: 8px; margin-bottom: 24px; }
.ob-logo-mark { width: 8px; height: 14px; background: var(--text-strong); }
.ob-body { color: var(--text-muted); margin-bottom: 24px; }
.ob-step-item { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 8px; font-size: var(--fs); }
.ob-step-num {
  width: 20px; height: 20px; background: var(--text-10);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: var(--fs-xs);
}
.ob-check-badge {
  width: 28px; height: 28px;
  background: var(--green-10); display: flex; align-items: center; justify-content: center;
  color: var(--green); font-size: 14px; flex-shrink: 0;
}
.ob-choice {
  width: 100%; text-align: left; padding: 12px;
  border: 1px solid var(--border); background: none;
  cursor: pointer; font-size: var(--fs); color: var(--text-strong);
  margin-bottom: 12px;
}
.ob-choice.recommended { border-color: var(--green-10); background: var(--green-10); }
.ob-label { display: block; margin-bottom: 10px; }
.ob-preset {
  padding: 0; border: 1px solid transparent; background: var(--bg-alt);
  color: var(--text-muted); cursor: pointer; font-size: var(--fs);
  display: flex; align-items: center; gap: 6px;
}
.ob-preset.selected { background: var(--text-strong); color: var(--bg); }
.ob-account-chip { padding: 0; border: 1px solid transparent; background: var(--text-strong); color: var(--bg); font-size: var(--fs); cursor: pointer; }
.ob-input {
  width: 100%; background: var(--bg-alt); border: none;
  color: var(--text-strong); font-family: inherit; font-size: inherit; outline: none;
}
.ob-field { margin-bottom: 12px; }
.ob-field label { display: block; margin-bottom: 6px; font-size: var(--fs-sm); color: var(--text-muted); }
.ob-field p { font-size: var(--fs-sm); color: var(--text-muted); margin-top: 6px; }
.ob-field p a { color: var(--blue); }
.ob-analyst {
  width: 100%; text-align: left; padding: 12px;
  border: 1px solid var(--border); background: none;
  margin-bottom: 8px; cursor: pointer; font-size: var(--fs);
}
.ob-analyst.selected { border-color: var(--text-strong); background: var(--text-10); }
.ob-analyst-check {
  width: 16px; height: 16px; border: 1px solid var(--border); border-radius: 3px;
  display: flex; align-items: center; justify-content: center;
  background: none; color: var(--bg); font-size: 10px;
}
.ob-analyst.selected .ob-analyst-check { border-color: var(--text-strong); background: var(--text-strong); }
.ob-nav { display: flex; justify-content: space-between; margin-top: 16px; }
.ob-summary-row { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--border); }
.ob-summary-row:last-child { border-bottom: none; }

/* ============================================================================
   DEV MODE — fab button (panel CSS injected by dev.js at runtime)
   ============================================================================ */

.dev-fab {
  position: fixed; bottom: 16px; right: 16px; z-index: 9999;
  background: #7c3aed; color: white; border: none;
  padding: 6px 12px; border-radius: 9999px;
  font-size: 12px; font-weight: 600; cursor: pointer;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* Settings statics */
.model-cost-hint { margin-left: auto; text-transform: none; color: var(--text-muted); }
.settings-btn-row { display: flex; gap: 8px; }
.settings-btn-row.center { align-items: center; }
.preset-accounts-input { height: 175px; }

