:root {
  --bg: #06060a; --surface: rgba(255,255,255,0.035); --surface-h: rgba(255,255,255,0.06);
  --border: rgba(255,255,255,0.06); --border-h: rgba(255,255,255,0.12);
  --t1: rgba(255,255,255,0.92); --t2: rgba(255,255,255,0.55); --t3: rgba(255,255,255,0.3);
  --accent: #818cf8; --accent-bg: rgba(129,140,248,0.1);
  --crit: #f87171; --high: #fbbf24; --med: #60a5fa; --low: #6b7280;
  --radius: 14px; --glass: blur(24px);
  --green: #34d399; --blue: #60a5fa; --amber: #fbbf24; --purple: #a78bfa;
  color-scheme: dark;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);background-image:radial-gradient(ellipse at 50% 0%,rgba(129,140,248,0.03) 0%,transparent 50%);color:var(--t1);-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:var(--accent);text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}
.muted{color:var(--t3);font-size:14px}
.hidden{display:none!important}

.glass-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:var(--glass);-webkit-backdrop-filter:var(--glass);transition:border-color .2s,transform .2s}
.glass-card:hover{border-color:var(--border-h)}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(6,6,10,0.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);padding:12px 0}
header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(129,140,248,0.3),transparent)}
.header-row{display:flex;align-items:center;gap:16px}
.brand{font-size:15px;font-weight:600;color:var(--t1);white-space:nowrap;letter-spacing:-.3px}
.brand span{font-weight:400;color:var(--t2)}
nav{display:flex;gap:2px;margin-left:auto}
.nav-btn{background:transparent;border:1px solid transparent;border-radius:8px;padding:6px 14px;font-size:12.5px;font-weight:500;color:var(--t2);cursor:pointer;font-family:inherit;transition:all .2s}
.nav-btn:hover{color:var(--t1)}
.nav-btn.active{background:var(--accent-bg);color:var(--accent);border-color:rgba(129,140,248,0.15)}
.nav-submit{color:var(--accent);border-color:rgba(129,140,248,0.15)}
.search{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 12px;color:var(--t1);font-size:12.5px;width:180px;outline:none;font-family:inherit;transition:border-color .2s}
.search:focus{border-color:var(--accent)}
.search::placeholder{color:var(--t3)}

