/* ============================================================================
   Mapa-Constelación v2 · Sistema visual
   Tema: espacio profundo de alto contraste, paneles de vidrio, HUD de juego.
   ============================================================================ */

:root{
  --bg:#04060f;
  --bg2:#0a1028;
  --glass:rgba(13,18,46,.72);
  --glass2:rgba(17,23,56,.88);
  --border:rgba(125,145,255,.16);
  --border2:rgba(125,145,255,.34);
  --txt:#eef2ff;
  --muted:#a9b4dc;
  --dim:#6e7ba8;
  --brand:#fbbf24;
  --brand2:#f5762c;
  --cyan:#22d3ee;
  --violet:#a78bfa;
  --pink:#f472b6;
  --green:#34d399;
  --red:#fb7185;
  --destacada:#ff4fa3;
  --r:16px;
  --shadow:0 16px 48px rgba(0,0,0,.55);
  --font:'Inter',system-ui,'Segoe UI',Roboto,sans-serif;
  --display:'Space Grotesk','Inter',system-ui,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%;overflow:hidden;background:var(--bg);color:var(--txt);
  font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:rgba(34,211,238,.35)}

/* Scrollbars */
*{scrollbar-width:thin;scrollbar-color:rgba(125,145,255,.35) transparent}
*::-webkit-scrollbar{width:9px;height:9px}
*::-webkit-scrollbar-thumb{background:rgba(125,145,255,.28);border-radius:8px;border:2px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:rgba(125,145,255,.5);background-clip:content-box}
*::-webkit-scrollbar-track{background:transparent}

#canvas{position:fixed;inset:0;display:block;cursor:grab;touch-action:none}
#canvas.grabbing{cursor:grabbing}

/* Paneles de vidrio */
.panel{position:fixed;z-index:6;background:var(--glass);border:1px solid var(--border);
  border-radius:var(--r);backdrop-filter:blur(20px) saturate(1.35);
  -webkit-backdrop-filter:blur(20px) saturate(1.35);box-shadow:var(--shadow)}

button{font-family:var(--font)}
button:focus-visible,input:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}

/* ============================== Barra superior ============================== */
#topbar{position:fixed;top:0;left:0;right:0;z-index:7;display:flex;align-items:center;gap:16px;
  padding:10px 18px;
  background:linear-gradient(180deg,rgba(4,6,15,.94) 0%,rgba(4,6,15,.72) 70%,rgba(4,6,15,0) 100%);
  pointer-events:none}
#topbar>*{pointer-events:auto}
.brandLink{display:inline-flex;align-items:center;gap:8px;text-decoration:none;flex:none}
.brandLogo{height:24px;width:auto;display:block;background:#fff;border-radius:7px;padding:4px 9px;
  box-shadow:0 2px 10px rgba(0,0,0,.4)}
.brandWord{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:.4px;color:#fff}
.brandWord b{color:var(--brand)}
#topbar .titles{min-width:0;flex:1}
#topbar h1{margin:0;font-family:var(--display);font-size:16px;font-weight:600;letter-spacing:.2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#topbar h1 b{color:var(--brand)}
#topbar .titles p{margin:2px 0 0;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#topbar .titles a{color:var(--brand);text-decoration:none}
#topbar .titles a:hover{text-decoration:underline}
.topActions{display:flex;align-items:center;gap:10px;flex:none}

#progressHud{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);
  background:var(--glass);border:1px solid var(--border);border-radius:30px;padding:6px 13px;
  backdrop-filter:blur(12px);cursor:default;user-select:none}
#progressHud b{color:var(--txt);font-size:13px}
#progressHud .pStar{color:var(--brand);font-size:13px;filter:drop-shadow(0 0 5px rgba(251,191,36,.8))}
#progressHud .pbar{width:64px;height:5px;border-radius:4px;background:rgba(255,255,255,.1);overflow:hidden}
#progressHud #progFill{display:block;height:100%;width:0%;border-radius:4px;
  background:linear-gradient(90deg,var(--brand),var(--pink));transition:width .6s cubic-bezier(.22,1,.36,1)}

