/* ═══════════════════════════════════════════════════════════
   0. CSS CUSTOM PROPERTIES — Tema Vivo
═══════════════════════════════════════════════════════════ */
:root {
    --vivo-primary:        #E84E0F;
    --vivo-primary-dark:   #c43d0c;
    --vivo-primary-darker: #b33a0b;
    --vivo-light:          #fff3ee;
    --vivo-tint:           #fff5f0;
    --vivo-warm:           #ffe8da;
    --vivo-pale:           #FCD1BF;
    --vivo-border:         #f5c6ac;
    --vivo-dark:           #6B1A00;
    --vivo-shadow-xs:      rgba(232, 78, 15, 0.12);
    --vivo-shadow-sm:      rgba(232, 78, 15, 0.15);
    --vivo-shadow-md:      rgba(232, 78, 15, 0.18);
    --vivo-shadow-lg:      rgba(232, 78, 15, 0.25);
    --vivo-bg-alpha:       rgba(232, 78, 15, 0.10);

    /* Bootstrap primary override */
    --bs-primary:          var(--vivo-primary);
    --bs-primary-rgb:      232, 78, 15;

    /* Bootstrap link override */
    --bs-link-color:            var(--vivo-primary);
    --bs-link-color-rgb:        232, 78, 15;
    --bs-link-hover-color:      var(--vivo-primary-dark);
    --bs-link-hover-color-rgb:  196, 61, 12;

    /* Bootstrap accordion override */
    --bs-accordion-active-color:         var(--vivo-primary);
    --bs-accordion-active-bg:            var(--vivo-tint);
    --bs-accordion-btn-focus-box-shadow: 0 0 0 0.25rem var(--vivo-shadow-lg);
    --bs-accordion-border-color:         var(--vivo-border);
    /* Icono chevron en estado expandido con color primario */
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23E84E0F'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

/* ───────────────────────────────────────────────────────────
   Tema SM — clase aplicada via ClaseCssPrincipal de la tienda
   Admin: Tiendas → Clase CSS principal = "tema-sm"
─────────────────────────────────────────────────────────── */
body.tema-sm {
    --vivo-primary:        #E0130C;
    --vivo-primary-dark:   #b30f09;
    --vivo-primary-darker: #920c08;
    --vivo-light:          #fff0f0;
    --vivo-tint:           #fff5f5;
    --vivo-warm:           #fce3e2;
    --vivo-pale:           #F98A86;
    --vivo-border:         #f5b4b2;
    --vivo-dark:           #3a3a3a;
    --vivo-shadow-xs:      rgba(224, 19, 12, 0.12);
    --vivo-shadow-sm:      rgba(224, 19, 12, 0.15);
    --vivo-shadow-md:      rgba(224, 19, 12, 0.18);
    --vivo-shadow-lg:      rgba(224, 19, 12, 0.25);
    --vivo-bg-alpha:       rgba(224, 19, 12, 0.10);

    /* Secundario azul SM */
    --vivo-secondary:       #0077A3;
    --vivo-secondary-light: #D8E0E9;

    /* Footer copyright */
    --footer-copyright-bg: #000000;

    /* Bootstrap overrides */
    --bs-primary:          var(--vivo-primary);
    --bs-primary-rgb:      224, 19, 12;
    --bs-link-color:       var(--vivo-primary);
    --bs-link-color-rgb:   224, 19, 12;
    --bs-link-hover-color: var(--vivo-primary-dark);
    --bs-link-hover-color-rgb: 179, 15, 9;
    --bs-accordion-active-color:         var(--vivo-primary);
    --bs-accordion-active-bg:            var(--vivo-tint);
    --bs-accordion-btn-focus-box-shadow: 0 0 0 0.25rem var(--vivo-shadow-lg);
    --bs-accordion-border-color:         var(--vivo-border);
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23E0130C'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");

    /* Bootstrap secondary → azul SM */
    --bs-secondary:     var(--vivo-secondary);
    --bs-secondary-rgb: 0, 119, 163;
}

/* form-control focus — usa el primary de cada tema en lugar del azul Bootstrap */
.form-control:focus {
    border-color: var(--vivo-primary);
    box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .25);
}

/* Footer copyright: negro con texto gris-azulado */
body.tema-sm .footer-copyright {
    background-color: var(--footer-copyright-bg);
    border-top-color: rgba(255, 255, 255, 0.15);
}
body.tema-sm .footer-copyright p {
    color: #D8E0E9;
}

/* Pack cards — iconos informativos en azul SM */
body.tema-sm .pack-card__oficial i,
body.tema-sm .pack-card__header-label i,
body.tema-sm .pack-card__header-student .bi-person-fill {
    color: var(--vivo-secondary);
}

/* Resumen carrito — iconos de features en azul SM */
body.tema-sm .resumen-features .feature-item i {
    color: var(--vivo-secondary);
}

/* Badge carrito en azul SM */
body.tema-sm .cart-badge {
    background: var(--vivo-secondary);
}

/* Home — numeración de pasos en azul SM */
body.tema-sm .paso-numero {
    color: var(--vivo-secondary);
}

/* Home — ola SVG de pasos en azul SM */
body.tema-sm .pasos-wave path,
body.tema-sm .pasos-wave polyline,
body.tema-sm .pasos-wave line {
    stroke: var(--vivo-secondary);
}

/* Home — títulos y burbujas de pasos en azul SM */
body.tema-sm .paso-titulo {
    color: var(--vivo-secondary);
}
body.tema-sm .paso-burbuja {
    background-color: var(--vivo-secondary-light);
    color: var(--vivo-secondary);
    box-shadow: 0 4px 16px rgba(0, 119, 163, 0.18);
}

/* Bloque contacto en tema SM: fondo gris-azulado, título negro */
body.tema-sm .bloque-contacto {
    background-color: var(--vivo-secondary-light);
    border-top-color: rgba(0, 119, 163, 0.2);
}
body.tema-sm .bloque-contacto-titulo {
    color: #1a1a1a;
}
body.tema-sm .bloque-contacto-telefono {
    color: var(--vivo-secondary);
}

/* Video card en tema SM: icono y título azul SM */
body.tema-sm .video-card-play-icon {
    color: var(--vivo-secondary);
}
body.tema-sm .video-card-titulo {
    color: var(--vivo-secondary);
}
body.tema-sm .video-carousel-dot.activo {
    background-color: var(--vivo-secondary);
}

/* btn-secondary y btn-outline-secondary en azul SM */
body.tema-sm .btn-secondary {
    --bs-btn-color:              #fff;
    --bs-btn-bg:                 var(--vivo-secondary);
    --bs-btn-border-color:       var(--vivo-secondary);
    --bs-btn-hover-color:        #fff;
    --bs-btn-hover-bg:           #005f82;
    --bs-btn-hover-border-color: #005f82;
    --bs-btn-active-color:       #fff;
    --bs-btn-active-bg:          #005880;
    --bs-btn-active-border-color:#005880;
    --bs-btn-disabled-bg:        var(--vivo-secondary);
    --bs-btn-disabled-border-color: var(--vivo-secondary);
}
body.tema-sm .btn-outline-secondary {
    --bs-btn-color:              var(--vivo-secondary);
    --bs-btn-border-color:       var(--vivo-secondary);
    --bs-btn-hover-color:        #fff;
    --bs-btn-hover-bg:           var(--vivo-secondary);
    --bs-btn-hover-border-color: var(--vivo-secondary);
    --bs-btn-active-color:       #fff;
    --bs-btn-active-bg:          var(--vivo-secondary);
    --bs-btn-active-border-color:var(--vivo-secondary);
    --bs-btn-disabled-color:     var(--vivo-secondary);
    --bs-btn-disabled-border-color: var(--vivo-secondary);
}

/* Filtro de modalidad/asignatura en azul SM */
body.tema-sm .filtro-pill {
    border-color: var(--vivo-secondary);
    color: var(--vivo-secondary);
}
body.tema-sm .filtro-pill:hover {
    background: var(--vivo-secondary-light);
}
body.tema-sm .filtro-pill.activo {
    background: var(--vivo-secondary);
    border-color: var(--vivo-secondary);
    color: #fff;
}


/* ═══════════════════════════════════════════════════════════
   1. BASE
═══════════════════════════════════════════════════════════ */
html {
    font-size: 14px;
}

body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.page-content {
    flex: 1;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

/* ═══════════════════════════════════════════════════════════
   2. BOOTSTRAP OVERRIDES
═══════════════════════════════════════════════════════════ */

/* Focus ring global */
.btn:focus, .btn:active:focus, .btn-link.nav-link:focus,
.form-control:focus, .form-select:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem var(--vivo-shadow-lg);
}

/* form-select focus border */
.form-select:focus {
    border-color: var(--vivo-primary);
}

/* btn-link con colores Vivo */
.btn-link {
    --bs-btn-color:       var(--vivo-primary);
    --bs-btn-hover-color: var(--vivo-primary-dark);
}

/* Accordion hover */
.accordion-button:hover {
    background-color: var(--vivo-light);
}

/* Accordion body: borde superior usa el color de borde Vivo */
.accordion-body.border-top {
    border-color: var(--vivo-border) !important;
}

/* Checkbox / radio */
.form-check-input:checked {
    background-color: var(--vivo-primary);
    border-color: var(--vivo-primary);
}

.form-check-input:focus {
    border-color: var(--vivo-primary);
    box-shadow: 0 0 0 0.25rem var(--vivo-shadow-lg);
}

/* Botón primario */
.btn-primary {
    --bs-btn-bg:                    var(--vivo-primary);
    --bs-btn-border-color:          var(--vivo-primary);
    --bs-btn-hover-bg:              var(--vivo-primary-dark);
    --bs-btn-hover-border-color:    var(--vivo-primary-dark);
    --bs-btn-active-bg:             var(--vivo-primary-darker);
    --bs-btn-active-border-color:   var(--vivo-primary-darker);
    --bs-btn-disabled-bg:           var(--vivo-primary);
    --bs-btn-disabled-border-color: var(--vivo-primary);
    --bs-btn-focus-shadow-rgb:      232, 78, 15;
}

