/* =============================================================
   SAN JOSÉ AGRO — Estilos extendidos del proyecto (template NOWA)
   Equivalente a assets/css/extras/style_extendido.css del template anterior.
   Aquí van TODOS los overrides y estilos custom del proyecto.
   El archivo style.css (del template) NO debe modificarse.
   ============================================================= */

/* ===== Global loader por encima de modales (BS5 modal z-index 1055) ===== */
#global-loader {
    z-index: 100000 !important;
}

/* ===== Light Button morado (no incluido por NOWA) ===== */
.btn-purple-light {
    color: #ad4ffa !important;
    background-color: rgba(173, 79, 250, 0.2);
    border-color: rgba(173, 79, 250, 0.2);
}

.btn-purple-light:hover {
    color: #fff !important;
    background-color: #ad4ffa !important;
    border-color: #ad4ffa;
}

.btn-purple-light:focus,
.btn-purple-light.focus {
    box-shadow: 0 0 0 0.2rem rgba(173, 79, 250, 0.2);
}

/* ===== Variables de la paleta San José Agro ===== */
:root {
    --sja-navy:             #031B37;
    --sja-navy-deep:        #021A36;
    --sja-menu-active:      #142B23;
    --sja-text-title:       #1C2944;
    --sja-text-label:       #383F52;
    --sja-text-input:       #747883;
    --sja-text-placeholder: #AFAFB4;
    --sja-text-sidebar:     #929EB0;
    --sja-bg-app:           #F3F3F3;
    --sja-bg-topbar:        #F9F9F9;
    --sja-bg-card:          #FDFDFD;
    --sja-bg-input:         #FEFEFE;
    --sja-border-soft:      #E8E8E8;
    --sja-border-2:         #EEEEEE;
    --sja-green:            #5E9226;
    --sja-green-accent:     #5D8D1D;
    --sja-btn-primary:      #95AB30;
    --sja-btn-primary-hover:#5D8D1D;
    --sja-chip-na:          #E5FFD3;
    --sja-bg-decorative:    #EEF5E3;
    --sja-lima:             #C6D600;
    --sja-outline-border:   #738F52;
    --sja-btn-icon:         #FFC107;
}

/* ===== Sidebar: item activo en menú de 2 niveles (ej: Bodega) ===== */
.slide-item.active {
    color: #ffffff !important;
    background-color: #95ab30 !important;
    border-radius: 8px;
}

.slide-item.active:hover {
    background-color: #7e9129 !important;
    color: #ffffff !important;
}

/* ===== Overrides globales de color de botones sobre NOWA ===== */

/* btn-primary → #95ab30 */
.btn-primary {
    background-color: #95AB30 !important;
    border-color:     #95AB30 !important;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: #5D8D1D !important;
    border-color:     #5D8D1D !important;
}

/* btn-success → verde principal #5E9226 */
.btn-success {
    background-color: #5E9226 !important;
    border-color:     #5E9226 !important;
}
.btn-success:hover,
.btn-success:focus,
.btn-success:active {
    background-color: #5D8D1D !important;
    border-color:     #5D8D1D !important;
}

/* btn-warning → amarillo #FFC107 */
.btn-warning {
    background-color: #FFC107 !important;
    border-color:     #FFC107 !important;
    color: #fff !important;
}
.btn-warning:hover,
.btn-warning:focus,
.btn-warning:active { color: #fff !important; }

/* btn-dark → navy profundo #021A36 */
.btn-dark {
    background-color: #021A36 !important;
    border-color:     #021A36 !important;
}
.btn-dark:hover,
.btn-dark:focus,
.btn-dark:active {
    background-color: #031B37 !important;
    border-color:     #031B37 !important;
}

/* btn-outline-primary → borde verde outline */
.btn-outline-primary {
    color:        #738F52 !important;
    border-color: #738F52 !important;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active {
    background-color: #738F52 !important;
    border-color:     #738F52 !important;
    color: #fff !important;
}

/* btn-success-light → verde SJA #69913A */
.btn-success-light {
    color: #69913A !important;
    background-color: rgba(105, 145, 58, 0.15);
    border-color: rgba(105, 145, 58, 0.15);
}
.btn-success-light:hover {
    color: #fff !important;
    background-color: #69913A !important;
    border-color: #69913A !important;
}
.btn-success-light:focus,
.btn-success-light.focus {
    box-shadow: 0 0 0 0.2rem rgba(105, 145, 58, 0.3);
}

/* ===== Select2: forzar ancho 100% para que respete el contenedor ===== */
.select2-container {
    width: 100% !important;
}
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    min-height: calc(1.5em + 0.5rem + 2px);
}

/* ===== Modal Editar: alinear inputs al fondo de cada columna =====
   Las etiquetas con distinto número de líneas ya no descuadran los campos. */
#mdlEditar form .row > [class*="col-"] {
    display: flex;
    flex-direction: column;
}
#mdlEditar form .row > [class*="col-"] .form-label {
    flex: 1 1 auto;
    margin-bottom: 0.25rem;
}
#mdlEditar form .row > [class*="col-"] .form-control,
#mdlEditar form .row > [class*="col-"] .select2-container {
    margin-top: auto;
}

/* ===== SweetAlert v2 por encima del modal Nowa =====
   El tema Nowa fuerza .modal { z-index: 99999999 } (style.css), muy por encima
   del z-index nativo de SweetAlert v2 (10000). Lo elevamos por encima del modal. */
.swal-overlay {
    z-index: 999999999 !important;
}


/* =============================================================================
   DASHBOARD NUEVO (San Jos� Agro) � fusionado desde assets/css/extras/dashboard_nuevo.css
   ============================================================================= */
/* =============================================================================
   Dashboard Nuevo — San José Agro
   Archivo: assets/css/extras/dashboard_nuevo.css

   Convenciones:
   - Variables CSS en :root para paleta corporativa y semántica.
   - Mobile-first con breakpoints 768px y 1280px.
   - Clases prefijadas con .sja- para evitar colisión con Bootstrap.
   - Sin gradientes pesados ni sombras excesivas (flat-modern).
============================================================================= */