#helpBtn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);cursor:pointer;
  background:var(--glass);color:var(--muted);font-size:15px;font-weight:700;backdrop-filter:blur(12px)}
#helpBtn:hover{color:var(--txt);border-color:var(--border2)}

/* ============================== Conmutador de vistas ============================== */
#viewSwitch{position:fixed;top:62px;left:50%;transform:translateX(-50%);z-index:7;display:flex;gap:3px;
  background:var(--glass2);border:1px solid var(--border);border-radius:30px;padding:4px;
  backdrop-filter:blur(20px) saturate(1.35);box-shadow:var(--shadow)}
#viewSwitch button{border:0;background:transparent;color:var(--muted);font-size:12.5px;font-weight:600;
  padding:7px 18px;border-radius:24px;cursor:pointer;transition:all .18s ease;letter-spacing:.2px}
#viewSwitch button:hover{color:var(--txt)}
#viewSwitch button.on{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#231503;
  box-shadow:0 2px 14px rgba(251,191,36,.4)}

#menuBtn{display:none;position:fixed;bottom:18px;left:14px;z-index:8;padding:11px 17px;border-radius:30px;
  border:1px solid var(--border2);background:var(--glass2);color:var(--txt);font-size:13px;font-weight:600;
  cursor:pointer;backdrop-filter:blur(16px);box-shadow:var(--shadow)}

/* ============================== Panel de control ============================== */
#controls{top:112px;left:14px;width:282px;padding:14px;max-height:calc(100vh - 170px);overflow:auto;
  overscroll-behavior:contain}
.cHead{display:flex;align-items:center;justify-content:space-between;margin:-2px 0 10px}
.cHead span{font-family:var(--display);font-size:13px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--muted)}
#closeControls{display:none;border:0;background:transparent;color:var(--muted);font-size:22px;
  cursor:pointer;line-height:1;padding:0 4px}

#controls h2{font-size:10.5px;text-transform:uppercase;letter-spacing:1.4px;color:var(--dim);
  margin:16px 0 7px;font-weight:600}
.search{width:100%;padding:10px 12px;border-radius:11px;border:1px solid var(--border);
  background:rgba(255,255,255,.06);color:var(--txt);font-size:13px;font-family:var(--font);
  transition:border-color .15s}
.search::placeholder{color:var(--dim)}
.search:focus{border-color:var(--cyan);outline:none;box-shadow:0 0 0 3px rgba(34,211,238,.15)}

.searchWrap{position:relative;margin-top:12px}
#suggest{position:absolute;top:calc(100% + 5px);left:0;right:0;z-index:9;display:none;
  background:var(--glass2);border:1px solid var(--border2);border-radius:12px;overflow:hidden;
  backdrop-filter:blur(20px);box-shadow:var(--shadow);max-height:280px;overflow-y:auto}
#suggest .sg{display:flex;align-items:center;gap:9px;padding:9px 12px;cursor:pointer;font-size:12.5px}
#suggest .sg:hover,#suggest .sg.act{background:rgba(34,211,238,.12)}
#suggest .sg .sgDot{width:8px;height:8px;border-radius:50%;flex:none}
#suggest .sg .sgCat{margin-left:auto;color:var(--dim);font-size:10.5px;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;max-width:110px}

.toggle{display:flex;background:rgba(255,255,255,.05);border:1px solid var(--border);
  border-radius:11px;overflow:hidden;margin-top:4px;padding:3px;gap:3px}
.toggle button{flex:1;padding:7px 6px;border:0;background:transparent;color:var(--muted);
  font-size:11.5px;cursor:pointer;font-weight:600;border-radius:8px;transition:all .15s}
.toggle button.on{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#231503}

.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:20px;
  border:1px solid var(--border);background:rgba(255,255,255,.05);color:var(--txt);
  font-size:11.5px;cursor:pointer;user-select:none;transition:all .15s;font-weight:500}
