:root {
  --bg:#f5f6f8;--surface:#ffffff;--surface2:#f0f2f5;
  --border:#e2e5ea;--border2:#d0d4db;
  --text:#111827;--text2:#374151;--muted:#6b7280;--faint:#9ca3af;
  --green:#059669;--green-bg:#ecfdf5;--green-b:#a7f3d0;
  --red:#dc2626;--red-bg:#fef2f2;--red-b:#fecaca;
  --amber:#d97706;--amber-bg:#fffbeb;
  --blue:#2563eb;--blue-bg:#eff6ff;--blue-b:#bfdbfe;
  --cr:10px;--shadow:0 1px 3px rgba(0,0,0,0.08);--shadow2:0 4px 12px rgba(0,0,0,0.08);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:14px;line-height:1.6;min-height:100vh}
nav{background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:58px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:30px;height:30px;background:var(--text);border-radius:7px;display:flex;align-items:center;justify-content:center}
.logo-icon svg{width:14px;height:14px}
.logo-name{font-family:'DM Serif Display',serif;font-size:18px;color:var(--text)}
.logo-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-b);padding:2px 7px;border-radius:4px}
.nav-time{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.main{max-width:1160px;margin:0 auto;padding:24px 20px 80px;width:100%}
.search-section{margin-bottom:24px}
.search-row{display:flex;gap:10px;margin-bottom:12px}
.ti{flex:1;height:46px;padding:0 14px;background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--cr);color:var(--text);font-family:'DM Mono',monospace;font-size:15px;font-weight:500;letter-spacing:2px;text-transform:uppercase;outline:none;box-shadow:var(--shadow);transition:border-color .15s,box-shadow .15s}
.ti::placeholder{letter-spacing:.3px;font-size:13px;color:var(--faint);text-transform:none;font-family:'Inter',sans-serif}
.ti:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.btn-a{height:46px;padding:0 22px;background:var(--text);color:white;border:none;border-radius:var(--cr);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-a:hover{background:#374151;transform:translateY(-1px);box-shadow:var(--shadow2)}
.btn-a:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.chips{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.chips-lbl{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.8px;margin-right:3px}
.chip{background:var(--surface);border:1px solid var(--border2);border-radius:6px;padding:4px 10px;font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);cursor:pointer;transition:all .15s;box-shadow:var(--shadow)}
.chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-bg)}
.s-empty{text-align:center;padding:80px 0;color:var(--muted)}
.s-empty h2{font-family:'DM Serif Display',serif;font-size:22px;font-weight:400;color:var(--text2);margin:14px 0 8px}
.s-empty p{font-size:13px;max-width:360px;margin:0 auto}
.ei{width:52px;height:52px;background:var(--surface);border:1px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto}
.s-load{display:none;flex-direction:column;align-items:center;padding:80px 0;gap:12px}
.s-load.on{display:flex}
.spin{width:26px;height:26px;border:2px solid var(--border2);border-top-color:var(--text);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* Time-based AI-generation progress bar (fresh analyses only). */
.ai-prog{display:flex;flex-direction:column;gap:7px;padding:8px 4px;max-width:340px}
.ai-prog-label{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:7px}
.ai-prog-track{height:6px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;overflow:hidden}
.ai-prog-fill{height:100%;width:0;background:var(--blue);border-radius:4px;transition:width .25s ease-out}
.ltick{font-family:'DM Mono',monospace;font-size:20px;font-weight:500;letter-spacing:3px;color:var(--text)}
.lbar-w{width:220px;height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.lbar-f{height:100%;background:var(--text);border-radius:2px;width:0;transition:width .5s ease}
.lmsg{font-size:12px;color:var(--muted)}
.s-err{display:none;padding:14px 18px;border:1px solid var(--red-b);border-radius:var(--cr);background:var(--red-bg);color:var(--red);font-size:13px}
.s-err.on{display:block}
.results{display:none}.results.on{display:block}
.tick-hdr{background:var(--surface);border:1px solid var(--border);border-radius:var(--cr);padding:18px 22px;margin-bottom:16px;box-shadow:var(--shadow);display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.tick-left{flex:1;min-width:180px}
.tick-sym{font-family:'DM Mono',monospace;font-size:26px;font-weight:500;color:var(--text);letter-spacing:1px;line-height:1}
.tick-co{font-size:13px;color:var(--muted);margin-top:3px}
.tick-tags{display:flex;gap:6px;margin-top:9px;flex-wrap:wrap;align-items:center}
.tag{font-size:11px;font-weight:500;padding:2px 8px;border-radius:5px}
.tag-s{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-b)}
.tag-e{background:var(--surface2);color:var(--muted);border:1px solid var(--border)}
.tag-l{background:var(--green-bg);color:var(--green);border:1px solid var(--green-b);display:flex;align-items:center;gap:4px}
.ldot{width:5px;height:5px;border-radius:50%;background:var(--green);animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.tick-right{display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap}
.prc-block{text-align:right}
.prc-val{font-family:'DM Mono',monospace;font-size:24px;font-weight:500;color:var(--text);line-height:1}
.prc-chg{font-size:13px;font-weight:500;margin-top:2px}
.pos{color:var(--green)}.neg{color:var(--red)}.neu{color:var(--muted)}
canvas#spark{display:block;margin-top:5px}
.sig-block{text-align:center}
.sig-lbl{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:5px}
.sig-val{font-size:12px;font-weight:700;letter-spacing:.8px;padding:5px 12px;border-radius:6px}
.sig-bull{background:var(--green-bg);color:var(--green);border:1px solid var(--green-b)}
.sig-bear{background:var(--red-bg);color:var(--red);border:1px solid var(--red-b)}
.sig-neut{background:var(--amber-bg);color:var(--amber);border:1px solid #fde68a}
.score-banner{background:var(--surface);border:1px solid var(--border);border-radius:var(--cr);padding:16px 22px;margin-bottom:16px;box-shadow:var(--shadow)}
.sb-title{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);font-weight:600;margin-bottom:14px}
.scores-row{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.si{flex:1;min-width:85px}
.si-lbl{font-size:11px;color:var(--muted);margin-bottom:5px;font-weight:500}
.si-bar{height:6px;background:var(--surface2);border-radius:3px;position:relative;margin-bottom:4px;overflow:visible}
.si-fill{height:100%;border-radius:3px;position:absolute;transition:all .6s ease}
.si-mid{position:absolute;left:50%;top:0;width:1px;height:100%;background:var(--border2)}
.si-num{font-family:'DM Mono',monospace;font-size:13px;font-weight:600}
.so-box{border-radius:8px;padding:10px 16px;text-align:center;min-width:100px;flex-shrink:0;transition:background .3s,color .3s,border-color .3s}
.so-lbl{font-size:10px;text-transform:uppercase;letter-spacing:1px;opacity:.6;margin-bottom:3px}
.so-val{font-family:'DM Mono',monospace;font-size:22px;font-weight:500}
.so-sub{font-size:10px;opacity:.55;margin-top:1px}

/* ── Ticker search modal ── */
.search-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:80px}
.search-modal{background:var(--surface);border-radius:14px;width:min(560px,95vw);box-shadow:0 24px 60px rgba(0,0,0,.35);overflow:hidden}
.search-modal-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}
.search-modal-input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:9px 14px;font-size:14px;color:var(--text);outline:none}
.search-modal-input:focus{border-color:var(--blue)}
.search-modal-btn{padding:9px 16px;border-radius:8px;background:var(--blue);color:#fff;border:none;cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap}
.search-modal-results{max-height:380px;overflow-y:auto}
.search-modal-result{display:flex;align-items:center;gap:12px;padding:11px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}
.search-modal-result:hover{background:var(--surface2)}
.search-modal-result:last-child{border-bottom:none}
.smr-symbol{font-family:'DM Mono',monospace;font-size:13px;font-weight:700;color:var(--blue);min-width:70px}
.smr-name{font-size:12px;color:var(--text);flex:1}
.smr-exch{font-size:10px;color:var(--muted);min-width:50px;text-align:right}
.smr-type{font-size:10px;padding:1px 5px;border-radius:3px;background:var(--surface2);color:var(--muted)}
.search-modal-empty{padding:24px;text-align:center;color:var(--muted);font-size:13px}
.search-trigger-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:9px 14px;font-size:13px;color:var(--muted);cursor:pointer;text-align:left;display:flex;align-items:center;gap:8px;width:100%;transition:border-color .15s}
.search-trigger-btn:hover{border-color:var(--blue)}
.search-trigger-btn .stb-ticker{font-family:'DM Mono',monospace;font-weight:700;color:var(--text);font-size:14px}
.tab-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--cr);padding:0 8px;margin-bottom:14px;box-shadow:var(--shadow);display:flex;overflow-x:auto}
.tab{padding:11px 10px;font-size:11.5px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color .15s,border-color .15s}
.tab:hover{color:var(--text)}
.tab.on{color:var(--blue);border-bottom-color:var(--blue);font-weight:600}
.panel{display:none !important}.panel.on{display:block !important}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--cr);padding:16px 20px;margin-bottom:12px;box-shadow:var(--shadow)}
.ctitle{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.4px;color:var(--muted);margin-bottom:13px;display:flex;align-items:center;justify-content:space-between}
.prose{font-size:13px;line-height:1.8;color:var(--text2)}
.prose p{margin-bottom:9px}.prose p:last-child{margin-bottom:0}
.mgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:8px;margin-bottom:13px}
.mcell{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px}
.mc-lbl{font-size:11px;color:var(--muted);margin-bottom:3px}
.mc-val{font-family:'DM Mono',monospace;font-size:14px;font-weight:500;color:var(--text)}
.mc-val.gn{color:var(--green)}.mc-val.rd{color:var(--red)}
.abar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.abar-lbl{font-size:12px;color:var(--muted);width:40px;flex-shrink:0}
.abar-bg{flex:1;height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}
.abar-fill{height:100%;border-radius:3px}
.ab-b{background:var(--green)}.ab-h{background:var(--amber)}.ab-s{background:var(--red)}
.abar-pct{font-family:'DM Mono',monospace;font-size:11px;color:var(--text);width:30px;text-align:right}
.sgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(115px,1fr));gap:8px}
.sc{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:9px 11px}
.sc-n{font-size:11px;color:var(--muted);margin-bottom:3px}
.sc-v{font-size:12px;font-weight:600}
.sv-bull{color:var(--green)}.sv-bear{color:var(--red)}.sv-neut{color:var(--amber)}
.rbar{height:6px;border-radius:3px;position:relative;margin:7px 0 3px;overflow:hidden;background:linear-gradient(90deg,var(--green),var(--amber),var(--red))}
.rneedle{position:absolute;top:-4px;width:2px;height:14px;background:var(--text);border-radius:1px;transform:translateX(-50%)}
.rlabels{display:flex;justify-content:space-between;font-size:10px;color:var(--muted)}
.nitem{padding:11px 0;border-bottom:1px solid var(--border);display:flex;gap:10px}
.nitem:last-child{border-bottom:none;padding-bottom:0}
.ndot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px}
.ndot.pos{background:var(--green)}.ndot.neg{background:var(--red)}.ndot.neu{background:var(--border2)}
.nh{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px;line-height:1.4}
.nh a{color:inherit;text-decoration:none}.nh a:hover{color:var(--blue)}
.nm{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.two-col{grid-template-columns:1fr}}
.sm-bar-w{display:flex;height:8px;background:var(--surface2);border-radius:4px;overflow:hidden;margin:8px 0 12px}
.sm-bull{background:var(--green)}.sm-bear{background:var(--red)}
.tweet{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:9px 11px;margin-bottom:7px}
.tweet-user{font-size:11px;color:var(--blue);font-family:'DM Mono',monospace;margin-bottom:3px}
.tweet-text{font-size:12px;color:var(--text2);line-height:1.5}
.tweet-meta{font-size:11px;color:var(--muted);margin-top:3px}
.ri-title{font-size:12px;font-weight:500;color:var(--text);margin-bottom:3px;line-height:1.4}
.ri-title a{color:inherit;text-decoration:none}.ri-title a:hover{color:var(--blue)}
.ri-meta{font-size:11px;color:var(--muted);display:flex;gap:8px;font-family:'DM Mono',monospace}
.score-up{color:var(--green)}
.no-data{font-size:13px;color:var(--muted);padding:10px 0;text-align:center}
.ptable-w{overflow-x:auto}
.ptable{width:100%;border-collapse:collapse;font-size:12px}
.ptable th{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:7px 9px;text-align:left;border-bottom:1px solid var(--border);background:var(--surface2);white-space:nowrap}
.ptable td{padding:8px 9px;border-bottom:1px solid var(--border);color:var(--text);font-family:'DM Mono',monospace;font-size:11px;white-space:nowrap}
.ptable tr:last-child td{border-bottom:none}
.ptable tr.hl td{background:#eff6ff}
.ptable tr:hover td{background:var(--surface2)}
.ptable .nc{font-family:'Inter',sans-serif;font-size:12px;color:var(--muted)}
.rpill{display:inline-block;font-size:10px;padding:2px 7px;border-radius:4px;font-family:'Inter',sans-serif;font-weight:600}
.r-buy{background:var(--green-bg);color:var(--green)}
.r-hold{background:var(--amber-bg);color:var(--amber)}
.r-sell{background:var(--red-bg);color:var(--red)}
.ins-summary{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.ins-stat{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 13px;flex:1;min-width:90px}
.ins-stat-lbl{font-size:11px;color:var(--muted);margin-bottom:3px}
.ins-stat-val{font-family:'DM Mono',monospace;font-size:14px;font-weight:600}
.ins-buy{color:var(--green)}.ins-sell{color:var(--red)}
.ins-table{width:100%;border-collapse:collapse;font-size:12px}
.ins-table th{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:7px 9px;border-bottom:1px solid var(--border);background:var(--surface2);text-align:left}
.ins-table td{padding:8px 9px;border-bottom:1px solid var(--border);font-size:12px;color:var(--text2)}
.ins-table tr:last-child td{border-bottom:none}
.ins-table tr:hover td{background:var(--surface2)}
.bull-card{background:var(--green-bg);border:1px solid var(--green-b);border-radius:var(--cr);padding:16px 18px}
.bear-card{background:var(--red-bg);border:1px solid var(--red-b);border-radius:var(--cr);padding:16px 18px}
.ct{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:11px}
.bull-card .ct{color:var(--green)}.bear-card .ct{color:var(--red)}
.pts{list-style:none;display:flex;flex-direction:column;gap:7px}
.pts li{font-size:13px;line-height:1.6;color:var(--text2);padding-left:12px;position:relative}
.pts li::before{content:'';position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%}
.bull-card .pts li::before{background:var(--green)}.bear-card .pts li::before{background:var(--red)}
.cpill{display:inline-flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;padding:5px 11px;font-size:13px;font-weight:600;color:var(--text);margin-bottom:12px}
.cdot{width:7px;height:7px;border-radius:50%}
.tgt-big{font-family:'DM Mono',monospace;font-size:26px;font-weight:500;color:var(--green)}
.tgt-range{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);margin-top:2px;margin-bottom:11px}
.sscore{font-size:11px;font-weight:600;padding:2px 9px;border-radius:4px;font-family:'DM Mono',monospace}
.ss-pos{background:var(--green-bg);color:var(--green);border:1px solid var(--green-b)}
.ss-neg{background:var(--red-bg);color:var(--red);border:1px solid var(--red-b)}
.ss-neu{background:var(--amber-bg);color:var(--amber);border:1px solid #fde68a}
.rationale{font-size:12px;color:var(--muted);font-style:italic;border-left:3px solid var(--border2);padding-left:10px;margin-top:12px;line-height:1.6}
.src-row{display:flex;align-items:flex-start;gap:10px}
.src-desc{font-size:12px;color:var(--text2);line-height:1.65;padding-top:2px}
.src-desc code{background:var(--surface2);border:1px solid var(--border);border-radius:3px;padding:0px 4px;font-size:11px;color:var(--blue)}
.src-pill{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;white-space:nowrap;flex-shrink:0;margin-top:2px;letter-spacing:.3px}
.src-ai{background:#059669;color:white}
.src-calc{background:#6b7280;color:white}
.src-st{background:#8b5cf6;color:white}
.src-fmp{background:#4f46e5;color:white}
.src-sec{background:#374151;color:white}
.history-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--cr);padding:14px 18px;margin-bottom:16px;box-shadow:var(--shadow)}
.history-bar-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:0;gap:10px;flex-wrap:wrap}
.history-bar-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted)}
.history-empty{font-size:12px;color:var(--faint);padding:4px 0}
.history-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.history-chip{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;padding:6px 11px;cursor:pointer;transition:all .15s}
.history-chip:hover{border-color:var(--blue);background:var(--blue-bg)}
.hc-ticker{font-family:"DM Mono",monospace;font-size:12px;font-weight:600;color:var(--text)}
.hc-score{font-size:11px;font-weight:700;font-family:"DM Mono",monospace;padding:1px 6px;border-radius:4px}
.hc-score-pos{background:var(--green-bg);color:var(--green)}
.hc-score-neg{background:var(--red-bg);color:var(--red)}
.hc-score-neu{background:var(--amber-bg);color:var(--amber)}
.hc-date{font-size:10px;color:var(--faint);font-family:"DM Mono",monospace}
.hc-remove{font-size:14px;color:var(--faint);line-height:1;margin-left:2px;padding:0 2px}
.hc-remove:hover{color:var(--red)}
.history-clear{font-size:11px;color:var(--faint);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px}
.history-clear:hover{color:var(--red);background:var(--red-bg)}
.btn-pdf{height:36px;padding:0 14px;background:var(--surface);border:1px solid var(--border2);
  border-radius:var(--cr);font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;transition:all .15s;box-shadow:var(--shadow)}
.btn-pdf:hover{border-color:var(--red);color:var(--red);background:var(--red-bg)}
.btn-pdf:disabled{opacity:.45;cursor:not-allowed}
.btn-pdf svg{width:14px;height:14px;flex-shrink:0}
/* ── Compare mode ── */
.nav-mode-btns{display:flex;gap:4px;background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:3px}
.nav-mode-btn{font-size:12px;font-weight:500;padding:4px 14px;border-radius:5px;border:none;cursor:pointer;background:transparent;color:var(--muted);transition:all .15s}
.nav-mode-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}
.cmp-section{display:none}.cmp-section.on{display:block}
.cmp-search{display:grid;grid-template-columns:1fr auto 1fr auto;gap:10px;align-items:center;margin-bottom:20px}
@media(max-width:640px){.cmp-vs{display:none}}
.cmp-vs{font-family:'DM Mono',monospace;font-size:16px;font-weight:600;color:var(--muted);text-align:center}
.cmp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:14px}
@media(max-width:580px){.cmp-grid{grid-template-columns:1fr}}
.cmp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--cr);padding:16px 18px;box-shadow:var(--shadow)}
.cmp-card.winner{border-color:var(--green);border-width:2px;background:var(--green-bg)}
.cmp-card.loser{opacity:.85}
.cmp-ticker-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.cmp-sym{font-family:'DM Mono',monospace;font-size:20px;font-weight:600;color:var(--text)}
.cmp-name{font-size:12px;color:var(--muted);margin-top:2px}
.cmp-price{font-family:'DM Mono',monospace;font-size:16px;font-weight:500}
.cmp-winner-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;background:var(--green);color:white;padding:2px 8px;border-radius:4px}
.cmp-score-big{font-family:'DM Mono',monospace;font-size:36px;font-weight:600;text-align:center;padding:10px 0 4px}
.cmp-score-lbl{font-size:11px;color:var(--muted);text-align:center;margin-bottom:12px;text-transform:uppercase;letter-spacing:.8px}
.cmp-section-scores{display:flex;flex-direction:column;gap:6px}
.cmp-sc-row{display:flex;align-items:center;gap:8px}
.cmp-sc-lbl{font-size:11px;color:var(--muted);width:90px;flex-shrink:0}
.cmp-sc-bar{flex:1;height:6px;background:var(--surface2);border-radius:3px;position:relative;overflow:visible}
.cmp-sc-mid{position:absolute;left:50%;top:0;width:1px;height:100%;background:var(--border2)}
.cmp-sc-fill{height:100%;border-radius:3px;position:absolute;transition:all .5s}
.cmp-sc-num{font-family:'DM Mono',monospace;font-size:11px;font-weight:600;width:28px;text-align:right}
.cmp-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);margin:16px 0 10px;border-bottom:1px solid var(--border);padding-bottom:6px}
.cmp-metric-row{display:flex;align-items:center;gap:0;margin-bottom:4px}
.cmp-metric-lbl{font-size:12px;color:var(--muted);width:130px;flex-shrink:0}
.cmp-metric-val{font-family:'DM Mono',monospace;font-size:12px;font-weight:500;flex:1}
.cmp-metric-win{color:var(--green);font-weight:700}
.cmp-metric-lose{color:var(--muted)}
.cmp-verdict{background:var(--surface2);border:1px solid var(--border);border-radius:var(--cr);padding:16px 18px;margin-top:4px}
.cmp-verdict-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);margin-bottom:10px}
.cmp-verdict-cat{font-size:12px;color:var(--muted);padding:5px 8px;display:flex;align-items:center;border-bottom:1px solid var(--border)}.cmp-verdict-cell{font-size:12px;text-align:center;padding:5px 8px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center}#cmpVerdictTable{display:grid;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-top:8px}#cmpVerdictTable>div:nth-child(-n+5){font-size:11px;font-weight:700;background:var(--surface2);padding:6px 8px;border-bottom:1px solid var(--border)}.cmp-vcell-win{background:var(--green-bg);color:var(--green);font-weight:700}.cmp-vcell-lose{background:var(--surface2);color:var(--muted)}#cmpValTable,#cmpHealthTable{display:grid;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-top:8px}.cmp-metric-hdr{font-size:11px;font-weight:700;padding:6px 10px;background:var(--surface2);border-bottom:1px solid var(--border)}.cmp-metric-label{font-size:12px;color:var(--muted);padding:5px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center}.cmp-metric-val{font-size:12px;font-family:'DM Mono',monospace;padding:5px 10px;text-align:center;border-bottom:1px solid var(--border);border-left:1px solid var(--border);display:flex;align-items:center;justify-content:center}.cmp-metric-win{color:var(--green);font-weight:700}
.cmp-vcell-tie{background:var(--amber-bg);color:var(--amber)}
.cmp-empty{text-align:center;padding:60px 0;color:var(--muted)}
.ticker-search-wrap{position:relative;flex:1}.ticker-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.14);z-index:200;overflow:hidden;display:none}.ticker-dropdown.open{display:block}.ticker-result{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border)}.ticker-result:last-child{border-bottom:none}.ticker-result:hover{background:var(--surface2)}.tr-symbol{font-family:"DM Mono",monospace;font-weight:700;font-size:13px;color:var(--blue);min-width:80px}.tr-name{font-size:12px;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tr-exch{font-size:10px;color:var(--faint);white-space:nowrap}.tr-type{font-size:9px;background:var(--surface2);border:1px solid var(--border);border-radius:3px;padding:1px 5px;color:var(--muted);white-space:nowrap}.sec-filing-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:10px}.sec-filing-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.sec-form-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px;white-space:nowrap}.sec-summary-box{font-size:12px;color:var(--text2);line-height:1.7;margin-top:10px;padding:10px 12px;background:var(--surface);border-radius:7px;border:1px solid var(--border)}.sec-summarise-btn{font-size:11px;font-weight:600;padding:5px 12px;border-radius:7px;background:var(--blue);color:#fff;border:none;cursor:pointer;transition:opacity .15s}.sec-summarise-btn:hover{opacity:.85}.sec-abort-btn{font-size:11px;padding:5px 12px;border-radius:7px;background:var(--surface2);color:var(--red);border:1px solid var(--red);cursor:pointer}.sec-summarise-btn:disabled{opacity:.5;cursor:not-allowed}
.cmp-loading{display:none;text-align:center;padding:50px 0;color:var(--muted)}
.cmp-loading.on{display:block}

.inst-table{width:100%;border-collapse:collapse;font-size:12px}
.inst-table th{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:7px 9px;border-bottom:1px solid var(--border);background:var(--surface2);text-align:left;white-space:nowrap}
.inst-table td{padding:8px 9px;border-bottom:1px solid var(--border);color:var(--text2);font-size:12px}
.inst-table tr:last-child td{border-bottom:none}
.inst-table tr:hover td{background:var(--surface2)}
.chg-up{color:var(--green);font-weight:600}
.chg-dn{color:var(--red);font-weight:600}
.oi-buy{color:var(--green);font-weight:600}
.oi-sell{color:var(--red);font-weight:600}
.sec-pill{display:inline-block;font-size:10px;padding:1px 7px;border-radius:4px;font-weight:600;background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-b)}
.inst-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin-bottom:14px}
.rc-feed{display:flex;flex-direction:column;gap:8px}
.rc-item{display:flex;align-items:flex-start;gap:12px;padding:11px 14px;border-radius:8px;border:1px solid var(--border)}
.rc-item.rc-up{background:var(--green-bg);border-color:var(--green-b)}
.rc-item.rc-down{background:var(--red-bg);border-color:var(--red-b)}
.rc-item.rc-sec{background:var(--blue-bg);border-color:var(--blue-b)}
.rc-icon{font-size:16px;flex-shrink:0;margin-top:1px;width:22px;text-align:center}
.rc-body{flex:1;min-width:0}
.rc-actor{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.rc-action{font-size:12px;color:var(--text2);margin-bottom:2px}
.rc-detail{font-size:11px;color:var(--muted);font-family:"DM Mono",monospace}
.rc-meta{font-size:10px;color:var(--faint);font-family:"DM Mono",monospace;white-space:nowrap;padding-top:2px}
.rc-source-pill{display:inline-block;font-size:10px;font-weight:600;padding:1px 6px;border-radius:3px;margin-right:5px}
.rcs-form4{background:#fef3c7;color:#92400e}
.rcs-13f{background:#ede9fe;color:#5b21b6}
.rcs-sec{background:#dbeafe;color:#1e40af}
.upg-table{width:100%;border-collapse:collapse;font-size:12px}
.upg-table th{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:7px 9px;border-bottom:1px solid var(--border);background:var(--surface2);text-align:left}
.upg-table td{padding:8px 9px;border-bottom:1px solid var(--border);color:var(--text2)}
.upg-table tr:last-child td{border-bottom:none}
.upg-table tr:hover td{background:var(--surface2)}
.upg-up{color:var(--green);font-weight:600}
.upg-down{color:var(--red);font-weight:600}
.upg-neu{color:var(--amber);font-weight:600}
.grade-pill{display:inline-block;font-size:11px;padding:1px 7px;border-radius:4px;font-weight:500}
.gp-buy{background:var(--green-bg);color:var(--green)}
.gp-sell{background:var(--red-bg);color:var(--red)}
.gp-hold{background:var(--amber-bg);color:var(--amber)}
.price-chart-wrap canvas{display:block;width:100%!important}
.w-slider-row{display:flex;flex-direction:column;gap:4px}
.w-slider-row label{font-size:11px;color:var(--text2);font-weight:500;display:flex;justify-content:space-between}
.w-slider-row input[type=range]{width:100%;accent-color:var(--blue);height:4px}
</style>

/* Exchange suffix helper tiles */
.exch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px;margin-top:12px}
.exch-tile{font-size:12px;padding:6px 10px;background:var(--surface2);border-radius:6px;border:1px solid var(--border)}
.exch-tile strong{font-family:'DM Mono',monospace;color:var(--blue)}

/* ============================================================
   MOBILE OPTIMISATION
   Tightens spacing, ensures rows wrap/scroll, enlarges tap
   targets, and prevents horizontal overflow on small screens.
   ============================================================ */

/* Tablets and below */
@media (max-width: 820px){
  .main{padding:16px 14px 64px}
  nav{padding:0 16px}
  .score-banner{padding:14px 16px}
  .tick-hdr{padding:16px 16px}
}

/* Phones */
@media (max-width: 560px){
  /* Layout width: reclaim horizontal space */
  .main{padding:12px 10px 56px}
  nav{padding:0 12px; height:54px}

  /* Header: hide the centre "cataldi.ai" link to avoid crowding the
     logo + mode buttons on a narrow bar; logo links home anyway. */
  nav > a[href*="cataldi.ai"]{display:none}
  .logo-name{font-size:16px}
  .nav-time{display:none}                 /* clock is non-essential on mobile */
  .nav-mode-btn{padding:5px 12px; font-size:13px}  /* bigger tap target */

  /* Search row: stack input above the Analyze button so neither is cramped */
  .search-row{flex-direction:column; gap:8px}
  .search-row .ti{width:100%}
  .search-row > button{width:100%; min-height:46px}

  /* Quick-ticker chips: allow wrap, comfortable tap size */
  .chips{gap:5px}
  .chip{padding:6px 11px; font-size:12px}

  /* Scorecard: items already wrap; give each a sensible min so they
     form a tidy 3-up grid rather than ragged rows, and let the
     Overall box sit full-width on its own line. */
  .scores-row{gap:8px}
  .si{min-width:0; flex:1 1 28%}          /* ~3 per row */
  .so-box{width:100% !important; min-width:0 !important; margin-top:6px}      /* Overall drops below, full width */

  /* Ticker header: price/signal block wraps under the name cleanly */
  .tick-hdr{padding:14px 14px; gap:12px}
  .tick-right{width:100%; justify-content:space-between}

  /* Tabs already scroll (overflow-x:auto); enlarge tap target slightly */
  .tab{padding:12px 11px; font-size:12px}

  /* Scroll affordance: fade the right (and left) edge of the tab bar so it's
     visually obvious the strip scrolls horizontally. The fades are toggled by
     .at-start / .at-end classes set by a scroll listener (app.js). */
  .tab-bar-wrap{position:relative}
  .tab-bar-wrap::before,
  .tab-bar-wrap::after{
    content:""; position:absolute; top:1px; bottom:1px; width:34px;
    pointer-events:none; z-index:2; opacity:1; transition:opacity .2s;
  }
  .tab-bar-wrap::before{
    left:1px; border-radius:var(--cr) 0 0 var(--cr);
    background:linear-gradient(to right, var(--surface) 30%, rgba(255,255,255,0));
  }
  .tab-bar-wrap::after{
    right:1px; border-radius:0 var(--cr) var(--cr) 0;
    background:linear-gradient(to left, var(--surface) 30%, rgba(255,255,255,0));
  }
  /* Hide the relevant fade at each scroll extreme */
  .tab-bar-wrap.at-start::before{opacity:0}
  .tab-bar-wrap.at-end::after{opacity:0}
  /* Thin scroll indicator under the bar as a secondary cue */
  .tab-bar{scrollbar-width:thin}

  /* Metric tiles: 2-up on phones instead of squeezing 3-4 */
  .mgrid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:7px}
  .sgrid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:7px}

  /* Cards: a touch less inner padding to fit more on screen */
  .card{padding:14px 14px}

  /* Buttons / interactive: ensure min 40px tap height where reasonable */
  .search-trigger-btn{min-height:42px}
  .sec-summarise-btn,.sec-abort-btn{padding:8px 14px}
}

/* Very small phones */
@media (max-width: 380px){
  .si{flex:1 1 45%}                        /* 2 per row on tiny screens */
  .logo-badge{display:none}               /* trim the AI badge if space is tight */
}
