/* ============================================================
   Sistema TEPE - Estilos compartidos
   Paleta: verde campo, dorado arroz, crema. Pensado para
   adultos mayores: alto contraste, botones grandes, texto grande.
   ============================================================ */

:root {
  --verde:        #2D6A2D;
  --verde-claro:  #4A9E4A;
  --dorado:       #C8941A;
  --dorado-claro: #F0B429;
  --crema:        #F5F0E8;
  --gris-borde:   #D4C9B0;
  --texto:        #1A1A1A;
  --texto-medio:  #6A6A6A;
  --rojo:         #C0392B;
  --radio:        14px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Segoe UI', Arial, sans-serif;
  background: var(--crema);
  color: var(--texto);
  min-height: 100vh;
}

/* ---------- LOGIN ---------- */
.login-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}
.login-header {
  background: var(--verde);
  width: 100%;
  padding: 46px 20px 60px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  border-radius: 0 0 40px 40px;
}
.logo-box {
  background: rgba(255,255,255,0.10);
  border: 2px solid rgba(240,180,41,0.45);
  border-radius: 16px;
  padding: 12px 26px 9px;
  text-align: center;
}
.logo-box .l { font-size: 44px; font-weight: 900; color: var(--dorado-claro); letter-spacing: 9px; line-height: 1; }
.logo-box .s { font-size: 9px; letter-spacing: 2px; color: rgba(255,255,255,0.7); font-weight: 600; text-transform: uppercase; margin-top: 3px; }
.login-welcome { color: rgba(255,255,255,0.9); font-size: 14px; margin-top: 10px; }

.login-card {
  background: #fff;
  width: 100%;
  max-width: 420px;
  margin: -34px 18px 0;
  border-radius: 20px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.12);
  padding: 26px 22px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.form-title { font-size: 18px; font-weight: 700; color: var(--texto); text-align: center; }

.campo { display: flex; flex-direction: column; gap: 6px; }
.campo label { font-size: 14px; font-weight: 700; color: var(--verde); padding-left: 3px; }
.input-row {
  display: flex; align-items: center; gap: 10px;
  background: #fff; border: 2.5px solid var(--gris-borde);
  border-radius: 12px; padding: 0 14px;
  transition: border .15s;
}
.input-row:focus-within { border-color: var(--verde); box-shadow: 0 0 0 3px rgba(45,106,45,0.12); }
.input-row .icono { font-size: 18px; }
.input-row input {
  flex: 1; border: none; outline: none; background: transparent;
  font-size: 16px; padding: 14px 0; color: var(--texto); font-family: inherit;
}
.ver-clave { background: none; border: none; font-size: 18px; cursor: pointer; color: var(--texto-medio); }

