﻿/* =========================================================================
   Multinational Life — Components + Global Overrides
   Se carga DESPUÉS de Bootstrap/Nifty para ganar en cascada.
   Principio: sobrescribir tokens y selectores de Bootstrap/Nifty para que
   las vistas existentes se repinten automáticamente sin tocarlas.
   ========================================================================= */

/* =========================================================================
   1. Bootstrap CSS variable overrides (heredado por todo lo demás)
   ========================================================================= */
:root {
    --bs-primary:        #7D1F3D;
    --bs-primary-rgb:    125, 31, 61;
    --bs-border-radius:  0.625rem;
    --bs-border-radius-sm: 0.375rem;
    --bs-body-font-family: var(--mn-font-sans);
    --bs-body-color:     var(--mn-foreground);
}

/* =========================================================================
   2. Global body + typography
   ========================================================================= */
body,
body.jumping {
    font-family: var(--mn-font-sans);
    color: var(--mn-foreground);
    background-color: var(--mn-background);
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--mn-font-sans);
    color: var(--mn-foreground);
    font-weight: var(--mn-fw-semibold);
}

.page-title,
.card-title {
    font-weight: var(--mn-fw-semibold);
    color: var(--mn-foreground);
}

.breadcrumb-item a {
    color: var(--mn-primary);
    text-decoration: none;
}
.breadcrumb-item.active {
    color: var(--mn-muted-foreground);
}

/* =========================================================================
   3. Buttons — Bootstrap overrides
   ========================================================================= */
.btn {
    border-radius: var(--mn-radius);
    font-weight: var(--mn-fw-medium);
    transition: var(--mn-transition);
    padding: 0.5rem 1rem;
}

.btn-primary,
.btn-primary:focus {
    background-color: var(--mn-primary);
    border-color: var(--mn-primary);
    color: var(--mn-primary-foreground);
}
.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus-visible,
.btn-check:checked + .btn-primary,
.btn-primary.active {
    background-color: var(--mn-primary-hover) !important;
    border-color: var(--mn-primary-hover) !important;
    color: var(--mn-primary-foreground);
}
.btn-primary:disabled,
.btn-primary.disabled {
    background-color: var(--mn-primary);
    border-color: var(--mn-primary);
    opacity: 0.5;
}

.btn-outline-primary {
    color: var(--mn-primary);
    border-color: var(--mn-primary);
    background-color: transparent;
}
.btn-outline-primary:hover,
.btn-outline-primary:active {
    background-color: var(--mn-primary);
    border-color: var(--mn-primary);
    color: var(--mn-primary-foreground);
}

.btn-secondary {
    background-color: var(--mn-secondary);
    border-color: var(--mn-secondary);
    color: var(--mn-secondary-foreground);
}
.btn-secondary:hover {
    background-color: var(--mn-accent);
    border-color: var(--mn-accent);
    color: var(--mn-secondary-foreground);
}

.btn-success {
    background-color: var(--mn-success);
    border-color: var(--mn-success);
}
.btn-success:hover {
    background-color: #15803D;
    border-color: #15803D;
}

.btn-danger {
    background-color: var(--mn-destructive);
    border-color: var(--mn-destructive);
}

/* Continuar pill button (accent blue) */
.btn-continuar,
.btn.btn-continuar {
    background-color: var(--mn-accent-blue);
    color: #fff;
    border: none;
    border-radius: var(--mn-radius-full);
    padding: 0.4rem 1.25rem;
    font-weight: var(--mn-fw-medium);
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
}
.btn-continuar:hover {
    background-color: var(--mn-accent-blue-hover);
    color: #fff;
}

/* =========================================================================
   4. Cards
   ========================================================================= */
.card {
    border-radius: var(--mn-radius);
    border: 1px solid var(--mn-border);
    box-shadow: var(--mn-shadow);
    background-color: var(--mn-card);
}

.card-header {
    background-color: var(--mn-card);
    border-bottom: 1px solid var(--mn-border);
    font-weight: var(--mn-fw-semibold);
}

/* Branded card header — opt-in via .mn-card */
.mn-card > .card-header,
.mn-card-header {
    background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-hover) 100%);
    color: #fff;
    border-radius: var(--mn-radius) var(--mn-radius) 0 0;
    padding: 1.25rem 1.5rem;
    border-bottom: none;
    display: flex;
    align-items: center;
    gap: 0.875rem;
}
.mn-card > .card-header h1,
.mn-card > .card-header h2,
.mn-card > .card-header h3,
.mn-card > .card-header h4,
.mn-card > .card-header h5,
.mn-card > .card-header h6,
.mn-card-header h1,
.mn-card-header h2,
.mn-card-header h3,
.mn-card-header h4,
.mn-card-header h5,
.mn-card-header h6 {
    color: #fff;
    margin: 0;
    font-weight: var(--mn-fw-semibold);
}
.mn-card-header-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(255,255,255,0.15);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.25rem;
    flex: 0 0 auto;
}
.mn-card-header-subtitle {
    color: rgba(255,255,255,0.85);
    font-size: 0.875rem;
    font-weight: var(--mn-fw-normal);
    display: block;
    margin-top: 2px;
}

/* =========================================================================
   5. Tables
   ========================================================================= */
.table {
    --bs-table-bg: transparent;
    border-radius: var(--mn-radius);
    overflow: hidden;
}

.table thead th {
    background-color: var(--mn-accent);
    color: var(--mn-primary);
    font-weight: var(--mn-fw-semibold);
    border-bottom: none;
    padding: 0.875rem 1rem;
    text-transform: none;
    font-size: 0.875rem;
}

.table tbody td {
    padding: 1rem;
    vertical-align: middle;
    border-bottom: 1px solid var(--mn-border);
}

.table-hover tbody tr:hover {
    background-color: rgba(245, 212, 220, 0.3);
}

/* Price destacado en rojo */
.mn-price,
.table .text-danger.fw-bold {
    color: var(--mn-destructive) !important;
    font-weight: var(--mn-fw-bold);
}

/* =========================================================================
   6. Forms
   ========================================================================= */
.form-control,
.form-select {
    border-radius: var(--mn-radius-sm);
    background-color: var(--mn-input-background);
    border: 1px solid var(--mn-border);
    padding: 0.55rem 0.875rem;
    font-family: var(--mn-font-sans);
    color: var(--mn-foreground);
    transition: var(--mn-transition);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--mn-primary);
    background-color: #fff;
    box-shadow: 0 0 0 3px rgba(164, 45, 82, 0.15);
    color: var(--mn-foreground);
}

.form-control::placeholder {
    color: var(--mn-muted-foreground);
}

.form-label {
    font-weight: var(--mn-fw-medium);
    color: var(--mn-foreground);
    margin-bottom: 0.375rem;
}

/* Search input con ícono interno */
.mn-search {
    position: relative;
}
.mn-search .form-control {
    padding-left: 2.5rem;
    background-color: #fff;
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
}
.mn-search::before {
    content: "\f002"; /* FontAwesome search */
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    position: absolute;
    left: 0.875rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--mn-muted-foreground);
    pointer-events: none;
    z-index: 2;
}

/* =========================================================================
   7. Modals
   ========================================================================= */
.modal-content {
    border-radius: var(--mn-radius);
    border: none;
    box-shadow: var(--mn-shadow-lg);
    overflow: hidden;
}
.modal-header {
    background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-hover) 100%);
    color: #fff;
    border-radius: var(--mn-radius) var(--mn-radius) 0 0;
    border-bottom: none;
    padding: 1.25rem 1.5rem;
}
.modal-header .modal-title {
    color: #fff;
    font-weight: var(--mn-fw-semibold);
}
.modal-header .btn-close {
    filter: brightness(0) invert(1);
    opacity: 0.9;
}
.modal-header .btn-close:hover {
    opacity: 1;
}
.modal-body {
    padding: 1.5rem;
}
.modal-footer {
    border-top: 1px solid var(--mn-border);
    padding: 1rem 1.5rem;
}

/* =========================================================================
   8. Badges, alerts, checks
   ========================================================================= */
.badge.bg-primary {
    background-color: var(--mn-primary) !important;
}
.badge.bg-secondary {
    background-color: var(--mn-secondary) !important;
    color: var(--mn-secondary-foreground);
}

.alert-success {
    background-color: var(--mn-success-light);
    color: #14532D;
    border-color: rgba(22, 163, 74, 0.25);
    border-radius: var(--mn-radius);
}
.alert-danger {
    background-color: #FEE2E2;
    color: #7F1D1D;
    border-color: rgba(212, 24, 61, 0.25);
    border-radius: var(--mn-radius);
}

/* Check mark helper (para listas de coberturas) */
.mn-check {
    color: var(--mn-success);
    font-weight: var(--mn-fw-bold);
    margin-right: 0.5rem;
}

/* =========================================================================
   9. Navigation — sidebar + nav tweaks
   ========================================================================= */
.nav-tabs {
    border-bottom: 2px solid var(--mn-border);
    gap: 0.35rem;
    padding: 0 0.5rem;
}
.nav-tabs .nav-link {
    color: var(--mn-foreground);
    background-color: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    font-weight: var(--mn-fw-semibold);
    font-size: 0.95rem;
    padding: 0.9rem 1.35rem;
    border-radius: var(--mn-radius) var(--mn-radius) 0 0;
    margin-bottom: -2px;
    transition: var(--mn-transition);
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}
.nav-tabs .nav-link i {
    color: var(--mn-muted-foreground);
    transition: var(--mn-transition);
    font-size: 1rem;
}
.nav-tabs .nav-link:hover,
.nav-tabs .nav-link:focus {
    color: var(--mn-primary);
    background-color: var(--mn-secondary);
    border-color: transparent;
    border-bottom-color: var(--mn-accent);
}
.nav-tabs .nav-link:hover i {
    color: var(--mn-primary);
}
.nav-tabs .nav-link.active,
.nav-tabs .nav-link.active:hover {
    color: var(--mn-primary) !important;
    background-color: var(--mn-secondary) !important;
    border-bottom: 3px solid var(--mn-primary) !important;
    font-weight: var(--mn-fw-bold);
    box-shadow: 0 -2px 8px rgba(125, 31, 61, 0.05);
}
.nav-tabs .nav-link.active i {
    color: var(--mn-primary) !important;
}

/* Sidebar active */
.mainnav__menu .nav-link.active,
.mainnav__menu .nav-link:hover {
    color: var(--mn-primary);
}

/* =========================================================================
   10. Branded components reusables
   ========================================================================= */

/* Language switcher ES/EN */
.mn-lang-switch {
    display: inline-flex;
    border: 1px solid var(--mn-primary);
    border-radius: var(--mn-radius-full);
    overflow: hidden;
    background: #fff;
}
.mn-lang-switch .mn-lang-btn {
    background: transparent;
    color: var(--mn-primary);
    border: none;
    padding: 0.35rem 0.9rem;
    font-weight: var(--mn-fw-medium);
    font-size: 0.875rem;
    cursor: pointer;
    transition: var(--mn-transition);
}
.mn-lang-switch .mn-lang-btn.active {
    background: var(--mn-primary);
    color: #fff;
}

/* Premium badge (Prima Mensual Estimada) */
.mn-premium-badge {
    text-align: right;
    line-height: 1.2;
}
.mn-premium-badge-label {
    font-size: 0.75rem;
    color: var(--mn-muted-foreground);
    display: block;
}
.mn-premium-badge-amount {
    font-weight: var(--mn-fw-bold);
    color: var(--mn-primary);
    font-size: 1.125rem;
}

