:root {
  --tinta: #1f2937;
  --suave: #6b7280;
  --linea: #e5e7eb;
  --fondo: #f7f7f5;
  --tarjeta: #ffffff;
  --verde: #2f9e6f;
  --verde-oscuro: #267a57;
  --rojo: #c0392b;
  --sombra: 0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.04);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--tinta);
  background: var(--fondo);
  line-height: 1.55;
}

/* Cabecera */
.cabecera {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 22px;
  background: var(--tarjeta);
  border-bottom: 1px solid var(--linea);
}
.marca { font-weight: 700; font-size: 1.15rem; color: var(--tinta); text-decoration: none; }
.marca span { color: var(--verde); margin: 0 4px; }
.marca small { font-weight: 500; color: var(--suave); font-size: .8rem; }
.nav { display: flex; align-items: center; gap: 14px; }
.usuario { color: var(--suave); font-size: .9rem; }
.boton-salir {
  color: var(--tinta); text-decoration: none; font-size: .9rem;
  border: 1px solid var(--linea); padding: 6px 14px; border-radius: 8px;
}
.boton-salir:hover { background: var(--fondo); }

/* Contenido */
.contenido { max-width: 920px; margin: 0 auto; padding: 32px 22px; }

/* Tarjeta centrada (login) */
.tarjeta-centro {
  max-width: 380px; margin: 6vh auto 0;
  background: var(--tarjeta); padding: 34px 30px;
  border-radius: 16px; box-shadow: var(--sombra);
}
.tarjeta-centro h1 { margin: 0 0 6px; font-size: 1.5rem; }
.sub { color: var(--suave); margin: 0 0 22px; }

/* Formulario */
.formulario { display: flex; flex-direction: column; gap: 16px; }
.formulario label { display: flex; flex-direction: column; gap: 6px; font-size: .9rem; font-weight: 600; }
.formulario input {
  padding: 11px 12px; border: 1px solid var(--linea); border-radius: 10px;
  font-size: 1rem; font-family: inherit;
}
.formulario input:focus { outline: 2px solid var(--verde); border-color: transparent; }

.boton-principal {
  margin-top: 6px; padding: 12px; border: none; border-radius: 10px;
  background: var(--verde); color: #fff; font-size: 1rem; font-weight: 600;
  cursor: pointer;
}
.boton-principal:hover { background: var(--verde-oscuro); }

/* Avisos */
.aviso { padding: 11px 14px; border-radius: 10px; margin-bottom: 18px; font-size: .92rem; }
.aviso-error { background: #fcebea; color: var(--rojo); border: 1px solid #f3c9c4; }

/* Panel */
.panel { background: var(--tarjeta); padding: 30px; border-radius: 16px; box-shadow: var(--sombra); }
.panel h1 { margin: 0 0 4px; }
.lista-restaurantes { padding-left: 20px; }
.proximamente {
  margin-top: 26px; padding: 18px 20px; background: var(--fondo);
  border: 1px dashed var(--linea); border-radius: 12px; color: var(--suave);
}
.proximamente ul { margin: 8px 0 0; }

/* Pie */
.pie { text-align: center; color: var(--suave); padding: 24px; }

/* Vinculación Telegram */
.dos-columnas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 16px;
  align-items: stretch;
}
@media (max-width: 520px) {
  .dos-columnas { grid-template-columns: 1fr; }
}
.columna-qr, .columna-manual {
  background: var(--fondo);
  border: 1px solid var(--linea);
  border-radius: 12px;
  padding: 18px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}