/* ── Variables ─────────────────────────────────────────────────────────── */
:root {
    /* Paleta corporativa */
    --sja-green-primary: #5a7d3a;
    --sja-green-light:   #7aaa4f;
    --sja-teal:          #1d9e75;
    --sja-blue:          #378add;
    --sja-amber:         #ef9f27;
    --sja-coral:         #d85a30;
    --sja-purple:        #534ab7;

    /* Superficies */
    --bg-card:    #ffffff;
    --bg-surface: #f4f5f0;
    --bg-page:    #eef0ea;

    /* Textos */
    --text-primary:   #2c2c2a;
    --text-secondary: #5f5e5a;
    --text-tertiary:  #888780;

    /* Bordes */
    --border:        rgba(0, 0, 0, 0.09);
    --border-strong: rgba(0, 0, 0, 0.18);

    /* Semántica */
    --success-bg:   #e1f5ee;
    --success-text: #0f6e56;
    --warning-bg:   #faeeda;
    --warning-text: #854f0b;
    --danger-bg:    #fcebeb;
    --danger-text:  #a32d2d;
    --info-bg:      #e8f2fc;
    --info-text:    #1a5fa8;
    --neutral-bg:   #f0f0ec;
    --neutral-text: #5f5e5a;

    /* Radios y espaciado */
    --radius-card:  10px;
    --radius-badge: 20px;
    --gap-md:       16px;
    --gap-lg:       20px;

    /* Transición */
    --transition: 0.2s ease;
}

/* ── Layout raíz ──────────────────────────────────────────────────────── */
.sja-dashboard {
    padding: 20px 24px 32px;
    min-height: calc(100vh - 80px);
    color: var(--text-primary);
    font-family: 'Open Sans', sans-serif;
}

/* ── Zona 1: Encabezado + filtros ─────────────────────────────────────── */
.sja-page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--gap-md);
    margin-bottom: var(--gap-lg);
}

.sja-title {
    font-size: 22px;
    font-weight: 700;
    color: var(--sja-green-primary);
    margin: 0 0 4px;
}

.sja-subtitle {
    font-size: 13px;
    color: var(--text-secondary);
}

.sja-filters {
    display: flex;
    align-items: flex-end;
    gap: 12px;
    flex-wrap: wrap;
}

.sja-filter-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 160px;
}

.sja-filter-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0;
}

.sja-select {
    border: 1px solid var(--border-strong);
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 13px;
    color: var(--text-primary);
    background: var(--bg-card);
    outline: none;
    cursor: pointer;
    transition: border-color var(--transition);
    width: 100%;
}

.sja-select:focus {
    border-color: var(--sja-green-primary);
    box-shadow: 0 0 0 3px rgba(90, 125, 58, 0.12);
}

.sja-daterange-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    border: 1px solid var(--border-strong);
    border-radius: 6px;
    padding: 6px 10px;
    height: 33px;
    font-size: 13px;
    color: var(--text-primary);
    background: var(--bg-card);
    cursor: pointer;
    transition: border-color var(--transition);
}

.sja-daterange-btn:hover {
    border-color: var(--sja-green-primary);
}

.sja-daterange-btn span {
    flex: 1;
    white-space: nowrap;
}

.sja-daterange-caret {
    margin-left: auto;
    color: var(--text-secondary);
}

/* ── Zona 2: KPI Grid ─────────────────────────────────────────────────── */
.sja-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--gap-md);
    margin-bottom: var(--gap-lg);
}

.sja-kpi-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-card);
    padding: 18px 16px 16px;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    transition: box-shadow var(--transition), transform var(--transition);
    min-width: 0;
    position: relative;
}

.sja-kpi-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.10);
    transform: translateY(-1px);
}

.sja-kpi-card--todo {
    opacity: 0.75;
    border-style: dashed;
}

.kpi-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
    color: #fff;
}

.kpi-icon--teal   { background: var(--sja-teal); }
.kpi-icon--blue   { background: var(--sja-blue); }
.kpi-icon--amber  { background: var(--sja-amber); }
.kpi-icon--coral  { background: var(--sja-coral); }
.kpi-icon--purple { background: var(--sja-purple); }
.kpi-icon--green  { background: var(--sja-green-primary); }

.kpi-body {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
    flex: 1;
}

.kpi-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    min-width: 0;
}

.kpi-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex-shrink: 1;
    min-width: 0;
}

.kpi-value-row {
    display: flex;
    align-items: baseline;
    gap: 4px;
    flex-wrap: wrap;
}

.kpi-value {
    font-size: 26px;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.1;
}

.kpi-unit {
    font-size: 12px;
    color: var(--text-tertiary);
    font-weight: 400;
}

.kpi-delta {
    font-size: 12px;
    font-weight: 600;
    border-radius: var(--radius-badge);
    padding: 2px 8px;
    display: inline-block;
    margin-top: 4px;
}

.kpi-delta--up      { background: var(--success-bg); color: var(--success-text); }
.kpi-delta--down    { background: var(--danger-bg);  color: var(--danger-text); }
.kpi-delta--neutral { background: var(--neutral-bg); color: var(--neutral-text); }

.kpi-ant {
    display: block;
    font-size: 11px;
    color: var(--text-muted, #8a8d91);
    margin-top: 3px;
}

/* ── Tooltip desglose tipo cosecha ──────────────────────────────────────── */
.kpi-breakdown-tooltip {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-card, #fff);
    border: 1px solid var(--border-color, #e0e3e7);
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0,0,0,.13);
    padding: 10px 14px;
    min-width: 190px;
    z-index: 120;
    white-space: nowrap;
    pointer-events: none;
}

#kpiDespacho:hover,
#kpiDespacho.kpi-breakdown--open {
    z-index: 200;
}

#kpiDespacho:hover .kpi-breakdown-tooltip,
#kpiDespacho.kpi-breakdown--open .kpi-breakdown-tooltip {
    display: block;
    z-index: 9999;
}

/* Indicar que el trigger es tappeable */
#kpiDespacho .kpi-ant,
#kpiMO .kpi-ant,
#kpiRendimiento .kpi-ant {
    cursor: pointer;
    user-select: none;
}

