:root{
  --bg:#14181c; --panel:#1d2329; --panel2:#232a31; --line:#2e3740;
  --txt:#e8ecef; --dim:#8a98a5; --acc:#39c98e; --acc2:#ffb454; --ut:#5dabf0;
  --danger:#e0556a;
  --mono:"Consolas","Roboto Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:var(--bg);color:var(--txt);
  font:15px/1.5 system-ui,"Segoe UI",Roboto,sans-serif;
  padding-bottom:40px;
}
a{color:var(--ut);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- barra superior ---- */
header.top{
  position:sticky;top:0;z-index:20;background:var(--bg);
  border-bottom:1px solid var(--line);
  padding:12px 16px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;
}
header.top h1{font-size:15px;font-weight:700;letter-spacing:.3px;flex:1;min-width:180px}
header.top h1 span{color:var(--acc);font-family:var(--mono)}
.who{font-size:12px;color:var(--dim);font-family:var(--mono)}
.btn-out{
  font-size:12px;color:var(--dim);border:1px solid var(--line);
  border-radius:6px;padding:5px 10px;background:none;cursor:pointer;
}
.btn-out:hover{border-color:var(--acc);color:var(--acc)}

/* ---- contenedores ---- */
.wrap{max-width:760px;margin:0 auto;padding:16px}
.wrap.wide{max-width:1200px}
.card{
  background:var(--panel);border:1px solid var(--line);
  border-radius:12px;padding:16px;margin-bottom:16px;
}
.card h2{font-size:14px;color:var(--dim);text-transform:uppercase;
  letter-spacing:.6px;margin-bottom:12px;font-weight:600}

/* ---- formulario ---- */
label{display:block;font-size:12.5px;color:var(--dim);margin:0 0 5px}
.field{margin-bottom:14px}
input,select,textarea{
  width:100%;padding:11px 12px;font-size:15px;border-radius:9px;
  border:1px solid var(--line);background:var(--panel2);color:var(--txt);
  outline:none;font-family:inherit;
}
input:focus,select:focus,textarea:focus{border-color:var(--acc)}
textarea{min-height:90px;resize:vertical}
.row2{display:flex;gap:12px;flex-wrap:wrap}
.row2>.field{flex:1;min-width:140px}
.hint{font-size:11.5px;color:var(--dim);margin-top:4px}

/* ---- buscador de equipo ---- */
.searchbox{position:relative}
#equipo_res{
  position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:30;
  background:var(--panel2);border:1px solid var(--line);border-radius:10px;
  max-height:280px;overflow-y:auto;display:none;box-shadow:0 10px 30px rgba(0,0,0,.5);
}
#equipo_res.show{display:block}
.res-item{padding:9px 12px;cursor:pointer;border-bottom:1px solid var(--line)}
.res-item:last-child{border-bottom:none}
.res-item:hover,.res-item.active{background:var(--panel)}
.res-item .code{font-family:var(--mono);color:var(--acc2);font-size:13px;font-weight:600}
.res-item.ut .code{color:var(--ut)}
.res-item .nm{font-size:13.5px;margin-top:2px}
.res-item .ar{font-size:11.5px;color:var(--dim);font-family:var(--mono);margin-top:2px}

/* equipo elegido */
.chosen{
  background:var(--panel2);border:1px solid var(--acc);border-radius:10px;
  padding:10px 12px;margin-top:8px;display:none;
}
.chosen.show{display:block}
.chosen .code{font-family:var(--mono);color:var(--acc2);font-weight:600}
.chosen .nm{font-size:14px;margin-top:2px}
.chosen .ar{font-size:12px;color:var(--dim);font-family:var(--mono);margin-top:2px}
.chosen .clear{float:right;color:var(--danger);cursor:pointer;font-size:12px}

/* materiales */
.mat-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.mat-row input{flex:1;min-width:0}
.mat-row .mat-desc{flex:2}
.mat-del{
  flex:0 0 auto;width:36px;height:42px;border:1px solid var(--line);
  border-radius:9px;background:none;color:var(--danger);cursor:pointer;font-size:18px;
}
.mat-del:hover{border-color:var(--danger)}
.btn-add{
  background:none;border:1px dashed var(--line);color:var(--acc);
  border-radius:9px;padding:9px;width:100%;cursor:pointer;font-size:13.5px;margin-top:2px;
}
.btn-add:hover{border-color:var(--acc)}