.metodo-label {
  font-weight: 700;
  font-size: .95rem;
  margin-bottom: 8px;
}
.instruccion {
  font-size: .9rem;
  margin: 0 0 12px;
  flex-shrink: 0;
}
.qr-centrado {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.qr-fondo {
  background: #fff;
  border: 1px solid var(--linea);
  border-radius: 10px;
  padding: 10px;
  display: inline-flex;
}
.qr-fondo img {
  display: block;
  width: 100%;
  max-width: 180px;
  height: auto;
}
.comando-bloque {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #fff;
  border: 1px solid var(--linea);
  border-radius: 10px;
  padding: 10px 12px;
  margin-top: 8px;
}
.comando-texto {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .05em;
  flex: 1;
  word-break: break-all;
}
.boton-copiar {
  border: 1px solid var(--linea);
  background: var(--fondo);
  border-radius: 8px;
  padding: 6px 12px;
  cursor: pointer;
  font-size: .82rem;
  white-space: nowrap;
  flex-shrink: 0;
}
.boton-copiar:hover { background: var(--linea); }
.codigo-sub { font-size: .8rem; color: var(--suave); }
.aviso-ok { background: #eafaf1; color: #1e6e42; border: 1px solid #b7e4c7; }
.enlace-volver { color: var(--suave); text-decoration: none; font-size: .92rem; }
.enlace-volver:hover { color: var(--tinta); }

/* Lista restaurantes en inicio */
.lista-restaurantes { list-style: none; padding: 0; margin: 0; }
.restaurante-fila {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 0; border-bottom: 1px solid var(--linea); gap: 12px;
}
.estado-telegram { display: flex; align-items: center; gap: 10px; }
.badge { font-size: .82rem; padding: 3px 10px; border-radius: 20px; }
.badge-ok  { background: #eafaf1; color: #1e6e42; }
.badge-aviso { background: #fef9ec; color: #8a6500; }
.enlace-accion { font-size: .88rem; color: var(--verde); text-decoration: none; font-weight: 600; }
.enlace-accion:hover { text-decoration: underline; }

/* ============================================================ */
/*  PANEL DE DECISIONES — "El libro de decisiones"              */
/* ============================================================ */
.pd {
  --pd-papel:#f6f4ef; --pd-tinta:#14201b; --pd-verde:#2f9e6f;
  --pd-verde-hondo:#1f7a53; --pd-clay:#c0563f; --pd-ambar:#c4892f;
  --pd-linea:#e6e1d8; --pd-musgo:#6f7a72; --pd-carta:#fffdf9;
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--pd-tinta);
  max-width:880px; margin:0 auto;
}
.pd ::selection{background:rgba(47,158,111,.18);}

/* Cabecera */
.pd-cabecera{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:30px;}
.pd-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--pd-verde-hondo);margin:0 0 8px;}
.pd-h1{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:2.5rem;line-height:1.02;margin:0;letter-spacing:-.025em;}
.pd-lede{color:var(--pd-musgo);margin:10px 0 0;font-size:1rem;}
.pd-volver{color:var(--pd-musgo);text-decoration:none;font-size:.9rem;white-space:nowrap;padding-top:8px;}
.pd-volver:hover{color:var(--pd-tinta);}

/* Balance */
.pd-balance{
  display:flex;align-items:stretch;
  background:var(--pd-carta);border:1px solid var(--pd-linea);
  border-radius:18px;padding:26px 10px;margin-bottom:20px;
  box-shadow:0 1px 2px rgba(20,32,27,.04),0 18px 40px rgba(20,32,27,.06);
}
.facet{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:4px 20px;gap:7px;}
.facet-label{font-size:.78rem;color:var(--pd-musgo);font-weight:500;}
.facet-cifra{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:2.1rem;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.03em;}
.facet-de{color:var(--pd-musgo);font-weight:400;}
.facet-nota{font-size:.74rem;color:var(--pd-musgo);}
.facet-sep{width:1px;background:var(--pd-linea);margin:8px 0;}
.signo-positivo{color:var(--pd-verde-hondo);}
.signo-negativo{color:var(--pd-clay);}
.signo-neutro{color:var(--pd-tinta);}

/* Composición */
.pd-composicion{margin-bottom:38px;padding:0 4px;}
.comp-barra{display:flex;height:9px;gap:3px;}
.comp-seg{display:block;border-radius:4px;min-width:8px;transition:flex-grow .4s ease;}
.seg-aprobar{background:var(--pd-verde);}
.seg-ajustar{background:var(--pd-ambar);}
.seg-rechazar{background:var(--pd-clay);}
.seg-pendiente{background:#cdd5cf;}
.comp-leyenda{display:flex;flex-wrap:wrap;gap:18px;margin-top:12px;}
.leg{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;color:var(--pd-musgo);}
.punto{width:9px;height:9px;border-radius:50%;display:inline-block;}

/* Vías */
.pd-vias{display:flex;flex-direction:column;gap:18px;}
.via{
  background:var(--pd-carta);border:1px solid var(--pd-linea);
  border-radius:18px;padding:24px 26px;
  box-shadow:0 1px 2px rgba(20,32,27,.04);
  opacity:0;transform:translateY(16px);
  transition:opacity .55s cubic-bezier(.22,.61,.36,1),transform .55s cubic-bezier(.22,.61,.36,1);
}
.via.visible{opacity:1;transform:none;}
.via:nth-child(2){transition-delay:.06s;}
.via:nth-child(3){transition-delay:.12s;}
.via:nth-child(4){transition-delay:.18s;}

.via-cab{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;}
.via-ambito{font-family:'IBM Plex Mono',monospace;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:4px 9px;border-radius:6px;display:inline-block;margin-bottom:9px;}
.ambito-delivery{background:rgba(47,158,111,.12);color:var(--pd-verde-hondo);}
.ambito-topes{background:rgba(196,137,47,.14);color:#9a6816;}
.via-titulo{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1.35rem;margin:0;letter-spacing:-.015em;}
.via-cab-der{display:flex;flex-direction:column;align-items:flex-end;gap:9px;flex-shrink:0;}
.via-impacto{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:1.4rem;font-variant-numeric:tabular-nums;letter-spacing:-.02em;}
.via-decision{font-size:.74rem;font-weight:600;padding:4px 11px;border-radius:20px;white-space:nowrap;}
.dec-aprobar{background:rgba(47,158,111,.14);color:var(--pd-verde-hondo);}
.dec-ajustar{background:rgba(196,137,47,.16);color:#9a6816;}
.dec-rechazar{background:rgba(192,86,63,.14);color:var(--pd-clay);}
.dec-pendiente{background:#eceae4;color:var(--pd-musgo);}

/* El bucle: espina con 4 estaciones */
.via-bucle{list-style:none;margin:0;padding:0;}
.paso{position:relative;padding:0 0 20px 40px;}
.paso:last-child{padding-bottom:0;}
.paso::before{content:"";position:absolute;left:13px;top:26px;bottom:-4px;width:2px;background:var(--pd-linea);}
.paso:last-child::before{display:none;}
.paso-nodo{
  position:absolute;left:0;top:0;width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'IBM Plex Mono',monospace;font-size:.8rem;font-weight:600;
  background:var(--pd-carta);border:2px solid var(--pd-linea);color:var(--pd-musgo);
}
.paso-cuerpo{padding-top:2px;}
.paso-titulo{font-weight:600;font-size:.9rem;margin-bottom:4px;display:flex;align-items:center;gap:9px;flex-wrap:wrap;}
.paso-texto{display:block;color:var(--pd-musgo);font-size:.9rem;line-height:1.55;}
.paso-origen{font-family:'IBM Plex Mono',monospace;font-size:.66rem;color:var(--pd-musgo);font-weight:400;letter-spacing:.04em;}

/* Nodo del resultado según estado */
.res-funciono .paso-nodo{background:var(--pd-verde);border-color:var(--pd-verde);color:#fff;}
.res-parcial .paso-nodo{background:var(--pd-ambar);border-color:var(--pd-ambar);color:#fff;}
.res-no_aplicado .paso-nodo,.res-no_mejoro .paso-nodo{background:var(--pd-clay);border-color:var(--pd-clay);color:#fff;}
.paso-vacio .paso-nodo{border-style:dashed;}
.paso-vacio .paso-texto{font-style:italic;opacity:.75;}

/* Chips de resultado */
.paso-chip{font-size:.68rem;font-weight:600;padding:2px 9px;border-radius:20px;}
.chip-funciono{background:rgba(47,158,111,.14);color:var(--pd-verde-hondo);}
.chip-parcial{background:rgba(196,137,47,.16);color:#9a6816;}
.chip-no_aplicado,.chip-no_mejoro{background:rgba(192,86,63,.14);color:var(--pd-clay);}

/* Nota de aprendizaje (la voz de Pepito) */
.via-aprendizaje{
  margin:18px 0 0;padding:13px 16px;background:var(--pd-papel);
  border-radius:10px;font-size:.86rem;color:var(--pd-tinta);
  border-left:3px solid var(--pd-verde);
}

/* Estado vacío */
.pd-vacio{text-align:center;padding:64px 26px;background:var(--pd-carta);border:1px solid var(--pd-linea);border-radius:18px;}
.vacio-marca{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.5rem;color:var(--pd-verde);margin-bottom:18px;}
.pd-vacio h2{font-family:'Bricolage Grotesque',sans-serif;margin:0 0 12px;font-weight:600;}
.pd-vacio p{color:var(--pd-musgo);max-width:460px;margin:0 auto 24px;line-height:1.6;}

/* Responsivo */
@media (max-width:640px){
  .pd-balance{flex-direction:column;padding:10px;}
  .facet{padding:18px;}
  .facet-sep{width:auto;height:1px;margin:0 18px;}
  .pd-h1{font-size:2rem;}
  .via-cab{flex-direction:column;}
  .via-cab-der{flex-direction:row;align-items:center;}
}

/* Respeto a quien prefiere menos movimiento */
@media (prefers-reduced-motion: reduce){
  .via{opacity:1;transform:none;transition:none;}
}

/* Ajuste lista de restaurantes en inicio (enlace secundario) */
.restaurante-nombre{font-weight:600;}
.enlace-sec{color:var(--suave)!important;font-weight:500!important;}
.enlace-sec:hover{color:var(--tinta)!important;}

/* Panel: ID, fecha de paso, filtro y paginación */
.via-meta{display:flex;align-items:center;gap:8px;margin-bottom:9px;}
.via-id{font-family:'IBM Plex Mono',monospace;font-size:.72rem;color:var(--pd-musgo);font-weight:500;}

.paso-fecha{font-family:'IBM Plex Mono',monospace;font-size:.68rem;color:var(--pd-musgo);font-weight:400;letter-spacing:.02em;}

.pd-filtro{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px;}
.filtro-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 15px;border-radius:30px;text-decoration:none;
  font-size:.88rem;font-weight:500;
  background:var(--pd-carta);border:1px solid var(--pd-linea);color:var(--pd-tinta);
  transition:border-color .15s ease,background .15s ease;
}
.filtro-btn:hover{border-color:var(--pd-verde);}
.filtro-btn.activo{background:var(--pd-verde);border-color:var(--pd-verde);color:#fff;}
.filtro-n{font-family:'IBM Plex Mono',monospace;font-size:.74rem;opacity:.75;}
.filtro-btn.activo .filtro-n{opacity:.9;}

.pd-sin-filtro{padding:30px;text-align:center;color:var(--pd-musgo);background:var(--pd-carta);border:1px dashed var(--pd-linea);border-radius:14px;}

.pd-paginacion{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:26px;}
.pag-btn{
  padding:8px 16px;border-radius:10px;text-decoration:none;font-size:.88rem;font-weight:500;
  background:var(--pd-carta);border:1px solid var(--pd-linea);color:var(--pd-tinta);
}
.pag-btn:hover{border-color:var(--pd-verde);}
.pag-off{opacity:.4;pointer-events:none;}
.pag-info{font-family:'IBM Plex Mono',monospace;font-size:.82rem;color:var(--pd-musgo);}

/* ============================================================ */
/*  GRÁFICAS DE INGRESOS Y GASTOS                               */
/* ============================================================ */
.gf {
  --gf-papel:#f6f4ef; --gf-tinta:#14201b; --gf-verde:#2f9e6f;
  --gf-verde-hondo:#1f7a53; --gf-clay:#c0563f; --gf-linea:#e6e1d8;
  --gf-musgo:#6f7a72; --gf-carta:#fffdf9;
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--gf-tinta); max-width:880px; margin:0 auto;
}

.gf-cabecera{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:26px;}
.gf-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gf-verde-hondo);margin:0 0 8px;}
.gf-h1{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:2.5rem;line-height:1.02;margin:0;letter-spacing:-.025em;}
.gf-lede{color:var(--gf-musgo);margin:10px 0 0;font-size:1rem;}
.gf-volver{color:var(--gf-musgo);text-decoration:none;font-size:.9rem;white-space:nowrap;padding-top:8px;}
.gf-volver:hover{color:var(--gf-tinta);}

/* Controles */
.gf-controles{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;}
.gf-niveles{display:inline-flex;background:var(--gf-carta);border:1px solid var(--gf-linea);border-radius:30px;padding:4px;}
.nivel-btn{
  border:none;background:transparent;cursor:pointer;
  padding:8px 18px;border-radius:24px;font-size:.9rem;font-weight:500;
  font-family:inherit;color:var(--gf-musgo);transition:all .15s ease;
}
.nivel-btn:hover{color:var(--gf-tinta);}
.nivel-btn.activo{background:var(--gf-verde);color:#fff;}

.gf-toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:.9rem;color:var(--gf-tinta);user-select:none;}
.gf-toggle input{position:absolute;opacity:0;width:0;height:0;}
.toggle-pista{width:42px;height:24px;border-radius:24px;background:#d8d3c8;position:relative;transition:background .2s ease;flex-shrink:0;}
.toggle-bolita{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s ease;box-shadow:0 1px 2px rgba(0,0,0,.2);}
.gf-toggle input:checked + .toggle-pista{background:var(--gf-verde);}
.gf-toggle input:checked + .toggle-pista .toggle-bolita{transform:translateX(18px);}
.gf-toggle input:focus-visible + .toggle-pista{outline:2px solid var(--gf-verde-hondo);outline-offset:2px;}

/* Resultado (gap) */
.gf-resultado{
  display:flex;align-items:center;gap:8px;
  background:var(--gf-carta);border:1px solid var(--gf-linea);border-radius:18px;
  padding:24px 28px;margin-bottom:18px;
  box-shadow:0 1px 2px rgba(20,32,27,.04),0 18px 40px rgba(20,32,27,.06);
}
.res-principal{display:flex;flex-direction:column;gap:5px;flex:1;}
.res-label{font-size:.82rem;color:var(--gf-musgo);}
.res-cifra{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:2.4rem;line-height:1;letter-spacing:-.03em;}
.res-sub{font-size:.8rem;color:var(--gf-musgo);}
.res-sep{width:1px;align-self:stretch;background:var(--gf-linea);margin:4px 24px;}
.res-secundario{display:flex;flex-direction:column;gap:14px;}
.res-mini{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;min-width:200px;}
.mini-punto{width:10px;height:10px;border-radius:3px;}
.punto-ingreso{background:var(--gf-verde);}
.punto-gasto{background:var(--gf-clay);}
.mini-label{font-size:.86rem;color:var(--gf-musgo);}
.mini-cifra{font-family:'IBM Plex Mono',monospace;font-weight:500;font-size:1rem;}
.signo-positivo{color:var(--gf-verde-hondo);}
.signo-negativo{color:var(--gf-clay);}
.signo-neutro{color:var(--gf-tinta);}

/* Gráfica */
.gf-grafica{background:var(--gf-carta);border:1px solid var(--gf-linea);border-radius:18px;padding:22px;margin-bottom:18px;box-shadow:0 1px 2px rgba(20,32,27,.04);}
.gf-canvas-caja{position:relative;height:340px;}

/* Tabla de desglose */
.gf-tabla-caja{background:var(--gf-carta);border:1px solid var(--gf-linea);border-radius:18px;padding:22px 24px;box-shadow:0 1px 2px rgba(20,32,27,.04);}
.gf-tabla-titulo{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1.1rem;margin:0 0 14px;}
.gf-tabla-titulo span{color:var(--gf-musgo);font-weight:400;font-size:.92rem;}
.gf-tabla{width:100%;border-collapse:collapse;font-size:.9rem;}
.gf-tabla th{text-align:left;font-weight:600;color:var(--gf-musgo);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;padding:6px 10px;border-bottom:1px solid var(--gf-linea);}
.gf-tabla td{padding:8px 10px;border-bottom:1px solid #f0ece3;}
.col-num{text-align:right;}
.mono{font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums;}
.tabla-punto{display:inline-block;width:9px;height:9px;border-radius:2px;margin-right:9px;vertical-align:middle;}
.fila-grupo td{font-weight:600;color:var(--gf-tinta);background:var(--gf-papel);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;padding-top:10px;padding-bottom:6px;}
.fila-gap td{border-top:2px solid var(--gf-linea);border-bottom:none;padding-top:12px;}
.fila-gap td:first-child{color:var(--gf-verde-hondo);}

@media (max-width:640px){
  .gf-h1{font-size:2rem;}
  .gf-resultado{flex-direction:column;align-items:stretch;}
  .res-sep{width:auto;height:1px;margin:18px 0;}
  .gf-controles{flex-direction:column;align-items:stretch;}
  .gf-niveles{justify-content:center;}
  .col-ant{display:none!important;}
  .gf-canvas-caja{height:300px;}
}

/* ============================================================ */
/*  LIBRO MAYOR                                                 */
/* ============================================================ */
.lb {
  --lb-papel:#f6f4ef; --lb-tinta:#14201b; --lb-verde:#2f9e6f;
  --lb-verde-hondo:#1f7a53; --lb-clay:#c0563f; --lb-linea:#e6e1d8;
  --lb-musgo:#6f7a72; --lb-carta:#fffdf9;
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--lb-tinta); max-width:1040px; margin:0 auto;
}
.lb-cabecera{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px;}
.lb-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--lb-verde-hondo);margin:0 0 8px;}
.lb-h1{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:2.5rem;line-height:1.02;margin:0;letter-spacing:-.025em;}
.lb-lede{color:var(--lb-musgo);margin:10px 0 0;font-size:1rem;}
.lb-volver{color:var(--lb-musgo);text-decoration:none;font-size:.9rem;white-space:nowrap;padding-top:8px;}
.lb-volver:hover{color:var(--lb-tinta);}

/* Filtros */
.lb-filtros{
  display:flex;flex-wrap:wrap;align-items:flex-end;gap:14px;
  background:var(--lb-carta);border:1px solid var(--lb-linea);
  border-radius:14px;padding:16px 18px;margin-bottom:20px;
}
.filtro-campo{display:flex;flex-direction:column;gap:5px;}
.filtro-campo label{font-size:.76rem;font-weight:600;color:var(--lb-musgo);}
.filtro-campo input,.filtro-campo select{
  padding:8px 11px;border:1px solid var(--lb-linea);border-radius:9px;
  font-size:.9rem;font-family:inherit;background:#fff;color:var(--lb-tinta);
}
.filtro-campo input:focus,.filtro-campo select:focus{outline:2px solid var(--lb-verde);border-color:transparent;}
.filtro-buscar{flex:1;min-width:160px;}
.filtro-buscar input{width:100%;box-sizing:border-box;}
.filtro-aplicar{
  padding:9px 20px;border:none;border-radius:9px;background:var(--lb-verde);
  color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit;
}
.filtro-aplicar:hover{background:var(--lb-verde-hondo);}

/* Resumen */
.lb-resumen{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:var(--lb-linea);border:1px solid var(--lb-linea);
  border-radius:14px;overflow:hidden;margin-bottom:12px;
}
.rsm{background:var(--lb-carta);padding:16px 18px;display:flex;flex-direction:column;gap:4px;}
.rsm-label{font-size:.74rem;color:var(--lb-musgo);}
.rsm-cifra{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:1.15rem;letter-spacing:-.02em;}
.rsm-nota{font-size:.66rem;color:var(--lb-musgo);font-style:italic;}
.rsm-ingreso .rsm-cifra{color:var(--lb-verde-hondo);}
.rsm-resultado{background:var(--lb-papel);}
.signo-positivo{color:var(--lb-verde-hondo);}
.signo-negativo{color:var(--lb-clay);}

.lb-aviso{font-size:.8rem;color:var(--lb-musgo);margin:0 0 22px;line-height:1.5;}
.lb-aviso a{color:var(--lb-verde-hondo);}

/* Tabla */
.lb-tabla-scroll{background:var(--lb-carta);border:1px solid var(--lb-linea);border-radius:14px;}
.lb-tabla{width:100%;border-collapse:collapse;font-size:.8rem;table-layout:auto;}
.lb-tabla th{
  text-align:left;font-weight:600;color:var(--lb-musgo);font-size:.72rem;
  text-transform:uppercase;letter-spacing:.04em;padding:12px 14px;
  border-bottom:1px solid var(--lb-linea);white-space:nowrap;position:sticky;top:0;background:var(--lb-carta);
}
.lb-tabla td{padding:8px 8px;border-bottom:1px solid #f0ece3;white-space:nowrap;}
.lb-tabla tr:last-child td{border-bottom:none;}
.col-num{text-align:right;}
.mono{font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums;}
.suave{color:var(--lb-musgo);}
.celda-fecha{color:var(--lb-musgo);font-family:'IBM Plex Mono',monospace;font-size:.8rem;}
.celda-concepto{font-weight:600;}
.fila-gasto_fijo{background:rgba(192,86,63,.035);}
.tipo-badge{font-size:.68rem;font-weight:600;padding:3px 9px;border-radius:20px;white-space:nowrap;}
.badge-ingreso{background:rgba(47,158,111,.13);color:var(--lb-verde-hondo);}
.badge-gasto_fijo{background:rgba(192,86,63,.13);color:var(--lb-clay);}

/* Pie y paginación */
.lb-pie{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:16px;flex-wrap:wrap;}
.lb-conteo{font-size:.84rem;color:var(--lb-musgo);}
.lb-paginacion{display:flex;align-items:center;gap:14px;}
.lb-paginacion .pag-btn{padding:7px 14px;border-radius:9px;text-decoration:none;font-size:.86rem;font-weight:500;background:var(--lb-carta);border:1px solid var(--lb-linea);color:var(--lb-tinta);}
.lb-paginacion .pag-btn:hover{border-color:var(--lb-verde);}
.lb-paginacion .pag-off{opacity:.4;pointer-events:none;}
.lb-paginacion .pag-info{font-family:'IBM Plex Mono',monospace;font-size:.8rem;color:var(--lb-musgo);}

.lb-vacio{padding:40px;text-align:center;color:var(--lb-musgo);background:var(--lb-carta);border:1px dashed var(--lb-linea);border-radius:14px;}

@media (max-width:760px){
  .lb-h1{font-size:2rem;}
  .lb-resumen{grid-template-columns:repeat(2,1fr);}
  .lb-filtros{flex-direction:column;align-items:stretch;}
}

/* Entrada manual en el libro mayor */
.lb-nueva {
  background: var(--lb-carta, #fffdf9);
  border: 1px solid var(--lb-linea, #e6e1d8);
  border-radius: 14px; padding: 20px 22px; margin-bottom: 20px;
}
.lb-nueva-titulo {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 1.05rem; font-weight: 600; margin: 0 0 16px;
}
.lb-form { width: 100%; }
.lbf-fila {
  display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end;
}
.lbf-campo {
  display: flex; flex-direction: column; gap: 5px;
  font-size: .85rem; font-weight: 600;
}
.lbf-tipo   { min-width: 130px; }
.lbf-concepto { flex: 2; min-width: 160px; }
.lbf-importe { min-width: 110px; }
.lbf-nota { flex: 1; min-width: 140px; }
.lbf-enviar { min-width: 90px; }
.lbf-campo input, .lbf-campo select {
  padding: 9px 11px; border: 1px solid var(--lb-linea, #e6e1d8);
  border-radius: 9px; font-size: .9rem; font-family: inherit;
  background: #fff;
}
.lbf-campo input:focus, .lbf-campo select:focus {
  outline: 2px solid var(--pd-verde, #2f9e6f); border-color: transparent;
}
.lbf-guardar { padding: 9px 18px; width: 100%; }

/* Badge de tipo manual en la tabla */
.badge-ingreso { background: #eafaf1; color: #1e6e42; }
.badge-gasto_fijo { background: #fef3ec; color: #8a4a1a; }
.fila-gasto_fijo { background: #fdfaf6; }


/* ============================================================ */
/*  CONFIGURACIÓN (topes, reloj)                               */
/* ============================================================ */
.cfg {
  --cfg-tinta:#14201b; --cfg-verde:#2f9e6f; --cfg-verde-hondo:#1f7a53;
  --cfg-linea:#e6e1d8; --cfg-musgo:#6f7a72; --cfg-carta:#fffdf9;
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--cfg-tinta); max-width:640px; margin:0 auto;
}
.cfg-cabecera{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:26px;}
.cfg-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cfg-verde-hondo);margin:0 0 8px;}
.cfg-h1{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:2.3rem;line-height:1.02;margin:0;letter-spacing:-.025em;}
.cfg-lede{color:var(--cfg-musgo);margin:10px 0 0;font-size:1rem;}
.cfg-volver{color:var(--cfg-musgo);text-decoration:none;font-size:.9rem;white-space:nowrap;padding-top:8px;}
.cfg-volver:hover{color:var(--cfg-tinta);}

.cfg-tarjeta{
  background:var(--cfg-carta);border:1px solid var(--cfg-linea);
  border-radius:18px;padding:28px;
  box-shadow:0 1px 2px rgba(20,32,27,.04),0 18px 40px rgba(20,32,27,.06);
}
.cfg-topes{display:flex;flex-direction:column;gap:18px;}
.cfg-tope{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.cfg-tope label{font-weight:600;font-size:1rem;}
.cfg-input-pct{display:flex;align-items:center;gap:8px;}
.cfg-input-pct input{
  width:110px;padding:11px 12px;border:1px solid var(--cfg-linea);
  border-radius:10px;font-size:1.05rem;font-family:'IBM Plex Mono',monospace;
  text-align:right;font-variant-numeric:tabular-nums;background:#fff;
}
.cfg-input-pct input:focus{outline:2px solid var(--cfg-verde);border-color:transparent;}
.cfg-pct{font-family:'IBM Plex Mono',monospace;color:var(--cfg-musgo);font-weight:600;}

.cfg-acciones{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:28px;flex-wrap:wrap;}
.cfg-acciones .boton-principal{padding:12px 24px;}
.cfg-enlace-sec{color:var(--cfg-musgo);text-decoration:none;font-size:.9rem;}
.cfg-enlace-sec:hover{color:var(--cfg-tinta);}
.cfg-nota{color:var(--cfg-musgo);font-size:.88rem;margin-top:20px;line-height:1.6;}

@media (max-width:540px){
  .cfg-h1{font-size:1.9rem;}
  .cfg-tope{flex-direction:row;}
}

/* Configuración del reloj */
.cfg-bloque-cab{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:6px;}
.cfg-bloque-titulo{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1.2rem;margin:0;}
.cfg-bloque-desc{color:var(--cfg-musgo);font-size:.9rem;margin:0 0 18px;}
.cfg-cadencia{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;}
.cfg-campo{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:600;color:var(--cfg-musgo);}
.cfg-campo select{
  padding:10px 12px;border:1px solid var(--cfg-linea);border-radius:10px;
  font-size:1rem;font-family:inherit;background:#fff;color:var(--cfg-tinta);min-width:120px;
}
.cfg-campo select:focus{outline:2px solid var(--cfg-verde);border-color:transparent;}

/* Switch activa/inactiva */
.cfg-switch{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-size:.86rem;color:var(--cfg-musgo);user-select:none;}
.cfg-switch input{position:absolute;opacity:0;width:0;height:0;}
.switch-pista{width:40px;height:23px;border-radius:23px;background:#d8d3c8;position:relative;transition:background .2s ease;}
.switch-bolita{position:absolute;top:3px;left:3px;width:17px;height:17px;border-radius:50%;background:#fff;transition:transform .2s ease;box-shadow:0 1px 2px rgba(0,0,0,.2);}
.cfg-switch input:checked + .switch-pista{background:var(--cfg-verde);}
.cfg-switch input:checked + .switch-pista .switch-bolita{transform:translateX(17px);}
.cfg-switch input:checked ~ .switch-txt{color:var(--cfg-verde-hondo);font-weight:600;}

/* Variación respecto al año anterior (color semántico) */
.var-buena{color:var(--gf-verde-hondo);font-weight:600;}
.var-mala{color:var(--gf-clay);font-weight:600;}
.var-neutro{color:var(--gf-musgo,#6f7a72);}

/* Voz de Pepito */
.voz-opciones{display:flex;flex-direction:column;gap:12px;}
.voz-opcion{
  display:block;border:1.5px solid var(--cfg-linea,#e6e1d8);border-radius:12px;
  padding:16px 18px;cursor:pointer;transition:border-color .15s ease,background .15s ease;
}
.voz-opcion:hover{border-color:var(--cfg-verde,#2f9e6f);}
.voz-opcion input{position:absolute;opacity:0;}
.voz-elegida{border-color:var(--cfg-verde,#2f9e6f);background:#f3faf6;}
.voz-opcion-nombre{display:block;font-weight:600;font-size:1.05rem;margin-bottom:6px;}
.voz-elegida .voz-opcion-nombre{color:var(--cfg-verde-hondo,#1f7a53);}
.voz-ejemplo{display:block;color:var(--cfg-musgo,#6f7a72);font-style:italic;font-size:.92rem;line-height:1.5;}
.voz-textarea{
  width:100%;box-sizing:border-box;padding:12px 14px;border:1px solid var(--cfg-linea,#e6e1d8);
  border-radius:10px;font-family:inherit;font-size:.95rem;line-height:1.5;resize:vertical;background:#fff;
}
.voz-textarea:focus{outline:2px solid var(--cfg-verde,#2f9e6f);border-color:transparent;}

/* ============================================================ */
/*  HOME — mosaicos por restaurante                            */
/* ============================================================ */
.home{
  --h-tinta:#14201b; --h-musgo:#6f7a72; --h-linea:#e6e1d8;
  --h-carta:#fffdf9; --h-verde-hondo:#1f7a53;
  max-width:880px; margin:0 auto;
  font-family:'Inter',system-ui,-apple-system,sans-serif; color:var(--h-tinta);
}
.home-saludo{
  font-family:'Bricolage Grotesque',sans-serif; font-weight:700;
  font-size:2.1rem; letter-spacing:-.025em; margin:0 0 28px;
}

.home-rest{ margin-bottom:40px; }
.home-rest + .home-rest{ border-top:1px solid var(--h-linea); padding-top:32px; }
.home-rest-cab{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap; margin-bottom:20px;
}
.home-rest-nombre{
  font-family:'Bricolage Grotesque',sans-serif; font-weight:600;
  font-size:1.55rem; letter-spacing:-.02em; margin:0;
}

/* Tira de estado de Telegram */
.tg-pill{
  font-size:.84rem; font-weight:600; padding:6px 13px; border-radius:20px;
  text-decoration:none; white-space:nowrap; transition:filter .15s ease;
}
.tg-pill:hover{ filter:brightness(.96); }
.tg-ok{ background:#e7f6ef; color:#1e6e42; }
.tg-warn{ background:#fdeede; color:#9a5a16; }

/* Eyebrow de sección */
.home-eyebrow{
  font-family:'IBM Plex Mono',monospace; font-size:.7rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--h-musgo); margin:0 0 12px;
}

/* Rejillas */
.home-grid{ display:grid; gap:14px; }
.home-grid--principal{ grid-template-columns:repeat(auto-fit,minmax(215px,1fr)); margin-bottom:26px; }
.home-grid--config{ grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); }

/* Mosaico base */
.home-tile{
  display:block; text-decoration:none; color:inherit;
  background:var(--h-carta); border:1px solid var(--h-linea);
  border-radius:16px; transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.home-tile:hover{
  transform:translateY(-3px);
  box-shadow:0 2px 4px rgba(20,32,27,.05), 0 16px 32px rgba(20,32,27,.09);
  border-color:transparent;
}

/* Mosaico grande (panel principal) */
.home-tile--big{ padding:22px; }
.home-ico{
  display:inline-flex; align-items:center; justify-content:center;
  width:46px; height:46px; border-radius:13px;
  background:var(--acc-bg); color:var(--acc); margin-bottom:16px;
}
.home-ico svg{ width:24px; height:24px; }
.home-tile-titulo{
  display:block; font-family:'Bricolage Grotesque',sans-serif;
  font-weight:600; font-size:1.18rem; letter-spacing:-.01em; margin-bottom:6px;
}
.home-tile-desc{ display:block; color:var(--h-musgo); font-size:.9rem; line-height:1.5; }

/* Mosaico pequeño (configuración) */
.home-tile--small{
  padding:16px 18px; display:flex; align-items:center; gap:13px;
}
.home-ico-mini{
  display:inline-flex; align-items:center; justify-content:center;
  width:38px; height:38px; border-radius:11px; flex-shrink:0;
  background:#f1efe9; color:var(--h-musgo);
}
.home-ico-mini svg{ width:20px; height:20px; }
.home-tile--small:hover .home-ico-mini{ color:var(--h-verde-hondo); background:#e9f4ee; }
.home-small-txt{ display:flex; flex-direction:column; gap:2px; }
.home-small-titulo{ font-weight:600; font-size:.98rem; }
.home-small-desc{ color:var(--h-musgo); font-size:.8rem; }

.home-vacio{
  background:var(--h-carta); border:1px solid var(--h-linea);
  border-radius:16px; padding:28px; color:var(--h-musgo);
}

@media (max-width:520px){
  .home-saludo{ font-size:1.7rem; }
  .home-rest-nombre{ font-size:1.3rem; }
}

/* Logo en cabecera */
.marca { display:flex; align-items:center; gap:10px; text-decoration:none; }
.marca-logo { height:36px; width:auto; display:block; }
.marca-texto { display:flex; align-items:baseline; gap:4px;
  font-family:'Bricolage Grotesque',sans-serif; font-weight:700;
  font-size:1.1rem; color:inherit; }
.marca-punto { opacity:.4; }

/* Logo en login */
.login-logo { text-align:center; margin-bottom:8px; }
.login-logo-img { height:110px; width:auto; }
