:root { --ink:#e9efe8; --muted:#8f9d95; --paper:#0d1210; --surface:#141b17; --surface-2:#19221d; --line:#28332d; --accent:#c9f36b; --accent-soft:#26351e; --orange:#f29d5f; --danger:#ff7b72; --safe-top:env(safe-area-inset-top,0px); --safe-right:env(safe-area-inset-right,0px); --safe-bottom:env(safe-area-inset-bottom,0px); --safe-left:env(safe-area-inset-left,0px); }
* { box-sizing:border-box; }
html { scroll-behavior:smooth; background:var(--paper); }
body { min-height:100vh; min-height:100dvh; margin:0; padding:var(--safe-top) var(--safe-right) var(--safe-bottom) var(--safe-left); background:var(--paper); color:var(--ink); font:14px/1.45 Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; -webkit-tap-highlight-color:transparent; }
button, select, input { font:inherit; }
button { cursor:pointer; }
.hidden { display:none !important; }
.app-shell { min-height:calc(100vh - var(--safe-top) - var(--safe-bottom)); min-height:calc(100dvh - var(--safe-top) - var(--safe-bottom)); display:grid; grid-template-columns:220px 1fr; }
.sidebar { position:sticky; top:0; height:100vh; padding:28px 20px; border-right:1px solid var(--line); display:flex; flex-direction:column; background:#0b100e; }
.brand { color:var(--ink); text-decoration:none; display:flex; gap:12px; align-items:center; margin:0 8px 44px; }
.brand b,.brand small { display:block; line-height:1.15; }.brand b { font:700 15px Inter, ui-sans-serif, system-ui, sans-serif; letter-spacing:.02em; }.brand small { color:var(--muted); font-size:11px; margin-top:4px; text-transform:uppercase; letter-spacing:.16em; }
.brand-mark { width:32px; height:32px; display:flex; align-items:flex-end; gap:3px; padding:6px; border:1px solid #415039; border-radius:9px; background:var(--accent-soft); }
.brand-mark span { width:5px; background:var(--accent); border-radius:3px; }.brand-mark span:nth-child(1){height:10px}.brand-mark span:nth-child(2){height:19px}.brand-mark span:nth-child(3){height:14px}
nav { display:grid; gap:7px; }.nav-item { padding:10px 12px; display:flex; gap:11px; align-items:center; color:var(--muted); border-radius:8px; text-decoration:none; font-weight:600; }.nav-icon{width:19px;height:19px;object-fit:contain;flex:0 0 auto;opacity:.76}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{opacity:1}.nav-item:hover,.nav-item.active { color:var(--ink); background:var(--surface-2); }.nav-item.active { box-shadow:inset 2px 0 var(--accent); }.nav-item.disabled{opacity:.38;cursor:not-allowed;pointer-events:none}
.privacy-note { margin-top:auto; padding:14px 12px; border-top:1px solid var(--line); display:flex; gap:10px; align-items:flex-start; }.privacy-note strong,.privacy-note small{display:block}.privacy-note strong{font-size:12px}.privacy-note small{color:var(--muted);font-size:11px;margin-top:3px}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(201,243,107,.1);margin-top:5px}
main { padding:35px 42px 70px; min-width:0; }.topbar { display:flex; align-items:center; justify-content:space-between; gap:24px; margin-bottom:28px; }.topbar-copy{min-width:0}.topbar-copy>p{color:var(--muted);font-size:12px;margin:4px 0 0}.topbar-actions{display:flex;align-items:center;gap:9px;flex:0 0 auto}.settings-trigger{width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);border-radius:9px;background:var(--surface);color:var(--muted);line-height:1}.settings-trigger svg{width:19px;height:19px}.settings-trigger:hover,.settings-trigger:focus-visible{color:var(--accent);border-color:#46563e;background:var(--surface-2)}.settings-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.demo-mode-indicator{display:inline-flex;align-items:center;gap:7px;padding:7px 10px;border:1px solid #52663e;border-radius:20px;background:var(--accent-soft);color:#d5f59b;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.demo-mode-indicator i{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(201,243,107,.1)}.eyebrow { color:var(--accent); font-size:10px; font-weight:700; letter-spacing:.2em; margin:0 0 8px; }.topbar h1 { font:600 clamp(25px,3vw,34px) Inter, ui-sans-serif,system-ui,sans-serif; margin:0; letter-spacing:-.035em; }
.button { border:0; padding:11px 16px; border-radius:8px; font-weight:700; color:#121912; }.button.primary { background:var(--accent); box-shadow:0 7px 25px rgba(201,243,107,.12); }.button.primary:hover{background:#d9ff83}.button.secondary{background:transparent;color:var(--ink);border:1px solid var(--line)}.button.danger{background:transparent;color:var(--danger);border:1px solid rgba(255,123,114,.35)}.button.danger:hover{background:rgba(255,123,114,.09);border-color:rgba(255,123,114,.65)}.button.danger.solid{background:var(--danger);color:#24100f;border-color:var(--danger)}.button.danger.solid:hover{background:#ff958e}.button:disabled{cursor:not-allowed;opacity:.55}.button.large{padding:14px 22px}
.filters { display:flex; gap:8px; align-items:flex-end; overflow-x:auto; padding-bottom:6px; margin-bottom:20px; }.filters label{min-width:125px;color:var(--muted);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.filters select,.filters input{display:block;width:100%;margin-top:5px;background:var(--surface);border:1px solid var(--line);color:var(--ink);border-radius:7px;padding:8px 27px 8px 9px;height:37px}.clear-filter{height:37px;background:transparent;border:0;color:var(--muted);font-weight:600;padding:0 7px}.clear-filter:hover{color:var(--ink)}
.empty-state { min-height:560px; border:1px solid var(--line); border-radius:16px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; background:radial-gradient(circle at 50% 33%, rgba(201,243,107,.07), transparent 31%),var(--surface); padding:50px 20px; }.empty-state h2{font:600 29px Inter, ui-sans-serif, system-ui, sans-serif;margin:0 0 12px;letter-spacing:-.03em}.empty-state>p:not(.eyebrow){color:var(--muted);max-width:560px;font-size:15px;margin:0 0 25px}.empty-state small{color:#6f7a74;margin-top:15px}.empty-visual{height:80px;display:flex;align-items:flex-end;gap:8px;margin-bottom:28px}.empty-visual span{display:block;width:12px;border-radius:6px 6px 2px 2px;background:linear-gradient(var(--accent),#5e7636)}.empty-visual span:nth-child(1){height:28px}.empty-visual span:nth-child(2){height:64px}.empty-visual span:nth-child(3){height:43px}.empty-visual span:nth-child(4){height:76px}
.kpi-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:12px; }.kpi-card,.panel{background:var(--surface);border:1px solid var(--line);border-radius:12px}.kpi-card{padding:20px}.kpi-card.featured{background:linear-gradient(135deg,#1e2c1a,var(--surface));border-color:#38472f}.kpi-card>span{display:block;color:var(--muted);font-size:12px;margin-bottom:9px}.kpi-card strong{display:block;font:600 27px Manrope;letter-spacing:-.04em}.kpi-card small{display:block;color:#728078;font-size:10px;margin-top:7px}.featured strong{color:var(--accent)}
.dashboard-grid{display:grid;grid-template-columns:1.45fr 1fr;gap:12px}.panel{padding:20px;min-width:0}.panel-heading{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.panel-heading h2{font:600 17px Manrope;letter-spacing:-.02em;margin:0}.panel-heading .eyebrow{margin-bottom:5px}.panel-actions{display:flex;align-items:center;gap:8px}.legend{color:var(--muted);font-size:11px;display:flex;gap:7px;align-items:center}.legend span{width:16px;height:2px;background:var(--accent)}.trend-panel{min-height:470px;grid-row:span 2;display:flex;flex-direction:column}.trend-panel .chart{flex:1;min-height:330px}.chart{height:235px;width:100%;overflow:hidden}.chart svg{width:100%;height:100%;display:block}.axis-label{fill:#748078;font:10px DM Sans}.grid-line{stroke:#29342e;stroke-width:1}.chart-line{fill:none;stroke:var(--accent);stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}.chart-area{fill:url(#areaGradient)}.chart-dot{fill:var(--surface);stroke:var(--accent);stroke-width:2}
.bar-list{display:grid;gap:15px}.bar-row{display:grid;grid-template-columns:minmax(95px,1fr) 2.1fr auto;gap:11px;align-items:center}.bar-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.bar-track{height:6px;border-radius:5px;background:#253029;overflow:hidden}.bar-fill{display:block;height:100%;background:linear-gradient(90deg,var(--accent),#8dae4a);border-radius:5px}.bar-value{font:600 11px Manrope;color:var(--muted);text-align:right}.tracks-panel{grid-column:1 / -1}.record-count{color:var(--muted);font-size:11px}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th{text-align:left;color:#6f7b74;text-transform:uppercase;letter-spacing:.08em;font-size:9px;padding:0 12px 10px}td{padding:12px;border-top:1px solid var(--line);font-size:12px}th:nth-child(n+2),td:nth-child(n+2){text-align:right}td small{color:var(--muted);display:block;margin-top:2px}.imports-panel{margin-top:12px}.import-list{display:grid;gap:8px}.import-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;gap:12px;align-items:center;width:100%;min-width:0;padding:11px 12px;background:var(--surface-2);border-radius:8px}.import-row>div{min-width:0}.source-icon{width:32px;height:32px;display:grid;place-items:center;border-radius:7px;background:var(--accent-soft);color:var(--accent);font-weight:800}.import-row strong,.import-row small{display:block}.import-row strong{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-row small{color:var(--muted);font-size:10px;margin-top:2px}.import-total{font:600 12px Manrope}.demo-source-tag{padding:3px 7px;border-radius:20px;background:var(--accent-soft);color:#bddc7f;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.delete-import{border:0;background:transparent;color:#6f7c74;font-size:18px}.delete-import:hover{color:var(--danger)}
.page-context{display:flex;justify-content:flex-end;align-items:center;min-height:38px;margin:0 0 12px}.data-panel{margin-top:12px;padding:0}.data-toolbar{display:flex;justify-content:space-between;gap:12px;padding:17px 19px;border-bottom:1px solid var(--line)}.data-toolbar label{color:var(--muted);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.data-toolbar input,.data-toolbar select{display:block;margin-top:5px;background:var(--surface-2);border:1px solid var(--line);color:var(--ink);border-radius:7px;height:38px;padding:8px 10px}.search-field{flex:1;max-width:430px}.search-field input{width:100%}.sort-field select{min-width:170px}.data-table{min-width:980px}.data-table th{padding:13px 14px;background:#111713;position:sticky;top:0;z-index:1}.data-table td{padding:14px;text-align:left!important;vertical-align:middle}.data-table .number-cell{text-align:right!important;font-variant-numeric:tabular-nums;font-weight:600}.data-table tbody tr:hover{background:rgba(201,243,107,.025)}.catalog-table-wrap{max-height:680px}.identifier{font:10px/1.55 ui-monospace,SFMono-Regular,Menlo,monospace;color:#aab4ae}.chip-row{display:flex;gap:5px;flex-wrap:wrap}.chip{display:inline-block;padding:3px 7px;border-radius:20px;background:var(--accent-soft);color:#bcd782;font-size:9px;white-space:nowrap}.muted-chip{background:#222b26;color:var(--muted)}.artist-link{border:0;background:transparent;color:var(--ink);font-weight:700;padding:0;text-align:left}.artist-link:hover{color:var(--accent)}.artists-grid{display:grid;gap:12px}.artist-data-panel{margin-top:0}.footnote{color:#66736c;font-size:10px;margin:18px 0 0}.sources-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:12px}.source-cards{display:grid;gap:9px}.source-card{display:grid;grid-template-columns:auto 1fr auto;gap:11px;align-items:center;padding:12px;background:var(--surface-2);border-radius:9px}.source-card-main strong,.source-card-main small{display:block}.source-card-main strong{font-size:12px}.source-card-main small{color:var(--muted);font-size:10px;margin-top:2px}.source-card>b{font-size:12px}.source-card-stats{grid-column:2 / -1;display:flex;gap:14px;color:#77847c;font-size:9px}.quality-list{display:grid;gap:17px}.quality-item>div:first-child{display:flex;justify-content:space-between;font-size:11px;margin-bottom:6px}.quality-item>div:first-child span{color:#b9c2bc}.quality-item>div:first-child b{color:var(--accent)}.quality-track{height:6px;background:#253029;border-radius:5px;overflow:hidden}.quality-track i{display:block;height:100%;background:linear-gradient(90deg,#789346,var(--accent));border-radius:5px}.quality-item small{display:block;color:#657169;font-size:9px;margin-top:5px}
dialog{border:0;padding:0;background:transparent;color:var(--ink);width:min(620px,calc(100vw - var(--safe-left) - var(--safe-right) - 28px));max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 28px)}dialog::backdrop{background:rgba(2,6,4,.78);backdrop-filter:blur(5px)}dialog[open] .dialog-card{animation:dialog-enter .22s cubic-bezier(.2,.8,.2,1) both}dialog.closing .dialog-card{animation:dialog-exit .18s ease-in both}dialog[open]::backdrop{animation:backdrop-enter .22s ease-out both}dialog.closing::backdrop{animation:backdrop-exit .18s ease-in both}.dialog-card{background:var(--surface);border:1px solid #34423a;border-radius:15px;padding:25px}.dialog-heading{display:flex;justify-content:space-between;align-items:flex-start}.dialog-heading h2{font:600 23px Manrope;margin:0}.icon-button{border:0;background:transparent;color:var(--muted);font-size:26px}.dialog-copy{color:var(--muted);font-size:13px}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:22px}.drop-zone{margin:20px 0;border:1px dashed #566458;background:#111814;border-radius:11px;min-height:190px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);transition:.2s}.drop-zone.dragover{border-color:var(--accent);background:var(--accent-soft)}.drop-zone input{position:absolute;opacity:0;pointer-events:none}.drop-zone strong{color:var(--ink);font-size:15px;margin:9px 0 2px}.upload-icon{font-size:28px;color:var(--accent)}.supported{display:flex;align-items:center;gap:7px;flex-wrap:wrap;color:var(--muted);font-size:10px}.supported b{color:#9da8a1;border:1px solid var(--line);border-radius:20px;padding:4px 8px}.progress-wrap{margin:18px 0}.progress-meta{display:flex;justify-content:space-between;color:var(--muted);font-size:11px;margin-bottom:7px}.progress-track{height:5px;background:#273029;border-radius:4px;overflow:hidden}.progress-track span{display:block;height:100%;width:0;background:var(--accent);transition:width .25s}.import-results{display:grid;gap:7px;margin:12px 0}.result-item{padding:9px 11px;background:var(--surface-2);border-radius:7px;font-size:11px}.result-item b{color:var(--accent)}.toast{position:fixed;right:calc(25px + var(--safe-right));bottom:calc(25px + var(--safe-bottom));background:#edf6e7;color:#151c15;padding:11px 16px;border-radius:8px;font-weight:700;box-shadow:0 10px 40px #0008;transform:translateY(80px);opacity:0;transition:.25s;z-index:20}.toast.show{transform:translateY(0);opacity:1}@keyframes dialog-enter{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}@keyframes dialog-exit{from{opacity:1;transform:none}to{opacity:0;transform:translateY(10px) scale(.98)}}@keyframes backdrop-enter{from{opacity:0}to{opacity:1}}@keyframes backdrop-exit{from{opacity:1}to{opacity:0}}@media(prefers-reduced-motion:reduce){dialog[open] .dialog-card,dialog[open]::backdrop{animation-duration:.01ms!important}}
dialog{border:0;padding:0;background:transparent;color:var(--ink);width:min(620px,calc(100vw - 28px))}dialog::backdrop{background:rgba(2,6,4,.78);backdrop-filter:blur(5px)}dialog[open] .dialog-card{animation:dialog-enter .22s cubic-bezier(.2,.8,.2,1) both}dialog.closing .dialog-card{animation:dialog-exit .18s ease-in both}dialog[open]::backdrop{animation:backdrop-enter .22s ease-out both}dialog.closing::backdrop{animation:backdrop-exit .18s ease-in both}.dialog-card{background:var(--surface);border:1px solid #34423a;border-radius:15px;padding:25px}.dialog-heading{display:flex;justify-content:space-between;align-items:flex-start}.dialog-heading h2{font:600 23px Manrope;margin:0}.icon-button{border:0;background:transparent;color:var(--muted);font-size:26px}.dialog-copy{color:var(--muted);font-size:13px}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:22px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:22px;padding:17px;border:1px solid var(--line);border-radius:11px;background:var(--surface-2)}.setting-row strong,.setting-row small{display:block}.setting-row strong{font-size:13px}.setting-row small{max-width:420px;margin-top:4px;color:var(--muted);font-size:11px;line-height:1.5}.setting-row input{appearance:none;position:relative;flex:0 0 auto;width:44px;height:24px;margin:0;border:1px solid #465149;border-radius:20px;background:#252e29;cursor:pointer;transition:.2s}.setting-row input::after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#89948d;transition:.2s}.setting-row input:checked{border-color:#789c49;background:var(--accent-soft)}.setting-row input:checked::after{left:23px;background:var(--accent)}.setting-row input:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.demo-disclosure{display:flex;justify-content:space-between;gap:12px;margin-top:10px;padding:0 4px;color:#718078;font-size:10px}.demo-disclosure b{color:#9eaf82}.drop-zone{margin:20px 0;border:1px dashed #566458;background:#111814;border-radius:11px;min-height:190px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);transition:.2s}.drop-zone.dragover{border-color:var(--accent);background:var(--accent-soft)}.drop-zone input{position:absolute;opacity:0;pointer-events:none}.drop-zone strong{color:var(--ink);font-size:15px;margin:9px 0 2px}.upload-icon{font-size:28px;color:var(--accent)}.supported{display:flex;align-items:center;gap:7px;flex-wrap:wrap;color:var(--muted);font-size:10px}.supported b{color:#9da8a1;border:1px solid var(--line);border-radius:20px;padding:4px 8px}.progress-wrap{margin:18px 0}.progress-meta{display:flex;justify-content:space-between;color:var(--muted);font-size:11px;margin-bottom:7px}.progress-track{height:5px;background:#273029;border-radius:4px;overflow:hidden}.progress-track span{display:block;height:100%;width:0;background:var(--accent);transition:width .25s}.import-results{display:grid;gap:7px;margin:12px 0}.result-item{padding:9px 11px;background:var(--surface-2);border-radius:7px;font-size:11px}.result-item b{color:var(--accent)}.toast{position:fixed;right:25px;bottom:25px;background:#edf6e7;color:#151c15;padding:11px 16px;border-radius:8px;font-weight:700;box-shadow:0 10px 40px #0008;transform:translateY(80px);opacity:0;transition:.25s;z-index:20}.toast.show{transform:translateY(0);opacity:1}@keyframes dialog-enter{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}@keyframes dialog-exit{from{opacity:1;transform:none}to{opacity:0;transform:translateY(10px) scale(.98)}}@keyframes backdrop-enter{from{opacity:0}to{opacity:1}}@keyframes backdrop-exit{from{opacity:1}to{opacity:0}}@media(prefers-reduced-motion:reduce){dialog[open] .dialog-card,dialog[open]::backdrop{animation-duration:.01ms!important}}
@media(max-width:1000px){.app-shell{grid-template-columns:76px 1fr}.sidebar{padding:25px 12px}.brand>span:last-child,.nav-item:not(.active){font-size:0}.brand{margin-left:8px}.nav-item{justify-content:center}.nav-icon{width:20px;height:20px}.privacy-note div{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}.sources-grid{grid-template-columns:1fr}}
@media(max-width:720px){.app-shell{display:block}.sidebar{height:auto;position:static;flex-direction:row;align-items:center;padding:12px 16px;border-right:0;border-bottom:1px solid var(--line)}.brand{margin:0 auto 0 0}.brand>span:last-child{display:none}nav{display:flex}.nav-item{padding:8px}.privacy-note{display:none}main{padding:24px 15px 50px}.topbar{align-items:flex-start;margin-bottom:18px}.topbar-copy>p{display:none}.topbar .button{font-size:0;padding:10px}.topbar .button span{font-size:18px}.filters{margin-bottom:14px}.kpi-grid{grid-template-columns:1fr 1fr}.dashboard-grid{grid-template-columns:1fr}.tracks-panel{grid-column:auto}.trend-panel{min-height:290px;grid-row:auto}.trend-panel .chart{min-height:235px}.import-row{grid-template-columns:auto 1fr auto}.import-total{display:none}.data-toolbar{align-items:stretch;flex-direction:column}.search-field{max-width:none}.sort-field select{width:100%}.page-context{min-height:0}}
@media(max-width:440px){.kpi-grid{grid-template-columns:1fr}.empty-state h2{font-size:24px}}
.data-table th{text-align:left;vertical-align:bottom}.data-table th:nth-last-child(-n+2){text-align:right}
.page-actions{display:flex;align-items:center;gap:12px}.merge-controls{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:end;margin:22px 0 14px}.merge-controls label{color:var(--muted);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.merge-controls select{display:block;width:100%;height:40px;margin-top:6px;padding:8px 10px;border:1px solid var(--line);border-radius:7px;background:var(--surface-2);color:var(--ink)}.merge-arrow{color:var(--accent);font-size:20px;padding-bottom:7px}.merge-save{width:100%}.merge-history{margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}.merge-list{display:grid;gap:7px;max-height:220px;overflow:auto}.merge-row{display:grid;grid-template-columns:1fr auto 1fr auto;gap:10px;align-items:center;padding:9px 10px;border-radius:7px;background:var(--surface-2);font-size:11px}.merge-row>b{color:var(--accent)}.merge-row>button{border:0;background:transparent;color:var(--muted);font-size:18px}.merge-row>button:hover{color:var(--danger)}
@media(max-width:600px){.merge-controls{grid-template-columns:1fr}.merge-arrow{transform:rotate(90deg);justify-self:center;padding:0}}
.map-metric{color:var(--muted);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.map-metric select{display:block;min-width:155px;height:38px;margin-top:5px;padding:8px 28px 8px 10px;border:1px solid var(--line);border-radius:7px;background:var(--surface-2);color:var(--ink)}
.locations-grid{display:grid;gap:12px}.map-panel{overflow:hidden}.world-heatmap{position:relative;min-height:420px;border:1px solid #24322a;border-radius:10px;overflow:hidden;background:radial-gradient(circle at 63% 44%,rgba(201,243,107,.055),transparent 29%),linear-gradient(180deg,#101915,#0c1310)}.world-heatmap svg{display:block;width:100%;height:auto;min-height:420px}.map-grid line{stroke:#26332c;stroke-width:.7;stroke-dasharray:3 7}.world-shapes path{fill:#202d26;stroke:#405047;stroke-width:1.2;stroke-linejoin:round}.map-marker{cursor:pointer;outline:none}.heat-halo{fill:var(--accent);opacity:var(--heat);filter:blur(5px);pointer-events:none}.heat-core{fill:url(#markerGlow);opacity:var(--heat);stroke:#e3ffad;stroke-width:.9;transition:opacity .15s,stroke-width .15s}.map-marker:hover .heat-core,.map-marker:focus .heat-core{opacity:1;stroke-width:2.2}.map-legend{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:9px;margin-top:12px}.map-legend i{width:110px;height:7px;border-radius:5px;background:linear-gradient(90deg,#344a2b,var(--accent))}.map-legend small{margin-left:auto;color:#657169}.market-panel{padding:0}.market-heading{padding:20px 20px 0}.market-table-wrap{max-height:540px}.market-table{min-width:720px}.market-table th:nth-child(n+3){text-align:right}.market-rank{display:inline-grid;place-items:center;width:22px;height:22px;margin-right:8px;border-radius:6px;background:var(--surface-2);color:var(--muted);font-size:9px}.territory-link{border:0;background:transparent;color:var(--ink);padding:0;font-weight:700;text-align:left}.territory-link:hover{color:var(--accent)}
@media(max-width:720px){nav{overflow-x:auto}.world-heatmap{min-height:270px}.world-heatmap svg{min-height:270px}.map-legend small{display:none}.map-metric{width:100%}.map-metric select{width:100%}}
:root{--font-app:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
body,button,select,input{font-family:var(--font-app)}
.brand b,.topbar h1,.empty-state h2,.kpi-card strong,.panel-heading h2,.bar-value,.import-total,.dialog-heading h2{font-family:var(--font-app)}
.axis-label{font-family:var(--font-app)}
.detail-link{min-height:32px;border:0;background:transparent;color:var(--ink);padding:4px 0;font:inherit;font-weight:750;text-align:left;text-decoration:underline;text-decoration-color:transparent;text-underline-offset:3px;touch-action:manipulation}
.detail-link:hover,.detail-link:focus-visible{color:var(--accent);text-decoration-color:currentColor;outline:none}
dialog.detail-dialog{width:min(720px,calc(100vw - 24px))}
.detail-dialog-card{max-height:min(86vh,760px);overflow:auto}
.detail-summary{margin:7px 0 0!important}
.detail-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:9px;margin-top:20px}
.detail-kpi{min-width:0;padding:14px;border:1px solid var(--line);border-radius:9px;background:var(--surface-2)}
.detail-kpi span,.detail-kpi small{display:block;color:var(--muted);font-size:9px}.detail-kpi span{text-transform:uppercase;letter-spacing:.08em}.detail-kpi strong{display:block;margin:7px 0 3px;color:var(--ink);font-size:17px;line-height:1.2;overflow-wrap:anywhere}.detail-kpi small{line-height:1.35}
.detail-body{margin-top:12px}.detail-facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;border:1px solid var(--line);border-radius:9px;overflow:hidden;background:var(--line)}
.detail-facts>div{min-width:0;padding:12px 14px;background:var(--surface-2)}.detail-facts span,.detail-facts strong{display:block}.detail-facts span{color:var(--muted);font-size:9px;text-transform:uppercase;letter-spacing:.08em}.detail-facts strong{margin-top:4px;font-size:11px;line-height:1.45;overflow-wrap:anywhere}
.detail-ranking{margin-top:12px;padding:15px;border:1px solid var(--line);border-radius:9px;background:var(--surface-2)}.detail-ranking>div{display:flex;justify-content:space-between;gap:16px;padding:8px 0;border-top:1px solid var(--line);font-size:11px}.detail-ranking>div:first-of-type{border-top:0}.detail-ranking strong{color:var(--accent);white-space:nowrap}
@media(max-width:600px){.detail-dialog-card{max-height:90vh;padding:20px}.detail-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-facts{grid-template-columns:1fr}.detail-dialog .dialog-actions{position:sticky;bottom:-20px;margin:18px -20px -20px;padding:12px 20px;background:linear-gradient(transparent,var(--surface) 28%)}.setting-row{align-items:flex-start}.demo-disclosure{flex-direction:column}}
dialog{width:min(620px,calc(100vw - var(--safe-left) - var(--safe-right) - 28px));max-height:calc(100dvh - var(--safe-top) - var(--safe-bottom) - 28px)}
.toast{right:calc(25px + var(--safe-right));bottom:calc(25px + var(--safe-bottom))}
html.standalone{overscroll-behavior-y:none}
html[data-mode="local"] .landing-page{display:none}
html[data-mode="landing"] .app-shell,html[data-mode="landing"] body>dialog,html[data-mode="landing"] .toast{display:none}
.landing-page{min-height:calc(100vh - var(--safe-top) - var(--safe-bottom));min-height:calc(100dvh - var(--safe-top) - var(--safe-bottom));padding:28px clamp(20px,5vw,72px) 54px;overflow:hidden;background:radial-gradient(circle at 18% 7%,rgba(201,243,107,.1),transparent 30%),radial-gradient(circle at 88% 78%,rgba(201,243,107,.045),transparent 27%),var(--paper)}
.landing-nav{display:flex;align-items:center;justify-content:space-between;gap:24px;max-width:1120px;margin:0 auto}.landing-brand{display:flex;align-items:center;gap:12px;color:var(--ink);text-decoration:none}.landing-brand b,.landing-brand small{display:block;line-height:1.15}.landing-brand b{font-size:15px;letter-spacing:.01em}.landing-brand small{margin-top:4px;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.15em}.landing-status{display:inline-flex;align-items:center;gap:8px;color:#aeb9b2;font-size:11px}.landing-status i{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(201,243,107,.09)}
.landing-content{max-width:1040px;margin:clamp(68px,10vh,112px) auto 0}.landing-hero{max-width:690px;margin-bottom:38px}.landing-hero h1{margin:0;font-size:clamp(38px,6vw,64px);line-height:.98;letter-spacing:-.055em}.landing-hero>p:last-child{max-width:630px;margin:18px 0 0;color:var(--muted);font-size:16px;line-height:1.55}
.tier-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.tier-card{display:flex;min-width:0;min-height:410px;flex-direction:column;padding:28px;border:1px solid var(--line);border-radius:16px;background:rgba(20,27,23,.88);box-shadow:0 24px 70px rgba(0,0,0,.16)}.local-tier{border-color:#465a39;background:linear-gradient(145deg,rgba(38,53,30,.76),rgba(20,27,23,.94) 54%)}.plus-tier{background:linear-gradient(145deg,rgba(28,34,31,.78),rgba(17,23,20,.92));color:#cbd2cd}.tier-status{display:inline-flex;width:max-content;padding:5px 9px;border:1px solid #3b4640;border-radius:20px;color:#849088;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.tier-status.available{border-color:#617843;background:rgba(201,243,107,.07);color:var(--accent)}.tier-heading>div{display:flex;align-items:baseline;justify-content:space-between;gap:18px;margin-top:18px}.tier-heading h2{margin:0;font-size:24px;letter-spacing:-.035em}.tier-heading strong{color:var(--accent);font-size:13px}.plus-tier .tier-heading strong{color:#88948c}.tier-heading>p{min-height:67px;margin:12px 0 0;color:var(--muted);font-size:13px;line-height:1.6}.tier-features{display:grid;gap:11px;margin:22px 0 28px;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);list-style:none}.tier-features li{position:relative;padding-left:22px;color:#c8d0ca;font-size:12px}.tier-features li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:800}.tier-features.planned li::before{content:"○";color:#657169}.tier-cta{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:44px;margin-top:auto;text-decoration:none}.plus-button{justify-content:center;border:1px solid #323d37;background:#1b231f;color:#707b74;box-shadow:none}.plus-button:disabled{opacity:1;cursor:not-allowed}.tier-card>small{display:block;margin-top:12px;color:#68746d;font-size:9px;text-align:center}
@media(max-width:760px){.landing-page{padding:20px 15px 38px}.landing-status{font-size:0}.landing-status::after{content:"Available";font-size:10px}.landing-content{margin-top:58px}.landing-hero{margin-bottom:28px}.landing-hero h1{font-size:42px}.landing-hero>p:last-child{font-size:14px}.tier-grid{grid-template-columns:1fr}.tier-card{min-height:0;padding:22px}.tier-heading>p{min-height:0}.plus-tier{margin-top:2px}}
@media(max-width:390px){.landing-brand>span:last-child{display:none}.landing-content{margin-top:44px}.landing-hero h1{font-size:37px}}