/* Plan selection card (MASTER 50K / VITAL 360 style) */
.mn-plan-card {
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
    overflow: hidden;
    background: #fff;
    box-shadow: var(--mn-shadow);
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: var(--mn-transition);
}
.mn-plan-card:hover {
    box-shadow: var(--mn-shadow-md);
    transform: translateY(-2px);
}
.mn-plan-card-header {
    background: var(--mn-primary);
    color: #fff;
    padding: 1rem 1.25rem;
    font-weight: var(--mn-fw-bold);
    font-size: 1.25rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.mn-plan-card-body {
    padding: 1.25rem 1.5rem;
    flex-grow: 1;
}
.mn-plan-card-body h6 {
    color: var(--mn-success);
    font-weight: var(--mn-fw-semibold);
    margin-bottom: 0.75rem;
}
.mn-plan-card-body ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.mn-plan-card-body ul li {
    padding: 0.375rem 0;
    display: flex;
    align-items: start;
    gap: 0.5rem;
    color: var(--mn-foreground);
    font-size: 0.9rem;
}
.mn-plan-card-body ul li::before {
    content: "\f00c"; /* FontAwesome check */
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    color: var(--mn-success);
    flex: 0 0 auto;
}
.mn-plan-card-footer {
    padding: 0 1.5rem 1.5rem;
}
.mn-plan-card-footer .btn {
    width: 100%;
    padding: 0.75rem;
    font-weight: var(--mn-fw-semibold);
}

/* Step bar (wizard) */
.mn-step-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    padding: 2rem 0 1rem;
    flex-wrap: wrap;
}
.mn-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    min-width: 40px;
}
.mn-step-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #E5E7EB;
    color: #9CA3AF;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    transition: var(--mn-transition);
}
.mn-step.active .mn-step-circle {
    background: var(--mn-primary);
    color: #fff;
    box-shadow: 0 0 0 4px rgba(125, 31, 61, 0.15);
}
.mn-step.complete .mn-step-circle {
    background: var(--mn-primary);
    color: #fff;
}
.mn-step-label {
    position: absolute;
    top: -28px;
    background: var(--mn-primary);
    color: #fff;
    padding: 2px 10px;
    border-radius: var(--mn-radius-full);
    font-size: 0.7rem;
    white-space: nowrap;
    display: none;
}
.mn-step.active .mn-step-label {
    display: inline-block;
}
.mn-step-connector {
    height: 2px;
    width: 24px;
    background: #E5E7EB;
    margin-top: 0;
}

/* Cotizaciones pendientes pill button (para header) */
.mn-pill-cta {
    background: var(--mn-primary);
    color: #fff;
    border: none;
    border-radius: var(--mn-radius-full);
    padding: 0.4rem 1rem;
    font-size: 0.875rem;
    font-weight: var(--mn-fw-medium);
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
}
.mn-pill-cta:hover {
    background: var(--mn-primary-hover);
    color: #fff;
}

/* =========================================================================
   10.b  Info stat-items (para el grid de Consulta de Póliza)
   Cada bloque de info (Nro Póliza, Producto, etc.) con ícono a la izq
   y label + valor apilados a la derecha
   ========================================================================= */
.mn-info-item {
    display: flex;
    align-items: flex-start;
    gap: 0.875rem;
    padding: 1rem;
    background: var(--mn-background);
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
    transition: var(--mn-transition);
    height: 100%;
}
.mn-info-item:hover {
    border-color: var(--mn-border-strong);
    box-shadow: var(--mn-shadow);
}
.mn-info-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--mn-accent);
    color: var(--mn-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex: 0 0 auto;
}
.mn-info-label {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--mn-muted-foreground);
    font-weight: var(--mn-fw-semibold);
    margin-bottom: 2px;
}
.mn-info-value {
    display: block;
    color: var(--mn-foreground);
    font-weight: var(--mn-fw-semibold);
    font-size: 0.95rem;
    word-break: break-word;
}
/* Variante destacada para campos importantes (prima) */
.mn-info-item--highlight {
    background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-hover) 100%);
    border-color: transparent;
}
.mn-info-item--highlight .mn-info-icon {
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
}
.mn-info-item--highlight .mn-info-label {
    color: rgba(255, 255, 255, 0.8);
}
.mn-info-item--highlight .mn-info-value {
    color: #fff;
    font-size: 1.1rem;
}

/* =========================================================================
   Policy Hero — header destacado para Consulta de Póliza
   Layout: número póliza (grande) + producto + status + prima destacada
   ========================================================================= */
.mn-policy-hero {
    background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-hover) 100%);
    color: #fff;
    border-radius: var(--mn-radius);
    padding: 1.1rem 1.5rem;
    margin-bottom: 1rem;
    position: relative;
    overflow: hidden;
    box-shadow: var(--mn-shadow-md);
}
/* Titular: número + chip estado en la misma línea */
.mn-policy-hero-headline {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}
.mn-policy-hero::before {
    content: "";
    position: absolute;
    top: -50px;
    right: -50px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.06);
}
.mn-policy-hero::after {
    content: "";
    position: absolute;
    bottom: -80px;
    right: 40px;
    width: 160px;
    height: 160px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.04);
}
.mn-policy-hero-grid {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.5rem;
    align-items: center;
    position: relative;
    z-index: 1;
}
.mn-policy-hero-label {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255, 255, 255, 0.75);
    font-weight: var(--mn-fw-semibold);
    margin-bottom: 0.3rem;
}
.mn-policy-hero-number {
    color: #fff;
    font-size: 1.7rem;
    font-weight: var(--mn-fw-bold);
    margin: 0;
    line-height: 1.1;
    letter-spacing: -0.01em;
}
.mn-policy-hero-product {
    display: block;
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.9rem;
    font-weight: var(--mn-fw-medium);
    margin-top: 0.2rem;
    letter-spacing: 0.01em;
}
.mn-policy-hero-status {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: rgba(255, 255, 255, 0.22);
    color: #fff;
    padding: 0.15rem 0.6rem;
    border-radius: var(--mn-radius-full);
    font-size: 0.7rem;
    font-weight: var(--mn-fw-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    flex-shrink: 0;
}
.mn-policy-hero-status .dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #22C55E;
    display: inline-block;
}
.mn-policy-hero-prima {
    text-align: right;
    color: #fff;
    padding: 0.55rem 1rem;
    background: rgba(255, 255, 255, 0.12);
    border-radius: var(--mn-radius);
    border: 1px solid rgba(255, 255, 255, 0.2);
    min-width: 130px;
}
.mn-policy-hero-prima-label {
    display: block;
    font-size: 0.66rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255, 255, 255, 0.75);
    font-weight: var(--mn-fw-semibold);
    margin-bottom: 0.15rem;
}
.mn-policy-hero-prima-value {
    display: block;
    color: #fff;
    font-size: 1.5rem;
    font-weight: var(--mn-fw-bold);
    line-height: 1;
    letter-spacing: -0.01em;
}
.mn-policy-hero-prima-freq {
    display: block;
    color: rgba(255, 255, 255, 0.75);
    font-size: 0.68rem;
    margin-top: 0.15rem;
}
@media (max-width: 767px) {
    .mn-policy-hero { padding: 1.25rem 1.25rem; }
    .mn-policy-hero-grid { grid-template-columns: 1fr; gap: 1rem; }
    .mn-policy-hero-number { font-size: 1.5rem; }
    .mn-policy-hero-prima-value { font-size: 1.5rem; }
    .mn-policy-hero-prima { text-align: left; }
}

/* =========================================================================
   Live Video Section (YouTube embed + promo banner)
   ========================================================================= */
.mn-live-section {
    margin-bottom: 1.5rem;
    border-radius: var(--mn-radius);
    overflow: hidden;
    box-shadow: var(--mn-shadow-md);
    background: #000;
    position: relative;
}
.mn-live-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1.25rem;
    background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-hover) 100%);
    color: #fff;
}
.mn-live-title {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    color: #fff;
    font-weight: var(--mn-fw-bold);
    font-size: 1rem;
    margin: 0;
}
.mn-live-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: #EF4444;
    color: #fff;
    padding: 0.2rem 0.65rem;
    border-radius: var(--mn-radius-full);
    font-size: 0.72rem;
    font-weight: var(--mn-fw-bold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.7);
    animation: mnLivePulse 2s infinite;
}
.mn-live-badge::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 0 6px #fff;
}
@keyframes mnLivePulse {
    0%   { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.7); }
    70%  { box-shadow: 0 0 0 10px rgba(239, 68, 68, 0); }
    100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0); }
}
.mn-live-embed {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
}
.mn-live-embed iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}
.mn-live-promo-banner {
    background: linear-gradient(90deg, #FFD700 0%, #FFA500 50%, #FFD700 100%);
    color: #7D1F3D;
    padding: 0.85rem 1.25rem;
    text-align: center;
    font-weight: var(--mn-fw-bold);
    font-size: 1.1rem;
    letter-spacing: 0.02em;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    animation: mnPromoShine 3s linear infinite;
    background-size: 200% 100%;
}
.mn-live-promo-banner i {
    font-size: 1.3rem;
    color: var(--mn-primary);
}
.mn-live-promo-amount {
    font-size: 1.5rem;
    color: #7D1F3D;
    font-weight: 900;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.6);
}
@keyframes mnPromoShine {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* =========================================================================
   Modal — variante más ancha para tabla de pagos (evita scroll horizontal)
   ========================================================================= */
.modal.mn-modal-wide .modal-dialog,
.modal-dialog.mn-modal-wide {
    max-width: 1280px;
    width: 95vw;
}

/* =========================================================================
   Tabla de pagos — diseño moderno
   ========================================================================= */
.mn-payment-table {
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
    overflow: hidden;
    box-shadow: var(--mn-shadow-sm);
    background: #fff;
    margin-bottom: 0;
}
.mn-payment-table thead th {
    background: var(--mn-secondary) !important;
    color: var(--mn-primary) !important;
    font-size: 0.72rem !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: var(--mn-fw-bold);
    padding: 0.85rem 0.75rem !important;
    border-bottom: 2px solid var(--mn-border);
    white-space: nowrap;
    vertical-align: middle;
    text-align: center;
}
.mn-payment-table tbody td {
    padding: 1rem 0.75rem !important;
    vertical-align: middle;
    border-bottom: 1px solid var(--mn-border);
    font-size: 0.88rem;
    color: var(--mn-foreground);
    text-align: center;
}
.mn-payment-table tbody tr:last-child td { border-bottom: none; }
.mn-payment-table tbody tr:hover { background-color: rgba(245, 212, 220, 0.25); }

/* Celda póliza — monospace y destacada */
.mn-cell-poliza {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-weight: var(--mn-fw-bold);
    color: var(--mn-primary);
    font-size: 0.92rem;
    letter-spacing: 0.02em;
}

/* Celda fecha — tipografía limpia */
.mn-cell-date {
    color: var(--mn-foreground);
    font-weight: var(--mn-fw-medium);
    font-variant-numeric: tabular-nums;
}
.mn-cell-date-empty {
    color: var(--mn-muted-foreground);
    font-weight: var(--mn-fw-normal);
}

/* Chip de días vencidos con severidad */
.mn-days-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.65rem;
    border-radius: var(--mn-radius-full);
    font-size: 0.78rem;
    font-weight: var(--mn-fw-bold);
    font-variant-numeric: tabular-nums;
}
.mn-days-chip.ok       { background: #DCFCE7; color: #166534; }
.mn-days-chip.warning  { background: #FEF3C7; color: #92400E; }
.mn-days-chip.danger   { background: #FEE2E2; color: #991B1B; }

/* Chip para método/modo de pago */
.mn-pay-method-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.6rem;
    background: #fff;
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius-full);
    color: var(--mn-foreground);
    font-size: 0.78rem;
    font-weight: var(--mn-fw-semibold);
}
.mn-pay-method-chip i {
    color: var(--mn-primary);
    font-size: 0.72rem;
}

/* Día de pago (número grande circular) */
.mn-due-day {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--mn-secondary);
    color: var(--mn-primary);
    font-weight: var(--mn-fw-bold);
    font-size: 0.85rem;
    font-variant-numeric: tabular-nums;
}

