/*
 *
 *   YAMISS ERP - Ajustes generales
 *   version 2.0 - Tema Azul Moderno
 *
 */

/* ===== PALETA DE COLORES AZUL ===== */
:root {
    --azul-principal: #1e40af;      /* Azul principal */
    --azul-oscuro: #1e3a8a;         /* Azul oscuro */
    --azul-claro: #3b82f6;          /* Azul claro */
    --azul-suave: #dbeafe;          /* Azul muy claro */
    --azul-gris: #64748b;           /* Azul grisáceo */
    --blanco: #ffffff;
    --gris-claro: #f8fafc;
    --gris-medio: #e2e8f0;
    --gris-texto: #334155;
    --verde-exito: #10b981;
    --rojo-error: #ef4444;
    --amarillo-warning: #f59e0b;
}

/* ===== ESTILOS GENERALES ===== */
body {
    background-color: var(--gris-claro);
    color: var(--gris-texto);
    font-family: 'Inter', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

/* ===== LÍNEAS DIVISORIAS ===== */
.hr-line-dashed {
    border-top: 1px dashed var(--azul-suave);
    color: var(--blanco);
    background-color: var(--blanco);
    height: 1px;
    margin: 10px 0 20px 0;
}

.hr-line-solid {
    border-bottom: 1px solid var(--azul-suave);
    background-color: rgba(0, 0, 0, 0);
    border-style: solid !important;
    margin-top: 15px;
    margin-bottom: 15px;
}

/* ===== INPUTS Y FORMULARIOS ===== */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type=number] {
    -moz-appearance: textfield;
}

input, select, textarea {
    border: 1px solid var(--gris-medio);
    border-radius: 6px;
    padding: 8px 12px;
    transition: all 0.3s ease;
}

input:focus, select:focus, textarea:focus {
    outline: none;
    border-color: var(--azul-principal);
    box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.1);
}

/* ===== BOTONES ===== */
.btn-primary {
    background-color: var(--azul-principal);
    border-color: var(--azul-principal);
    color: var(--blanco);
    padding: 10px 20px;
    border-radius: 6px;
    transition: all 0.3s ease;
}

.btn-primary:hover {
    background-color: var(--azul-oscuro);
    border-color: var(--azul-oscuro);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(30, 64, 175, 0.3);
}

.btn-secondary {
    background-color: var(--azul-gris);
    border-color: var(--azul-gris);
    color: var(--blanco);
}

.btn-success {
    background-color: var(--verde-exito);
    border-color: var(--verde-exito);
}

.btn-danger {
    background-color: var(--rojo-error);
    border-color: var(--rojo-error);
}

.btn-warning {
    background-color: var(--amarillo-warning);
    border-color: var(--amarillo-warning);
}

/* ===== NAVEGACIÓN ===== */
.navbar {
    background-color: var(--azul-principal);
    border-bottom: 3px solid var(--azul-oscuro);
    box-shadow: 0 2px 10px rgba(30, 64, 175, 0.2);
}

.navbar-brand, .nav-link {
    color: var(--blanco) !important;
}

.nav-link:hover {
    color: var(--azul-suave) !important;
    transition: color 0.3s ease;
}

/* ===== SIDEBAR ===== */
.sidebar {
    background-color: var(--blanco);
    border-right: 1px solid var(--gris-medio);
    box-shadow: 2px 0 10px rgba(0, 0, 0, 0.05);
}

.sidebar .nav-link {
    color: var(--gris-texto);
    padding: 12px 20px;
    transition: all 0.3s ease;
}

.sidebar .nav-link:hover {
    background-color: var(--azul-suave);
    color: var(--azul-principal);
    border-radius: 6px;
    margin: 2px 8px;
}

.sidebar .nav-link.active {
    background-color: var(--azul-principal);
    color: var(--blanco);
    border-radius: 6px;
    margin: 2px 8px;
}

/* ===== TARJETAS ===== */
.card {
    border: 1px solid var(--gris-medio);
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
    transition: all 0.3s ease;
    background-color: var(--blanco);
}

.card:hover {
    box-shadow: 0 8px 25px rgba(30, 64, 175, 0.15);
    transform: translateY(-2px);
}

.card-header {
    background-color: var(--azul-suave);
    border-bottom: 1px solid var(--gris-medio);
    color: var(--azul-principal);
    font-weight: 600;
}

/* ===== TABLAS ===== */
.table {
    background-color: var(--blanco);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.table thead th {
    background-color: var(--azul-principal);
    color: var(--blanco);
    border: none;
    padding: 15px;
    font-weight: 600;
}

.table tbody tr:hover {
    background-color: var(--azul-suave);
    transition: background-color 0.3s ease;
}

.table tbody td {
    padding: 12px 15px;
    border-top: 1px solid var(--gris-medio);
}

/* ===== ALERTAS ===== */
.alert-primary {
    background-color: rgba(30, 64, 175, 0.1);
    border-color: var(--azul-principal);
    color: var(--azul-oscuro);
}

.alert-success {
    background-color: rgba(16, 185, 129, 0.1);
    border-color: var(--verde-exito);
    color: #065f46;
}

.alert-danger {
    background-color: rgba(239, 68, 68, 0.1);
    border-color: var(--rojo-error);
    color: #991b1b;
}

/* ===== RESPONSIVO ===== */
@media (min-width: 767px) {
    .ya-d-panel-balance {
        overflow-y: auto;
    }
}

/* ===== EFECTOS ADICIONALES ===== */
.shadow-azul {
    box-shadow: 0 4px 15px rgba(30, 64, 175, 0.2);
}

.bg-gradient-azul {
    background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
}

.text-azul {
    color: var(--azul-principal);
}

.border-azul {
    border-color: var(--azul-principal);
}

/* ===== ANIMACIONES ===== */
.fade-in {
    animation: fadeIn 0.5s ease-in;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}