/* ==========================================================
   VARIABLES DE IDENTIDAD VISUAL - TRZ COMPANY SAC
   ========================================================== */

:root {
    --sidebar-width: 260px;
    /* COLORES PRINCIPALES DEL LOGO */
    --trz-navy: #30466F;
    --trz-navy-dark: #243653;
    --trz-coral: #F47C5B;
    --trz-coral-dark: #D96348;
    /* COLORES DE ESTRUCTURA */
    --trz-sidebar: #171C21;
    --trz-sidebar-header: #11161A;
    --trz-background: #F4F7F6;
    --trz-text: #26313D;
    --trz-muted: #7B8794;
    /* COLORES SEMÁNTICOS */
    --trz-success: #198754;
    --trz-danger: #DC3545;
    --trz-warning: #FFC107;
    --trz-info: #19C5DB;
}


/* ==========================================================
   RESET Y BASE GENERAL
   ========================================================== */

html {
    font-size: 14px;
}

body {
    background-color: var(--trz-background);
    color: var(--trz-text);
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

.wrapper {
    display: flex;
    width: 100%;
    align-items: stretch;
}


/* ==========================================================
   SIDEBAR
   ========================================================== */

#sidebar {
    min-width: var(--sidebar-width);
    max-width: var(--sidebar-width);
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1050;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    color: #FFFFFF;
    background-color: var(--trz-sidebar);
    transition: margin-left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

    /* Scrollbar del menú lateral */
    #sidebar::-webkit-scrollbar {
        width: 4px;
    }

    #sidebar::-webkit-scrollbar-thumb {
        background: rgba(255, 255, 255, 0.15);
        border-radius: 10px;
    }

    /* Encabezado del sidebar */
    #sidebar .sidebar-header {
        padding: 25px 20px;
        background-color: var(--trz-sidebar-header);
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }

.sidebar-subtitle {
    color: rgba(255, 255, 255, 0.45);
}

/* Espaciado del menú */
#sidebar ul.components {
    padding-top: 15px;
    padding-bottom: 120px !important;
}

/* Enlaces */
#sidebar ul li a {
    display: block;
    padding: 12px 20px;
    color: #ADB5BD;
    font-size: 0.95rem;
    text-decoration: none;
    transition: all 0.2s ease-in-out;
}

    /* Hover del menú */
    #sidebar ul li a:hover {
        color: #FFFFFF;
        background-color: rgba(244, 124, 91, 0.12);
    }

/* Elemento activo del menú */
#sidebar ul li.active > a {
    color: #FFFFFF;
    background-color: var(--trz-coral);
    font-weight: 600;
}

/* Sidebar oculto en computadora */
#sidebar.collapsed {
    margin-left: calc(-1 * var(--sidebar-width));
}


/* ==========================================================
   CONTENIDO PRINCIPAL
   ========================================================== */

#content {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 100vh;
    padding-left: var(--sidebar-width);
    transition: padding-left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Expandir contenido cuando se oculta el sidebar */
#sidebar.collapsed + #content {
    padding-left: 0;
}


/* ==========================================================
   NAVBAR SUPERIOR
   ========================================================== */

.navbar-trz {
    padding: 15px 20px;
    background-color: #FFFFFF;
    border: none;
    border-bottom: 3px solid var(--trz-coral);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.sidebar-toggle-button {
    padding: 5px 10px;
}


/* ==========================================================
   OVERLAY PARA CELULARES
   ========================================================== */

.overlay {
    display: none;
    position: fixed;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.70);
    z-index: 1040;
    transition: all 0.3s ease-in-out;
}

    .overlay.active {
        display: block;
    }


/* ==========================================================
   COLORES PERSONALIZADOS
   ========================================================== */

.text-trz-accent {
    color: var(--trz-coral) !important;
}

.text-trz-primary {
    color: var(--trz-navy) !important;
}

.bg-trz-primary {
    background-color: var(--trz-navy) !important;
}

.bg-trz-accent {
    background-color: var(--trz-coral) !important;
}

.bg-trz-dark {
    background-color: var(--trz-sidebar) !important;
}

/* Reemplazar visualmente algunos colores predeterminados de Bootstrap */
.text-primary {
    color: var(--trz-coral) !important;
}

.bg-primary {
    background-color: var(--trz-navy) !important;
}


/* ==========================================================
   TARJETAS
   ========================================================== */

.card {
    border: none;
    border-radius: 12px;
    box-shadow: 0 0.125rem 0.35rem rgba(0, 0, 0, 0.08);
    margin-bottom: 1.5rem;
}

.card-header {
    border-bottom: 1px solid #E8ECEF;
}


/* ==========================================================
   TABLAS
   ========================================================== */

.table-responsive {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    background-color: #FFFFFF;
    border-radius: 8px;
}

.table thead th {
    background-color: #F8F9FA;
    color: #6C757D;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    font-weight: 700;
    border-top: none;
}

.table-hover tbody tr:hover {
    background-color: rgba(48, 70, 111, 0.05);
}


/* ==========================================================
   BOTONES
   ========================================================== */

.btn {
    padding: 8px 16px;
    border-radius: 8px;
    font-weight: 500;
    transition: all 0.2s ease-in-out;
}