.chip .dot{width:9px;height:9px;border-radius:50%;flex:none;box-shadow:0 0 6px currentColor}
.chip.off{opacity:.32;filter:grayscale(.7)}
.chip:hover{border-color:var(--border2);transform:translateY(-1px)}
.seg{display:flex;flex-wrap:wrap;gap:5px}
.seg .chip{font-size:11px;padding:4px 9px}

.row{display:flex;gap:8px;margin-top:14px}
.row button{flex:1;padding:8px;border-radius:10px;border:1px solid var(--border);
  background:rgba(255,255,255,.05);color:var(--muted);font-size:11.5px;cursor:pointer;font-weight:600;
  transition:all .15s}
.row button:hover{color:var(--txt);border-color:var(--border2)}
.hint{font-size:10.5px;color:var(--dim);margin:12px 0 0;line-height:1.5}

.hubDesc{margin-top:9px;font-size:11.5px;line-height:1.5;color:#cfd8ff;
  background:rgba(125,145,255,.08);border-left:3px solid var(--brand);border-radius:7px;
  padding:8px 10px;min-height:38px}
.hubDesc b{color:#fff}

.guiaBtn{width:100%;padding:12px;border:0;border-radius:12px;cursor:pointer;font-size:13.5px;
  font-weight:700;color:#231503;background:linear-gradient(135deg,var(--brand),var(--brand2));
  box-shadow:0 4px 22px rgba(251,191,36,.35);transition:transform .15s,box-shadow .15s;
  font-family:var(--display);letter-spacing:.2px}
.guiaBtn:hover{transform:translateY(-1px);box-shadow:0 6px 28px rgba(251,191,36,.5)}
.guiaBtn:active{transform:translateY(0)}

.aboutBtn{width:100%;margin-top:12px;padding:9px;border-radius:10px;border:1px solid var(--border);
  background:rgba(125,145,255,.08);color:var(--muted);font-size:11.5px;cursor:pointer;font-weight:600;
  transition:all .15s}
.aboutBtn:hover{color:var(--txt);border-color:var(--border2)}

/* ============================== Acerca de (contenido indexable) ============================== */
#aboutWrap{position:fixed;inset:0;z-index:15;display:none;overflow:auto;
  background:rgba(2,4,12,.72);backdrop-filter:blur(8px);padding:40px 16px}
#aboutWrap.show{display:block}
.aboutCard{position:relative;max-width:720px;margin:0 auto;padding:30px 34px;
  background:var(--glass2);animation:tourIn .4s cubic-bezier(.22,1,.36,1)}