/* Hero */
.hero{padding:48px 0 40px;border-bottom:1px solid var(--border);background-image:radial-gradient(rgba(129,140,248,0.04) 1px,transparent 1px);background-size:24px 24px}
.hero-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:center}
.kicker{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:14px}
.hero h1{font-size:36px;font-weight:800;line-height:1.15;letter-spacing:-1px;margin-bottom:14px}
.hero-sub{font-size:14px;color:var(--t2);line-height:1.6;margin-bottom:24px}
.stat-row{display:flex;gap:10px;flex-wrap:wrap}
.stat-chip{display:flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:5px 14px;font-size:12px;color:var(--t2)}
.stat-chip strong{color:var(--t1);font-weight:700}
.stat-chip.live{color:#34d399;border-color:rgba(52,211,153,0.2);background:rgba(52,211,153,0.06)}
.pulse{width:6px;height:6px;border-radius:50%;background:#34d399;box-shadow:0 0 6px #34d399;animation:pls 2s ease infinite}
@keyframes pls{0%,100%{opacity:1}50%{opacity:.3}}

.hero-chart-wrap{padding:16px;overflow:hidden}
.hero-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.chart-label{font-size:12px;font-weight:600;color:var(--t2)}
.chart-src{font-size:10px;color:var(--t3)}
.hero-chart-wrap canvas{width:100%!important;height:160px!important}
.hero-chart-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.kpi{text-align:center}
.kpi-val{display:block;font-size:18px;font-weight:700;color:var(--t1);text-shadow:0 0 20px rgba(129,140,248,0.2)}
.kpi-lbl{display:block;font-size:10px;color:var(--t3);margin-top:2px}

/* Stats bar */
.stats-bar{padding:24px 0;border-bottom:1px solid var(--border)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat-card{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;transition:border-color .2s,background .2s}
.stat-card:hover{background:rgba(255,255,255,0.04)}
.sc-icon{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:rgba(255,255,255,0.7)}
.sc-icon svg{width:18px;height:18px}
.stat-card strong{display:block;font-size:20px;font-weight:700;color:var(--t1);letter-spacing:-.3px;text-shadow:0 0 20px rgba(129,140,248,0.15)}
.stat-card span{display:block;font-size:11px;color:var(--t2);line-height:1.4;margin-top:2px}
.stat-src{display:block;font-size:9.5px;color:var(--t3);font-style:normal;margin-top:6px;letter-spacing:.2px}

/* Views */
.view{display:none;padding:0 0 48px;min-height:calc(100vh - 120px)}
.view.active{display:block}
.section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin-bottom:16px}

/* Home section headers */
.home-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.home-section-header .section-title{margin-bottom:0}

/* Discovery preview (home) */
.disco-preview-empty{padding:40px 32px;text-align:center}
.disco-preview-inner{max-width:480px;margin:0 auto}
.disco-preview-icon{margin-bottom:16px;display:flex;justify-content:center}
.disco-preview-empty h3{font-size:16px;font-weight:600;color:var(--t2);margin-bottom:8px}
.disco-preview-empty p{font-size:13px;color:var(--t3);line-height:1.6;margin-bottom:20px}
.disco-preview-buckets{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.disco-preview-bucket{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--t3);background:var(--surface);padding:6px 14px;border-radius:20px;border:1px solid var(--border)}

/* Toolbar */
.toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pills{display:flex;gap:4px;flex-wrap:wrap}
.pill{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:11.5px;font-weight:500;color:var(--t2);cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap}
.pill:hover,.pill.active{color:var(--accent);border-color:rgba(129,140,248,0.2);background:var(--accent-bg)}

/* View toggle */
.view-toggle{display:flex;gap:2px;background:var(--surface);border-radius:8px;border:1px solid var(--border);padding:2px}
.toggle-btn{background:none;border:none;color:var(--t3);padding:4px 8px;font-size:14px;cursor:pointer;border-radius:6px;transition:all .2s;font-family:inherit}
.toggle-btn.active{color:var(--accent);background:var(--accent-bg)}

/* Filter bar */
.filter-select{background:#0a0a12;border:1px solid var(--border);border-radius:8px;padding:5px 10px;font-size:11.5px;color:var(--t2);font-family:inherit;cursor:pointer;outline:none;max-width:160px}
.filter-select:focus{border-color:var(--accent)}
.filter-row{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.filter-date{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px 8px;font-size:11px;color:var(--t2);font-family:inherit;outline:none;color-scheme:dark}
.filter-date:focus{border-color:var(--accent)}
.filter-sep{color:var(--t3);font-size:12px}

/* Card grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.card{overflow:hidden;cursor:pointer;display:flex;flex-direction:column;position:relative}
.card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;z-index:1;border-radius:var(--radius) 0 0 var(--radius)}
.card.sig-critical::before{background:var(--crit)}
.card.sig-high::before{background:var(--high)}
.card.sig-medium::before{background:var(--med)}
.card.sig-low::before{background:rgba(255,255,255,0.08)}
.card:hover{transform:translateY(-2px);border-color:var(--border-h)}
.card-img{width:100%;height:170px;object-fit:cover;display:block}
.card-ph{width:100%;height:120px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(129,140,248,0.05),rgba(96,165,250,0.04),rgba(167,139,250,0.03))}
.card-ph-letter{font-size:28px;font-weight:800;color:rgba(255,255,255,0.07);text-transform:uppercase;letter-spacing:2px}
.card-body{padding:18px;flex:1;display:flex;flex-direction:column}
.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.card-top-r{display:flex;align-items:center;gap:8px}
.card-date{font-size:10.5px;color:var(--t3);font-weight:500;white-space:nowrap;font-variant-numeric:tabular-nums}
.badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:4px;letter-spacing:.2px}
.badge-sm{font-size:9px;font-weight:600;padding:2px 6px;border-radius:3px;letter-spacing:.2px;white-space:nowrap}
.sig-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.sig-dot.critical{background:var(--crit);box-shadow:0 0 6px var(--crit)} .sig-dot.high{background:var(--high)} .sig-dot.medium{background:var(--med)} .sig-dot.low{background:var(--low)}
.card-title{font-size:14px;font-weight:600;line-height:1.4;margin-bottom:6px}
.card-summary{font-size:12.5px;color:var(--t2);line-height:1.55;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-source{font-size:10.5px;color:var(--t3);margin-top:8px;display:flex;align-items:center;gap:5px}
.card-source::before{content:'';display:inline-block;width:3px;height:3px;border-radius:50%;background:var(--t3);flex-shrink:0}
.card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,0.04);font-size:11px;color:var(--t3)}
.card-foot-r{display:flex;align-items:center;gap:6px}
.card-tags{display:flex;gap:4px}
.tag{background:rgba(255,255,255,0.04);padding:2px 6px;border-radius:3px;font-size:10px}
.card-link{color:var(--accent);font-weight:500;font-size:11px;display:flex;align-items:center;gap:3px}
.card-link svg{width:10px;height:10px}

/* Pin button */
.pin-btn{background:none;border:none;cursor:pointer;font-size:14px;color:var(--t3);transition:color .2s;padding:0 2px}
.pin-btn:hover{color:var(--high)}
.pin-btn.pinned{color:var(--high)}

/* Table view */
.feed-table-wrap{overflow-x:auto}
.feed-table{width:100%;border-collapse:collapse;font-size:12.5px}
.feed-table thead{border-bottom:1px solid var(--border)}
.feed-table th{text-align:left;padding:8px 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--t3)}
.feed-table td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.03);vertical-align:middle}
.table-row{cursor:pointer;transition:background .15s}
.table-row:hover{background:var(--surface-h)}
.td-date{white-space:nowrap;color:var(--t3);font-size:11px}
.td-img{width:32px}
.table-thumb{width:32px;height:24px;object-fit:cover;border-radius:4px;display:block}
.td-title{font-weight:500;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.td-tags{max-width:160px;overflow:hidden}
.td-src{color:var(--t3);font-size:11px;white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}

/* Charts */
.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.chart-box{padding:20px;min-height:240px}
.chart-box canvas{max-height:220px}

/* Trends & Briefs */
.trends-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.trend-card{padding:16px}
.trend-card h4{font-size:14px;font-weight:600;margin-bottom:4px}
.trend-card p{font-size:12px;color:var(--t2);line-height:1.5}
.briefs-list{display:flex;flex-direction:column;gap:12px}
.brief-card{padding:20px}
.brief-card h3{font-size:16px;font-weight:600;margin-bottom:6px}
.brief-card .brief-date{font-size:12px;color:var(--t3);margin-bottom:10px}
.brief-card p{font-size:13px;color:var(--t2);line-height:1.6}

/* Custom scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.12);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.22)}
*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.12) transparent}

/* Modal */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:100;display:none;align-items:center;justify-content:center;padding:20px}
.overlay.open{display:flex}
.modal{max-width:900px;width:96%;max-height:90vh;overflow-y:auto;position:relative}
.modal-x{position:sticky;top:0;float:right;background:rgba(6,6,10,0.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:8px;color:var(--t2);font-size:20px;cursor:pointer;z-index:2;line-height:1;padding:4px 10px;margin:10px 10px 0 0}
.modal-x:hover{color:var(--t1);background:rgba(6,6,10,0.9)}
.modal-img{width:100%;height:220px;object-fit:cover;border-radius:var(--radius) var(--radius) 0 0}
.modal-ph{width:100%;height:140px;display:flex;align-items:center;justify-content:center;font-size:42px;background:linear-gradient(135deg,rgba(129,140,248,0.08),rgba(236,72,153,0.05));border-radius:var(--radius) var(--radius) 0 0}
.modal-body{padding:24px}
.modal-badges{display:flex;gap:8px;align-items:center;margin-bottom:10px}
.editors-pick{font-size:10px;font-weight:600;color:var(--high);background:rgba(251,191,36,0.1);padding:3px 8px;border-radius:4px}
.modal-body h2{font-size:20px;font-weight:600;line-height:1.35;margin-bottom:10px}
.modal-body .meta{display:flex;gap:14px;font-size:11.5px;color:var(--t3);margin-bottom:12px;flex-wrap:wrap}
.rel-bar{height:6px;background:var(--surface);border-radius:3px;margin-bottom:14px;position:relative;overflow:hidden}
.rel-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:3px;transition:width .3s}
.rel-bar span{position:absolute;right:0;top:-16px;font-size:10px;color:var(--t3)}
.modal-body .desc{font-size:14px;color:var(--t2);line-height:1.65;margin-bottom:18px}
.modal-body .tags-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.modal-body .tag-m{background:var(--accent-bg);color:var(--accent);padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500}
.btn-source{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:8px;background:var(--accent);color:#fff;font-size:12.5px;font-weight:600;transition:opacity .2s}
.btn-source:hover{opacity:.85;color:#fff}

/* ── Discovery View ── */
.disco-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;margin-top:24px}
.disco-stat{padding:18px 20px;text-align:center}
.disco-stat-val{font-size:28px;font-weight:800;color:var(--t1);letter-spacing:-.5px;line-height:1.1}
.disco-stat-lbl{font-size:11px;font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.6px;margin-top:6px}

.disco-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.disco-toolbar-left,.disco-toolbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

.time-windows{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2px}
.tw-btn{background:none;border:none;color:var(--t3);padding:4px 10px;font-size:11px;font-weight:600;cursor:pointer;border-radius:6px;transition:all .2s;font-family:inherit}
.tw-btn:hover{color:var(--t1)}
.tw-btn.active{color:var(--accent);background:var(--accent-bg)}

.results-count{font-size:12px;color:var(--t3);white-space:nowrap}

/* Bucket Grid */
.bucket-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.bucket-card{border-radius:var(--radius);overflow:hidden;background:var(--surface);border:1px solid var(--border);backdrop-filter:var(--glass);-webkit-backdrop-filter:var(--glass)}
.bucket-header{padding:16px 20px 12px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start}
.bucket-header-left{flex:1}
.bucket-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.bucket-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.bucket-desc{font-size:11px;color:var(--t3);margin-top:3px;line-height:1.4}
.bucket-count{font-size:11px;color:var(--t3);margin-top:3px}
.bucket-link{font-size:10.5px;color:var(--accent);white-space:nowrap;cursor:pointer;background:none;border:none;font-family:inherit;padding:4px 0;transition:opacity .2s}
.bucket-link:hover{opacity:.7}

.bucket-table{width:100%;border-collapse:collapse;font-size:12px}
.bucket-table th{text-align:left;padding:8px 16px;font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--t3);border-bottom:1px solid var(--border);background:rgba(255,255,255,0.015)}
.bucket-table th:not(:first-child){text-align:right}
.bucket-table td{padding:8px 16px;border-bottom:1px solid rgba(255,255,255,0.025);vertical-align:middle}
.bucket-table td:not(:first-child){text-align:right}
.bucket-table tr{cursor:pointer;transition:background .15s}
.bucket-table tr:hover{background:var(--surface-h)}
.bucket-table tr:last-child td{border-bottom:none}
.td-trend-name{font-weight:500;color:var(--t1);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.td-sparkline{width:120px}

.bucket-empty{padding:24px 20px;text-align:center;color:var(--t3);font-size:12px;font-style:italic}

/* Sparklines */
.sparkline-svg{width:120px;height:30px;display:block}
.sparkline-empty{color:var(--t3);font-size:11px}
.sparkline-lg{width:100%;height:120px;display:block}

/* Momentum badges */
.momentum-badge{display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;min-width:36px;padding:2px 6px;border-radius:4px}
.momentum-low{background:rgba(248,113,113,0.15);color:#f87171}
.momentum-mid{background:rgba(251,191,36,0.15);color:#fbbf24}
.momentum-high{background:rgba(52,211,153,0.15);color:#34d399}

/* Lifecycle badges */
.lifecycle-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:capitalize;white-space:nowrap}
.lifecycle-seed{background:rgba(107,114,128,0.15);color:#9ca3af}
.lifecycle-emerging{background:rgba(96,165,250,0.15);color:#60a5fa}
.lifecycle-growing{background:rgba(52,211,153,0.15);color:#34d399}
.lifecycle-mainstream{background:rgba(167,139,250,0.15);color:#a78bfa}
.lifecycle-declining{background:rgba(251,191,36,0.15);color:#fbbf24}
.lifecycle-dead{background:rgba(248,113,113,0.15);color:#f87171}

/* Growth percentages */
.growth-pos{color:#34d399;font-weight:600;font-size:11.5px}
.growth-neg{color:#f87171;font-weight:600;font-size:11.5px}
.growth-zero{color:var(--t3);font-size:11.5px}

/* Discovery Summary Table (full-width mode) */
.disco-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}
.disco-table{width:100%;border-collapse:collapse;font-size:12.5px}
.disco-table thead{border-bottom:1px solid var(--border)}
.disco-table th{text-align:left;padding:10px 14px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);background:rgba(255,255,255,0.02)}
.disco-table td{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,0.03);vertical-align:middle}
.disco-table tr{cursor:pointer;transition:background .15s}
.disco-table tr:hover{background:var(--surface-h)}

/* Trend Detail Modal */
.trend-modal{max-width:960px;width:96%}
.trend-modal-header{padding:24px 24px 16px;border-bottom:1px solid var(--border)}
.trend-modal-header h2{font-size:22px;font-weight:700;margin-bottom:8px}
.trend-meta-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.trend-momentum-bar{height:6px;background:var(--surface-h);border-radius:3px;overflow:hidden;margin-top:12px;position:relative}
.trend-momentum-fill{height:100%;border-radius:3px;transition:width .4s ease}
.trend-momentum-label{font-size:10px;color:var(--t3);margin-top:4px;display:flex;justify-content:space-between}

.trend-chart-area{padding:24px 28px;border-bottom:1px solid var(--border)}
.trend-metrics{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;padding:20px 28px;border-bottom:1px solid var(--border)}
.trend-metric{text-align:center;padding:12px 8px;background:rgba(255,255,255,0.02);border-radius:10px;border:1px solid var(--border)}
.trend-metric-val{font-size:20px;font-weight:700;color:var(--t1)}
.trend-metric-lbl{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;margin-top:3px}

.trend-items-section{padding:20px 24px}
.trend-items-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin-bottom:12px}
.trend-item-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.03);transition:background .15s}
.trend-item-row:last-child{border-bottom:none}
.trend-item-row:hover{background:rgba(255,255,255,0.02)}
.trend-item-title{font-size:12.5px;font-weight:500;line-height:1.4}
.trend-item-sig{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:6px}
.trend-dates{display:flex;gap:20px;padding:12px 24px;font-size:11px;color:var(--t3);border-top:1px solid var(--border)}

/* Discovery empty state */
.disco-empty{text-align:center;padding:40px 20px;color:var(--t3)}
.disco-empty h3{font-size:15px;color:var(--t2);margin-bottom:6px;font-weight:600}
.disco-empty p{font-size:13px;line-height:1.5}

/* Submit panel */
.submit-panel{padding:0;overflow:hidden}
.sp-section{padding:24px;border-bottom:1px solid var(--border)}
.sp-section:last-child{border-bottom:none}
.sp-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.scrape-row{display:flex;gap:10px}
.scrape-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 16px;color:var(--t1);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.scrape-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(129,140,248,0.1)}
.scrape-input::placeholder{color:var(--t3)}
.scrape-alt{font-size:12px;color:var(--t3);margin-top:10px}
.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:12px;font-family:inherit;text-decoration:underline;padding:0}
.link-btn:hover{opacity:.8}
.scrape-status{font-size:12px;margin-top:10px;min-height:18px}
.scrape-status.loading{color:var(--accent)}
.scrape-status.success{color:#34d399}
.scrape-status.error{color:var(--crit)}

.submit-form{}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}
.form-group label{font-size:10.5px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.4px}

.submit-panel input[type="text"],
.submit-panel input[type="url"],
.submit-panel input[type="search"],
.submit-panel textarea,
.submit-panel select{
  background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 14px;
  color:var(--t1);font-size:13px;font-family:inherit;outline:none;width:100%;
  transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;appearance:none}
.submit-panel select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='rgba(255,255,255,0.3)' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}
.submit-panel input:focus,
.submit-panel textarea:focus,
.submit-panel select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(129,140,248,0.08)}
.submit-panel textarea{resize:vertical;min-height:70px}
.submit-panel input[type="range"]{-webkit-appearance:auto;appearance:auto;accent-color:var(--accent);padding:0;border:none;background:transparent}
.submit-panel input[type="range"]:focus{box-shadow:none}
.check-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--t2);cursor:pointer;text-transform:none;letter-spacing:0;font-weight:500;padding-top:12px}
.check-label input[type="checkbox"]{width:auto;-webkit-appearance:auto;appearance:auto;accent-color:var(--accent)}

