:root{--bg:#0e1420;--card:#151d2b;--line:#1c2430;--txt:#e7ecf3;--muted:#9aa4b2;--accent:#f7931a}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);font-family:Inter,system-ui,Segoe UI,Arial,sans-serif}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted);font-size:.85rem}

/* Login */
.login-bg{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--card);padding:2.2rem;border-radius:14px;width:330px;border:1px solid var(--line)}
.login-card h1{margin:0 0 .2rem;color:var(--accent)}
.login-card form{display:flex;flex-direction:column;margin-top:1rem}
.login-card label{font-size:.8rem;color:var(--muted);margin:.6rem 0 .2rem}
.login-card input{padding:.6rem;border-radius:8px;border:1px solid var(--line);background:#0c121d;color:var(--txt)}
.login-card button{margin-top:1.2rem;padding:.7rem;border:0;border-radius:8px;background:var(--accent);color:#1a1a1a;font-weight:700;cursor:pointer}
.error{background:#3a1620;color:#ff8a9c;padding:.5rem .7rem;border-radius:8px;font-size:.85rem;margin-top:.8rem}

/* Layout */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1.2rem;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:5}
.brand{font-weight:800;color:var(--accent);font-size:1.1rem}
.actions{display:flex;gap:.6rem;align-items:center}
.ghost{padding:.45rem .8rem;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--txt);cursor:pointer;font-size:.85rem}
main{max-width:1100px;margin:0 auto;padding:1.2rem}

.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:.8rem;margin-bottom:1rem}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:.8rem}
.kpi-label{color:var(--muted);font-size:.72rem}
.kpi-value{font-size:1.15rem;font-weight:700;margin-top:.25rem}

.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:1rem;margin-bottom:1rem}
.card-head{display:flex;justify-content:space-between;align-items:center}
.card h2{margin:.1rem 0 .8rem;font-size:1rem}
.chart-wrap{height:380px}
.switch{font-size:.8rem;color:var(--muted)}

.legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.7rem;font-size:.78rem;color:var(--muted)}
.lg{display:flex;align-items:center;gap:.35rem}
.lg i{width:14px;height:10px;display:inline-block;border-radius:2px}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.proj-row{display:flex;align-items:center;gap:.5rem;margin-top:.6rem;font-size:.95rem}
.proj-detail{margin:.1rem 0 .4rem 1rem}
.dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.dot.teal{background:#16b3b3}.dot.green{background:#2E9E5B}

.calc{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.calc label{font-size:.78rem;color:var(--muted);display:flex;flex-direction:column;gap:.25rem}
.calc input{padding:.45rem;border-radius:8px;border:1px solid var(--line);background:#0c121d;color:var(--txt)}
.calc-out{margin-top:.9rem;border-top:1px solid var(--line);padding-top:.7rem}
.calc-out .row{display:flex;justify-content:space-between;padding:.25rem 0}

.badge{padding:.15rem .5rem;border-radius:6px;background:#222c3a;font-size:.8rem}
.badge.buy{background:#0f5132;color:#7be0a6;font-weight:700}
.disclaimer{color:var(--muted);font-size:.75rem;text-align:center;margin:1.5rem 0}

@media(max-width:900px){.kpis{grid-template-columns:repeat(2,1fr)}.grid2{grid-template-columns:1fr}}

/* TradingView widget */
.tv-wrap{height:480px;width:100%}
.tv-copy{font-size:.72rem;margin-top:.4rem}
.tv-copy a{color:var(--muted)}

/* Estadísticas */
.tabs{display:flex;gap:.4rem;margin-bottom:1rem;flex-wrap:wrap}
.tab{padding:.5rem .9rem;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;font-size:.85rem}
.tab.active{background:var(--accent);color:#1a1a1a;font-weight:700;border-color:var(--accent)}
.tabpane.hidden{display:none}
.tools{display:flex;gap:.5rem;align-items:center}
.tools input{padding:.45rem .6rem;border-radius:8px;border:1px solid var(--line);background:#0c121d;color:var(--txt);font-size:.85rem}
.table-wrap{max-height:62vh;overflow:auto;border:1px solid var(--line);border-radius:10px;margin-top:.6rem}
table{width:100%;border-collapse:collapse;font-size:.85rem}
thead th{position:sticky;top:0;background:#0c1320;color:#cdd6e3;text-align:left;padding:.55rem .7rem;border-bottom:1px solid var(--line);font-weight:600}
tbody td{padding:.45rem .7rem;border-bottom:1px solid #141b27}
tbody tr:hover{background:#121a28}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.seasondot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:.4rem;vertical-align:-1px}

/* Tablas de estadísticas */
.filter{width:100%;padding:.5rem .7rem;border-radius:8px;border:1px solid var(--line);background:#0c121d;color:var(--txt);margin-bottom:.7rem}
.table-scroll{max-height:430px;overflow:auto;border:1px solid var(--line);border-radius:10px}
.data-table{width:100%;border-collapse:collapse;font-size:.85rem}
.data-table th,.data-table td{padding:.45rem .7rem;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
.data-table thead th{position:sticky;top:0;background:#0f1622;color:var(--muted);font-weight:600;z-index:1}
.data-table td.num,.data-table th.num{text-align:right;font-variant-numeric:tabular-nums}
.data-table tbody tr:hover{background:#11192655}
.small{font-size:.72rem;margin-top:.5rem}

/* ===== Bitácora / journal (Sprint 1) ===== */
/* Sub-navegación de secciones */
.subnav{display:flex;gap:.3rem;flex-wrap:wrap;padding:.5rem 1.2rem;border-bottom:1px solid var(--line);background:var(--bg);position:sticky;top:51px;z-index:4}
.subnav a{padding:.4rem .8rem;border-radius:8px;color:var(--muted);font-size:.85rem}
.subnav a:hover{color:var(--txt);background:#161f2e}
.subnav a.on{color:var(--accent);background:#1b2433;font-weight:700}

/* Botones */
.primary{padding:.45rem .9rem;border:1px solid var(--accent);border-radius:8px;background:var(--accent);color:#1a1a1a;font-weight:700;cursor:pointer;font-size:.85rem}
.primary:hover{filter:brightness(1.07)}
.quick{display:flex;flex-wrap:wrap;gap:.6rem}
.mini{padding:.3rem .6rem;border:1px solid var(--line);border-radius:7px;background:transparent;color:var(--txt);cursor:pointer;font-size:.78rem}
.mini:hover{background:#161f2e}
.mini.danger:hover{border-color:#ea3943;color:#ff8a9c}
.icon-btn{background:transparent;border:0;color:var(--muted);font-size:1.1rem;cursor:pointer;line-height:1}
.icon-btn:hover{color:var(--txt)}

/* Grid y tarjetas de nota */
.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.8rem;margin-top:.4rem}
.note-card{background:#101725;border:1px solid var(--line);border-radius:10px;padding:.8rem;display:flex;flex-direction:column;gap:.4rem}
.note-card:hover{border-color:#2a3650}
.nc-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.nc-date{color:var(--muted);font-size:.72rem}
.nc-badges{display:flex;gap:.35rem;flex-wrap:wrap}
.nc-meta{font-size:.78rem;color:#c4ccd8}
.nc-setup{font-weight:600;font-size:.85rem}
.nc-text{font-size:.83rem;color:#aeb7c4;margin:.1rem 0;line-height:1.35}
.nc-tags{display:flex;flex-wrap:wrap;gap:.3rem}
.nc-actions{display:flex;gap:.4rem;margin-top:.2rem;border-top:1px solid var(--line);padding-top:.5rem}

/* Badges de sesgo y resultado */
.badge.b-up{background:#0f3a2a;color:#5fd6a0}
.badge.b-down{background:#3a1620;color:#ff8a9c}
.badge.b-neu{background:#2a3142;color:#aeb7c4}
.badge.r-ok{background:#0f3a2a;color:#5fd6a0}
.badge.r-bad{background:#3a1620;color:#ff8a9c}
.badge.r-part{background:#3a2f12;color:#e1b657}
.badge.r-pend{background:#1d2a3f;color:#7fa8d6}
.tag{background:#1c2738;color:#9fb0c6;border-radius:6px;padding:.1rem .45rem;font-size:.72rem}

/* Filtros */
.filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.8rem}
.filters .filter{flex:1 1 240px;margin-bottom:0}
.filters select{padding:.45rem .6rem;border-radius:8px;border:1px solid var(--line);background:#0c121d;color:var(--txt);font-size:.82rem}
.empty{text-align:center;color:var(--muted);padding:1.8rem;border:1px dashed var(--line);border-radius:10px}

/* Overlay + drawer + modal */
.overlay{position:fixed;inset:0;background:rgba(4,8,14,.6);z-index:40}
.overlay[hidden]{display:none}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(440px,100%);background:var(--card);border-left:1px solid var(--line);z-index:50;display:flex;flex-direction:column}
.drawer[hidden]{display:none}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(580px,92vw);max-height:86vh;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:14px;z-index:50;padding:0 0 1rem}
.modal[hidden]{display:none}
.drawer-head,.modal .drawer-head{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.1rem;border-bottom:1px solid var(--line)}
.drawer-head h3{margin:0;font-size:1rem}
.drawer-body{flex:1;overflow:auto;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.7rem}
.drawer-foot{display:flex;justify-content:flex-end;gap:.6rem;padding:.9rem 1.1rem;border-top:1px solid var(--line)}
.drawer label{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;color:var(--muted)}
.drawer input,.drawer select,.drawer textarea{padding:.5rem .6rem;border-radius:8px;border:1px solid var(--line);background:#0c121d;color:var(--txt);font-size:.9rem;font-family:inherit}
.drawer textarea{resize:vertical}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.checklist{border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;margin:0}
.checklist legend{color:var(--muted);font-size:.78rem;padding:0 .3rem}
.ck{flex-direction:row!important;align-items:center;gap:.5rem;color:var(--txt)!important;font-size:.85rem;margin:.15rem 0}
.ck input{width:auto}

/* Detalle de nota */
.ck-list{list-style:none;padding:0;margin:.6rem 0;display:grid;gap:.2rem;font-size:.85rem}
.ck-list li.ok{color:#5fd6a0}
.ck-list li.no{color:var(--muted)}
.snapshot{margin-top:.6rem;border-top:1px solid var(--line);padding-top:.5rem}

/* Próximamente (stubs) */
.soon{text-align:center;padding:2.4rem 1rem}
.soon-badge{display:inline-block;background:#1b2433;color:var(--accent);font-weight:700;font-size:.72rem;padding:.25rem .7rem;border-radius:999px;margin-bottom:.6rem}

@media(max-width:700px){
  .drawer{width:100%}
  .frow{grid-template-columns:1fr}
  .notes-grid{grid-template-columns:1fr}
  .subnav{top:49px}
}

/* ===== Operaciones (Sprint 3) ===== */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.metric{background:#101725;border:1px solid var(--line);border-radius:10px;padding:.6rem .7rem}
.m-label{color:var(--muted);font-size:.7rem}
.m-value{font-size:1.05rem;font-weight:700;margin-top:.15rem}
.pos{color:#16c784}.neg{color:#ea3943}
.warn{background:#3a2f12;color:#e1b657;border:1px solid #5a4a1c;padding:.5rem .7rem;border-radius:8px;font-size:.82rem}
.warn-row{color:#e1b657;font-size:.82rem;padding:.3rem 0}
.warn-x{display:inline-block;width:18px;height:18px;line-height:18px;text-align:center;border-radius:50%;background:#3a2f12;color:#e1b657;font-weight:700;font-size:.75rem}
.trow{display:flex;justify-content:space-between;padding:.3rem 0;border-bottom:1px solid var(--line);font-size:.9rem}
.data-table td.ops{white-space:nowrap}
.data-table td.ops .mini{margin-right:.25rem}
#tradesTable td{white-space:nowrap}
@media(max-width:700px){.metrics{grid-template-columns:repeat(2,1fr)}}

/* ===== Configuración (Sprint 4) ===== */
.cfg-h{font-size:.92rem;margin:.2rem 0 .6rem}
.cfg-l{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;color:var(--muted);margin-bottom:.6rem}
.cfg-l input{padding:.5rem .6rem;border-radius:8px;border:1px solid var(--line);background:#0c121d;color:var(--txt)}
.cfg-msg{margin-top:.6rem;font-size:.82rem;padding:.4rem .6rem;border-radius:8px}
.cfg-ok{background:#0f3a2a;color:#5fd6a0}
.cfg-err{background:#3a1620;color:#ff8a9c}
.cfg-sep{border:0;border-top:1px solid var(--line);margin:1rem 0}
.danger-zone{border-color:#5a2230}

/* ===== Capturas (Sprint 2) ===== */
.shots-field{border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem}
.shots-head{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:.78rem;margin-bottom:.5rem}
.shots{display:flex;flex-wrap:wrap;gap:.5rem}
.shot{position:relative;display:block;width:96px;height:60px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#0c121d}
.shot img{width:100%;height:100%;object-fit:cover;display:block}
.shot-x{position:absolute;top:2px;right:2px;width:18px;height:18px;line-height:16px;text-align:center;border:0;border-radius:50%;background:rgba(14,20,32,.85);color:#ff8a9c;cursor:pointer;font-size:.7rem;padding:0}
#viewBody .shots .shot{width:140px;height:88px}

/* ===== Research (Sprint 5) ===== */
.drawer-wide{width:min(640px,100%)}
.modal-wide{width:min(760px,92vw)}
.rich{font-size:.92rem;line-height:1.55;color:#d3dae4;margin:.4rem 0}
.rich h3{font-size:1.05rem;margin:1rem 0 .4rem;color:var(--txt)}
.rich h4{font-size:.95rem;margin:.8rem 0 .3rem;color:var(--txt)}
.rich p{margin:.4rem 0}
.rich ul{margin:.4rem 0 .4rem 1.1rem}
.rich li{margin:.15rem 0}
.rich strong{color:var(--txt)}
code{background:#0c121d;border:1px solid var(--line);border-radius:5px;padding:.05rem .3rem;font-size:.85em}

/* ===== Research (Sprint 5) ===== */
.research-body{line-height:1.6;color:#cdd5e0;font-size:.92rem;margin:.4rem 0}
.research-body p{margin:.5rem 0;white-space:pre-wrap}
.research-body h3{font-size:1rem;margin:1rem 0 .3rem}
.research-body h4{font-size:.92rem;margin:.8rem 0 .2rem;color:#e7ecf3}
.research-body ul{margin:.4rem 0 .4rem 1.1rem}
.research-body li{margin:.15rem 0}
.research-body strong{color:#e7ecf3}