/* Botón outline primario */
.btn-outline-primary {
    --bs-btn-color:              var(--vivo-primary);
    --bs-btn-border-color:       var(--vivo-primary);
    --bs-btn-hover-color:        #fff;
    --bs-btn-hover-bg:           var(--vivo-primary);
    --bs-btn-hover-border-color: var(--vivo-primary);
    --bs-btn-active-color:       #fff;
    --bs-btn-active-bg:          var(--vivo-primary-darker);
    --bs-btn-active-border-color:var(--vivo-primary-darker);
    --bs-btn-focus-shadow-rgb:   232, 78, 15;
}

/* Alert info */
.alert-info {
    --bs-alert-color:        #495057;
    --bs-alert-bg:           #F8F9FA;
    --bs-alert-border-color: #dee2e6;
}

/* ═══════════════════════════════════════════════════════════
   3. FORM CONTROLS
═══════════════════════════════════════════════════════════ */

/* Placeholder global: gris claro para distinguirlo del texto real */
.form-control::placeholder,
.form-select::placeholder,
input::placeholder,
textarea::placeholder {
    color: #7B8794;
    opacity: 1;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* Autofill override */
input:not([type="checkbox"]):not([type="radio"]):focus-visible,
input:not([type="checkbox"]):not([type="radio"]):focus,
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0 1000px white inset !important;
    box-shadow: 0 0 0 1000px white inset !important;
    font-size: 14px !important;
    outline: none !important;
}

/* Validation feedback */
.invalid-feedback {
    color: #FF3D00;
}

.input-group .form-control.is-invalid {
    z-index: 1;
}

/* Input con etiqueta solapada (floating label) */
.input-etiqueta-solapada {
    position: relative;
}

.input-etiqueta-solapada label {
    position: absolute;
    top: -10px;
    left: 15px;
    background: white;
    padding: 0 10px;
    font-size: 14px;
    opacity: 0;
    transition: all 0.2s ease;
    background-color: #fff;
    z-index: 99;
}

.input-etiqueta-solapada textarea:focus,
.input-etiqueta-solapada input:focus {
    border: 1px solid var(--vivo-primary);
    outline: none;
    box-shadow: none;
}

.input-etiqueta-solapada .input-group input {
    border-right: 0;
}

.input-etiqueta-solapada .input-group button {
    border-top-right-radius: 6px !important;
    border-bottom-right-radius: 6px !important;
}

.input-etiqueta-solapada .input-group:focus-within input,
.input-etiqueta-solapada .input-group:focus-within button {
    border-color: var(--vivo-primary);
}

.input-etiqueta-solapada textarea:focus + label,
.input-etiqueta-solapada .input-group:focus-within label,
.input-etiqueta-solapada input:focus + label,
.input-etiqueta-solapada input:focus ~ label {
    opacity: 1;
    color: var(--vivo-primary);
}

.input-etiqueta-solapada textarea:focus::placeholder,
.input-etiqueta-solapada input:focus::placeholder,
.input-etiqueta-solapada .input-group:focus-within input::placeholder {
    opacity: 0;
}

/* ═══════════════════════════════════════════════════════════
   4. GLOBAL UI
═══════════════════════════════════════════════════════════ */

/* Loading */
div#loading {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(125, 125, 125, 0.5);
    color: #ff0040;
}

/* Error global */
.msg-error {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    background-color: #dc3545;
    color: #fff;
    padding: 12px 20px;
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.25);
    display: flex;
    align-items: center;
    gap: 12px;
    max-width: 500px;
}

.msg-error .btn-close {
    filter: invert(1);
    cursor: pointer;
}

/* Modal de alerta (warning) */
.modal-alerta {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #fff;
    border-top: 4px solid #ffc107;
    padding: 24px 24px 20px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
    border-radius: 8px;
    z-index: 1120;
    width: 90%;
    max-width: 460px;
    text-align: center;
}

.modal-alerta__icono {
    font-size: 2rem;
    color: #ffc107;
    margin-bottom: 12px;
}

.modal-alerta__mensaje {
    font-size: 0.95rem;
    color: #333;
    margin-bottom: 20px;
}


/* Enlace */
.enlace {
    color: var(--vivo-primary);
    text-decoration: none;
}

/* Pointer */
.pointer { cursor: pointer; }

/* Alta usuario / ficha */
.ficha {
    color: #5D5D5D;
    font-size: 14px;
    padding: 10px 20px;
    margin-top: 20px;
}

ul.errores-validacion {
    color: #dc3545;
    padding-left: 20px;
}

/* ═══════════════════════════════════════════════════════════
   5. AUTH PAGES (Login / Alta-Usuario)
═══════════════════════════════════════════════════════════ */

/* Login card */
#login .card {
    border-radius: 10px;
}

.bi-person-circle {
    color: var(--vivo-primary) !important;
}

.bi-person-circle:hover:active, .bi-person-circle:hover {
    color: white !important;
}

#login .card a {
    text-decoration: none;
    color: var(--vivo-primary);
}

/* Página de autenticación */
.auth-page {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 3rem 1rem 4rem;
    min-height: 60vh;
}

.auth-page__inner {
    width: 100%;
    max-width: 580px;
    background: white;
    border-radius: 12px;
    padding: 2.2rem;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.09);
}

@media (max-width: 767px) {
    .auth-page {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 20px 10px;
    }

    .auth-page__inner {
        padding: 1.5rem;
    }
}

/* Auth Panel: título */
.auth-panel__titulo {
    font-size: 1.55rem;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 0.5rem;
    text-align: center;
}

.auth-panel__subtitulo {
    font-size: 1rem;
    color: #5d5d5d;
    text-align: start;
   margin-bottom: 1.25rem;
    line-height: 1.5;
}

.auth-panel__colegio {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--vivo-primary, #E84E0F);
}

/* Auth Panel: social login */
.auth-panel__social {
    display: flex;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.auth-social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 1px solid #dee2e6;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.auth-social-btn:hover {
    border-color: var(--vivo-primary);
    box-shadow: 0 2px 8px var(--vivo-shadow-xs);
}

/* Auth Panel: divider */
.auth-panel__divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    color: #999;
    font-size: 0.85rem;
}

.auth-panel__divider::before,
.auth-panel__divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: #dee2e6;
}

/* Auth Panel: toggle link */
.auth-panel__toggle-link {
    display: block;
    width: 100%;
    background: none;
    border: none;
    color: var(--vivo-primary);
    font-size: 0.95rem;
    cursor: pointer;
    text-align: center;
    padding: 0;
}

.auth-panel__toggle-link:hover {
    text-decoration: underline;
}

/* Auth: icono circular decorativo */
.auth-icono {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: var(--vivo-bg-alpha);
    margin-bottom: 1rem;
}

.auth-icono i {
    font-size: 1.6rem;
    color: var(--vivo-primary);
}

.auth-icono--success { background: rgba(25, 135, 84, 0.12); }
.auth-icono--success i { color: #198754; }
.auth-icono--warning { background: rgba(255, 193, 7, 0.15); }
.auth-icono--warning i { color: #ffc107; }
.auth-icono--error { background: rgba(220, 53, 69, 0.10); }
.auth-icono--error i { color: #dc3545; }

/* Verificación de email pendiente — mensaje post-registro */
.verificacion-pendiente {
    text-align: center;
    padding: 1.5rem 0;
}

.verificacion-pendiente__icono {
    font-size: 2.5rem;
    color: var(--vivo-primary);
    display: block;
    margin-bottom: 0.5rem;
}

body.tema-sm .verificacion-pendiente__icono {
    color: var(--vivo-primary);
}

/* Auth: tipografía páginas secundarias */
.auth-page__inner h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 0.35rem;
}

.auth-page__inner .auth-descripcion {
    font-size: 0.9rem;
    color: #5d5d5d;
    margin-bottom: 1.5rem;
    line-height: 1.5;
}

.auth-page__inner .auth-volver {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.85rem;
    color: #6c757d;
    text-decoration: none;
    transition: color 0.15s;
}

.auth-page__inner .auth-volver:hover {
    color: var(--vivo-primary);
}

.auth-page__inner .auth-nota {
    font-size: 0.78rem;
    color: #6c757d;
    margin-top: 1.25rem;
}

/* Auth Panel: tabs */
.auth-panel__tabs {
    display: flex;
    border-bottom: 2px solid #dee2e6;
    margin-bottom: 1.75rem;
}

.auth-tab {
    flex: 1;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    padding: 0.65rem 0.5rem;
    font-size: 0.925rem;
    color: #6c757d;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
    text-align: center;
}

.auth-tab:hover { color: var(--vivo-primary); }

.auth-tab--active {
    color: var(--vivo-primary);
    font-weight: 600;
    border-bottom-color: var(--vivo-primary);
}

/* Auth Panel: mensaje carrito */
.auth-panel__mensaje-carrito {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    margin-top: 1.25rem;
    padding: 0.875rem 1rem;
    background: #fff8f5;
    border: 1px solid #f3cbb8;
    border-radius: 8px;
    font-size: 0.875rem;
    color: #5d5d5d;
    line-height: 1.5;
}

.auth-panel__mensaje-carrito .bi {
    color: var(--vivo-primary);
    font-size: 1rem;
    margin-top: 1px;
}

/* Modal de autenticación (desde carrito) */
.modal-auth-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1040;
}

.modal-auth {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1050;
    width: min(580px, 94vw);
    max-height: 90vh;
    overflow-y: auto;
    background: white;
    border-radius: 12px;
    padding: 2rem;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18);
}

.modal-auth__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
}

.modal-auth__header h5 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════
   6. MI CUENTA
═══════════════════════════════════════════════════════════ */

/* Título de página */
.mi-cuenta h1 {
    font-weight: 700;
    font-size: 2rem;
    margin-bottom: 24px;
}

/* Menú lateral */
.nombre-cliente {
    margin-bottom: 20px;
}

.nombre-cliente .iniciales {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 55px;
    height: 55px;
    border-radius: 50%;
    background-color: var(--vivo-primary);
    color: #fff;
    font-weight: 700;
    font-size: 22px;
    flex-shrink: 0;
}

body.tema-sm .nombre-cliente .iniciales {
    background-color: var(--vivo-secondary);
}

.nombre-cliente .nombre {
    display: block;
    font-weight: 700;
    font-size: 18px;
    color: #000;
}

