/* Mantenimiento AAP — estilos propios, mobile-first */
:root {
  --azul: #1f4e78; --azul-claro: #eaf1f8; --fondo: #f4f6f8; --carta: #ffffff;
  --texto: #1c2733; --gris: #6b7a89; --borde: #dde4ea;
  --verde: #1e9e57; --verde-bg: #e2f5ea;
  --amarillo: #c98a00; --amarillo-bg: #fdf3d7;
  --rojo: #cc3344; --rojo-bg: #fbe4e7;
  --mp: #2f6fad; --mp-bg: #ddebf7;
  --radius: 10px;
}
* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
       background: var(--fondo); color: var(--texto); font-size: 15px; }
a { color: var(--azul); text-decoration: none; }
h1 { font-size: 1.25rem; margin: .3rem 0 .6rem; }
h2 { font-size: 1.05rem; margin: 1rem 0 .5rem; }

/* Barra superior + navegación */
header.top { background: var(--azul); color: #fff; padding: .55rem .9rem;
             display: flex; align-items: center; gap: .7rem; flex-wrap: wrap; }
header.top .brand { font-weight: 700; letter-spacing: .3px; }
header.top .who { margin-left: auto; font-size: .8rem; opacity: .9; display: flex; align-items: center; gap: .5rem; }
header.top button { background: transparent; border: 1px solid rgba(255,255,255,.5);
                    color: #fff; border-radius: 6px; padding: .15rem .55rem; cursor: pointer; }
nav.menu { background: #fff; border-bottom: 1px solid var(--borde); display: flex;
           overflow-x: auto; white-space: nowrap; padding: 0 .4rem; }
nav.menu a { padding: .6rem .7rem; font-size: .88rem; color: var(--gris); border-bottom: 2px solid transparent; }
nav.menu a.activo { color: var(--azul); border-bottom-color: var(--azul); font-weight: 600; }
main { padding: .9rem; max-width: 1200px; margin: 0 auto; }

/* Tarjetas y tablas */
.card { background: var(--carta); border: 1px solid var(--borde); border-radius: var(--radius);
        padding: .8rem .9rem; margin-bottom: .7rem; }
.tabla-wrap { overflow-x: auto; background: var(--carta); border: 1px solid var(--borde);
              border-radius: var(--radius); }
table { border-collapse: collapse; width: 100%; font-size: .85rem; }
th { background: var(--azul-claro); color: var(--azul); text-align: left; padding: .45rem .55rem;
     position: sticky; top: 0; }
td { padding: .4rem .55rem; border-top: 1px solid var(--borde); vertical-align: top; }

/* Insignias de estado */
.badge { display: inline-block; border-radius: 6px; padding: .1rem .45rem; font-size: .75rem; font-weight: 700; }
.badge.C { background: var(--verde-bg); color: var(--verde); }
.badge.R { background: var(--amarillo-bg); color: var(--amarillo); }
.badge.A { background: var(--rojo-bg); color: var(--rojo); }
.badge.MP, .badge.P { background: var(--mp-bg); color: var(--mp); }
.badge.vencida { background: var(--rojo); color: #fff; }

/* Semáforo de productividad */
.sem { display: inline-block; width: .7rem; height: .7rem; border-radius: 50%; margin-right: .3rem; }
.sem.verde { background: var(--verde); } .sem.amarillo { background: var(--amarillo); }
.sem.rojo { background: var(--rojo); } .sem.gris { background: var(--gris); }

/* Tarjeta de tarea (Mi día) */
.tarea { border-left: 4px solid var(--mp); }
.tarea.C { border-left-color: var(--verde); } .tarea.R { border-left-color: var(--amarillo); }
.tarea.A { border-left-color: var(--rojo); } .tarea.vencida { border-left-color: var(--rojo); }
.tarea .equipo { font-weight: 700; }
.tarea .desc { margin: .15rem 0 .3rem; }
.tarea .meta { color: var(--gris); font-size: .8rem; }
.tarea .acciones { display: flex; gap: .5rem; margin-top: .5rem; flex-wrap: wrap; }
.tarea details { margin-top: .4rem; }
.tarea details summary { cursor: pointer; list-style: none; }
.tarea form { display: flex; flex-direction: column; gap: .45rem; margin-top: .45rem; }

/* Botones */
.btn { border: none; border-radius: 8px; padding: .5rem .9rem; font-weight: 700;
       cursor: pointer; font-size: .88rem; }
.btn.ok { background: var(--verde); color: #fff; }
.btn.warn { background: var(--amarillo); color: #fff; }
.btn.peligro { background: var(--rojo); color: #fff; }
.btn.plano { background: var(--azul-claro); color: var(--azul); }
.btn.primario { background: var(--azul); color: #fff; }
.btn:disabled { opacity: .55; cursor: default; }
input, select, textarea { border: 1px solid var(--borde); border-radius: 8px;
                          padding: .5rem .6rem; font-size: .95rem; font-family: inherit; width: 100%; }
label { font-size: .8rem; color: var(--gris); font-weight: 600; display: block; margin-bottom: .2rem; }
.form-grid { display: grid; gap: .7rem; grid-template-columns: 1fr; max-width: 560px; }
.fila { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.fila.entre { justify-content: space-between; }

/* KPIs del tablero */
.kpis { display: grid; grid-template-columns: repeat(2, 1fr); gap: .6rem; }
.kpi { background: var(--carta); border: 1px solid var(--borde); border-radius: var(--radius);
       padding: .7rem .8rem; }
.kpi .valor { font-size: 1.55rem; font-weight: 800; }
.kpi .titulo { color: var(--gris); font-size: .78rem; text-transform: uppercase; letter-spacing: .4px; }
.kpi.verde .valor { color: var(--verde); } .kpi.amarillo .valor { color: var(--amarillo); }
.kpi.rojo .valor { color: var(--rojo); } .kpi.azul .valor { color: var(--mp); }

/* Gráfico semanal de barras (CSS) */
.barras { display: flex; align-items: flex-end; gap: 6px; height: 130px; padding: .4rem 0; }
.barras .col { flex: 1; display: flex; flex-direction: column; justify-content: flex-end;
               align-items: center; gap: 4px; min-width: 26px; }
.barras .barra { width: 100%; border-radius: 4px 4px 0 0; background: var(--mp); }
.barras .barra.verde { background: var(--verde); } .barras .barra.amarillo { background: var(--amarillo); }
.barras .barra.rojo { background: var(--rojo); } .barras .barra.gris { background: var(--borde); }
.barras .etq { font-size: .62rem; color: var(--gris); white-space: nowrap; }
.linea-objetivo { border-top: 2px dashed var(--rojo); position: relative; top: 0; }

/* Cronograma (cuadrícula) */
.grid-crono td, .grid-crono th { padding: .25rem .3rem; font-size: .78rem; }
.grid-crono td.celda { text-align: center; min-width: 30px; cursor: pointer; }
.grid-crono td.celda span { display: inline-block; min-width: 24px; border-radius: 5px;
                            font-weight: 700; font-size: .72rem; padding: .1rem .2rem; }
.grid-crono td.hoy { outline: 2px solid var(--azul); outline-offset: -2px; }
.grid-crono .fija { position: sticky; left: 0; background: var(--carta); z-index: 1;
                    max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Modal simple para detalle de tarea */
#modal { position: fixed; inset: 0; background: rgba(20,30,40,.5); display: none;
         align-items: flex-end; justify-content: center; z-index: 50; padding: 1rem; }
#modal.abierto { display: flex; }
#modal .contenido { background: var(--fondo); border-radius: 14px; width: 100%;
                    max-width: 480px; max-height: 85vh; overflow-y: auto; padding: 1rem; }

/* Login */
.login-caja { max-width: 380px; margin: 8vh auto; }
.login-caja .logo { text-align: center; font-size: 1.4rem; font-weight: 800; color: var(--azul);
                    margin-bottom: 1rem; }
.error { background: var(--rojo-bg); color: var(--rojo); border-radius: 8px;
         padding: .5rem .7rem; margin-bottom: .7rem; font-size: .88rem; }
.vacio { color: var(--gris); text-align: center; padding: 1.2rem; }

@media (min-width: 720px) {
  .kpis { grid-template-columns: repeat(4, 1fr); }
  .form-grid { grid-template-columns: 1fr 1fr; }
  .form-grid .ancho { grid-column: 1 / -1; }
  #modal { align-items: center; }
}
