/* ============================================
   Total Gas LP - Personalización
   ============================================ */

/* Logo - imagen completa por defecto, icono cuando colapsado */
.sidebar-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
}
.sidebar-logo .tg-logo-full {
    display: block;
}
.sidebar-logo .tg-logo-icon {
    display: none;
}
/* Cuando el sidebar está colapsado: oculta logo full y muestra solo icono */
body.active .sidebar .sidebar-logo .tg-logo-full,
.sidebar.active .sidebar-logo .tg-logo-full {
    display: none !important;
}
body.active .sidebar .sidebar-logo .tg-logo-icon,
.sidebar.active .sidebar-logo .tg-logo-icon {
    display: block !important;
}

/* Vista del recibo / pedido */
.recibo-card {
    background: #fff;
    border: 1px solid #eef0f3;
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

.recibo-header-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px;
    align-items: start;
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid #eef0f3;
}

.recibo-bank-box, .recibo-num-box {
    border: 1px solid #2c3e50;
    border-radius: 6px;
    overflow: hidden;
    text-align: center;
}
.recibo-bank-box .header,
.recibo-num-box .header {
    background: #1a1a1a;
    color: #fff;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 700;
}
.recibo-bank-box .body { padding: 8px 10px; font-size: 12px; }
.recibo-num-box .body { padding: 10px; font-size: 22px; font-weight: 700; }

.recibo-logo {
    font-size: 28px;
    font-weight: 700;
    color: var(--primary-600);
    line-height: 1;
}

.total-pagar-box {
    background: linear-gradient(135deg, #fff5e6 0%, #ffe3b8 100%);
    border: 2px solid #ff7a00;
    padding: 20px 28px;
    border-radius: 10px;
    margin: 24px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.total-pagar-box .label {
    font-size: 20px;
    font-weight: 800;
    color: #1a1a1a;
    letter-spacing: 0.5px;
}
.total-pagar-box .monto {
    font-size: 32px;
    font-weight: 800;
    color: #d65a00;
}

/* Vista previa de imagen */
.img-preview {
    max-width: 200px;
    max-height: 200px;
    border-radius: 8px;
    margin-top: 8px;
    border: 1px solid #e0e3e7;
    object-fit: cover;
    display: block;
}

/* Cards de direcciones */
.direccion-card {
    background: #fafbfc;
    border: 1px solid #e0e3e7;
    border-radius: 8px;
    padding: 20px;
    margin-bottom: 16px;
}

/* Sección de info de dirección en form de pedido */
.info-direccion-box {
    background: #f4f6f8;
    border-left: 4px solid var(--primary-600);
    padding: 12px 16px;
    border-radius: 6px;
    margin-top: 12px;
    font-size: 13px;
}

/* Stats card customización */
.stat-card-custom {
    background: #fff;
    padding: 24px;
    border-radius: 12px;
    border: 1px solid #eef0f3;
    transition: transform 0.2s, box-shadow 0.2s;
}
.stat-card-custom:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

/* Print styles para impresión del recibo */
@media print {
    .sidebar, .navbar-header, .d-footer, .no-print {
        display: none !important;
    }
    .dashboard-main-body { padding: 0 !important; margin: 0 !important; }
    .dashboard-main { margin: 0 !important; }
    .recibo-card { box-shadow: none !important; border: none !important; }
}

/* Title de grupo en sidebar */
.sidebar-menu-group-title {
    padding: 12px 16px 6px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--primary-light);
    letter-spacing: 0.5px;
    list-style: none;
    margin-top: 12px;
}

/* ===========================================================
   Fix global: iconify-icon dentro de títulos, headers y labels
   Antes: el icono se renderizaba en bloque y se acomodaba arriba del texto
   Ahora: queda inline, alineado verticalmente con el texto
   =========================================================== */
iconify-icon {
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
    line-height: 1;
}

/* Asegura que iconify-icon dentro de h1-h6, card-title, card-header
   se alinee correctamente con el texto */
h1 iconify-icon, h2 iconify-icon, h3 iconify-icon,
h4 iconify-icon, h5 iconify-icon, h6 iconify-icon,
.card-title iconify-icon,
.card-header iconify-icon,
.modal-title iconify-icon,
label iconify-icon,
.form-label iconify-icon,
.btn iconify-icon,
.alert iconify-icon,
li iconify-icon,
.breadcrumb iconify-icon {
    display: inline-block;
    vertical-align: -0.125em; /* alineación óptica con el texto */
    margin-right: 0.25em;
    line-height: 1;
}

/* Cuando ya tiene clase me-X (margin-end) de Bootstrap, respeta esa clase */
h1 iconify-icon[class*="me-"], h2 iconify-icon[class*="me-"],
h3 iconify-icon[class*="me-"], h4 iconify-icon[class*="me-"],
h5 iconify-icon[class*="me-"], h6 iconify-icon[class*="me-"],
.card-title iconify-icon[class*="me-"],
.modal-title iconify-icon[class*="me-"] {
    margin-right: 0;
}

/* Si el icono está dentro de un d-flex con gap, no añadir margin extra */
.d-flex iconify-icon {
    margin-right: 0;
}

/* ===========================================================
   Bloque 5: Mejoras UX/UI
   =========================================================== */

/* Selectores rápidos de fecha */
.date-quick-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 8px;
}
.date-quick-buttons .btn-quick-date {
    padding: 4px 12px;
    border: 1px solid #e0e0e0;
    background: #f8f9fa;
    border-radius: 16px;
    font-size: 12px;
    color: #666;
    cursor: pointer;
    transition: all 0.15s;
}
.date-quick-buttons .btn-quick-date:hover {
    background: #fff5e6;
    border-color: #ff7a00;
    color: #d65a00;
}
.date-quick-buttons .btn-quick-date.active {
    background: #ff7a00;
    color: #fff;
    border-color: #ff7a00;
}

