/* ═══════════════════════════════════════════════════
   Findex News Runtime Pro v3.2 — Premium Terminal UI
═══════════════════════════════════════════════════ */
:root {
    --bg:       #07090f;
    --bg2:      #0c1018;
    --bg3:      #111827;
    --bg4:      #1a2236;
    --border:   #1c2840;
    --border2:  #243355;
    --blue:     #3b82f6;
    --blue2:    #60a5fa;
    --green:    #22c55e;
    --red:      #ef4444;
    --amber:    #f59e0b;
    --orange:   #f97316;
    --violet:   #8b5cf6;
    --cyan:     #06b6d4;
    --text:     #e2e8f0;
    --text2:    #94a3b8;
    --text3:    #4b5d7a;
    --font:     -apple-system,BlinkMacSystemFont,'Inter','Segoe UI',sans-serif;
    --mono:     'SFMono-Regular','Consolas',monospace;
    --r:        5px;
    --hh:       50px;
    --fh:       42px;
    --th:       36px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:var(--font)}

/* ── Root ─────────────────────────────────────────── */
#fnrp-root{background:var(--bg);color:var(--text);font-family:var(--font);font-size:13px;line-height:1.5;min-height:100vh}

/* ── Header ───────────────────────────────────────── */
.fh-bar{position:sticky;top:0;z-index:300;height:var(--hh);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 18px;gap:14px}
.fh-logo{font-size:14px;font-weight:800;color:var(--blue2);letter-spacing:-.2px;display:flex;align-items:center;gap:7px;white-space:nowrap}
.fh-logo svg{flex-shrink:0}
.fh-ticker-wrap{flex:1;overflow:hidden;height:18px;position:relative;mask-image:linear-gradient(90deg,transparent,black 5%,black 95%,transparent)}
.fh-ticker{display:flex;gap:28px;white-space:nowrap;font-family:var(--mono);font-size:11px;animation:ticker 50s linear infinite}
.fh-ticker:hover{animation-play-state:paused}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ft-sym{color:var(--text3);font-weight:700;margin-right:3px}
.ft-price{color:var(--text2)}
.ft-chg{font-size:10px}
.ft-chg.up{color:var(--green)}
.ft-chg.down{color:var(--red)}
.fh-live{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;color:var(--green);white-space:nowrap}
.fh-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(1.6)}}
.fh-clock{font-family:var(--mono);font-size:10.5px;color:var(--text3);white-space:nowrap}