/* Botones de acción en la tabla — más presence */
.mn-payment-table .payButton,
.mn-payment-table .payButtonTerm,
.mn-payment-table .payButtonAdelantado {
    background: var(--mn-primary);
    border: none;
    color: #fff;
    font-weight: var(--mn-fw-semibold);
    padding: 0.5rem 1rem;
    border-radius: var(--mn-radius);
    font-size: 0.85rem;
    transition: var(--mn-transition);
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    white-space: nowrap;
}
.mn-payment-table .payButton:not(:disabled):hover,
.mn-payment-table .payButtonTerm:not(:disabled):hover,
.mn-payment-table .payButtonAdelantado:not(:disabled):hover {
    background: var(--mn-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(125, 31, 61, 0.25);
    color: #fff;
}
.mn-payment-table .payButton:disabled,
.mn-payment-table .payButtonTerm:disabled,
.mn-payment-table .payButtonAdelantado:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.mn-payment-table .payButtonTerm {
    background: #D97706;
}
.mn-payment-table .payButtonTerm:not(:disabled):hover {
    background: #B45309;
    box-shadow: 0 4px 10px rgba(217, 119, 6, 0.3);
}
.mn-payment-table .payButtonAdelantado {
    background: var(--mn-success);
}
.mn-payment-table .payButtonAdelantado:not(:disabled):hover {
    background: #15803D;
    box-shadow: 0 4px 10px rgba(22, 163, 74, 0.3);
}

/* Estado vacío de tabla de pagos */
.mn-payment-empty {
    padding: 3rem 1rem;
    text-align: center;
    color: var(--mn-muted-foreground);
}
.mn-payment-empty i {
    font-size: 2.5rem;
    color: var(--mn-accent);
    display: block;
    margin-bottom: 0.75rem;
}
.mn-payment-empty p {
    margin: 0;
    font-weight: var(--mn-fw-semibold);
}

/* =========================================================================
   Monto a Pagar — input readonly destacado (no apagado)
   ========================================================================= */
.mn-monto-pagar {
    display: inline-flex;
    align-items: center;
    background: var(--mn-secondary);
    border: 2px solid var(--mn-primary);
    border-radius: var(--mn-radius);
    padding: 0.3rem 0.6rem;
    min-width: 7rem;
    box-shadow: 0 2px 6px rgba(125, 31, 61, 0.12);
    transition: var(--mn-transition);
}
.mn-monto-pagar:hover {
    box-shadow: 0 4px 10px rgba(125, 31, 61, 0.2);
}
.mn-monto-pagar .mn-monto-currency {
    color: var(--mn-primary);
    font-weight: var(--mn-fw-bold);
    font-size: 0.95rem;
    margin-right: 0.35rem;
    opacity: 0.9;
}
.mn-monto-pagar .mn-monto-input {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    box-shadow: none !important;
    color: var(--mn-primary) !important;
    font-weight: var(--mn-fw-bold) !important;
    font-size: 1.05rem !important;
    font-variant-numeric: tabular-nums;
    text-align: left;
    cursor: default;
    height: auto;
    line-height: 1.2;
    opacity: 1 !important;
    -webkit-text-fill-color: var(--mn-primary);
}
.mn-monto-pagar .mn-monto-input::placeholder {
    color: var(--mn-primary);
    opacity: 0.35;
    font-weight: var(--mn-fw-semibold);
}
.mn-monto-pagar .mn-monto-input:focus {
    outline: none;
}
/* Cuando NO hay valor, aspecto más sutil; cuando SÍ hay valor, destaca */
.mn-monto-pagar:has(.mn-monto-input[value=""]) {
    background: #fff;
    border-color: var(--mn-border-strong);
}

/* =========================================================================
   Payment Amount Check — label que envuelve checkbox + monto
   Uso: en la tabla de pagos, reemplaza el checkbox nativo por una card
   clickeable con el monto al lado y efecto visual de "selected"
   ========================================================================= */
.mn-check-amount {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.4rem 0.75rem;
    border: 2px solid var(--mn-border);
    border-radius: var(--mn-radius);
    cursor: pointer;
    transition: var(--mn-transition);
    background: #fff;
    user-select: none;
    min-width: 6.5rem;
    white-space: nowrap;
}
.mn-check-amount:hover {
    border-color: var(--mn-primary);
    background: var(--mn-secondary);
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(125, 31, 61, 0.12);
}
.mn-check-amount input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 20px;
    height: 20px;
    min-width: 20px;
    border: 2px solid var(--mn-border-strong);
    border-radius: 5px;
    position: relative;
    cursor: pointer;
    flex-shrink: 0;
    background: #fff;
    transition: var(--mn-transition);
    margin: 0;
    padding: 0;
}
.mn-check-amount input[type="checkbox"]:hover {
    border-color: var(--mn-primary);
}
.mn-check-amount input[type="checkbox"]:checked {
    background: var(--mn-primary);
    border-color: var(--mn-primary);
    box-shadow: 0 0 0 3px rgba(125, 31, 61, 0.18);
}
.mn-check-amount input[type="checkbox"]:checked::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 5px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: translate(-50%, -60%) rotate(45deg);
}
.mn-check-amount:has(input:checked),
.mn-check-amount.mn-checked {
    border-color: var(--mn-primary);
    background: var(--mn-secondary);
    box-shadow: 0 2px 10px rgba(125, 31, 61, 0.15);
}
.mn-check-amount .mn-check-currency {
    color: var(--mn-primary);
    font-weight: var(--mn-fw-bold);
    font-size: 0.78rem;
    opacity: 0.85;
}
.mn-check-amount .mn-check-amount-value {
    color: var(--mn-foreground);
    font-weight: var(--mn-fw-semibold);
    font-size: 0.95rem;
    font-variant-numeric: tabular-nums;
}
.mn-check-amount:has(input:checked) .mn-check-amount-value,
.mn-check-amount.mn-checked .mn-check-amount-value {
    color: var(--mn-primary);
    font-weight: var(--mn-fw-bold);
}

/* =========================================================================
   Home — Sección 1: Banner + 3 cards de blog
   ========================================================================= */
.mn-home-banner-row {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: 1rem;
    margin-bottom: 1.5rem;
}
.mn-home-hero-banner {
    position: relative;
    border-radius: var(--mn-radius);
    overflow: hidden;
    min-height: 320px;
    background-size: cover;
    background-position: center;
    box-shadow: var(--mn-shadow-md);
    color: #fff;
    display: flex;
    align-items: flex-end;
}
.mn-home-hero-banner::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(125, 31, 61, 0.1) 0%, rgba(125, 31, 61, 0.75) 85%, rgba(125, 31, 61, 0.9) 100%);
}
.mn-home-hero-banner-content {
    position: relative;
    z-index: 2;
    padding: 1.75rem 2rem;
}
.mn-home-hero-banner-content h2 {
    color: #fff;
    font-size: 1.8rem;
    font-weight: var(--mn-fw-bold);
    margin: 0 0 0.4rem 0;
    line-height: 1.15;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}
.mn-home-hero-banner-content p {
    color: rgba(255, 255, 255, 0.95);
    margin: 0;
    font-size: 0.95rem;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.mn-blog-cards {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.mn-blog-card {
    background: #fff;
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
    padding: 0.75rem;
    display: grid;
    grid-template-columns: 96px 1fr;
    gap: 0.85rem;
    align-items: center;
    text-decoration: none;
    color: var(--mn-foreground);
    transition: var(--mn-transition);
    box-shadow: var(--mn-shadow-sm);
}
.mn-blog-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--mn-shadow-md);
    border-color: var(--mn-primary);
    color: var(--mn-foreground);
    text-decoration: none;
}
.mn-blog-card-img {
    width: 96px;
    height: 80px;
    object-fit: cover;
    border-radius: var(--mn-radius-sm);
    background: var(--mn-secondary);
}
.mn-blog-card-title {
    font-size: 0.88rem;
    font-weight: var(--mn-fw-semibold);
    color: var(--mn-foreground);
    line-height: 1.3;
    margin: 0 0 0.3rem 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.mn-blog-card-link {
    font-size: 0.75rem;
    color: var(--mn-primary);
    font-weight: var(--mn-fw-semibold);
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}
@media (max-width: 991px) {
    .mn-home-banner-row { grid-template-columns: 1fr; }
    .mn-home-hero-banner { min-height: 220px; }
}

/* =========================================================================
   Home — Sección 3: Ticker/teleprompter de noticias
   ========================================================================= */
.mn-ticker-wrap {
    background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-hover) 100%);
    border-radius: var(--mn-radius);
    display: flex;
    align-items: center;
    overflow: hidden;
    margin-bottom: 1.5rem;
    box-shadow: var(--mn-shadow);
}
.mn-ticker-label {
    flex: 0 0 auto;
    color: #fff;
    font-weight: var(--mn-fw-bold);
    font-size: 0.92rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 1.05rem 1.4rem;
    background: rgba(0, 0, 0, 0.2);
    border-right: 2px solid rgba(255, 255, 255, 0.3);
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    white-space: nowrap;
}
.mn-ticker-label i {
    font-size: 1.05rem;
}
.mn-ticker-viewport {
    flex: 1 1 auto;
    overflow: hidden;
    position: relative;
}
.mn-ticker-track {
    display: inline-flex;
    white-space: nowrap;
    animation: mnTickerScroll 90s linear infinite;
}
.mn-ticker-track:hover { animation-play-state: paused; }
.mn-ticker-item {
    color: #fff;
    font-size: 1.05rem;
    padding: 1.05rem 1.6rem;
    position: relative;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    white-space: nowrap;
}
.mn-ticker-item::after {
    content: "•";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    color: rgba(255, 255, 255, 0.5);
    font-weight: bold;
}
.mn-ticker-item:hover { color: #fff; text-decoration: underline; }
.mn-ticker-item i { color: #FFD700; font-size: 0.9rem; }
@keyframes mnTickerScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* =========================================================================
   Welcome banner (Home) — estático, sin carousel
   ========================================================================= */
.mn-welcome-banner {
    position: relative;
    background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-hover) 100%);
    color: #fff;
    border-radius: var(--mn-radius);
    padding: 0.85rem 1.4rem !important;
    margin-bottom: 1rem;
    overflow: hidden;
    box-shadow: var(--mn-shadow-md);
}
.mn-welcome-banner::before {
    content: "";
    position: absolute;
    top: -60px;
    right: -80px;
    width: 260px;
    height: 260px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.06);
}
.mn-welcome-banner::after {
    content: "";
    position: absolute;
    bottom: -100px;
    right: 60px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
}
.mn-welcome-banner-grid {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    position: relative;
    z-index: 1;
}
.mn-welcome-banner h1 {
    color: #fff;
    font-size: 1.15rem !important;
    font-weight: var(--mn-fw-bold);
    margin: 0 0 0.15rem 0 !important;
    line-height: 1.2;
    letter-spacing: -0.01em;
}
.mn-welcome-banner p {
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.85rem;
    margin: 0;
    max-width: 38rem;
}
/* Icono FontAwesome de cada vista — A LA IZQUIERDA del título (compacto) */
.mn-welcome-banner-icon {
    width: 44px !important;
    height: 44px !important;
    border-radius: 12px !important;
    background: rgba(255, 255, 255, 0.18) !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem !important;
    color: #fff !important;
    flex: 0 0 auto;
    order: -1;          /* va antes que el título */
}
@media (max-width: 767px) {
    .mn-welcome-banner { padding: 0.75rem 1rem !important; }
    .mn-welcome-banner-grid { justify-content: flex-start; gap: .75rem; }
    .mn-welcome-banner h1 { font-size: 1.05rem !important; }
    .mn-welcome-banner-icon { width: 38px !important; height: 38px !important; font-size: 1rem !important; }
    .mn-welcome-socials { justify-content: center; }
}