.tag-input-wrap{position:relative}
.selected-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.tag-chip{background:var(--accent-bg);color:var(--accent);padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:5px;border:1px solid rgba(129,140,248,0.15)}
.tag-chip button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:14px;line-height:1;padding:0;opacity:.7}
.tag-chip button:hover{opacity:1}
.tag-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg);border:1px solid var(--border-h);border-radius:10px;max-height:220px;overflow-y:auto;z-index:10;margin-top:4px;box-shadow:0 8px 32px rgba(0,0,0,0.5)}
.tag-option{padding:10px 14px;font-size:12.5px;color:var(--t2);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .15s}
.tag-option:hover{background:var(--surface-h);color:var(--t1)}
.tag-option:first-child{border-radius:10px 10px 0 0}
.tag-option:last-child{border-radius:0 0 10px 10px}
.tag-group{font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;background:var(--surface);padding:2px 6px;border-radius:3px}

/* Buttons */
.btn-accent{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:10px 22px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap}
.btn-accent:hover{opacity:.85;transform:translateY(-1px)}
.btn-accent:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-lg{padding:12px 32px;font-size:14px}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--t2);border-radius:10px;padding:10px 20px;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost:disabled{opacity:.5;cursor:not-allowed}
.btn-ai{background:var(--accent-bg);color:var(--accent);border:1px solid rgba(129,140,248,0.15);border-radius:20px;padding:4px 12px;font-size:10.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;text-transform:none;letter-spacing:0}
.btn-ai:hover{background:rgba(129,140,248,0.18)}
.btn-ai:disabled{opacity:.5;cursor:not-allowed}
.form-actions{padding:24px;display:flex;justify-content:flex-end}