/* ── Breaking ribbon ──────────────────────────────── */
.fb-ribbon{background:rgba(239,68,68,.07);border-bottom:1px solid rgba(239,68,68,.2);padding:6px 18px;display:flex;align-items:center;gap:10px;overflow:hidden;display:none}
.fb-ribbon.visible{display:flex}
.fb-label{flex-shrink:0;font-size:9.5px;font-weight:800;letter-spacing:.8px;color:var(--red);text-transform:uppercase;padding:2px 7px;border:1px solid rgba(239,68,68,.35);border-radius:3px;animation:blink 1.4s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.fb-track{flex:1;overflow:hidden;white-space:nowrap;mask-image:linear-gradient(90deg,transparent,black 3%,black 97%,transparent)}
.fb-items{display:inline-flex;gap:40px;animation:ticker 35s linear infinite}
.fb-item{font-size:11.5px;color:var(--text);cursor:pointer;transition:color .15s}
.fb-item:hover{color:var(--blue2)}
.fb-item .fb-src{color:var(--text3);font-size:10px;margin-left:6px}

/* ── Market tabs ──────────────────────────────────── */
.fm-tabs{height:var(--th);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:stretch;padding:0 18px;overflow-x:auto;scrollbar-width:none}
.fm-tabs::-webkit-scrollbar{display:none}
.fm-tab{padding:0 14px;font-size:11.5px;font-weight:600;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:5px;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;transition:color .15s,border-color .15s}
.fm-tab:hover{color:var(--text2)}
.fm-tab.active{color:var(--blue2);border-bottom-color:var(--blue)}
.fm-tab-c{font-size:9px;color:var(--text3);background:var(--bg3);padding:1px 5px;border-radius:10px}

/* ── Filter bar ───────────────────────────────────── */
.ff-bar{position:sticky;top:var(--hh);z-index:200;height:var(--fh);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:5px;overflow-x:auto;scrollbar-width:none}
.ff-bar::-webkit-scrollbar{display:none}
.ff-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;border:1px solid var(--border2);background:transparent;color:var(--text3);font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}
.ff-chip:hover{border-color:var(--blue);color:var(--blue2)}
.ff-chip.active{background:var(--blue);border-color:var(--blue);color:#fff}
.ff-chip.c-breaking.active{background:var(--red);border-color:var(--red)}
.ff-sep{width:1px;height:16px;background:var(--border2);flex-shrink:0}
.ff-sort{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);color:var(--text2);font-size:11px;padding:4px 8px;outline:none;font-family:var(--font)}
.ff-search-w{position:relative;margin-left:auto;flex-shrink:0}
.ff-search-ic{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}
.ff-search{background:var(--bg3);border:1px solid var(--border2);border-radius:20px;color:var(--text);font-size:11.5px;padding:5px 12px 5px 28px;outline:none;width:180px;font-family:var(--font);transition:border-color .15s,width .2s}
.ff-search:focus{border-color:var(--blue);width:230px}
.ff-search::placeholder{color:var(--text3)}
.ff-view{display:flex;border:1px solid var(--border2);border-radius:var(--r);overflow:hidden;flex-shrink:0}
.ff-view-btn{padding:3px 9px;background:transparent;border:none;color:var(--text3);font-size:11px;font-weight:600;transition:all .15s}
.ff-view-btn:hover{background:var(--bg4);color:var(--text2)}
.ff-view-btn.active{background:var(--blue);color:#fff}

/* ── Body layout ──────────────────────────────────── */
.fn-body{display:grid;grid-template-columns:1fr 250px;min-height:calc(100vh - var(--hh) - var(--th) - var(--fh))}
@media(max-width:860px){.fn-body{grid-template-columns:1fr}.fn-sidebar{display:none}}

/* ── Stream ───────────────────────────────────────── */
.fn-stream{border-right:1px solid var(--border);overflow-y:auto}
.fn-banner{background:var(--blue);color:#fff;text-align:center;padding:7px;font-size:11.5px;font-weight:700;cursor:pointer;display:none;letter-spacing:.1px}
.fn-banner.vis{display:block}
.fn-banner:hover{background:#2563eb}

/* ── News item ────────────────────────────────────── */
.fn-item{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;position:relative;animation:slideIn .22s ease}
@keyframes slideIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.fn-item:hover{background:var(--bg3)}
.fn-item.breaking{border-left:2px solid var(--red);padding-left:14px}
.fn-item.critical{border-left:2px solid var(--orange);padding-left:14px}

.fn-meta{display:flex;align-items:center;gap:6px;margin-bottom:5px;flex-wrap:wrap}
.fn-badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:9px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;line-height:1.8}
.b-breaking{background:var(--red);color:#fff;animation:blink 1.2s step-end infinite}
.b-critical{background:var(--orange);color:#fff}
.b-high{background:rgba(245,158,11,.18);color:var(--amber);border:1px solid rgba(245,158,11,.3)}
.b-official{background:rgba(139,92,246,.15);color:#a78bfa;border:1px solid rgba(139,92,246,.3)}
.fn-source{font-size:10.5px;color:var(--text3);font-family:var(--mono)}
.fn-sentiment{font-size:10px;font-weight:700;padding:1px 5px;border-radius:3px}
.sent-bullish{color:var(--green);background:rgba(34,197,94,.1)}
.sent-bearish{color:var(--red);background:rgba(239,68,68,.1)}
.fn-time{margin-left:auto;font-size:10px;color:var(--text3);font-family:var(--mono);white-space:nowrap}

.fn-title{font-size:13px;font-weight:600;line-height:1.45;color:var(--text);display:block;margin-bottom:5px;transition:color .15s}
.fn-item:hover .fn-title{color:var(--blue2)}

.fn-excerpt{font-size:11.5px;color:var(--text2);line-height:1.5;margin-bottom:7px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Compact mode */
.fn-stream.compact .fn-item{padding:7px 16px}
.fn-stream.compact .fn-excerpt,.fn-stream.compact .fn-actions,.fn-stream.compact .fn-reaction-bar{display:none}

/* ── Reaction bar ─────────────────────────────────── */
.fn-reaction-bar{display:flex;align-items:center;gap:5px;margin-top:7px;flex-wrap:wrap}
.fn-react-btn{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:4px;border:1px solid var(--border2);background:transparent;color:var(--text3);font-size:10.5px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font)}
.fn-react-btn:hover{border-color:var(--blue2);color:var(--blue2)}
.fn-react-btn.active-bullish{border-color:var(--green);color:var(--green);background:rgba(34,197,94,.1)}
.fn-react-btn.active-bearish{border-color:var(--red);color:var(--red);background:rgba(239,68,68,.1)}
.fn-react-btn.active-important{border-color:var(--amber);color:var(--amber);background:rgba(245,158,11,.1)}
.fn-react-btn.active-rumor{border-color:var(--violet);color:#a78bfa;background:rgba(139,92,246,.1)}
.fn-react-cnt{font-size:9.5px;opacity:.8}

.fn-actions{display:flex;align-items:center;gap:8px;margin-top:6px}
.fn-action-btn{font-size:10.5px;color:var(--text3);border:1px solid var(--border2);padding:2px 8px;border-radius:3px;background:transparent;cursor:pointer;font-family:var(--font);transition:all .15s}
.fn-action-btn:hover{border-color:var(--blue);color:var(--blue2)}
.fn-action-btn.comment-btn{position:relative}
.fn-cmt-count{position:absolute;top:-5px;right:-5px;background:var(--blue);color:#fff;border-radius:8px;font-size:8px;font-weight:700;padding:0 4px;min-width:14px;text-align:center;line-height:14px}
.fn-views{font-size:10px;color:var(--text3);margin-left:auto;display:flex;align-items:center;gap:3px}

/* ── Sentiment gauge ──────────────────────────────── */
.fn-sentiment-gauge{height:2px;background:var(--border);border-radius:1px;margin-top:6px;overflow:hidden}
.fn-gauge-fill{height:100%;border-radius:1px;transition:width .4s}
.gauge-bull{background:var(--green)}
.gauge-bear{background:var(--red)}
.gauge-neut{background:var(--text3)}

/* ── Load more ────────────────────────────────────── */
.fn-load-more{display:block;width:calc(100% - 32px);margin:12px 16px;padding:9px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);color:var(--text3);font-size:11.5px;font-family:var(--font);font-weight:600;text-align:center;cursor:pointer;transition:all .15s}
.fn-load-more:hover{border-color:var(--blue);color:var(--blue2)}
.fn-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:50px 20px;gap:12px;color:var(--text3)}
.fn-spinner{width:24px;height:24px;border:2px solid var(--border2);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.fn-empty{text-align:center;padding:50px;color:var(--text3);font-size:12px}

/* ── Popup modal ──────────────────────────────────── */
.fn-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px);animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.fn-modal{background:var(--bg2);border:1px solid var(--border2);border-radius:8px;width:100%;max-width:720px;max-height:88vh;overflow-y:auto;display:flex;flex-direction:column;animation:slideUp .2s ease}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.fn-modal::-webkit-scrollbar{width:4px}
.fn-modal::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

.fn-modal-hd{padding:16px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;position:sticky;top:0;background:var(--bg2);z-index:1}
.fn-modal-title{font-size:16px;font-weight:700;line-height:1.4;color:var(--text);flex:1}
.fn-modal-close{background:var(--bg3);border:1px solid var(--border2);color:var(--text3);width:28px;height:28px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .15s}
.fn-modal-close:hover{border-color:var(--red);color:var(--red)}

.fn-modal-body{padding:16px 20px;flex:1}
.fn-modal-meta{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}

/* AI Summary box */
.fn-ai-box{background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.15);border-radius:6px;padding:12px 16px;margin-bottom:16px}
.fn-ai-box-hd{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--blue2);margin-bottom:6px;display:flex;align-items:center;gap:5px}
.fn-ai-box-hd::before{content:'';width:6px;height:6px;background:var(--blue2);border-radius:50%}
.fn-ai-text{font-size:12.5px;color:var(--text2);line-height:1.6}
.fn-ai-loading{color:var(--text3);font-size:11.5px;font-style:italic}

/* AI sentiment meter in modal */
.fn-meter-wrap{margin:12px 0}
.fn-meter-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;display:flex;justify-content:space-between}
.fn-meter-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden;position:relative}
.fn-meter-fill{height:100%;border-radius:3px;transition:width .6s ease}

/* Source link */
.fn-source-link{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--text3);border:1px solid var(--border2);padding:4px 10px;border-radius:4px;transition:all .15s;margin-bottom:14px}
.fn-source-link:hover{border-color:var(--blue);color:var(--blue2)}
.fn-source-link svg{width:11px;height:11px}

