:root{
  --bg:#ffffff; --fg:#0f172a; --muted:#475569; --line:#e5e7eb;
  --panel:#ffffff; --brand:#0ea5e9; --brand-ink:#075985; --link:#0b5ed7;
  --pageH: 90vh;
}

*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--fg);
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Ubuntu,"Helvetica Neue",Arial,"Noto Sans",sans-serif}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

/* Top bar */
#topbar{position:sticky;top:0;left:0;right:0;height:56px;background:var(--panel);
  border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:center;z-index:9000}
.topbar-inner{width:100%;max-width:1200px;display:flex;align-items:center;gap:12px;padding:0 16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.2px;color:var(--brand-ink)}
.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 3px rgba(14,165,233,.2)}
.brand a{color:inherit;text-decoration:none}
.spacer{flex:1}
.hamb{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#f8fafc;display:flex;align-items:center;justify-content:center;cursor:pointer}
.hamb span{display:block;width:18px;height:2px;background:var(--fg);position:relative}
.hamb span:before,.hamb span:after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--fg)}
.hamb span:before{top:-6px} .hamb span:after{top:6px}
.menu{position:absolute;top:60px;right:16px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.12);display:none;min-width:220px;z-index:9500;overflow:hidden}
.menu a{display:block;padding:12px 14px;color:var(--fg);text-decoration:none}
.menu a:hover{background:#f1f5f9}

/* Page containers */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 16px}

/* Picker page */
.hero{padding:26px 16px 10px}
.hero h1{margin:0;font-size:clamp(20px,2.6vw,28px)}
.hero p{margin:.4rem 0 0;color:var(--muted)}
.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;padding:12px 0}
.search{flex:1;display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--line);
  border-radius:12px;padding:8px 12px}
.search input{border:none;background:transparent;outline:none;width:100%;color:var(--fg)}
.pasteGo{display:flex;gap:8px}
.pasteGo input{border:1px solid var(--line);border-radius:10px;padding:8px 10px;min-width:220px}
.pasteGo button{border:1px solid var(--line);background:#0ea5e9;color:#fff;border-radius:10px;padding:8px 12px;font-weight:600;cursor:pointer}
.pasteGo button:hover{filter:brightness(.95)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;padding:8px 0 26px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;box-shadow:0 6px 18px rgba(2,6,23,.04);display:flex;flex-direction:column;gap:8px}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#0f172a;background:#eff6ff;border:1px solid #dbeafe;border-radius:999px;padding:4px 8px;width:max-content}
.meta{color:#667085;font-size:13px}
.card a.view{display:inline-flex;align-items:center;gap:8px;width:max-content;border:1px solid var(--line);
  background:#f8fafc;border-radius:10px;padding:8px 10px;font-weight:600;color:#0b5ed7;text-decoration:none}
.card a.view:hover{background:#eef2f7}
.meta { display: flex; flex-direction: column; gap: 2px; }

.card .thumb{
  width:100%;
  height:auto;
  display:block;
  border-radius:10px;
  margin-bottom:10px;
  background:#f8fafc;
  object-fit:cover;
}


/* Viewer page */
#map{height: calc(var(--pageH) * 0.55); border-bottom:1px solid var(--line)}
/*
#stats{padding:10px 16px;text-align:center;font-weight:700;font-size:clamp(14px,1.9vw,20px);color:var(--muted)}
*/

/* smaller stats text */
/* Viewer: make the stats line smaller */
#stats .stats-line{
  font-size:12px;     /* adjust smaller/larger here */
  line-height:1.15;
  font-weight:500;    /* lighter than 700 */
}

/* (optional) also tighten the container spacing a bit */
#stats{
  padding:6px 12px;
}

#chartWrap{padding:12px 16px 22px}
#chartContainer{height: calc(var(--pageH) * 0.35); width:100%; background:#fff; border:1px solid var(--line); border-radius:14px; position:relative; box-shadow:0 6px 18px rgba(2,6,23,0.06)}
#emptyMsg{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#64748b; font-size:14px}

/* Modals */
.modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.45);display:none;align-items:center;justify-content:center;z-index:10000;padding:16px}
.modal{background:#fff;border:1px solid var(--line);border-radius:16px;max-width:560px;width:100%;color:#0f172a;box-shadow:0 20px 50px rgba(2,6,23,.2)}
.modal header{padding:14px 18px;border-bottom:1px solid var(--line);font-weight:700}
.modal .content{padding:16px 18px;max-height:60vh;overflow:auto;line-height:1.5}
.modal .track-list a{display:block;padding:10px 12px;border:1px solid var(--line);border-radius:10px;margin:8px 0;color:#0b5ed7;text-decoration:none}
.closebtn{position:absolute;top:12px;right:14px;background:#f1f5f9;border:1px solid var(--line);color:#0f172a;border-radius:10px;padding:6px 10px;cursor:pointer}

footer{padding:18px 16px 28px;color:#94a3b8;text-align:center}