select,select option{background:#0a0a12;color:rgba(255,255,255,0.92)}
select option:checked{background:var(--accent-bg)}
.filter-select,.filter-select option{background:#0a0a12;color:var(--t2)}

/* ── Scraper Page ── */
.sc-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.sc-pub-bar{display:flex;gap:8px;margin-bottom:10px;align-items:center;flex-wrap:wrap}
.sc-input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 14px;color:var(--t1);font-size:13px;font-family:inherit;outline:none;transition:border-color .2s}
.sc-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(129,140,248,0.08)}
.sc-input::placeholder{color:var(--t3)}
input[type="date"].sc-input{color-scheme:dark;color:var(--t2)}
.btn-sm{padding:5px 12px;font-size:11px;border-radius:6px}

.sc-pub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:4px;max-height:220px;overflow-y:auto;padding:10px;background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:10px}
.sc-pub-item{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--t2);cursor:pointer;padding:4px 8px;border-radius:5px;transition:background .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-pub-item:hover{background:var(--surface-h);color:var(--t1)}
.sc-pub-item input[type="checkbox"]{accent-color:var(--accent);flex-shrink:0}
.sc-pub-item.no-feed{opacity:.45}
.rss-dot{width:5px;height:5px;border-radius:50%;background:#34d399;flex-shrink:0;margin-left:auto}

.sc-date-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.sc-status{font-size:12px;margin-top:10px;min-height:18px;color:var(--t2)}
.sc-status-ok{color:#34d399}
.sc-status-warn{color:var(--high)}
.sc-status-err{color:var(--crit)}
.sc-status-info{color:var(--accent)}

/* Filter bar */
.sc-filter-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}
.sc-filter-left{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.sc-filter-right{display:flex;gap:8px;align-items:center}
.sc-select{background:#0a0a12;border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:12px;color:var(--t2);font-family:inherit;cursor:pointer;outline:none}
.sc-select option{background:#0a0a12;color:var(--t2)}
.sc-select:focus{border-color:var(--accent)}
.sc-slider-wrap{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--t3)}
.sc-slider-wrap strong{color:var(--accent)}
.sc-slider-wrap input[type="range"]{width:100px;accent-color:var(--accent)}

.sc-results-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px;flex-wrap:wrap}
.sc-results-bar span{font-size:13px;color:var(--t2)}
.sc-results-bar strong{color:var(--t1)}

/* Card grid */
.sc-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.sc-card{position:relative;overflow:hidden;transition:transform .2s,border-color .2s}
.sc-card:hover{transform:translateY(-2px);border-color:var(--border-h)}
.sc-card-check{position:absolute;top:10px;left:10px;z-index:2}
.sc-card-check input{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}
.sc-card-img{width:100%;height:180px;object-fit:cover;display:block}
.sc-card-ph{width:100%;height:120px;display:flex;align-items:center;justify-content:center;font-size:32px;background:linear-gradient(135deg,rgba(129,140,248,0.06),rgba(236,72,153,0.04))}
.sc-card-body{padding:14px}
.sc-card-title{font-size:13.5px;font-weight:600;line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sc-card-summary{font-size:12px;color:var(--t2);line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sc-views{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap}
.sc-view{font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--accent);background:var(--accent-bg);padding:2px 8px;border-radius:4px}
.sc-card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}
.sc-tag{font-size:10.5px;color:var(--t2);background:rgba(255,255,255,0.04);padding:2px 6px;border-radius:3px}
.sc-tag-dim{color:var(--t3);font-style:italic}
.sc-signal{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.sc-signal-bar{flex:1;height:5px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden}
.sc-signal-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),#a78bfa)}
.sc-signal span{font-size:11px;font-weight:600;color:var(--accent);min-width:30px}
.sc-card-foot{display:flex;justify-content:space-between;align-items:center}
.sc-card-meta{font-size:11px;color:var(--t3)}
.sc-card-link{font-size:11px;font-weight:500;color:var(--accent)}
.sc-card-link:hover{opacity:.8}
.sc-imported{opacity:.45}

.view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.view-toggle .toggle-btn{background:#0a0a12;border:none;color:var(--t3);padding:6px 10px;font-size:14px;line-height:1;cursor:pointer;transition:background .15s,color .15s}
.view-toggle .toggle-btn:hover{color:var(--t2)}
.view-toggle .toggle-btn.active{background:rgba(129,140,248,0.15);color:var(--accent)}
.sc-results-list-host{display:block}
.sc-list-wrap{overflow-x:auto;margin-top:0}
.sc-list-table{width:100%;border-collapse:collapse;font-size:12.5px}
.sc-list-table thead{border-bottom:1px solid var(--border)}
.sc-list-table th{text-align:left;padding:8px 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--t3)}
.sc-list-table td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.03);vertical-align:middle}
.sc-list-table tbody tr.sc-imported{opacity:.45}
.sc-list-thumb{width:48px;height:36px;object-fit:cover;border-radius:4px;display:block;background:rgba(255,255,255,0.04)}
.sc-list-thumb-ph{width:48px;height:36px;border-radius:4px;background:linear-gradient(135deg,rgba(129,140,248,0.08),rgba(236,72,153,0.05))}
.sc-list-title{font-weight:500;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sc-list-source{color:var(--t2);font-size:12px}
.sc-list-date{color:var(--t3);font-size:11px;white-space:nowrap}
.sc-list-tags{font-size:11px;color:var(--t2);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sc-signal-mini{display:inline-block;font-size:11px;font-weight:600;color:var(--accent);background:var(--accent-bg);padding:2px 8px;border-radius:4px}
.sc-load-more{text-align:center;padding:20px 0 8px;margin-top:16px}

/* Loading & empty */
.loading{text-align:center;padding:40px;color:var(--t3);grid-column:1/-1}
.spin{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:sp .6s linear infinite;margin:0 auto 8px}
@keyframes sp{to{transform:rotate(360deg)}}
.empty{text-align:center;padding:60px 20px;color:var(--t3);grid-column:1/-1}
.empty h3{color:var(--t1);font-size:15px;margin-bottom:4px}

footer{border-top:1px solid var(--border);padding:16px 0;font-size:11.5px;color:var(--t3)}
.foot-row{display:flex;justify-content:space-between}

@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .disco-stats{grid-template-columns:1fr 1fr}
  .bucket-grid{grid-template-columns:1fr}
  .charts-row{grid-template-columns:1fr}
  .trend-metrics{grid-template-columns:repeat(3,1fr)}
  .form-grid{grid-template-columns:1fr}
  .form-group.full{grid-column:1}
  .modal,.trend-modal{width:98%;max-width:98%}
}
@media(max-width:640px){
  .hero h1{font-size:26px}
  .hero-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .disco-stats{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .sc-card-grid{grid-template-columns:1fr}
  nav{margin-left:0}
  .header-row{flex-wrap:wrap}
  .toolbar{flex-direction:column;align-items:flex-start}
  .toolbar-left,.toolbar-right{width:100%}
  .disco-toolbar{flex-direction:column;align-items:flex-start}
  .disco-toolbar-left,.disco-toolbar-right{width:100%}
  .sc-filter-bar{flex-direction:column;align-items:flex-start}
  .sc-filter-left,.sc-filter-right{width:100%}
  .scrape-row{flex-direction:column}
  .trend-metrics{grid-template-columns:repeat(2,1fr)}
  .overlay{padding:8px}
  .modal,.trend-modal{max-height:95vh}
}

/* ── Curation: Votes ── */
.vote-w{display:flex;align-items:center;gap:2px;flex-shrink:0}
.vote-w button{background:none;border:none;color:var(--t3);cursor:pointer;font-size:11px;padding:2px 4px;transition:color .2s;line-height:1}
.vote-w .v-up:hover,.vote-w .v-up.voted{color:#34d399}
.vote-w .v-dn:hover,.vote-w .v-dn.voted{color:#f87171}
.vote-w .v-sc{font-size:12px;font-weight:700;color:var(--t1);min-width:18px;text-align:center}

/* ── Curation: Comments ── */
.cur-cmt-section{border-top:1px solid var(--border);margin-top:18px;padding-top:16px}
.cur-cmt-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin-bottom:10px}
.cur-cmt{padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.03)}
.cur-cmt-hd{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--t2);margin-bottom:4px}
.cur-cmt-hd strong{color:var(--t1)}
.cur-cmt-hd span{color:var(--t3);font-size:11px}
.cur-cmt-del{background:none;border:none;color:var(--t3);cursor:pointer;font-size:16px;margin-left:auto;padding:0 4px;transition:color .15s}
.cur-cmt-del:hover{color:var(--crit)}
.cur-cmt p{font-size:13px;color:var(--t2);line-height:1.5}
.cur-cmt-add{display:flex;gap:8px;align-items:flex-end;margin-top:12px}
.cur-cmt-ta{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--t1);font-size:12.5px;font-family:inherit;outline:none;resize:vertical}
.cur-cmt-ta:focus{border-color:var(--accent)}