/* Mejoras móviles */
@media (max-width: 768px) {
    /* Tablas con scroll horizontal automático */
    .table-responsive { -webkit-overflow-scrolling: touch; }

    /* Cards con padding más cómodo */
    .card-body { padding: 1rem !important; }

    /* Botones más grandes para tocar */
    .btn-sm { padding: 6px 12px !important; font-size: 13px !important; }

    /* Breadcrumbs más compactos */
    ul.d-flex.align-items-center.gap-2 { font-size: 12px; }

    /* KPIs apilados */
    .kpi-card { padding: 14px !important; }
    .kpi-value { font-size: 22px !important; }

    /* Modal más amigable */
    .modal-dialog { margin: 8px !important; }

    /* Inputs un poco más grandes para tocar */
    .form-control, .form-select { font-size: 14px !important; }

    /* Sidebar móvil overlay con sombra */
    .sidebar.active { box-shadow: 4px 0 20px rgba(0,0,0,0.2); }

    /* h6 títulos un poco más grandes en móvil para mejor lectura */
    h6.fw-semibold.mb-0 { font-size: 16px; }
}

/* Toast notifications (no usadas aún pero listas) */
.toast-container-custom {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.toast-custom {
    background: #fff;
    border-left: 4px solid #28a745;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    padding: 12px 18px;
    border-radius: 6px;
    min-width: 280px;
    animation: slideInRight 0.3s ease;
}
.toast-custom.danger { border-left-color: #dc3545; }
.toast-custom.warning { border-left-color: #ff7a00; }
@keyframes slideInRight {
    from { transform: translateX(120%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

/* Mejoras al modal de búsqueda global */
#modal_busqueda_global .modal-dialog {
    max-width: 600px;
}
.busqueda-item:hover {
    background-color: #fff5e6 !important;
}

/* kbd estilo consistente */
kbd {
    background: #f8f9fa;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 2px 6px;
    font-size: 11px;
    color: #555;
    font-family: monospace;
    box-shadow: 0 1px 0 rgba(0,0,0,0.1);
}