.aboutCard h2{font-family:var(--display);font-size:22px;font-weight:700;margin:0 0 12px;
  line-height:1.3;color:#fff}
.aboutCard h3{font-family:var(--display);font-size:15px;font-weight:600;margin:22px 0 8px;
  color:var(--brand)}
.aboutCard p{font-size:13.5px;line-height:1.65;color:#dde4ff;margin:0 0 10px}
.aboutCard strong{color:#fff}
.aboutCard a{color:var(--cyan);text-decoration:none}
.aboutCard a:hover{text-decoration:underline}
.aboutCats{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-wrap:wrap;gap:6px}
.aboutCats li{font-size:11.5px;padding:5px 11px;border-radius:20px;border:1px solid var(--border);
  background:rgba(255,255,255,.05);color:var(--txt)}
.aboutCard details{border:1px solid var(--border);border-radius:11px;margin:8px 0;
  background:rgba(255,255,255,.03);overflow:hidden}
.aboutCard summary{padding:11px 14px;font-size:13px;font-weight:600;cursor:pointer;color:#fff;
  list-style:none;position:relative;padding-right:34px}
.aboutCard summary::-webkit-details-marker{display:none}
.aboutCard summary::after{content:"+";position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--brand);font-size:16px;font-weight:700}
.aboutCard details[open] summary::after{content:"−"}
.aboutCard details p{padding:0 14px 12px;margin:0;font-size:12.5px;color:var(--muted)}
.aboutFoot{margin-top:20px !important;padding-top:14px;border-top:1px solid var(--border);
  font-size:11.5px !important;color:var(--muted) !important}
.aboutCard .close{position:absolute;top:14px;right:18px;cursor:pointer;color:var(--muted);
  font-size:22px;line-height:1}
.aboutCard .close:hover{color:#fff}

/* ============================== Ficha de herramienta ============================== */
#detail{top:112px;right:14px;width:330px;padding:0;display:none;overflow:hidden;
  max-height:calc(100vh - 170px);overflow-y:auto;animation:slideIn .28s cubic-bezier(.22,1,.36,1)}
@keyframes slideIn{from{opacity:0;transform:translateX(26px)}to{opacity:1;transform:none}}
#detail .dhead{padding:16px 18px 13px;border-bottom:1px solid var(--border);
  background:linear-gradient(135deg,rgba(251,191,36,.10),rgba(167,139,250,.08))}
#detail .cat{font-size:10px;text-transform:uppercase;letter-spacing:1.4px;color:var(--brand);font-weight:600}
#detail h3{margin:5px 0 0;font-size:20px;font-family:var(--display);font-weight:700;letter-spacing:.2px}
#dBadges{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
#dBadges .badge{font-size:10px;font-weight:600;padding:3px 9px;border-radius:12px;letter-spacing:.3px}
#detail .body{padding:14px 18px}
#detail .func{font-size:13px;line-height:1.55;color:#dde4ff;margin:0 0 12px}
#detail .kv{display:flex;font-size:12.5px;margin:7px 0;gap:8px}
#detail .kv .lab{color:var(--dim);min-width:74px;flex:none}
#detail .tags{display:flex;flex-wrap:wrap;gap:5px}
#detail .tag{font-size:10.5px;padding:3px 9px;border-radius:20px;background:rgba(255,255,255,.07);
  cursor:pointer;border:1px solid transparent;transition:border-color .15s}
#detail .tag:hover{border-color:currentColor}
#detail .capsTitle{font-size:10px;text-transform:uppercase;letter-spacing:1.4px;color:var(--brand);
  margin:14px 0 7px;font-weight:600}
#detail .caps{display:flex;flex-direction:column;gap:4px}
#detail .cap{font-size:11.5px;padding:5px 9px;border-radius:8px;display:flex;align-items:center;gap:8px}
#detail .cap.on{background:rgba(52,211,153,.13);color:#a9f0d2}
#detail .cap.off{background:rgba(251,113,133,.09);color:#ffb9c4}
#detail .cap .ck{font-weight:700}
#detail a.visit{display:block;text-align:center;margin:6px 18px 16px;padding:11px;
  border-radius:11px;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#231503;
  text-decoration:none;font-weight:700;font-size:13px;transition:transform .15s,box-shadow .15s;
  box-shadow:0 4px 18px rgba(251,191,36,.3)}
#detail a.visit:hover{transform:translateY(-1px);box-shadow:0 6px 26px rgba(251,191,36,.45)}
#detail .close,#shortcuts .close{position:absolute;top:11px;right:14px;cursor:pointer;color:var(--muted);
  font-size:21px;line-height:1;z-index:2}
#detail .close:hover,#shortcuts .close:hover{color:#fff}

/* ============================== HUD inferior ============================== */
#legend{position:fixed;bottom:14px;left:14px;z-index:6;font-size:11px;color:var(--muted);
  display:flex;gap:4px;align-items:center;background:var(--glass);border:1px solid var(--border);
  border-radius:30px;padding:6px 10px;backdrop-filter:blur(16px);max-width:calc(100vw - 260px);
  overflow-x:auto;white-space:nowrap}
#legend .k{display:flex;align-items:center;gap:6px;cursor:pointer;padding:4px 9px;border-radius:18px;
  transition:background .15s;flex:none}
