@import url('https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=DM+Mono:wght@400;500&family=Outfit:wght@400;500;600;700&display=swap');

:root{
  --yellow:#FFCC00; --yellow-d:#e6b800;
  --black:#0f0f0f;  --white:#fff;
  --red:#ef4444;    --orange:#f97316;
  --blue:#3b82f6;   --purple:#8b5cf6;
  --pink:#ec4899;   --green:#16a34a;
  --g50:#f9fafb;    --g100:#f3f4f6;
  --g200:#e5e7eb;   --g400:#9ca3af;
  --g600:#4b5563;   --g700:#374151;
  --g900:#111827;
  --r:10px; --sh:0 2px 10px rgba(0,0,0,.07);
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{max-width:100%;overflow-x:hidden;}
body{font-family:'Outfit',sans-serif;background:var(--g100);color:var(--g900);}

/* HEADER */
header{
  background:var(--black);color:var(--white);
  padding:10px 20px;display:flex;justify-content:space-between;
  align-items:center;border-bottom:4px solid var(--yellow);
  position:sticky;top:0;z-index:200;gap:12px;
}
.header-left{display:flex;align-items:center;gap:10px;min-width:0;}
.logo{font-size:20px;background:var(--yellow);width:38px;height:38px;
  border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
header h1{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.subtitle{font-size:10px;color:var(--g400);display:block;}
.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.clock-val{font-family:'DM Mono',monospace;font-size:11px;color:var(--g400);white-space:nowrap;}
#btnActualizar{background:var(--yellow);color:var(--black);border:none;
  padding:7px 14px;border-radius:6px;font-weight:700;font-size:13px;
  cursor:pointer;white-space:nowrap;transition:background .2s;}
#btnActualizar:hover{background:var(--yellow-d);}
#btnActualizar:disabled{opacity:.5;cursor:not-allowed;}

/* BÚSQUEDA RÁPIDA EN HEADER */
.header-search{
  display:flex;align-items:center;
  background:#1f2937;border-radius:6px;
  padding:0 10px;gap:6px;flex:1;max-width:280px;
}
.header-search input{
  background:none;border:none;outline:none;
  color:var(--white);font-size:13px;
  font-family:'Outfit',sans-serif;
  padding:7px 0;width:100%;
}
.header-search input::placeholder{color:var(--g400);}
.header-search span{color:var(--g400);font-size:14px;}

/* ERROR */
.error-banner{background:#fee2e2;color:#991b1b;padding:10px 20px;
  font-size:13px;border-left:4px solid var(--red);}

/* KPIs */
.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;padding:16px 20px 0;}
.kpi-card{background:var(--white);border-radius:var(--r);padding:14px 12px;
  display:flex;align-items:center;gap:10px;box-shadow:var(--sh);
  border-left:4px solid transparent;}
.kpi-yellow{border-left-color:var(--yellow);}
.kpi-red{border-left-color:var(--red);}
.kpi-orange{border-left-color:var(--orange);}
.kpi-blue{border-left-color:var(--blue);}
.kpi-purple{border-left-color:var(--purple);}
.kpi-pink{border-left-color:var(--pink);}
.kpi-icon{font-size:20px;flex-shrink:0;}
.kpi-label{font-size:10px;color:var(--g600);font-weight:600;
  text-transform:uppercase;letter-spacing:.3px;line-height:1.2;}
.kpi-value{font-size:26px;font-weight:700;font-family:'DM Mono',monospace;
  color:var(--black);line-height:1.1;}

/* LAYOUT 2 COLUMNAS */
.main-layout{display:grid;grid-template-columns:1fr 340px;gap:14px;padding:14px 20px 0;}
.col-left{display:flex;flex-direction:column;gap:14px;min-width:0;}
.col-right{display:flex;flex-direction:column;gap:14px;min-width:0;}

/* CARD */
.card{background:var(--white);border-radius:var(--r);padding:16px;box-shadow:var(--sh);}
.card-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;
  margin-bottom:12px;color:var(--g900);}

/* GRÁFICOS */
.dona-wrap{position:relative;width:100%;height:200px;}
.chart-wrap{position:relative;width:100%;height:220px;}
.dona-wrap canvas,.chart-wrap canvas{
  position:absolute;top:0;left:0;width:100%!important;height:100%!important;}

