*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #38bdf8;--border: #475569;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary)}body{min-height:100vh}#root{max-width:800px;margin:0 auto;padding:2rem 1rem}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.header{text-align:center;margin-bottom:2rem}.header h1{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.subtitle{color:var(--text-secondary);font-size:.95rem}.last-updated{color:var(--text-muted);font-size:.8rem;margin-top:.25rem}.gauge-section{display:flex;justify-content:center;margin-bottom:1.5rem}.gauge-container{width:300px}.gauge-container svg{width:100%;height:auto}.article-list{background:var(--bg-secondary);border-radius:8px;padding:1.25rem}.article-list h2{font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.article-list ul{list-style:none}.article-item{display:flex;align-items:flex-start;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--bg-card)}.article-item:last-child{border-bottom:none}.sentiment-dot{flex-shrink:0;width:10px;height:10px;border-radius:50%;margin-top:.45rem}.article-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.article-info a{font-size:.9rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.article-meta{font-size:.75rem;color:var(--text-muted)}.score-badge{font-weight:600;margin-left:.4rem}.article-columns{display:flex;gap:1.25rem;align-items:flex-start}.sentiment-group{flex:1;min-width:0}.sentiment-group-header{font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.sentiment-group-count{background:var(--bg-card);color:var(--text-muted);font-size:.7rem;font-weight:500;padding:.1rem .4rem;border-radius:10px;letter-spacing:0;text-transform:none}.loading-text{text-align:center;color:var(--text-secondary);padding:1rem}.error-text{text-align:center;color:#f97316;padding:1rem;font-size:.85rem}@media(max-width:480px){#root{padding:1rem .75rem}.header h1{font-size:1.4rem}.gauge-container{width:260px}.article-columns{flex-direction:column}}