.mi-cuenta-nav {
    border-radius: 10px;
    border-color: #E8E8E8;
    overflow: hidden;
}

.nav-menu-item {
    display: flex;
    align-items: center;
    padding: 11px 16px;
    color: #555;
    text-decoration: none;
    border-left: 3px solid transparent;
    font-size: 15px;
    transition: background 0.15s, border-left-color 0.15s, color 0.15s;
}

.nav-menu-item:hover {
    background-color: var(--vivo-light);
    color: var(--vivo-primary);
    border-left-color: var(--vivo-pale);
}

.nav-menu-item.active {
    color: var(--vivo-primary);
    font-weight: 600;
    border-left-color: var(--vivo-primary);
    background-color: var(--vivo-light);
}

.nav-menu-item i {
    width: 20px;
    text-align: center;
    margin-right: 10px;
    font-size: 1.05rem;
}

/* Enlace cerrar sesión */
.nav-menu-item--peligro {
    color: #dc3545 !important;
    border-left-color: transparent !important;
}

.nav-menu-item--peligro:hover {
    color: #dc3545 !important;
    background-color: #fff5f5;
    border-left-color: transparent !important;
}

/* Contenido Mi Cuenta */
.mis-datos {
    padding: 20px 20px;
    border-radius: 10px;
    border: 1px solid #ECECEC;
}

.mis-datos .cabecera {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid #ECECEC;
}

.mis-datos .cabecera-icono {
    color: var(--vivo-primary);
    font-size: 2rem;
    line-height: 1;
}

.mis-datos .cabecera h2 {
    margin-bottom: 4px;
    font-size: 20px;
    font-weight: 700;
}

.mis-datos .cabecera p {
    color: #5D5D5D;
    margin: 0;
    font-size: 14px;
}

.mis-datos .ficha {
    background-color: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 10px;
    padding: 16px 20px;
    margin-top: 16px;
}

.mis-datos .ficha h3 {
    font-size: 16px;
    font-weight: 700;
    color: #333;
}

@media (max-width: 768px) {
    .mis-datos {
        padding: 15px;
    }

    .mis-datos .ficha {
        padding: 15px;
    }
}

.ficha-titulo {
    margin-bottom: 12px;
}

.campo-lista {
    display: flex;
    flex-direction: column;
}

.campo-fila {
    padding: 8px 0;
}
.campo-fila:last-child {
    border-bottom: none;
}

.campo-label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    margin-bottom: 3px;
}

.campo-valor-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.campo-valor {
    font-size: 14px;
    color: #333;
}

.campo-modificar {
    color: #999;
    font-size: 13px;
    white-space: nowrap;
    padding: 0;
    text-decoration: none !important;
    flex-shrink: 0;
}
.campo-modificar:hover {
    color: var(--vivo-primary);
}

.campo-borrar {
    color: #dc3545;
    font-size: 13px;
    white-space: nowrap;
    padding: 0;
    text-decoration: none !important;
    flex-shrink: 0;
}
.campo-borrar:hover {
    color: #b02a37;
}

.campo-input-wrap {
    flex: 1;
    min-width: 0;
    max-width: 75%;
}

@media (max-width: 575px) {
    .campo-valor-row { flex-wrap: wrap; }
    .campo-input-wrap { max-width: 100%; }
    .campo-acciones { width: 100%; justify-content: flex-end; }
}

.campo-acciones {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
    align-items: flex-start;
}

.campo-metodo-registro {
    margin-top: 12px;
    text-align: right;
}

.mis-datos-separador {
    border-color: #e8e8e8;
    margin: 4px 0 0;
}

.mensaje-ok {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    margin-top: 10px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-left: 3px solid #16a34a;
    border-radius: 6px;
    color: #15803d;
    font-size: 13px;
}

.mensaje-ok i {
    font-size: 15px;
    flex-shrink: 0;
}

.errores-form {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: #fff5f5;
    border: 1px solid #fecaca;
    border-left: 3px solid #dc3545;
    border-radius: 6px;
    color: #b91c1c;
    font-size: 13px;
}

.errores-form i {
    font-size: 15px;
    flex-shrink: 0;
    margin-top: 2px;
}

/* btn-outline-secondary dentro de mis-datos y carrito actúa como outline-primary
   (los componentes React usan btn-outline-secondary; migrar a btn-outline-primary en futuro) */
.mis-datos .btn-outline-secondary,
.carrito-page .btn-outline-secondary {
    border-color: var(--vivo-primary);
    color: var(--vivo-primary);
}

.mis-datos .btn-outline-secondary:hover,
.carrito-page .btn-outline-secondary:hover {
    background-color: var(--vivo-primary);
    border-color: var(--vivo-primary);
    color: #fff;
}

/* Caja pedido */
.caja-pedido .ficha {
    border: 1px solid #ECECEC;
    border-radius: 10px;
    background-color: #fff;
    padding: 16px 20px;
}

.caja-pedido .ficha h3 {
    font-size: 16px;
    font-weight: 700;
    color: #333;
}

.caja-pedido .badge {
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 20px;
}

.caja-pedido .btn-link {
    color: var(--vivo-primary);
    text-decoration: none;
    font-size: 14px;
}

.caja-pedido .btn-link:hover {
    color: var(--vivo-primary-dark);
}

/* Filtros estado */
.botones-estado {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}

.botones-estado .nav-link {
    color: #5D5D5D;
    border: 1px solid #dee2e6;
    border-radius: 20px;
    padding: 5px 16px;
    font-size: 14px;
    transition: border-color 0.15s, color 0.15s;
}

.botones-estado .nav-link:hover {
    border-color: var(--vivo-primary);
    color: var(--vivo-primary);
}

.botones-estado .nav-link.active {
    background-color: var(--vivo-primary);
    border-color: var(--vivo-primary);
    color: #fff;
}

/* Pedidos: badge estado */
.pedido-estado-badge {
    background-color: var(--vivo-primary);
    color: #fff;
    font-weight: 500;
    font-size: 12px;
    white-space: nowrap;
}

/* Pedidos tema-sm: filtros y badge en azul secundario */
body.tema-sm .botones-estado .nav-link:hover {
    border-color: var(--vivo-secondary);
    color: var(--vivo-secondary);
}

body.tema-sm .botones-estado .nav-link.active {
    background-color: var(--vivo-secondary);
    border-color: var(--vivo-secondary);
    color: #fff;
}

body.tema-sm .pedido-estado-badge {
    background-color: var(--vivo-secondary);
}

/* ═══════════════════════════════════════════════════════════
   7. NAVEGACIÓN
═══════════════════════════════════════════════════════════ */

/* Selector de idioma */
.selector-idiomas {
    list-style-type: none;
    display: flex;
    gap: 6px;
    font-size: 0.8rem;
    font-weight: 400;
    margin: 0;
    padding: 0;
}

.selector-idiomas a {
    text-decoration: none;
    color: var(--bs-body-color) !important;
    opacity: 0.55;
}

.selector-idiomas a.activo {
    font-weight: 700;
    opacity: 1;
}

.selector-idiomas a:hover {
    opacity: 1;
}

/* Enlace de navegación Catálogo en navbar */
.nav-catalogo {
    color: var(--bs-body-color) !important;
    text-decoration: none;
}

.nav-catalogo:hover {
    color: var(--vivo-primary) !important;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.nav-catalogo.activo {
    color: var(--vivo-primary) !important;
}

/* Top bar */
.top-bar {
    font-weight: 700;
    font-size: 16px;
    background-color: var(--vivo-primary);
    color: #fff;
    padding: 10px 0;
}

@media (max-width: 575px) {
    .top-bar { font-size: 13px; padding: 8px 0; }
}

.avisos-home {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

/* Navbar */
.navbar.bg-white {
    padding: 10px 0;
    overflow: visible;
}

header {
    overflow: visible;
}

header .menu-mi-cuenta .dropdown-menu {
    position: absolute;
    z-index: 1050;
}

header .menu-mi-cuenta .dropdown-toggle::after {
    display: none;
}

.logo-temporal {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--vivo-primary) !important;
    text-decoration: none;
}

.logo-temporal i {
    font-size: 1.6rem;
}

.nav-mi-cuenta {
    list-style: none;
    margin: 0;
    padding: 0;
}

.navbar-bienvenido {
    flex: 1;
    text-align: center;
    font-size: 16px;
    font-weight: 700;
    color: var(--vivo-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 0 16px;
}

/* Mobile nav menu */
.nav-mobile-menu {
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    background-color: #fff;
}

.nav-mobile-link {
    color: var(--bs-body-color) !important;
    padding: 11px 0;
    font-size: 0.95rem;
    display: flex;
    align-items: center;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    transition: color 0.15s;
}

.nav-mobile-link:hover,
.nav-mobile-link.activo {
    color: var(--vivo-primary) !important;
}

.nav-mobile-link--secondary {
    color: var(--bs-secondary) !important;
}

.nav-mobile-link--secondary:hover {
    color: var(--bs-secondary) !important;
    opacity: 0.75;
}

.nav-mobile-idiomas {
    padding: 10px 0;
    border-bottom: none;
}

.navbar-toggler {
    width: 36px;
    height: 36px;
}

.navbar-toggler:focus {
    box-shadow: none;
}

.navbar-toggler-icon {
    display: inline-block;
    width: 1em;
    height: 1em;
    vertical-align: middle;
    background-image: var(--bs-navbar-toggler-icon-bg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100%;
}

.btn-header-usuario {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    font-size: 1.3rem;
    color: var(--vivo-primary);
    text-decoration: none;
    border: 1px solid var(--vivo-primary);
    border-radius: 10px;
    line-height: 1;
    transition: color 0.15s, background-color 0.15s;
}

.btn-header-usuario:hover {
    color: white !important;
    background-color: var(--vivo-primary);
}

.btn-header-usuario:hover * {
    color: white !important;
}

header .menu-mi-cuenta .dropdown-menu {
    padding: 10px;
    margin-top: 6px;
    box-shadow: 0px 10px 40px 0px rgba(0, 0, 0, 0.15);
    border: none;
    border-radius: 10px;
    min-width: 180px;
}

    header .menu-mi-cuenta .dropdown-menu .dropdown-item-primary,
    header .menu-mi-cuenta .dropdown-menu .dropdown-item-secondary {
        display: block;
        padding: 12px 15px;
        font-size: 15px;
        color: #111;
        border-radius: 8px;
        background-color: transparent;
        text-decoration: none;
        transition: background-color 0.15s;
        margin-bottom: 2px;
    }

        header .menu-mi-cuenta .dropdown-menu .dropdown-item-primary:hover,
        header .menu-mi-cuenta .dropdown-menu .dropdown-item-primary:active,
        header .menu-mi-cuenta .dropdown-menu .dropdown-item-secondary:hover,
        header .menu-mi-cuenta .dropdown-menu .dropdown-item-secondary:active {
            background-color: #f5f5f5;
            color: #111;
            font-weight: 600;
        }

        header .menu-mi-cuenta .dropdown-menu .dropdown-item-primary.active {
            background-color: #f5f5f5;
            color: #111;
        }

    header .menu-mi-cuenta .dropdown-menu .dropdown-divider-pale {
        border-color: #ECECEC;
        margin: 4px 8px;
    }

/* ═══════════════════════════════════════════════════════════
   8. HOME
═══════════════════════════════════════════════════════════ */

/* Bloque buscar libros */
.bloque-buscar-libros {
    background-color: var(--vivo-pale);
    padding: 48px 0;
}

.buscar-libros-card {
    border-radius: 12px;
    border: none;
    min-height: 405px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    overflow: hidden;
}

@media (max-width: 575px) {
    .buscar-libros-card { min-height: auto; }
}

.buscar-libros-paso-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.buscar-libros-preview-scroll {
    margin-bottom: 4px;
}

.buscar-libros-asignatura {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #888;
    padding: 6px 0 2px;
    border-bottom: 1px solid #eee;
    margin-bottom: 2px;
}

.buscar-libros-libro-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 4px 0;
    gap: 8px;
}

.buscar-libros-libro-titulo {
    font-size: 0.85rem;
    line-height: 1.3;
    flex: 1;
    min-width: 0;
}

.buscar-libros-libro-precio {
    font-size: 0.85rem;
    font-weight: 600;
    white-space: nowrap;
    color: #333;
}

.buscar-libros-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid #dee2e6;
    padding-top: 10px;
    margin-top: 6px;
    margin-bottom: 12px;
    font-size: 0.95rem;
}

.buscar-libros-titulo {
    font-size: 1.5rem;
    font-weight: 700;
    color: black;
    margin-bottom: 6px;
}

.buscar-libros-subtitulo {
    color: #585858;
    font-size: 0.95rem;
    margin-bottom: 22px;
}

.btn-buscar-libros {
    background-color: var(--vivo-primary);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    font-size: 1rem;
    transition: background-color 0.15s;
}

.btn-buscar-libros:hover {
    background-color: var(--vivo-primary-dark);
    color: #fff;
}

/* Bloque iconos */
#bloque-iconos {
    padding: 55px 0;
    border-bottom: 1px solid #e9ecef;
    margin-bottom: 32px;
}