#legend .k:hover{background:rgba(255,255,255,.08);color:var(--txt)}
#legend .sym{width:10px;height:10px;border-radius:50%;box-shadow:0 0 6px currentColor;flex:none}

#hudRight{position:fixed;bottom:14px;right:14px;z-index:6;display:flex;flex-direction:column;
  align-items:flex-end;gap:8px}
#count{font-size:12px;color:var(--muted);background:var(--glass);border:1px solid var(--border);
  border-radius:30px;padding:6px 13px;backdrop-filter:blur(16px)}
#count b{color:var(--txt)}
#minimap{display:block;border:1px solid var(--border);border-radius:12px;background:rgba(6,9,22,.78);
  backdrop-filter:blur(10px);cursor:crosshair;box-shadow:var(--shadow)}

#tooltip{position:fixed;z-index:9;pointer-events:none;background:rgba(7,10,24,.96);
  border:1px solid var(--border2);border-radius:9px;padding:7px 11px;font-size:12px;
  display:none;max-width:240px;box-shadow:var(--shadow);line-height:1.45}

#empty{position:fixed;top:50%;left:calc(50% + 130px);transform:translate(-50%,-50%);z-index:5;
  display:none;text-align:center;background:var(--glass2);border:1px solid var(--border);
  border-radius:var(--r);padding:22px 28px;color:var(--muted);font-size:13px;line-height:1.6;
  max-width:300px;backdrop-filter:blur(16px)}
#empty b{color:var(--txt);font-size:15px}
#empty button{margin-top:12px;padding:8px 16px;border-radius:9px;border:1px solid var(--border);
  background:rgba(251,191,36,.14);color:var(--brand);font-size:12.5px;cursor:pointer;font-weight:600}
#empty button:hover{border-color:var(--brand)}

/* ============================== Toasts / logros ============================== */
#toasts{position:fixed;top:116px;left:50%;transform:translateX(-50%);z-index:11;display:flex;
  flex-direction:column;gap:8px;pointer-events:none;align-items:center}
.toast{background:var(--glass2);border:1px solid rgba(251,191,36,.45);border-radius:30px;
  padding:10px 22px;font-size:13px;font-weight:600;color:var(--txt);box-shadow:0 8px 32px rgba(0,0,0,.5),
  0 0 24px rgba(251,191,36,.25);backdrop-filter:blur(16px);
  animation:toastIn .4s cubic-bezier(.22,1,.36,1),toastOut .4s ease 3.4s forwards}
.toast .tIc{margin-right:6px}
@keyframes toastIn{from{opacity:0;transform:translateY(-16px) scale(.92)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(-10px) scale(.95)}}

/* ============================== Tour de bienvenida ============================== */
#tour{position:fixed;inset:0;z-index:20;display:none;align-items:center;justify-content:center;
  background:rgba(2,4,12,.72);backdrop-filter:blur(8px)}
#tour.show{display:flex}
.tourCard{position:relative;max-width:480px;margin:18px;padding:26px 28px;
  animation:tourIn .5s cubic-bezier(.22,1,.36,1)}
@keyframes tourIn{from{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:none}}
.tourTitle{font-family:var(--display);font-size:21px;font-weight:700;margin-bottom:14px;
  background:linear-gradient(90deg,var(--brand),var(--pink));-webkit-background-clip:text;
  background-clip:text;-webkit-text-fill-color:transparent}
.tourCard ul{margin:0;padding:0;list-style:none}
.tourCard li{font-size:13.5px;line-height:1.6;color:#dde4ff;padding:9px 0 9px 30px;position:relative}
.tourCard li::before{content:"✦";position:absolute;left:4px;color:var(--brand)}
.tourCard li b{color:#fff}
#tourGo{width:100%;margin-top:18px;padding:13px;border:0;border-radius:12px;cursor:pointer;
  font-size:14.5px;font-weight:700;color:#231503;font-family:var(--display);
  background:linear-gradient(135deg,var(--brand),var(--brand2));
  box-shadow:0 6px 28px rgba(251,191,36,.4);transition:transform .15s}
#tourGo:hover{transform:translateY(-2px)}

/* ============================== Atajos ============================== */
#shortcuts{display:none;top:50%;left:50%;transform:translate(-50%,-50%);z-index:21;width:380px;
  max-width:calc(100vw - 28px);padding:22px 24px;background:var(--glass2)}