/* Strip social friendly DENTRO del welcome banner — LLAMATIVAS */
.mn-welcome-socials {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    margin-top: 1.25rem;
    flex-wrap: wrap;
}
.mn-welcome-socials-label {
    font-size: 0.9rem;
    color: #fff;
    font-weight: var(--mn-fw-semibold);
    margin-right: 0.3rem;
}
.mn-welcome-social-btn {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 1.25rem;
    border: 2px solid rgba(255, 255, 255, 0.35);
    transition: var(--mn-transition);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
    position: relative;
}
.mn-welcome-social-btn:hover {
    transform: translateY(-3px) scale(1.05);
    color: #fff;
    text-decoration: none;
    border-color: #fff;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}
/* Colores de marca desde el inicio */
.mn-welcome-social-btn.mn-social-fb { background: #1877F2; }
.mn-welcome-social-btn.mn-social-ig {
    background: linear-gradient(45deg, #F58529 0%, #DD2A7B 50%, #8134AF 100%);
}
.mn-welcome-social-btn.mn-social-x  {
    background: #000000;
    /* Borde blanco más opaco + halo para que destaque sobre burgundy */
    border-color: rgba(255, 255, 255, 0.7);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.18), 0 4px 12px rgba(0, 0, 0, 0.35);
}
.mn-welcome-social-btn.mn-social-x:hover {
    background: #1a1a1a;
    border-color: #fff;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.25), 0 8px 20px rgba(0, 0, 0, 0.4);
}

.mn-welcome-web-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--mn-primary);
    background: #fff;
    text-decoration: none;
    font-size: 0.92rem;
    font-weight: var(--mn-fw-semibold);
    padding: 0.55rem 1.1rem;
    border-radius: var(--mn-radius-full);
    margin-left: 0.3rem;
    transition: var(--mn-transition);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
}
.mn-welcome-web-link:hover {
    color: var(--mn-primary);
    text-decoration: none;
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
}
.mn-welcome-web-link i { font-size: 1rem; }

/* =========================================================================
   Social cards grid (redes sociales profesionales)
   ========================================================================= */
.mn-social-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0.875rem;
    margin-bottom: 1rem;
}
.mn-social-card {
    background: #fff;
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
    padding: 1.1rem 1rem;
    text-decoration: none;
    color: var(--mn-foreground);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.5rem;
    transition: var(--mn-transition);
    position: relative;
    overflow: hidden;
}
.mn-social-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--social-color, var(--mn-primary));
    opacity: 0;
    transition: opacity 0.2s;
    z-index: 0;
}
.mn-social-card > * { position: relative; z-index: 1; }
.mn-social-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--mn-shadow-lg);
    border-color: transparent;
    color: #fff;
    text-decoration: none;
}
.mn-social-card:hover::before { opacity: 1; }
.mn-social-card:hover .mn-social-card-icon,
.mn-social-card:hover .mn-social-card-name,
.mn-social-card:hover .mn-social-card-handle { color: #fff; }

.mn-social-card-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--mn-secondary);
    color: var(--social-color, var(--mn-primary));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    transition: var(--mn-transition);
}
.mn-social-card:hover .mn-social-card-icon {
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
}
.mn-social-card-name {
    font-weight: var(--mn-fw-bold);
    font-size: 0.95rem;
    color: var(--mn-foreground);
    transition: var(--mn-transition);
}
.mn-social-card-handle {
    font-size: 0.8rem;
    color: var(--mn-muted-foreground);
    transition: var(--mn-transition);
}

/* Colores de marca por platform */
.mn-social-card.social-facebook  { --social-color: #1877F2; }
.mn-social-card.social-instagram { --social-color: #E4405F; }
.mn-social-card.social-linkedin  { --social-color: #0A66C2; }
.mn-social-card.social-youtube   { --social-color: #FF0000; }
.mn-social-card.social-twitter   { --social-color: #000000; }
.mn-social-card.social-facebook:hover::before {
    background: #1877F2;
}
.mn-social-card.social-instagram:hover::before {
    background: linear-gradient(45deg, #F58529 0%, #DD2A7B 50%, #8134AF 100%);
}
.mn-social-card.social-linkedin:hover::before {
    background: #0A66C2;
}
.mn-social-card.social-youtube:hover::before {
    background: #FF0000;
}
.mn-social-card.social-twitter:hover::before {
    background: #000000;
}

/* =========================================================================
   Payment modal — preview de tarjeta + secciones
   ========================================================================= */
.mn-card-preview {
    position: relative;
    background: linear-gradient(135deg, #2d0a1c 0%, var(--mn-primary) 50%, var(--mn-primary-hover) 100%);
    color: #fff;
    border-radius: 14px;
    padding: 1.25rem 1.4rem;
    box-shadow: 0 10px 30px rgba(125, 31, 61, 0.35);
    aspect-ratio: 1.586 / 1;
    max-width: 340px;
    margin: 0 auto 1.25rem;
    overflow: hidden;
    font-family: ui-monospace, "SF Mono", Menlo, monospace;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.mn-card-preview::before {
    content: "";
    position: absolute;
    top: -60px;
    right: -60px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
}
.mn-card-preview::after {
    content: "";
    position: absolute;
    bottom: -80px;
    left: -40px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
}
.mn-card-preview-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    z-index: 1;
}
.mn-card-chip {
    width: 40px;
    height: 30px;
    border-radius: 5px;
    background: linear-gradient(135deg, #E4B64A 0%, #C29234 100%);
    position: relative;
}
.mn-card-chip::before,
.mn-card-chip::after {
    content: "";
    position: absolute;
    left: 10%;
    right: 10%;
    height: 1px;
    background: rgba(0, 0, 0, 0.2);
}
.mn-card-chip::before { top: 35%; }
.mn-card-chip::after { bottom: 35%; }
.mn-card-network {
    font-size: 1.25rem;
    font-weight: var(--mn-fw-bold);
    letter-spacing: 0.05em;
    opacity: 0.95;
}
.mn-card-preview-number {
    font-size: 1.15rem;
    letter-spacing: 0.12em;
    font-weight: var(--mn-fw-medium);
    color: #fff;
    position: relative;
    z-index: 1;
    margin: 0.5rem 0;
    word-spacing: 0.15em;
}
.mn-card-preview-bottom {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    font-size: 0.72rem;
    position: relative;
    z-index: 1;
}
.mn-card-preview-bottom .label {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.6rem;
    opacity: 0.65;
    margin-bottom: 0.15rem;
    font-family: var(--mn-font-sans);
}
.mn-card-preview-bottom .value {
    font-size: 0.8rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* Sección con título dentro del modal de pago */
.mn-payment-section {
    margin-bottom: 1.25rem;
}
.mn-payment-section-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8rem;
    font-weight: var(--mn-fw-semibold);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--mn-muted-foreground);
    margin-bottom: 0.6rem;
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--mn-border);
}
.mn-payment-section-title i { color: var(--mn-primary); }

/* Amount hero arriba del modal */
.mn-payment-amount {
    text-align: center;
    padding: 1rem 1rem;
    background: var(--mn-secondary);
    border-radius: var(--mn-radius);
    margin-bottom: 1rem;
}
.mn-payment-amount-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--mn-muted-foreground);
    font-weight: var(--mn-fw-semibold);
    display: block;
}
.mn-payment-amount-value {
    color: var(--mn-primary);
    font-size: 1.75rem;
    font-weight: var(--mn-fw-bold);
    display: block;
    line-height: 1.1;
    letter-spacing: -0.01em;
    margin-top: 0.2rem;
}

/* Trust footer */
.mn-trust-footer {
    text-align: center;
    padding: 0.75rem 0;
    margin-top: 0.5rem;
    border-top: 1px solid var(--mn-border);
}
.mn-trust-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    color: var(--mn-muted-foreground);
}
.mn-trust-badge i { color: var(--mn-success); }
.mn-trust-cards {
    display: inline-flex;
    gap: 0.5rem;
    margin-left: 0.75rem;
    font-size: 1.3rem;
    opacity: 0.6;
    vertical-align: middle;
}
.mn-trust-cards i { color: var(--mn-muted-foreground); }

/* =========================================================================
   Avatar con iniciales (para tablas tipo "asegurado")
   ========================================================================= */
.mn-avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-hover) 100%);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--mn-fw-bold);
    font-size: 0.82rem;
    letter-spacing: 0.02em;
    flex: 0 0 auto;
    text-transform: uppercase;
}
.mn-avatar-sm {
    width: 28px;
    height: 28px;
    font-size: 0.7rem;
}
.mn-cell-person {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}
.mn-cell-person-name {
    font-weight: var(--mn-fw-semibold);
    color: var(--mn-foreground);
    font-size: 0.9rem;
    line-height: 1.25;
}

/* Policy number monoespaciado/prominente */
.mn-cell-policy {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-weight: var(--mn-fw-semibold);
    color: var(--mn-primary);
    font-size: 0.9rem;
    letter-spacing: 0.02em;
}

/* =========================================================================
   Action button group (botones de acción en tablas)
   Todos mismo tamaño, border-radius pill, comportamiento consistente
   ========================================================================= */
.mn-action-group {
    display: inline-flex;
    gap: 0.35rem;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
}
.mn-action-btn {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 1px solid var(--mn-border);
    background: #fff;
    color: var(--mn-muted-foreground);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    transition: var(--mn-transition);
    cursor: pointer;
    text-decoration: none;
    padding: 0;
    line-height: 1;
}
.mn-action-btn:hover,
.mn-action-btn:focus {
    background: var(--mn-secondary);
    color: var(--mn-primary);
    border-color: var(--mn-primary);
    transform: translateY(-1px);
    box-shadow: var(--mn-shadow);
}
.mn-action-btn.mn-action-view,
.mn-action-btn.mn-action-view:hover {
    background: var(--mn-secondary);
    color: var(--mn-primary);
    border-color: transparent;
}
.mn-action-btn.mn-action-view:hover {
    background: var(--mn-accent);
}
/* Botón Pagar (más prominente, con texto + ícono) */
.mn-action-pay {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.9rem;
    height: 34px;
    border-radius: var(--mn-radius-full);
    background: var(--mn-success);
    color: #fff;
    border: none;
    font-size: 0.8rem;
    font-weight: var(--mn-fw-semibold);
    text-decoration: none;
    transition: var(--mn-transition);
    cursor: pointer;
}
.mn-action-pay:hover,
.mn-action-pay:focus {
    background: #15803D;
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(22, 163, 74, 0.25);
}

/* =========================================================================
   Stats strip (fila de chips con KPIs encima de las tablas)
   ========================================================================= */
