*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#030305; --sf:#0a0a0a; --cd:#111111; --bd:#222222; --bd2:#333333; 
  --t1:#f3f4f6; --t2:#9ca3af; --t3:#6b7280; 
  --ac:#818cf8; --cy:#38bdf8; --gn:#10b981; --warn:#f59e0b; --err:#ef4444;
}
html,body{height:100%;overflow:hidden;background:var(--bg)}
body{font-family:'Inter',sans-serif;color:var(--t1);-webkit-font-smoothing:antialiased; text-rendering: optimizeLegibility;}

/* Landing */
#landing{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .8s ease,transform .8s cubic-bezier(0.16, 1, 0.3, 1)}
#landing.exit{opacity:0;transform:scale(1.05);pointer-events:none}
.land-grid{position:absolute;inset:0;background-image:linear-gradient(to right,#ffffff05 1px,transparent 1px),linear-gradient(to bottom,#ffffff05 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 20%,transparent 100%)}
.land-c{position:relative;z-index:2;text-align:center;max-width:640px;padding:0 28px;animation:fadeUp 1s cubic-bezier(0.16, 1, 0.3, 1) .2s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.land-icon{font-size:54px;margin-bottom:20px;background:linear-gradient(135deg, var(--cy), var(--ac));-webkit-background-clip:text;-webkit-text-fill-color:transparent; filter:drop-shadow(0 10px 20px rgba(56, 189, 248, 0.2))}
.land-title{font-size:48px;font-weight:600;letter-spacing:-.04em;margin-bottom:16px;color:var(--t1)}
.land-sub{font-size:16px;color:var(--t2);line-height:1.7;margin-bottom:48px;font-weight:300}
.land-sub b{color:var(--t1);font-weight:500}
.land-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;animation:fadeUp 1s cubic-bezier(0.16, 1, 0.3, 1) .4s both}
.land-enter{padding:14px 36px;font-family:'Inter',sans-serif;font-size:14px;font-weight:500;background:var(--t1);color:#000;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px rgba(255,255,255,0.15)}
.land-enter:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 30px rgba(255,255,255,0.25)}
.land-how{padding:14px 36px;font-family:'Inter',sans-serif;font-size:14px;font-weight:500;background:rgba(255,255,255,0.03);color:var(--t2);border:1px solid var(--bd2);border-radius:8px;cursor:pointer;transition:all .3s ease}
.land-how:hover{border-color:var(--t1);color:var(--t1); background:rgba(255,255,255,0.08)}
.land-tags{display:flex;gap:24px;justify-content:center;margin-top:56px;font-size:11px;color:var(--t3);font-family:'JetBrains Mono',monospace;letter-spacing:0.05em;animation:fadeUp 1s cubic-bezier(0.16, 1, 0.3, 1) .6s both}

/* App */
#app{display:none;height:100vh;flex-direction:column}
#app.on{display:flex}
canvas{flex:1;display:block;cursor:grab;outline:none}
canvas.dragging{cursor:grabbing}

/* Desktop HUD */
.hud-top {
  position: fixed; top: 0; left: 0; right: 0;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 20px;
  padding: 16px 32px; z-index: 100; pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,0.9) 0%, transparent 100%);
}
.hud-top > * { pointer-events: auto; }
.hud-left { display: flex; flex-direction: column; gap: 6px; align-items: flex-start; }
.hud-center { display: flex; justify-content: center; }
.hud-right { display: flex; justify-content: flex-end; align-items: center; }

.hud-logo { display: flex; align-items: center; gap: 12px; }
.hud-logo h1 { font-size: 15px; font-weight: 600; letter-spacing: -.01em; color: var(--t1); margin: 0; }
.hud-info { display: flex; gap: 16px; font-size: 11px; color: var(--t3); font-family: 'JetBrains Mono', monospace; margin: 0; }
.hud-btns { display: flex; gap: 8px; align-items: center; flex-wrap: nowrap; }