/* CHART TABS */
.chart-tabs{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap;}
.ctab{background:var(--g100);color:var(--g600);border:none;padding:4px 10px;
  border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;
  font-family:'Outfit',sans-serif;transition:all .15s;}
.ctab.active{background:var(--black);color:var(--yellow);}

/* FILTROS */
.filtros-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.btn-link{background:none;border:none;color:var(--g600);font-size:12px;cursor:pointer;font-family:'Outfit',sans-serif;}
.btn-link:hover{color:var(--red);}
.filtros-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.filtro-group{display:flex;flex-direction:column;gap:4px;}
.filtro-group.full-width{grid-column:1/-1;}
.filtro-group label{font-size:10px;font-weight:700;color:var(--g600);
  text-transform:uppercase;letter-spacing:.4px;}
.filtro-group input,.filtro-group select{
  padding:6px 8px;border:1.5px solid var(--g200);border-radius:6px;
  font-size:12px;color:var(--g900);background:var(--white);
  font-family:'Outfit',sans-serif;outline:none;width:100%;transition:border-color .2s;}
.filtro-group input:focus,.filtro-group select:focus{border-color:var(--yellow);}
.btn-primary{background:var(--yellow);color:var(--black);border:none;
  padding:8px 16px;border-radius:6px;font-weight:700;font-size:13px;
  cursor:pointer;font-family:'Outfit',sans-serif;transition:background .2s;}
.btn-primary:hover{background:var(--yellow-d);}
.btn-block{width:100%;}

/* RESUMEN */
.resumen-card{overflow:hidden;}
.resumen-tabs{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap;}
.rtab{background:var(--g100);color:var(--g600);border:none;padding:3px 9px;
  border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;
  font-family:'Outfit',sans-serif;transition:all .15s;}