/* Botón principal: naranja coral */
.btn-primary {
    color: #FFFFFF;
    background-color: var(--trz-coral);
    border-color: var(--trz-coral);
}

    .btn-primary:hover,
    .btn-primary:focus,
    .btn-primary:active {
        color: #FFFFFF;
        background-color: var(--trz-coral-dark) !important;
        border-color: var(--trz-coral-dark) !important;
        transform: translateY(-1px);
    }

/* Botón secundario: azul navy */
.btn-outline-primary {
    color: var(--trz-navy);
    border-color: var(--trz-navy);
}

    .btn-outline-primary:hover,
    .btn-outline-primary:focus,
    .btn-outline-primary:active {
        color: #FFFFFF;
        background-color: var(--trz-navy) !important;
        border-color: var(--trz-navy) !important;
    }


/* ==========================================================
   FORMULARIOS
   ========================================================== */

.form-control,
.form-select {
    padding: 10px 15px;
    border: 1px solid #DEE2E6;
    border-radius: 8px;
}

    .form-control:focus,
    .form-select:focus {
        border-color: var(--trz-coral);
        box-shadow: 0 0 0 0.25rem rgba(244, 124, 91, 0.18);
    }


/* ==========================================================
   SELECT2
   ========================================================== */

.select2-container--bootstrap-5 .select2-selection {
    border-radius: 8px;
    border-color: #DEE2E6;
}

.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection {
    border-color: var(--trz-coral);
    box-shadow: 0 0 0 0.25rem rgba(244, 124, 91, 0.18);
}


/* ==========================================================
   BADGES
   ========================================================== */

.badge {
    padding: 6px 12px;
    border-radius: 6px;
    font-weight: 600;
}


/* ==========================================================
   DATATABLES
   ========================================================== */

.page-link {
    color: var(--trz-navy);
}

.page-item.active .page-link {
    color: #FFFFFF;
    background-color: var(--trz-coral);
    border-color: var(--trz-coral);
}

.page-link:focus {
    box-shadow: 0 0 0 0.25rem rgba(244, 124, 91, 0.18);
}


/* ==========================================================
   RESPONSIVE: CELULARES Y TABLETS
   ========================================================== */

@media screen and (max-width: 768px) {

    /* Sidebar inicialmente oculto */
    #sidebar {
        margin-left: calc(-1 * var(--sidebar-width));
    }

        /* Sidebar visible al abrirlo */
        #sidebar.active {
            margin-left: 0;
        }

    /* El contenido ocupa toda la pantalla */
    #content {
        padding-left: 0 !important;
    }

    .navbar-trz {
        padding: 10px;
    }

    main {
        padding: 15px !important;
    }

    .card-body {
        padding: 15px !important;
    }
}


/* ==========================================================
   TABLAS APILADAS EN PANTALLAS PEQUEÑAS
   ========================================================== */

@media screen and (max-width: 600px) {

    .table-responsive-stack tr {
        display: flex;
        flex-direction: column;
        border-bottom: 3px solid #CCCCCC;
    }
}

/* ==========================================================
   MÓDULO DE INVENTARIO - TRZ COMPANY SAC
   ========================================================== */

/* Encabezado corporativo para tablas */
.table-trz th {
    background-color: var(--trz-navy) !important;
    color: #FFFFFF !important;
    border-color: rgba(255, 255, 255, 0.10) !important;
    vertical-align: middle;
}

/* Borde naranja personalizado */
.border-trz-accent {
    border-color: var(--trz-coral) !important;
}

/* Campo para subir Excel */
.input-excel {
    width: 210px;
}

/* Miniatura de producto en el listado */
.producto-miniatura {
    object-fit: cover;
}

/* Placeholder pequeño para productos sin foto */
.producto-sin-imagen-mini {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    color: #9CA3AF;
    background-color: #F3F4F6;
    font-size: 1.35rem;
    border: 1px solid #DEE2E6;
    border-radius: 8px;
}

/* Placeholder general para productos sin foto */
.producto-sin-imagen {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    min-height: 165px;
    padding: 20px;
    color: #9CA3AF;
    background-color: #F8F9FA;
    border: 1px dashed #CED4DA;
    border-radius: 10px;
}

/* Placeholder de detalles */
.producto-sin-imagen-grande {
    width: 100%;
    min-height: 280px;
    font-size: 3rem;
}

/* Vista previa de imagen */
.producto-preview {
    width: 100%;
    max-height: 220px;
    object-fit: contain;
}

/* Imagen en detalles */
.producto-detalle-imagen {
    width: 100%;
    max-height: 420px;
    object-fit: contain;
}

/* Caja de stock del kardex */
.stock-kardex-box {
    padding: 15px;
    background-color: #F8F9FA;
    border: 1px solid #DEE2E6;
    border-left: 4px solid var(--trz-coral);
    border-radius: 10px;
}

/* Imagen pequeña del kardex */
.kardex-miniatura {
    width: 72px;
    height: 72px;
    object-fit: cover;
}

/* Fila resaltada para stock crítico */
.fila-stock-critico {
    background-color: rgba(220, 53, 69, 0.07);
}