#kpiMO:hover,
#kpiMO.kpi-breakdown--open {
    z-index: 200;
}

#kpiMO:hover .kpi-breakdown-tooltip,
#kpiMO.kpi-breakdown--open .kpi-breakdown-tooltip {
    display: block;
    z-index: 9999;
}

#kpiRendimiento:hover,
#kpiRendimiento.kpi-breakdown--open {
    z-index: 200;
}

#kpiRendimiento:hover .kpi-breakdown-tooltip,
#kpiRendimiento.kpi-breakdown--open .kpi-breakdown-tooltip {
    display: block;
    z-index: 9999;
}

.kpi-breakdown-arrow {
    position: absolute;
    top: -6px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
    width: 10px;
    height: 10px;
    background: var(--bg-card, #fff);
    border-left: 1px solid var(--border-color, #e0e3e7);
    border-top: 1px solid var(--border-color, #e0e3e7);
}

.kpi-breakdown-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    font-size: 12px;
    padding: 3px 0;
    color: var(--text-body, #3d3f44);
    border-bottom: 1px solid var(--border-color, #f0f2f5);
}

.kpi-breakdown-row:last-child { border-bottom: none; }

.kpi-breakdown-row .bd-nombre { font-weight: 500; }

.kpi-breakdown-row .bd-vals {
    display: flex;
    gap: 8px;
    color: var(--text-muted, #8a8d91);
}

/* ── Zona 3: Banda de alertas ─────────────────────────────────────────── */
.sja-alert-band {
    background: var(--warning-bg);
    border: 1px solid rgba(239, 159, 39, 0.4);
    border-left: 4px solid var(--sja-amber);
    border-radius: var(--radius-card);
    padding: 14px 18px;
    margin-bottom: var(--gap-lg);
}

.alert-band-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--warning-text);
    margin-bottom: 10px;
}

.alert-count {
    background: var(--sja-amber);
    color: #fff;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    margin-left: 2px;
}

.alert-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.alert-item {
    font-size: 12px;
    color: var(--warning-text);
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(239, 159, 39, 0.3);
    border-radius: 6px;
    padding: 5px 12px;
}

.alert-item a {
    color: var(--warning-text);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.alert-item a:hover { color: var(--sja-coral); }

/* ── Paneles 2-col ────────────────────────────────────────────────────── */
.sja-panel-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gap-lg);
    margin-bottom: var(--gap-lg);
}

.sja-panel {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-card);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.sja-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    padding: 14px 18px 12px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-surface);
}

.panel-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--sja-green-primary);
    display: flex;
    align-items: center;
    gap: 6px;
}

.panel-subtitle {
    font-size: 11px;
    color: var(--text-tertiary);
}

/* Badge coloreado de especie — aparece en headers de paneles y KPI cards */
.sja-especie-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 9px;
    border-radius: 20px;
    font-size: 10px;
    font-weight: 600;
    color: #fff;
    letter-spacing: 0.3px;
    line-height: 1.6;
}

.kpi-especie-badge {
    flex-shrink: 0;
}

.panel-filters-inline {
    display: flex;
    gap: 6px;
    align-items: center;
    flex-wrap: wrap;
}

.sja-select-sm {
    border: 1px solid var(--border-strong);
    border-radius: 5px;
    padding: 4px 8px;
    font-size: 12px;
    color: var(--text-primary);
    background: var(--bg-card);
    outline: none;
    cursor: pointer;
}

.sja-select-sm:focus {
    border-color: var(--sja-green-primary);
}

.sja-panel-body {
    padding: 16px 18px;
    flex: 1;
}

/* ── Panel A: Rendimiento por especie ─────────────────────────────────── */
.rend-especie-row {
    margin-bottom: 14px;
}

.rend-especie-row:last-child {
    margin-bottom: 0;
}

.rend-especie-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 5px;
}

.rend-especie-nombre {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
}

.rend-especie-meta {
    font-size: 11px;
    color: var(--text-secondary);
}

.rend-especie-pct {
    font-size: 12px;
    font-weight: 700;
    min-width: 42px;
    text-align: right;
}

.sja-progress-track {
    background: #e8e8e4;
    border-radius: var(--radius-badge);
    height: 8px;
    overflow: hidden;
}