/* Modal reactions */
.fn-modal-reactions{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.fn-modal-react{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 16px;border-radius:6px;border:1px solid var(--border2);background:var(--bg3);cursor:pointer;min-width:60px;transition:all .15s}
.fn-modal-react:hover{border-color:var(--blue2)}
.fn-modal-react .r-icon{font-size:18px}
.fn-modal-react .r-label{font-size:9.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.3px}
.fn-modal-react .r-cnt{font-size:13px;font-weight:700;color:var(--text)}
.fn-modal-react.active-bullish{border-color:var(--green);background:rgba(34,197,94,.08)}
.fn-modal-react.active-bearish{border-color:var(--red);background:rgba(239,68,68,.08)}
.fn-modal-react.active-important{border-color:var(--amber);background:rgba(245,158,11,.08)}
.fn-modal-react.active-rumor{border-color:var(--violet);background:rgba(139,92,246,.08)}

/* Market sentiment in modal — unique feature */
.fn-crowd-meter{background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:12px 16px;margin-bottom:16px}
.fn-crowd-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:10px}
.fn-crowd-bar{height:8px;border-radius:4px;overflow:hidden;display:flex;margin-bottom:5px}
.fn-crowd-bull{background:var(--green);transition:flex .6s ease}
.fn-crowd-bear{background:var(--red);transition:flex .6s ease}
.fn-crowd-labels{display:flex;justify-content:space-between;font-size:10px}
.fn-crowd-labels span:first-child{color:var(--green);font-weight:700}
.fn-crowd-labels span:last-child{color:var(--red);font-weight:700}