.bloque-icono-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
}

.bloque-icono-i {
    font-size: 1.8rem;
    color: var(--vivo-primary);
    flex-shrink: 0;
    margin-top: 2px;
}

.bloque-icono-titulo {
    font-weight: 700;
    font-size: 0.9rem;
    color: #000;
    margin-bottom: 4px;
}

.bloque-icono-texto {
    font-size: 0.8rem;
    color: #585858;
    line-height: 1.4;
}

/* Cómo funciona (pasos) */
.como-funciona {
    padding: 56px 0 64px;
}

.como-funciona-titulo {
    font-size: 1.75rem;
    font-weight: 700;
    color: #000;
    margin-bottom: 8px;
}

.como-funciona-subtitulo {
    color: #585858;
    font-size: 0.95rem;
    margin-bottom: 40px;
}

.pasos-container {
    position: relative;
    height: 480px;
}

.pasos-wave {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    pointer-events: none;
}

.paso {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    z-index: 2;
}

.paso-1 { top: 0; left: 0; width: 26%; height: 348px; }
.paso-2 { top: 37px; left: 32.5%; width: 24%; height: 340px; }
.paso-3 { top: 37px; left: 62%; width: 35%; height: 340px; }

/* Paso 3: la etiqueta se desplaza para alinearse con la ola SVG */
.paso-3 .paso-etiqueta { margin-left: 115px; }

.paso-etiqueta {
    align-self: flex-start;
    width: 100%;
    display: flex;
    align-items: flex-start;
    gap: 4px;
    background-color: #fff;
    border-radius: 8px;
    padding: 4px 0;
}

.paso-info {
    flex: 1;
    min-width: 0;
}

.paso-burbuja {
    background-color: var(--vivo-pale);
    border-radius: 14px;
    width: 76px;
    height: 76px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--vivo-primary);
    font-size: 2rem;
    flex-shrink: 0;
    box-shadow: 0 4px 16px var(--vivo-shadow-md);
}

.paso-titulo {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--vivo-primary);
    margin-bottom: 6px;
}

.paso-numero {
    font-size: clamp(80px, 12vw, 160px);
    font-weight: 700;
    color: var(--vivo-primary);
    opacity: 0.18;
    line-height: 1;
    flex-shrink: 0;
}

.paso-texto {
    color: #444;
    font-size: 0.85rem;
    margin: 0;
    line-height: 1.5;
}

@media (max-width: 768px) {
    .pasos-container {
        height: auto;
        display: flex;
        flex-direction: column;
        gap: 24px;
    }

    .pasos-wave { display: none; }

    .paso {
        position: static;
        width: 100% !important;
        height: auto !important;
        flex-direction: row;
        align-items: flex-start;
        justify-content: flex-start;
        gap: 16px;
    }

    .paso-1 { flex-direction: row-reverse; }
    .paso-etiqueta { flex: 1; }
    .paso-3 .paso-etiqueta { margin-left: 0; }
    .paso-numero { display: none; }
}

/* Video card — formato vertical con thumbnail y carousel dots */
.video-card {
    display: block;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    background-color: #fff;
    transition: box-shadow 0.2s;
    text-decoration: none;
    color: inherit;
}
.video-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.10);
    text-decoration: none;
    color: inherit;
}
.video-card-thumb {
    background-color: #e8eaec;
    aspect-ratio: 16 / 9;
    display: flex;
    align-items: center;
    justify-content: center;
}
.video-card-play-icon {
    font-size: 2.75rem;
    color: var(--vivo-primary);
    transition: opacity 0.2s;
}
.video-card:hover .video-card-play-icon {
    opacity: 0.75;
}
.video-card-body {
    padding: 0.75rem 1rem 1rem;
}
.video-card-titulo {
    color: var(--vivo-primary);
    font-weight: 600;
    font-size: 0.9rem;
    margin-bottom: 0.2rem;
    line-height: 1.4;
}
.video-card-categoria {
    color: #777;
    font-size: 0.78rem;
}

/* Carousel dots */
.video-carousel-dots {
    display: flex;
    justify-content: flex-end;
    gap: 6px;
    margin-top: 1.25rem;
    align-items: center;
}
.video-carousel-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #ccc;
    cursor: pointer;
    border: none;
    padding: 0;
    transition: background-color 0.2s, width 0.2s;
    flex-shrink: 0;
}
.video-carousel-dot.activo {
    background-color: var(--vivo-primary);
    width: 24px;
    border-radius: 5px;
}

/* Bloque Contacto */
.bloque-contacto {
    background-color: #fff1e8;
    border-top: 1px solid var(--vivo-border);
    padding: 3rem 0;
    margin-top: 3rem;
}

.bloque-contacto-titulo {
    color: var(--vivo-primary);
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 1.25rem;
}

.bloque-contacto-texto {
    color: #444;
    line-height: 1.7;
    margin-bottom: 0.9rem;
}

.bloque-contacto-telefono {
    color: var(--vivo-primary);
    font-weight: 600;
    text-decoration: none;
}

.bloque-contacto-telefono:hover {
    text-decoration: underline;
}

.bloque-contacto .form-control {
    border-color: var(--vivo-border);
    background-color: #fff;
}

.bloque-contacto .form-control:focus {
    border-color: var(--vivo-primary);
    box-shadow: 0 0 0 0.2rem var(--vivo-shadow-sm);
}

.bloque-contacto-ok {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 2.5rem 1rem;
    text-align: center;
    color: #2c6e2c;
    background-color: #f0faf0;
    border: 1px solid #b6d9b6;
    border-radius: 8px;
}

.bloque-contacto-ok .bi {
    font-size: 2.5rem;
    color: #2c6e2c;
}

/* Contenido web CMS — tipografía y responsive */
.contenido-web-body a {
    color: var(--vivo-primary);
}

/* Bloque FAQs — accordion minimalista */
.bloque-faqs .accordion-item {
    border: none;
    border-bottom: 1px solid #e5e5e5;
    border-radius: 0 !important;
    background-color: transparent;
}
.bloque-faqs .accordion-item:first-child {
    border-top: 1px solid #e5e5e5;
}
.bloque-faqs .accordion-button {
    font-weight: 500;
    font-size: 0.95rem;
    color: #1a1a1a;
    background-color: transparent;
    padding-left: 0;
    padding-right: 0.25rem;
}
.bloque-faqs .accordion-button:not(.collapsed) {
    color: #1a1a1a;
    background-color: transparent;
    box-shadow: none;
}
.bloque-faqs .accordion-button:focus {
    box-shadow: none;
}
.bloque-faqs .accordion-body {
    padding-left: 0;
    padding-right: 0;
    color: #555;
    font-size: 0.9rem;
    line-height: 1.6;
}
.bloque-faqs .accordion-body.border-top {
    border-color: #e5e5e5 !important;
}
.bloque-faqs .accordion-body p {
    margin-bottom: 0;
}
.bloque-faqs .pagination,
.mis-datos .pagination {
    --bs-pagination-color:             var(--vivo-primary);
    --bs-pagination-hover-color:       var(--vivo-primary-dark);
    --bs-pagination-focus-color:       var(--vivo-primary);
    --bs-pagination-focus-box-shadow:  0 0 0 0.25rem var(--vivo-shadow-sm);
    --bs-pagination-active-bg:         var(--vivo-primary);
    --bs-pagination-active-border-color: var(--vivo-primary);
}
.bloque-faqs-explora {
    margin-top: 2rem;
    text-align: center;
}