.sja-progress-bar {
    height: 100%;
    border-radius: var(--radius-badge);
    transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.sja-progress-bar--green  { background: var(--sja-teal); }
.sja-progress-bar--yellow { background: var(--sja-amber); }
.sja-progress-bar--red    { background: var(--sja-coral); }
.sja-progress-bar--dynamic { background: var(--sja-blue); }

/* ── Panel C: Top labores ─────────────────────────────────────────────── */
.labores-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.labores-table th {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0 8px 8px;
    border-bottom: 1px solid var(--border);
    text-align: left;
}

.labores-table th:last-child,
.labores-table td:last-child {
    text-align: right;
}

.labores-table td {
    padding: 8px 8px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
    color: var(--text-primary);
}

.labores-table tr:last-child td {
    border-bottom: none;
}

.labor-bar-cell {
    min-width: 80px;
}

.labor-mini-bar {
    height: 6px;
    border-radius: 3px;
    background: var(--sja-teal);
    transition: width 0.5s ease;
}

/* ── Panel D: Órdenes ─────────────────────────────────────────────────── */
.ordenes-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.ordenes-metric {
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 14px 12px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.ordenes-metric--success { border-color: rgba(29, 158, 117, 0.3); background: var(--success-bg); }
.ordenes-metric--warning { border-color: rgba(239, 159, 39, 0.3); background: var(--warning-bg); }
.ordenes-metric--info    { border-color: rgba(55, 138, 221, 0.3); background: var(--info-bg); }

.ordenes-metric-val {
    font-size: 28px;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1;
}

.ordenes-metric--success .ordenes-metric-val { color: var(--success-text); }
.ordenes-metric--warning .ordenes-metric-val { color: var(--warning-text); }
.ordenes-metric--info    .ordenes-metric-val { color: var(--info-text); }

.ordenes-metric-lbl {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

/* ── Panel D: Tipo-badge y divisor de órdenes ────────────────────────── */
.ordenes-tipo-header {
    margin-bottom: 10px;
}

.ordenes-tipo-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 20px;
}

.ordenes-tipo-badge--fito {
    background: rgba(220, 80, 60, 0.12);
    color: #c0392b;
    border: 1px solid rgba(220, 80, 60, 0.3);
}

.ordenes-tipo-badge--fert {
    background: rgba(55, 138, 221, 0.12);
    color: var(--info-text, #1a6eb5);
    border: 1px solid rgba(55, 138, 221, 0.3);
}

.ordenes-divider {
    border: none;
    border-top: 1px dashed var(--border);
    margin: 14px 0;
}

.ordenes-progress-wrap {
    margin-top: 8px;
    margin-bottom: 4px;
}

/* ── Panel F: Combustible ─────────────────────────────────────────────── */
.combustible-total {
    text-align: center;
    padding: 8px 0 16px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 16px;
}

.combustible-val {
    font-size: 40px;
    font-weight: 700;
    color: var(--sja-amber);
    line-height: 1;
}

.combustible-unit {
    font-size: 14px;
    color: var(--text-secondary);
    display: block;
    margin-top: 4px;
}

.combustible-tipo-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
    font-size: 13px;
}

.combustible-tipo-row:last-child {
    border-bottom: none;
}

.combustible-tipo-nombre {
    color: var(--text-primary);
    font-weight: 500;
}

.combustible-tipo-litros {
    font-weight: 700;
    color: var(--sja-amber);
}

/* ── Skeleton loader ──────────────────────────────────────────────────── */
.sja-skeleton-loader {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 4px 0;
}

.sja-skeleton-bar {
    height: 16px;
    background: linear-gradient(90deg, #ebebeb 25%, #f5f5f5 50%, #ebebeb 75%);
    background-size: 200% 100%;
    border-radius: 4px;
}

/* =============================================================================
   Footer — accesos directos a otras apps de la suite
============================================================================= */

.sja-suite-footer {
    margin-top: 32px;
    padding: 24px 0 8px;
    border-top: 1px solid var(--border);
}

.sja-suite-footer__title {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-tertiary);
    margin: 0 0 14px;
}

.sja-suite-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

@media (max-width: 768px) {
    .sja-suite-grid {
        grid-template-columns: repeat(1, 1fr);
    }
}

.sja-suite-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    text-decoration: none;
    color: var(--text-primary);
    transition: box-shadow 0.18s, transform 0.18s, border-color 0.18s;
}

.sja-suite-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.10);
    transform: translateY(-2px);
    border-color: var(--border-strong);
    text-decoration: none;
    color: var(--text-primary);
}

.sja-suite-card:focus-visible {
    outline: 2px solid var(--sja-teal);
    outline-offset: 2px;
}

.sja-suite-card__icon {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: #fff;
}

.sja-suite-card__icon--green  { background: var(--sja-green-primary); }
.sja-suite-card__icon--teal   { background: var(--sja-teal); }
.sja-suite-card__icon--blue   { background: var(--sja-blue); }
.sja-suite-card__icon--amber  { background: var(--sja-amber); }
.sja-suite-card__icon--coral  { background: var(--sja-coral); }
.sja-suite-card__icon--purple { background: var(--sja-purple); }

.sja-suite-card__body {
    min-width: 0;
}

.sja-suite-card__name {
    display: block;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sja-suite-card__desc {
    display: block;
    font-size: 11px;
    color: var(--text-tertiary);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
    animation: sja-shimmer 1.4s infinite;
    width: 100%;
}

.sja-skeleton-bar--short  { width: 60%; }
.sja-skeleton-bar--medium { width: 80%; }

@keyframes sja-shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* KPI value mientras espera respuesta async */
.kpi-value--loading {
    color: transparent;
    background: linear-gradient(90deg, #d8dbd2 25%, #eceee8 50%, #d8dbd2 75%);
    background-size: 200% 100%;
    animation: sja-shimmer 1.2s infinite;
    border-radius: 4px;
    display: inline-block;
    min-width: 60px;
}

/* ── Estado vacío ─────────────────────────────────────────────────────── */
.sja-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 32px 16px;
    color: var(--text-tertiary);
    gap: 8px;
    text-align: center;
}

.sja-empty-state i {
    font-size: 32px;
    opacity: 0.4;
}

.sja-empty-state p {
    font-size: 13px;
    margin: 0;
}

/* ── Select2 override para sja-select ─────────────────────────────────── */
.sja-filters .select2-container .select2-selection--single {
    height: 33px;
    border-radius: 6px;
    border-color: var(--border-strong);
}

.sja-filters .select2-container .select2-selection--single .select2-selection__rendered {
    line-height: 31px;
    font-size: 13px;
    color: var(--text-primary);
}

.sja-filters .select2-container .select2-selection--single .select2-selection__arrow {
    height: 31px;
}

/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 1100px) {
    .sja-panel-row {
        grid-template-columns: 1fr;
    }

    .sja-kpi-grid {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    }
}

@media (max-width: 768px) {
    .sja-dashboard {
        padding: 12px 14px 24px;
    }

    .sja-page-header {
        flex-direction: column;
    }

    .sja-kpi-grid {
        grid-template-columns: 1fr 1fr;
    }

    .sja-title {
        font-size: 18px;
    }

    .kpi-value {
        font-size: 20px;
    }

    .sja-filters {
        width: 100%;
    }

    .sja-filter-group {
        flex: 1;
        min-width: 120px;
    }

    .ordenes-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 480px) {
    .sja-kpi-grid {
        grid-template-columns: 1fr;
    }
}

/* =============================================================
   ====== LOGIN BAIKAGO � fusionado desde login_baikago.css =====
   ============================================================= */
/* =====================================================
   BaikaGo Agro — Login Premium
   assets/css/extras/login_baikago.css
   ===================================================== */

