:root{
  --bg:#05080f; --bg2:#0a1830; --panel:rgba(255,255,255,.035); --panel2:rgba(10,25,45,.5);
  --line:rgba(140,180,220,.16); --txt:#dfeaf7; --dim:#7d96b5; --agua:#5b8cff; --agua-luz:#7fe6e0;
  --verde:#39d98a; --rosa:#e0607a; --amar:#f0b950;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:radial-gradient(130% 100% at 50% -10%,#0b1830 0%,#05080f 60%,#03060c 100%);
  color:var(--txt);font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;-webkit-font-smoothing:antialiased}
.hidden{display:none!important}
.grow{flex:1}
button{font:inherit;cursor:pointer}
.empty{color:var(--dim);font-size:12.5px;padding:18px;text-align:center}

/* ---------- compuerta ---------- */
.gate{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px}
.gate-box{background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:46px 40px;max-width:430px;text-align:center;backdrop-filter:blur(16px);box-shadow:0 30px 80px rgba(0,0,0,.5)}
.gate-mark{font-size:40px;filter:drop-shadow(0 0 18px rgba(127,230,224,.5))}
.gate-box h1{font-size:26px;font-weight:800;letter-spacing:-.5px;margin:10px 0 0}
.gate-box h1 span{color:var(--agua-luz)}
.gate-sub{color:var(--dim);font-size:13px;margin:10px 0 24px}
.gate-btn{background:linear-gradient(180deg,#3a86ff,#2f6fe0);border:0;color:#fff;border-radius:12px;padding:12px 22px;font-size:14px;font-weight:600;box-shadow:0 8px 24px rgba(58,134,255,.35)}
.gate-btn:hover{filter:brightness(1.08)}
.gate-msg{color:var(--rosa);font-size:12px;margin-top:14px;min-height:16px}

/* ---------- buque ---------- */
.ship{display:flex;flex-direction:column;height:100vh}
#topbar{flex:0 0 auto;display:flex;align-items:center;gap:14px;padding:10px 16px;border-bottom:1px solid var(--line);background:rgba(8,18,32,.55);backdrop-filter:blur(12px)}
.brand{font-weight:800;letter-spacing:-.3px}
.brand span{color:var(--agua-luz)}
#tabs{display:flex;gap:4px}
#tabs button{background:transparent;border:1px solid transparent;color:var(--dim);border-radius:9px;padding:6px 12px;font-size:13px}
#tabs button:hover{color:var(--txt)}
#tabs button.on{color:#eaf5ff;background:rgba(60,110,180,.22);border-color:var(--line)}
.who{font-size:12.5px;color:var(--agua-luz);font-weight:600}
.port{font-size:11px;color:var(--dim)}
.port.up{color:var(--verde)}
.port.down{color:var(--rosa)}
.iconbtn{background:transparent;border:1px solid var(--line);color:var(--dim);border-radius:8px;width:30px;height:28px}
.iconbtn:hover{color:var(--txt);border-color:var(--agua-luz)}

#stage{flex:1;min-height:0;position:relative}
.view{position:absolute;inset:0;overflow:auto;padding:16px;display:none}
.view.on{display:block}

/* ---------- cartografía ---------- */
.carto{display:flex;flex-flow:row wrap;align-items:flex-start;gap:14px;max-width:1100px;margin:0 auto}
.cell{flex:1 1 320px;min-width:280px;background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.sec-roadmap{box-shadow:inset 3px 0 0 var(--verde)}
.sec-notas{box-shadow:inset 3px 0 0 var(--amar)}
.cell-h{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--line);font-size:10px;letter-spacing:1.5px}
.sec-roadmap .cell-h b{color:#7fd9ad}.sec-notas .cell-h b{color:#e6c779}
.add{background:transparent;border:0;color:var(--agua-luz);font-size:16px;opacity:.8}
.add:hover{opacity:1}
.cell-list{padding:8px 10px}
.rm-card{border-bottom:1px solid rgba(150,180,215,.1);padding:2px 0}
.rm-card.oculta{opacity:.45}
.rm-head,.rm-sub{display:flex;align-items:flex-start;gap:7px;padding:5px 4px}
.rm-sub{border-radius:6px}
.chk{flex:0 0 auto;width:17px;height:17px;margin-top:1px;border:1.5px solid rgba(150,180,215,.4);border-radius:5px;background:transparent;color:var(--verde);font-size:11px;font-weight:800;line-height:1;display:flex;align-items:center;justify-content:center}
.chk.sm{width:15px;height:15px}
.chk.done{background:#2f9d6a;border-color:#2f9d6a;color:#eafff4}
.rm-text{flex:1;background:transparent;border:0;color:var(--txt);outline:none;resize:none;font:12px/1.45 inherit;padding-top:1px}
.rm-text.sm{font-size:11px;color:#cfe0f5}
.rm-text::placeholder{color:#6f88a8}
.rm-sub.done .rm-text{color:#7d96b5;text-decoration:line-through}
.mini{background:transparent;border:0;color:var(--dim);font-size:11px;display:flex;align-items:center;gap:3px;padding:2px 4px}
.mini:hover{color:#eaf5ff}
.badge{font-size:9px;background:rgba(150,180,215,.15);padding:1px 5px;border-radius:8px;color:#9fc1e6}
.del{background:transparent;border:0;color:#8aa2bf;opacity:.35;font-size:14px;padding:0 4px}
.rm-head:hover .del,.nota:hover .del,.rm-sub:hover .del{opacity:.75}
.rm-subs{margin:2px 0 6px 24px;border-left:1px solid rgba(150,180,215,.14);padding-left:7px}
.addsub{background:transparent;border:0;color:#6f88a8;font-size:9.5px;padding:3px}
.addsub:hover{color:#9fc1e6}
.nota-head{display:flex;align-items:center;gap:8px;padding:7px 4px;cursor:pointer;border-bottom:1px solid rgba(150,180,215,.1)}
.nota-head:hover{background:rgba(150,180,215,.06);border-radius:6px}
.nota .caret{color:var(--dim);opacity:.6}
.nl{flex:1;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* overlay nota */
.ov{position:fixed;inset:0;z-index:60;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;padding:24px}
.ov-box{background:#141a24;border:1px solid var(--line);border-radius:16px;width:min(780px,93vw);height:min(74vh,760px);display:flex;flex-direction:column;padding:16px;box-shadow:0 24px 64px rgba(0,0,0,.6)}
.ov-big{flex:1;background:var(--panel2);border:1px solid var(--line);color:#eaf2fb;border-radius:12px;padding:18px 20px;font:15px/1.65 inherit;outline:none;resize:none}
.ov-big:focus{border-color:var(--agua-luz)}
.ov-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.ov-foot .hint{font-size:11px;color:var(--dim)}
.ov-foot .ok{background:var(--agua);border:1px solid var(--agua);color:#fff;border-radius:9px;padding:8px 18px;font-size:13px}

/* ---------- atolón ---------- */
.atolon{max-width:1100px;margin:0 auto}
.bread{display:flex;gap:6px;align-items:center;padding:4px 2px 10px;font-size:11.5px;color:var(--dim);flex-wrap:wrap}
.crumb{cursor:pointer;padding:2px 7px;border-radius:6px;color:#bcd6f0}
.crumb:hover{background:var(--panel2)}
.crumb.cur{color:#eaf5ff}
.cells{display:flex;flex-flow:row wrap;align-content:flex-start;gap:2px 12px}
.aname{font-size:10px;line-height:1.7;color:var(--dim);cursor:pointer;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}
.aname:hover{color:#eaf5ff}
.aname.rock{color:#9fb1c8}
.aname.water{color:var(--agua-luz)}.aname.water::before{content:"~ "}
.aname.file{color:#6f7d8c;cursor:default}

/* ---------- tripulación ---------- */
.trip{display:flex;flex-direction:column;height:100%;max-width:1100px;margin:0 auto}
.trip-grid{flex:1;min-height:0;display:flex;gap:12px;overflow:auto}
.tm{flex:1 1 0;min-width:240px;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.tm-head{flex:0 0 auto;display:flex;align-items:center;gap:7px;padding:8px 11px;background:rgba(20,38,60,.5);border-bottom:1px solid var(--line);font-size:12.5px}
.tm-model,.tm-reset,.tm-x{background:transparent;border:0;color:var(--dim);font-size:13px;padding:2px 5px;border-radius:6px}
.tm-model{font-weight:700;border:1px solid var(--line)}
.tm-model:hover,.tm-reset:hover,.tm-x:hover{color:#eaf5ff;background:rgba(150,180,215,.12)}
.tm-chat{flex:1;overflow:auto;padding:10px;display:flex;flex-direction:column;gap:8px}
.msg{max-width:88%;padding:8px 11px;border-radius:12px;font-size:12.5px;line-height:1.45;white-space:pre-wrap;word-break:break-word}
.msg.q{align-self:flex-end;background:linear-gradient(180deg,#2f6fe0,#2a5fc0);color:#fff}
.msg.a{align-self:flex-start;background:var(--panel2);border:1px solid var(--line);color:#e6edf7}
.msg.pend{opacity:.6;font-style:italic}
.tm-compose{flex:0 0 auto;display:flex;gap:6px;padding:8px;border-top:1px solid var(--line)}
.tm-compose textarea{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:9px;padding:8px 10px;font:12.5px/1.4 inherit;outline:none;resize:none;min-height:36px;max-height:120px}
.tm-compose .send{flex:0 0 auto;background:var(--agua);border:0;color:#fff;border-radius:9px;width:38px;font-size:15px}
.trip-bar{flex:0 0 auto;display:flex;gap:6px;padding:10px 2px 2px}
.chip{display:flex;align-items:center;gap:6px;background:var(--panel2);border:1px solid var(--line);color:var(--dim);border-radius:9px;padding:6px 12px;font-size:12.5px}
.chip:hover{color:var(--txt);border-color:var(--agua-luz)}
.chip.on{color:#fff;border-color:var(--agua);background:rgba(60,110,180,.3)}

/* ---------- edición en vivo ---------- */
.vivo{max-width:1000px;margin:0 auto;height:100%;display:flex;flex-direction:column}
.vivo-bar{display:flex;align-items:center;gap:8px;padding:4px 2px 12px;font-size:13px}
.vivo-bar b{letter-spacing:.3px}
.vivo-who{font-size:11px;color:var(--dim)}
.vivo-ta{flex:1;background:var(--panel2);border:1px solid var(--line);color:#eaf2fb;border-radius:14px;padding:20px 24px;font:15px/1.7 inherit;outline:none;resize:none}
.vivo-ta:focus{border-color:var(--agua-luz)}

/* ---------- toasts ---------- */
#toast-host{position:fixed;right:18px;bottom:18px;z-index:80;display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.toast{background:#141a24;border:1px solid var(--line);color:var(--txt);border-radius:11px;padding:10px 14px;font-size:12.5px;max-width:320px;box-shadow:0 14px 36px rgba(0,0,0,.5);opacity:0;transform:translateY(10px);transition:.25s}
.toast.in{opacity:1;transform:translateY(0)}
.toast.err{border-color:rgba(224,96,122,.55)}

/* scrollbars */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:rgba(150,180,215,.18);border-radius:6px}
::-webkit-scrollbar-track{background:transparent}

@media(max-width:680px){ #tabs button span{display:none} .trip-grid{flex-direction:column} }