/* Ajustes para celulares */
@media screen and (max-width: 768px) {

    .input-excel {
        width: 100%;
    }

    .producto-detalle-imagen {
        max-height: 280px;
    }

    .stock-kardex-box {
        text-align: center;
    }
}

/* ==========================================================
   MÓDULO DE CLIENTES - TRZ COMPANY SAC
   ========================================================== */

/* Encabezado de formularios */
.cliente-form-header {
    background-color: var(--trz-navy);
    color: #FFFFFF;
    border-bottom: 4px solid var(--trz-coral);
}

/* Avatar del perfil */
.cliente-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 105px;
    height: 105px;
    margin-right: auto;
    margin-left: auto;
    color: var(--trz-coral);
    background-color: rgba(244, 124, 91, 0.10);
    font-size: 4.5rem;
    border: 2px solid rgba(244, 124, 91, 0.25);
    border-radius: 50%;
}

/* Datos de contacto */
.cliente-contacto {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cliente-contacto-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px;
    background-color: #F8F9FA;
    border: 1px solid #E9ECEF;
    border-radius: 8px;
}

    .cliente-contacto-item > i {
        color: var(--trz-coral);
        font-size: 1.15rem;
    }

    .cliente-contacto-item small {
        display: block;
        color: #6C757D;
        font-size: 0.75rem;
        text-transform: uppercase;
    }

    .cliente-contacto-item p {
        margin-bottom: 0;
        color: var(--trz-text);
        font-weight: 600;
    }

.cliente-texto-ajustable {
    overflow-wrap: anywhere;
}

/* Tarjeta de motocicleta */
.moto-cliente-card {
    height: 100%;
    padding: 16px;
    background-color: #F8F9FA;
    border: 1px solid #DEE2E6;
    border-left: 4px solid var(--trz-coral);
    border-radius: 10px;
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

    .moto-cliente-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.08);
    }

/* Estado vacío */
.cliente-empty-icon {
    color: #CED4DA;
    font-size: 4rem;
}

/* Vista de eliminación */
.cliente-delete-icon {
    font-size: 5rem;
}

.cliente-delete-summary {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

    .cliente-delete-summary div {
        padding: 12px;
        background-color: #F8F9FA;
        border: 1px solid #DEE2E6;
        border-radius: 8px;
    }

    .cliente-delete-summary small {
        display: block;
        color: #6C757D;
        font-size: 0.75rem;
        text-transform: uppercase;
    }

    .cliente-delete-summary p {
        margin-bottom: 0;
    }


/* ==========================================================
   AJUSTES PARA CELULARES
   ========================================================== */

@media screen and (max-width: 768px) {

    .cliente-delete-summary {
        grid-template-columns: 1fr;
    }

    .cliente-avatar {
        width: 90px;
        height: 90px;
        font-size: 3.75rem;
    }
}

/* ==========================================================
   MÓDULO DE VEHÍCULOS - TRZ COMPANY SAC
   ========================================================== */

/* Encabezado corporativo de formularios */
.vehiculo-form-header {
    background-color: var(--trz-navy);
    color: #FFFFFF;
    border-bottom: 4px solid var(--trz-coral);
}

/* Placa visual */
.vehiculo-placa {
    display: inline-block;
    min-width: 92px;
    padding: 7px 12px;
    color: #FFFFFF;
    background-color: var(--trz-sidebar);
    font-size: 0.95rem;
    font-weight: 700;
    text-align: center;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 2px solid #6C757D;
    border-radius: 6px;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.12);
}

.vehiculo-placa-grande {
    min-width: 135px;
    padding: 9px 16px;
    font-size: 1.2rem;
}

/* Avatar de motocicleta */
.vehiculo-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 105px;
    height: 105px;
    margin-right: auto;
    margin-left: auto;
    color: var(--trz-coral);
    background-color: rgba(244, 124, 91, 0.10);
    font-size: 4.2rem;
    border: 2px solid rgba(244, 124, 91, 0.25);
    border-radius: 50%;
}

/* Cuadrícula de información técnica */
.vehiculo-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.vehiculo-info-item {
    padding: 14px;
    background-color: #F8F9FA;
    border: 1px solid #DEE2E6;
    border-radius: 8px;
}

.vehiculo-info-item-wide {
    grid-column: span 2;
}

.vehiculo-info-item small,
.vehiculo-historial-dato small,
.vehiculo-delete-summary small {
    display: block;
    color: #6C757D;
    font-size: 0.75rem;
    text-transform: uppercase;
}

.vehiculo-info-item p,
.vehiculo-historial-dato p,
.vehiculo-delete-summary p {
    margin-bottom: 0;
    color: var(--trz-text);
    font-weight: 600;
}

/* Texto largo: VIN y motor */
.vehiculo-texto-ajustable {
    overflow-wrap: anywhere;
}

/* Propietario */
.vehiculo-owner-card {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    background-color: #F8F9FA;
    border: 1px solid #DEE2E6;
    border-left: 4px solid var(--trz-coral);
    border-radius: 10px;
}

.vehiculo-owner-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    flex-shrink: 0;
    color: var(--trz-coral);
    background-color: rgba(244, 124, 91, 0.12);
    font-size: 2rem;
    border-radius: 50%;
}

