/* ============================================================
   BOOTSTRAP DARK/LIGHT THEME OVERRIDES — ALMACEN
   ============================================================
   Unifica los colores de Bootstrap con el sistema de diseño
   del proyecto usando las variables CSS de theme.css.
   
   Cargar DESPUÉS de Bootstrap CSS y DESPUÉS de theme.css.
   
   Orden: bootstrap.min.css → theme.css → almacen.css → theme-overrides.css
   ============================================================ */

/* ── FORM CONTROLS (base state — no solo focus) ──────── */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background-color: var(--color-input-bg);
    border-color: var(--color-input-border);
    color: var(--color-input-text);
}

[data-theme="dark"] .form-control::placeholder,
[data-theme="dark"] .form-select::placeholder {
    color: var(--color-input-placeholder);
}

[data-theme="dark"] .form-control:disabled,
[data-theme="dark"] .form-select:disabled {
    background-color: var(--color-surface-active);
    color: var(--color-text-muted);
    opacity: 0.7;
}

[data-theme="light"] .form-control:focus,
[data-theme="light"] .form-select:focus {
    border-color: var(--color-input-focus);
    box-shadow: 0 0 0 3px var(--color-primary-15);
}

/* ── INPUT GROUP ─────────────────────────────────── */
[data-theme="dark"] .input-group-text {
    background-color: var(--color-surface-active);
    border-color: var(--color-input-border);
    color: var(--color-text-muted);
}

/* ── BUTTONS ─────────────────────────────────────── */
[data-theme="dark"] .btn-primary,
[data-theme="light"] .btn-primary {
    background: var(--gradient-primary);
    border-color: var(--color-primary);
    color: var(--color-text-inverse);
}
[data-theme="dark"] .btn-primary:hover,
[data-theme="light"] .btn-primary:hover {
    background: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: var(--color-text-inverse);
}

[data-theme="dark"] .btn-light {
    background-color: var(--color-surface);
    border-color: var(--color-border);
    color: var(--color-text);
}
[data-theme="dark"] .btn-light:hover {
    background-color: var(--color-surface-hover);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

[data-theme="light"] .btn-light {
    background-color: var(--color-surface);
    border-color: var(--color-border);
    color: var(--color-text);
}
[data-theme="light"] .btn-light:hover {
    background-color: var(--color-surface-hover);
    color: var(--color-primary);
}

.btn-outline-primary {
    border-color: var(--color-primary);
    color: var(--color-primary);
}
.btn-outline-primary:hover {
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
}

.btn-outline-danger {
    border-color: var(--color-rubi);
    color: var(--color-rubi);
}
.btn-outline-danger:hover {
    background-color: var(--color-rubi);
    color: var(--color-text-inverse);
}

.btn-outline-warning {
    border-color: var(--color-warning);
    color: var(--color-warning);
}
.btn-outline-warning:hover {
    background-color: var(--color-warning);
    color: var(--color-text-inverse);
}

[data-theme="dark"] .btn-outline-light {
    border-color: var(--color-border);
    color: var(--color-text-muted);
}
[data-theme="dark"] .btn-outline-light:hover {
    background-color: var(--color-surface-hover);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

[data-theme="light"] .btn-outline-light {
    border-color: var(--color-border);
    color: var(--color-text-muted);
}
[data-theme="light"] .btn-outline-light:hover {
    background-color: var(--color-surface-hover);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

/* ── TEXT COLORS ───────────────────────────────────── */
[data-theme="dark"] .text-muted,
[data-theme="light"] .text-muted {
    color: var(--color-text-muted) !important;
}

.text-primary {
    color: var(--color-primary) !important;
}

[data-theme="dark"] .text-success,
[data-theme="light"] .text-success {
    color: var(--color-esmeralda) !important;
}

[data-theme="dark"] .text-danger,
[data-theme="light"] .text-danger {
    color: var(--color-rubi) !important;
}

[data-theme="dark"] .text-warning,
[data-theme="light"] .text-warning {
    color: var(--color-warning) !important;
}

[data-theme="dark"] .text-info,
[data-theme="light"] .text-info {
    color: var(--color-info) !important;
}

/* ── BADGES ───────────────────────────────────────── */
[data-theme="dark"] .badge.bg-secondary,
[data-theme="light"] .badge.bg-secondary {
    background: var(--color-surface-hover) !important;
    color: var(--color-text-muted) !important;
    border: 1px solid var(--color-border);
}

/* ── CARDS ────────────────────────────────────────── */
[data-theme="dark"] .card {
    background-color: var(--color-surface);
    border-color: var(--color-border);
    color: var(--color-text);
}

[data-theme="dark"] .card-header {
    background-color: var(--color-bg-alt);
    border-bottom-color: var(--color-border);
    color: var(--color-text-heading);
}

[data-theme="dark"] .card-footer {
    background-color: var(--color-bg-alt);
    border-top-color: var(--color-border);
    color: var(--color-text);
}

/* ── PRINT ────────────────────────────────────────── */
@media print {
    [data-theme="dark"] .form-control,
    [data-theme="dark"] .form-select {
        background-color: #fff;
        border-color: #000;
        color: #000;
    }
    .btn-primary {
        background: #000 !important;
        color: #fff !important;
    }
}