/* ── Reset scoped (solo dentro del login, specificity 0) ─── */
:where(body.baikago-login, body.baikago-login *, body.baikago-login *::before, body.baikago-login *::after) {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body.baikago-login {
    width: 100%;
    height: 100%;
    overflow: hidden;
    font-family: 'Inter', 'Poppins', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: #06131d;
    color: #ffffff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
html:has(body.baikago-login) {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

/* ── Variables (scopeadas al login) ───────────────── */
body.baikago-login {
    --bl-bg-dark:     #06131d;
    --bl-bg-mid:      #081b29;
    --bl-bg-panel:    #0d2233;
    --bl-green:       #39c95f;
    --bl-lime:        #8be233;
    --bl-yellow:      #f5d51b;
    --bl-text-1:      #ffffff;
    --bl-text-2:      #9aa8b8;
    --bl-border:      rgba(255, 255, 255, 0.10);
    --bl-input-bg:    rgba(255, 255, 255, 0.06);
    --bl-r-input:     14px;
    --bl-r-btn:       14px;
    --bl-shadow-green: 0 8px 32px rgba(57, 201, 95, 0.30);
}

/* ── Layout ───────────────────────────────────────── */
.bl-container {
    display: flex;
    width:  100vw;
    height: 100vh;
    overflow: hidden;
}

/* =================================================
   LEFT PANEL
   ================================================= */
.bl-left {
    position: relative;
    flex: 0 0 65%;
    width: 65%;
    height: 100%;
    overflow: hidden;
}

.bl-left-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    transform: scale(1.04);
    transition: transform 10s ease-out, opacity 0.8s ease;
    opacity: 0.92;
}

.bl-left-bg.bl-loaded {
    transform: scale(1.0);
}

/* Main overlay — darkens the image for legibility */
.bl-left-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        140deg,
        rgba(6, 19, 29, 0.82) 0%,
        rgba(8, 27, 41, 0.58) 45%,
        rgba(13, 34, 51, 0.72) 100%
    );
    z-index: 1;
}

/* Bottom fade for brand text readability */
.bl-left-overlay::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 55%;
    background: linear-gradient(to top, rgba(6, 19, 29, 0.90) 0%, transparent 100%);
}

/* ── Decorative elements ──────────────────────────── */
.bl-deco {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    overflow: hidden;
}

.bl-deco-circle {
    position: absolute;
    border-radius: 50%;
    border: 1px solid rgba(57, 201, 95, 0.14);
}

.bl-deco-circle:nth-child(1) {
    width: 480px;
    height: 480px;
    top: -140px;
    left: -120px;
    animation: bl-pulse 5s ease-in-out infinite;
}

.bl-deco-circle:nth-child(2) {
    width: 320px;
    height: 320px;
    bottom: 80px;
    right: -60px;
    border-color: rgba(139, 226, 51, 0.10);
    animation: bl-pulse 6s ease-in-out infinite 1.8s;
}

.bl-deco-circle:nth-child(3) {
    width: 180px;
    height: 180px;
    top: 42%;
    left: 8%;
    border-color: rgba(245, 213, 27, 0.08);
    animation: bl-pulse 7s ease-in-out infinite 3.2s;
}

@keyframes bl-pulse {
    0%, 100% { transform: scale(1);    opacity: 0.55; }
    50%       { transform: scale(1.04); opacity: 1.00; }
}

/* Dot grid */
.bl-deco-dots {
    position: absolute;
    top: 56px;
    right: 52px;
    display: grid;
    grid-template-columns: repeat(5, 8px);
    gap: 9px;
}

.bl-deco-dots span {
    display: block;
    width: 3.5px;
    height: 3.5px;
    border-radius: 50%;
    background: rgba(57, 201, 95, 0.5);
    animation: bl-blink 3.5s ease-in-out infinite;
}

.bl-deco-dots span:nth-child(odd)  { animation-delay: 0.6s; }
.bl-deco-dots span:nth-child(3n)   { animation-delay: 1.2s; background: rgba(139, 226, 51, 0.5); }

@keyframes bl-blink {
    0%, 100% { opacity: 0.45; transform: scale(1);   }
    50%       { opacity: 1.00; transform: scale(1.5); }
}

/* Light glow accents */
.bl-deco-glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    pointer-events: none;
}

.bl-deco-glow:nth-child(5) {
    width: 300px;
    height: 300px;
    background: rgba(57, 201, 95, 0.09);
    bottom: 20%;
    left: 15%;
}

.bl-deco-glow:nth-child(6) {
    width: 200px;
    height: 200px;
    background: rgba(139, 226, 51, 0.07);
    top: 20%;
    right: 15%;
}

/* ── Left brand content ───────────────────────────── */
.bl-left-content {
    position: absolute;
    inset: 0;
    z-index: 3;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding-bottom: 68px;
}

.bl-brand-logo {
    width: 88px;
    height: 88px;
    margin-bottom: 22px;
    filter: drop-shadow(0 6px 28px rgba(57, 201, 95, 0.55));
    animation: bl-float 4s ease-in-out infinite;
}

@keyframes bl-float {
    0%, 100% { transform: translateY(0);   }
    50%       { transform: translateY(-6px); }
}

.bl-brand-title {
    font-family: 'Poppins', sans-serif;
    font-size: 44px;
    font-weight: 700;
    color: #ffffff;
    letter-spacing: -0.5px;
    line-height: 1.1;
    text-align: center;
    text-shadow: 0 4px 24px rgba(0, 0, 0, 0.55);
    margin-bottom: 12px;
}

.bl-brand-title span {
    background: linear-gradient(90deg, #39c95f 0%, #8be233 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.bl-brand-subtitle {
    font-size: 16.5px;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.70);
    letter-spacing: 0.6px;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
}

/* =================================================
   RIGHT PANEL
   ================================================= */