/* ── Collections ── */
.coll-header{display:flex;justify-content:space-between;align-items:center;margin:24px 0 16px}
.coll-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.coll-card{padding:20px;cursor:pointer;transition:border-color .2s,transform .2s}
.coll-card:hover{border-color:var(--border-h);transform:translateY(-2px)}
.coll-card h4{font-size:15px;font-weight:600;margin-bottom:6px}
.coll-card p{font-size:12.5px;color:var(--t2);line-height:1.5;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.coll-card-foot{display:flex;justify-content:space-between;font-size:11px;color:var(--t3)}
.feat-coll{padding:24px;margin-bottom:16px;cursor:pointer;border-left:3px solid var(--accent);transition:border-color .2s}
.feat-coll:hover{border-color:var(--high)}
.feat-coll-badge{font-size:10px;font-weight:600;color:var(--high);margin-bottom:6px}
.feat-coll h3{font-size:17px;margin-bottom:4px}
.feat-coll p{font-size:13px;color:var(--t2)}
.feat-banner{margin-bottom:20px}
.feat-row{display:flex;gap:12px;flex-wrap:wrap}
.feat-chip{padding:12px 16px;cursor:pointer;transition:border-color .2s;display:flex;flex-direction:column;gap:2px}
.feat-chip:hover{border-color:var(--accent)}
.coll-item-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.03)}
.coll-item-info{flex:1;overflow:hidden}
.coll-item-title{font-size:13px;font-weight:500}
.coll-item-note{font-size:11px;color:var(--t3);font-style:italic;margin-top:2px}
.add-to-coll{position:relative;margin-top:14px}
.coll-dd{position:absolute;bottom:100%;left:0;right:0;background:var(--bg);border:1px solid var(--border-h);border-radius:8px;z-index:10;max-height:200px;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,.5);margin-bottom:4px}
.coll-dd-item{padding:8px 14px;font-size:12px;color:var(--t2);cursor:pointer;transition:background .15s}
.coll-dd-item:hover{background:var(--surface-h);color:var(--t1)}
.coll-dd-empty{padding:12px 14px;font-size:12px;color:var(--t3)}

/* ── API Docs ── */
.api-ep{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.03);flex-wrap:wrap}
.api-method{font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;background:rgba(52,211,153,0.15);color:#34d399;letter-spacing:.5px;flex-shrink:0}
.api-ep code{font-size:12px;color:var(--t1);font-family:'SF Mono',monospace}
.api-pre{background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:8px;padding:12px 16px;font-size:12px;color:var(--t2);font-family:'SF Mono',monospace;overflow-x:auto;white-space:pre-wrap;word-break:break-all;margin-top:10px}
.api-key-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.03);font-size:12.5px;color:var(--t2)}

@media(max-width:640px){
  .coll-grid{grid-template-columns:1fr}
  .feat-row{flex-direction:column}
  .api-ep{flex-direction:column;align-items:flex-start}
}

/* ── Geo Map & Source Network ── */
.geo-container,.net-container{position:relative;padding:8px;overflow:hidden}
.geo-svg,.net-svg{width:100%;display:block;border-radius:var(--radius)}
.geo-svg{height:auto;min-height:280px}
.net-svg{height:auto;min-height:320px}

.geo-node circle,.net-node circle{transition:stroke-width .2s,r .15s}
.geo-node:hover circle{stroke-width:2.5}
.net-node:hover circle{stroke-width:2.5;filter:url(#nglow) brightness(1.3)}

.gn-tooltip{position:fixed;z-index:200;background:rgba(6,6,10,0.92);border:1px solid var(--border-h);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--t1);pointer-events:none;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);white-space:nowrap;line-height:1.5;max-width:260px}
.gn-tooltip strong{font-weight:700}
.gn-tooltip.hidden{display:none}

.geo-detail{margin-top:16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);max-height:420px;overflow-y:auto}
.geo-detail.hidden{display:none}
.geo-detail-hdr{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border)}
.geo-detail-hdr h3{font-size:15px;font-weight:700}
.geo-detail-hdr .modal-x{background:none;border:none;color:var(--t2);font-size:22px;cursor:pointer;line-height:1}
.geo-detail-hdr .modal-x:hover{color:var(--t1)}

.geo-items{padding:6px 0}
.geo-item{display:flex;align-items:center;gap:10px;padding:8px 18px;border-bottom:1px solid rgba(255,255,255,0.025);transition:background .15s}
.geo-item:last-child{border-bottom:none}
.geo-item:hover{background:var(--surface-h)}
.geo-item-body{flex:1;min-width:0}
.geo-item-title{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.geo-item-meta{font-size:11px;color:var(--t3)}
.geo-item-link{color:var(--accent);font-size:14px;flex-shrink:0;padding:2px 4px}
.geo-item-link:hover{opacity:.7}

@media(max-width:640px){
  .geo-container,.net-container{padding:4px}
  .geo-detail{max-height:300px}
}

/* ── Trend DNA & Genealogy ── */
.dna-tabs{display:flex;gap:2px;padding:0 24px;border-bottom:1px solid var(--border);background:rgba(255,255,255,0.015)}
.dna-tab{background:none;border:none;padding:12px 18px;font-size:12px;font-weight:600;color:var(--t3);cursor:pointer;font-family:inherit;border-bottom:2px solid transparent;transition:all .2s}
.dna-tab:hover{color:var(--t1)}
.dna-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.dna-tab-content{padding:20px 24px}
.dna-tab-content.hidden{display:none}

.dna-card{display:flex;flex-direction:column;gap:16px}
.dna-section{display:flex;flex-direction:column;gap:8px}
.dna-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3)}

.dna-colors{display:flex;gap:10px;flex-wrap:wrap}
.dna-color-swatch{display:flex;align-items:center;gap:6px}
.dna-swatch-circle{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,0.1);flex-shrink:0}
.dna-swatch-name{font-size:11.5px;color:var(--t2)}