.shTitle{font-family:var(--display);font-size:17px;font-weight:700;margin-bottom:14px}
.shGrid{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:12.5px;color:var(--muted)}
.key{display:inline-block;background:rgba(255,255,255,.08);border:1px solid var(--border);
  border-radius:7px;padding:3px 9px;font-size:11px;color:var(--txt);font-weight:600;
  font-family:var(--font);text-align:center;white-space:nowrap}

/* ============================== Brújula ============================== */
#guiaBackdrop{position:fixed;inset:0;z-index:9;display:none;background:rgba(2,4,12,.6);
  backdrop-filter:blur(6px)}
#guia{top:50%;left:50%;transform:translate(-50%,-50%);width:480px;max-width:calc(100vw - 24px);
  max-height:calc(100vh - 90px);overflow-y:auto;padding:20px 22px;display:none;z-index:10;
  background:var(--glass2)}
#guia .gtitle{font-family:var(--display);font-size:18px;font-weight:700;margin:0 0 3px}
#guia .gsub{font-size:12px;color:var(--muted)}
#guia .gstep{font-size:11px;text-transform:uppercase;letter-spacing:1.4px;color:var(--brand);
  margin:16px 0 9px;font-weight:600;display:flex;align-items:center;gap:8px}
#guia .gnum{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;
  border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#231503;
  font-size:11px;font-weight:700}
#guia .gclose{position:absolute;top:13px;right:16px;cursor:pointer;color:var(--muted);font-size:21px;z-index:2}
#guia .gclose:hover{color:#fff}
#guia .gopts{display:flex;flex-wrap:wrap;gap:7px}
#guia .gopt{padding:9px 13px;border-radius:11px;border:1px solid var(--border);
  background:rgba(255,255,255,.05);color:var(--txt);font-size:12.5px;cursor:pointer;text-align:left;
  transition:all .15s;font-weight:500}
#guia .gopt:hover{border-color:var(--brand);background:rgba(251,191,36,.12);transform:translateY(-1px)}
#guia .gopt.sel{background:linear-gradient(135deg,var(--brand),var(--brand2));border-color:transparent;
  color:#231503;font-weight:700}
#guia .gresult{margin-top:16px;border-top:1px solid var(--border);padding-top:13px}
#guia .gtool{display:flex;align-items:center;gap:10px;padding:10px 13px;border-radius:11px;
  background:rgba(255,255,255,.05);margin-bottom:7px;cursor:pointer;border:1px solid var(--border);
  transition:all .15s}
#guia .gtool:hover{border-color:var(--brand);transform:translateX(3px)}
#guia .gtool .gn{font-weight:700;font-size:13.5px}
#guia .gtool .gf{font-size:11px;color:var(--muted)}
#guia .gtool .gp{margin-left:auto;font-size:10.5px;color:var(--muted);white-space:nowrap;flex:none}
#guia .gnote{font-size:11.5px;color:#ffd9a8;background:rgba(251,146,60,.12);border-radius:9px;
  padding:9px 11px;margin-top:8px;line-height:1.5}
#guia .gnote b{color:#ffc37a}
#guia .grow{display:flex;gap:8px;margin-top:14px}
#guia .grow button{flex:1;padding:9px;border-radius:9px;border:1px solid var(--border);
  background:rgba(255,255,255,.05);color:var(--muted);font-size:12px;cursor:pointer;font-weight:600}
#guia .grow button:hover{color:#fff;border-color:var(--brand)}