.bl-right {
    flex: 0 0 35%;
    width: 35%;
    height: 100%;
    background: linear-gradient(
        165deg,
        #0e2535 0%,
        #081c2c 40%,
        #06131d 100%
    );
    border-left: 1px solid rgba(255, 255, 255, 0.055);
    box-shadow: -24px 0 72px rgba(0, 0, 0, 0.50);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 44px;
    position: relative;
    overflow-y: auto;
    overflow-x: hidden;
    animation: bl-panel-in 0.75s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes bl-panel-in {
    from { opacity: 0; transform: translateX(36px); }
    to   { opacity: 1; transform: translateX(0);    }
}

/* Scrollbar */
.bl-right::-webkit-scrollbar { width: 4px; }
.bl-right::-webkit-scrollbar-track { background: transparent; }
.bl-right::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.08); border-radius: 4px; }

.bl-panel-inner {
    width: 100%;
    max-width: 360px;
}

/* ── Panel logo ───────────────────────────────────── */
.bl-panel-logo {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 34px;
}

.bl-panel-logo svg {
    width: 54px;
    height: 54px;
    margin-bottom: 11px;
    filter: drop-shadow(0 4px 18px rgba(57, 201, 95, 0.42));
}

.bl-panel-logo-name {
    font-family: 'Poppins', sans-serif;
    font-size: 16.5px;
    font-weight: 600;
    color: #ffffff;
    letter-spacing: 0.1px;
}

.bl-panel-logo-tagline {
    font-size: 11.5px;
    color: var(--bl-text-2);
    margin-top: 3px;
    letter-spacing: 0.3px;
}

/* ── Welcome heading ──────────────────────────────── */
.bl-welcome-title {
    font-family: 'Poppins', sans-serif;
    font-size: 27px;
    font-weight: 700;
    color: #ffffff;
    text-align: center;
    letter-spacing: -0.3px;
    margin-bottom: 7px;
}

.bl-welcome-subtitle {
    font-size: 13.5px;
    color: var(--bl-text-2);
    text-align: center;
    margin-bottom: 28px;
}

/* ── Error alert ──────────────────────────────────── */
.bl-alert {
    display: none;
    align-items: flex-start;
    gap: 9px;
    background: rgba(220, 53, 69, 0.10);
    border: 1px solid rgba(220, 53, 69, 0.28);
    border-radius: var(--bl-r-input);
    color: #ff7080;
    font-size: 13px;
    line-height: 1.5;
    padding: 12px 16px;
    margin-bottom: 20px;
}

.bl-alert.bl-show {
    display: flex;
    animation: bl-alert-in 0.28s ease both;
}

@keyframes bl-alert-in {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0);    }
}

.bl-alert svg { flex-shrink: 0; margin-top: 1px; }

/* ── Form ─────────────────────────────────────────── */
.bl-form { width: 100%; }

.bl-form-group {
    position: relative;
    margin-bottom: 14px;
}

/* Icon inside input */
.bl-icon {
    position: absolute;
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
    width: 17px;
    height: 17px;
    color: var(--bl-text-2);
    opacity: 0.65;
    pointer-events: none;
    transition: color 0.22s, opacity 0.22s;
}

.bl-form-group:focus-within .bl-icon {
    color: var(--bl-green);
    opacity: 1;
}

/* Input field */
.bl-input {
    width: 100%;
    background: var(--bl-input-bg);
    border: 1.5px solid var(--bl-border);
    border-radius: var(--bl-r-input);
    padding: 14px 46px 14px 44px;
    color: var(--bl-text-1);
    font-size: 14px;
    font-family: inherit;
    outline: none;
    transition: border-color 0.25s, background 0.25s, box-shadow 0.25s;
    -webkit-appearance: none;
    appearance: none;
    letter-spacing: 0.1px;
}

.bl-input::placeholder {
    color: var(--bl-text-2);
    opacity: 0.65;
}

.bl-input:focus {
    border-color: var(--bl-green);
    background: rgba(57, 201, 95, 0.055);
    box-shadow: 0 0 0 3.5px rgba(57, 201, 95, 0.11);
}

/* Password toggle button */
.bl-pwd-toggle {
    position: absolute;
    right: 13px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--bl-text-2);
    padding: 5px;
    opacity: 0.60;
    transition: opacity 0.2s, color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
}

.bl-pwd-toggle:hover {
    opacity: 1;
    color: var(--bl-text-1);
}

/* ── Checkbox row ─────────────────────────────────── */
.bl-check-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 22px;
    margin-top: 4px;
}

.bl-checkbox-label {
    display: flex;
    align-items: center;
    gap: 9px;
    cursor: pointer;
    font-size: 13px;
    color: var(--bl-text-2);
    user-select: none;
}

.bl-checkbox-label input[type="checkbox"] {
    -webkit-appearance: none;
    appearance: none;
    width: 17px;
    height: 17px;
    border: 1.5px solid rgba(255, 255, 255, 0.18);
    border-radius: 5px;
    background: var(--bl-input-bg);
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
    transition: border-color 0.2s, background 0.2s;
}

.bl-checkbox-label input[type="checkbox"]:checked {
    background: var(--bl-green);
    border-color: var(--bl-green);
}

.bl-checkbox-label input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    left: 4px;
    top: 1.5px;
    width: 6px;
    height: 10px;
    border: 2px solid #fff;
    border-top: none;
    border-left: none;
    transform: rotate(44deg);
}

.bl-forgot-link {
    font-size: 12.5px;
    color: var(--bl-green);
    text-decoration: none;
    opacity: 0.88;
    transition: opacity 0.2s, color 0.2s;
}

.bl-forgot-link:hover {
    opacity: 1;
    color: var(--bl-lime);
}

/* ── Submit button ────────────────────────────────── */
.bl-btn-submit {
    width: 100%;
    padding: 14.5px 24px;
    border: none;
    border-radius: var(--bl-r-btn);
    background: linear-gradient(90deg, #39c95f 0%, #6fd52b 55%, #f5d51b 100%);
    color: #05111a;
    font-size: 14.5px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    letter-spacing: 0.15px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    transition: transform 0.22s, box-shadow 0.22s, opacity 0.22s;
    box-shadow: var(--bl-shadow-green);
    margin-bottom: 22px;
    position: relative;
    overflow: hidden;
}

.bl-btn-submit::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(255,255,255,0.12) 0%, transparent 60%);
    opacity: 0;
    transition: opacity 0.22s;
}