/* Datos laterales del historial */
.vehiculo-historial-dato {
    padding: 10px 0;
    border-bottom: 1px solid #E9ECEF;
}

/* Tarjetas de la línea de tiempo */
.vehiculo-timeline-card {
    margin-bottom: 15px;
    border-left: 5px solid transparent !important;
}

.vehiculo-timeline-pendiente {
    border-left-color: #FFC107 !important;
}

.vehiculo-timeline-completado {
    border-left-color: #198754 !important;
}

/* Ícono para estados vacíos */
.vehiculo-empty-icon {
    color: #CED4DA;
    font-size: 4rem;
}

/* Eliminación */
.vehiculo-delete-icon {
    font-size: 5rem;
}

.vehiculo-delete-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

    .vehiculo-delete-summary div {
        padding: 12px;
        background-color: #F8F9FA;
        border: 1px solid #DEE2E6;
        border-radius: 8px;
    }

/* Select2 */
.select2-container--bootstrap-5 .select2-selection--single {
    min-height: 42px;
}


/* ==========================================================
   AJUSTES PARA CELULARES
   ========================================================== */

@media screen and (max-width: 768px) {

    .vehiculo-info-grid {
        grid-template-columns: 1fr;
    }

    .vehiculo-info-item-wide {
        grid-column: span 1;
    }

    .vehiculo-delete-summary {
        grid-template-columns: 1fr;
    }

    .vehiculo-avatar {
        width: 90px;
        height: 90px;
        font-size: 3.5rem;
    }

    .vehiculo-placa-grande {
        min-width: 120px;
        font-size: 1rem;
    }
}

/* ==========================================================
   MÓDULO DE ÓRDENES DE SERVICIO - TRZ COMPANY SAC

   Copiar este bloque al FINAL de:
   wwwroot/css/site.css
   ========================================================== */

/* Pestañas del flujo operativo */
.taller-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 10px;
    background-color: #FFFFFF;
    border: 1px solid #E9ECEF;
    border-radius: 12px;
    box-shadow: 0 0.125rem 0.35rem rgba(0, 0, 0, 0.06);
}

    .taller-tabs .nav-link {
        color: #6C757D;
        font-weight: 600;
        border-radius: 9px;
        transition: all 0.2s ease-in-out;
    }

        .taller-tabs .nav-link:hover {
            color: var(--trz-navy);
            background-color: rgba(48, 70, 111, 0.07);
        }

        .taller-tabs .nav-link.active {
            color: #FFFFFF;
            background-color: var(--trz-coral);
        }

/* Encabezados corporativos */
.taller-form-header,
.taller-modal-header {
    color: #FFFFFF;
    background-color: var(--trz-navy);
    border-bottom: 4px solid var(--trz-coral);
}

/* Número de paso */
.taller-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    margin-right: 8px;
    color: #FFFFFF;
    background-color: var(--trz-coral);
    font-size: 0.9rem;
    border-radius: 50%;
}

/* Tabla */
.taller-table td {
    vertical-align: middle;
}

.taller-estado {
    min-width: 150px;
    padding: 8px;
    font-size: 0.72rem;
    text-align: center;
}

/* Cuadros de información */
.taller-info-item {
    padding: 10px 0;
    border-bottom: 1px solid #E9ECEF;
}

    .taller-info-item small,
    .taller-delete-summary small {
        display: block;
        color: #6C757D;
        font-size: 0.75rem;
        text-transform: uppercase;
    }

    .taller-info-item p,
    .taller-delete-summary p {
        margin-bottom: 0;
        color: var(--trz-text);
        font-weight: 600;
    }

/* Diagnóstico */
.taller-diagnostico-box {
    min-height: 100px;
    padding: 15px;
    background-color: rgba(48, 70, 111, 0.08);
    border: 1px solid rgba(48, 70, 111, 0.16);
    border-radius: 8px;
}

/* Eliminación */
.taller-delete-icon {
    font-size: 5rem;
}

.taller-delete-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

    .taller-delete-summary div {
        padding: 12px;
        background-color: #F8F9FA;
        border: 1px solid #DEE2E6;
        border-radius: 8px;
    }

/* Ticket */
.ticket-servicio {
    background-color: #FFFFFF;
}

/* Impresión */
@media print {

    #sidebar,
    .navbar-trz,
    .footer,
    .d-print-none {
        display: none !important;
    }

    #content {
        padding-left: 0 !important;
    }

    main {
        padding: 0 !important;
    }

    body {
        background-color: #FFFFFF !important;
    }

    .container {
        width: 100% !important;
        max-width: 100% !important;
    }

    .card {
        border: none !important;
        box-shadow: none !important;
    }

    .ticket-servicio {
        padding: 0 !important;
    }
}