/* ═══════════════════════════════════════════════════════════
   9. CARRITO — Icono con badge
═══════════════════════════════════════════════════════════ */
.icono-carrito-wrapper {
    position: relative;
    background: transparent;
    border-radius: 9px;
    padding: 6px 11px;
    cursor: pointer;
    font-size: 1.1rem;
    color: var(--vivo-primary);
    transition: background .18s ease, color .18s ease;
}

.icono-carrito-wrapper:hover {
    background: var(--vivo-primary);
    color: #fff;
}

.cart-badge {
    position: absolute;
    top: -4px;
    right: -6px;
    background: var(--vivo-primary);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    border-radius: 50%;
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════
   10. CARRITO — Modal panel derecho
═══════════════════════════════════════════════════════════ */
.modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .45);
    z-index: 1040;
}

body:has(.modal-right) {
    overflow-y: hidden;
}

.modal-right {
    position: fixed;
    right: 0;
    top: 0;
    height: 100vh;
    width: min(510px, 100vw);
    background: #fff;
    box-shadow: -4px 0 24px rgba(0, 0, 0, .18);
    z-index: 1050;
    display: flex;
    flex-direction: column;
    animation: slideInRight .2s ease;
}

@keyframes slideInRight {
    from { transform: translateX(100%); }
    to   { transform: translateX(0); }
}

.modal-right__header {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid #e5e5e5;
}

.modal-right__header h2 {
    flex: 1;
    font-weight: 700;
    font-size: 22px;
    margin: 0;
}

.modal-right__close {
    border: none;
    padding: 8px !important;
    background-color: #D9D9D9;
    border-radius: 25px;
    color: #000;
    font-size: 10px;
}