.dna-pills{display:flex;gap:6px;flex-wrap:wrap}
.dna-pill{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:11px;font-weight:500;color:var(--t2);display:inline-flex;align-items:center;gap:5px}
.dna-pill-accent{background:var(--accent-bg);color:var(--accent);border-color:rgba(129,140,248,0.15)}
.dna-brand-orig{border-color:rgba(52,211,153,0.3);color:#34d399}
.dna-brand-adopt{border-color:rgba(96,165,250,0.3);color:#60a5fa}
.dna-brand-amp{border-color:rgba(167,139,250,0.3);color:#a78bfa}
.dna-brand-role{font-size:9px;text-transform:uppercase;letter-spacing:.4px;opacity:.65;margin-left:2px}

.dna-meta-row{display:flex;gap:6px;flex-wrap:wrap}
.dna-meta-badge{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:11px;font-weight:500;color:var(--t2);text-transform:capitalize}
.dna-season{color:var(--accent);border-color:rgba(129,140,248,0.15)}
.dna-demo{color:var(--purple);border-color:rgba(167,139,250,0.15)}

.dna-confidence{display:flex;align-items:center;gap:10px}
.dna-conf-label{font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.dna-conf-bar{flex:1;height:6px;background:var(--surface-h);border-radius:3px;overflow:hidden}
.dna-conf-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:3px;transition:width .4s}
.dna-conf-val{font-size:12px;font-weight:700;color:var(--accent);min-width:36px;text-align:right}

.dna-actions{display:flex;gap:8px;padding-top:8px}
.dna-empty{font-size:12px;color:var(--t3);padding:8px 0}
.dna-empty-state{text-align:center;padding:24px 0}
.dna-empty-state p{font-size:13px;color:var(--t3);margin-bottom:12px}

/* Genealogy */
.gen-section{display:flex;flex-direction:column;gap:16px}
.gen-tree-title,.gen-timeline-title,.gen-suggestions-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3)}
.gen-tree-wrap{overflow-x:auto;padding:8px 0}
.gen-tree-svg{width:100%;max-height:280px}
.gen-node{fill:var(--surface);stroke-width:1.5}
.gen-node-current{fill:rgba(129,140,248,0.1);stroke-width:2}
.gen-node-text{fill:var(--t1);font-size:11px;font-family:Inter,system-ui,sans-serif}
.gen-edge{fill:none;stroke:var(--border-h);stroke-width:1.5;stroke-dasharray:4,3}
.gen-edge-label{fill:var(--t3);font-size:9px;font-family:Inter,system-ui,sans-serif}
.gen-tree-empty{font-size:12px;color:var(--t3);padding:16px 0;text-align:center}

.gen-actions{display:flex;gap:8px;flex-wrap:wrap}
.gen-form{padding:14px;background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;gap:10px}
.gen-form.hidden{display:none}
.gen-form-title{font-size:11px;font-weight:700;color:var(--accent)}
.gen-input{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--t1);font-size:12px;font-family:inherit;outline:none;width:100%;transition:border-color .2s}
.gen-input:focus{border-color:var(--accent)}
.gen-form label{font-size:10px;color:var(--t3);display:flex;flex-direction:column;gap:4px}

.gen-suggestion{display:flex;align-items:center;gap:10px;padding:8px 12px;background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:8px}
.gen-sug-name{font-size:12px;font-weight:500;color:var(--t1);flex:1}
.gen-sug-type{font-size:10px;color:var(--accent);background:var(--accent-bg);padding:2px 8px;border-radius:4px}
.gen-sug-str{font-size:11px;font-weight:600;color:var(--t2);min-width:36px;text-align:right}

.gen-timeline{display:flex;flex-direction:column;gap:0;padding-left:12px;border-left:2px solid var(--border)}
.gen-tl-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;position:relative}
.gen-tl-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:3px;margin-left:-17px;border:2px solid var(--bg)}
.gen-tl-dot[data-type="peak"]{background:#34d399}
.gen-tl-dot[data-type="decline"]{background:#f87171}
.gen-tl-dot[data-type="fork"],.gen-tl-dot[data-type="merge"]{background:#fbbf24}
.gen-tl-dot[data-type="revival"]{background:#a78bfa}
.gen-tl-content{flex:1}
.gen-tl-type{font-size:11px;font-weight:600;color:var(--t1);text-transform:capitalize}
.gen-tl-date{font-size:10px;color:var(--t3);margin-left:8px}
.gen-tl-desc{font-size:12px;color:var(--t2);margin-top:3px;line-height:1.4}

select.gen-input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='rgba(255,255,255,0.3)' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px;cursor:pointer}
select.gen-input,select.gen-input option{background:#06060a;color:var(--t1)}
input[type="date"].gen-input{color-scheme:dark;color:var(--t2)}

/* ── Smart Alerts & Export ── */
.ae-bell-wrap{position:relative;display:flex;align-items:center}
.ae-bell{background:none;border:1px solid var(--border);border-radius:8px;padding:5px 8px;color:var(--t2);cursor:pointer;display:flex;align-items:center;position:relative;transition:all .2s}
.ae-bell:hover{color:var(--t1);border-color:var(--border-h)}
.ae-badge{position:absolute;top:-5px;right:-5px;background:var(--crit);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:none;align-items:center;justify-content:center;padding:0 4px;line-height:1}
.ae-badge.visible{display:flex}

.ae-panel{position:fixed;top:52px;right:20px;width:380px;max-height:480px;background:rgba(10,10,18,0.97);border:1px solid var(--border-h);border-radius:var(--radius);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);z-index:200;display:none;flex-direction:column;box-shadow:0 12px 48px rgba(0,0,0,0.6)}
.ae-panel.open{display:flex}
.ae-panel-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border)}
.ae-panel-title{font-size:13px;font-weight:700;color:var(--t1)}
.ae-panel-actions{display:flex;gap:6px}
.ae-icon-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--t2);cursor:pointer;font-size:14px;padding:3px 7px;transition:all .2s}
.ae-icon-btn:hover{color:var(--accent);border-color:rgba(129,140,248,0.2)}