/* Responsive */
@media screen and (max-width: 768px) {

    .taller-tabs {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

        .taller-tabs .nav-link {
            width: 100%;
            text-align: left;
        }

    .taller-delete-summary {
        grid-template-columns: 1fr;
    }

    .taller-estado {
        min-width: 130px;
    }
}

@media screen and (max-width: 450px) {

    .taller-tabs {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================
   MÓDULO DE COTIZACIONES - TRZ COMPANY SAC
   Copiar este bloque al FINAL de wwwroot/css/site.css
   ========================================================== */

.cotizacion-form-header,
.cotizacion-modal-header {
    color: #FFFFFF;
    background-color: var(--trz-navy);
    border-bottom: 4px solid var(--trz-coral);
}

.cotizacion-total-box {
    padding: 15px;
    background-color: #F8F9FA;
    border: 1px solid #DEE2E6;
    border-left: 4px solid var(--trz-coral);
    border-radius: 10px;
}

.cotizacion-disabled-block {
    opacity: 0.45;
}

.cotizacion-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 18px 0;
    color: #6C757D;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
}

    .cotizacion-divider::before,
    .cotizacion-divider::after {
        flex: 1;
        height: 1px;
        background-color: #DEE2E6;
        content: "";
    }

.vehiculo-placa-small {
    min-width: 78px;
    padding: 5px 9px;
    font-size: 0.78rem;
}

@media screen and (max-width: 768px) {
    .cotizacion-total-box {
        margin-top: 5px;
    }
}

/* ==========================================================
   MÓDULO DE VENTAS - TRZ COMPANY SAC

   Copiar este bloque al FINAL de:
   wwwroot/css/site.css
   ========================================================== */

/* Encabezado corporativo */
.venta-form-header {
    color: #FFFFFF;
    background-color: var(--trz-navy);
    border-bottom: 4px solid var(--trz-coral);
}

/* Caja de totales del carrito */
.venta-total-box {
    padding: 15px;
    background-color: #F8F9FA;
    border: 1px solid #DEE2E6;
    border-left: 4px solid var(--trz-coral);
    border-radius: 10px;
}

/* Contenedor del comprobante */
.venta-ticket-wrapper {
    display: flex;
    justify-content: center;
}

/* Diseño tipo boleta o ticket */
.venta-ticket {
    width: 100%;
    max-width: 520px;
    padding: 24px;
    background-color: #FFFFFF;
    border: 1px solid #DEE2E6;
    border-top: 5px solid var(--trz-coral);
    border-radius: 10px;
    box-shadow: 0 0.35rem 1rem rgba(0, 0, 0, 0.10);
}

.venta-ticket-header h3 {
    color: var(--trz-navy);
}

.venta-ticket-divider {
    margin: 15px 0;
    border-top: 1px dashed #ADB5BD;
}

.venta-ticket-data {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-size: 0.9rem;
}

.venta-ticket-table {
    width: 100%;
    border-collapse: collapse;
}

    .venta-ticket-table th,
    .venta-ticket-table td {
        padding: 8px 4px;
        font-size: 0.88rem;
        border-bottom: 1px solid #E9ECEF;
    }

    .venta-ticket-table th {
        color: var(--trz-navy);
        font-size: 0.74rem;
        text-transform: uppercase;
    }

.venta-ticket-total-row {
    display: flex;
    justify-content: space-between;
    padding: 3px 0;
}

.venta-ticket-grand-total {
    margin-top: 4px;
    color: #198754;
    font-size: 1.25rem;
    font-weight: 700;
}

/* Impresión tipo ticket */
@media print {

    #sidebar,
    .navbar-trz,
    .footer,
    .d-print-none {
        display: none !important;
    }

    #content {
        padding-left: 0 !important;
    }

    main {
        padding: 0 !important;
    }

    body {
        background-color: #FFFFFF !important;
    }

    .container {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .venta-ticket {
        width: 80mm;
        max-width: 80mm;
        padding: 8px;
        border: none;
        border-top: 2px solid #000000;
        border-radius: 0;
        box-shadow: none;
    }

        .venta-ticket-table th,
        .venta-ticket-table td,
        .venta-ticket-data,
        .venta-ticket .small {
            font-size: 10px !important;
        }

    .venta-ticket-header h3 {
        font-size: 17px;
    }
}

/* ==========================================================
   MÓDULO DE CITAS - TRZ COMPANY SAC
   Copiar al FINAL de wwwroot/css/site.css
   ========================================================== */

.cita-form-header,
.cita-modal-header {
    color: #FFFFFF;
    background-color: var(--trz-navy);
    border-bottom: 4px solid var(--trz-coral);
}

#calendar {
    padding: 12px;
    background-color: #FFFFFF;
    border-radius: 12px;
}

.fc .fc-toolbar-title {
    color: var(--trz-text);
    font-size: 1.35rem;
    font-weight: 700;
    text-transform: capitalize;
}

.fc .fc-button-primary {
    background-color: var(--trz-navy);
    border-color: var(--trz-navy);
}

    .fc .fc-button-primary:hover,
    .fc .fc-button-primary:focus,
    .fc .fc-button-primary:not(:disabled).fc-button-active {
        background-color: var(--trz-coral);
        border-color: var(--trz-coral);
    }

.fc-event {
    padding: 3px 7px !important;
    cursor: pointer;
    border: none !important;
    border-radius: 6px !important;
    transition: transform 0.2s ease-in-out, filter 0.2s ease-in-out;
}

    .fc-event:hover {
        transform: scale(1.02);
        filter: brightness(92%);
    }

.estado-programada {
    background-color: var(--trz-navy) !important;
    border-left: 4px solid var(--trz-coral) !important;
}

.estado-realizada {
    background-color: #198754 !important;
    border-left: 4px solid #0F5132 !important;
}

.estado-cancelada {
    background-color: #DC3545 !important;
    border-left: 4px solid #842029 !important;
}

.cita-event-content {
    color: #FFFFFF;
    overflow: hidden;
}

.cita-event-time {
    font-size: 0.68rem;
    font-weight: 700;
}

.cita-event-title {
    overflow: hidden;
    font-size: 0.78rem;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cita-legend {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    background-color: #FFFFFF;
    font-size: 0.78rem;
    font-weight: 600;
    border: 1px solid #DEE2E6;
    border-radius: 20px;
}

.cita-legend-programada i {
    color: var(--trz-navy);
}

.cita-legend-realizada i {
    color: #198754;
}

.cita-legend-cancelada i {
    color: #DC3545;
}

.cita-step-box {
    padding: 15px;
    background-color: #F8F9FA;
    border: 1px solid #E9ECEF;
    border-left: 4px solid var(--trz-coral);
    border-radius: 10px;
}

.cita-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    margin-right: 6px;
    color: #FFFFFF;
    background-color: var(--trz-coral);
    font-size: 0.82rem;
    border-radius: 50%;
}

@media screen and (max-width: 768px) {
    #calendar {
        padding: 4px;
        border-radius: 0;
    }

    .fc .fc-toolbar {
        gap: 5px;
        margin-bottom: 0.6rem !important;
    }

    .fc .fc-toolbar-title {
        font-size: 0.95rem;
    }

    .fc .fc-button {
        padding: 0.3rem 0.45rem;
        font-size: 0.68rem;
    }

    .fc .fc-col-header-cell-cushion {
        font-size: 0.62rem;
    }

    .fc .fc-daygrid-day-number {
        font-size: 0.72rem;
    }

    .cita-event-time {
        font-size: 0.58rem;
    }
}