/* ============================== Vista de tabla ============================== */
#tableWrap{position:fixed;top:112px;left:312px;right:14px;bottom:14px;z-index:4;display:none;
  flex-direction:column;background:rgba(7,10,24,.92);border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;backdrop-filter:blur(20px)}
#tableBar{display:flex;align-items:center;gap:14px;padding:11px 16px;flex:none;
  border-bottom:1px solid var(--border);background:rgba(13,18,46,.6)}
#tableCount{font-size:12.5px;color:var(--muted)}
#tableCount b{color:var(--txt)}
#csvBtn{margin-left:auto;padding:7px 15px;border-radius:9px;border:1px solid var(--border);
  background:rgba(34,211,238,.10);color:var(--cyan);font-size:12px;font-weight:600;cursor:pointer;
  transition:all .15s}
#csvBtn:hover{border-color:var(--cyan);background:rgba(34,211,238,.18)}
#tableScroll{flex:1;overflow:auto}

#dataTable{border-collapse:separate;border-spacing:0;width:100%;font-size:12.5px}
#dataTable th{position:sticky;top:0;background:#10173a;color:var(--txt);text-align:left;
  padding:11px 14px;border-bottom:1px solid var(--border2);cursor:pointer;white-space:nowrap;z-index:1;
  font-size:11px;text-transform:uppercase;letter-spacing:1px;font-weight:600;user-select:none}
#dataTable th:hover{color:var(--brand)}
#dataTable th .ar{color:var(--brand);font-size:10px}
#dataTable td{padding:11px 14px;border-bottom:1px solid rgba(125,145,255,.08);vertical-align:top;
  color:#e6ebff}
#dataTable tbody tr{cursor:pointer;transition:background .12s}
#dataTable tbody tr:nth-child(even) td{background:rgba(125,145,255,.025)}
#dataTable tbody tr:hover td{background:rgba(34,211,238,.07)}
#dataTable tr.tGen td{background:rgba(255,242,194,.05)}
#dataTable tr.tDest td{background:rgba(255,79,163,.10)}
#dataTable tr.tRec td{box-shadow:inset 3px 0 0 var(--brand)}
#dataTable mark{background:rgba(251,191,36,.4);color:#fff;border-radius:3px;padding:0 1px}