.mn-stats-strip {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin-left: auto;
}
.mn-stat-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--mn-secondary);
    color: var(--mn-primary);
    padding: 0.4rem 0.85rem;
    border-radius: var(--mn-radius-full);
    font-size: 0.82rem;
    font-weight: var(--mn-fw-semibold);
}
.mn-stat-chip strong {
    color: var(--mn-primary);
    font-weight: var(--mn-fw-bold);
    font-size: 0.95rem;
}
.mn-stat-chip-success { background: #DCFCE7; color: #166534; }
.mn-stat-chip-success strong { color: #166534; }
.mn-stat-chip-danger { background: #FEE2E2; color: #991B1B; }
.mn-stat-chip-danger strong { color: #991B1B; }

/* Mejora de rows en tablas branded */
.table-hover tbody tr {
    transition: background-color 0.15s ease;
}
.table-hover tbody tr:hover {
    background-color: var(--mn-secondary) !important;
}

/* Info rows — grid limpio en 2 columnas con divisores */
.mn-info-rows {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 2rem;
    row-gap: 0;
    background: #fff;
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
    padding: 0.25rem 1.25rem;
    margin-bottom: 1rem;
}
.mn-info-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.7rem 0;
    border-bottom: 1px solid var(--mn-border);
}
/* Última fila de cada columna sin border: usamos :nth-last-child */
.mn-info-rows .mn-info-row:nth-last-child(-n+2) {
    border-bottom: none;
}
.mn-info-row-icon {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--mn-secondary);
    color: var(--mn-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    flex: 0 0 auto;
}
.mn-info-row-body {
    flex: 1;
    min-width: 0;
}
.mn-info-row-label {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--mn-muted-foreground);
    font-weight: var(--mn-fw-semibold);
    margin-bottom: 2px;
}
.mn-info-row-value {
    display: block;
    color: var(--mn-foreground);
    font-weight: var(--mn-fw-semibold);
    font-size: 0.95rem;
    word-break: break-word;
}
@media (max-width: 767px) {
    .mn-info-rows { grid-template-columns: 1fr; padding: 0.5rem 1rem; }
    .mn-info-rows .mn-info-row:nth-last-child(-n+2) { border-bottom: 1px solid var(--mn-border); }
    .mn-info-rows .mn-info-row:last-child { border-bottom: none; }
}

/* =========================================================================
   11. Utilities
   ========================================================================= */
.mn-text-primary { color: var(--mn-primary) !important; }
.mn-text-muted   { color: var(--mn-muted-foreground) !important; }
.mn-bg-primary   { background-color: var(--mn-primary) !important; color: #fff; }
.mn-bg-tint      { background-color: var(--mn-accent) !important; }
.mn-rounded      { border-radius: var(--mn-radius); }
.mn-rounded-full { border-radius: var(--mn-radius-full); }

/* =========================================================================
   12. Footer
   ========================================================================= */
footer {
    color: var(--mn-muted-foreground);
    font-size: 0.875rem;
}

/* =========================================================================
   14. Split layout (Login / Register / RegisterAuth)
   Hero image left 50% + form panel right 50%
   ========================================================================= */
.mn-split-layout {
    display: flex;
    min-height: 100vh;
    background: #fff;
}
.mn-split-hero {
    flex: 1 1 50%;
    position: relative;
    background-size: cover;
    background-position: center;
    overflow: hidden;
    display: none;
}
@media (min-width: 992px) {
    .mn-split-hero { display: block; }
}
.mn-split-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(125, 31, 61, 0.55) 0%, rgba(164, 45, 82, 0.35) 60%, rgba(125, 31, 61, 0.75) 100%);
    z-index: 1;
}
.mn-split-hero-content {
    position: absolute;
    bottom: 3rem;
    left: 3rem;
    right: 3rem;
    color: #fff;
    z-index: 2;
}
.mn-split-hero-content h2 {
    color: #fff;
    font-size: 2.5rem;
    font-weight: var(--mn-fw-bold);
    margin-bottom: 0.75rem;
    line-height: 1.1;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}
.mn-split-hero-content p {
    font-size: 1.05rem;
    color: rgba(255, 255, 255, 0.92);
    max-width: 32rem;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.mn-split-hero-dots {
    position: absolute;
    bottom: 1.5rem;
    left: 3rem;
    display: flex;
    gap: 0.5rem;
    z-index: 3;
}
.mn-split-hero-dots .dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.5);
}
.mn-split-hero-dots .dot.active {
    background: #fff;
    width: 28px;
    border-radius: 4px;
}
.mn-split-panel {
    flex: 1 1 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.5rem;
    background: #fff;
}
.mn-split-card {
    width: 100%;
    max-width: 420px;
    background: #fff;
}
.mn-split-logo {
    text-align: center;
    margin-bottom: 1.5rem;
}
.mn-split-logo img {
    max-height: 60px;
    width: auto;
}
.mn-split-title {
    font-size: 2rem;
    font-weight: var(--mn-fw-bold);
    color: var(--mn-foreground);
    text-align: center;
    margin-bottom: 0.5rem;
}
.mn-split-subtitle {
    text-align: center;
    color: var(--mn-muted-foreground);
    font-size: 0.95rem;
    margin-bottom: 2rem;
}

/* =========================================================================
   15. Tabs underline (para Inicio de Agente / Inicio Interno)
   ========================================================================= */
.mn-tabs-underline {
    display: flex;
    border-bottom: 1px solid var(--mn-border);
    margin-bottom: 1.5rem;
    gap: 0;
}
.mn-tabs-underline .mn-tab {
    flex: 1;
    background: transparent;
    border: none;
    padding: 0.875rem 1rem;
    color: var(--mn-muted-foreground);
    font-weight: var(--mn-fw-medium);
    font-size: 0.95rem;
    cursor: pointer;
    position: relative;
    transition: var(--mn-transition);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}
.mn-tabs-underline .mn-tab:hover {
    color: var(--mn-primary);
}
.mn-tabs-underline .mn-tab.active {
    color: var(--mn-primary);
    font-weight: var(--mn-fw-semibold);
}
.mn-tabs-underline .mn-tab.active::after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--mn-primary);
}

/* =========================================================================
   16. Method pills (Correo / Teléfono toggle)
   ========================================================================= */
.mn-method-pills {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}
.mn-method-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.65rem 1rem;
    border-radius: var(--mn-radius-full);
    border: 1px solid var(--mn-border);
    background: #fff;
    color: var(--mn-muted-foreground);
    font-weight: var(--mn-fw-medium);
    font-size: 0.9rem;
    cursor: pointer;
    transition: var(--mn-transition);
}
.mn-method-pill:hover {
    border-color: var(--mn-primary);
    color: var(--mn-primary);
}
.mn-method-pill.active {
    background: var(--mn-primary);
    border-color: var(--mn-primary);
    color: #fff;
}

/* =========================================================================
   17. Input with icon (ícono a la izquierda dentro del input)
   ========================================================================= */
.mn-input-icon {
    position: relative;
}
.mn-input-icon > i {
    position: absolute;
    left: 0.95rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--mn-muted-foreground);
    pointer-events: none;
    font-size: 0.95rem;
    z-index: 2;
}
.mn-input-icon .form-control {
    padding-left: 2.5rem;
    background: #fff;
}
.mn-input-label {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--mn-muted-foreground);
    font-weight: var(--mn-fw-semibold);
    margin-bottom: 0.4rem;
}

/* CTA button "block" (full width, prominente) */
.btn-mn-cta {
    width: 100%;
    background: var(--mn-primary);
    color: #fff;
    border: none;
    border-radius: var(--mn-radius);
    padding: 0.8rem 1rem;
    font-weight: var(--mn-fw-semibold);
    font-size: 1rem;
    transition: var(--mn-transition);
    box-shadow: 0 4px 12px rgba(125, 31, 61, 0.25);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    text-decoration: none;
    line-height: 1.2;
}
.btn-mn-cta:hover,
.btn-mn-cta:focus {
    background: var(--mn-primary-hover);
    color: #fff;
    box-shadow: 0 6px 18px rgba(125, 31, 61, 0.35);
    transform: translateY(-1px);
}
/* Variante outline con MISMA altura/padding que btn-mn-cta */
.btn-mn-cta.btn-mn-cta--outline,
.btn-mn-cta-outline {
    width: 100%;
    background: #fff;
    color: var(--mn-primary);
    border: 2px solid var(--mn-primary);
    border-radius: var(--mn-radius);
    padding: calc(0.8rem - 2px) 1rem;
    font-weight: var(--mn-fw-semibold);
    font-size: 1rem;
    transition: var(--mn-transition);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    text-decoration: none;
    line-height: 1.2;
    box-shadow: none;
}
.btn-mn-cta-outline:hover,
.btn-mn-cta-outline:focus {
    background: var(--mn-secondary);
    color: var(--mn-primary);
    border-color: var(--mn-primary);
    transform: translateY(-1px);
}

/* =========================================================================
   OTP Input — cajas separadas para código 2FA
   ========================================================================= */
.mn-otp-input {
    display: flex;
    gap: 0.6rem;
    justify-content: center;
    margin: 0.5rem 0 1rem;
}
.mn-otp-box {
    width: 2.85rem;
    height: 3.5rem;
    border: 2px solid var(--mn-border);
    border-radius: var(--mn-radius);
    text-align: center;
    font-size: 1.5rem;
    font-weight: var(--mn-fw-bold);
    color: var(--mn-primary);
    background: #fff;
    transition: var(--mn-transition);
    padding: 0;
    font-family: ui-monospace, Menlo, monospace;
}
.mn-otp-box:focus {
    border-color: var(--mn-primary);
    outline: none;
    box-shadow: 0 0 0 4px rgba(164, 45, 82, 0.18);
    transform: translateY(-2px);
}
.mn-otp-box.filled {
    border-color: var(--mn-primary);
    background: var(--mn-secondary);
}
/* Responsive para móvil */
@media (max-width: 420px) {
    .mn-otp-box { width: 2.4rem; height: 3rem; font-size: 1.25rem; }
    .mn-otp-input { gap: 0.4rem; }
}

/* =========================================================================
   18. Sidebar v2 (estilo imagen referencia: bg blanco, items con hover rose,
   activo con bg rose claro + borde izq burgundy)
   ========================================================================= */
.mn-sidebar-v2 .mainnav {
    background: #fff !important;
    border-right: 1px solid var(--mn-border);
    max-width: 16rem !important;
    width: 16rem !important;
}
.mn-sidebar-v2 .mainnav__inner {
    background: transparent;
    color: var(--mn-foreground);
}
.mn-sidebar-v2 .mainnav__profile {
    background: var(--mn-secondary);
    padding: 1.25rem 1rem;
    margin: 0;
    text-align: center;
    border-bottom: 1px solid var(--mn-border);
}
.mn-sidebar-v2 .mainnav__profile img {
    max-width: 100% !important;
    height: auto !important;
    width: auto !important;
    max-height: 56px;
    object-fit: contain;
    display: inline-block;
}
/* Contenedor del logo: centrado y con padding controlado */
.mn-sidebar-v2 .mainnav__profile .mininav-toggle {
    padding: 0.25rem 0.5rem !important;
    overflow: hidden;
}
.mn-sidebar-v2 .mainnav__profile h6,
.mn-sidebar-v2 .mainnav__profile .text-dark,
.mn-sidebar-v2 .mainnav__profile [class*="text-"] {
    color: var(--mn-primary) !important;
    font-weight: var(--mn-fw-semibold);
    font-size: 0.82rem;
    line-height: 1.2;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    text-align: center;
    padding: 0 0.5rem;
    margin: 0;
}
/* Dropdown toggle del nombre usuario: también wrap */
.mn-sidebar-v2 .mainnav__profile .dropdown-toggle {
    white-space: normal;
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
    line-height: 1.2;
}
.mn-sidebar-v2 .mainnav__profile .btn {
    white-space: normal;
    padding: 0.5rem 0.25rem;
}
.mn-sidebar-v2 .mainnav__caption {
    color: var(--mn-muted-foreground) !important;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 1rem 1rem 0.5rem;
}
.mn-sidebar-v2 .mainnav__menu .nav-link {
    color: var(--mn-foreground) !important;
    padding: 0.85rem 1rem 0.85rem 1.3rem;
    margin: 3px 0.6rem;
    border-radius: var(--mn-radius);
    font-weight: var(--mn-fw-medium);
    font-size: 0.95rem;
    border-left: 3px solid transparent;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    transition: var(--mn-transition);
}
.mn-sidebar-v2 .mainnav__menu .nav-link i {
    color: var(--mn-muted-foreground);
    font-size: 1.15rem;
    width: 22px;
    text-align: center;
    transition: var(--mn-transition);
}
.mn-sidebar-v2 .mainnav__caption {
    font-size: 0.72rem !important;
    padding: 1.1rem 1.1rem 0.55rem !important;
}
/* Nombre del usuario bajo el logo — texto plano más legible */
.mn-sidebar-v2 .mn-profile-name {
    color: var(--mn-primary) !important;
    font-weight: var(--mn-fw-semibold);
    font-size: 0.88rem;
    line-height: 1.25;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    padding: 0.5rem 0.75rem 0;
    margin: 0;
}
.mn-sidebar-v2 .mainnav__menu .nav-link:hover {
    background: var(--mn-secondary);
    color: var(--mn-primary) !important;
}
.mn-sidebar-v2 .mainnav__menu .nav-link:hover i {
    color: var(--mn-primary);
}
.mn-sidebar-v2 .mainnav__menu .nav-link.active,
.mn-sidebar-v2 .mainnav__menu .nav-link.active:hover,
.mn-sidebar-v2 .mainnav__menu > .nav-item > .nav-link.active,
.mn-sidebar-v2 .mainnav__menu > .nav-item > .nav-link.active:hover {
    background: var(--mn-secondary) !important;
    color: var(--mn-primary) !important;
    border-left-color: var(--mn-primary);
    font-weight: var(--mn-fw-semibold);
    box-shadow: none;
}
/* Forzar color burgundy en TODOS los descendientes del link activo
   para pisar la regla de Nifty que pone color:#fff en .nav-label/span */