/* ==========================================================
   MÓDULO DE FIDELIZACIÓN - TRZ COMPANY SAC

   Copiar este bloque al FINAL de:
   wwwroot/css/site.css
   ========================================================== */

/* Encabezado principal */
.fidelizacion-hero {
    color: #FFFFFF;
    background: linear-gradient( 135deg, var(--trz-navy), var(--trz-navy-dark) );
    border-left: 6px solid var(--trz-coral) !important;
}

.fidelizacion-hero-subtitle {
    color: rgba(255, 255, 255, 0.72);
}

/* Indicadores */
.fidelizacion-stat-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 108px;
    padding: 16px;
    background-color: #FFFFFF;
    border: 1px solid #E9ECEF;
    border-left: 5px solid transparent;
    border-radius: 12px;
    box-shadow: 0 0.125rem 0.35rem rgba(0, 0, 0, 0.06);
}

    .fidelizacion-stat-card small {
        display: block;
        color: #6C757D;
        font-size: 0.74rem;
        font-weight: 700;
        text-transform: uppercase;
    }

    .fidelizacion-stat-card h3 {
        margin-bottom: 0;
        color: var(--trz-text);
        font-weight: 700;
    }

    .fidelizacion-stat-card > i {
        font-size: 2rem;
    }

.fidelizacion-stat-critical {
    border-left-color: #DC3545;
}

    .fidelizacion-stat-critical > i {
        color: #DC3545;
    }

.fidelizacion-stat-overdue {
    border-left-color: #FFC107;
}

    .fidelizacion-stat-overdue > i {
        color: #FFC107;
    }

.fidelizacion-stat-next {
    border-left-color: #0DCAF0;
}

    .fidelizacion-stat-next > i {
        color: #0DCAF0;
    }

.fidelizacion-stat-ok {
    border-left-color: #198754;
}

    .fidelizacion-stat-ok > i {
        color: #198754;
    }


/* ==========================================================
   AJUSTES PARA CELULARES
   ========================================================== */

@media screen and (max-width: 768px) {

    .fidelizacion-stat-card {
        min-height: 94px;
        padding: 13px;
    }

        .fidelizacion-stat-card > i {
            font-size: 1.55rem;
        }

        .fidelizacion-stat-card h3 {
            font-size: 1.55rem;
        }
}

/* ==========================================================
   MÓDULO DE USUARIOS - TRZ COMPANY SAC

   Copiar este bloque al FINAL de:
   wwwroot/css/site.css
   ========================================================== */

/* Encabezado de formularios */
.usuario-form-header {
    color: #FFFFFF;
    background-color: var(--trz-navy);
    border-bottom: 4px solid var(--trz-coral);
}

/* Avatar */
.usuario-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 105px;
    height: 105px;
    margin-right: auto;
    margin-left: auto;
    color: var(--trz-coral);
    background-color: rgba(244, 124, 91, 0.10);
    font-size: 4rem;
    border: 2px solid rgba(244, 124, 91, 0.25);
    border-radius: 50%;
}

/* Tarjetas de ranking */
.usuario-ranking-card {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

    .usuario-ranking-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.10) !important;
    }

/* Barra de avance */
.usuario-progress {
    height: 9px;
    border-radius: 8px;
}

