/* ============================================================
   Relevo · Paleta oficial HAON
   Fondo degradado azul profundo + acento dorado + glass.
   ============================================================ */
:root{
  /* Colores HAON */
  --haon-blue-deep:#0f2847;
  --haon-blue:#1a5bb8;
  --haon-blue-bright:#2c79e0;
  --haon-blue-light:#5BA3E8;
  --haon-accent:#ffd700;
  --haon-white:#ffffff;

  /* Fondo firma HAON */
  --bg-gradient:linear-gradient(160deg,#0f2847 0%,#1a4a8a 40%,#1a5bb8 100%);
  --superficie-oscura:linear-gradient(160deg,#14335c 0%,#0f2847 100%);

  /* Glass */
  --bg-glass:rgba(255,255,255,0.06);
  --bg-glass-border:rgba(255,255,255,0.12);
  --bg-glass-hover:rgba(255,255,255,0.1);
  --bg-input:rgba(0,0,0,0.25);
  --bg-input-focus:rgba(0,0,0,0.35);

  /* Texto */
  --text-primary:#ffffff;
  --text-secondary:rgba(255,255,255,0.9);
  --text-muted:rgba(255,255,255,0.6);
  --text-faint:rgba(255,255,255,0.4);

  /* Sombras y glow */
  --shadow-sm:0 2px 10px rgba(0,0,0,0.3);
  --shadow-md:0 4px 20px rgba(0,0,0,0.35);
  --shadow-glow:0 0 24px rgba(255,215,0,0.4);

  /* Estados */
  --color-success:#51cf66;
  --color-error:#ff6b6b;
  --color-warning:#ffd700;

  --radio:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  background:var(--bg-gradient);
  background-attachment:fixed;
  color:var(--text-primary);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  padding-bottom:90px;
  min-height:100vh;
}

/* ---------- Header ---------- */
header{
  background:linear-gradient(180deg,rgba(0,0,0,0.35),rgba(0,0,0,0.15));
  backdrop-filter:blur(10px);
  padding:20px 18px 16px;position:sticky;top:0;z-index:10;
  border-bottom:1px solid var(--bg-glass-border);
}
header .fila{display:flex;justify-content:space-between;align-items:center}
header h1{font-size:1.28rem;font-weight:700;display:flex;align-items:center;gap:8px}
header .ancla{color:var(--haon-accent)}
header p{font-size:.8rem;color:var(--text-muted);margin-top:2px;font-weight:300}
.admin-btn{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--bg-glass-border);padding:7px 12px;border-radius:9px;font-size:.76rem;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s}
.admin-btn:hover{background:var(--bg-glass-hover)}
.admin-btn.on{background:linear-gradient(135deg,#f5c44a 0%,#e0a830 100%);color:var(--haon-blue-deep);box-shadow:var(--shadow-glow)}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:4px;background:var(--bg-glass);border:1px solid var(--bg-glass-border);padding:6px;margin:14px 14px 0;border-radius:var(--radio);backdrop-filter:blur(8px)}
.tab{flex:1;border:none;background:transparent;padding:10px 6px;border-radius:10px;font-size:.8rem;font-weight:600;color:var(--text-muted);cursor:pointer;font-family:inherit;transition:.15s;display:flex;flex-direction:column;align-items:center;gap:3px}
.tab .ic{font-size:1.1rem;line-height:1}
.tab.activa{background:linear-gradient(135deg,#5BA3E8 0%,#3a87d4 100%);color:#fff;box-shadow:var(--shadow-sm)}

main{padding:16px 14px 0;max-width:560px;margin:0 auto}
.vista{display:none}
.vista.activa{display:block;animation:entra .2s ease}
@keyframes entra{from{opacity:0}to{opacity:1}}

/* ---------- Calendario ---------- */
.cal{background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radio);padding:14px;backdrop-filter:blur(10px);box-shadow:var(--shadow-md);margin-bottom:16px}
.cal-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.cal-top button{background:var(--bg-glass);border:1px solid var(--bg-glass-border);width:36px;height:36px;border-radius:10px;font-size:1.1rem;cursor:pointer;color:var(--text-primary);font-family:inherit;transition:.15s}
.cal-top button:hover{background:var(--bg-glass-hover)}
.cal-mes{font-size:1rem;font-weight:700;text-transform:capitalize;color:var(--text-primary)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-dow{text-align:center;font-size:.68rem;font-weight:700;color:var(--text-faint);padding:4px 0;text-transform:uppercase}
.cal-cel{aspect-ratio:1;border:none;background:transparent;border-radius:10px;font-size:.92rem;font-family:inherit;color:var(--text-secondary);cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;transition:.12s}
.cal-cel:disabled{color:transparent;cursor:default}
.cal-cel:hover:not(:disabled):not(.sel){background:var(--bg-glass-hover)}
.cal-cel.abierto{background:rgba(91,163,232,0.25);color:var(--haon-blue-light);font-weight:700}
.cal-cel.sel{background:linear-gradient(135deg,#5BA3E8 0%,#3a87d4 100%);color:#fff;font-weight:700;box-shadow:var(--shadow-sm)}
.cal-cel.hoy::after{content:"";position:absolute;bottom:5px;width:4px;height:4px;border-radius:50%;background:currentColor}
.cal-cel .punto{position:absolute;bottom:5px;width:5px;height:5px;border-radius:50%;background:var(--haon-accent);box-shadow:0 0 6px rgba(255,215,0,0.6)}
.cal-cel.sel .punto{background:#fff;box-shadow:none}
.cal-leyenda{display:flex;gap:14px;justify-content:center;margin-top:12px;font-size:.72rem;color:var(--text-muted)}
.cal-leyenda span{display:flex;align-items:center;gap:5px}
.punto-ley{width:8px;height:8px;border-radius:50%}

.dia-sel{font-size:.82rem;font-weight:700;color:var(--haon-accent);text-transform:uppercase;letter-spacing:.5px;margin:4px 4px 10px}

/* ---------- Turnos ---------- */
.turno{background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-left-width:4px;border-radius:12px;padding:13px 14px;margin-bottom:10px;backdrop-filter:blur(8px);box-shadow:var(--shadow-sm)}
.turno.pase{border-left-color:var(--haon-blue-light)}
.turno.guardia{border-left-color:var(--haon-accent)}
.turno-cab{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.turno-tipo{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:6px}
.turno.pase .turno-tipo{background:rgba(91,163,232,0.2);color:var(--haon-blue-light)}
.turno.guardia .turno-tipo{background:rgba(255,215,0,0.15);color:var(--haon-accent)}
.turno-hora{font-size:1.05rem;font-weight:700;margin-top:6px;color:var(--text-primary)}
.turno-etq{font-size:.8rem;color:var(--text-muted);margin-top:1px}
.turno-estado{margin-top:10px;font-size:.88rem}
.turno-estado .libre{color:var(--haon-accent);font-weight:600}
.turno-estado .tomado{color:var(--color-success);font-weight:600}
.turno-acciones{margin-top:11px;display:flex;gap:7px;flex-wrap:wrap}

/* ---------- Chips / botones de acción ---------- */
.chip{border:none;border-radius:8px;padding:7px 13px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s}
.chip-tomar{background:linear-gradient(135deg,#5BA3E8 0%,#3a87d4 100%);color:#fff}
.chip-soltar{background:rgba(255,215,0,0.15);color:var(--haon-accent);border:1px solid rgba(255,215,0,0.3)}
.chip-borrar{background:rgba(255,107,107,0.15);color:var(--color-error);border:1px solid rgba(255,107,107,0.3)}
.chip:active{transform:scale(.95)}
.chip-tomar:hover{box-shadow:var(--shadow-sm)}

.vacio{text-align:center;color:var(--text-muted);font-size:.9rem;padding:26px 18px;background:var(--bg-glass);border:1px dashed var(--bg-glass-border);border-radius:var(--radio)}
.vacio button{margin-top:12px;background:linear-gradient(135deg,#f5c44a 0%,#e0a830 100%);color:var(--haon-blue-deep);border:none;padding:10px 18px;border-radius:10px;font-weight:700;font-size:.85rem;cursor:pointer;font-family:inherit;transition:.15s}
.vacio button:hover{background:#ffe700;box-shadow:var(--shadow-glow)}

/* ---------- Reportes y apoyos ---------- */
.intro{font-size:.85rem;color:var(--text-muted);margin-bottom:14px;padding:0 4px}
.tarjeta{background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:var(--radio);padding:14px;margin-bottom:11px;backdrop-filter:blur(8px);box-shadow:var(--shadow-sm)}
.reporte .fecha{font-size:.72rem;font-weight:700;color:var(--haon-blue-light);text-transform:uppercase;letter-spacing:.5px}
.reporte .texto{font-size:.95rem;margin-top:6px;white-space:pre-wrap;color:var(--text-secondary)}
.reporte .meta{font-size:.75rem;color:var(--text-faint);margin-top:8px}
.apoyo .estado{display:inline-block;font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:6px;margin-bottom:6px}
.e-pend{background:rgba(255,215,0,0.15);color:var(--haon-accent)}
.e-cub{background:rgba(81,207,102,0.15);color:var(--color-success)}
.apoyo .titulo{font-weight:600;font-size:.96rem;color:var(--text-primary)}
.apoyo .detalle{font-size:.83rem;color:var(--text-muted);margin-top:3px}
.apoyo .quien{font-size:.83rem;margin-top:5px;color:var(--text-secondary)}
.acciones{margin-top:10px;display:flex;gap:7px;flex-wrap:wrap}

/* ---------- Botones flotantes ---------- */
.fab{position:fixed;right:18px;bottom:22px;background:linear-gradient(135deg,#f5c44a 0%,#e0a830 100%);color:var(--haon-blue-deep);border:none;width:56px;height:56px;border-radius:50%;font-size:1.7rem;cursor:pointer;box-shadow:var(--shadow-glow);display:flex;align-items:center;justify-content:center;z-index:20;transition:.15s}
.fab:active{transform:scale(.92)}
.recargar{position:fixed;left:18px;bottom:22px;background:var(--bg-glass);border:1px solid var(--bg-glass-border);width:46px;height:46px;border-radius:50%;font-size:1.2rem;cursor:pointer;box-shadow:var(--shadow-sm);z-index:20;color:var(--text-primary);backdrop-filter:blur(8px)}

/* ---------- Modal ---------- */
.fondo{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(3px);display:none;align-items:flex-end;justify-content:center;z-index:30}
.fondo.abierto{display:flex}
.modal{background:var(--superficie-oscura);border-top:1px solid var(--bg-glass-border);width:100%;max-width:560px;border-radius:18px 18px 0 0;padding:22px 18px 26px;animation:sube .25s ease;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-md)}
@keyframes sube{from{transform:translateY(100%)}to{transform:none}}
.modal h3{font-size:1.1rem;margin-bottom:4px;color:var(--text-primary)}
.modal .sub{font-size:.82rem;color:var(--text-muted);margin-bottom:16px}
label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin:12px 0 5px}
input,select,textarea{width:100%;border:1px solid var(--bg-glass-border);border-radius:10px;padding:11px 12px;font-size:.95rem;font-family:inherit;color:var(--text-primary);background:var(--bg-input);transition:.15s}
input::placeholder,textarea::placeholder{color:var(--text-faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--haon-blue-light);background:var(--bg-input-focus)}
select option{background:var(--haon-blue-deep);color:var(--text-primary)}
textarea{resize:vertical;min-height:80px}
.botones{display:flex;gap:10px;margin-top:20px}
.btn{flex:1;border:none;border-radius:11px;padding:13px;font-size:.92rem;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s}
.btn-cancel{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--bg-glass-border)}
.btn-ok{background:linear-gradient(135deg,#5BA3E8 0%,#3a87d4 100%);color:#fff}
.btn-ok:hover{box-shadow:var(--shadow-sm)}
.btn:active{transform:scale(.97)}
.cargando{text-align:center;padding:40px;color:var(--text-muted)}

/* ---------- Botón info en turnos ---------- */
.btn-info{
  width:24px;height:24px;border-radius:50%;flex-shrink:0;
  border:1px solid var(--bg-glass-border);
  background:var(--bg-glass);color:var(--haon-blue-light);
  font-weight:700;font-family:Georgia,serif;font-style:italic;
  font-size:.9rem;cursor:pointer;line-height:1;transition:.15s;
}
.btn-info:hover{background:var(--haon-blue-light);color:var(--haon-blue-deep);box-shadow:var(--shadow-sm)}

/* ---------- Lista de responsabilidades en popup ---------- */
.info-lista{list-style:none;margin:6px 0 4px;padding:0}
.info-lista li{
  font-size:.88rem;color:var(--text-secondary);
  padding:9px 12px;margin-bottom:6px;border-radius:10px;
  background:var(--bg-glass);border:1px solid var(--bg-glass-border);
  line-height:1.45;
}
.info-lista li b{color:var(--text-primary)}
.info-lista li.info-dura{
  background:rgba(255,107,107,0.1);
  border-color:rgba(255,107,107,0.3);
}
.info-lista li.info-dura b{color:#ffd0d0}

/* ============================================================
   PANEL DE ADMIN — KPIs colapsables, transparente y sobrio
   ============================================================ */
.kpi{
  background:transparent;
  border:1px solid var(--bg-glass-border);
  border-radius:12px;
  margin-bottom:9px;
  overflow:hidden;
  cursor:pointer;
  transition:.15s;
}
.kpi:hover{border-color:rgba(255,255,255,.22)}
.kpi-cab{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:14px 15px;
}
.kpi-tit{font-size:.92rem;font-weight:700;color:var(--text-primary)}
.kpi-resumen{
  font-size:.76rem;color:var(--text-muted);
  display:flex;align-items:center;gap:7px;white-space:nowrap;text-align:right;
}
.kpi-flecha{color:var(--haon-accent);transition:transform .2s;display:inline-block;font-size:.85rem}
.kpi.abierto .kpi-flecha{transform:rotate(90deg)}
.kpi-cuerpo{
  max-height:0;overflow:hidden;opacity:0;transition:.25s;
  padding:0 15px;
}
.kpi.abierto .kpi-cuerpo{
  max-height:2000px;opacity:1;
  padding:0 15px 14px;
}

.panel-vacio{font-size:.84rem;color:var(--text-muted);text-align:center;padding:14px}

/* Mini KPIs dentro del resumen */
.mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.mini{text-align:center;padding:9px 3px;border:1px solid var(--bg-glass-border);border-radius:9px}
.mini-num{display:block;font-size:1.3rem;font-weight:800;color:var(--text-primary);line-height:1}
.mini-lbl{display:block;font-size:.62rem;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:.3px}
.mini-sub{font-size:.76rem;color:var(--text-muted);text-align:center;margin-top:9px}

/* Ranking */
.rank-fila{display:flex;gap:11px;align-items:center;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.rank-fila:last-child{border-bottom:none}
.rank-pos{font-size:1.25rem;width:28px;text-align:center;flex-shrink:0}
.rank-n{display:inline-block;width:22px;height:22px;line-height:22px;border-radius:50%;border:1px solid var(--bg-glass-border);color:var(--text-muted);font-size:.78rem;font-weight:700}
.rank-cuerpo{flex:1;min-width:0}
.rank-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}
.rank-nombre{font-weight:700;font-size:.92rem;color:var(--text-primary)}
.rank-tot{font-weight:800;font-size:.98rem;color:var(--haon-accent)}
.rank-barra{height:6px;background:rgba(255,255,255,.08);border-radius:4px;overflow:hidden}
.rank-rel{height:100%;background:linear-gradient(90deg,var(--haon-blue-light),var(--haon-accent));border-radius:4px}
.rank-det{font-size:.73rem;color:var(--text-muted);margin-top:5px}

/* Chat de reportes (anidado dentro del KPI) */
.chat-lista{display:flex;flex-direction:column;gap:7px}
.chat-item{border:1px solid var(--bg-glass-border);border-radius:10px;padding:11px 13px;cursor:pointer;transition:.15s}
.chat-item:hover{background:rgba(255,255,255,.04)}
.chat-cab{display:flex;justify-content:space-between;align-items:center;gap:10px}
.chat-quien{font-weight:700;font-size:.86rem;color:var(--haon-blue-light)}
.chat-hora{font-size:.71rem;color:var(--text-muted);display:flex;align-items:center;gap:6px;white-space:nowrap}
.chat-flecha{transition:transform .2s;display:inline-block;color:var(--haon-accent)}
.chat-item.abierto .chat-flecha{transform:rotate(90deg)}
.chat-cuerpo{font-size:.87rem;color:var(--text-secondary);line-height:1.5;white-space:pre-wrap;max-height:0;overflow:hidden;opacity:0;transition:.2s}
.chat-item.abierto .chat-cuerpo{max-height:600px;opacity:1;margin-top:9px;padding-top:9px;border-top:1px solid rgba(255,255,255,.1)}

/* Apoyos por persona (anidado) */
.ap-pers{border:1px solid var(--bg-glass-border);border-radius:10px;padding:11px 13px;cursor:pointer;margin-bottom:7px;transition:.15s}
.ap-pers:hover{background:rgba(255,255,255,.04)}
.ap-pers:last-child{margin-bottom:0}
.ap-pers-cab{display:flex;justify-content:space-between;align-items:center;gap:10px}
.ap-pers-nombre{font-weight:700;font-size:.88rem;color:var(--text-primary)}
.ap-pers-veces{font-size:.77rem;color:var(--haon-accent);font-weight:700;display:flex;align-items:center;gap:6px;white-space:nowrap}
.ap-pers.abierto .chat-flecha{transform:rotate(90deg)}
.ap-pers-det{max-height:0;overflow:hidden;opacity:0;transition:.2s}
.ap-pers.abierto .ap-pers-det{max-height:600px;opacity:1;margin-top:9px;padding-top:9px;border-top:1px solid rgba(255,255,255,.1)}
.ap-det-item{display:flex;justify-content:space-between;gap:10px;padding:5px 0;font-size:.82rem}
.ap-det-tit{color:var(--text-secondary)}
.ap-det-fecha{color:var(--text-faint);white-space:nowrap;font-size:.75rem}