.mn-sidebar-v2 .mainnav__menu .nav-link.active,
.mn-sidebar-v2 .mainnav__menu .nav-link.active *,
.mn-sidebar-v2 .mainnav__menu .nav-link.active i,
.mn-sidebar-v2 .mainnav__menu .nav-link.active .nav-label,
.mn-sidebar-v2 .mainnav__menu .nav-link.active .mininav-content,
.mn-sidebar-v2 .mainnav__menu .nav-link.active span,
.mn-sidebar-v2 .mainnav__menu > .nav-item > .nav-link.active,
.mn-sidebar-v2 .mainnav__menu > .nav-item > .nav-link.active *,
.mn-sidebar-v2 .mainnav__menu > .nav-item > .nav-link.active i,
.mn-sidebar-v2 .mainnav__menu > .nav-item > .nav-link.active .nav-label,
.mn-sidebar-v2 .mainnav__menu > .nav-item > .nav-link.active .mininav-content,
.mn-sidebar-v2 .mainnav__menu > .nav-item > .nav-link.active span {
    color: var(--mn-primary) !important;
}

/* =========================================================================
   19. Top bar v2 (burgundy bar con lang switch + welcome pill)
   ========================================================================= */
.mn-topbar-v2 .header__content-end {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding-right: 1rem;
}
.mn-lang-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--mn-radius-full);
    padding: 0.35rem 0.9rem;
    font-size: 0.85rem;
    font-weight: var(--mn-fw-medium);
    cursor: pointer;
    transition: var(--mn-transition);
}
.mn-lang-btn:hover {
    background: rgba(255, 255, 255, 0.22);
    color: #fff;
}
.mn-welcome-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    background: #fff;
    color: var(--mn-primary);
    border-radius: var(--mn-radius-full);
    padding: 0.35rem 0.4rem 0.35rem 1rem;
    font-size: 0.85rem;
    font-weight: var(--mn-fw-medium);
}
.mn-welcome-pill .mn-welcome-logout {
    background: var(--mn-primary);
    color: #fff;
    border-radius: var(--mn-radius-full);
    padding: 0.3rem 0.85rem;
    font-size: 0.8rem;
    font-weight: var(--mn-fw-semibold);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    transition: var(--mn-transition);
}
.mn-welcome-pill .mn-welcome-logout:hover {
    background: var(--mn-primary-hover);
    color: #fff;
}

/* =========================================================================
   20. Hero carousel (Home — full-width con overlay + texto)
   ========================================================================= */
.mn-hero-carousel {
    position: relative;
    border-radius: var(--mn-radius);
    overflow: hidden;
    box-shadow: var(--mn-shadow-md);
    margin-bottom: 1.5rem;
}
.mn-hero-carousel .carousel-item {
    position: relative;
    height: 380px;
}
.mn-hero-carousel .carousel-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.mn-hero-carousel .carousel-item::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.3) 50%, transparent 100%);
}
.mn-hero-carousel-caption {
    position: absolute;
    bottom: 2.5rem;
    left: 2.5rem;
    right: 2.5rem;
    z-index: 3;
    color: #fff;
    max-width: 42rem;
}
.mn-hero-carousel-caption h2 {
    color: #fff;
    font-size: 2.25rem;
    font-weight: var(--mn-fw-bold);
    line-height: 1.15;
    margin-bottom: 0.5rem;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}
.mn-hero-carousel-caption p {
    color: rgba(255, 255, 255, 0.95);
    font-size: 1.05rem;
    max-width: 32rem;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.mn-hero-carousel .carousel-indicators {
    bottom: 1rem;
    margin-bottom: 0;
}
.mn-hero-carousel .carousel-indicators button {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.6);
    border: none;
    margin: 0 4px;
    transition: var(--mn-transition);
}
.mn-hero-carousel .carousel-indicators button.active {
    background: #fff;
    width: 28px;
    border-radius: 5px;
}
.mn-hero-carousel .carousel-control-prev,
.mn-hero-carousel .carousel-control-next {
    width: 4%;
}

/* =========================================================================
   21. Notice banner + section labels
   ========================================================================= */
.mn-notice-banner {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    background: var(--mn-primary);
    color: #fff;
    padding: 0.55rem 1.15rem;
    border-radius: var(--mn-radius-full);
    font-size: 0.85rem;
    font-weight: var(--mn-fw-semibold);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 1rem;
}
.mn-notice-banner i { font-size: 1rem; }

.mn-section-title {
    font-size: 1.15rem;
    font-weight: var(--mn-fw-semibold);
    color: var(--mn-foreground);
    margin: 2rem 0 1rem;
    display: flex;
    align-items: center;
    gap: 0.625rem;
}
.mn-section-title i {
    color: var(--mn-primary);
}

/* =========================================================================
   22. KPI cards (dashboard quick stats)
   ========================================================================= */
.mn-kpi-card {
    background: #fff;
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
    padding: 1.25rem;
    box-shadow: var(--mn-shadow-sm);
    transition: var(--mn-transition);
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}
.mn-kpi-card:hover {
    box-shadow: var(--mn-shadow-md);
    transform: translateY(-2px);
    border-color: var(--mn-border-strong);
}
.mn-kpi-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.mn-kpi-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--mn-muted-foreground);
    font-weight: var(--mn-fw-semibold);
}
.mn-kpi-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--mn-accent);
    color: var(--mn-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
}
.mn-kpi-value {
    font-size: 2rem;
    font-weight: var(--mn-fw-bold);
    color: var(--mn-foreground);
    line-height: 1.1;
}
.mn-kpi-footer {
    font-size: 0.8rem;
    color: var(--mn-muted-foreground);
    margin-top: 0.25rem;
}
.mn-kpi-footer a {
    color: var(--mn-primary);
    text-decoration: none;
    font-weight: var(--mn-fw-medium);
}
.mn-kpi-footer a:hover { text-decoration: underline; }

/* =========================================================================
   23. Quick actions (botones grandes con ícono)
   ========================================================================= */
.mn-quick-action {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 1rem 1.25rem;
    background: #fff;
    border: 1px solid var(--mn-border);
    border-radius: var(--mn-radius);
    color: var(--mn-foreground);
    text-decoration: none;
    font-weight: var(--mn-fw-medium);
    transition: var(--mn-transition);
    box-shadow: var(--mn-shadow-sm);
    height: 100%;
}
.mn-quick-action:hover {
    border-color: var(--mn-primary);
    transform: translateY(-2px);
    box-shadow: var(--mn-shadow-md);
    color: var(--mn-primary);
    text-decoration: none;
}
.mn-quick-action-icon {
    width: 44px;
    height: 44px;
    border-radius: var(--mn-radius);
    background: var(--mn-accent);
    color: var(--mn-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    flex: 0 0 auto;
}
.mn-quick-action:hover .mn-quick-action-icon {
    background: var(--mn-primary);
    color: #fff;
}
.mn-quick-action-title {
    font-weight: var(--mn-fw-semibold);
    font-size: 0.95rem;
    display: block;
}
.mn-quick-action-desc {
    font-size: 0.8rem;
    color: var(--mn-muted-foreground);
    display: block;
}

/* =========================================================================
   24. Social media strip (footer redes sociales)
   ========================================================================= */
.mn-social-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 2rem 1rem;
    margin-top: 2rem;
    flex-wrap: wrap;
}
.mn-social-strip-label {
    color: var(--mn-muted-foreground);
    font-size: 0.875rem;
    font-weight: var(--mn-fw-medium);
    margin-right: 0.25rem;
}
.mn-social-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--mn-border);
    color: var(--mn-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    transition: var(--mn-transition);
    text-decoration: none;
}
.mn-social-btn:hover {
    background: var(--mn-primary);
    color: #fff;
    border-color: var(--mn-primary);
    transform: translateY(-2px);
    box-shadow: var(--mn-shadow-md);
}

/* =========================================================================
   25. Modal — header con ícono grande (alusivo)
   ========================================================================= */
.mn-modal-icon-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem !important;
}
.mn-modal-icon-header .mn-modal-big-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    flex: 0 0 auto;
}
.mn-modal-icon-header .mn-modal-title {
    color: #fff;
    font-size: 1.15rem;
    font-weight: var(--mn-fw-semibold);
    margin: 0;
}
.mn-modal-icon-header .mn-modal-subtitle {
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.85rem;
    display: block;
    margin-top: 2px;
}

/* =========================================================================
   26. Status chip (para estatus en tablas)
   ========================================================================= */
.mn-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.2rem 0.65rem;
    border-radius: var(--mn-radius-full);
    font-size: 0.75rem;
    font-weight: var(--mn-fw-semibold);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}