.enlace-borrar {
    text-decoration: none;
    color: var(--bs-danger, #dc3545);
    display: flex;
    align-items: center;
    font-size: 13px;
    white-space: nowrap;
}
.enlace-borrar:hover {
    color: #a71d2a;
}

.modal-right__body {
    flex: 1 1 auto;
    padding: 12px 16px;
    overflow-y: auto;
}

.modal-right__item {
    font-size: 14px;
    padding: 12px 0;
    border-bottom: 1px solid #D9D9D9;
}

.modal-right__item-nombre {
    font-weight: 600;
    line-height: 1.3;
}

.modal-right__item .precio-normal {
    font-size: 14px;
    font-weight: 700;
    margin-top: 4px;
    color: var(--vivo-primary);
}

.modal-right__item-detalle {
    color: #666;
    font-size: 0.9rem;
}

.libro-modal-placeholder {
    height: 80px;
    background: #f8f9fa;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.libro-carrito-placeholder {
    height: 87px;
    background: #f8f9fa;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.libro-carrito-placeholder-paquete {
    height: 63px;
    background: #f8f9fa;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-right__footer {
    border-top: 1px solid #e5e5e5;
    padding: 16px;
}

.modal-right__footer .precio-final {
    color: #000;
    font-weight: 700;
    font-size: 20px;
}

.botones-cantidad {
    font-size: 18px;
    display: inline-flex;
    align-items: center;
    font-weight: 400;
    border-radius: 50px;
    border: 1px solid #E2E2E2;
    user-select: none;
}

.botones-cantidad .boton-menos,
.botones-cantidad .boton-mas {
    cursor: pointer;
    padding: 0 8px;
}

.botones-cantidad .cantidad {
    color: var(--vivo-primary);
    font-weight: 700;
    font-size: 16px;
    min-width: 28px;
    text-align: center;
}

/* ═══════════════════════════════════════════════════════════
   11. CATÁLOGO — Layout
═══════════════════════════════════════════════════════════ */
.catalogo-wrap {
    display: flex;
    min-height: calc(100vh - 120px);
    margin: 0 -12px;
}

.catalogo-sidebar {
    width: 280px;
    min-width: 220px;
    flex-shrink: 0;
    padding: 23px 24px 0 0;
    border-right: 1px solid #dee2e6;
}

.catalogo-main {
    flex: 1;
    padding: 20px 5px 20px 24px;
}

@media (max-width: 768px) {
    .catalogo-wrap { flex-direction: column; }
    .catalogo-sidebar {
        width: 100%;
        min-width: unset;
        border-right: none;
        border-bottom: 1px solid #dee2e6;
        padding: 15px;
    }
    .catalogo-main {
        flex: 1;
        padding: 20px 15px;
    }
}

/* Título y subtítulo del grado seleccionado */
.catalogo-grado-titulo {
    font-size: 1.75rem;
    font-weight: 800;
    color: #1a1a1a;
    line-height: 1.1;
}

.catalogo-grado-subtitulo {
    font-size: 1rem;
    font-weight: 600;
    color: #555;
}

/* Barra de filtros por asignatura */
.catalogo-filtros {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.catalogo-filtros-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: #888;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.catalogo-filtros-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.filtro-pill {
    padding: 6px 16px;
    border-radius: 50px;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    border: 1px solid var(--vivo-primary);
    background: #fff;
    color: var(--vivo-primary);
    transition: background .15s, color .15s, border-color .15s;
    white-space: nowrap;
}

.filtro-pill:hover {
    background: var(--vivo-light);
}

.filtro-pill.activo {
    background: var(--vivo-primary);
    color: #fff;
}

/* Pestañas Paquetes / Libros sueltos */
.catalogo-tabs {
    border-bottom: 2px solid var(--vivo-border);
    gap: 4px;
}
.catalogo-tabs .nav-link {
    border: none;
    border-bottom: 3px solid transparent;
    border-radius: 0;
    color: #6c757d;
    font-weight: 600;
    padding: .5rem 1rem;
    margin-bottom: -2px;
    transition: color .15s, border-color .15s;
}
.catalogo-tabs .nav-link:hover {
    color: var(--vivo-primary);
    border-bottom-color: var(--vivo-border);
}
.catalogo-tabs .nav-link.active {
    color: var(--vivo-primary);
    border-bottom-color: var(--vivo-primary);
    background: transparent;
}

/* Cabecera de sección de asignatura */
.catalogo-seccion-titulo {
    font-size: 1rem;
    font-weight: 700;
    color: #222;
    border-bottom: 2px solid var(--vivo-border);
    padding-bottom: 8px;
    display: flex;
    align-items: baseline;
    gap: 8px;
}

.catalogo-seccion-count {
    font-size: 0.8rem;
    font-weight: 400;
    color: #aaa;
}

/* Sidebar árbol de categorías */
ul.arbol-categorias {
    list-style: none;
    padding: 10px;
    margin: 0;
    border-radius: 10px;
    border: 1px solid #e0e0e0;
    /*box-shadow: 0 10px 40px 0 rgba(0, 0, 0, .15);*/
}

ul.arbol-categorias ul {
    list-style: none;
    padding: 0;
    margin-top: 12px;
}

ul.arbol-categorias > li {
    font-weight: 700;
    padding: 10px;
    padding-top: 16px;
    margin-bottom: 4px;
    border-radius: 8px;
}

ul.arbol-categorias > li > span {
    display: block;
    position: relative;
    padding-left: 44px;
    margin-bottom: 4px;
}

ul.arbol-categorias > li > span::before {
    content: "";
    width: 30px;
    height: 30px;
    border-radius: 8px;
    display: inline-block;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

ul.arbol-categorias li.categoria-0 > span::before { background-color: #FAB96D; }
ul.arbol-categorias li.categoria-1 > span::before { background-color: #FF7D6A; }
ul.arbol-categorias li.categoria-2 > span::before { background-color: var(--vivo-primary); }
ul.arbol-categorias li.categoria-3 > span::before { background-color: #2F6BAF; }
ul.arbol-categorias li.categoria-4 > span::before { background-color: #00A2A3; }
ul.arbol-categorias li.categoria-5 > span::before { background-color: #FAB96D; }
ul.arbol-categorias li.categoria-6 > span::before { background-color: #FF7D6A; }

.paquete-cat-0, .paquete-cat-5 { background: linear-gradient(135deg, #fafafa, #fef0d5); }
.paquete-cat-1, .paquete-cat-6 { background: linear-gradient(135deg, #fafafa, #ffe8e5); }
.paquete-cat-2              { background: linear-gradient(135deg, #fafafa, #fde8de); }
.paquete-cat-3              { background: linear-gradient(135deg, #fafafa, #dae8f7); }
.paquete-cat-4              { background: linear-gradient(135deg, #fafafa, #d5f0f0); }
.paquete-cat-0 .paquete-icon, .paquete-cat-5 .paquete-icon { color: #FAB96D; }
.paquete-cat-1 .paquete-icon, .paquete-cat-6 .paquete-icon { color: #FF7D6A; }
.paquete-cat-2 .paquete-icon { color: #E84E0F; }
.paquete-cat-3 .paquete-icon { color: #2F6BAF; }
.paquete-cat-4 .paquete-icon { color: #00A2A3; }

ul.arbol-categorias > li.selected { background: #F7F6F2; }

ul.arbol-categorias ul li {
    font-weight: 400;
    padding: 2px 0;
}

ul.arbol-categorias ul li a {
    display: block;
    padding: 5px 8px;
    text-decoration: none;
    color: #444;
    font-size: 0.875rem;
    border-radius: 6px;
    transition: color .15s, background .15s;
}

ul.arbol-categorias ul li a:hover {
    color: var(--vivo-primary);
    background: var(--vivo-tint);
}

ul.arbol-categorias ul li.selected a {
    color: var(--vivo-primary);
    font-weight: 700;
    background: var(--vivo-tint);
}

.conteo-libros {
    color: #aaa;
    font-size: 0.8rem;
}


/* Grid de libros */
.producto-card {
    height: 100%;
    min-height: 300px;
    background: #fff;
    border-radius: 10px;
    border: 1px solid #ECECEC;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: box-shadow .2s;
}

.producto-card:hover {
    box-shadow: 0 4px 20px rgba(0, 0, 0, .12);
}

.producto-card a.img-producto {
    display: block;
    height: 220px;
    align-content: center;
    text-align: center;
    overflow: hidden;
    position: relative;
    background: #fafafa;
}

.producto-card a.img-producto img {
    max-height: 100%;
    max-width: 100%;
    padding: 12px;
    margin: 0 auto;
    object-fit: contain;
    display: block;
}

.producto-card a.img-producto .overlay {
    position: absolute;
    inset: 0;
    background: rgba(255, 255, 255, .82);
    color: #000;
    font-weight: 600;
    font-size: 14px;
    opacity: 0;
    transition: opacity .2s ease;
    z-index: 1;
}

.producto-card a.img-producto:hover .overlay {
    opacity: 1;
}

.producto-card .titulo {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 8px 10px 12px;
}

.producto-card .titulo .precio-normal {
    font-size: 15px;
    font-weight: 700;
    color: var(--vivo-primary);
    margin-bottom: 2px;
}

.precio-campana {
    display: flex;
    align-items: baseline;
    gap: 6px;
    flex-wrap: wrap;
}

.precio-tachado {
    font-size: 12px;
    color: #999;
    text-decoration: line-through;
    font-weight: 400;
}

.precio-descuento {
    font-size: 15px;
    font-weight: 700;
    color: var(--vivo-primary);
}

.item-precio .precio-tachado {
    font-size: 13px;
}

.producto-card .titulo a {
    font-size: 13px;
    text-decoration: none;
    color: #222;
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.producto-card .titulo a span {
    font-weight: 600;
}

.producto-card .titulo a:hover span {
    color: var(--vivo-primary);
}

/* Hover en tarjeta del catálogo */
.img-produto {
    overflow: hidden;
    border-radius: 8px 8px 0 0;
}

.img-produto img {
    transition: transform .2s ease;
}

.img-produto:hover img {
    transform: scale(1.04);
}

/* Libro detalle — modal */
.libro-detalle-img {
    max-width: 100%;
    object-fit: contain;
    /* Desktop: altura generosa */
    max-height: 320px;
}

@media (max-width: 768px) {
    .libro-detalle-img {
        /* Móvil: imagen centrada y acotada para no ocupar toda la pantalla */
        max-height: 180px;
        width: auto;
    }
}


.libro-detalle-placeholder {
    height: 260px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 5rem;
    color: #ccc;
    background: #f8f9fa;
    border-radius: 8px;
}

.libro-detalle-precio {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--vivo-primary);
}

.libro-detalle-descripcion div {
    line-height: 1.7;
}

/* ═══════════════════════════════════════════════════════════
   12. CARRITO — Página completa
═══════════════════════════════════════════════════════════ */
.carrito-page {
    max-width: 1300px;
    margin: 0 auto;
    padding: 30px 0 45px 0;
}

@media (max-width: 575px) {
    .carrito-page { padding: 16px 0 24px 0; }
}

.carrito-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 30px;
    flex-wrap: wrap;
    gap: 12px;
}

.carrito-content {
    display: flex;
    gap: 30px;
    align-items: flex-start;
}

.carrito-items {
    flex: 1;
    min-width: 0;
}

.carrito-resumen {
    width: 375px;
    flex-shrink: 0;
    align-self: flex-start;
    position: sticky;
    top: 16px;
}

.carrito-resumen__box {
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    padding: 20px;
    /*box-shadow: 0 4px 16px rgba(0,0,0,.06);*/
}

@media (max-width: 768px) {
    .carrito-content { flex-direction: column; }
    .carrito-resumen { width: 100%; }
}

/* Toolbar */
.carrito-toolbar {
    padding-bottom: 12px;
    border-bottom: 1px solid #ececec;
    margin-bottom: 4px;
}

/* Grupos (por curso / por estudiante) */
.carrito-grupo {
    margin-top: 8px;
}

.carrito-grupo__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 0 8px;
    border-bottom: 2px solid var(--vivo-primary);
    margin-bottom: 4px;
    color: #333;
}

.carrito-grupo__header i {
    color: var(--vivo-primary);
}

/* Bloque paquete — modal lateral (estilo coherente con pack-card) */
.modal-pack-bloque {
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    margin: 10px 0;
    overflow: hidden;
    background: #fff;
}

/* Cabecera: dos filas — label tipo + fila de alumno/pack/count */
.modal-pack-bloque__header {
    padding: 8px 12px 7px;
    background: #f8f9fa;
    border-bottom: 1px solid #ececec;
}

.modal-pack-bloque__header-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 600;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.modal-pack-bloque__header-label i {
    color: var(--vivo-primary);
    font-size: 13px;
}

.modal-pack-bloque__header-meta {
    display: flex;
    align-items: baseline;
    gap: 4px;
    margin-top: 3px;
    justify-content: space-between;
}

.modal-pack-bloque__alumno {
    font-size: 13px;
    font-weight: 600;
    color: #333;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.modal-pack-bloque__pack-nombre {
    font-size: 11px;
    color: #888;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}

.modal-pack-bloque__count {
    font-size: 11px;
    color: #aaa;
    flex-shrink: 0;
}

/* Botón eliminar paquete — icono limpio */
.modal-pack-bloque__del {
    background: none;
    border: none;
    color: var(--bs-danger, #dc3545);
    cursor: pointer;
    padding: 0 0 0 8px;
    line-height: 1;
    font-size: 13px;
    flex-shrink: 0;
    transition: color 0.15s;
}
.modal-pack-bloque__del:hover { color: #a71d2a; }

/* Ítem compacto — portada + info — reutilizado para pack y sueltos */
.modal-book-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    border-bottom: 1px solid #f0f0f0;
}
.modal-pack-bloque .modal-book-item:last-of-type,
.modal-book-item:last-child { border-bottom: none; }

.modal-book-item__cover {
    flex-shrink: 0;
    width: 40px;
    height: 54px;
    border-radius: 4px;
    overflow: hidden;
    background: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}
.modal-book-item__cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 4px;
}

.modal-book-item__info {
    flex: 1;
    min-width: 0;
}

.modal-book-item__titulo {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.3;
    color: inherit;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.modal-book-item__titulo:hover { text-decoration: none; }

/* Botón eliminar ítem suelto */
.modal-book-item__del {
    background: none;
    border: none;
    color: var(--bs-danger, #dc3545);
    cursor: pointer;
    padding: 2px;
    line-height: 1;
    font-size: 14px;
    flex-shrink: 0;
    transition: color 0.15s;
}
.modal-book-item__del:hover { color: #a71d2a; }

.modal-pack-precio {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 14px;
    background: #fafafa;
    border-top: 1px solid #ececec;
    font-size: 13px;
}

/* Precio total dentro de bloques de paquete */
.carrito-pack-total .fw-bold,
.modal-pack-precio .fw-bold {
    color: var(--vivo-primary);
}

.carrito-pack-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 12px;
    background: #fff3ef;
    border-top: 1px solid var(--vivo-border);
    font-size: 14px;
}

/* Bloque paquete (dentro del grupo de estudiante) */
.carrito-pack-bloque {
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    margin: 8px 0;
    overflow: hidden;
}

.carrito-pack-bloque__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 12px;
    background: #e9ecef;
    border-bottom: 1px solid #dee2e6;
}

.carrito-pack-bloque .lista-carrito {
    padding: 0 12px;
}

.carrito-pack-bloque .item-carrito {
    padding: 12px 0;
}

.carrito-grupo__header--paquete {
    border-bottom-color: #6c757d;
}

.carrito-grupo__header--paquete i {
    color: #6c757d;
}

.paquete-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 600;
    color: #495057;
    background: #e9ecef;
    border: 1px solid #ced4da;
    border-radius: 4px;
    padding: 2px 8px;
    margin-left: 8px;
    vertical-align: middle;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.paquete-badge i {
    color: #495057;
    font-size: 12px;
}

.btn-eliminar-paquete {
    font-size: 12px;
    padding: 2px 10px;
    white-space: nowrap;
}

/* Ítem bloqueado (paquete) */
.item-carrito--paquete {
    background: #fafafa;
    border-radius: 6px;
    padding: 12px 10px;
    margin-bottom: 4px;
    border-bottom: 1px solid #e9e9e9;
}

.item-carrito--paquete:last-child {
    border-bottom: none;
}

/* Lista de items */
.lista-carrito {
    list-style: none;
    padding: 0;
    margin: 0;
}

.item-carrito {
    padding: 16px 0;
    border-bottom: 1px solid #e9e9e9;
}

.item-carrito:last-child {
    border-bottom: none;
}

.item-titulo {
    font-weight: 600;
    font-size: 14px;
    line-height: 1.35;
    margin-bottom: 4px;
}

.sin-asignar {
    display: inline-block;
    font-size: 11px;
    font-weight: 500;
    color: var(--vivo-primary);
    background: var(--vivo-bg-alpha);
    border-radius: 4px;
    padding: 1px 7px;
    margin-left: 6px;
    vertical-align: middle;
}

.item-meta {
    font-size: 12px;
    color: #777;
    margin-bottom: 2px;
}

.item-meta span {
    font-weight: 600;
    color: #555;
}

.item-precio {
    font-size: 15px;
    font-weight: 700;
    color: var(--vivo-primary);
    white-space: nowrap;
}

/* Resumen lateral */
.resumen-totales .resumen-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 0;
    font-size: 14px;
}

.resumen-totales .resumen-row .label { color: #555; }
.resumen-totales .resumen-row .valor { font-weight: 600; }

.resumen-totales .resumen-row .por-calcular {
    color: #999;
    font-size: 13px;
}

.resumen-totales .resumen-row.total-final {
    font-size: 15px;
    font-weight: 700;
    padding-top: 10px;
    margin-top: 10px;
    border-top: 1px solid #dee2e6;
}

.resumen-totales .resumen-row.total-final .valor {
    color: var(--vivo-primary);
    font-size: 20px;
}

.cupon-section .form-control:focus {
    border-color: var(--vivo-primary);
    box-shadow: 0 0 0 .2rem var(--vivo-shadow-sm);
}

/* ═══════════════════════════════════════════════════════════
   13. DESCUENTOS — Estilos compartidos
═══════════════════════════════════════════════════════════ */
.descuento-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: #d1e7dd;
    color: #0a5c36;
    border-radius: 50rem;
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.4;
}

.descuento-nombre {
    font-size: 11px;
    color: #6c757d;
    font-weight: 400;
}

.resumen-row--descuento {
    color: #198754;
    align-items: flex-start !important;
}

.resumen-row--descuento .valor {
    color: #198754;
    font-weight: 600;
}

.cupon-card {
    background: #f0faf4;
    border: 1px solid #d1e7dd;
    border-radius: 0.5rem;
    padding: 8px 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.cupon-card__icon { color: #198754; font-size: 13px; flex-shrink: 0; }
.cupon-card__codigo { font-weight: 600; font-size: 14px; color: #0a5c36; }

.cupon-card__quitar {
    color: #6c757d;
    padding: 2px 6px;
    background: none;
    border: none;
    cursor: pointer;
    line-height: 1;
    transition: color .15s;
    margin-left: auto;
    flex-shrink: 0;
}

.cupon-card__quitar:hover:not(:disabled) { color: #222; }
.cupon-card__quitar:disabled { opacity: .45; cursor: not-allowed; }

/* ═══════════════════════════════════════════════════════════
   14. RESUMEN COMPRA — Grupos de estudiante, packs y libros
═══════════════════════════════════════════════════════════ */
.grupo-card {
    border: 1px solid #e9ecef;
    border-radius: 0.5rem;
    overflow: hidden;
}

.grupo-card__header {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 8px 14px;
    background: #f8f9fa;
    border-bottom: 1px solid #e9ecef;
    font-size: 13px;
}

.grupo-card__header .bi-person-fill { color: var(--vivo-primary); }
.grupo-card__header .bi { font-size: 13px; flex-shrink: 0; }

.grupo-card__body { padding: 10px 14px; }

.pack-cabecera {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0 8px;
    border-bottom: 1px solid #f0f0f0;
    margin-bottom: 4px;
}

.pack-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: var(--vivo-light);
    color: var(--vivo-primary);
    font-size: 11px;
    font-weight: 600;
    border-radius: 50rem;
    padding: 3px 9px;
    white-space: nowrap;
}

.pack-precio { font-weight: 700; font-size: 13px; color: var(--vivo-primary); }

.pack-libros { list-style: none; padding-left: 4px; margin: 0; }
.pack-libros li {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 0;
    font-size: 12px;
    color: #666;
}
.pack-libros li + li { border-top: 1px solid #f5f5f5; }
.pack-libros .bi { font-size: 10px; flex-shrink: 0; }

.libro-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 8px 0;
    font-size: 13px;
}
.libro-item + .libro-item { border-top: 1px solid #f0f0f0; }

.libro-meta {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
    margin-top: 3px;
}
.libro-meta__tag {
    font-size: 10px;
    background: #f3f3f3;
    color: #888;
    border-radius: 4px;
    padding: 1px 6px;
    line-height: 1.6;
}

.resumen-features {
    margin-top: 16px;
    padding-top: 6px;
}

.resumen-features .feature-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: #555;
    margin-bottom: 8px;
}

.resumen-features .feature-item i {
    color: var(--vivo-primary);
    font-size: 15px;
    flex-shrink: 0;
}

/* Sección header (ResumenCompra) */
.seccion-header-icon {
    background: var(--vivo-light);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 14px;
    color: var(--vivo-primary);
}

.seccion-header-label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #666;
}

/* Ficha seleccionada/activa */
.ficha--activo {
    border-color: var(--vivo-primary) !important;
}

/* Ficha tipo radio: sin borde por defecto, línea fina en hover/activo */
.mis-datos .ficha.ficha--radio {
    border-color: transparent;
    margin-top: 8px;
    transition: border-color 0.15s;
}
.mis-datos .ficha.ficha--radio:hover {
    border-color: #ccc;
}
.mis-datos .ficha.ficha--radio.ficha--activo {
    border-color: var(--vivo-primary);
}

/* Modal de añadir dirección: sin margen superior en la ficha interna */
.modal-agregar-direccion .ficha {
    margin-top: 0;
}

/* Modal de añadir estudiante: estilos de ficha coherentes con .mis-datos */
.modal-agregar-estudiante .ficha {
    margin-top: 0;
}
.modal-agregar-estudiante .ficha h3 {
    font-size: 16px;
    font-weight: 700;
    color: #333;
}

/* Validación: el label del checkbox de condiciones no hereda el color rojo */
.mis-datos .form-check-input.is-invalid ~ .form-check-label {
    color: inherit;
}

/* ═══════════════════════════════════════════════════════════
   15. CATÁLOGO — Botón añadir / control cantidad
═══════════════════════════════════════════════════════════ */
.btn-add-carrito {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    width: 100%;
    padding: 7px 10px;
    font-size: 13px;
    font-weight: 600;
    color: var(--vivo-primary);
    background: transparent;
    border: 1.5px solid var(--vivo-primary);
    border-radius: 50px;
    cursor: pointer;
    transition: background .15s, color .15s;
    white-space: nowrap;
}

.btn-add-carrito:hover {
    background: var(--vivo-primary);
    color: #fff;
}

.solo-paquetes-badge {
    display: inline-flex;
    align-items: center;
    font-size: .75rem;
    color: #6c757d;
    border: 1px solid #dee2e6;
    border-radius: 20px;
    padding: .25rem .75rem;
    white-space: nowrap;
}

.sin-precio-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    color: #92400e;
    border: 1px solid #fcd34d;
    border-radius: 20px;
    padding: .5rem .75rem;
    white-space: nowrap;
    background-color: #fffbeb;
    width: 100%;
}

/* ── Modal detalle paquete ──────────────────────────────── */
.paquete-detalle-icono {
    width: 64px;
    height: 64px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: #FAB96D;
    flex-shrink: 0;
}

.libro-paquete-item {
    border: 1px solid #e9ecef;
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
    transition: box-shadow .15s, border-color .15s;
    cursor: pointer;
}
.libro-paquete-item:hover {
    box-shadow: 0 2px 8px rgba(0,0,0,.1);
    border-color: #ced4da;
}

.libro-paquete-img {
    width: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    display: block;
    background: #fafafa;
}

.libro-paquete-placeholder {
    width: 100%;
    aspect-ratio: 3 / 4;
    background: #fafafa;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    color: #dee2e6;
}

.libro-paquete-titulo {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.carrito-qty-control {
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1.5px solid var(--vivo-primary);
    border-radius: 50px;
    overflow: hidden;
    user-select: none;
}

.btn-qty {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 14px;
    color: var(--vivo-primary);
    transition: background .12s;
    flex-shrink: 0;
}

.btn-qty:hover { background: var(--vivo-light); }
.btn-qty--remove:hover { color: var(--vivo-primary-dark); }

.qty-number {
    min-width: 28px;
    text-align: center;
    font-weight: 700;
    font-size: 15px;
    color: var(--vivo-primary);
    line-height: 34px;
}

/* ═══════════════════════════════════════════════════════════
   16. WIZARD DE COMPRA
═══════════════════════════════════════════════════════════ */
.wizard-progreso {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 16px 8px 8px;
    list-style: none;
    margin: 0;
}

.wizard-paso__contenido {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    min-width: 60px;
}

.wizard-paso__circulo {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    border: 2px solid #dee2e6;
    background: #fff;
    color: #adb5bd;
    transition: all 0.2s;
}

.wizard-paso__contenido.activo .wizard-paso__circulo {
    border-color: var(--vivo-primary);
    background: var(--vivo-primary);
    color: #fff;
}

.wizard-paso__contenido.completado .wizard-paso__circulo {
    border-color: var(--vivo-primary);
    background: #fff;
    color: var(--vivo-primary);
}

.wizard-paso__label {
    font-size: 11px;
    color: #adb5bd;
    text-align: center;
    white-space: nowrap;
}

.wizard-paso__contenido.activo .wizard-paso__label {
    color: var(--vivo-primary);
    font-weight: 600;
}

.wizard-paso__contenido.completado .wizard-paso__label {
    color: #333;
}

.wizard-paso__linea {
    flex: 1;
    height: 2px;
    background: #dee2e6;
    margin: 0 8px;
    margin-top: 18px;
    min-width: 24px;
    transition: background 0.2s;
}

.wizard-paso__linea.completada {
    background: var(--vivo-primary);
}

@media (max-width: 575px) {
    .wizard-paso__label { font-size: 10px; }
    .wizard-paso__circulo { width: 32px; height: 32px; font-size: 12px; }
    .wizard-paso__linea { margin-top: 15px; }
}

/* Variante compacta — usada en BuscarLibros */
.wizard-progreso--sm {
    padding: 8px 4px 6px;
    margin-bottom: 20px !important;
}
.wizard-progreso--sm .wizard-paso__contenido {
    gap: 4px;
    min-width: 52px;
}
.wizard-progreso--sm .wizard-paso__circulo {
    width: 30px;
    height: 30px;
    font-size: 12px;
    border-width: 2px;
}
.wizard-progreso--sm .wizard-paso__label {
    font-size: 11px;
}
.wizard-progreso--sm .wizard-paso__linea {
    margin-top: 15px;
    margin-left: 6px;
    margin-right: 6px;
}

.wizard-nav .btn-link {
    padding: 0.5rem 0;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
}

/* Alertas inline */
.wizard-alerta {
    border-radius: 10px;
    padding: 14px 16px;
    margin-top: 16px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 13px;
    animation: wizardAlertaIn 0.25s ease;
}

.wizard-alerta .btn-close { font-size: 10px; margin-top: 2px; flex-shrink: 0; }
.wizard-alerta strong { font-size: 14px; }
.wizard-alerta ul { font-size: 13px; }

.wizard-alerta--error {
    background: #fdf0f0;
    border: 1px solid #f5c6cb;
    color: #842029;
}

.wizard-alerta--error > i {
    color: #dc3545;
    font-size: 1.1rem;
    margin-top: 1px;
}

.wizard-alerta--aviso {
    background: #fff8f0;
    border: 1px solid var(--vivo-pale);
    color: var(--vivo-dark);
}

.wizard-alerta--aviso > i {
    color: var(--vivo-primary);
    font-size: 1.1rem;
    margin-top: 1px;
}

/* wizard-alerta usado inline dentro de ficha (sin margen top global) */
.ficha .wizard-alerta {
    margin-top: 12px;
}

@keyframes wizardAlertaIn {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════════════════════
   17. FOOTER
═══════════════════════════════════════════════════════════ */
.footer {
    background-color: var(--vivo-dark);
    color: var(--vivo-pale);
    padding: 48px 0 0;
    position: inherit !important;
    white-space: normal;
}

.footer--sin-contenido {
    padding-top: 0;
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 40px;
    padding-bottom: 40px;
    align-items: start;
}

.footer-col {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.footer-titulo {
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #fff;
    margin-bottom: 16px;
}

.footer-lista {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
}

.footer a { color: #fff !important; text-decoration: none; }
.footer a:hover { opacity: 0.75; color: #fff !important; }
.footer-lista a { font-size: 0.9rem; transition: opacity 0.15s; }

.footer-rrss { display: flex; gap: 16px; }
.footer-rrss a { font-size: 1.25rem; transition: opacity 0.15s; }

.footer-contacto li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 0.9rem;
    color: #fff;
    white-space: wrap;
}
.footer-contacto li i {
    flex-shrink: 0;
}
.footer-contacto li a,
.footer-contacto li span {
    min-width: 0;
    overflow-wrap: break-word;
    word-break: break-word;
}

.footer-copyright {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.footer-copyright p {
    text-align: center;
    color: var(--vivo-pale);
    font-size: 0.82rem;
    margin: 0;
}

@media (max-width: 991px) and (min-width: 768px) {
    .footer-grid { gap: 24px; }
}

@media (max-width: 767px) {
    .footer-grid { grid-template-columns: 1fr; gap: 25px; }
    .footer {
        padding: 30px 0 0;
    }
}

/* ═══════════════════════════════════════════════════════════
   18. MODALES UTILITARIOS (ModalConfirm, debug modal)
═══════════════════════════════════════════════════════════ */

/* Fondo oscuro reutilizable */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1040;
}

/* Diálogo de confirmación */
.modal-confirm {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #fff;
    padding: 24px;
    border-radius: 8px;
    z-index: 1050;
    min-width: 320px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

/* Neutralizar overrides de contexto (.mis-datos, .carrito-page) dentro del modal */
.modal-confirm .btn-outline-secondary {
    border-color: var(--bs-secondary);
    color: var(--bs-secondary);
}
.modal-confirm .btn-outline-secondary:hover {
    border-color: var(--bs-secondary);
    color: #fff;
    background-color: var(--bs-secondary);
}

/* Diálogo de mensaje informativo (display.tsx) */
.modal-mensaje {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #fff;
    color: #000;
    padding: 20px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
    border-radius: 8px;
    z-index: 1120;
}

.modal-overlay--mensaje {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1100;
}

/* ═══════════════════════════════════════════════════════════
   19. CARRITO — Pack cards (rediseño visual)
═══════════════════════════════════════════════════════════ */
.pack-card {
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    margin-bottom: 20px;
    background: #fff;
    overflow: hidden;
}

.pack-card:last-child {
    margin-bottom: 0;
}

.pack-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px;
    background: #f8f9fa;
    border-bottom: 1px solid #ececec;
}

.pack-card__header-label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #666;
}

.pack-card__header .btn-link {
    font-size: 14px;
    padding: 0;
}

.pack-card__header .btn-link:hover {
    color: #a71d2a;
}

.pack-card__student {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 14px 16px 10px;
    gap: 12px;
}

.pack-card__student-meta {
    flex: 1;
    min-width: 0;
}

.pack-card__student-nombre {
    font-weight: 700;
    font-size: 1rem;
    color: #1a1a1a;
    margin-bottom: 4px;
}

.pack-card__student-nombre em {
    font-style: normal;
    font-weight: 400;
    font-size: 0.875rem;
    color: #666;
}

.pack-card__oficial {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: #333;
    margin-top: 4px;
}

.pack-card__oficial i {
    color: var(--vivo-primary);
    font-size: 14px;
    flex-shrink: 0;
}

.pack-card__nota {
    font-size: 12px;
    color: var(--vivo-primary);
    margin-top: 3px;
}

.pack-card__ahorro-padre {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
    color: #198754;
    background: #d1e7dd;
    border-radius: 6px;
    padding: 2px 8px;
}

.pack-card__thumbs {
    display: flex;
    align-items: flex-start;
    flex-shrink: 0;
}

.pack-card__thumb {
    width: 48px;
    height: 64px;
    border-radius: 5px;
    border: 1.5px solid #e0e0e0;
    overflow: hidden;
    background: #f5f5f5;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: -10px;
    box-shadow: -2px 0 6px rgba(0, 0, 0, .08);
}

.pack-card__thumb:first-child {
    margin-left: 0;
}

.pack-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pack-card__toggle {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 16px 12px;
    border: none;
    background: none;
    color: var(--vivo-primary);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    transition: color 0.15s;
}

.pack-card__toggle:hover {
    color: var(--vivo-primary-dark);
}

.pack-card__books {
    border-top: 1px solid #ececec;
}

.pack-card__books-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: #ececec;
}

@media (max-width: 575px) {
    .pack-card__books-grid {
        grid-template-columns: 1fr;
    }
}

.pack-card__book-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 14px;
    background: #fff;
}

.pack-card__book-cover {
    width: 44px;
    height: 58px;
    border-radius: 4px;
    overflow: hidden;
    background: #f0f0f0;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e8e8e8;
}

.pack-card__book-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.pack-card__book-titulo {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.3;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    margin-bottom: 3px;
    color: #222;
}

.pack-card__book-isbn,
.pack-card__book-editorial {
    font-size: 11px;
    color: #888;
    margin-top: 1px;
}

.pack-card__footer {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-top: 1px solid #ececec;
    background: #fafafa;
    font-size: 14px;
}

.pack-card__separador {
    border-top: 2px dashed #e0e0e0;
    margin: 0 16px;
}

.pack-card__footer-label {
    color: #666;
}

.pack-card__footer-precio {
    font-weight: 700;
    font-size: 15px;
    color: #1a1a1a;
}

/* Resumen — fila por estudiante */
.resumen-pack-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 0;
    font-size: 14px;
}

.resumen-pack-item:last-child {
    border-bottom: none;
}

.resumen-pack-item .label { color: #444; }
.resumen-pack-item .valor { font-weight: 600; }

.resumen-envio-gratuito {
    color: #198754;
    font-weight: 600;
    font-size: 13px;
}

/* Sección de libros sueltos dentro de la tarjeta */
.pack-card__sueltos {
    background: #fafbfc;
}

.pack-card__sueltos--adicional {
    border-top: 2px dashed #e0e0e0;
}

.pack-card__sueltos-header {
    display: flex;
    align-items: center;
    padding: 10px 16px 6px;
    font-size: 13px;
    font-weight: 600;
    color: #555;
}

.pack-card__sueltos-student {
    padding: 14px 16px 0;
    font-weight: 700;
    font-size: 1rem;
    color: #1a1a1a;
}

.pack-card__sueltos-student em {
    font-style: italic;
    font-weight: 400;
    font-size: 0.9rem;
    color: #555;
}

/* Botón añadir alumno */
.btn-anadir-alumno {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 12px;
    border: 1.5px dashed #ccc;
    border-radius: 10px;
    background: transparent;
    color: #777;
    font-size: 14px;
    cursor: pointer;
    transition: border-color .15s, color .15s;
    margin-top: 4px;
    text-decoration: none;
}

.btn-anadir-alumno:hover {
    border-color: var(--vivo-primary);
    color: var(--vivo-primary);
}

/* ═══════════════════════════════════════════════════════════
   20. PACK-CARD — Cabecera con nombre de estudiante (vistas de sólo lectura)
═══════════════════════════════════════════════════════════ */

/* Variante del header de pack-card para mostrar el nombre del estudiante
   (sin uppercase, con icono coloreado). Usada en ResumenCompra, CompraOk,
   PedidoSapDetalle donde el header identifica al alumno en lugar del tipo de tarjeta. */
.pack-card__header-student {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 600;
    color: #333;
}

.pack-card__header-student .bi-person-fill {
    color: var(--vivo-primary);
}

/* Imagen de portada dentro de un ítem del modal (reemplaza estilos inline) */
.modal-item-img {
    border-radius: 6px;
    display: block;
    max-width: 100%;
    height: auto;
}

/* Icono estrellas pequeño (reemplaza style fontSize inline) */
.bi-stars--sm {
    font-size: 11px;
}

.footer {
    position: absolute;
    bottom: 0;
    width: 100%;
    white-space: nowrap;
    line-height: 50px;
}


/* =============================================================
   CART TOAST - Notificacion al anadir al carrito
   ============================================================= */
.cart-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 1090;
    display: flex;
    align-items: center;
    gap: 12px;
    background: #fff;
    border-left: 4px solid var(--vivo-primary);
    border-radius: 10px;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.13);
    padding: 12px 14px;
    min-width: 270px;
    max-width: 340px;
    transform: translateX(calc(100% + 32px));
    opacity: 0;
    transition: transform 0.32s cubic-bezier(.22,.68,0,1.2), opacity 0.28s ease;
    pointer-events: none;
}

.cart-toast--visible {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}

.cart-toast__icon {
    flex-shrink: 0;
    color: var(--vivo-primary);
    font-size: 1.35rem;
    line-height: 1;
}

.cart-toast__img {
    flex-shrink: 0;
    width: 40px;
    height: 52px;
    object-fit: cover;
    border-radius: 4px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}

.cart-toast__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.cart-toast__label {
    font-size: 12px;
    font-weight: 700;
    color: var(--vivo-primary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.cart-toast__titulo {
    font-size: 13px;
    font-weight: 500;
    color: #333;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.cart-toast__close {
    flex-shrink: 0;
    background: none;
    border: none;
    color: #aaa;
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
    padding: 0 2px;
    transition: color 0.15s;
}

.cart-toast__close:hover {
    color: var(--vivo-primary);
}

/* Ahorro padre en resumen del carrito */
.resumen-ahorro-padre {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 700;
    color: #146c43;
    background: #d1e7dd;
    border-radius: 20px;
    padding: 3px 10px;
}

@media (min-width: 992px) {
    .border-lg-end {
        border-right: 1px solid #dee2e6 !important;
    }
    /* En grid de 2 col, si la última fila está completa (N par), el ítem izquierda también pierde border-bottom */
    .row-cols-lg-2 > .item-carrito:nth-last-child(2):nth-child(odd) {
        border-bottom: none;
    }
}