.ae-list{overflow-y:auto;max-height:400px;flex:1}
.ae-alert{display:flex;align-items:flex-start;gap:10px;padding:12px 18px;border-bottom:1px solid rgba(255,255,255,0.03);transition:background .15s;cursor:default}
.ae-alert:hover{background:var(--surface-h)}
.ae-unread{background:rgba(129,140,248,0.04)}
.ae-read{opacity:.6}
.ae-alert-icon{font-size:12px;flex-shrink:0;margin-top:2px}
.ae-alert-body{flex:1;min-width:0}
.ae-alert-title{font-size:12.5px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ae-alert-msg{font-size:11.5px;color:var(--t2);margin-top:2px;line-height:1.4}
.ae-alert-time{font-size:10px;color:var(--t3);margin-top:4px}
.ae-mark{background:none;border:1px solid var(--border);border-radius:4px;color:var(--green);cursor:pointer;font-size:12px;padding:2px 6px;flex-shrink:0;transition:all .2s}
.ae-mark:hover{background:rgba(52,211,153,0.1);border-color:rgba(52,211,153,0.3)}
.ae-empty{text-align:center;padding:32px 20px;font-size:12px;color:var(--t3)}

/* Rules Modal */
.ae-rules-modal{max-width:700px;width:96%;max-height:90vh;overflow-y:auto}
.ae-rules-head{padding:20px 24px 14px}
.ae-rules-head h2{font-size:18px;font-weight:700}
.ae-rules-list{padding:0 24px 12px;display:flex;flex-direction:column;gap:6px}
.ae-rule{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:8px;gap:12px}
.ae-rule-info{flex:1;min-width:0}
.ae-rule-name{font-size:13px;font-weight:600;color:var(--t1)}
.ae-rule-meta{font-size:11px;color:var(--t3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ae-rule-acts{display:flex;gap:6px;flex-shrink:0}
.ae-rule-toggle{font-size:10px;font-weight:700;padding:3px 10px;border-radius:4px;border:none;cursor:pointer;font-family:inherit}
.ae-rule-toggle.on{background:rgba(52,211,153,0.15);color:#34d399}
.ae-rule-toggle.off{background:rgba(248,113,113,0.15);color:#f87171}
.ae-rule-del{background:none;border:1px solid var(--border);border-radius:4px;color:var(--t3);cursor:pointer;font-size:12px;padding:2px 8px;transition:all .2s}
.ae-rule-del:hover{color:var(--crit);border-color:rgba(248,113,113,0.3)}

.ae-rules-add{padding:12px 24px 20px;border-top:1px solid var(--border)}
.ae-rule-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.ae-input{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:7px 12px;color:var(--t1);font-size:12px;font-family:inherit;outline:none;flex:1;min-width:120px;transition:border-color .2s}
.ae-input:focus{border-color:var(--accent)}
.ae-select{background:#0a0a12;border:1px solid var(--border);border-radius:8px;padding:7px 12px;font-size:12px;color:var(--t2);font-family:inherit;cursor:pointer;outline:none}

/* Export */
.ae-export-wrap{position:relative}
.ae-export-btn{background:var(--accent-bg);border:1px solid rgba(129,140,248,0.15);border-radius:8px;padding:5px 14px;font-size:12px;font-weight:600;color:var(--accent);cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap}
.ae-export-btn:hover{background:rgba(129,140,248,0.18)}
.ae-export-dd{position:absolute;top:calc(100% + 6px);right:0;background:rgba(10,10,18,0.97);border:1px solid var(--border-h);border-radius:10px;min-width:220px;z-index:100;display:none;flex-direction:column;box-shadow:0 8px 32px rgba(0,0,0,0.5);overflow:hidden}
.ae-export-dd.open{display:flex}
.ae-export-opt{background:none;border:none;padding:11px 16px;font-size:12.5px;color:var(--t2);cursor:pointer;text-align:left;font-family:inherit;transition:all .15s;border-bottom:1px solid rgba(255,255,255,0.03)}
.ae-export-opt:last-child{border-bottom:none}
.ae-export-opt:hover{background:var(--surface-h);color:var(--t1)}

/* ── Scraper Enhancements ── */
.sc-classify-progress{display:flex;align-items:center;gap:12px;width:100%}
.sc-classify-bar{flex:1;height:6px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden}
.sc-classify-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),#a78bfa);transition:width .3s ease}
.sc-classify-text{font-size:12px;color:var(--t2);white-space:nowrap}

/* Geo map (Leaflet) — appended */
.geo-marker{background:none!important;border:none!important}
.geo-marker-circle{border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s}
.geo-marker-circle:hover{transform:scale(1.15)}
.geo-marker-code{font-size:9px;font-weight:700;color:rgba(255,255,255,0.92);line-height:1}
.geo-marker-count{font-size:10px;font-weight:600;color:rgba(255,255,255,0.7);line-height:1}
.gn-leaflet-tip{background:rgba(6,6,10,0.92)!important;border:1px solid rgba(255,255,255,0.12)!important;border-radius:8px!important;padding:6px 10px!important;color:rgba(255,255,255,0.92)!important;font-size:12px!important;font-family:Inter,system-ui,sans-serif!important;box-shadow:0 4px 16px rgba(0,0,0,0.4)!important}
.gn-leaflet-tip strong{font-weight:700}
.leaflet-tooltip-top:before{border-top-color:rgba(6,6,10,0.92)!important}

/* ── Search Trends Widget ── */
.search-trends-widget{padding:0;margin-bottom:20px;overflow:hidden}
.stw-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}
.stw-title{font-size:14px;font-weight:700;color:var(--t1)}
.stw-sub{font-size:11px;color:var(--t3);margin-top:2px}
.stw-actions{display:flex;align-items:center;gap:12px}
.stw-refresh-time{font-size:10px;color:var(--t3)}
.stw-empty{padding:32px 20px;text-align:center;font-size:12px;color:var(--t3)}
.stw-table{width:100%;border-collapse:collapse;font-size:12.5px}
.stw-table thead{border-bottom:1px solid var(--border)}
.stw-table th{text-align:left;padding:8px 16px;font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--t3);background:rgba(255,255,255,0.015)}
.stw-table td{padding:8px 16px;border-bottom:1px solid rgba(255,255,255,0.025);vertical-align:middle}
.stw-table tr{transition:background .15s}
.stw-table tr:hover{background:var(--surface-h)}
.stw-kw{font-weight:600;color:var(--t1)}
.stw-vol{color:var(--t2);font-size:12px}
.stw-linked{color:var(--accent);cursor:pointer;font-size:12px;font-weight:500}
.stw-linked:hover{text-decoration:underline}

/* Search growth badge on feed cards */
.search-growth-badge{display:inline-flex;align-items:center;gap:3px;background:rgba(52,211,153,0.1);color:#34d399;padding:2px 7px;border-radius:3px;font-size:10px;font-weight:600;margin-left:4px;white-space:nowrap}

/* ── Discovery Tabs ── */
.disco-tabs{display:flex;gap:2px;margin-bottom:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px;width:fit-content}
.disco-tab{background:none;border:none;padding:8px 20px;font-size:12.5px;font-weight:600;color:var(--t3);cursor:pointer;border-radius:8px;font-family:inherit;transition:all .2s}
.disco-tab:hover{color:var(--t1)}
.disco-tab.active{background:var(--accent-bg);color:var(--accent)}

/* Sortable columns */
.sortable{cursor:pointer;user-select:none;position:relative}
.sortable:hover{color:var(--t1)}
.sort-asc::after{content:' ▲';font-size:8px}
.sort-desc::after{content:' ▼';font-size:8px}

/* ── Social Signals ── */
.social-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;margin-bottom:16px}
.social-header-left{flex:1}
.social-header-right{display:flex;align-items:center;gap:12px}

.social-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.social-card{padding:16px;cursor:pointer;transition:transform .2s,border-color .2s}
.social-card:hover{transform:translateY(-2px);border-color:var(--border-h)}
.social-card-header{display:flex;align-items:center;gap:6px;margin-bottom:10px}
.social-platform{font-size:16px}
.social-tag{font-size:13px;font-weight:600;color:var(--t1);flex:1}
.social-growth{font-size:11px;font-weight:600}
.social-card-sparkline{height:30px;margin-bottom:10px}
.social-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.social-stat{text-align:center;padding:6px;background:rgba(255,255,255,0.02);border-radius:6px}
.social-stat-val{font-size:14px;font-weight:700;color:var(--t1)}
.social-stat-lbl{font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;margin-top:2px}

.social-chart-modal{margin-top:20px;padding:20px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}
.social-chart-modal.hidden{display:none}
.social-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.social-chart-header h3{font-size:15px;font-weight:700;color:var(--t1)}
.social-chart-meta{display:flex;gap:20px;margin-top:14px;font-size:12px;color:var(--t2);padding-top:12px;border-top:1px solid var(--border)}
.social-chart-meta strong{color:var(--t1)}

/* Source count and keywords in discovery table */
.td-src-count{font-weight:600;color:var(--t1)}
.td-first-seen{color:var(--t3);font-size:11px;white-space:nowrap}
.td-keywords{max-width:200px;overflow:hidden}
.td-keywords .tag{font-size:9px;margin-right:2px}

/* ── Demo Data Badge ── */
.tag-demo{background:rgba(248,113,113,0.12);color:#f87171;border:1px dashed rgba(248,113,113,0.3);font-style:italic;font-size:9px;letter-spacing:.3px}

/* ── Composite Signal Overlay Chart ── */
.composite-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.composite-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--t3)}
.confidence-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;letter-spacing:.3px}
.composite-legend{display:flex;gap:16px;margin-top:10px;padding-top:8px;border-top:1px solid var(--border)}
.comp-leg-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--t2)}
.comp-leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.composite-sparkline-label{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.6px;margin-top:16px;margin-bottom:6px;font-weight:600}
#compositeChart{max-height:200px}