.btn-principal {
  background: var(--verde); color: #fff; border: none;
  border-radius: var(--radio); padding: 16px;
  font-size: 17px; font-weight: 800; cursor: pointer;
  box-shadow: 0 4px 16px rgba(45,106,45,0.3);
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.btn-principal:active { transform: scale(0.99); }
.btn-principal:disabled { opacity: .6; cursor: default; }

.mensaje-error {
  background: #FFEBEE; color: var(--rojo);
  border-radius: 10px; padding: 12px 14px;
  font-size: 14px; font-weight: 600; text-align: center;
  display: none;
}
.mensaje-error.visible { display: block; }

.login-footer { text-align: center; font-size: 11px; color: var(--texto-medio); margin-top: 6px; }

/* ---------- MENU ---------- */
.app-header {
  background: var(--verde);
  padding: 18px 18px 20px;
  border-radius: 0 0 22px 22px;
  display: flex; justify-content: space-between; align-items: center;
}
.saludo .h1 { color: #fff; font-size: 18px; font-weight: 800; }
.saludo .h2 { color: rgba(255,255,255,0.75); font-size: 12px; margin-top: 2px; }
.btn-salir {
  background: rgba(255,255,255,0.15); color: #fff; border: none;
  border-radius: 11px; padding: 10px 16px; font-size: 13px; font-weight: 700; cursor: pointer;
  display: flex; align-items: center; gap: 6px;
}

.contenido { max-width: 900px; margin: 0 auto; padding: 18px 16px 40px; }
.seccion-titulo { font-size: 14px; font-weight: 700; color: var(--texto-medio); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px; }

.modulos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 14px;
}
.modulo {
  background: #fff; border-radius: 18px; padding: 20px 14px;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  box-shadow: 0 3px 10px rgba(0,0,0,0.08); text-decoration: none; color: inherit;
  border: 2px solid transparent; transition: transform .12s, border-color .12s;
}
.modulo:hover { transform: translateY(-3px); border-color: var(--verde-claro); }
.modulo .ico { width: 56px; height: 56px; border-radius: 16px; display: flex; align-items: center; justify-content: center; font-size: 28px; }
.bg-verde{background:#E3F2E3} .bg-dorado{background:#FFF3D6} .bg-azul{background:#E3F0FB} .bg-tierra{background:#F3E9DF} .bg-morado{background:#EFE7F7} .bg-rojo{background:#FBE6E3}
.modulo .nombre { font-size: 15px; font-weight: 800; color: var(--texto); }
.modulo .desc { font-size: 11px; color: var(--texto-medio); text-align: center; }

.cargando { text-align: center; color: var(--texto-medio); padding: 40px; font-size: 15px; }

/* ---------- BARRA DE NAVEGACION (modulos) ---------- */
.barra-nav {
  background: var(--verde); padding: 16px 16px; display: flex; align-items: center; gap: 12px;
}
.barra-nav .volver {
  width: 38px; height: 38px; background: rgba(255,255,255,0.15); border-radius: 11px;
  display: flex; align-items: center; justify-content: center; color: #fff; font-size: 22px;
  text-decoration: none; border: none; cursor: pointer;
}
.barra-nav .titulo { color: #fff; }
.barra-nav .titulo .t1 { font-size: 17px; font-weight: 800; line-height: 1.1; }
.barra-nav .titulo .t2 { font-size: 12px; color: rgba(255,255,255,0.75); }

/* ---------- LISTAS ---------- */
.lista { max-width: 760px; margin: 0 auto; padding: 16px 16px 90px; display: flex; flex-direction: column; gap: 12px; }
.buscador {
  background: #fff; border: 2px solid var(--gris-borde); border-radius: 12px;
  display: flex; align-items: center; gap: 8px; padding: 0 14px; margin-bottom: 4px;
}
.buscador input { flex: 1; border: none; outline: none; padding: 13px 0; font-size: 15px; background: transparent; font-family: inherit; }

.tarjeta {
  background: #fff; border-radius: 16px; padding: 14px; box-shadow: 0 2px 8px rgba(0,0,0,0.07);
  display: flex; align-items: center; gap: 12px; border-left: 5px solid var(--verde);
}
.tarjeta.pendiente { border-left-color: var(--dorado); }
.tarjeta.parcial   { border-left-color: #1565C0; }
.tarjeta .avatar { width: 46px; height: 46px; border-radius: 12px; background: #E3F2E3; display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.tarjeta .info { flex: 1; min-width: 0; }
.tarjeta .nombre { font-size: 16px; font-weight: 800; color: var(--texto); }
.tarjeta .detalle { font-size: 13px; color: var(--texto-medio); margin-top: 2px; }
.tarjeta .lote { display: inline-block; background: var(--crema); color: var(--verde); font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 6px; margin-top: 6px; }
.tarjeta .derecha { text-align: right; flex-shrink: 0; }
.tarjeta .monto { font-size: 16px; font-weight: 800; color: var(--texto); }
.badge { font-size: 11px; font-weight: 800; padding: 4px 11px; border-radius: 12px; margin-top: 6px; display: inline-block; }
.badge.pagado { background: #E3F2E3; color: var(--verde); }
.badge.pendiente { background: #FFF3D6; color: var(--dorado); }
.badge.parcial { background: #E3F0FB; color: #1565C0; }

.vacio { text-align: center; color: var(--texto-medio); padding: 50px 20px; }
.vacio .emoji { font-size: 50px; }
.vacio .txt { font-size: 15px; margin-top: 10px; }

/* Boton flotante agregar */
.fab {
  position: fixed; bottom: 22px; right: 22px; width: 64px; height: 64px;
  background: var(--dorado); border-radius: 20px; display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 34px; box-shadow: 0 6px 20px rgba(200,148,26,0.5); text-decoration: none;
}

/* ---------- FORMULARIOS ---------- */
.form { max-width: 560px; margin: 0 auto; padding: 18px 16px 40px; display: flex; flex-direction: column; gap: 16px; }
.form .campo label { font-size: 14px; font-weight: 700; color: var(--verde); padding-left: 3px; }
.form .obligatorio { color: var(--rojo); }
.form .opcional { background: #9E9E9E; color: #fff; font-size: 9px; font-weight: 700; padding: 1px 7px; border-radius: 5px; }
.form select, .form input[type=text], .form input[type=number], .form input[type=date] {
  width: 100%; background: #fff; border: 2.5px solid var(--gris-borde); border-radius: 12px;
  padding: 13px 14px; font-size: 16px; color: var(--texto); font-family: inherit; outline: none;
}
.form select:focus, .form input:focus { border-color: var(--verde); box-shadow: 0 0 0 3px rgba(45,106,45,0.12); }
.fila { display: flex; gap: 10px; }
.fila .campo { flex: 1; }
.campo { display: flex; flex-direction: column; gap: 6px; }

.segmento { display: flex; gap: 8px; }
.opt {
  flex: 1; border: 2.5px solid var(--gris-borde); background: #fff; border-radius: 12px;
  padding: 12px 6px; text-align: center; cursor: pointer; font-size: 14px; font-weight: 800; color: var(--texto-medio);
}
.opt.activo { border-color: var(--verde); background: #E3F2E3; color: var(--verde); }
.opt.activo.dorado { border-color: var(--dorado); background: #FFF3D6; color: var(--dorado); }

.caja-total { background: var(--verde); border-radius: 16px; padding: 15px 18px; display: flex; justify-content: space-between; align-items: center; }
.caja-total .et { color: rgba(255,255,255,0.85); font-size: 13px; }
.caja-total .val { color: var(--dorado-claro); font-size: 26px; font-weight: 900; }
.nota-calc { background: #FFF3D6; border-radius: 10px; padding: 10px 13px; font-size: 13px; color: #8B6000; line-height: 1.4; }

.btn-agregar-mini { background: #FFF3D6; border: 2px dashed var(--dorado); color: var(--dorado); border-radius: 10px; padding: 11px; text-align: center; font-weight: 800; font-size: 14px; cursor: pointer; }

/* Comprobante / exito */
.exito { max-width: 460px; margin: 0 auto; padding: 30px 20px; display: flex; flex-direction: column; align-items: center; text-align: center; }
.exito .circulo { width: 88px; height: 88px; background: #E3F2E3; border: 4px solid var(--verde-claro); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 46px; color: var(--verde); margin-bottom: 14px; }
.exito h2 { font-size: 22px; color: var(--verde); }
.exito .sub { font-size: 14px; color: var(--texto-medio); margin: 4px 0 18px; }
.recibo { background: #fff; border-radius: 18px; width: 100%; padding: 18px; box-shadow: 0 4px 16px rgba(0,0,0,0.1); }
.recibo .lote-grande { background: var(--dorado); color: #fff; border-radius: 12px; padding: 12px; text-align: center; margin-bottom: 14px; }
.recibo .lote-grande .a { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; opacity: .85; }
.recibo .lote-grande .b { font-size: 24px; font-weight: 900; letter-spacing: 2px; }
.recibo .r-fila { display: flex; justify-content: space-between; padding: 7px 0; border-bottom: 1px dashed var(--gris-borde); font-size: 14px; }
.recibo .r-fila:last-of-type { border-bottom: none; }
.recibo .r-et { color: var(--texto-medio); } .recibo .r-val { font-weight: 700; }
.recibo .r-total { display: flex; justify-content: space-between; border-top: 2px solid var(--verde); margin-top: 6px; padding-top: 10px; }
.recibo .r-total .et { font-size: 15px; font-weight: 800; } .recibo .r-total .val { font-size: 18px; font-weight: 900; color: var(--verde); }
.acciones { display: flex; gap: 10px; width: 100%; margin-top: 16px; }
.btn-sec { flex: 1; background: #fff; border: 2.5px solid var(--verde); color: var(--verde); border-radius: 14px; padding: 14px; font-size: 15px; font-weight: 800; cursor: pointer; text-decoration: none; text-align: center; }

/* ---------- SELECCION DE LOTE (ventas) ---------- */
.lotes-box { display: flex; flex-direction: column; gap: 10px; }
.lote-op {
  background: #fff; border: 2.5px solid var(--gris-borde); border-radius: 14px; padding: 12px 14px; cursor: pointer;
}
.lote-op.sel { border-color: var(--verde); background: #E3F2E3; }
.lote-op .arriba { display: flex; align-items: center; gap: 10px; }
.lote-op .radio { width: 22px; height: 22px; border-radius: 50%; border: 2.5px solid var(--gris-borde); flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 900; }
.lote-op.sel .radio { border-color: var(--verde); background: var(--verde); }
.lote-op .li { flex: 1; }
.lote-op .ln { font-size: 14px; font-weight: 800; color: var(--texto); }
.lote-op .lm { font-size: 12px; color: var(--texto-medio); }
.lote-op .lstock { text-align: right; }
.lote-op .lsv { font-size: 15px; font-weight: 900; color: var(--verde); }
.lote-op .lsl { font-size: 10px; color: var(--texto-medio); }
.lote-op .etiquetas { margin-top: 7px; display: flex; gap: 5px; flex-wrap: wrap; }
.tag-fifo { background: var(--verde); color: #fff; font-size: 10px; font-weight: 800; padding: 2px 8px; border-radius: 6px; }
.tag-dias { background: #FFF3D6; color: #8B6000; font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 6px; }
.aviso-stock { background: #E3F0FB; border-radius: 10px; padding: 10px 13px; font-size: 13px; color: #1565C0; font-weight: 600; }
.aviso-rojo { background: #FFEBEE; color: var(--rojo); }

/* ---------- INVENTARIO ---------- */
.filtros-almacen { display: flex; gap: 8px; overflow-x: auto; padding: 14px 16px 4px; max-width: 760px; margin: 0 auto; }
.chip-alm { background: #fff; border: 2px solid var(--gris-borde); color: var(--texto-medio); font-size: 13px; font-weight: 700; padding: 8px 15px; border-radius: 20px; white-space: nowrap; cursor: pointer; }
.chip-alm.activo { background: var(--verde); border-color: var(--verde); color: #fff; }

.resumen-inv { display: flex; gap: 10px; max-width: 760px; margin: 0 auto; padding: 10px 16px 0; }
.resumen-inv .caja { flex: 1; background: #fff; border-radius: 13px; padding: 12px 14px; box-shadow: 0 2px 7px rgba(0,0,0,0.07); }
.resumen-inv .caja.alerta { border-left: 4px solid var(--rojo); }
.resumen-inv .v { font-size: 20px; font-weight: 900; }
.resumen-inv .v.rojo { color: var(--rojo); }
.resumen-inv .l { font-size: 11px; color: var(--texto-medio); }

.prod-inv { background: #fff; border-radius: 16px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); overflow: hidden; }
.prod-inv.bajo { border-left: 5px solid var(--rojo); }
.prod-inv .cab { display: flex; align-items: center; gap: 12px; padding: 14px; cursor: pointer; }
.prod-inv .ico { width: 46px; height: 46px; border-radius: 12px; background: #E3F2E3; display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.prod-inv .info { flex: 1; }
.prod-inv .nom { font-size: 16px; font-weight: 800; }
.prod-inv .sub { font-size: 12px; color: var(--texto-medio); }
.prod-inv .stock { text-align: right; }
.prod-inv .sv { font-size: 18px; font-weight: 900; color: var(--verde); }
.prod-inv .sv.rojo { color: var(--rojo); }
.tag-bajo { background: #FFEBEE; color: var(--rojo); font-size: 9px; font-weight: 800; padding: 2px 7px; border-radius: 6px; display: inline-block; margin-top: 3px; }
.prod-inv .flecha { color: var(--gris-borde); font-size: 20px; transition: transform .2s; }
.prod-inv.abierto .flecha { transform: rotate(90deg); }
.detalle-lotes { background: var(--crema); padding: 4px 14px 12px; display: none; flex-direction: column; gap: 8px; }
.prod-inv.abierto .detalle-lotes { display: flex; }
.lote-linea { background: #fff; border-radius: 10px; padding: 10px 12px; display: flex; align-items: center; gap: 10px; }
.lote-linea .punto { width: 9px; height: 9px; border-radius: 50%; background: var(--verde); flex-shrink: 0; }
.lote-linea .li { flex: 1; }
.lote-linea .ln { font-size: 13px; font-weight: 800; }
.lote-linea .lm { font-size: 11px; color: var(--texto-medio); }
.lote-linea .lq { font-size: 14px; font-weight: 800; color: var(--verde); }
.lote-linea .la { font-size: 10px; color: #1565C0; font-weight: 700; text-align: right; }
.btn-editar-lote { flex-shrink: 0; width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; background: #F3EEFA; border: 1.5px solid #D9CCEC; border-radius: 10px; text-decoration: none; font-size: 15px; }
.btn-editar-lote:active { background: #E6DBF5; }

.btn-proceso {
  position: fixed; bottom: 22px; right: 22px; background: #1565C0; color: #fff; border: none;
  border-radius: 18px; padding: 16px 20px; font-size: 14px; font-weight: 800; cursor: pointer;
  box-shadow: 0 6px 20px rgba(21,101,192,0.45); text-decoration: none; display: flex; align-items: center; gap: 8px;
}

/* ---------- PILADO ---------- */
.bloque-entra { background: #FFF3D6; border: 2px solid #E8C97A; border-radius: 14px; padding: 14px; }
.bloque-entra .et { font-size: 11px; font-weight: 800; color: #8B6000; text-transform: uppercase; margin-bottom: 8px; }
.salida-row { background: #fff; border-radius: 12px; padding: 12px; box-shadow: 0 2px 6px rgba(0,0,0,0.06); display: flex; flex-direction: column; gap: 8px; position: relative; }
.salida-row .quitar { position: absolute; top: 8px; right: 10px; background: none; border: none; color: var(--rojo); font-size: 18px; cursor: pointer; }
.salida-row .linea { display: flex; gap: 8px; }
.salida-row select, .salida-row input { width: 100%; }
.merma-box { background: #E3F0FB; border-radius: 10px; padding: 11px 14px; display: flex; justify-content: space-between; align-items: center; font-size: 14px; color: #1565C0; font-weight: 700; }
.merma-box.error { background: #FFEBEE; color: var(--rojo); }

/* Lista fija de productos resultantes del pilado */
.salida-fija { background: #fff; border-radius: 12px; padding: 11px 13px; box-shadow: 0 2px 6px rgba(0,0,0,0.06); }
.salida-fija.lleno { box-shadow: 0 0 0 2px var(--verde); }
.salida-fija .nom { font-size: 14px; font-weight: 800; margin-bottom: 8px; display: flex; align-items: center; gap: 7px; }
.salida-fija .controles { display: flex; gap: 8px; align-items: center; }
.salida-fija .controles input { flex: 1; min-width: 0; }
.salida-fija .controles .qq { font-size: 13px; font-weight: 700; color: var(--texto-medio); }
.salida-fija .controles select { flex: 1.3; min-width: 0; }

/* ---------- PESTAÑAS ---------- */
.pestanas { display: flex; background: var(--verde); }
.pestana { flex: 1; text-align: center; padding: 13px 0; font-size: 14px; font-weight: 800; color: rgba(255,255,255,0.6); border-bottom: 3px solid transparent; cursor: pointer; }
.pestana.activa { color: #fff; border-bottom-color: var(--dorado-claro); }
.pestana .cuenta { font-size: 10px; background: rgba(255,255,255,0.2); padding: 1px 7px; border-radius: 10px; margin-left: 4px; }

/* ---------- PERSONAS ---------- */
.rol-badge { font-size: 9px; font-weight: 800; padding: 2px 7px; border-radius: 6px; background: #EFE7F7; color: #6A4C93; margin-left: 6px; }
.saldo-mini { font-size: 13px; font-weight: 900; }
.saldo-mini.debe { color: var(--rojo); }
.saldo-mini.ok { color: var(--verde); }
.saldo-l { font-size: 10px; color: var(--texto-medio); }

/* Ficha de persona */
.ficha-hero { background: var(--verde); padding: 18px 16px 20px; text-align: center; color: #fff; }
.ficha-hero .av { width: 60px; height: 60px; border-radius: 18px; background: rgba(255,255,255,0.15); display: flex; align-items: center; justify-content: center; font-size: 28px; margin: 0 auto 8px; }
.ficha-hero .nom { font-size: 19px; font-weight: 900; }
.ficha-hero .sub { font-size: 12px; color: rgba(255,255,255,0.75); }
.ficha-roles { display: flex; gap: 6px; justify-content: center; margin-top: 7px; }
.ficha-roles .r { font-size: 10px; font-weight: 800; padding: 3px 11px; border-radius: 13px; }
.r-prov { background: var(--dorado-claro); color: #1A1A1A; }
.r-cli { background: #A5D8FF; color: #0d47a1; }
.btn-editar-ficha { display: inline-block; margin-top: 12px; background: rgba(255,255,255,0.18); color: #fff; font-size: 12px; font-weight: 800; padding: 7px 16px; border-radius: 13px; text-decoration: none; border: 1.5px solid rgba(255,255,255,0.35); }
.btn-editar-ficha:active { background: rgba(255,255,255,0.3); }
.ficha-cont { max-width: 600px; margin: 0 auto; padding: 16px; display: flex; flex-direction: column; gap: 12px; }
.estado-cuenta { display: flex; flex-direction: column; gap: 10px; }
.cuenta-card { background: #fff; border-radius: 14px; padding: 14px 15px; box-shadow: 0 2px 8px rgba(0,0,0,0.08); display: flex; align-items: center; gap: 13px; }
.cuenta-card.cobrar { border-left: 5px solid var(--verde); }
.cuenta-card.pagar { border-left: 5px solid var(--rojo); }
.cuenta-card .ci { width: 42px; height: 42px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 20px; }
.cuenta-card .ci.g { background: #E3F2E3; } .cuenta-card .ci.r { background: #FBE6E3; }
.cuenta-card .ct { flex: 1; }
.cuenta-card .cl { font-size: 11px; color: var(--texto-medio); }
.cuenta-card .cv { font-size: 22px; font-weight: 900; }
.cuenta-card .cv.verde { color: var(--verde); } .cuenta-card .cv.rojo { color: var(--rojo); }
.cuenta-card .cbtn { font-size: 12px; font-weight: 800; color: #fff; padding: 9px 15px; border-radius: 10px; border: none; cursor: pointer; }
.cbtn.cobrar { background: var(--verde); } .cbtn.pagar { background: var(--rojo); }
.stats-fila { display: flex; gap: 8px; }
.stats-fila .st { flex: 1; background: #fff; border-radius: 11px; padding: 10px; text-align: center; box-shadow: 0 2px 6px rgba(0,0,0,0.05); }
.stats-fila .sv { font-size: 16px; font-weight: 900; } .stats-fila .sl { font-size: 10px; color: var(--texto-medio); }
.contacto-fila { display: flex; gap: 8px; }
.contacto-fila a { flex: 1; background: #fff; border: 2px solid var(--gris-borde); border-radius: 11px; padding: 11px; text-align: center; font-size: 13px; font-weight: 700; color: var(--verde); text-decoration: none; }

/* ---------- DEUDAS ---------- */
.deudas-resumen { display: flex; gap: 10px; padding: 14px 16px 0; max-width: 760px; margin: 0 auto; }
.dr-caja { flex: 1; border-radius: 14px; padding: 12px 14px; }
.dr-cobrar { background: #E3F2E3; } .dr-pagar { background: #FBE6E3; }
.dr-l { font-size: 11px; font-weight: 600; }
.dr-cobrar .dr-l { color: #2D6A2D; } .dr-pagar .dr-l { color: #C0392B; }
.dr-v { font-size: 19px; font-weight: 900; margin-top: 2px; }
.dr-cobrar .dr-v { color: var(--verde); } .dr-pagar .dr-v { color: var(--rojo); }
.deuda-card { background: #fff; border-radius: 14px; padding: 13px 14px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); border-left: 5px solid var(--verde); }
.deuda-card.pagar { border-left-color: var(--rojo); }
.deuda-card.vencida { background: #FFF8F7; }
.deuda-top { display: flex; align-items: center; gap: 11px; }
.deuda-top .av { width: 40px; height: 40px; border-radius: 11px; background: #E3F2E3; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.deuda-top .av.r { background: #FBE6E3; }
.deuda-top .info { flex: 1; min-width: 0; }
.deuda-top .nom { font-size: 15px; font-weight: 800; }
.deuda-top .meta { font-size: 11px; color: var(--texto-medio); }
.deuda-top .saldo { font-size: 16px; font-weight: 900; }
.deuda-top .saldo.verde { color: var(--verde); } .deuda-top .saldo.rojo { color: var(--rojo); }
.deuda-bottom { display: flex; justify-content: space-between; align-items: center; margin-top: 10px; padding-top: 9px; border-top: 1px dashed var(--gris-borde); }
.venc { font-size: 11px; font-weight: 700; }
.venc.ok { color: var(--texto-medio); } .venc.pronto { color: var(--dorado); } .venc.vencida { color: var(--rojo); }
.barra-parcial { height: 6px; background: #E5DCC8; border-radius: 4px; margin-top: 8px; overflow: hidden; }
.barra-parcial .fill { height: 100%; background: #1565C0; border-radius: 4px; }
.balance-neto { position: fixed; bottom: 0; left: 0; right: 0; background: #1A1A1A; padding: 13px 18px; display: flex; justify-content: space-between; align-items: center; }
.balance-neto .l { color: rgba(255,255,255,0.8); font-size: 12px; font-weight: 600; }
.balance-neto .v { font-size: 17px; font-weight: 900; }

/* ---------- MODAL PAGO ---------- */
.modal-fondo { position: fixed; inset: 0; background: rgba(0,0,0,0.45); display: flex; align-items: flex-end; justify-content: center; z-index: 50; }
.modal-hoja { background: var(--crema); border-radius: 24px 24px 0 0; width: 100%; max-width: 480px; padding: 10px 18px 22px; display: flex; flex-direction: column; gap: 12px; }
.modal-asa { width: 44px; height: 5px; background: #C9BCA0; border-radius: 5px; margin: 6px auto; }
.modal-titulo { font-size: 18px; font-weight: 900; color: var(--verde); text-align: center; }
.modal-sub { font-size: 12px; color: var(--texto-medio); text-align: center; margin-top: -6px; }
.saldo-grande { background: #FBE6E3; border-radius: 12px; padding: 12px 16px; display: flex; justify-content: space-between; align-items: center; }
.saldo-grande .l { font-size: 13px; color: var(--rojo); } .saldo-grande .v { font-size: 18px; font-weight: 900; color: var(--rojo); }
.atajos { display: flex; gap: 7px; }
.atajo { flex: 1; background: #fff; border: 2px solid var(--gris-borde); border-radius: 10px; padding: 9px 4px; font-size: 12px; font-weight: 700; color: var(--texto-medio); text-align: center; cursor: pointer; }
.atajo.full { background: var(--verde); border-color: var(--verde); color: #fff; }
.modal-hoja .campo { display: flex; flex-direction: column; gap: 6px; }
.modal-hoja .campo label { font-size: 14px; font-weight: 700; color: var(--verde); }
.modal-hoja input[type=number], .modal-hoja select {
  width: 100%; background: #fff; border: 2.5px solid var(--verde); border-radius: 12px;
  padding: 13px 14px; font-size: 18px; font-weight: 700; color: var(--texto); font-family: inherit; outline: none;
}

/* ---------- REPORTES ---------- */
.rep-cont { max-width: 720px; margin: 0 auto; padding: 16px; display: flex; flex-direction: column; gap: 14px; }
.periodo-box { background: #fff; border-radius: 14px; padding: 14px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); }
.periodo-box .et { font-size: 12px; font-weight: 700; color: var(--texto-medio); margin-bottom: 8px; }
.periodo-fechas { display: flex; gap: 8px; align-items: center; }
.periodo-fechas input { flex: 1; background: var(--crema); border: 2px solid var(--gris-borde); border-radius: 10px; padding: 11px; font-size: 15px; font-family: inherit; color: var(--texto); outline: none; }
.periodo-fechas span { font-size: 12px; color: var(--texto-medio); }
.atajos-periodo { display: flex; gap: 7px; margin-top: 9px; }
.atajo-p { flex: 1; background: var(--crema); border: 2px solid var(--gris-borde); border-radius: 9px; padding: 8px 4px; font-size: 12px; font-weight: 700; color: var(--texto-medio); text-align: center; cursor: pointer; }
.atajo-p.activo { background: var(--verde); border-color: var(--verde); color: #fff; }

.ganancia-card { background: var(--verde); border-radius: 16px; padding: 18px; }
.ganancia-card .et { color: rgba(255,255,255,0.85); font-size: 12px; }
.ganancia-card .big { color: var(--dorado-claro); font-size: 32px; font-weight: 900; margin: 3px 0 12px; }
.gc-fila { display: flex; justify-content: space-between; font-size: 13px; padding: 3px 0; }
.gc-fila .l { color: rgba(255,255,255,0.8); } .gc-fila .v { font-weight: 700; color: #fff; }
.gc-fila .v.mas { color: #A5E8A5; } .gc-fila .v.menos { color: #FFB3AB; }
.gc-div { border-top: 1px solid rgba(255,255,255,0.2); margin: 5px 0; }
.gc-final .l { font-weight: 800; color: #fff; } .gc-final .v { color: var(--dorado-claro); font-weight: 900; }

.kpis-rep { display: flex; gap: 9px; }
.kpis-rep .k { flex: 1; background: #fff; border-radius: 12px; padding: 12px 10px; box-shadow: 0 2px 6px rgba(0,0,0,0.06); text-align: center; }
.kpis-rep .kv { font-size: 17px; font-weight: 900; } .kpis-rep .kl { font-size: 10px; color: var(--texto-medio); }

.comp-card { background: #fff; border-radius: 14px; padding: 16px; box-shadow: 0 2px 8px rgba(0,0,0,0.06); }
.comp-card .tt { font-size: 13px; font-weight: 800; margin-bottom: 12px; }
.comp-barra { margin-bottom: 12px; }
.comp-barra .cl { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 4px; }
.comp-barra .track { height: 14px; background: var(--crema); border-radius: 7px; overflow: hidden; }
.comp-barra .fill { height: 100%; border-radius: 7px; }
.fill-ventas { background: var(--verde); } .fill-compras { background: var(--dorado); }

.rank-card { background: #fff; border-radius: 14px; padding: 16px; box-shadow: 0 2px 8px rgba(0,0,0,0.06); }
.rank-card .tt { font-size: 13px; font-weight: 800; color: var(--tierra, #8B5E3C); margin-bottom: 11px; }
.rank-fila { display: flex; align-items: center; gap: 11px; padding: 7px 0; border-bottom: 1px dashed var(--gris-borde); }
.rank-fila:last-child { border-bottom: none; }
.rank-pos { width: 24px; height: 24px; border-radius: 8px; background: var(--crema); color: #8B5E3C; font-size: 12px; font-weight: 900; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rank-pos.oro { background: var(--dorado-claro); color: #fff; }
.rank-fila .rn { flex: 1; font-size: 13px; font-weight: 700; }
.rank-fila .rv { font-size: 13px; font-weight: 800; color: var(--verde); }

.btn-pdf { background: var(--rojo); color: #fff; border: none; border-radius: 14px; padding: 15px; font-size: 16px; font-weight: 800; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; }

/* Selector de tipo de informe */
.tipo-informe { display: flex; gap: 7px; }
.ti-btn { flex: 1; background: #fff; border: 2px solid var(--gris-borde); border-radius: 10px; padding: 11px 6px; font-size: 12.5px; font-weight: 800; color: var(--texto-medio); text-align: center; cursor: pointer; }
.ti-btn.activo { background: var(--verde); border-color: var(--verde); color: #fff; }

/* Secciones de informe (stock / deudas) */
.sec-informe { background: #fff; border-radius: 14px; box-shadow: 0 2px 8px rgba(0,0,0,0.06); overflow: hidden; }
.sec-cab { display: flex; justify-content: space-between; align-items: center; padding: 12px 15px; background: var(--crema); border-bottom: 1px solid var(--gris-borde); }
.sec-cab.cobrar { background: #E3F2E3; } .sec-cab.pagar { background: #FBE6E3; }
.sec-cab .st { font-size: 15px; font-weight: 800; display: flex; align-items: center; gap: 7px; }
.sec-cab .stot { font-size: 14px; font-weight: 900; color: var(--verde); }
.sec-cab.bajo .stot { color: var(--rojo); }
.sec-cab.pagar .stot { color: var(--rojo); }
.fila-rep { display: flex; align-items: center; gap: 10px; padding: 10px 15px; border-bottom: 1px solid #F0EBE0; }
.fila-rep:last-child { border-bottom: none; }
.fila-rep .frl { flex: 1; min-width: 0; }
.fila-rep .frn { font-size: 13px; font-weight: 800; }
.fila-rep .frm { font-size: 11px; color: var(--texto-medio); margin-top: 1px; }
.fila-rep .frv { font-size: 14px; font-weight: 800; color: var(--verde); text-align: right; white-space: nowrap; }
.fila-rep .frv.rojo { color: var(--rojo); }
.fila-rep.venc { background: #FFF8F7; }
.tag-mini { font-size: 9px; font-weight: 800; padding: 1px 6px; border-radius: 5px; }
.tag-venc { background: #FFEBEE; color: var(--rojo); }
.tag-pronto { background: #FFF3D6; color: #8B6000; }
.tag-sinf { background: #EEE; color: #777; }
.total-grande { background: #1A1A1A; border-radius: 12px; padding: 13px 16px; display: flex; justify-content: space-between; align-items: center; }
.total-grande .l { color: rgba(255,255,255,0.85); font-size: 13px; font-weight: 600; }
.total-grande .v { color: var(--dorado-claro); font-size: 19px; font-weight: 900; }

/* ---------- CONFIGURACION (acordeon) ---------- */
.cfg-cont { max-width: 640px; margin: 0 auto; padding: 16px; display: flex; flex-direction: column; gap: 12px; }
.acc { background: #fff; border-radius: 14px; box-shadow: 0 2px 8px rgba(0,0,0,0.06); overflow: hidden; }
.acc-cab { display: flex; align-items: center; gap: 12px; padding: 15px; cursor: pointer; }
.acc-cab .ai { font-size: 22px; width: 28px; text-align: center; }
.acc-cab .at { flex: 1; font-size: 15px; font-weight: 800; }
.acc-cab .ad { font-size: 11px; color: var(--texto-medio); }
.acc-cab .flecha { color: var(--gris-borde); font-size: 22px; transition: transform .2s; }
.acc.abierto .flecha { transform: rotate(90deg); }
.acc-cuerpo { display: none; padding: 0 15px 15px; flex-direction: column; gap: 10px; }
.acc.abierto .acc-cuerpo { display: flex; }
.cfg-campo { display: flex; flex-direction: column; gap: 5px; }
.cfg-campo label { font-size: 13px; font-weight: 700; color: var(--verde); }
.cfg-campo input, .cfg-campo select {
  width: 100%; background: #fff; border: 2px solid var(--gris-borde); border-radius: 10px;
  padding: 11px 13px; font-size: 15px; color: var(--texto); font-family: inherit; outline: none;
}
.cfg-campo input:focus, .cfg-campo select:focus { border-color: var(--verde); }
.cfg-fila { display: flex; gap: 10px; }
.cfg-fila .cfg-campo { flex: 1; }
.btn-cfg { background: var(--verde); color: #fff; border: none; border-radius: 11px; padding: 12px; font-size: 14px; font-weight: 800; cursor: pointer; }
.cat-item { display: flex; align-items: center; gap: 9px; padding: 10px 12px; background: var(--crema); border-radius: 10px; }
.cat-item.inactivo { opacity: .5; }
.cat-item .cn { flex: 1; font-size: 14px; font-weight: 700; }
.cat-item .cb { width: 34px; height: 34px; border-radius: 8px; border: none; font-size: 15px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.cb-edit { background: #E3F0FB; } .cb-off { background: #FBE6E3; } .cb-on { background: #E3F2E3; }
.cat-add { display: flex; gap: 8px; margin-top: 4px; }
.cat-add input { flex: 1; border: 2px solid var(--gris-borde); border-radius: 10px; padding: 10px 12px; font-size: 14px; font-family: inherit; outline: none; }
.cat-add button { background: var(--dorado); color: #fff; border: none; border-radius: 10px; padding: 0 16px; font-weight: 800; cursor: pointer; }
.user-row { display: flex; align-items: center; gap: 9px; padding: 11px 12px; background: var(--crema); border-radius: 10px; }
.user-row .ur-i { flex: 1; }
.user-row .ur-n { font-size: 14px; font-weight: 800; }
.user-row .ur-m { font-size: 11px; color: var(--texto-medio); }
.user-rol { font-size: 9px; font-weight: 800; padding: 2px 8px; border-radius: 8px; }
.user-rol.admin { background: #2D6A2D; color: #fff; } .user-rol.op { background: #E3F0FB; color: #1565C0; }
.cfg-nota { font-size: 12px; color: var(--texto-medio); line-height: 1.5; }
.ok-msg { background: #E3F2E3; color: var(--verde); border-radius: 10px; padding: 10px 13px; font-size: 13px; font-weight: 700; text-align: center; }

/* ---------- HISTORIAL ---------- */
.hist-dia { font-size: 12px; font-weight: 800; color: var(--texto-medio); text-transform: uppercase; letter-spacing: .5px; margin: 6px 2px 2px; }
.hist-item { background: #fff; border-radius: 13px; padding: 12px 14px; box-shadow: 0 2px 7px rgba(0,0,0,0.06); display: flex; align-items: center; gap: 12px; border-left: 4px solid #ccc; }
.hist-item.compra { border-left-color: #2D6A2D; } .hist-item.venta { border-left-color: #C8941A; }
.hist-item.cobro { border-left-color: #4A9E4A; } .hist-item.pago { border-left-color: #C0392B; }
.hist-item.pilado { border-left-color: #1565C0; }
.hi-ico { width: 40px; height: 40px; border-radius: 11px; display: flex; align-items: center; justify-content: center; font-size: 19px; flex-shrink: 0; }
.hi-ico.compra { background: #E3F2E3; } .hi-ico.venta { background: #FFF3D6; } .hi-ico.cobro { background: #E3F2E3; } .hi-ico.pago { background: #FBE6E3; } .hi-ico.pilado { background: #E3F0FB; }
.hi-info { flex: 1; min-width: 0; }
.hi-det { font-size: 14px; font-weight: 800; color: var(--texto); }
.hi-meta { font-size: 11.5px; color: var(--texto-medio); margin-top: 2px; }
.hi-meta b { color: var(--verde); }
.hi-monto { font-size: 14px; font-weight: 800; text-align: right; white-space: nowrap; }
.hi-monto.verde { color: var(--verde); } .hi-monto.rojo { color: var(--rojo); } .hi-monto.dorado { color: var(--dorado); }

@media print {
  /* Forzar que se impriman los colores de fondo */
  * { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }

  .barra-nav, .periodo-box, .btn-pdf { display: none !important; }
  body { background: #fff; }
  .rep-cont { max-width: 100%; padding: 0; gap: 10px; }

  /* La tarjeta de ganancia pasa a fondo blanco con texto oscuro (siempre legible) */
  .ganancia-card { background: #fff !important; border: 2px solid #2D6A2D; }
  .ganancia-card .et { color: #6A6A6A !important; }
  .ganancia-card .big { color: #2D6A2D !important; }
  .ganancia-card .gc-fila .l { color: #1A1A1A !important; }
  .ganancia-card .gc-fila .v { color: #1A1A1A !important; }
  .ganancia-card .gc-fila .v.mas { color: #2D6A2D !important; }
  .ganancia-card .gc-fila .v.menos { color: #C0392B !important; }
  .ganancia-card .gc-final .v { color: #2D6A2D !important; }
  .ganancia-card .gc-div { border-color: #ccc !important; }

  /* Quitar sombras y poner borde fino para que se vean los recuadros */
  .comp-card, .rank-card, .kpis-rep .k, .periodo-box { box-shadow: none !important; border: 1px solid #D4C9B0; }

  /* Evitar que las tarjetas se corten entre paginas */
  .ganancia-card, .comp-card, .rank-card, .kpis-rep { break-inside: avoid; }
}