.mn-chip-success { background: #DCFCE7; color: #166534; }
.mn-chip-warning { background: #FEF3C7; color: #92400E; }
.mn-chip-danger  { background: #FEE2E2; color: #991B1B; }
.mn-chip-muted   { background: #F3F4F6; color: #4B5563; }
.mn-chip-primary { background: var(--mn-accent); color: var(--mn-primary); }

/* =========================================================================
   13. Nifty color overrides — cambiar #9D1738 a #7D1F3D
   (NO pisamos aquí el item activo del sidebar — eso lo maneja la
   sección 18 .mn-sidebar-v2 con fondo rosa y texto burgundy)
   ========================================================================= */
.header {
    background-color: var(--mn-primary) !important;
}
.header__content .searchbox {
    background-color: var(--mn-primary) !important;
}
.scroll-page {
    background-color: var(--mn-primary) !important;
}
/* Banner superior con breadcrumb + page-title (el "overlapping") */
.content__header {
    background-color: var(--mn-primary) !important;
}

/* =========================================================================
   19. Encuéntranos — Hero blog (1 grande + 3 laterales)
   ========================================================================= */
.mn-blog-hero-section {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: 1.25rem;
    align-items: stretch;
}

.mn-blog-hero-big {
    display: flex;
    flex-direction: column;
    border-radius: 16px;
    overflow: hidden;
    background: var(--mn-card, #fff);
    box-shadow: 0 8px 28px rgba(125, 31, 61, 0.08), 0 2px 4px rgba(0, 0, 0, 0.04);
    text-decoration: none !important;
    color: inherit;
    border: 1px solid var(--mn-border, #eee);
    transition: transform .25s ease, box-shadow .25s ease;
}

.mn-blog-hero-big:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 40px rgba(125, 31, 61, 0.16), 0 4px 8px rgba(0, 0, 0, 0.06);
    color: inherit;
}

.mn-blog-hero-img-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #f3f3f3;
}

.mn-blog-hero-img {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: transform .5s ease;
}

.mn-blog-hero-big:hover .mn-blog-hero-img {
    transform: scale(1.04);
}

.mn-blog-hero-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--mn-primary, #7D1F3D);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    padding: .35rem .7rem;
    border-radius: 999px;
    letter-spacing: .02em;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.22);
}

.mn-blog-hero-badge i {
    margin-right: .3rem;
}

.mn-blog-hero-body {
    padding: 1.25rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    flex: 1;
}

.mn-blog-hero-date {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--mn-muted-foreground, #888);
    font-weight: 600;
}

.mn-blog-hero-title {
    font-size: 1.25rem;
    line-height: 1.3;
    font-weight: 700;
    color: var(--mn-primary, #7D1F3D);
    margin: 0;
}

.mn-blog-hero-excerpt {
    font-size: .9rem;
    color: var(--mn-foreground, #444);
    margin: 0;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mn-blog-hero-cta {
    margin-top: auto;
    padding-top: .25rem;
    color: var(--mn-primary, #7D1F3D);
    font-weight: 600;
    font-size: .9rem;
}

.mn-blog-hero-cta i {
    margin-left: .3rem;
    transition: transform .2s ease;
}

.mn-blog-hero-big:hover .mn-blog-hero-cta i {
    transform: translateX(3px);
}

/* Columna derecha — 3 cards horizontales que abarcan TODA la altura del hero */
.mn-blog-hero-list {
    display: flex;
    flex-direction: column;
    gap: .85rem;
    height: 100%;
}

.mn-blog-hero-list-item {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: .9rem;
    background: var(--mn-card, #fff);
    border: 1px solid var(--mn-border, #eee);
    border-radius: 12px;
    overflow: hidden;
    text-decoration: none !important;
    color: inherit;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    flex: 1 1 0;        /* las 3 cards distribuyen el espacio igual */
    min-height: 0;       /* permite a flex-grow funcionar bien */
}

.mn-blog-hero-list-item:hover {
    transform: translateX(3px);
    border-color: var(--mn-primary, #7D1F3D);
    box-shadow: 0 6px 18px rgba(125, 31, 61, 0.12);
    color: inherit;
}

.mn-blog-hero-list-item.skeleton {
    background: linear-gradient(90deg, #f2f2f2 0%, #f9f9f9 50%, #f2f2f2 100%);
    background-size: 200% 100%;
    animation: mnSkeleton 1.4s infinite;
    border: 1px solid #eee;
    flex: 1 1 0;
}

.mn-blog-hero-list-empty {
    color: var(--mn-muted-foreground, #888);
    font-size: .85rem;
    padding: 1rem;
    border: 1px dashed var(--mn-border, #ddd);
    border-radius: 12px;
    text-align: center;
}

@keyframes mnSkeleton {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.mn-blog-hero-list-thumb {
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
    background-color: #f3f3f3;
}

.mn-blog-hero-list-body {
    padding: .7rem .9rem .7rem 0;
    display: flex;
    flex-direction: column;
    gap: .2rem;
    min-width: 0;
}

.mn-blog-hero-list-date {
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--mn-muted-foreground, #888);
    font-weight: 600;
}

.mn-blog-hero-list-title {
    font-size: .85rem;
    line-height: 1.3;
    font-weight: 600;
    color: var(--mn-foreground, #2a2a2a);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mn-blog-hero-list-cta {
    margin-top: auto;
    color: var(--mn-primary, #7D1F3D);
    font-weight: 600;
    font-size: .72rem;
}

.mn-blog-hero-list-cta i {
    margin-left: .25rem;
}

/* Responsive: en pantallas < 992px, apilar */
@media (max-width: 991.98px) {
    .mn-blog-hero-section {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .mn-blog-hero-list-item {
        grid-template-columns: 88px 1fr;
        min-height: 88px;
    }
    .mn-blog-hero-title {
        font-size: 1.1rem;
    }
    .mn-blog-hero-body {
        padding: 1rem 1.1rem 1.2rem;
    }
}

/* =========================================================================
   20. Productos / Contacto — Banner CTA full-width
   ========================================================================= */
.mn-product-banner {
    position: relative;
    border-radius: 18px;
    overflow: hidden;
    min-height: 320px;
    display: flex;
    align-items: center;
    color: #fff;
    background-color: var(--mn-primary, #7D1F3D);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    box-shadow: 0 12px 40px rgba(125, 31, 61, 0.18);
}

.mn-product-banner-products {
    background-image: url('https://images.unsplash.com/photo-1556761175-5973dc0f32e7?w=1600&q=80');
}

.mn-product-banner-contact {
    background-image: url('https://images.unsplash.com/photo-1521791136064-7986c2920216?w=1600&q=80');
}

.mn-product-banner-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(125, 31, 61, 0.92) 0%, rgba(125, 31, 61, 0.74) 55%, rgba(125, 31, 61, 0.55) 100%);
}

.mn-product-banner-content {
    position: relative;
    z-index: 2;
    padding: 2.5rem 2.75rem;
    max-width: 720px;
    display: flex;
    flex-direction: column;
    gap: .85rem;
}

.mn-product-banner-eyebrow {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.92);
    background: rgba(255, 255, 255, 0.12);
    padding: .35rem .8rem;
    border-radius: 999px;
    width: fit-content;
    backdrop-filter: blur(4px);
}

.mn-product-banner-eyebrow i {
    margin-right: .35rem;
}

.mn-product-banner-title {
    font-size: 2rem;
    line-height: 1.2;
    font-weight: 700;
    margin: 0;
    color: #fff;
}

.mn-product-banner-subtitle {
    font-size: 1rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.92);
    margin: 0;
    max-width: 600px;
}

.mn-product-banner-cta {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    background: #fff;
    color: var(--mn-primary, #7D1F3D);
    padding: .9rem 1.6rem;
    border-radius: 999px;
    font-weight: 700;
    text-decoration: none !important;
    margin-top: .5rem;
    width: fit-content;
    transition: transform .2s ease, box-shadow .2s ease;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18);
}

.mn-product-banner-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.28);
    color: var(--mn-primary, #7D1F3D);
}

.mn-product-banner-cta i {
    transition: transform .2s ease;
}

.mn-product-banner-cta:hover i {
    transform: translate(2px, -2px);
}

.mn-product-banner-note {
    font-size: .78rem;
    color: rgba(255, 255, 255, 0.78);
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin-top: .25rem;
}

@media (max-width: 767.98px) {
    .mn-product-banner {
        min-height: 280px;
    }
    .mn-product-banner-content {
        padding: 1.75rem 1.5rem;
    }
    .mn-product-banner-title {
        font-size: 1.5rem;
    }
    .mn-product-banner-subtitle {
        font-size: .9rem;
    }
}

/* Tarjetas highlight bajo el banner */
.mn-product-feature {
    background: var(--mn-card, #fff);
    border: 1px solid var(--mn-border, #eee);
    border-radius: 14px;
    padding: 1.5rem 1.4rem;
    height: 100%;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

.mn-product-feature-link {
    text-decoration: none !important;
    color: inherit;
    cursor: pointer;
}

.mn-product-feature:hover {
    transform: translateY(-3px);
    border-color: var(--mn-primary, #7D1F3D);
    box-shadow: 0 10px 28px rgba(125, 31, 61, 0.12);
}

.mn-product-feature-link:hover {
    color: inherit;
}

.mn-product-feature-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(125, 31, 61, 0.08);
    color: var(--mn-primary, #7D1F3D);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

.mn-product-feature-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--mn-primary, #7D1F3D);
    margin: 0;
}

.mn-product-feature-text {
    font-size: .9rem;
    color: var(--mn-foreground, #555);
    margin: 0;
    line-height: 1.5;
}

/* =========================================================================
   21. Preguntas Frecuentes — Acordeón Multinational
   ========================================================================= */
.mn-faq-accordion {
    background: transparent;
}

.mn-faq-item {
    background: var(--mn-card, #fff) !important;
    border: 1px solid var(--mn-border, #e6e6e6) !important;
    border-radius: 14px !important;
    margin-bottom: .85rem;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    transition: box-shadow .2s ease, border-color .2s ease;
}

.mn-faq-item:has(.accordion-button:not(.collapsed)),
.mn-faq-item:hover {
    box-shadow: 0 6px 18px rgba(125, 31, 61, 0.10);
    border-color: rgba(125, 31, 61, 0.35) !important;
}

.mn-faq-btn.accordion-button {
    background: transparent !important;
    color: var(--mn-foreground, #2a2a2a) !important;
    font-weight: 600;
    padding: 1.05rem 1.3rem;
    box-shadow: none !important;
    display: flex;
    align-items: center;
    gap: 1rem;
}

.mn-faq-btn.accordion-button:not(.collapsed) {
    background: rgba(125, 31, 61, 0.04) !important;
    color: var(--mn-primary, #7D1F3D) !important;
}

.mn-faq-btn.accordion-button::after {
    background-image: none;
    content: "\2b"; /* + */
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    width: auto;
    height: auto;
    font-size: .9rem;
    color: var(--mn-primary, #7D1F3D);
    margin-left: auto;
    transform: none;
    transition: transform .2s ease, content .2s ease;
}

.mn-faq-btn.accordion-button:not(.collapsed)::after {
    content: "\f068"; /* - */
    transform: none;
}

.mn-faq-num {
    flex: 0 0 auto;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: rgba(125, 31, 61, 0.08);
    color: var(--mn-primary, #7D1F3D);
    font-weight: 700;
    font-size: .82rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    letter-spacing: .02em;
}

.mn-faq-btn.accordion-button:not(.collapsed) .mn-faq-num {
    background: var(--mn-primary, #7D1F3D);
    color: #fff;
}

.mn-faq-q {
    flex: 1;
    line-height: 1.4;
    font-size: .98rem;
}

.mn-faq-a {
    padding: .25rem 1.3rem 1.3rem 4rem;
    color: var(--mn-foreground, #444);
    line-height: 1.65;
    font-size: .92rem;
}

.mn-faq-footer {
    background: rgba(125, 31, 61, 0.06);
    border: 1px dashed rgba(125, 31, 61, 0.25);
    border-radius: 14px;
    padding: 1rem 1.3rem;
    color: var(--mn-foreground, #444);
    font-size: .92rem;
    display: flex;
    align-items: center;
    gap: .7rem;
}

.mn-faq-footer i:first-child {
    color: var(--mn-primary, #7D1F3D);
    font-size: 1.1rem;
}

.mn-faq-footer-link {
    margin-left: auto;
    color: var(--mn-primary, #7D1F3D);
    font-weight: 700;
    text-decoration: none !important;
}

.mn-faq-footer-link:hover {
    text-decoration: underline !important;
    color: var(--mn-primary, #7D1F3D);
}

@media (max-width: 575.98px) {
    .mn-faq-btn.accordion-button {
        padding: .9rem 1rem;
        gap: .7rem;
    }
    .mn-faq-num {
        width: 30px;
        height: 30px;
        font-size: .72rem;
    }
    .mn-faq-q {
        font-size: .9rem;
    }
    .mn-faq-a {
        padding: .25rem 1rem 1.1rem 2.8rem;
    }
    .mn-faq-footer {
        flex-direction: column;
        align-items: flex-start;
    }
    .mn-faq-footer-link {
        margin-left: 0;
    }
}

/* =========================================================================
   22. Sidenav vertical (sidebar fijo a la izquierda, desde arriba sin header)
   - Desktop (>=992px): siempre visible, content con padding-left
   - Movil (<992px): collapse Bootstrap + hamburguesa flotante
   ========================================================================= */

/* SIDENAV_WIDTH: ancho del sidebar */
:root {
    --mn-sidenav-width: 240px;
}

/* Override del root de Nifty para usar el ancho de NUESTRO sidebar */
html body #root.root,
html body #root.root.mn-sidebar-v2,
html body #root.root.mn-topbar-v2 {
    padding-left: var(--mn-sidenav-width) !important;
    padding-top: 0 !important;
    display: block !important;
    min-height: 100vh;
}

/* Oculta totalmente el header y nav de Nifty si quedara residuo */
body .header,
body #mainnav-container.mainnav {
    display: none !important;
}

/* SIDENAV principal */
.mn-sidenav {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: var(--mn-sidenav-width);
    background: #fff;
    border-right: 1px solid var(--mn-border, #e6e6e6);
    box-shadow: 2px 0 12px rgba(0, 0, 0, 0.04);
    z-index: 1030;
    overflow-y: auto;
    display: block !important; /* Bootstrap collapse no debe ocultarlo en desktop */
}

.mn-sidenav-inner {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 1rem 0 1.5rem;
}

/* Logo */
.mn-sidenav-brand {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: .75rem 1rem 1.25rem;
    border-bottom: 1px solid var(--mn-border, #f0f0f0);
    margin-bottom: .75rem;
}

.mn-sidenav-brand img {
    max-width: 160px;
    height: auto;
    object-fit: contain;
}

/* Lista del menú */
.mn-sidenav-menu {
    list-style: none;
    margin: 0;
    padding: 0 .75rem;
    display: flex;
    flex-direction: column;
    gap: .15rem;
}

.mn-sidenav-section {
    padding: .85rem .65rem .35rem;
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--mn-muted-foreground, #999);
    font-weight: 700;
}

.mn-sidenav-link {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .65rem .8rem;
    border-radius: 8px;
    color: var(--mn-foreground, #333);
    font-weight: 500;
    font-size: .9rem;
    text-decoration: none !important;
    transition: background-color .18s ease, color .18s ease;
    cursor: pointer;
    line-height: 1.25;
}

.mn-sidenav-link i {
    color: var(--mn-primary, #7D1F3D);
    font-size: 1rem;
    width: 20px;
    text-align: center;
    flex: 0 0 auto;
}

.mn-sidenav-link:hover {
    background: rgba(125, 31, 61, 0.07);
    color: var(--mn-primary, #7D1F3D);
}

.mn-sidenav-link.active {
    background: var(--mn-primary, #7D1F3D);
    color: #fff;
}

.mn-sidenav-link.active i {
    color: #fff;
}

/* Toggler hamburguesa: solo móvil */
.mn-sidenav-toggler {
    display: none;
    position: fixed;
    top: .85rem;
    left: .85rem;
    z-index: 1031;
    background: #fff;
    border: 1px solid var(--mn-border, #e6e6e6);
    border-radius: 10px;
    padding: .55rem .8rem;
    color: var(--mn-primary, #7D1F3D);
    font-size: 1.15rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    cursor: pointer;
}

.mn-sidenav-toggler:focus {
    outline: 2px solid rgba(125, 31, 61, 0.25);
    outline-offset: 2px;
}

/* Responsive: <992px sidebar se oculta y aparece hamburguesa */
@media (max-width: 991.98px) {
    html body #root.root,
    html body #root.root.mn-sidebar-v2,
    html body #root.root.mn-topbar-v2 {
        padding-left: 0 !important;
        padding-top: 60px !important; /* espacio para hamburguesa */
    }
    .mn-sidenav-toggler {
        display: inline-flex;
    }
    .mn-sidenav {
        transform: translateX(-100%);
        transition: transform .3s ease;
        display: block !important;
    }
    .mn-sidenav.show {
        transform: translateX(0);
    }
}

/* =========================================================================
   23. Welcome banner — extensión: bloque usuario + logout a la derecha
   ========================================================================= */
.mn-welcome-banner-grid {
    align-items: center;
}

.mn-banner-user {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: .7rem;
    flex: 0 0 auto;
}

.mn-banner-user-greeting {
    font-size: .82rem;
    color: rgba(255, 255, 255, 0.92);
    white-space: nowrap;
}

.mn-banner-user-greeting i {
    color: #FFD700;            /* dorado para que destaque */
    margin-right: .3rem;
}

.mn-banner-user-greeting strong {
    color: #fff;
    font-weight: 700;
}

.mn-banner-user-logout {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    background: #fff;
    color: var(--mn-primary, #7D1F3D) !important;
    padding: .35rem .85rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: .78rem;
    text-decoration: none !important;
    transition: background-color .2s ease, transform .2s ease, box-shadow .2s ease;
    white-space: nowrap;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.mn-banner-user-logout:hover {
    background: var(--mn-secondary, #F5D4DC);
    color: var(--mn-primary, #7D1F3D) !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.22);
}

@media (max-width: 767.98px) {
    .mn-welcome-banner-grid {
        flex-wrap: wrap;
    }
    .mn-banner-user {
        margin-left: 0;
        margin-top: .5rem;
        flex-basis: 100%;
        justify-content: space-between;
    }
}

/* Compactar el banner cuando el ícono original está al lado del título */
.mn-welcome-banner .mn-welcome-banner-icon {
    flex: 0 0 auto;
}

/* =========================================================================
   24. Encuéntranos — Grid uniforme de cards (sin hero diferenciado)
   ========================================================================= */
.mn-blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.25rem;
}

.mn-blog-grid-card {
    display: flex;
    flex-direction: column;
    border-radius: 14px;
    overflow: hidden;
    background: var(--mn-card, #fff);
    border: 1px solid var(--mn-border, #e6e6e6);
    box-shadow: 0 4px 14px rgba(125, 31, 61, 0.06);
    text-decoration: none !important;
    color: inherit;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.mn-blog-grid-card:hover {
    transform: translateY(-4px);
    border-color: rgba(125, 31, 61, 0.4);
    box-shadow: 0 14px 32px rgba(125, 31, 61, 0.14);
    color: inherit;
}

.mn-blog-grid-card-img {
    width: 100%;
    aspect-ratio: 16 / 9;
    background-size: cover;
    background-position: center;
    background-color: #f3f3f3;
    transition: transform .5s ease;
}

.mn-blog-grid-card:hover .mn-blog-grid-card-img {
    transform: scale(1.04);
}

.mn-blog-grid-card-body {
    padding: 1rem 1.1rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    flex: 1;
}

.mn-blog-grid-card-date {
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--mn-muted-foreground, #888);
    font-weight: 600;
}

.mn-blog-grid-card-title {
    font-size: .98rem;
    line-height: 1.35;
    font-weight: 700;
    color: var(--mn-primary, #7D1F3D);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mn-blog-grid-card-excerpt {
    font-size: .82rem;
    line-height: 1.5;
    color: var(--mn-foreground, #555);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mn-blog-grid-card-cta {
    margin-top: auto;
    padding-top: .25rem;
    color: var(--mn-primary, #7D1F3D);
    font-weight: 600;
    font-size: .82rem;
}

.mn-blog-grid-card-cta i {
    margin-left: .3rem;
    transition: transform .2s ease;
}

.mn-blog-grid-card:hover .mn-blog-grid-card-cta i {
    transform: translateX(3px);
}

.mn-blog-grid-card.skeleton {
    background: linear-gradient(90deg, #f2f2f2 0%, #f9f9f9 50%, #f2f2f2 100%);
    background-size: 200% 100%;
    animation: mnSkeleton 1.4s infinite;
    min-height: 280px;
}

/* Compactar Encuéntranos para reducir scroll */
.mn-encontranos-compact .mn-welcome-banner {
    padding: 1rem 1.5rem !important;
}
.mn-encontranos-compact .mn-section-title {
    margin-top: 1rem !important;
    margin-bottom: .65rem !important;
    font-size: 1rem !important;
}
.mn-encontranos-compact .mn-social-grid {
    gap: .75rem !important;
}
.mn-encontranos-compact .mn-social-card {
    padding: .85rem 1rem !important;
}
.mn-encontranos-compact .mn-blog-grid-card-img {
    aspect-ratio: 16 / 8;
}

/* Hero del blog más pequeño (para que entre todo en pantalla) */
.mn-encontranos-compact .mn-blog-hero-img-wrap {
    aspect-ratio: 16 / 9;
    max-height: 240px;            /* tope hard */
}
/* Imagen alineada arriba para no cortar caras/cabezas */
.mn-encontranos-compact .mn-blog-hero-img,
.mn-blog-hero-img {
    background-position: center top !important;
}
.mn-encontranos-compact .mn-blog-hero-body {
    padding: .85rem 1.1rem 1rem !important;
    gap: .3rem !important;
}
.mn-encontranos-compact .mn-blog-hero-title {
    font-size: 1.05rem !important;
    line-height: 1.25 !important;
}
.mn-encontranos-compact .mn-blog-hero-excerpt {
    font-size: .82rem !important;
    -webkit-line-clamp: 2 !important;
}
.mn-encontranos-compact .mn-blog-hero-date {
    font-size: .65rem !important;
}
.mn-encontranos-compact .mn-blog-hero-cta {
    font-size: .82rem !important;
}
.mn-encontranos-compact .mn-blog-hero-section {
    gap: 1rem !important;
}
.mn-encontranos-compact .mn-blog-hero-list {
    gap: .55rem !important;
}
.mn-encontranos-compact .mn-blog-hero-list-item {
    grid-template-columns: 100px 1fr !important;
    gap: .7rem !important;
}
.mn-encontranos-compact .mn-blog-hero-list-title {
    font-size: .8rem !important;
    -webkit-line-clamp: 2 !important;
}
.mn-encontranos-compact .mn-blog-hero-list-body {
    padding: .55rem .75rem .55rem 0 !important;
}
.mn-encontranos-compact .mn-blog-hero-list-date {
    font-size: .6rem !important;
}
.mn-encontranos-compact .mn-blog-hero-list-cta {
    font-size: .68rem !important;
}

/* =========================================================================
   25. Responsive — refuerzos para móvil/tablet
   ========================================================================= */

/* Todas las tablas: scroll horizontal automático para no romper el layout */
.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Modales muy anchos: en móvil pasan a fullscreen para no perder contenido */
@media (max-width: 767.98px) {
    .modal.mn-modal-wide .modal-dialog {
        margin: 0;
        max-width: 100%;
        height: 100%;
    }
    .modal.mn-modal-wide .modal-content {
        height: 100vh;
        border-radius: 0;
        border: 0;
    }
    .modal.mn-modal-wide .modal-body {
        max-height: calc(100vh - 110px);
        overflow-y: auto;
    }
    /* Modal de pago (formulario) — también fullscreen en móvil */
    #paymentModal .modal-dialog {
        margin: 0;
        max-width: 100%;
        height: 100%;
    }
    #paymentModal .modal-content {
        height: 100vh;
        border-radius: 0;
        border: 0;
    }
    /* Tabla de pagos en móvil — chips más compactos */
    .mn-days-chip {
        padding: .25rem .55rem !important;
        font-size: .72rem !important;
    }
    .mn-pay-method-chip {
        padding: .25rem .55rem !important;
        font-size: .72rem !important;
    }
    /* Banner welcome — saludo + logout bajan a su línea */
    .mn-welcome-banner-grid {
        flex-wrap: wrap !important;
        gap: .65rem !important;
    }
    .mn-banner-user {
        margin-left: 0 !important;
        flex-basis: 100%;
        justify-content: space-between;
    }
    /* Tabs del detalle de póliza — scroll horizontal */
    .nav-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
    }
    .nav-tabs .nav-link {
        white-space: nowrap;
        flex-shrink: 0;
    }
    /* Acciones de la fila de pólizas: stack vertical en móvil pequeño */
    .mn-action-group {
        flex-wrap: wrap;
        gap: .25rem;
    }
}

/* Tablet (768-991px): la sidebar ya pasó a hamburguesa, sólo ajusto banners */
@media (min-width: 768px) and (max-width: 991.98px) {
    .mn-welcome-banner {
        padding: 0.85rem 1.25rem !important;
    }
    .mn-blog-hero-section {
        grid-template-columns: 1fr !important;  /* hero arriba, lista abajo */
    }
}

/* Pantallas muy pequeñas (<420px): el form de pago y los chips se compactan */
@media (max-width: 419.98px) {
    .mn-payment-amount-value {
        font-size: 1.6rem !important;
    }
    .mn-otp-input {
        gap: .35rem !important;
    }
    .mn-otp-box {
        width: 38px !important;
        height: 46px !important;
        font-size: 1.1rem !important;
    }
    .mn-product-banner-title {
        font-size: 1.25rem !important;
    }
    .mn-faq-q {
        font-size: .85rem !important;
    }
}