/* Diagnóstico largo */
.usuario-diagnostico-cell {
    max-width: 320px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Correo largo */
.usuario-email-ajustable {
    overflow-wrap: anywhere;
}

/* Pestañas */
.usuario-tabs .nav-link {
    color: var(--trz-navy);
}

    .usuario-tabs .nav-link.active {
        color: var(--trz-coral);
        font-weight: 700;
    }

@media screen and (max-width: 768px) {
    .usuario-avatar {
        width: 90px;
        height: 90px;
        font-size: 3.4rem;
    }

    .usuario-diagnostico-cell {
        max-width: 190px;
    }
}

/* ==========================================================
   MÓDULO DE GASTOS - TRZ COMPANY SAC

   Copiar este bloque al FINAL de:
   wwwroot/css/site.css
   ========================================================== */

/* Contenedor de formularios */
.gastos-form-container {
    max-width: 820px;
}

/* Encabezados */
.gasto-form-header,
.gasto-modal-header {
    color: #FFFFFF;
    background-color: var(--trz-navy);
    border-bottom: 4px solid var(--trz-coral);
}

/* Monto principal */
.gasto-monto-input {
    color: var(--trz-navy);
    background-color: rgba(244, 124, 91, 0.10);
    font-size: 2.4rem;
    font-weight: 700;
    border: 1px solid rgba(244, 124, 91, 0.30);
}

/* Impuesto */
.gasto-tax-box {
    padding: 15px;
    background-color: #F8F9FA;
    border: 1px solid #DEE2E6;
    border-left: 4px solid var(--trz-coral);
    border-radius: 10px;
}

/* Detalle */
.gasto-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

    .gasto-detail-grid div {
        padding: 12px;
        background-color: #F8F9FA;
        border: 1px solid #DEE2E6;
        border-radius: 8px;
    }

    .gasto-detail-grid small {
        display: block;
        color: #6C757D;
        font-size: 0.72rem;
        text-transform: uppercase;
    }

    .gasto-detail-grid p {
        margin-bottom: 0;
        color: var(--trz-text);
        font-weight: 600;
        overflow-wrap: anywhere;
    }

.gasto-detail-wide {
    grid-column: span 2;
}

/* Comprobante */
.gasto-factura-img {
    max-height: 520px;
}

.gasto-pdf-frame {
    width: 100%;
    height: 520px;
    background-color: #FFFFFF;
    border: 1px solid #DEE2E6;
    border-radius: 8px;
}

.gasto-empty-icon {
    color: #ADB5BD;
    font-size: 4.5rem;
}

/* Archivo de actualización */
.gasto-upload-box {
    padding: 15px;
    background-color: #F8F9FA;
    border: 1px dashed #CED4DA;
    border-radius: 10px;
}

/* Agenda de gastos fijos */
.gasto-fijo-badge {
    color: #30466F;
    background-color: rgba(48, 70, 111, 0.10);
    border: 1px solid rgba(48, 70, 111, 0.20);
}


/* ==========================================================
   AJUSTES PARA CELULARES
   ========================================================== */

@media screen and (max-width: 768px) {

    .gasto-monto-input {
        font-size: 1.9rem;
    }

    .gasto-detail-grid {
        grid-template-columns: 1fr;
    }

    .gasto-detail-wide {
        grid-column: span 1;
    }

    .gasto-pdf-frame {
        height: 420px;
    }
}

/* ==========================================================
   MÓDULO DE CAJA - TRZ COMPANY SAC
   Copiar este bloque al FINAL de wwwroot/css/site.css
   ========================================================== */

.caja-form-header {
    color: #FFFFFF;
    background-color: var(--trz-navy);
    border-bottom: 4px solid var(--trz-coral);
}

.caja-safe-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100px;
    height: 100px;
    margin-right: auto;
    margin-left: auto;
    color: var(--trz-coral);
    background-color: rgba(244, 124, 91, 0.10);
    font-size: 4rem;
    border: 2px solid rgba(244, 124, 91, 0.20);
    border-radius: 50%;
}

.caja-count-box {
    padding: 20px;
    background-color: #F8F9FA;
    border: 1px solid #DEE2E6;
    border-left: 4px solid var(--trz-coral);
    border-radius: 10px;
}

.caja-summary-card {
    border-left-width: 5px !important;
    border-left-style: solid !important;
}

.caja-summary-success {
    border-left-color: #198754 !important;
}

.caja-summary-danger {
    border-left-color: #DC3545 !important;
}

.caja-summary-divider {
    border-left: 1px solid #DEE2E6;
}

@media print {
    #sidebar,
    .navbar-trz,
    .footer,
    .d-print-none {
        display: none !important;
    }

    #content {
        padding-left: 0 !important;
    }

    main {
        padding: 0 !important;
    }

    body {
        background-color: #FFFFFF !important;
    }

    .container-fluid {
        width: 100% !important;
        padding: 0 !important;
    }

    .card {
        border: 1px solid #DEE2E6 !important;
        box-shadow: none !important;
    }
}

@media screen and (max-width: 768px) {
    .caja-summary-divider {
        border-left: none;
    }

    .caja-safe-icon {
        width: 86px;
        height: 86px;
        font-size: 3.3rem;
    }
}
/* ==========================================================
   MÓDULO DE LOGIN - TRZ COMPANY SAC
   Copiar este bloque al FINAL de wwwroot/css/site.css
   ========================================================== */
