.home-page{--accent: #2563eb;--accent-dark: #1e3a8a;--surface: #f8fafc;--surface-2: #ffffff;--border: #e2e8f0;--text-muted: #64748b;--gold: #f59e0b;--silver: #94a3b8;--bronze: #b45309}@media(prefers-color-scheme:dark){.home-page{--surface: #18181b;--surface-2: #27272a;--border: #3f3f46;--text-muted: #a1a1aa}}.home-page .hero{background:linear-gradient(135deg,#1e3a8a,#2563eb 55%,#0891b2);color:#fff;border-radius:16px;padding:2rem 1.75rem;margin-bottom:2rem;box-shadow:0 12px 40px #2563eb40}.home-page .hero-badge{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:.35rem .75rem;margin-bottom:.75rem}.home-page .hero-title{font-size:clamp(1.5rem,4.5vw,2rem);margin:0 0 .5rem;color:#fff;line-height:1.25;text-wrap:balance}.home-page .hero-lead{font-size:1.05rem;line-height:1.75;opacity:.95;margin:0 0 1.25rem;max-width:none;text-wrap:pretty;line-break:strict;hanging-punctuation:allow-end}.home-page .hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.home-page .hero-actions a{color:#1e3a8a;background:#fff;padding:.55rem 1rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:.9rem}.home-page .hero-actions a.secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}.home-page .stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}.home-page .stat-card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:1rem 1.1rem}.home-page .stat-card .label{font-size:.8rem;color:var(--text-muted);margin-bottom:.25rem}.home-page .stat-card .value{font-size:1.75rem;font-weight:700;line-height:1.2}.home-page .stat-card .sub{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.home-page .section-title{font-size:1.35rem;margin:0 0 .35rem}.home-page .section-lead{color:var(--text-muted);margin:0 0 1.25rem;font-size:.95rem}.home-page .charts-section{margin-bottom:2.5rem}.home-page .charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.home-page .chart-card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:1rem}.home-page .chart-card--wide{grid-column:1 / -1}.home-page .chart-card h3{margin:0 0 .25rem;font-size:1rem}.home-page .chart-note{font-size:.8rem;color:var(--text-muted);margin:0 0 .75rem}.home-page .chart-empty{font-size:.9rem;color:var(--text-muted);margin:0 0 1rem;padding:.75rem 1rem;border:1px dashed var(--border);border-radius:8px}.home-page .chart-wrap{position:relative;height:220px}.home-page .chart-wrap--tall{height:280px}.home-page .podium{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.home-page .podium-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem;position:relative;overflow:hidden}.home-page .podium-card.rank-1{border-color:var(--gold)}.home-page .podium-card.rank-2{border-color:var(--silver)}.home-page .podium-card.rank-3{border-color:var(--bronze)}.home-page .podium-rank{font-size:1.5rem;margin-bottom:.35rem}.home-page .podium-score{font-size:1.25rem;font-weight:700;color:var(--accent);margin:.5rem 0}.home-page .podium-title{font-size:.9rem;font-weight:600;line-height:1.4;margin:0}.home-page .podium-title a{text-decoration:none}.home-page .podium-meta{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}.home-page .category-tag{display:inline-block;font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:4px;background:var(--surface);border:1px solid var(--border);margin-top:.35rem}.home-page .ranking-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.home-page .ranking-tab{padding:.45rem .9rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:.85rem;font-weight:600}.home-page .ranking-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.home-page .ranking-panel{display:none}.home-page .ranking-panel.active,.home-page.rankings-page .ranking-panel{display:block}.home-page .ranking-loading{font-style:italic;color:var(--text-muted)}.home-page .rankings-more{margin-top:1rem}.home-page .rankings-more-link{font-weight:600;text-decoration:none}.home-page .rankings-header{margin-bottom:.5rem}.home-page .ranking-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px;background:var(--surface-2)}.home-page .ranking-table{width:100%;border-collapse:collapse;font-size:.88rem}.home-page .ranking-table th,.home-page .ranking-table td{padding:.65rem .75rem;border-bottom:1px solid var(--border);text-align:left}.home-page .ranking-table th{background:var(--surface);font-size:.8rem;color:var(--text-muted)}.home-page .ranking-table tr:last-child td{border-bottom:none}.home-page .ranking-table td.num,.home-page .ranking-table th.num{text-align:right;white-space:nowrap}.home-page .ranking-table tr.top-3{background:#2563eb0a}.home-page .score-bar-cell{min-width:100px}.home-page .score-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:4px}.home-page .score-bar-fill{height:100%;background:linear-gradient(90deg,#2563eb,#0891b2);border-radius:3px}.home-page .tag-row{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.home-page .venue-tag{display:inline-block;font-size:.72rem;font-weight:600;padding:.2rem .5rem;border-radius:999px;background:#fef3c7;color:#92400e}@media(prefers-color-scheme:dark){.home-page .venue-tag{background:#422006;color:#fcd34d}}