.hbtn{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;height:34px;padding:0 16px;border:1px solid var(--bd);background:var(--sf);color:var(--t2);font-family:'Inter',sans-serif;font-size:12px;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.hbtn:hover{border-color:var(--bd2);color:var(--t1);background:rgba(255,255,255,0.05)}
.hbtn.on{border-color:var(--t1);color:var(--bg);background:var(--t1)}
.hbtn.scanning{border-color:var(--cy);color:var(--cy);animation:pul 1.5s infinite;box-shadow:0 0 15px rgba(56, 189, 248, 0.3)}
@keyframes pul{0%,100%{opacity:1}50%{opacity:.5}}

.filter-bar {display: flex;gap: 6px;background: var(--sf);padding: 6px;border-radius: 8px;border: 1px solid var(--bd);backdrop-filter: saturate(180%) blur(20px);-webkit-backdrop-filter: saturate(180%) blur(20px);pointer-events: auto;box-shadow:0 10px 30px rgba(0,0,0,0.5)}
.fbtn {background: transparent;border: none;color: var(--t3);font-family: 'JetBrains Mono', monospace;font-size: 10px;font-weight: 500;text-transform: uppercase;letter-spacing: 0.05em;padding: 6px 14px;border-radius: 4px;cursor: pointer;transition: all 0.3s ease; white-space: nowrap;}
.fbtn:hover {color: var(--t1);background: rgba(255, 255, 255, 0.05);}
.fbtn.active {color: var(--t1);background: rgba(255, 255, 255, 0.1);box-shadow: 0 2px 10px rgba(0,0,0,0.2);}

/* TIMELINE SCRUBBER */
#timeline {position:fixed;bottom:54px;left:50%;transform:translateX(-50%);width:640px;max-width:90vw;background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:14px 24px;display:flex;align-items:center;gap:20px;z-index:150;backdrop-filter:saturate(180%) blur(24px);-webkit-backdrop-filter:saturate(180%) blur(24px);box-shadow:0 20px 40px rgba(0,0,0,0.6)}
.tl-date {font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:500;color:var(--cy);width:85px;text-align:center;flex-shrink:0; text-shadow: 0 0 10px rgba(56,189,248,0.5)}
.tl-slider {flex:1;-webkit-appearance:none;background:transparent;outline:none;height:4px}
.tl-slider::-webkit-slider-runnable-track {width:100%;height:4px;background:var(--bd2);border-radius:2px}
.tl-slider::-webkit-slider-thumb {-webkit-appearance:none;height:16px;width:16px;border-radius:50%;background:var(--t1);cursor:pointer;margin-top:-6px;box-shadow:0 0 15px rgba(255,255,255,0.6);transition:transform 0.2s cubic-bezier(0.16, 1, 0.3, 1)}
.tl-slider::-webkit-slider-thumb:hover {transform:scale(1.3)}

.ticker{position:fixed;bottom:0;left:0;right:0;padding:12px 32px;background:linear-gradient(0deg, rgba(0,0,0,0.9), transparent);z-index:100;display:flex;align-items:center;gap:16px;pointer-events:none}
.ticker>*{pointer-events:auto}
.ticker-lbl{color:var(--t3);font-weight:600;font-size:10px;letter-spacing:.08em;white-space:nowrap; text-transform:uppercase;}
.ticker-txt{color:var(--t2);font-family:'JetBrains Mono',monospace;font-size:11px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.ticker-txt a{color:var(--t1);text-decoration:none;border-bottom:1px dashed var(--bd2);transition:all .2s}
.ticker-txt a:hover{border-style:solid; color:var(--cy); border-color:var(--cy)}

/* Tooltip */
#tooltip{position:fixed;padding:12px 16px;background:var(--sf);border:1px solid var(--bd2);border-radius:8px;pointer-events:none;z-index:500;display:none;backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);box-shadow:0 15px 35px rgba(0,0,0,0.5);max-width:280px}
#tooltip.on{display:block}
.tt-name{font-size:14px;font-weight:600;margin-bottom:4px;color:var(--t1)}
.tt-lab{font-size:10px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em; font-family:'JetBrains Mono',monospace;}
.tt-stat{font-size:11px;color:var(--t2);line-height:1.6}

/* Panel */
#panel{position:fixed;right:32px;top:84px;width:400px;max-height:calc(100vh - 160px);overflow-y:auto;background:var(--sf);border:1px solid var(--bd);border-radius:16px;z-index:200;display:none;backdrop-filter:saturate(180%) blur(24px);-webkit-backdrop-filter:saturate(180%) blur(24px);box-shadow:0 30px 80px rgba(0,0,0,0.8);animation:slideIn .4s cubic-bezier(0.16, 1, 0.3, 1)}
#panel.on{display:block}
@keyframes slideIn{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}
.pan-x{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:rgba(255,255,255,0.05);color:var(--t2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s; z-index:10;}
.pan-x:hover{color:var(--t1);background:rgba(255,255,255,0.1)}
.pan-top{padding:28px 24px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:16px}
.pan-orb{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.pan-name{font-size:20px;font-weight:600;line-height:1.2;color:var(--t1)}
.pan-sub{font-size:12px;margin-top:4px; font-family:'JetBrains Mono', monospace;}
.pan-link{color:var(--t3);text-decoration:none;font-size:10px;margin-left:8px;transition:color .2s}
.pan-link:hover{color:var(--t1)}
.pan-body{padding:24px}
.pan-desc{font-size:13px;color:var(--t2);line-height:1.7;margin-bottom:24px}

.pan-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.pan-stat{padding:12px 14px;background:var(--cd);border:1px solid var(--bd);border-radius:8px}
.pan-lbl{display:block;font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-family:'JetBrains Mono',monospace}
.pan-val{font-size:14px;font-weight:500;color:var(--t1)}

.pan-tabs{display:flex;gap:20px;margin-bottom:24px;border-bottom:1px solid var(--bd)}
.pan-tab{padding:10px 0;border:none;background:none;color:var(--t3);font-family:'Inter',sans-serif;font-size:13px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s;font-weight:500}
.pan-tab:hover{color:var(--t2)}
.pan-tab.active{color:var(--t1);border-bottom-color:var(--t1)}

.bench-row{margin-bottom:14px}
.bench-hdr{display:flex;justify-content:space-between;margin-bottom:8px;align-items:baseline}
.bench-nm{font-size:11px;color:var(--t2);font-family:'JetBrains Mono',monospace}
.bench-sc{font-size:12px;font-family:'JetBrains Mono',monospace;font-weight:500}
.bench-bg{height:6px;background:var(--cd);border-radius:3px;overflow:hidden; border:1px solid var(--bd)}
.bench-fill{height:100%;border-radius:3px;transition:width 1s cubic-bezier(0.16, 1, 0.3, 1)}

/* Compare Mode */
.pan-compare-hdr { display: flex; justify-content: space-between; align-items: center; width: 100%; }
.pan-compare-vs { font-size:14px; color:var(--t3); font-style:italic; font-family:'JetBrains Mono',monospace; font-weight:500; padding:0 12px;}
.pan-stat-compare { display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px; align-items: center; text-align: center; padding: 12px; background: var(--cd); border: 1px solid var(--bd); border-radius: 8px; margin-bottom: 10px; }
.pan-stat-compare > div:nth-child(1) { font-weight: 600; font-size: 14px; text-align: right; }
.pan-stat-compare > div:nth-child(2) { color: var(--t3); font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; font-family: 'JetBrains Mono', monospace; width: 80px; }
.pan-stat-compare > div:nth-child(3) { font-weight: 600; font-size: 14px; text-align: left; }

.bench-compare { display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px; align-items: center; margin-bottom: 16px; }
.bench-comp-val { font-size: 12px; font-family: 'JetBrains Mono', monospace; font-weight: 500; margin-bottom: 8px; display:block; }
.bench-comp-left { text-align: right; }
.bench-comp-bar-container { width: 100%; height: 6px; background: var(--cd); border:1px solid var(--bd); border-radius: 3px; display: flex; align-items: center; }
.bench-comp-bar-left { height: 100%; border-radius: 2px; transition: width 1s cubic-bezier(0.16, 1, 0.3, 1); margin-left: auto; }
.bench-comp-bar-right { height: 100%; border-radius: 2px; transition: width 1s cubic-bezier(0.16, 1, 0.3, 1); margin-right: auto; }
.bench-comp-lbl { font-size: 11px; color: var(--t2); font-family: 'JetBrains Mono', monospace; text-align: center; width: 70px; }

/* Overlays */
.ov{position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:10000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.ov.on{display:flex}
.ov-pan{background:var(--sf);border:1px solid var(--bd);border-radius:16px;padding:36px;width:600px;max-width:92vw;max-height:85vh;overflow-y:auto;animation:fadeUp .4s cubic-bezier(0.16, 1, 0.3, 1);position:relative;box-shadow:0 30px 80px rgba(0,0,0,0.9); backdrop-filter:saturate(180%) blur(24px);-webkit-backdrop-filter:saturate(180%) blur(24px)}
.ov-title{font-size:20px;font-weight:600;margin-bottom:32px;text-align:center;color:var(--t1)}
.ov-x{position:absolute;top:20px;right:20px;width:36px;height:36px;border:none;background:rgba(255,255,255,0.05);color:var(--t2);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s; z-index:100;}
.ov-x:hover{background:rgba(255,255,255,0.1);color:var(--t1)}

/* Census */
.neb-group{margin-bottom:32px}
.neb-hdr{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--bd)}
.neb-hdr-dot{width:12px;height:12px;border-radius:50%; box-shadow:0 0 10px currentColor}
.neb-hdr-name{font-size:15px;font-weight:600;color:var(--t1)}
.neb-hdr-ct{font-size:11px;color:var(--t3);margin-left:auto;font-family:'JetBrains Mono',monospace}
.cen-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cen-card{padding:14px;background:var(--cd);border:1px solid var(--bd);border-radius:10px;cursor:pointer;transition:all .2s;display:flex;gap:12px;align-items:center;font-size:13px}
.cen-card:hover{background:rgba(255,255,255,0.05);border-color:var(--bd2); transform:translateY(-2px)}
.cen-sc{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;margin-left:auto}

.sel-input{width:100%;padding:14px 16px;background:rgba(0,0,0,0.5);border:1px solid var(--bd2);color:var(--t1);font-family:'JetBrains Mono',monospace;font-size:13px;border-radius:8px;outline:none;margin-top:8px;transition:border-color .2s}
.sel-input:focus{border-color:var(--cy)}
.sel-select{padding:12px 16px;background:rgba(0,0,0,0.5);border:1px solid var(--bd2);color:var(--t1);font-family:'Inter',sans-serif;font-size:13px;border-radius:8px;outline:none;cursor:pointer;width:100%}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:3px}

.instr-s{margin-bottom:24px}
.instr-h{font-size:15px;font-weight:600;color:var(--t1);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.instr-p{font-size:13px;color:var(--t2);line-height:1.7}
.instr-p b{color:var(--t1);font-weight:500}

/* Analytics Dashboard */
.ana-layout { display:flex; height:100%; min-height:600px; }
.ana-sidebar { width: 220px; background: rgba(0,0,0,0.4); border-right: 1px solid var(--bd); padding: 24px 0; display:flex; flex-direction:column; gap:8px;}
.ana-nav-btn { padding: 12px 24px; text-align: left; background: transparent; border: none; color: var(--t3); font-family: 'JetBrains Mono', monospace; font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; cursor: pointer; transition: all 0.2s; border-left: 3px solid transparent; }
.ana-nav-btn:hover { color: var(--t2); background: rgba(255,255,255,0.02); }
.ana-nav-btn.active { color: var(--t1); background: rgba(255,255,255,0.05); border-left-color: var(--cy); }
.ana-content { flex: 1; padding: 32px; overflow-y: auto; max-height: 80vh;}
.ana-header { font-size: 20px; font-weight: 600; margin-bottom: 24px; color: var(--t1); display:flex; align-items:center; gap:12px;}

.data-table { width: 100%; border-collapse: collapse; text-align: left; font-size: 12px; }
.data-table th, .data-table td { padding: 12px 8px; border-bottom: 1px solid var(--bd); }
.data-table th { color: var(--t3); font-weight: 500; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; font-size: 10px; letter-spacing: 0.05em; position: sticky; top: -32px; background: var(--bg); z-index: 10; box-shadow: 0 1px 0 var(--bd);}
.data-table tr:hover td { background: rgba(255,255,255,0.02); cursor: pointer; }
.data-table td.highlight { color: var(--gn); font-family: 'JetBrains Mono', monospace; font-weight: 600; }
.data-table td.num { font-family: 'JetBrains Mono', monospace; color:var(--t2); }

.chip-container { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.model-chip { display: inline-flex; align-items:center; gap:6px; padding: 6px 12px; border: 1px solid var(--bd2); border-radius: 16px; font-size: 11px; cursor: pointer; color: var(--t2); background: rgba(0,0,0,0.5); transition:all .2s;}
.model-chip:hover { border-color: var(--t2); color: var(--t1); }
.model-chip.active { background: var(--t1); color: #000; border-color: var(--t1); font-weight: 500; }
.chip-dot { width: 8px; height: 8px; border-radius: 50%; }

.insight-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.insight-card { background: var(--cd); padding: 20px; border-radius: 12px; border: 1px solid var(--bd); font-size: 13px; line-height: 1.6; display:flex; flex-direction:column; gap:8px;}
.insight-lbl { font-size:10px; color:var(--t3); font-family:'JetBrains Mono', monospace; text-transform:uppercase; letter-spacing:0.05em;}
.insight-val { font-size:18px; font-weight:600; color:var(--t1);}

.chart-container { background: var(--cd); border: 1px solid var(--bd); border-radius: 12px; padding: 24px; margin-bottom: 24px; }
.chart-title { font-size: 13px; color: var(--t2); margin-bottom: 20px; font-weight: 500; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 0.05em; }
.scatter-svg { width: 100%; height: 300px; overflow: visible; }
.scatter-axis { stroke: var(--bd2); stroke-width: 1.5; }
.scatter-grid { stroke: var(--bd); stroke-width: 1; stroke-dasharray: 4 4; }
.scatter-label { fill: var(--t3); font-size: 10px; font-family: 'JetBrains Mono', monospace; }

/* ==================================================== */
/* 📱 ULTIMATE MOBILE & LANDSCAPE RESPONSIVENESS        */
/* ==================================================== */

@media (pointer: coarse) {
   #tooltip { display: none !important; } /* Hard-disable tooltips on touch devices */
}

@media (max-width: 992px) {
  /* HORIZONTAL SCROLLING RIBBON FOR MOBILE HUD */
  .hud-top {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    justify-content: flex-start;
    padding: 12px 16px;
    gap: 16px;
    -webkit-overflow-scrolling: touch;
    background: linear-gradient(180deg, rgba(0,0,0,0.95) 0%, rgba(0,0,0,0.7) 100%);
  }
  .hud-top::-webkit-scrollbar { display: none; } /* Hide scrollbar for clean UI */
  .hud-left, .hud-center, .hud-right { display: flex; flex-shrink: 0; }
  .hud-info { display: none; } /* Hide technical readouts on mobile */
  
  .land-title { font-size: 32px; }
  .land-sub { font-size: 14px; }
  .land-tags { flex-wrap: wrap; text-align: center; }

  #timeline { width: 92vw; bottom: 40px; padding: 10px 16px; gap: 12px; }
  .tl-date { font-size: 11px; width: 60px; }
  .ticker { padding: 8px 16px; bottom: 0; }
}

/* PORTRAIT MODE SPECIFIC (Phones held vertically) */
@media (max-width: 900px) and (orientation: portrait) {
  /* Bottom Sheet Panel */
  #panel {
    top: auto; bottom: 0; left: 0; right: 0;
    width: 100%; max-height: 75vh;
    border-radius: 20px 20px 0 0;
    border-bottom: none; border-left: none; border-right: none;
    animation: slideUp .4s cubic-bezier(0.16, 1, 0.3, 1);
  }
  @keyframes slideUp { from { transform: translateY(100%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
  .pan-top { flex-direction: column; text-align: center; }
  .pan-orb { margin: 0 auto; }
  .pan-link { display: inline-block; margin-top: 6px; margin-left: 0; }
  
  /* Analytics Overlay Mobile Restructure */
  .ov-pan { padding: 16px; border-radius: 0; width: 100%; height: 100%; max-width: 100%; max-height: 100vh; }
  .ov-x { z-index: 1000; background: rgba(0,0,0,0.8); }
  
  .ana-layout { flex-direction: column; min-height: 100vh; }
  .ana-sidebar { 
    width: 100%; flex-direction: row; overflow-x: auto; 
    border-right: none; border-bottom: 1px solid var(--bd); 
    padding: 0 0 8px 0; gap: 4px; flex-shrink: 0;
    -webkit-overflow-scrolling: touch;
  }
  .ana-sidebar::-webkit-scrollbar { display: none; }
  .ana-sidebar > div:first-child { display: none; } /* Hide 'ANALYTICS' title */
  .ana-nav-btn { white-space: nowrap; padding: 10px 14px; border-left: none; border-bottom: 2px solid transparent; font-size: 11px;}
  .ana-nav-btn.active { border-left: none; border-bottom-color: var(--cy); background: rgba(255,255,255,0.05); }
  .ana-content { padding: 20px 0; max-height: none; overflow-x: hidden; }
  
  .insight-grid { grid-template-columns: 1fr; gap: 12px; }
  .data-table th, .data-table td { padding: 10px 6px; font-size: 11px; }
}

/* LANDSCAPE MODE SPECIFIC (Phones held horizontally) */
@media (max-height: 500px) {
  /* Revert panel to side so it doesn't block the canvas */
  #panel {
    top: 0; bottom: 0; left: auto; right: 0;
    width: 320px; max-height: 100vh;
    border-radius: 16px 0 0 16px;
    border-top: none; border-bottom: none; border-right: none;
    animation: slideIn .4s cubic-bezier(0.16, 1, 0.3, 1);
  }
  
  /* Shrink overlay paddings to fit narrow heights */
  .ov-pan { height: 100vh; max-height: 100vh; padding: 16px; border-radius: 0; }
  .ov-title { margin-bottom: 16px; font-size: 16px; }
  
  /* Move timeline to corner to avoid blocking the panel */
  #timeline { bottom: 16px; width: 300px; left: 16px; transform: none; padding: 8px 16px; gap: 10px;}
  .ticker { display: none; } /* Hide ticker to save space on tiny landscape screens */
  
  .ana-layout { flex-direction: row; }
  .ana-sidebar { padding: 12px 0; width: 180px; }
  .ana-content { padding: 16px 24px; }
}
/* 3D Label Container */
#labels-container {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  pointer-events: none; /* Let clicks pass through to the 3D canvas */
  z-index: 50;
  overflow: hidden;
}
.star-label {
  position: absolute;
  transform: translate(-50%, -50%);
  text-align: center;
  white-space: nowrap;
  transition: opacity 0.2s;
}
.star-name {
  font-family: 'Inter', sans-serif;
  text-shadow: 0 2px 4px rgba(0,0,0,0.8);
}
.neb-label {
  position: absolute;
  transform: translate(-50%, -50%);
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-shadow: 0 4px 10px rgba(0,0,0,1);
  pointer-events: auto;
}