/* segmentos sí/no */
.seg{display:flex;gap:8px}
.seg label{
  flex:1;display:flex;align-items:center;justify-content:center;gap:6px;
  border:1px solid var(--line);border-radius:9px;padding:11px;cursor:pointer;
  color:var(--txt);margin:0;font-size:14px;
}
.seg input{display:none;width:auto}
.seg input:checked + span{font-weight:700}
.seg label:has(input:checked){border-color:var(--acc);background:rgba(57,201,142,.12)}

/* botón principal */
.btn-go{
  width:100%;background:var(--acc);color:#0d1f17;font-weight:700;font-size:16px;
  border:none;border-radius:10px;padding:14px;cursor:pointer;margin-top:6px;
}
.btn-go:hover{filter:brightness(1.06)}

/* mensajes */
.flash{border-radius:10px;padding:12px 14px;margin-bottom:16px;font-size:14px}
.flash.ok{background:rgba(57,201,142,.14);border:1px solid var(--acc);color:#bff0d8}
.flash.err{background:rgba(224,85,106,.14);border:1px solid var(--danger);color:#f3c0c8}

/* login */
.login-wrap{max-width:360px;margin:14vh auto 0;padding:16px}
.login-wrap h1{font-size:18px;text-align:center;margin-bottom:4px}
.login-wrap h1 span{color:var(--acc);font-family:var(--mono)}
.login-wrap p.sub{text-align:center;color:var(--dim);font-size:12.5px;margin-bottom:20px}

/* ---- tabla admin ---- */
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.filters .field{margin:0;min-width:130px;flex:1}
.filters .field.sm{flex:0 0 130px}
.btn-sm{background:var(--acc);color:#0d1f17;border:none;border-radius:8px;
  padding:11px 16px;font-weight:700;cursor:pointer;font-size:14px}
.btn-ghost{background:none;border:1px solid var(--line);color:var(--txt);
  border-radius:8px;padding:11px 16px;cursor:pointer;font-size:14px}
.btn-ghost:hover{border-color:var(--acc)}
.btn-danger{color:#c0392b;border-color:#e6b3ad}
.btn-danger:hover{background:#fbe9e7;border-color:#c0392b}

.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:10px}
table{border-collapse:collapse;width:100%;font-size:13px;min-width:900px}
th,td{padding:9px 11px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
th{background:var(--panel2);color:var(--dim);font-weight:600;position:sticky;top:0;
  text-transform:uppercase;font-size:11px;letter-spacing:.4px}
tr:hover td{background:var(--panel2)}
td .code{font-family:var(--mono);color:var(--acc2);font-weight:600}
.pill{font-size:11px;padding:2px 8px;border-radius:20px;border:1px solid var(--line);white-space:nowrap}
.pill.fin{color:#bff0d8;border-color:var(--acc);background:rgba(57,201,142,.10)}
.pill.pen{color:var(--acc2);border-color:var(--acc2);background:rgba(255,180,84,.10)}
.pill.av{color:var(--ut);border-color:var(--ut)}
.mats{font-size:12px;color:var(--dim)}
.count{font-family:var(--mono);font-size:12.5px;color:var(--dim);margin:10px 2px}
.count b{color:var(--acc)}
.empty{text-align:center;color:var(--dim);padding:40px 20px}
.del-link{color:var(--danger);font-size:12px;cursor:pointer;background:none;border:none}

/* ---- logo Ganfeng ---- */
.brand-chip{display:inline-flex;align-items:center;justify-content:center;
  background:#fff;border-radius:8px;padding:5px 9px;line-height:0;flex:0 0 auto}
.brand-logo{height:24px;width:auto;display:block}
.brand-word{font-weight:800;letter-spacing:.5px;color:#0d6b3f;font-size:14px}
.login-logo{display:flex;margin:0 auto 16px;width:max-content;padding:12px 18px}
.login-logo .brand-logo{height:42px}

/* ---- filtros de equipo (Área + Categoría) ---- */
.eq-filters{display:flex;gap:8px;margin-bottom:8px}
.eq-filters select{flex:1;min-width:0;font-size:13.5px;padding:9px 10px}

/* ---- crédito ---- */
.credit{text-align:center;color:var(--dim);font-size:12px;padding:22px 16px 8px;letter-spacing:.3px}
.credit b{color:var(--txt);letter-spacing:.5px}

/* ---- panel operaciones ---- */
.oper-check{text-align:center}
.bigcheck{display:inline-flex;align-items:center;cursor:pointer}
.bigcheck input{width:22px;height:22px;accent-color:var(--acc);cursor:pointer}
.bigcheck span{display:none}
.oper-com{min-width:150px;padding:8px 10px;font-size:13px}
.btn-sm.sm2{padding:8px 12px;font-size:13px;white-space:nowrap}

/* ---- miniatura de foto ---- */
.thumb{width:54px;height:54px;object-fit:cover;border-radius:8px;border:1px solid var(--line);cursor:pointer}
.thumb:hover{border-color:var(--acc)}

/* ---- dashboard de análisis ---- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center}
.kpi-n{font-size:28px;font-weight:800;color:var(--acc);font-family:var(--mono)}
.kpi-l{font-size:12px;color:var(--dim);margin-top:4px;text-transform:uppercase;letter-spacing:.4px}
.chart-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:16px}
.chart-card h3{font-size:14px;margin-bottom:14px;font-weight:700}
.chart-card h3 small{color:var(--dim);font-weight:400;font-size:12px}
.chart-box{position:relative;width:100%}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:820px){ .kpis{grid-template-columns:repeat(2,1fr)} .grid2{grid-template-columns:1fr} }

/* ---- selector de equipo reutilizable ---- */
.eqpicker{position:relative}
.eqp-res{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:30;background:var(--panel2);
  border:1px solid var(--line);border-radius:10px;max-height:260px;overflow-y:auto;display:none;
  box-shadow:0 10px 30px rgba(0,0,0,.5)}
.eqp-res.show{display:block}

/* ---- handover / urgencias ---- */
.note{border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:10px;background:var(--panel2)}
.note.unseen{border-color:var(--acc2);background:rgba(255,180,84,.06)}
.note .meta{font-size:12px;color:var(--dim);margin-bottom:6px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.note .txt{font-size:14px;white-space:pre-wrap;line-height:1.5}
.note .acts{margin-top:8px;display:flex;gap:8px}
.scope-tag{font-size:11px;padding:2px 8px;border-radius:20px;border:1px solid var(--line);font-family:var(--mono)}
.scope-tag.eq{color:var(--acc2);border-color:var(--acc2)}
.scope-tag.ar{color:var(--ut);border-color:var(--ut)}
.scope-tag.ge{color:var(--acc);border-color:var(--acc)}

.urg{border-left:4px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:10px;background:var(--panel2);border:1px solid var(--line)}
.urg.crit{border-left-color:var(--danger)}
.urg.alta{border-left-color:var(--acc2)}
.urg.media{border-left-color:var(--ut)}
.urg.resuelta{opacity:.55}
.nivel{font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}
.nivel.crit{background:rgba(224,85,106,.15);color:#f3c0c8;border:1px solid var(--danger)}
.nivel.alta{background:rgba(255,180,84,.13);color:var(--acc2);border:1px solid var(--acc2)}
.nivel.media{background:rgba(93,171,240,.13);color:var(--ut);border:1px solid var(--ut)}

.alert-bar{background:rgba(224,85,106,.12);border:1px solid var(--danger);border-radius:10px;
  padding:12px 14px;margin-bottom:16px;color:#f3c0c8;font-size:14px}
.alert-bar a{color:#fff;font-weight:700}

/* ---- repuestos ---- */
.rep-min{width:90px;padding:7px 9px;font-size:13px;text-align:right}
.row-corte td{background:rgba(224,85,106,.10) !important}
.badge-corte{font-size:11px;font-weight:700;color:#f3c0c8;background:rgba(224,85,106,.2);
  border:1px solid var(--danger);border-radius:20px;padding:2px 8px;white-space:nowrap}

/* ---- selector principal (Cargar parte / Operaciones / Admin) ---- */
.navseg{display:inline-flex;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.navseg-i{padding:7px 14px;border-radius:8px;font-size:13px;font-weight:600;color:var(--dim);text-decoration:none;white-space:nowrap}
.navseg-i:hover{color:var(--ink)}
.navseg-i.on{background:var(--acc);color:#06231a}
@media(max-width:640px){ .navseg-i{padding:6px 10px;font-size:12px} }

/* ---- desplegable de sección (Cargar parte / Operaciones / Admin) ---- */
.navsel{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background:var(--panel2) url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2339c98e' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 11px center;
  border:1px solid var(--line);border-radius:10px;color:var(--ink);
  font-size:13px;font-weight:700;letter-spacing:.3px;padding:9px 34px 9px 14px;cursor:pointer}
.navsel:hover{border-color:var(--acc)}
.navsel:focus{outline:none;border-color:var(--acc)}
.navsel option{background:var(--panel2);color:var(--ink)}

/* botones del admin en MAYÚSCULAS */
.btn-out{text-transform:uppercase;letter-spacing:.4px}