.bl-btn-submit:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 12px 36px rgba(57, 201, 95, 0.48);
}

.bl-btn-submit:hover:not(:disabled)::before { opacity: 1; }

.bl-btn-submit:active:not(:disabled) { transform: translateY(0); }

.bl-btn-submit:disabled {
    opacity: 0.60;
    cursor: not-allowed;
    transform: none;
}

.bl-btn-arrow {
    display: flex;
    align-items: center;
    transition: transform 0.22s;
}

.bl-btn-submit:hover:not(:disabled) .bl-btn-arrow {
    transform: translateX(4px);
}

/* Loading spinner */
.bl-spinner {
    display: none;
    width: 18px;
    height: 18px;
    border: 2.5px solid rgba(5, 17, 26, 0.25);
    border-top-color: #05111a;
    border-radius: 50%;
    animation: bl-spin 0.65s linear infinite;
    flex-shrink: 0;
}

@keyframes bl-spin {
    to { transform: rotate(360deg); }
}

/* ── Separator ────────────────────────────────────── */
.bl-separator {
    display: flex;
    align-items: center;
    gap: 11px;
    margin-bottom: 18px;
    color: var(--bl-text-2);
    font-size: 12px;
    opacity: 0.70;
}

.bl-separator-line {
    flex: 1;
    height: 1px;
    background: var(--bl-border);
}

/* ── Social buttons ───────────────────────────────── */
.bl-social-row {
    display: flex;
    gap: 12px;
    margin-bottom: 0;
}

.bl-btn-social {
    flex: 1;
    padding: 11px 14px;
    background: rgba(255, 255, 255, 0.048);
    border: 1.5px solid var(--bl-border);
    border-radius: var(--bl-r-btn);
    color: var(--bl-text-1);
    font-size: 13px;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: background 0.2s, border-color 0.2s, transform 0.18s;
}

.bl-btn-social:hover {
    background: rgba(255, 255, 255, 0.085);
    border-color: rgba(255, 255, 255, 0.20);
    transform: translateY(-1px);
}

/* ── Footer ───────────────────────────────────────── */
.bl-footer {
    position: absolute;
    bottom: 22px;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 44px;
}

.bl-footer-secure {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11.5px;
    color: var(--bl-text-2);
    opacity: 0.65;
}

.bl-footer-copy {
    font-size: 11.5px;
    color: var(--bl-text-2);
    opacity: 0.65;
}

/* =================================================
   RESPONSIVE
   ================================================= */
@media (max-width: 1100px) {
    .bl-left  { flex: 0 0 55%; width: 55%; }
    .bl-right { flex: 0 0 45%; width: 45%; padding: 40px 32px; }
    .bl-brand-title { font-size: 36px; }
    .bl-footer { padding: 0 32px; }
}

@media (max-width: 820px) {
    .bl-left  { flex: 0 0 42%; width: 42%; }
    .bl-right { flex: 0 0 58%; width: 58%; padding: 36px 28px; }
    .bl-brand-title  { font-size: 28px; }
    .bl-brand-logo   { width: 68px; height: 68px; }
    .bl-footer { padding: 0 28px; }
}

@media (max-width: 660px) {
    html:has(body.baikago-login),
    body.baikago-login { overflow-y: auto; }

    .bl-left { display: none; }

    .bl-right {
        flex: 1;
        width: 100%;
        height: 100%;
        min-height: 100dvh;
        border-left: none;
        box-shadow: none;
        justify-content: center;
        padding: 48px 28px 80px;
        animation: bl-mobile-in 0.55s cubic-bezier(0.16, 1, 0.3, 1) both;
    }

    @keyframes bl-mobile-in {
        from { opacity: 0; transform: translateY(20px); }
        to   { opacity: 1; transform: translateY(0);    }
    }

    .bl-container {
        min-height: 100dvh;
        height: auto;
        overflow: visible;
    }

    .bl-footer {
        bottom: 16px;
        padding: 0 28px;
    }
}

/* =============================================================
   ====== LOGIN BAIKAGO V3 � overrides (hereda v1) =============
   ============================================================= */
/* =====================================================
   BaikaGo Agro — Login v3
   Combina la base oscura del v1 (dark glassmorphism)
   con la barra de íconos de beneficios del v2.
   assets/css/extras/login_baikago_v3.css
   ===================================================== */

/* ── Base: hereda todos los estilos del v1 ─────────── */
/* =================================================
   FONDO EXTENDIDO A PANTALLA COMPLETA
   El bl-left-bg pasa a fixed para cubrir todo el
   viewport. El overlay también se extiende.
   ================================================= */
.bl-left {
    background: transparent;
    overflow: visible;
    flex: 1;
    width: auto;
}

.bl-left-bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    background-position: 60% center;
}

.bl-left-overlay {
    position: fixed;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        140deg,
        rgba(6, 19, 29, 0.80) 0%,
        rgba(8, 27, 41, 0.40) 45%,
        rgba(6, 19, 29, 0.65) 100%
    );
}

/* Elevar el contenedor sobre el fondo fijo */
.bl-container {
    position: relative;
    z-index: 2;
    align-items: stretch;
}