.rtab.active{background:var(--yellow);color:var(--black);}
.resumen-pane{display:none;}
.resumen-pane.active-pane{display:block;}
.resumen-label{font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.5px;color:var(--g400);display:block;margin-bottom:5px;}
.resumen-table{width:100%;border-collapse:collapse;font-size:11px;margin-bottom:4px;}
.resumen-table thead tr{background:var(--black);}
.resumen-table thead th{color:var(--yellow);padding:5px 7px;text-align:left;font-size:10px;font-weight:700;}
.resumen-table tbody tr{border-bottom:1px solid var(--g100);}
.resumen-table tbody tr:hover{background:#fffbeb;}
.resumen-table td{padding:4px 7px;color:var(--g700);}
.resumen-table tr.resumen-total td{font-weight:700;background:var(--g50);border-top:2px solid var(--g200);}
.mini-bar-wrap{display:flex;align-items:center;gap:5px;}
.mini-bar{height:5px;background:var(--yellow);border-radius:3px;min-width:2px;max-width:60px;}
.mini-bar-wrap span{font-size:10px;color:var(--g600);}
.res-emp-row td{background:var(--g50);padding:5px 7px;border-top:2px solid var(--g200);}
.res-sup-row td{padding:3px 7px;color:var(--g600);font-size:11px;}
.res-sup-row:hover td{background:#fffbeb;}
.ranking-nota{font-size:10px;color:var(--g400);font-style:italic;margin:-8px 0 10px;}

/* DETALLE PESTAÑAS */
.detalle-section{margin:14px 20px 28px;}
.detalle-tabs-bar{display:flex;gap:0;flex-wrap:nowrap;overflow-x:auto;
  border-bottom:2px solid var(--g100);margin-bottom:14px;
  -webkit-overflow-scrolling:touch;}
.dtab{background:none;border:none;padding:9px 14px;font-size:12px;font-weight:600;
  color:var(--g600);cursor:pointer;font-family:'Outfit',sans-serif;
  border-bottom:3px solid transparent;margin-bottom:-2px;white-space:nowrap;
  display:flex;align-items:center;gap:5px;transition:all .15s;flex-shrink:0;}
.dtab:hover{color:var(--g900);}
.dtab.active{color:var(--black);border-bottom-color:var(--yellow);}
.dtab-count{background:var(--yellow);color:var(--black);font-size:10px;
  font-weight:700;padding:1px 6px;border-radius:20px;}
.detalle-pane{display:none;}
.detalle-pane.active-pane{display:block;}
.pane-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.pane-info{font-size:11px;color:var(--g400);}
.btn-export{background:transparent;color:var(--g600);border:1px solid var(--g200);
  padding:4px 10px;border-radius:5px;font-size:11px;cursor:pointer;
  font-family:'Outfit',sans-serif;transition:all .2s;}
.btn-export:hover{background:var(--black);color:var(--yellow);border-color:var(--black);}

/* AGRUPACIÓN */
.agrupacion-controls{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;}

/* TABLAS */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;}
table{width:100%;border-collapse:collapse;font-size:12px;}
thead tr{background:var(--black);}
thead th{padding:8px 10px;text-align:left;color:var(--yellow);
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.4px;white-space:nowrap;}
th.sortable{cursor:pointer;user-select:none;}
th.sortable:hover{background:#1f2937;}
tbody tr{border-bottom:1px solid var(--g100);transition:background .1s;}
tbody tr:hover{background:#fffbeb;}
tbody td{padding:7px 10px;color:var(--g700);white-space:nowrap;
  max-width:200px;overflow:hidden;text-overflow:ellipsis;}
td.empty{text-align:center;color:var(--g400);padding:20px;font-style:italic;white-space:normal;}

/* BADGES */
.badge{display:inline-block;padding:2px 8px;border-radius:20px;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;}
.badge-red{background:#fee2e2;color:#991b1b;}
.badge-yellow{background:#fef9c3;color:#854d0e;}
.badge-orange{background:#ffedd5;color:#9a3412;}
.text-red{color:var(--red);font-weight:700;}
.text-orange{color:var(--orange);font-weight:700;}
.text-green{color:var(--green);font-weight:700;}

/* PAGINACIÓN */
.paginacion{display:flex;align-items:center;gap:4px;margin-top:10px;flex-wrap:wrap;}
.paginacion button{background:var(--g100);border:1px solid var(--g200);
  padding:4px 8px;border-radius:5px;font-size:11px;cursor:pointer;
  font-family:'Outfit',sans-serif;transition:all .15s;}
.paginacion button:hover{background:var(--black);color:var(--yellow);}
.paginacion button.pag-active{background:var(--yellow);color:var(--black);
  font-weight:700;border-color:var(--yellow);}
.pag-info{font-size:11px;color:var(--g400);margin-right:6px;}

/* NAV MÓDULOS */
.mod-nav{display:flex;background:var(--black);border-bottom:1px solid #1f2937;
  overflow-x:auto;-webkit-overflow-scrolling:touch;}
.mod-tab{padding:10px 20px;color:var(--g400);font-size:13px;font-weight:600;
  white-space:nowrap;text-decoration:none;border-bottom:3px solid transparent;
  font-family:'Outfit',sans-serif;transition:all .15s;}
.mod-tab:hover{color:var(--white);}
.mod-tab.active{color:var(--yellow);border-bottom-color:var(--yellow);}

/* NAV INFERIOR PWA */
.nav-bottom{display:none;}

/* CARDS MÓVIL */
.mobile-cards{display:none;}
.desktop-table{display:block;}

/* RESPONSIVE TABLET */
@media(max-width:1100px){
  .main-layout{grid-template-columns:1fr;}
  .col-right{flex-direction:row;flex-wrap:wrap;}
  .col-right .card{flex:1;min-width:260px;}
  .kpi-grid{grid-template-columns:repeat(3,1fr);}
}

/* RESPONSIVE MÓVIL */
@media(max-width:640px){
  /* Header */
  header{padding:8px 10px;gap:6px;}
  header h1{font-size:13px;}
  .subtitle{display:none;}
  .clock-val{display:none;}
  .header-search{max-width:none;flex:1;}
  #btnActualizar{display:none;}

  /* Nav módulos compacto */
  .mod-tab{padding:8px 14px;font-size:12px;}

  /* KPIs 2 columnas */
  .kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:10px 12px 0;}
  .kpi-card{padding:10px 8px;gap:8px;}
  .kpi-icon{font-size:18px;}
  .kpi-value{font-size:20px;}
  .kpi-label{font-size:9px;}

  /* Layout 1 columna */
  .main-layout{padding:10px 12px 0;gap:10px;grid-template-columns:1fr;}
  .col-right{flex-direction:column;}

  /* Gráficos compactos */
  .dona-wrap{height:160px;}
  .chart-wrap{height:180px;}

  /* Filtros 1 columna */
  .filtros-grid{grid-template-columns:1fr;}

  /* Pestañas scroll */
  .detalle-tabs-bar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .dtab{font-size:11px;padding:8px 10px;flex-shrink:0;}
  .dtab-count{font-size:9px;padding:1px 5px;}

  /* Detalle */
  .detalle-section{margin:10px 12px 70px;}

  /* Tablas */
  table{font-size:11px;}
  thead th{padding:6px 8px;font-size:9px;}
  tbody td{padding:5px 8px;}

  /* Resumen */
  .resumen-tabs{flex-wrap:wrap;}
  .rtab{font-size:10px;padding:3px 7px;}

  /* Paginación táctil */
  .paginacion button{padding:7px 10px;font-size:11px;min-height:34px;}
  .pag-info{font-size:10px;width:100%;margin-bottom:3px;}

  /* Agrupación */
  .agrupacion-controls{flex-direction:column;}
  .agrupacion-controls>*{width:100%;}

  /* Mostrar cards, ocultar tabla */
  .mobile-cards{display:block;}
  .desktop-table{display:none;}

  /* NAV INFERIOR */
  .nav-bottom{
    display:flex;position:fixed;bottom:0;left:0;right:0;
    background:var(--black);border-top:3px solid var(--yellow);
    z-index:500;height:56px;
    padding-bottom:env(safe-area-inset-bottom,0);
  }
  .nav-bottom button{
    flex:1;background:none;border:none;color:var(--g400);cursor:pointer;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
    font-family:'Outfit',sans-serif;-webkit-tap-highlight-color:transparent;transition:color .15s;
  }
  .nav-bottom button.active,.nav-bottom button:active{color:var(--yellow);}
  .nav-icon{font-size:18px;line-height:1;}
  .nav-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;}

  body{padding-bottom:56px;}
}

/* CARDS DE OPERADOR (móvil) */
.op-card{
  background:var(--white);border-radius:8px;margin-bottom:8px;
  box-shadow:var(--sh);overflow:hidden;
  border-left:4px solid var(--g200);
}
.op-card.vencida{border-left-color:var(--red);}
.op-card.por-vencer{border-left-color:var(--yellow);}
.op-card.sin-unidad{border-left-color:var(--orange);}
.op-card.no-coincide{border-left-color:var(--pink);}

.op-card-main{
  padding:12px;display:grid;
  grid-template-columns:1fr auto;gap:4px;
  cursor:pointer;-webkit-tap-highlight-color:transparent;
}
.op-card-name{font-weight:700;font-size:14px;color:var(--g900);line-height:1.2;}
.op-card-sub{font-size:11px;color:var(--g600);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap;}
.op-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;}
.op-card-dias{font-family:'DM Mono',monospace;font-size:13px;font-weight:700;}
.op-card-dias.neg{color:var(--red);}
.op-card-dias.warn{color:var(--orange);}
.op-card-dias.ok{color:var(--green);}
.op-card-expand-icon{font-size:10px;color:var(--g400);transition:transform .2s;}
.op-card.expanded .op-card-expand-icon{transform:rotate(180deg);}

.op-card-detail{
  display:none;padding:8px 12px 12px;
  border-top:1px solid var(--g100);background:var(--g50);
}
.op-card.expanded .op-card-detail{display:block;}
.op-card-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;}
.op-card-field label{font-size:9px;font-weight:700;color:var(--g400);
  text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:1px;}
.op-card-field span{font-size:12px;color:var(--g700);font-weight:500;}

/* Safe area iPhone */
@supports(padding:max(0px)){
  .nav-bottom{padding-bottom:max(0px,env(safe-area-inset-bottom));}
  header{padding-top:max(8px,env(safe-area-inset-top));}
}