.tName{display:flex;align-items:center;gap:9px}
.tFav{width:18px;height:18px;border-radius:5px;flex:none;background:rgba(255,255,255,.08)}
.tName a{color:#9fc3ff;text-decoration:none;font-weight:700;font-size:13px}
.tName a:hover{text-decoration:underline}
.tDesc{font-size:11.5px;color:var(--muted);margin-top:4px;max-width:380px;line-height:1.5}
.tMeta{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.tcell{display:flex;flex-wrap:wrap;gap:4px;max-width:240px}
.tbadge{font-size:10px;padding:2.5px 8px;border-radius:10px;background:rgba(255,255,255,.07);
  white-space:nowrap;font-weight:500}
.fdot{display:inline-flex;align-items:center;justify-content:center;width:19px;height:19px;
  border-radius:50%;font-size:9.5px;font-weight:700;color:#04060f;flex:none}
.fdots{display:flex;flex-wrap:wrap;gap:4px;max-width:130px}
.pill{display:inline-block;font-size:10.5px;font-weight:600;padding:3px 10px;border-radius:12px;
  border:1px solid;white-space:nowrap}
.aBadge{font-size:9.5px;font-weight:700;padding:2.5px 8px;border-radius:10px;letter-spacing:.3px;
  background:rgba(255,140,66,.16);color:#ffb380;border:1px solid rgba(255,140,66,.35)}
.recBadge{font-size:9.5px;font-weight:700;padding:2.5px 8px;border-radius:10px;
  background:rgba(251,191,36,.16);color:#ffd97a;border:1px solid rgba(251,191,36,.3)}

/* ============================== Vista de insights ============================== */
#insightsWrap{position:fixed;top:112px;left:312px;right:14px;bottom:14px;z-index:4;display:none;
  overflow:auto;background:rgba(7,10,24,.92);border:1px solid var(--border);border-radius:var(--r);
  padding:22px 26px;backdrop-filter:blur(20px)}
.insHead{margin:0 0 4px;font-size:20px;color:#fff;font-family:var(--display);font-weight:700}
.insSub{margin:0 0 20px;font-size:12px;color:var(--muted)}
.insGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:10px;margin-bottom:24px}
.insCard{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:13px;
  padding:14px 16px;transition:border-color .2s}
.insCard:hover{border-color:var(--border2)}
.insCard .num{font-size:27px;font-weight:700;color:var(--brand);line-height:1.1;font-family:var(--display)}
.insCard .lab{font-size:11.5px;color:var(--muted);margin-top:3px}
.insCard .sub{font-size:10.5px;color:var(--dim);margin-top:5px;line-height:1.45}
.insSection{margin:0 0 28px}
.insSection h3{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:#fff;margin:0 0 4px;
  font-family:var(--display)}
.insSection .note{font-size:11.5px;color:var(--muted);margin:0 0 12px;line-height:1.55;max-width:760px}
.insSection .note b{color:#ffd9a8}
.bar{display:flex;align-items:center;gap:10px;margin:5px 0;font-size:12px}
.bar .bl{width:190px;flex:none;color:#dde4ff;text-align:right;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis}
.bar .bt{flex:1;height:18px;background:rgba(255,255,255,.05);border-radius:6px;overflow:hidden;display:block}
.bar .bf{display:block;height:100%;border-radius:6px;min-width:2px;transition:width .4s}
.bar .bv{width:74px;flex:none;color:var(--muted);font-variant-numeric:tabular-nums}
.bar .bv b{color:#fff}
.heatScroll{overflow:auto;max-width:100%}
table.heat{border-collapse:collapse;font-size:11px}
table.heat th,table.heat td{padding:5px 7px;text-align:center;border:1px solid rgba(125,145,255,.10)}
table.heat th{color:#cfd8ff;font-weight:600;white-space:nowrap}
table.heat th.rowh{text-align:right;color:#e6ebff}
table.heat td{color:#fff;font-variant-numeric:tabular-nums;min-width:34px;font-weight:600}
table.heat td.z{color:#5a6b8c;font-weight:400}
table.heat .corner{background:transparent;border:0}
.insList{list-style:none;padding:0;margin:0}
.insList li{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:12.5px;
  border-bottom:1px solid rgba(125,145,255,.08)}
.insList li .rk{width:22px;color:var(--dim);text-align:right;font-weight:600}
.insList li .nm{flex:1;color:#e6ebff}
.insList li .badge{font-size:10px;padding:2px 8px;border-radius:10px;background:rgba(255,242,194,.12);
  color:#ffe9a8}
.insList li .mt{color:var(--muted);font-variant-numeric:tabular-nums}
.insFlex{display:flex;flex-wrap:wrap;gap:30px}
.insFlex>div{flex:1;min-width:300px}

/* ============================== Responsive ============================== */
@media (max-width:980px){
  #topbar .titles p{display:none}
}
@media (max-width:860px){
  #menuBtn{display:block}
  #controls{left:10px;right:10px;width:auto;top:auto;bottom:74px;max-height:62vh;
    transform:translateY(calc(100% + 90px));transition:transform .3s cubic-bezier(.22,1,.36,1)}
  #controls.open{transform:none}
  #closeControls{display:block}
  #detail{left:10px;right:10px;width:auto;top:auto;bottom:10px;max-height:64vh}
  #viewSwitch{top:58px}
  #legend{display:none}
  #minimap{display:none}
  #empty{left:50%}
  #topbar h1{font-size:13.5px}
  #progressHud .pbar{display:none}
  #tableWrap,#insightsWrap{top:104px;bottom:10px;left:10px;right:10px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}