/* ── Override: panel derecho redondeado y flotante ──── */
.bl-right {
    position: relative;
    z-index: 10;
    align-self: center;
    height: auto;
    max-height: calc(100vh - 72px);
    flex: 0 0 auto;
    width: 397px;
    border-radius: 36px;
    border: 1px solid rgba(255, 255, 255, 0.10);
    border-left: 1px solid rgba(255, 255, 255, 0.10);
    margin: 36px 30px 36px 0;
    padding: 42px 41px 36px;
    box-shadow:
        0 32px 80px rgba(0, 0, 0, 0.65),
        0 0 0 1px rgba(255, 255, 255, 0.055),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    overflow-y: auto;
    overflow-x: hidden;
    animation: bl-panel-v3-in 0.75s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes bl-panel-v3-in {
    from { opacity: 0; transform: translateY(24px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0)    scale(1);    }
}

/* Cancelar la animación lateral del v1 en v3 */
.bl-right { animation-name: bl-panel-v3-in; }

/* Contenido del panel izquierdo sobre el fondo fijo */
.bl-deco        { z-index: 3; }
.bl-left-content { z-index: 4; }

/* ── Override .bl-left-content para acomodar la barra ─ */
/* En v1 usa padding-bottom:68px + align-items:center.
   En v3 necesitamos stretch para que la barra ocupe
   todo el ancho, y sin padding-bottom propio (la barra
   lo gestiona internamente). */
.bl-left-content {
    align-items: stretch;
    padding-bottom: 0;
}

/* ── Bloque de marca (logo + título + subtítulo) ─────── */
/* Ocupa el espacio disponible y empuja el contenido
   hacia la parte inferior antes de la barra. */
.bl3-brand-block {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    padding-bottom: 52px;
    padding-left: 48px;
    width: 100%;
}
.bl3-brand-text {
    animation: bl-float 4s ease-in-out infinite;
}
.bl3-brand-block .bl-brand-title,
.bl3-brand-block .bl-brand-subtitle {
    text-align: left;
    animation: none;
}
.bl3-brand-block .bl-brand-title span {
    font-weight: 400;
}

/* =================================================
   BARRA DE BENEFICIOS — parte inferior izquierda
   ================================================= */
.bl3-features-bar {
    width: 100%;
    display: flex;
    align-items: flex-start;
    gap: 0;
    background: transparent;
    border-top: 1px solid rgba(255, 255, 255, 0.09);
    padding: 28px 48px;
}

/* ── Cada ítem de beneficio ───────────────────────── */
.bl3-feat {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0 24px;
    border-right: 1px solid rgba(255, 255, 255, 0.11);
}

.bl3-feat:first-child { padding-left: 0; }
.bl3-feat:last-child  { border-right: none; }

/* ── Icono circular ───────────────────────────────── */
.bl3-feat-icon {
    width: 48px;
    height: 48px;
    border: 1.5px solid rgba(57, 201, 95, 0.50);
    border-radius: 50%;
    background: rgba(57, 201, 95, 0.10);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #39c95f;
    margin-bottom: 13px;
    flex-shrink: 0;
    transition: background 0.25s, border-color 0.25s, box-shadow 0.25s;
}

.bl3-feat:hover .bl3-feat-icon {
    background: rgba(57, 201, 95, 0.22);
    border-color: rgba(57, 201, 95, 0.85);
    box-shadow: 0 0 18px rgba(57, 201, 95, 0.25);
}

/* ── Textos ───────────────────────────────────────── */
.bl3-feat-title {
    font-size: 13.5px;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 5px;
    line-height: 1.3;
    letter-spacing: 0.05px;
}

.bl3-feat-desc {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.58);
    line-height: 1.5;
}

/* =================================================
   PANEL LOGO — Imagen PNG
   ================================================= */
.bl-panel-logo-img {
    display: block;
    max-width: 250px;
    width: 98%;
    height: auto;
    object-fit: contain;
    margin-bottom: 8px;
}

/* =================================================
   BOTÓN INGRESAR — paleta agrícola sobria
   ================================================= */
.bl-btn-submit {
    background: linear-gradient(90deg, #2F8F4E 0%, #5F7F3A 100%);
    color: #ffffff;
    border: 1px solid rgba(139, 195, 74, 0.35);
    box-shadow: 0 8px 24px rgba(47, 143, 78, 0.28);
}

.bl-btn-submit:hover:not(:disabled) {
    box-shadow: 0 12px 32px rgba(47, 143, 78, 0.42);
}

/* =================================================
   RESPONSIVE
   ================================================= */

/* ── Laptop pequeño / tablet landscape (≤1100px) ─── */
@media (max-width: 1100px) {
    .bl-right          { width: 44%; margin: 24px 28px 24px 0; padding: 40px 36px 34px; border-radius: 28px; }
    .bl3-features-bar  { padding: 22px 36px; }
    .bl3-feat          { padding: 0 18px; }
}

/* ── Tablet portrait (≤820px) ───────────────────── */
@media (max-width: 820px) {
    .bl-right          { width: 56%; margin: 16px 20px 16px 0; padding: 34px 28px 28px; border-radius: 22px; }
    .bl3-features-bar  { padding: 18px 20px; }
    .bl3-feat          { padding: 0 10px; }
    .bl3-feat-title    { font-size: 12px; }
    .bl3-feat-desc     { display: none; }
    .bl3-feat-icon     { width: 40px; height: 40px; margin-bottom: 9px; }
}

/* ── Tablet pequeña / móvil grande (≤660px) ─────── */
@media (max-width: 660px) {
    html:has(body.baikago-login),
    body.baikago-login { overflow-y: auto; }

    .bl-left { display: none; }

    .bl-right {
        width: 100%;
        max-width: 460px;
        margin: auto;
        border-radius: 24px;
        max-height: none;
        border: 1px solid rgba(255, 255, 255, 0.12);
        box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
        padding: 40px 32px 36px;
        align-self: center;
    }

    .bl-container {
        min-height: 100dvh;
        height: auto;
        overflow: visible;
        justify-content: center;
        align-items: center;
        padding: 24px 16px;
        box-sizing: border-box;
    }

    /* El fondo fijo sigue cubriendo todo el viewport */
    .bl-left-bg,
    .bl-left-overlay { display: block; }
}

/* ── Móvil estándar (≤480px) ────────────────────── */
@media (max-width: 480px) {
    .bl-right {
        max-width: 100%;
        border-radius: 18px;
        padding: 32px 22px 28px;
    }

    .bl-container {
        padding: 16px 12px;
        align-items: flex-start;
        padding-top: max(16px, env(safe-area-inset-top));
        padding-bottom: max(16px, env(safe-area-inset-bottom));
    }

    .bl-panel-logo-img { max-width: 180px; }
    .bl-welcome-title  { font-size: 22px; }
}

/* ── Móvil muy pequeño (≤380px) ─────────────────── */
@media (max-width: 380px) {
    .bl-right { padding: 28px 18px 24px; border-radius: 14px; }
}