/* ── Brand Index ── */
.bi-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;margin-bottom:16px}
.bi-header-left{flex:1}
.bi-header-right{display:flex;align-items:center}
.bi-quarter{font-size:13px;font-weight:700;color:var(--accent);background:rgba(129,140,248,0.1);padding:4px 12px;border-radius:16px;letter-spacing:.5px}
.bi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:12px}
.bi-card{display:flex;gap:16px;padding:16px;transition:transform .15s,border-color .15s}
.bi-card:hover{transform:translateY(-2px);border-color:var(--border-h)}
.bi-rank-col{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:48px}
.bi-rank{font-size:26px;font-weight:800;color:var(--t1);line-height:1;font-variant-numeric:tabular-nums}
.bi-card:nth-child(1) .bi-rank,.bi-card:nth-child(2) .bi-rank,.bi-card:nth-child(3) .bi-rank{background:linear-gradient(135deg,#d4a574,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.bi-change{font-size:10px;font-weight:700;padding:2px 6px;border-radius:8px;white-space:nowrap}
.bi-up{color:#34d399;background:rgba(52,211,153,0.12)}
.bi-down{color:#f87171;background:rgba(248,113,113,0.12)}
.bi-same{color:var(--t3);background:rgba(255,255,255,0.04)}
.bi-new{color:#818cf8;background:rgba(129,140,248,0.12);letter-spacing:.5px}
.bi-info{flex:1;min-width:0}
.bi-brand-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.bi-brand{font-size:15px;font-weight:700;color:var(--t1)}
.bi-cat{font-size:9px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}
.bi-demand{font-size:12px;margin-bottom:6px}
.bi-demand .growth-pos{font-weight:700}
.bi-highlights{display:flex;flex-direction:column;gap:3px}
.bi-highlight{font-size:11px;color:var(--t2);line-height:1.4;padding-left:10px;position:relative}
.bi-highlight::before{content:'';position:absolute;left:0;top:6px;width:4px;height:4px;border-radius:50%;background:var(--border-h)}
@media(max-width:640px){.bi-grid{grid-template-columns:1fr}.bi-rank{font-size:22px}}

/* ── Search Trends keyword links ── */
.stw-kw-link{color:var(--t1);text-decoration:none;display:inline-flex;align-items:center;gap:4px;transition:color .2s}
.stw-kw-link:hover{color:var(--accent)}
.stw-ext-icon{display:inline-flex;opacity:.4;transition:opacity .2s}
.stw-ext-icon svg{width:10px;height:10px}
.stw-kw-link:hover .stw-ext-icon{opacity:1}

/* ── Research View ── */
.research-hero{padding:32px 0 24px}
.research-hero .kicker{margin-bottom:8px}
.research-hero h2{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:8px}
.research-hero-sub{font-size:14px;color:var(--t2);line-height:1.6;max-width:600px}
.research-index-stats{font-size:12px;color:var(--t3);margin-top:12px}
.research-index-stats span{color:var(--accent);font-weight:700}

.research-search-wrap{padding:20px;margin-bottom:20px}
.research-search-inner{display:flex;align-items:center;gap:10px}
.research-search-icon{width:20px;height:20px;color:var(--t3);flex-shrink:0}
.research-search-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 16px;font-size:15px;color:var(--t1);font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}
.research-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(129,140,248,0.08)}
.research-search-input::placeholder{color:var(--t3)}
.research-search-actions{display:flex;justify-content:space-between;align-items:center;margin-top:14px;gap:12px;flex-wrap:wrap}
.research-search-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.research-hint{font-size:11px;color:var(--t3)}
.research-suggestions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.research-suggestions-label{font-size:11px;color:var(--t3);font-weight:600}
.research-suggestion{font-size:11px;cursor:pointer}

.research-meta{font-size:13px;color:var(--t2);margin-bottom:16px;min-height:20px}
.research-meta strong{color:var(--t1)}
.research-upgrade{color:var(--accent);font-weight:600}

.research-grid{display:flex;flex-direction:column;gap:12px}
.research-card{display:flex;gap:16px;padding:16px;transition:transform .15s,border-color .15s}
.research-card:hover{transform:translateY(-1px);border-color:var(--border-h)}
.research-card-left{flex-shrink:0;width:140px}
.research-card-img{width:140px;height:90px;object-fit:cover;border-radius:8px;display:block}
.research-card-ph{width:140px;height:90px;border-radius:8px;background:linear-gradient(135deg,rgba(129,140,248,0.08),rgba(236,72,153,0.05));display:flex;align-items:center;justify-content:center;transition:opacity .3s}
.research-card-ph-letter{font-size:28px;font-weight:800;color:rgba(255,255,255,0.15);text-transform:uppercase;letter-spacing:2px}
.research-card-body{flex:1;min-width:0;display:flex;flex-direction:column}
.research-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.research-source{font-size:10px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.3px}
.research-date{font-size:10px;color:var(--t3)}
.research-card-title{font-size:14px;font-weight:600;line-height:1.4;color:var(--t1);text-decoration:none;transition:color .2s;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.research-card-title:hover{color:var(--accent)}
.research-card-summary{font-size:12px;color:var(--t2);line-height:1.5;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:8px}
.research-card-foot{display:flex;align-items:center;gap:8px}
.research-in-tracker{font-size:10px;color:#34d399;font-weight:600;background:rgba(52,211,153,0.1);padding:2px 8px;border-radius:10px}
.research-added{color:#34d399!important;border-color:rgba(52,211,153,0.2)!important}
.research-read{margin-left:auto}

.research-pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:24px}
.research-page-info{font-size:12px;color:var(--t3)}

.research-cta{margin-top:24px;text-align:center;padding:32px}
.research-cta h3{font-size:16px;font-weight:700;margin-bottom:8px}
.research-cta p{font-size:13px;color:var(--t2);line-height:1.6;max-width:480px;margin:0 auto 16px}

.research-empty{text-align:center;padding:40px 20px}
.research-empty h3{font-size:15px;color:var(--t2);margin-bottom:6px;font-weight:600}
.research-empty p{font-size:13px;color:var(--t3);line-height:1.5}

@media(max-width:640px){
  .research-card{flex-direction:column}
  .research-card-left{width:100%}
  .research-card-img,.research-card-ph{width:100%;height:160px}
  .research-search-actions{flex-direction:column;align-items:flex-start}
}

/* ── Trend item rows with links ── */
.trend-item-body{flex:1;min-width:0}
.trend-item-link{color:var(--t1);text-decoration:none;display:inline-flex;align-items:center;gap:4px;transition:color .2s}
.trend-item-link:hover{color:var(--accent)}
.trend-item-link .stw-ext-icon{opacity:.3}
.trend-item-link:hover .stw-ext-icon{opacity:1}
.trend-item-meta{display:flex;align-items:center;gap:8px;margin-top:3px}
.trend-item-source{font-size:10px;color:var(--accent);opacity:.7;font-weight:600}
.trend-item-date{font-size:10px;color:var(--t3)}
