/* =========================
   ERP_SIAC — Hoja de estilos global
   Paleta: azul #0083b0  | acento #0ea5e9
   Tipografía: system-ui / Roboto
   ========================= */
:root{
  --azul:#0083b0;        /* color base */
  --brand:#0083b0;        /* primario */
  --accent:#0ea5e9;       /* acento */
  --ink:#0f172a;          /* texto principal */
  --muted:#64748b;        /* texto secundario */
  --line:#e2e8f0;         /* líneas */
  --bg:#f8fafc;           /* fondo app */
  --card:#ffffff;         /* tarjetas */
  --danger:#ef4444;       /* peligro */
  --shadow:0 8px 24px rgba(2,6,23,.06); /* sombra */
}

*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font:14px/1.45 system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial}
img{max-width:100%;display:block}

/* ====== Contenedor genérico ====== */
.container{max-width:1200px;margin:0 auto;padding:0 16px}

/* ====== Tarjetas, botones, inputs ====== */
.card{background:var(--card); border:1px solid var(--line);
  border-radius:14px; padding:16px; box-shadow:var(--shadow)}
.btn{display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:10px;border:1px solid var(--line);
  background:#fff;color:var(--ink);text-decoration:none;cursor:pointer}
.btn.primary{background:var(--brand-2);border-color:#0284c7;color:#fff}
.btn.outline{background:#fff;color:var(--brand);border:1px solid #cfe8f7}
.btn.warn{background:#fee2e2;border-color:#fecaca;color:#7f1d1d}
.input, .select, textarea{
  width:100%; padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fff
}
.label{display:block;font-weight:600;margin-bottom:6px;color:var(--mut)}
textarea{min-height:90px;resize:vertical}

/* ====== Alerts ====== */
.ok{border:1px solid #bbf7d0;background:#f0fdf4;color:#065f46;
  padding:10px 12px;border-radius:10px;margin-bottom:12px}
.err{border:1px solid #fecaca;background:#fef2f2;color:#7f1d1d;
  padding:10px 12px;border-radius:10px;margin-bottom:12px}

/* ====== Grids utilitarias ====== */
.grid{display:grid;gap:12px}
.top-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:1200px){ .top-grid{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:640px){  .top-grid{grid-template-columns:1fr} }

/* ====== Tabla genérica ====== */
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px dashed #eef3f8;text-align:left;vertical-align:middle}
.table thead th{font-size:12.5px;color:var(--mut);text-transform:uppercase;letter-spacing:.04em}

/* ====== Tabla con cuerpo desplazable y encabezado fijo ====== */
.table-wrap{overflow:auto;max-height:60vh;-webkit-overflow-scrolling:touch;border-radius:12px}
.items-table thead th{position:sticky;top:0;background:#fff;z-index:2}
.items-table td:last-child,.items-table th:last-child{width:44px}

/* Inputs compactos dentro de las filas */
.items-table input[type="text"],
.items-table input[type="number"],
.items-table input[type="date"]{padding:8px 10px;border-radius:8px;width:100%}

/* ====== Barra de totales ====== */
.totbar{display:flex;justify-content:flex-end;align-items:center;gap:12px;
  margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.totbar .monto{font-weight:800;font-size:18px}

/* ====== Modal genérico ====== */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);
  display:none;align-items:center;justify-content:center;padding:20px;z-index:60}
.modal.show{display:flex}
.modal-box{background:#fff;border:1px solid var(--line);border-radius:14px;
  max-width:640px;width:100%;padding:16px}
.modal-grid{display:grid;gap:12px;grid-template-columns:1fr 1fr}
@media (max-width:640px){ .modal-grid{grid-template-columns:1fr} }

/* ====== Sugerencias (autocomplete) ====== */
.suggest{position:fixed;left:0;top:0;display:none;z-index:80;
  background:#fff;border:1px solid var(--line);border-radius:10px;
  box-shadow:0 12px 30px rgba(0,0,0,.12);max-height:320px;overflow:auto;
  width:min(420px,96vw)}
.suggest-item{padding:9px 12px;cursor:pointer;line-height:1.25}
.suggest-item:hover,.suggest-item.active{background:#f1f5f9}
.suggest .code{font-size:12px;color:var(--mut)}
.suggest .extra{font-size:12px;color:#065f46}

/* ====== Cabecera simple ====== */
.header{background:linear-gradient(135deg,#0099c7,#006d92);color:#fff}
.header .container{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.header strong{font-weight:700}

/* ====== Secciones scroll con barra propia (para paneles como “alerta bajo stock” y “entradas recientes”) ====== */
.panel-scroll{max-height:420px;overflow:auto;-webkit-overflow-scrolling:touch;border-radius:12px}
.panel-title{font-weight:700;margin:0 0 8px 0}

/* ====== Formularios de inventario: aplicar look sin cambiar lógica ====== */
.ui-form .items-card{border:1px solid var(--line);background:var(--card);
  border-radius:14px;padding:12px;box-shadow:var(--shadow)}
/* Botones principales coherentes */
.ui-form .btn-primary{background:var(--brand-2);border-color:#0284c7;color:#fff}
.ui-form .btn-secondary{background:#fff;border:1px solid var(--line);color:var(--ink)}

/* ====== Ajustes finos móvil ====== */
@media (max-width:560px){
  .btn, .btn.primary, .btn.outline{padding:10px 12px}
  .totbar{justify-content:space-between}
}

/* ====== Utilitarios rápidos ====== */
.mt-1{margin-top:4px} .mt-2{margin-top:8px} .mt-3{margin-top:12px}
.mb-1{margin-bottom:4px} .mb-2{margin-bottom:8px} .mb-3{margin-bottom:12px}
.flex{display:flex;gap:8px;align-items:center} .wrap{flex-wrap:wrap}
.right{text-align:right} .muted{color:var(--mut)}
.topbar{background:var(--azul);color:#fff;padding:14px 22px;display:flex;align-items:center;justify-content:space-between}
.topbar a{background:#fff;color:var(--azul);padding:8px 14px;border-radius:10px;text-decoration:none}
.wrap{max-width:1100px;margin:26px auto;padding:0 16px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid #e9eef3;border-radius:16px;box-shadow:0 6px 22px rgba(2,84,100,.08);padding:18px}

.logo-global{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    padding:4px 0;
}
.logo-global img{
    max-height:60px;
    width:auto;
}
@media print{
    .logo-global img{max-height:70px!important;}
}

  :root{
    --teal:#0ea5b9;
    --card-bg:#fff;
    --card-br:#e9eef3;
    --card-shadow:0 6px 22px rgba(2,84,100,.08);
    --text:#163042;
    --muted:#5f7285;
    --pill-bg:#f2f8fb;
 }
 *{box-sizing:border-box}
  body{margin:100;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f5f9fc;color:var(--text);}
  .topbar{background:var(--teal);color:#fff;padding:14px 22px;display:flex;align-items:center;justify-content:space-between}
.topbar .brand{font-weight:700}
  .topbar a{background:#fff;color:var(--teal);text-decoration:none;padding:8px 14px;border-radius:10px}
.wrap{max-width:1100px;margin:26px auto;padding:0 16px}
  h1{font-size:22px;margin:0 0 16px}
/* ==== PARCHE MINIMO DE CONTRASTE Y VARS (agregar al FINAL del archivo) ==== */

/* 2.1: Variable faltante usada en .topbar */
:root{
  --azul: #0083b0; /* armoniza con --brand */
}

/* 2.2: Links y botones dentro de barras/headers oscuros */
.header a, .topbar a {
  color:#fff;
}
.header .btn, .topbar .btn {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.25);
  color:#fff;
}
.header .btn:hover, .topbar .btn:hover {
  background: rgba(255,255,255,.20);
}

/* 2.3: Variante de botón para fondos oscuros (por si la necesitas) */
.btn.inverse{
  background:#111827; border-color:#1f2937; color:#fff;
}
.btn.inverse:hover{ filter:brightness(1.05); }

/* 2.4: Aumentar contraste de .btn.primary en general */
.btn.primary{
  /* ya definías color blanco, reforzamos accesibilidad */
  color:#fff; filter: saturate(1.05) brightness(1.02);
}

/* 2.5: Asegurar que el fallback de logo tenga buen aspecto */
#siac-logo-fallback.hidden{ display:none; }
#siac-logo-fallback strong{ font-size:18px; }

/* 2.6: Ajuste de densidad del header reutilizable */
.siac-logo-header .muted{ color: #e2e8f0; font-weight:500; }
.contenedor-produccion {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

/* HEADER */
.resumen-top {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px,1fr));
    gap: 15px;
}

.card {
    background: #fff;
    padding: 15px;
    border-radius: 10px;
    box-shadow: 0 2px 6px rgba(0,0,0,.1);
}

/* CICLO */
.ciclo-productivo .flujo {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

.bloque {
    background: #fff;
    padding: 15px;
    border-radius: 10px;
    flex: 1;
    min-width: 180px;
    text-align: center;
}

.bloque.activo {
    border: 2px solid #0083b0;
}

/* ANALISIS */
.grid-analisis,
.grid-pradera,
.grid-alertas,
.grid-procesos {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px,1fr));
    gap: 15px;
}

/* ALERTAS */
.alerta {
    background: #fff;
    padding: 10px;
    border-left: 4px solid #f39c12;
    border-radius: 6px;
}

/* BOTONES */
.btn {
    display: block;
    padding: 12px;
    background: #0083b0;
    color: #fff;
    text-align: center;
    border-radius: 6px;
    text-decoration: none;
}