/* Comments section */
.fn-comments{margin-top:16px;border-top:1px solid var(--border);padding-top:14px}
.fn-comments-hd{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.4px;margin-bottom:12px}
.fn-comment{padding:10px 12px;background:var(--bg3);border-radius:5px;margin-bottom:8px;border-left:2px solid var(--border2)}
.fn-comment.sent-bullish{border-left-color:var(--green)}
.fn-comment.sent-bearish{border-left-color:var(--red)}
.fn-comment-meta{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.fn-comment-author{font-size:11px;font-weight:700;color:var(--text2)}
.fn-comment-time{font-size:10px;color:var(--text3);margin-left:auto;font-family:var(--mono)}
.fn-comment-sent{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px}
.fn-comment-text{font-size:12px;color:var(--text);line-height:1.5}

/* Comment form */
.fn-comment-form{margin-top:14px;background:var(--bg3);border-radius:6px;border:1px solid var(--border);padding:12px}
.fn-comment-form-title{font-size:10.5px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}
.fn-cf-row{display:flex;gap:8px;margin-bottom:8px}
.fn-cf-input{background:var(--bg);border:1px solid var(--border2);border-radius:var(--r);color:var(--text);font-family:var(--font);font-size:12px;padding:7px 10px;outline:none;transition:border-color .15s;flex:1}
.fn-cf-input:focus{border-color:var(--blue)}
.fn-cf-input::placeholder{color:var(--text3)}
.fn-cf-textarea{width:100%;background:var(--bg);border:1px solid var(--border2);border-radius:var(--r);color:var(--text);font-family:var(--font);font-size:12px;padding:8px 10px;outline:none;resize:none;height:70px;margin-bottom:8px;transition:border-color .15s}
.fn-cf-textarea:focus{border-color:var(--blue)}
.fn-cf-submit{background:var(--blue);color:#fff;border:none;border-radius:var(--r);font-size:12px;font-weight:600;padding:7px 16px;cursor:pointer;transition:background .15s}
.fn-cf-submit:hover{background:#2563eb}
.fn-cf-char{font-size:10px;color:var(--text3);margin-left:8px}
.fn-cf-error{font-size:11px;color:var(--red);margin-top:4px}

/* ── Sidebar ──────────────────────────────────────── */
.fn-sidebar{background:var(--bg2);overflow-y:auto;max-height:calc(100vh - var(--hh) - var(--th) - var(--fh));position:sticky;top:calc(var(--hh) + var(--th) + var(--fh))}
.fn-sb-sect{border-bottom:1px solid var(--border)}
.fn-sb-hd{padding:8px 12px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--text3);border-bottom:1px solid var(--border)}
.fn-asset-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:8px}
.fn-asset-btn{padding:6px 8px;border-radius:var(--r);border:1px solid var(--border2);background:var(--bg3);color:var(--text2);font-size:11px;font-weight:700;text-align:center;font-family:var(--mono);transition:all .15s}
.fn-asset-btn:hover{border-color:var(--blue);color:var(--blue2)}
.fn-asset-btn.active{background:rgba(59,130,246,.12);border-color:var(--blue);color:var(--blue2)}
.fn-stat-row{display:flex;justify-content:space-between;padding:7px 12px;font-size:11.5px;border-bottom:1px solid rgba(28,40,64,.5)}
.fn-stat-row:last-child{border-bottom:none}
.fn-stat-lbl{color:var(--text3)}
.fn-stat-val{font-weight:700;color:var(--text);font-family:var(--mono)}
.fn-stat-val.g{color:var(--green)}
.fn-stat-val.r{color:var(--red)}
.fn-topic-row{display:flex;align-items:center;justify-content:space-between;padding:5px 12px;font-size:11px;color:var(--text3);cursor:pointer;transition:all .1s}
.fn-topic-row:hover,.fn-topic-row.active{background:var(--bg3);color:var(--blue2)}
.fn-topic-cnt{font-family:var(--mono);font-size:10px;color:var(--blue2)}

/* Trending sidebar */
.fn-trending-item{padding:8px 12px;border-bottom:1px solid rgba(28,40,64,.5);cursor:pointer;transition:background .1s}
.fn-trending-item:hover{background:var(--bg3)}
.fn-trending-title{font-size:11.5px;color:var(--text);line-height:1.35;margin-bottom:3px}
.fn-trending-meta{display:flex;gap:6px;font-size:10px;color:var(--text3)}
.fn-trending-num{font-weight:700;color:var(--blue2);font-family:var(--mono)}

/* Market mood — unique feature */
.fn-mood{padding:10px 12px}
.fn-mood-title{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:8px}
.fn-mood-track{height:12px;border-radius:6px;overflow:hidden;display:flex;margin-bottom:5px}
.fn-mood-bull{background:linear-gradient(90deg,#16a34a,#22c55e);transition:flex .8s ease}
.fn-mood-neut{background:var(--border)}
.fn-mood-bear{background:linear-gradient(90deg,#ef4444,#b91c1c);transition:flex .8s ease}
.fn-mood-pct{display:flex;justify-content:space-between;font-size:10px;font-weight:700}
.fn-mood-pct .bull{color:var(--green)}
.fn-mood-pct .bear{color:var(--red)}

/* ── Scrollbar ────────────────────────────────────── */
.fn-stream::-webkit-scrollbar,.fn-sidebar::-webkit-scrollbar{width:3px}
.fn-stream::-webkit-scrollbar-thumb,.fn-sidebar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* ── Mobile ───────────────────────────────────────── */
@media(max-width:600px){
    .fh-ticker-wrap{display:none}
    .fn-modal{max-height:95vh}
    .fn-modal-hd{padding:12px 14px}
    .fn-modal-body{padding:12px 14px}
}
