/* ...existing styles... */
:root { --bg:#0b0b0b; --fg:#eaeaea; --muted:#9aa0a6; --accent:#4aa3ff; --panel:#141414; --line:#242424;
  --quake:#ff5555; --fault:#c9a227; --tsunami:#00c2ff; --volcano:#ff7a00; --fire:#ffa600; --landslide:#9b59b6; --alert:#2ecc71;
}
*{box-sizing:border-box} body{margin:0;background:var(--bg);color:var(--fg);font-family:"Noto Sans",system-ui,sans-serif}
.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line)}
.brand{font-weight:600;letter-spacing:.5px}
.controls{display:flex;gap:12px;align-items:center}
.toggle{display:flex;gap:8px;align-items:center} .toggle select{background:var(--panel);color:var(--fg);border:1px solid var(--line);padding:6px 8px;border-radius:6px}
.layer-row{display:flex;gap:10px;flex-wrap:wrap}
.btn{background:var(--accent);border:none;color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer}
.app-main{display:grid;grid-template-columns:320px 1fr;min-height:calc(100vh - 53px)}
.sidebar {
  border-right: 1px solid var(--line);
  padding: 12px;
  overflow: auto;
  /* Optionally set a max-height or height if your layout needs it */
}
.legend h3,.events h3{margin:.4rem 0 .6rem} .legend ul{list-style:none;padding:0;margin:0 0 10px 0}
.legend li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin:6px 0}
.key{display:inline-block;width:12px;height:12px;border-radius:50%}
.key-quake{background:var(--quake)} .key-fault{background:var(--fault)} .key-tsunami{background:var(--tsunami)}
.key-volcano{background:var(--volcano)} .key-fire{background:var(--fire)} .key-landslide{background:var(--landslide)} .key-alert{background:var(--alert)}
.depth-scale{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)} .depth-scale .gradient{flex:1;height:8px;border-radius:4px;background:linear-gradient(90deg,#ffb3b3,#ff5555,#7f3bff)}
.events-list{display:flex;flex-direction:column;gap:8px;max-width:100%}
.events-list-scroll {
  max-height: 340px;   /* Adjust this value as needed */
  overflow-y: auto;
  background: var(--panel);
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  margin-bottom: 8px;
}
.event-item{padding:8px;background:var(--panel);border:1px solid var(--line);border-radius:8px;cursor:pointer}
.event-item .meta{font-size:12px;color:var(--muted)}
.globe-wrap{position:relative}
#globeCanvas{display:block;width:100%;height:calc(100vh - 53px)}
.tooltip{position:absolute;background:#111;padding:6px 8px;border:1px solid var(--line);border-radius:6px;font-size:12px;pointer-events:none}
.panel{position:fixed;right:16px;bottom:16px;width:340px;max-width:92vw;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.panel.hidden{display:none} .panel-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--line)}
.panel-title{font-weight:600} .panel-close{background:transparent;border:none;color:var(--fg);font-size:18px;cursor:pointer}
.panel-body{padding:12px;font-size:14px;color:var(--fg)}
.badge{display:inline-block;padding:2px 6px;border-radius:6px;font-size:11px;margin-right:6px}
.badge.quake{background:rgba(255,85,85,.15);border:1px solid rgba(255,85,85,.3)}
/* ...existing styles... */