.login-page {
    min-height: 100vh;
    margin: 0;
    background: #F5F7FB;
}

.login-shell {
    display: grid;
    min-height: 100vh;
    grid-template-columns: minmax(360px,46%) 1fr;
}

.login-brand-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    padding: 48px;
    color: #fff;
    background: linear-gradient(145deg,rgba(36,54,83,.98),rgba(48,70,111,.94));
}

    .login-brand-panel::before, .login-brand-panel::after {
        position: absolute;
        border-radius: 50%;
        content: "";
    }

    .login-brand-panel::before {
        top: -130px;
        right: -90px;
        width: 320px;
        height: 320px;
        background: rgba(244,124,91,.20);
    }

    .login-brand-panel::after {
        bottom: -180px;
        left: -150px;
        width: 420px;
        height: 420px;
        background: rgba(255,255,255,.06);
    }

.login-brand-content {
    position: relative;
    z-index: 1;
    max-width: 560px;
}

.login-brand-mark {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 90px;
    height: 90px;
    margin-bottom: 24px;
    color: #fff;
    background: var(--trz-coral);
    font-size: 3.3rem;
    border-radius: 26px;
    box-shadow: 0 14px 34px rgba(0,0,0,.18);
}

.login-brand-eyebrow {
    margin-bottom: 5px;
    color: rgba(255,255,255,.70);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .18em;
}

.login-brand-title {
    margin-bottom: 16px;
    color: #fff;
    font-size: clamp(2.5rem,5vw,4.5rem);
    font-weight: 800;
    letter-spacing: -.04em;
}

    .login-brand-title span {
        display: block;
        color: var(--trz-coral);
        font-size: .42em;
        letter-spacing: .11em;
    }

.login-brand-subtitle {
    max-width: 520px;
    color: rgba(255,255,255,.82);
    font-size: 1.05rem;
    line-height: 1.7;
}

.login-brand-features {
    display: grid;
    gap: 13px;
    margin-top: 32px;
}

    .login-brand-features div {
        display: flex;
        align-items: center;
        gap: 11px;
        color: rgba(255,255,255,.90);
    }

    .login-brand-features i {
        color: var(--trz-coral);
        font-size: 1.15rem;
    }

.login-form-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 34px;
}

.login-card {
    width: 100%;
    max-width: 450px;
    padding: 34px;
    background: #fff;
    border: 1px solid #E9ECEF;
    border-radius: 18px;
    box-shadow: 0 16px 42px rgba(36,54,83,.12);
}

.login-mobile-logo {
    display: none;
    color: var(--trz-coral);
    font-size: 3.2rem;
}

.login-card .input-group-text {
    color: var(--trz-navy);
    background: #F8F9FA;
}

.login-card .form-control:focus {
    border-color: var(--trz-coral);
    box-shadow: 0 0 0 .25rem rgba(244,124,91,.15);
}

.login-security-note {
    color: #6C757D;
    font-size: .78rem;
}

.login-footer {
    margin-top: 24px;
    padding-top: 18px;
    color: #6C757D;
    font-size: .78rem;
    text-align: center;
    border-top: 1px solid #E9ECEF;
}

.access-denied-header {
    height: 8px;
    background: var(--trz-coral);
}

.access-denied-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 112px;
    height: 112px;
    margin: auto;
    color: #DC3545;
    background: rgba(220,53,69,.08);
    font-size: 4.7rem;
    border: 2px solid rgba(220,53,69,.14);
    border-radius: 50%;
}

@media screen and (max-width:900px) {
    .login-shell {
        display: block;
    }

    .login-brand-panel {
        display: none;
    }

    .login-form-panel {
        min-height: 100vh;
        padding: 20px;
    }

    .login-card {
        max-width: 430px;
        padding: 28px 22px;
    }

    .login-mobile-logo {
        display: block;
    }
}

/* ==========================================================
   MÓDULO DE NOTIFICACIONES - TRZ COMPANY SAC

   Copiar este bloque al FINAL de:
   wwwroot/css/site.css
   ========================================================== */

/* Elementos del listado */
.notificacion-item {
    padding: 18px;
    transition: background-color 0.2s ease-in-out, opacity 0.2s ease-in-out, border-color 0.2s ease-in-out;
}

.notificacion-no-leida {
    background-color: rgba(244, 124, 91, 0.04);
    border-left: 4px solid var(--trz-coral) !important;
}

.notificacion-leida {
    opacity: 0.72;
    background-color: #FFFFFF;
    border-left: 4px solid transparent !important;
}

/* Icono circular */
.notificacion-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 44px;
    height: 44px;
    border-radius: 50%;
}

.notificacion-icon-pendiente {
    color: #DC3545;
    background-color: rgba(220, 53, 69, 0.10);
}

.notificacion-icon-leida {
    color: #198754;
    background-color: rgba(25, 135, 84, 0.10);
}


/* ==========================================================
   CELULARES
   ========================================================== */

@media screen and (max-width: 768px) {

    .notificacion-item {
        padding: 15px;
    }

    .notificacion-icon {
        width: 38px;
        height: 38px;
    }
}
