@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700&family=Inter:wght@400;600&display=swap');

:root {
    /* Primary Palette */
    --color-primary-darkest: #004d40;
    --color-primary-dark: #00695c;
    --color-primary: #00897b;
    --color-primary-medium: #00a693;
    --color-primary-light: #26d0a8;
    --color-primary-lighter: #4fffdf;

    /* Neutrals */
    --color-neutral-darkest: #0a1628;
    --color-neutral-dark: #1a2f4f;
    --color-neutral-medium: #2c4868;
    --color-neutral-light: #8b9cb6;
    --color-neutral-soft: #d3d8e2;

    /* Accents */
    --color-accent-amber: #fbb03b;
    --color-accent-bronze-light: #c49954;
    --color-accent-bronze: #cd7f32;
    --color-accent-bronze-dark: #804a00;
    --color-accent-crimson: #e63946;
    --color-accent-sky-blue: #3498db;
    --color-accent-sky-blue-light: #3cb0ff;
    --color-accent-sky-blue-dark: #236898;
    --color-accent-gold: #ffd700;
    --color-accent-purple: #6a1b9a;

    /* Globals */
    --color-white: #ffffff;
    --color-black: #000000;

    /* Typography */
    --font-family-base: 'Roboto', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 2rem;

    /* Spacing scale (4px rhythm) */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-7: 1.75rem;
    --space-8: 2rem;

    /* Radius */
    --radius-sm: 0.5rem;
    --radius-md: 0.75rem;
    --radius-lg: 1rem;
    --radius-xl: 1.5rem;
    --radius-xxl: 2rem;
    --radius-pill: 999px;

    /* Shadows */
    --shadow-soft: 0 12px 24px rgba(0, 0, 0, 0.15);
    --shadow-card: 0 18px 35px rgba(0, 0, 0, 0.2);
    --shadow-inset: inset 0 2px 6px rgba(0, 0, 0, 0.35);

    /* Layout */
    --sidebar-width: 260px;
    --navbar-height: 72px;

    /* Icon Sizing */
    --icon-sm: 14px;
    --icon-md: 18px;
    --icon-lg: 24px;
    --icon-xl: 30px;

    /* Transitions */
    --default-transition-duration: 0.3s;

}

body,
.dashboard-body {
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-regular);
    background-color: var(--color-neutral-darkest);
    color: var(--color-white);
    line-height: 1.6;
    min-height: 100vh;
    margin: 0;
}

a,
a:hover {
    color: var(--color-primary-light);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: var(--font-weight-bold);
    color: var(--color-white);
}

p,
span,
small,
label {
    color: var(--color-neutral-light);
}

/* .alert-warning span {
    color: rgba(255, 218, 106, 0.7)
}

.alert-info span {
    color: rgba(110, 223, 246, 0.7)
} */

/* Custom Alerts */
.alert {
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    border: 1px solid;
    font-size: var(--font-size-base);
    line-height: 1.6;
    position: relative;
    overflow: hidden;
}

.alert::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: currentColor;
}

/* Alert with icon */
.alert-with-icon {
    display: flex;
    align-items: start;
    gap: var(--space-3);
}

.alert-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.alert-content {
    flex: 1;
}

.alert-title {
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-2);
    font-size: var(--font-size-base);
}

.alert-message {
    margin: 0;
    font-size: var(--font-size-sm);
}

/* Primary Alert */
.alert-primary {
    background: linear-gradient(135deg, rgba(38, 208, 168, 0.12), rgba(0, 137, 123, 0.08));
    border-color: rgba(38, 208, 168, 0.3);
    color: var(--color-primary-light);
}

.alert-primary .alert-icon {
    background: rgba(38, 208, 168, 0.2);
    color: var(--color-primary-light);
}

.alert-primary a {
    color: var(--color-primary-lighter);
    text-decoration: underline;
}

.alert-primary a:hover {
    color: var(--color-white);
}

/* Success Alert */
.alert-success {
    background: linear-gradient(135deg, rgba(38, 208, 168, 0.15), rgba(0, 137, 123, 0.1));
    border-color: rgba(38, 208, 168, 0.35);
    color: var(--color-primary-light);
}

.alert-success .alert-icon {
    background: rgba(38, 208, 168, 0.25);
    color: var(--color-primary-light);
}

.alert-success a {
    color: var(--color-primary-lighter);
    text-decoration: underline;
}

/* Info Alert */
.alert-info {
    background: linear-gradient(135deg, rgba(60, 176, 255, 0.12), rgba(52, 152, 219, 0.08));
    border-color: rgba(60, 176, 255, 0.3);
    color: var(--color-accent-sky-blue-light);
}

.alert-info .alert-icon {
    background: rgba(60, 176, 255, 0.2);
    color: var(--color-accent-sky-blue-light);
}

.alert-info a {
    color: var(--color-accent-sky-blue-light);
    text-decoration: underline;
}

.alert-info a:hover {
    color: var(--color-white);
}

/* Warning Alert */
.alert-warning {
    background: linear-gradient(135deg, rgba(251, 176, 59, 0.12), rgba(251, 176, 59, 0.08));
    border-color: rgba(251, 176, 59, 0.35);
    color: var(--color-accent-amber);
}

.alert-warning .alert-icon {
    background: rgba(251, 176, 59, 0.2);
    color: var(--color-accent-amber);
}

.alert-warning a {
    color: var(--color-accent-amber);
    font-weight: var(--font-weight-semibold);
    text-decoration: underline;
}

.alert-warning a:hover {
    color: var(--color-white);
}

/* Danger Alert */
.alert-danger {
    background: linear-gradient(135deg, rgba(230, 57, 70, 0.12), rgba(230, 57, 70, 0.08));
    border-color: rgba(230, 57, 70, 0.35);
    color: var(--color-accent-crimson);
}

.alert-danger .alert-icon {
    background: rgba(230, 57, 70, 0.2);
    color: var(--color-accent-crimson);
}

.alert-danger a {
    color: var(--color-accent-crimson);
    text-decoration: underline;
}

.alert-danger a:hover {
    color: var(--color-white);
}

/* Neutral/Secondary Alert */
.alert-secondary {
    background: linear-gradient(135deg, rgba(139, 156, 182, 0.12), rgba(139, 156, 182, 0.08));
    border-color: rgba(139, 156, 182, 0.25);
    color: var(--color-neutral-light);
}

.alert-secondary .alert-icon {
    background: rgba(139, 156, 182, 0.2);
    color: var(--color-neutral-light);
}

.alert-secondary a {
    color: var(--color-white);
    text-decoration: underline;
}

/* Dark Alert */
.alert-dark {
    background: linear-gradient(135deg, rgba(26, 47, 79, 0.8), rgba(10, 22, 40, 0.6));
    border-color: rgba(255, 255, 255, 0.15);
    color: var(--color-white);
}

.alert-dark .alert-icon {
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-white);
}

/* Light Alert */
.alert-light {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.05));
    border-color: rgba(255, 255, 255, 0.2);
    color: var(--color-white);
}

.alert-light .alert-icon {
    background: rgba(255, 255, 255, 0.15);
    color: var(--color-white);
}

/* Bronze/Premium Alert (for special features) */
.alert-bronze {
    background: linear-gradient(135deg, rgba(205, 127, 50, 0.12), rgba(196, 153, 84, 0.08));
    border-color: rgba(205, 127, 50, 0.3);
    color: var(--color-accent-bronze-light);
}

.alert-bronze .alert-icon {
    background: rgba(205, 127, 50, 0.2);
    color: var(--color-accent-bronze-light);
}

/* Gold/Premium Alert */
.alert-gold {
    background: linear-gradient(135deg, rgba(255, 215, 0, 0.12), rgba(255, 215, 0, 0.08));
    border-color: rgba(255, 215, 0, 0.3);
    color: var(--color-accent-gold);
}

.alert-gold .alert-icon {
    background: rgba(255, 215, 0, 0.2);
    color: var(--color-accent-gold);
}

/* Trial/Special Alert */
.alert-trial {
    background: linear-gradient(135deg, rgba(106, 27, 154, 0.12), rgba(106, 27, 154, 0.08));
    border-color: rgba(106, 27, 154, 0.3);
    color: var(--color-accent-purple);
}

.alert-trial .alert-icon {
    background: rgba(106, 27, 154, 0.2);
    color: var(--color-accent-purple);
}

/* Dismissible Alerts */
.alert-dismissible {
    padding-right: 3rem;
}

.alert-dismissible .btn-close {
    position: absolute;
    top: var(--space-3);
    right: var(--space-3);
    padding: 0.5rem;
    opacity: 0.6;
    transition: opacity 0.2s ease;
}

.alert-dismissible .btn-close:hover {
    opacity: 1;
}

.alert-dismissible .btn-close:focus {
    opacity: 1;
    box-shadow: 0 0 0 0.2rem rgba(38, 208, 168, 0.25);
}

/* Alert with actions */
.alert-actions {
    margin-top: var(--space-3);
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.alert-actions .btn {
    font-size: var(--font-size-sm);
    padding: 0.375rem 0.75rem;
}

/* Solid variant (higher contrast) */
.alert-solid.alert-primary {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    border-color: var(--color-primary-light);
    color: var(--color-white);
}

.alert-solid.alert-success {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    border-color: var(--color-primary);
    color: var(--color-white);
}

.alert-solid.alert-warning {
    background: linear-gradient(135deg, var(--color-accent-amber), #e8a02c);
    border-color: var(--color-accent-amber);
    color: var(--color-neutral-darkest);
}

.alert-solid.alert-danger {
    background: linear-gradient(135deg, var(--color-accent-crimson), #c62f3a);
    border-color: var(--color-accent-crimson);
    color: var(--color-white);
}

.alert-solid.alert-info {
    background: linear-gradient(135deg, var(--color-accent-sky-blue-light), var(--color-accent-sky-blue));
    border-color: var(--color-accent-sky-blue);
    color: var(--color-white);
}

/* Soft/Minimal variant */
.alert-minimal {
    border-left-width: 4px;
    border-top: none;
    border-right: none;
    border-bottom: none;
    background: rgba(255, 255, 255, 0.02);
    padding-left: var(--space-4);
}

.alert-minimal::before {
    display: none;
}

/* Banner style (full width, less padding) */
.alert-banner {
    border-radius: 0;
    border-left: none;
    border-right: none;
    margin-left: calc(var(--space-4) * -1);
    margin-right: calc(var(--space-4) * -1);
}

/* Compact alert */
.alert-compact {
    padding: var(--space-3);
    font-size: var(--font-size-sm);
}

.alert-compact .alert-icon {
    width: 32px;
    height: 32px;
}

/* Animation for new alerts */
@keyframes slideInAlert {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.alert-animated {
    animation: slideInAlert 0.3s ease;
}

/* List inside alerts */
.alert ul {
    margin-bottom: 0;
    padding-left: 1.25rem;
}

.alert ul li {
    margin-bottom: var(--space-2);
}

.alert ul li:last-child {
    margin-bottom: 0;
}

/* Strong text in alerts */
.alert strong {
    font-weight: var(--font-weight-semibold);
    color: currentColor;
    opacity: 1;
}

/* Code in alerts */
.alert code {
    background: rgba(0, 0, 0, 0.2);
    padding: 0.2rem 0.4rem;
    border-radius: var(--radius-sm);
    font-size: 0.875em;
}

.gradient-onboarding {
    min-height: 100vh;
    background: radial-gradient(circle at top, rgba(38, 208, 168, 0.2), transparent 60%), linear-gradient(160deg, var(--color-primary-darkest), var(--color-neutral-darkest));
}

.card {
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: var(--color-neutral-dark);
    box-shadow: var(--shadow-soft);
}

.card.glow {
    box-shadow: 0 25px 45px rgba(14, 23, 39, 0.45);
}

.btn {
    border-radius: var(--radius-sm);
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.01em;
}

.btn-icon {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-lg);
    padding: 0;
}

.btn-primary,
.btn-success {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    border: none;
    color: var(--color-white) !important;
}

.btn-outline-light {
    border-color: rgba(255, 255, 255, 0.3);
    color: var(--color-white);
}

.btn-soft-primary {
    background-color: rgba(38, 208, 168, 0.15);
    color: var(--color-primary-light);
    border: none;
}


.btn span {
    color: inherit;
}

.badge {
    border-radius: var(--radius-pill);
    font-weight: var(--font-weight-semibold);
    padding: 0.35rem 0.75rem;
}

.badge-soft-primary {
    background-color: rgba(38, 208, 168, 0.15);
    color: var(--color-primary-light);
}

.badge-soft-amber {
    background-color: rgba(251, 176, 59, 0.15);
    color: var(--color-accent-amber);
}

.badge-soft-neutral {
    background-color: rgba(211, 216, 226, 0.15);
    color: var(--color-neutral-soft);
}

/* Loyalty snapshots */
.membership-snapshot .card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.membership-snapshot .badge {
    font-size: var(--font-size-xs);
}

.loyalty-carousel {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.loyalty-carousel-track {
    display: flex;
    gap: var(--space-4);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: var(--space-2);
    scrollbar-width: none;
}

.loyalty-carousel-track::-webkit-scrollbar {
    display: none;
}

.loyalty-carousel-item {
    flex: 0 0 100%;
    scroll-snap-align: start;
}

.loyalty-carousel-indicators {
    display: flex;
    justify-content: center;
    gap: var(--space-2);
}

.loyalty-carousel-indicators .indicator-dot {
    background: rgba(255, 255, 255, 0.2);
    border: none;
    padding: 0;
    cursor: pointer;
}

.loyalty-carousel-indicators .indicator-dot.active {
    background: var(--color-primary-light);
}

.loyalty-alert-otp {
    border-left: 3px solid var(--color-primary-light);
}

.loyalty-modal-content {
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.loyalty-modal-content.updating {
    opacity: 0.94;
    transform: translateY(2px);
}

.loyalty-modal-content {
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.loyalty-confirmation {
    background: linear-gradient(180deg, rgba(38, 208, 168, 0.12), rgba(38, 208, 168, 0.04));
    border-radius: var(--radius-lg);
}

.loyalty-confirmation-body {
    align-items: stretch;
}

.loyalty-confirmation-full {
    width: 100%;
}

.loyalty-confirmation-icon {
    width: 78px;
    height: 78px;
    border-radius: 50%;
    background-color: var(--color-primary);
    display: grid;
    place-items: center;
    color: var(--color-white);
    font-size: 36px;
}

.loyalty-portal-qr {
    max-width: 320px;
    margin: 0 auto;
}

.loyalty-portal-qr-code {
    width: max-content;
    padding: 10px;
    border-radius: var(--radius-md);
    background: #ffffff;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.22);
}

.reward-option {
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

.reward-option:hover {
    border-color: rgba(38, 208, 168, 0.4);
    background-color: rgba(38, 208, 168, 0.05);
}

.reward-option input[type="radio"] {
    transform: scale(1.1);
}

.otp-input input {
    letter-spacing: 0.3rem;
}

.quick-action-modal .modal-content {
    background: var(--color-neutral-dark);
    color: var(--color-white);
    border-radius: var(--radius-xxl);
}

.quick-action-modal .card {
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(255, 255, 255, 0.08);
}

.quick-action-modal .alert {
    border-radius: var(--radius-md);
}

.quick-action-modal .btn-outline-light {
    border-color: rgba(255, 255, 255, 0.4);
}

.quick-action-modal .section-toggle .btn {
    min-width: 180px;
}

.quick-action-modal .empty-state {
    border: 1px dashed rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.02);
}

.action-card {
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    background: rgba(255, 255, 255, 0.03);
    transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.1s ease;
    cursor: pointer;
}

.action-card:hover,
.action-card:focus,
.action-card.selected {
    border-color: rgba(38, 208, 168, 0.5);
    background: rgba(38, 208, 168, 0.08);
    transform: translateY(-2px);
    outline: none;
}

.action-card.is-disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.action-card.is-disabled:hover,
.action-card.is-disabled:focus {
    border-color: rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.03);
    transform: none;
}

.action-card-body {
    display: none;
    margin-top: var(--space-4);
    padding-top: var(--space-4);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.action-card.selected .action-card-body {
    display: block;
}

.action-icon {
    width: 42px;
    height: 42px;
    border-radius: var(--radius-pill);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(38, 208, 168, 0.15);
    color: var(--color-primary-light);
}

.action-icon.bg-outline {
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-white);
}

.badge.bg-success-subtle {
    background-color: rgba(38, 208, 168, 0.1);
    color: var(--color-primary-light);
}

.badge.bg-warning-subtle {
    background-color: rgba(251, 176, 59, 0.1);
    color: var(--color-accent-amber);
}

/* Plan management */
.plan-summary-card {
    background: linear-gradient(135deg, rgba(38, 208, 168, 0.08), rgba(0, 137, 123, 0.05));
    border: 1px solid rgba(38, 208, 168, 0.2);
}

.trial-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: rgba(251, 176, 59, 0.15);
    color: var(--color-accent-amber);
    padding: 0.5rem 1rem;
    border-radius: var(--radius-pill);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
}

.trial-badge span {
    color: var(--color-accent-amber);
}


.badge.badge-primary {
    background: var(--color-primary-light);
    color: var(--color-white);
}

.badge.badge-warning {
    background: rgba(251, 176, 59, 0.2);
    color: var(--color-accent-amber);
}

.plan-selection-card {
    position: relative;
    border: 2px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-xl);
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.plan-selection-card:not(.is-disabled):hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.2);
    border-color: rgba(38, 208, 168, 0.4);
}

.plan-selection-card.selected {
    border-color: var(--color-primary-light);
    background: linear-gradient(135deg, rgba(0, 137, 123, 0.08), rgba(38, 208, 168, 0.05));
}

.plan-selection-card.selected::after {
    content: '';
    position: absolute;
    top: -2px;
    right: -2px;
    width: 32px;
    height: 32px;
    background: var(--color-primary-light);
    border-radius: 0 var(--radius-xl) 0 var(--radius-xl);
}

.plan-selection-card.selected::before {
    content: '';
    position: absolute;
    top: 7px;
    right: 9px;
    width: 10px;
    height: 10px;
    background: var(--color-white);
    border-radius: 50%;
    z-index: 1;
}

.plan-selection-card.is-disabled {
    opacity: 0.6;
    cursor: not-allowed;
    box-shadow: none;
}

.plan-selection-card.is-disabled:hover {
    transform: none;
    box-shadow: none;
}

.features-preview {
    list-style: none;
    padding: 0;
    margin: 0;
}

.features-preview li {
    margin-bottom: var(--space-2);
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
}

.feature-toggle {
    background: transparent;
    border: none;
    color: var(--color-primary-light);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: 0;
}

.feature-toggle:hover {
    text-decoration: underline;
}

.toggle-icon {
    transition: transform 0.2s ease;
}

.feature-toggle[aria-expanded='true'] .toggle-icon {
    transform: rotate(180deg);
}

.features-list {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.features-list.expanded {
    max-height: 1000px;
}

.branch-quantity-card {
    background-color: var(--color-neutral-dark);
}

.branch-quantity-input {
    max-width: 140px;
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--color-white);
}

.quantity-btn {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-md);
}

.quantity-helper {
    background: rgba(38, 208, 168, 0.1);
    border: 1px solid rgba(38, 208, 168, 0.2);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    margin-top: var(--space-4);
}

#quantity-status.is-increase {
    color: var(--color-primary-light);
}

#quantity-status.is-decrease {
    color: var(--color-accent-amber);
}

.plan-management-summary {
    position: sticky;
    top: var(--space-6);
}

.price-preview-card {
    margin-top: 40px;
    border-width: 2px;
    border-color: rgba(38, 208, 168, 0.3);
    background: linear-gradient(135deg, rgba(38, 208, 168, 0.08), rgba(0, 137, 123, 0.05));

}

.price-comparison {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4);
    background: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-md);
}

.price-arrow {
    color: var(--color-neutral-light);
    font-size: 1.5rem;
}

.change-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: 0.5rem 1rem;
    border-radius: var(--radius-pill);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
}

.change-badge.increase {
    background: rgba(230, 57, 70, 0.15);
    color: var(--color-accent-crimson);
}

.change-badge.decrease {
    background: rgba(38, 208, 168, 0.15);
    color: var(--color-primary-light);
}

.change-badge.neutral {
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-neutral-light);
}

.blocker-alert {
    background: rgba(251, 176, 59, 0.1);
    border: 2px solid rgba(251, 176, 59, 0.3);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    margin-bottom: var(--space-4);
}

.blocker-alert .icon-circle {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(251, 176, 59, 0.2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-accent-amber);
}

.blocker-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-3);
    background: rgba(0, 0, 0, 0.2);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-3);
}

.blocker-item:last-child {
    margin-bottom: 0;
}

.action-area {
    background: var(--color-neutral-dark);
    border-top: 2px solid rgba(255, 255, 255, 0.08);
    padding: var(--space-4);
    border-radius: var(--radius-lg);
    box-shadow: 0 -8px 16px rgba(0, 0, 0, 0.2);
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.card,
.btn,
.form-control {
    transition: all 0.2s ease;
}

.fade-in {
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Reports */
.reports-filters .form-label {
    color: #c8d0e0;
}

.reports-filters .form-control,
.reports-filters select {
    background-color: var(--color-neutral-dark);
    border-color: var(--color-neutral-medium);
    color: var(--color-white);
}

.reports-filters .btn {
    white-space: nowrap;
}

.report-chart-container {
    position: relative;
    min-height: 280px;
}

.report-stat-card,
.program-card,
.branch-performance-card {
    background-color: var(--color-neutral-dark);
    border: 1px solid var(--color-neutral-medium);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft);
    padding: var(--space-4);
}

.report-stat-card .stat-value {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    line-height: 1.2;
    letter-spacing: -0.01em;
}

.report-stat-card .stat-label {
    font-size: var(--font-size-sm);
    opacity: 0.8;
}

.report-stat-card.gradient-primary {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    color: var(--color-white);
}

.report-stat-card.gradient-sky {
    background: linear-gradient(135deg, var(--color-accent-sky-blue-light), var(--color-accent-sky-blue));
    color: var(--color-white);
}

.icon-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background-color: rgba(255, 255, 255, 0.08);
    color: var(--color-white);
}

.icon-pill-primary {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
}

.icon-pill-sky {
    background: linear-gradient(135deg, var(--color-accent-sky-blue-light), var(--color-accent-sky-blue));
}

.icon-pill-neutral {
    background: rgba(255, 255, 255, 0.08);
}

.icon-pill-white {
    background: rgba(255, 255, 255, 0.12);
    color: var(--color-white);
}

.program-card {
    border-top: 6px solid var(--color-neutral-medium);
    padding: var(--space-4);
}

.program-card-points {
    border-top-color: var(--color-primary);
}

.program-card-visits {
    border-top-color: var(--color-accent-sky-blue);
}

.program-card-tiers {
    border-top-color: var(--color-neutral-light);
}

.program-metrics {
    gap: var(--space-3);
}

.program-metric {
    flex: 1 1 0;
    background: var(--color-neutral-medium) !important;
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-md);
    padding: var(--space-2);
}

.trend-positive {
    background-color: rgba(38, 208, 168, 0.15);
    color: var(--color-primary-light);
    border: 1px solid rgba(38, 208, 168, 0.35);
}

.trend-negative {
    background-color: rgba(230, 57, 70, 0.15);
    color: var(--color-accent-crimson);
    border: 1px solid rgba(230, 57, 70, 0.35);
}

.trend-neutral {
    background-color: rgba(255, 255, 255, 0.08);
    color: var(--color-white);
    border: 1px solid rgba(255, 255, 255, 0.15);
}

.metric-row .icon-pill {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    background-color: rgba(255, 255, 255, 0.06);
}

.branch-performance-card .metric-row {
    background: rgba(255, 255, 255, 0.02);
    border-radius: var(--radius-sm);
    padding: var(--space-2) var(--space-3);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.branch-metrics {
    display: flex;
    gap: var(--space-3);
}

.branch-metric {
    flex: 1 1 0;
    background: var(--color-neutral-medium);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-md);
    padding: var(--space-2);
}

.branch-performance-card .progress {
    background-color: rgba(255, 255, 255, 0.08);
    height: 8px;
}

.branch-performance-card .progress-bar {
    background-color: var(--color-primary-light);
}

.report-chart-container canvas {
    width: 100% !important;
}

.reports-empty .icon-circle {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background-color: rgba(38, 208, 168, 0.12);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary-light);
}

.branch-revenue-item .progress {
    background-color: rgba(255, 255, 255, 0.08);
}

@media (max-width: 768px) {
    .reports-filters .row>div {
        margin-bottom: 0.5rem;
    }


    .plan-management-summary,
    .price-preview-card {
        position: static;
    }

    .action-area {
        z-index: 10;
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    }
}

.badge.bg-secondary {
    background-color: rgba(255, 255, 255, 0.12) !important;
    color: var(--color-white);
}

.badge.bg-success {
    background-color: rgba(38, 208, 168, 0.2) !important;
    color: var(--color-primary-light);
}

.badge.bg-danger {
    background-color: rgba(230, 57, 70, 0.8) !important;
    color: var(--color-accent-crimson);
}

.badge.bg-warning {
    background-color: rgba(251, 176, 59, 0.8) !important;
    color: var(--color-accent-amber);
}

.role-option-card {
    width: 100%;
    border: 1px solid var(--color-neutral-medium);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    background: var(--color-neutral-darkest);
    color: var(--color-white);
    display: flex;
    align-items: center;
    gap: var(--space-3);
    transition: border-color var(--default-transition-duration), box-shadow var(--default-transition-duration), background var(--default-transition-duration);
}

.role-option-card.active {
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 2px rgba(38, 208, 168, 0.15);
    background: linear-gradient(135deg, rgba(38, 208, 168, 0.08), rgba(0, 137, 123, 0.05));
}

.role-option-card .role-icon {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.role-option-card .role-icon.bg-gradient-primary {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
}

.role-option-card .role-icon.bg-gradient-sky {
    background: linear-gradient(135deg, var(--color-accent-sky-blue-light), var(--color-accent-sky-blue));
}

.role-option-card .role-icon.bg-gradient-neutral {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.04));
}

.role-option-card .role-text strong {
    display: block;
    color: var(--color-white);
}

.role-option-card .role-text small {
    color: var(--color-neutral-light);
}

.role-option-card .role-check {
    margin-left: auto;
    color: var(--color-primary-light);
    opacity: 0;
    transition: opacity var(--default-transition-duration);
}

.role-option-card.active .role-check {
    opacity: 1;
}

.modal-content.border-primary-soft {
    border-color: rgba(38, 208, 168, 0.35) !important;
}

.modal-surface {
    background-color: var(--color-neutral-dark);
}

.bg-modal {
    background-color: var(--color-neutral-dark);
}

/* Ensure Google Places autocomplete appears above modals */
.pac-container {
    z-index: 2000 !important;
}

.branch-card {
    background: var(--color-neutral-dark);
    border: 1px solid var(--color-neutral-medium);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    box-shadow: var(--shadow-soft);
}

.branch-icon {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-md);
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.branch-map-placeholder {
    height: 150px;
    border-radius: var(--radius-md);
    background: var(--color-neutral-darkest);
}

.branch-map-static {
    width: 100%;
    height: 150px;
    object-fit: cover;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-neutral-medium);
    display: block;
}

.btn-neutral {
    background-color: var(--color-neutral-medium);
    color: var(--color-white);
    border: none;
}

.btn-neutral:hover {
    background-color: var(--color-neutral-light);
    color: var(--color-white);
}

.team-card {
    background: var(--color-neutral-dark);
    border: 1px solid var(--color-neutral-medium);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    box-shadow: var(--shadow-soft);
}

.team-avatar {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-lg);
    color: var(--color-white);
}

.avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-white);
}

.avatar-sm {
    width: 42px;
    height: 42px;
    font-size: var(--font-size-sm);
}

.icon-circle {
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(255, 255, 255, 0.08);
}

.icon-pill {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-pill);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-white);
}

.icon-pill-success,
.icon-pill-primary {
    background: rgba(38, 208, 168, 0.2);
    color: var(--color-primary-light);
}

.icon-pill-neutral {
    background: rgba(139, 156, 182, 0.2);
    color: var(--color-neutral-light);
}

.icon-pill-sky-blue {
    background: rgba(60, 176, 255, 0.2);
    color: var(--color-accent-sky-blue);
}

.icon-pill-amber {
    background: rgba(251, 176, 59, 0.2);
    color: var(--color-accent-amber);
}

.stat-card {
    background: linear-gradient(160deg, var(--color-neutral-dark), var(--color-neutral-medium));
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-soft);
}

.stat-card__label {
    color: var(--color-neutral-light);
    font-size: var(--font-size-sm);
}

.stat-card__value {
    color: var(--color-white);
    font-size: var(--font-size-2xl);
}

.program-card {
    background: rgba(26, 47, 79, 0.85);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-soft);
}

.program-card__stats {
    display: flex;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-4) 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.quick-action-card {
    background: var(--color-neutral-dark);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.quick-action-wrapper {
    max-width: 780px;
    margin: 0 auto var(--space-6);
}

.quick-action-card .input-group-text {
    border-radius: var(--radius-md) 0 0 var(--radius-md);
    border-color: rgba(255, 255, 255, 0.08);
}

.quick-action-card .quick-action-country-select {
    width: 156px;
    max-width: 156px;
    flex: 0 0 auto;
    border-color: rgba(255, 255, 255, 0.08);
    border-left: 1px solid rgba(255, 255, 255, 0.08);
    border-right: 0;
    border-radius: var(--radius-md) 0 0 var(--radius-md);
    background-color: rgba(255, 255, 255, 0.03);
    color: var(--color-white);
}

.quick-action-card .form-control {
    background-color: rgba(255, 255, 255, 0.03);
    color: var(--color-white);
}

.quick-action-card .quick-action-phone-local {
    min-width: 220px;
    border-right: 0;
}

.quick-action-card .quick-action-submit {
    align-self: flex-start;
}

.quick-action-card .quick-action-submit-addon {
    min-width: 208px;
    white-space: nowrap;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

@media (min-width: 768px) {
    .quick-action-card .quick-action-submit {
        padding-top: calc(var(--space-6) + 2px);
    }
}

.app-shell {
    display: flex;
    min-height: 100vh;
}

#main-area {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.app-sidebar {
    width: var(--sidebar-width);
    background: var(--color-neutral-dark);
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-inset);
    padding-bottom: var(--space-6);
    flex-shrink: 0;
    transition: width 0.3s ease, opacity 0.3s ease, margin 0.3s ease;
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
}

.app-sidebar.collapsed {
    width: 0;
    opacity: 0;
    padding: 0;
    border: none;
    overflow: hidden;
    pointer-events: none;
}

.sidebar-collapsed #main-area {
    width: 100%;
}

.sidebar-backdrop {
    display: none;
}

.app-sidebar .nav-link {
    padding: var(--space-3) var(--space-4);
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-md);
    color: var(--color-neutral-light);
    transition: background-color var(--default-transition-duration);
}

.app-sidebar .nav-link.active {
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-white);
}

.app-sidebar .nav-link:hover {
    color: var(--color-white);
    background: rgba(255, 255, 255, 0.04);
}

.app-header {
    height: var(--navbar-height);
    background: var(--color-neutral-dark);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 var(--space-5);
}

.main-content {
    flex: 1;
    padding: var(--space-6);
    background: linear-gradient(180deg, rgba(10, 22, 40, 0.9), rgba(10, 22, 40, 0.96));
}

.page-header {
    background: var(--color-neutral-dark);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding: var(--space-5) 0;
}

.page-header-title {
    font-size: 1.75rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-white);
    margin-bottom: 0.25rem;
}

.page-header-description {
    color: var(--color-neutral-light);
    margin-bottom: 0;
    font-size: 0.9375rem;
}

.page-header-tabs-wrapper {
    background: var(--color-neutral-dark);
    border-bottom: 2px solid rgba(255, 255, 255, 0.08);
    position: sticky;
    top: 0;
    z-index: 100;
}


.page-header-tabs {
    /* max-width: 1400px; */
    margin: 0 auto;
    display: flex;
    gap: 0;
    padding: 0;
    list-style: none;
}

.page-header-tabs .nav-item {
    flex: 1;
}

.page-header-tabs .nav-link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-3);
    color: var(--color-neutral-light);
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    font-weight: var(--font-weight-semibold);
    transition: all 0.2s ease;
    text-decoration: none;
    position: relative;
}

.page-header-tabs .nav-link:hover {
    color: var(--color-white);
    background: rgba(255, 255, 255, 0.03);
}

.page-header-tabs .nav-link.active {
    color: var(--color-primary-light) !important;
    background: rgba(38, 208, 168, 0.05);
    border-bottom-color: var(--color-primary-light);
}

.page-header-tabs .nav-link.active span {
    color: var(--color-primary-light);
}

.page-header-tabs .nav-link.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--color-primary-light);
    box-shadow: 0 0 12px rgba(38, 208, 168, 0.5);
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.section-title {
    font-size: 1.25rem;
    font-weight: var(--font-weight-semibold);
    color: var(--color-white);
    margin-bottom: 0.25rem;
}

.section-subtitle {
    color: var(--color-neutral-light);
    margin-bottom: 0;
    font-size: 0.875rem;
}

/* Responsive */
@media (max-width: 768px) {
    .page-header-tabs .nav-link {
        font-size: 0.875rem;
        padding: var(--space-3) var(--space-2);
    }

    .page-header-tabs .nav-link span {
        display: none;
    }

    .section-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-3);
    }
}

.table-card {
    border-radius: var(--radius-lg);
    background: rgba(26, 47, 79, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.table-card table {
    color: var(--color-white);
}

.table-card thead {
    color: var(--color-neutral-light);
}

.form-control,
.form-select,
.input-group-text {
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background-color: rgba(255, 255, 255, 0.04);
    color: var(--color-white);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 0.2rem rgba(38, 208, 168, 0.25);
    background-color: rgba(255, 255, 255, 0.04);
    color: var(--color-white);
}

input::placeholder,
textarea::placeholder {
    color: var(--color-neutral-light);
}

/* Custom Radio Buttons */
.form-check-input[type="radio"] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    background-color: transparent;
    cursor: pointer;
    transition: all 0.2s ease;
}

.form-check-input[type="radio"]:hover {
    border-color: var(--color-primary-light);
    background-color: rgba(38, 208, 168, 0.05);
}

.form-check-input[type="radio"]:checked {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary-light);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23ffffff'/%3e%3c/svg%3e");
    box-shadow: 0 0 0 3px rgba(38, 208, 168, 0.2);
}

.form-check-input[type="radio"]:focus {
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 3px rgba(38, 208, 168, 0.25);
    outline: none;
}

.form-check-input[type="radio"]:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    border-color: rgba(255, 255, 255, 0.2);
}

/* Custom Checkboxes */
.form-check-input[type="checkbox"] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--radius-sm);
    background-color: transparent;
    cursor: pointer;
    transition: all 0.2s ease;
}

.form-check-input[type="checkbox"]:hover {
    border-color: var(--color-primary-light);
    background-color: rgba(38, 208, 168, 0.05);
}

.form-check-input[type="checkbox"]:checked {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary-light);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
    box-shadow: 0 0 0 3px rgba(38, 208, 168, 0.2);
}

.form-check-input[type="checkbox"]:focus {
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 3px rgba(38, 208, 168, 0.25);
    outline: none;
}

.form-check-input[type="checkbox"]:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    border-color: rgba(255, 255, 255, 0.2);
}

.form-check-input[type="checkbox"]:indeterminate {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary-light);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10h8'/%3e%3c/svg%3e");
}

/* Form Check Labels */
.form-check-label {
    color: var(--color-white);
    font-weight: var(--font-weight-regular);
    cursor: pointer;
    user-select: none;
    margin-left: var(--space-2);
}

.form-check-label:hover {
    color: var(--color-primary-light);
}

.form-check-input:disabled~.form-check-label {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Form Check Container */
.form-check {
    display: flex;
    align-items: center;
    padding-left: 0;
    margin-bottom: var(--space-3);
}

.form-check .form-check-input {
    margin-left: 0;
    margin-right: var(--space-2);
    float: none;
}

/* Inline Checkboxes/Radios */
.form-check-inline {
    display: inline-flex;
    align-items: center;
    margin-right: var(--space-4);
}

/* Custom Toggle Switch (Bonus) */
.form-switch .form-check-input {
    width: 44px;
    height: 24px;
    background-color: rgba(255, 255, 255, 0.2);
    border: 2px solid rgba(255, 255, 255, 0.3);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba(255,255,255,0.8)'/%3e%3c/svg%3e");
}

.form-switch .form-check-input:checked {
    background-color: var(--color-primary);
    border-color: var(--color-primary-light);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23ffffff'/%3e%3c/svg%3e");
}

.form-switch .form-check-input:focus {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba(255,255,255,0.8)'/%3e%3c/svg%3e");
}

/* Card-based Radio/Checkbox Options (for plan selection style) */
.form-check-card {
    position: relative;
}

.form-check-card .form-check-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.form-check-card .form-check-label {
    display: block;
    border: 2px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    background: var(--color-neutral-dark);
    cursor: pointer;
    transition: all 0.2s ease;
    margin: 0;
}

.form-check-card .form-check-label:hover {
    border-color: rgba(38, 208, 168, 0.4);
    transform: translateY(-2px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.2);
}

.form-check-card .form-check-input:checked~.form-check-label {
    border-color: var(--color-primary-light);
    background: linear-gradient(135deg, rgba(0, 137, 123, 0.08), rgba(38, 208, 168, 0.05));
    box-shadow: 0 0 0 2px rgba(38, 208, 168, 0.2);
}

.form-check-card .form-check-input:checked~.form-check-label::after {
    content: '✓';
    position: absolute;
    top: 12px;
    right: 12px;
    width: 24px;
    height: 24px;
    background: var(--color-primary-light);
    color: var(--color-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    font-weight: var(--font-weight-bold);
}

.form-check-card .form-check-input:disabled~.form-check-label {
    opacity: 0.6;
    cursor: not-allowed;
}

.form-check-card .form-check-input:disabled~.form-check-label:hover {
    transform: none;
    box-shadow: none;
}

/* Validation States */
.form-check-input.is-valid {
    border-color: var(--color-primary-light);
}

.form-check-input.is-valid:checked {
    background-color: var(--color-primary-light);
}

.form-check-input.is-invalid {
    border-color: var(--color-accent-crimson);
}

.form-check-input.is-invalid:checked {
    background-color: var(--color-accent-crimson);
}

.invalid-feedback,
.valid-feedback {
    font-size: var(--font-size-sm);
    margin-top: var(--space-2);
}

.invalid-feedback {
    color: var(--color-accent-crimson);
}

.valid-feedback {
    color: var(--color-primary-light);
}

.progress-bar-gradient {
    background: linear-gradient(90deg, var(--color-primary-light), var(--color-primary));
}

.empty-state {
    padding: var(--space-6);
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.02);
    border: 1px dashed rgba(255, 255, 255, 0.1);
    text-align: center;
}

.empty-state .icon-circle {
    margin: 0 auto var(--space-4);
}

.offcanvas-dark {
    background: var(--color-neutral-dark);
    color: var(--color-white);
}

.dropdown-menu-dark {
    background: var(--color-neutral-dark);
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.dropdown-item {
    color: var(--color-neutral-light);
}

.dropdown-item:hover,
.dropdown-item:focus {
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-white);
}

/* Utility helpers */
.text-gradient-primary {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
}

.border-primary-soft {
    border-color: rgba(38, 208, 168, 0.4) !important;
}

.shadow-glow {
    box-shadow: 0 20px 40px rgba(38, 208, 168, 0.25);
}

.rounded-xxl {
    border-radius: var(--radius-xxl) !important;
}

.gradient-surface {
    background: radial-gradient(circle at top, rgba(38, 208, 168, 0.1), transparent 60%);
}

.onboarding-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-6);
}

.onboarding-card {
    width: 100%;
    max-width: 540px;
    background: rgba(10, 22, 40, 0.9);
    border-radius: var(--radius-xxl);
    padding: var(--space-6);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-card);
}

.onboarding-card--wide {
    max-width: 980px;
}

.onboarding-progress .progress {
    height: 8px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-pill);
    margin-bottom: var(--space-2);
}

.onboarding-card .btn-outline-light.active,
.onboarding-card .btn-outline-light.selected {
    background: var(--color-primary);
    border-color: transparent;
    color: var(--color-white);
    box-shadow: 0 10px 20px rgba(38, 208, 168, 0.3);
}

/* Onboarding step 4: program */

.visual-card {
    padding: 2rem;
    min-height: 276px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.visual-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
    opacity: 0.1;
}

/* Sellos Digitales */
.stamps-visual {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    position: relative;
    z-index: 1;
}

.stamp {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    border: 3px solid var(--color-primary-light);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    background: var(--color-neutral-dark);
}

.stamp.filled {
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    box-shadow: 0 0 20px hsla(169, 68%, 49%, 0.4);
    animation: stampFill 0.5s ease-out;
}

.stamp svg {
    width: 32px;
    height: 32px;
    stroke: var(--color-primary-light);
    stroke-width: 2;
    fill: none;
}

.stamp.filled svg {
    stroke: white;
}

/* Programa de Puntos */
.points-visual {
    text-align: center;
    position: relative;
    z-index: 1;
}

.points-display {
    font-size: 4rem;
    font-weight: 900;
    color: var(--color-primary-lighter);
    text-shadow: 0 0 20px hsla(169, 100%, 65%, 0.5);
    margin-bottom: 0.5rem;
    animation: pulse 2s ease-in-out infinite;
}

.points-label {
    font-size: 0.875rem;
    color: var(--muted-foreground);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.progress-ring {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 180px;
    height: 180px;
}

.progress-ring circle {
    fill: none;
    stroke: var(--color-primary-light);
    stroke-width: 3;
    stroke-dasharray: 440;
    stroke-dashoffset: 110;
    opacity: 0.3;
    animation: progressRing 3s ease-in-out infinite;
}

/* Niveles/Tiers */
.tiers-visual {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
    position: relative;
    z-index: 1;
}

.tier {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.tier-bronze {
    background: linear-gradient(90deg, hsla(30, 50%, 30%, 0.3), transparent);
    border-color: hsl(30, 50%, 40%);
}

.tier-silver {
    background: linear-gradient(90deg, hsla(0, 0%, 60%, 0.3), transparent);
    border-color: hsl(0, 0%, 70%);
}

.tier-gold {
    background: linear-gradient(90deg, hsla(51, 100%, 50%, 0.3), transparent);
    border-color: var(--color-accent-gold);
    box-shadow: 0 0 20px hsla(51, 100%, 50%, 0.2);
}

.tier-icon {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
}

.tier-bronze .tier-icon {
    background: hsl(30, 50%, 40%);
}

.tier-silver .tier-icon {
    background: hsl(0, 0%, 70%);
}

.tier-gold .tier-icon {
    background: var(--color-accent-gold);
    color: var(--color-neutral-darkest);
}

.tier-name {
    font-weight: 700;
    font-size: 1rem;
}

/* Recommended Badge */
.recommended-badge {
    position: absolute;
    top: -13px;
    left: 50%;
    transform: translateX(-50%);
}

.text-primary-light {
    color: var(--color-primary-light) !important;
}

.text-primary {
    color: var(--color-primary) !important;
}

.text-muted {
    color: var(--color-neutral-light) !important;
}

.bg-gradient {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary)) !important;
}

.preview-card {
    border-radius: var(--radius-xl);
    background: linear-gradient(160deg, rgba(0, 137, 123, 0.2), rgba(10, 22, 40, 0.8));
    padding: var(--space-6);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: var(--shadow-soft);
}

.program-choice-card {
    width: 100%;
    border-radius: var(--radius-lg);
    background: var(--color-neutral-dark);
    border: 1px solid var(--color-neutral-medium);
    padding: var(--space-4);
    text-align: left;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.program-choice-card:hover {
    border-color: var(--color-primary-light);
    transform: translateY(-2px);
}

.program-choice-card.is-selected {
    border-color: var(--color-primary-light);
    box-shadow: 0 12px 30px rgba(38, 208, 168, 0.25);
}

.branch-map-preview {
    height: 180px;
    border-radius: var(--radius-md);
    background: var(--color-neutral-darkest);
    border: 1px solid var(--color-neutral-medium);
}

.reward-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--space-3);
}

.reward-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    border-radius: var(--radius-md);
    padding: var(--space-3);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.points-ratio {
    padding: var(--space-4);
    border-radius: var(--radius-lg);
    background: rgba(38, 208, 168, 0.1);
    border: 1px solid rgba(38, 208, 168, 0.2);
}

.points-card {
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-darkest));
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    color: var(--color-white);
}

.points-balance {
    background: rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
}

.tiers-card {
    background: linear-gradient(135deg, var(--color-neutral-medium), var(--color-neutral-dark));
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    color: var(--color-white);
}

.tiers-level-card {
    background: rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
}

.tiers-progress {
    height: 8px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: var(--radius-pill);
}

.tiers-progress .progress-bar {
    background: var(--color-white);
}


.tier-stack .tier-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-3);
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.2);
}

.tier-stack .tier-item-active {
    background: rgba(255, 255, 255, 0.3);
}

.tier-stack {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.tier-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-lg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.tier-icon-1 {
    background: rgba(251, 176, 59, 0.2);
    color: var(--color-accent-amber);
}

.tier-icon-2 {
    background: rgba(255, 255, 255, 0.15);
    color: var(--color-neutral-light);
}

.tier-icon-3 {
    background: rgba(255, 215, 0, 0.2);
    color: var(--color-accent-gold);
}

.formset-item {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-3);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background-color: var(--color-neutral-medium);
    align-items: flex-end;
}


.program-option {
    display: flex;
    gap: var(--space-4);
    padding: var(--space-4);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.02);
    text-decoration: none;
    color: inherit;
    transition: all var(--default-transition-duration), transform var(--default-transition-duration);
}

.program-option:hover {
    border-color: rgba(38, 208, 168, 0.6);
    transform: translateY(-2px);
}

.program-option .visual-card {
    min-width: 276px;
}

.empty-state-card {
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    border: 1px dashed rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.02);
}

.branch-card {
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.pricing-card {
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(10, 22, 40, 0.8);
}

.pricing-card-featured {
    border-color: rgba(38, 208, 168, 0.6);
    box-shadow: 0 20px 40px rgba(38, 208, 168, 0.2);
}

.pricing-features li:not(:last-child) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding-bottom: var(--space-2);
    margin-bottom: var(--space-2);
}

.chart-placeholder {
    height: 280px;
    border-radius: var(--radius-lg);
    border: 1px dashed rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.02);
    position: relative;
    overflow: hidden;
}

.chart-placeholder .placeholder-glow {
    background: repeating-linear-gradient(-45deg,
            rgba(255, 255, 255, 0.03),
            rgba(255, 255, 255, 0.03) 20px,
            rgba(255, 255, 255, 0.08) 20px,
            rgba(255, 255, 255, 0.08) 40px);
    border-radius: inherit;
}

.indicator-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: inline-block;
}

@media (max-width: 992px) {
    .app-shell {
        min-height: 100dvh;
    }

    .app-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: min(86vw, var(--sidebar-width));
        max-width: 360px;
        height: 100dvh;
        z-index: 1045;
        transform: translateX(0);
        transition: transform 0.3s ease;
        box-shadow: var(--shadow-card);
        overscroll-behavior: contain;
    }

    .app-sidebar.collapsed {
        width: min(86vw, var(--sidebar-width));
        max-width: 360px;
        opacity: 1;
        padding-bottom: var(--space-6);
        border-right: 1px solid rgba(255, 255, 255, 0.08);
        pointer-events: none;
        transform: translateX(-100%);
    }

    #main-area {
        width: 100%;
        min-height: 100dvh;
    }

    .sidebar-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 1040;
        background: rgba(0, 0, 0, 0.45);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.2s ease;
    }

    .sidebar-backdrop.is-active {
        opacity: 1;
        pointer-events: auto;
    }

    body.sidebar-overlay-open {
        overflow: hidden;
    }

    .main-content {
        padding: var(--space-4);
    }
}

.auth-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-6);
}

.auth-card {
    width: 100%;
    max-width: 420px;
    background: rgba(10, 22, 40, 0.9);
    border-radius: var(--radius-xxl);
    padding: var(--space-6);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-card);
}

.auth-logo {
    height: 72px;
}

.profile-modal .modal-dialog {
    max-width: 420px;
}

.profile-modal .modal-content {
    background: transparent;
    border: none;
}

.profile-modal-header {
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-darkest));
    border-radius: var(--radius-xxl) var(--radius-xxl) 0 0;
    padding: var(--space-6);
    border: 2px solid var(--color-primary-light);
    border-bottom: none;
}

.profile-modal-body {
    background: var(--color-neutral-dark);
    border-radius: 0 0 var(--radius-xxl) var(--radius-xxl);
    padding: var(--space-6);
    border: 2px solid var(--color-primary-light);
    border-top: none;
}

.profile-avatar {
    position: relative;
    width: 96px;
    height: 96px;
    border-radius: 50%;
    background: var(--color-primary-light);
    display: grid;
    place-items: center;
    margin-bottom: var(--space-3);
}

.profile-avatar-initials {
    font-size: 2rem;
    font-weight: var(--font-weight-bold);
    color: var(--color-white);
}

.profile-avatar-edit {
    position: absolute;
    top: 0;
    right: 0;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.25);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.profile-avatar-lg {
    width: 128px;
    height: 128px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
}

.object-fit-cover {
    object-fit: cover;
}

.profile-action {
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-xl);
    color: var(--color-white);
    padding: var(--space-3);
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-weight: var(--font-weight-semibold);
    border: none;
    width: 100%;
    text-align: left;
}

.profile-action .lucide,
.profile-action i {
    color: var(--color-primary-light) !important;
}

.profile-action-danger {
    background: rgba(230, 57, 70, 0.15);
}

.profile-modal .btn-close {
    filter: invert(1);
}

.restaurant-modal .modal-dialog {
    max-width: 420px;
}

.restaurant-modal .modal-content {
    background: transparent;
    border: none;
}

.restaurant-modal-header {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    border-radius: var(--radius-xxl) var(--radius-xxl) 0 0;
    padding: var(--space-6);
    border: 2px solid var(--color-primary-light);
    border-bottom: none;
}

.restaurant-modal-body {
    background: var(--color-neutral-dark);
    border-radius: 0 0 var(--radius-xxl) var(--radius-xxl);
    padding: var(--space-6);
    border: 2px solid var(--color-primary-light);
    border-top: none;
}

.restaurant-avatar {
    width: 80px;
    height: 80px;
    border-radius: var(--radius-xl);
    background: rgba(255, 255, 255, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    margin: 0 auto var(--space-3);
}

.info-card {
    border-radius: var(--radius-xl);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: var(--space-4);
    display: flex;
    align-items: start;
    gap: var(--space-3);
    background: var(--color-neutral-darkest);
}

.info-card .lucide,
.info-card i {
    color: var(--color-primary-light);
}

.restaurant-action {
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-xl);
    color: var(--color-white);
    padding: var(--space-3);
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-weight: var(--font-weight-semibold);
    border: none;
    width: 100%;
    text-align: left;
}

.restaurant-action i,
.restaurant-action .lucide {
    color: var(--color-primary-light);
}

.restaurant-card {
    background: var(--color-neutral-dark);
    border: 1px solid var(--color-neutral-medium);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    box-shadow: var(--shadow-soft);
    transition: all var(--default-transition-duration), transform var(--default-transition-duration);
}

.restaurant-card:hover {
    border-color: rgba(38, 208, 168, 0.6);
    transform: translateY(-2px);
}

.modal-header-capsule {
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    border-radius: var(--radius-xxl) var(--radius-xxl) 0 0;
    padding: var(--space-5);
    border: 2px solid var(--color-primary-light);
    border-bottom: none;
}

.team-modal .modal-dialog,
.branch-modal .modal-dialog {
    max-width: 420px;
}

.team-modal .modal-content,
.branch-modal .modal-content {
    background: transparent;
    border: none;
}

.modal-surface,
.team-modal .modal-body,
.branch-modal .modal-body,
.quick-action-modal .modal-body {
    background: var(--color-neutral-dark);
    border-radius: 0 0 var(--radius-xxl) var(--radius-xxl);
    padding: var(--space-5);
    border: 2px solid var(--color-primary-light);
    border-top: none;
}


.profile-action.profile-action-danger .lucide,
.profile-action.profile-action-danger i,
.profile-action.profile-action-danger span {
    color: var(--color-accent-crimson) !important;
}

.google-icon {
    width: 24px;
    height: 24px;
}

.icon-sm {
    width: var(--icon-sm);
    height: var(--icon-sm);
}

.icon-md {
    width: var(--icon-md);
    height: var(--icon-md);
}

.icon-lg {
    width: var(--icon-lg);
    height: var(--icon-lg);
}

.icon-xl {
    width: var(--icon-xl);
    height: var(--icon-xl);
}

.visits-card {
    background: linear-gradient(135deg, var(--color-accent-sky-blue), var(--color-accent-sky-blue-dark));
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    box-shadow: var(--shadow-soft);
}

.visits-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.visit-node {
    width: 42px;
    height: 42px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.12);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
    font-weight: var(--font-weight-semibold);
}

.visit-node-complete {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.4);
}

.visit-node-reward {
    background: var(--color-white);
    color: var(--color-accent-sky-blue);
    border: none;
}

.visits-grid-card {
    grid-template-columns: repeat(auto-fill, minmax(48px, 1fr));
}

.visits-rewards-list {
    background: rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-lg);
    padding: var(--space-3);
}

/* Menu module */
.menu-onboarding-hint {
    background: rgba(38, 208, 168, 0.1);
    border: 1px solid rgba(38, 208, 168, 0.3);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    margin-bottom: var(--space-4);
}

.menu-onboarding-hint .icon-circle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(38, 208, 168, 0.2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary-light);
    margin-right: var(--space-3);
}

.menu-category-modal .modal-content,
.menu-item-modal .modal-content {
    background: var(--color-neutral-dark);
}

.menu-delete-item-modal .modal-content {
    background: var(--color-neutral-dark);
}

.menu-items-page .menu-category-tabs .menu-category-tab {
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-semibold);
}

.menu-items-page .menu-category-tab.active {
    background: var(--bs-info-bg-subtle);
    border-color: var(--color-primary-light);
    color: var(--color-white);
    box-shadow: none;
}

.menu-item-card {
    background: var(--color-neutral-dark);
    border: 1px solid var(--color-neutral-medium);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.menu-item-media {
    height: 180px;
    background: rgba(255, 255, 255, 0.04);
    display: flex;
    align-items: center;
    justify-content: center;
}

.menu-item-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.menu-item-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-neutral-light);
}

.menu-item-price {
    color: var(--color-primary-light);
    font-weight: var(--font-weight-semibold);
}

.menu-add-card {
    background: transparent;
    border: 2px dashed rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-lg);
    color: var(--color-white);
    transition: border-color var(--default-transition-duration);
}

.menu-add-card:hover {
    border-color: var(--color-primary-light);
}

.menu-add-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(38, 208, 168, 0.12);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary-light);
    margin: 0 auto;
}

.menu-image-drop {
    position: relative;
    border: 1px dashed rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    text-align: center;
    background: rgba(255, 255, 255, 0.02);
}

.menu-image-drop input[type="file"] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.menu-image-thumb {
    width: 100%;
    max-height: 240px;
    object-fit: cover;
    border-radius: var(--radius-md);
}

.menu-category-option {
    width: 100%;
    border: 1px solid var(--color-neutral-medium);
    border-radius: var(--radius-md);
    padding: var(--space-3);
    background: var(--color-neutral-darkest);
    text-align: left;
    color: var(--color-white);
    transition: border-color var(--default-transition-duration), box-shadow var(--default-transition-duration);
}

.menu-category-option.active {
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 2px rgba(38, 208, 168, 0.15);
}

.menu-category-option-new {
    border-style: dashed;
}

.menu-category-option-new.active {
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 2px rgba(38, 208, 168, 0.15);
    background: rgba(38, 208, 168, 0.08);
}

.menu-tag-chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-2);
}

.menu-tag-chip {
    border: none;
    background: rgba(38, 208, 168, 0.2);
    color: var(--color-primary-light);
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.menu-tag-chip-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: rgba(0, 137, 123, 0.25);
    color: var(--color-primary-light);
    font-size: 0.65rem;
    line-height: 1;
}

.menu-template-card,
.menu-palette-card {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3);
    border: 1px solid var(--color-neutral-medium);
    border-radius: var(--radius-lg);
    background: var(--color-neutral-darkest);
    cursor: pointer;
    transition: border-color var(--default-transition-duration), box-shadow var(--default-transition-duration);
}

.menu-template-card:hover,
.menu-palette-card:hover {
    border-color: var(--color-primary-light);
}

.menu-template-preview img {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: var(--radius-md);
}

.menu-palette-swatches {
    display: flex;
    gap: 0.4rem;
}

.menu-palette-swatches span {
    width: 22px;
    height: 22px;
    border-radius: 50%;
}

.menu-preview-frame {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: var(--color-neutral-darkest);
    height: 560px;
}

.menu-preview-frame iframe {
    width: 100%;
    height: 100%;
    border: none;
    background: transparent;
}

.menu-qr-wrapper {
    display: inline-flex;
    padding: var(--space-3);
    border-radius: var(--radius-lg);
    background: var(--color-white);
}

.menu-status-badge {
    display: inline-flex;
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.menu-status-live {
    background: rgba(38, 208, 168, 0.2);
    color: var(--color-primary-light);
}

.menu-status-draft {
    background: rgba(255, 255, 255, 0.12);
    color: var(--color-neutral-light);
}

.btn-check:checked+.menu-template-card,
.btn-check:checked+.menu-palette-card {
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 2px rgba(38, 208, 168, 0.2);
}

.menu-item-wrapper.dragging,
.menu-category-tab.dragging {
    opacity: 0.6;
}

@media (max-width: 768px) {
    .menu-preview-frame {
        height: 420px;
    }
}

/* Responsive remediation pass (mobile-first stability + CTA discoverability) */
body.dashboard-body,
#main-area,
.main-content {
    overflow-x: hidden;
}

.main-content .container-fluid {
    max-width: 100%;
}

.card,
.quick-action-card,
.program-card,
.program-option,
.team-card,
.plan-summary-card,
.branch-quantity-card,
.price-preview-card,
.subscription-summary-card {
    max-width: 100%;
}

.app-header.navbar {
    flex-wrap: nowrap;
}

.app-header-leading {
    min-width: 0;
    flex: 1 1 auto;
}

.app-header-title-wrap {
    min-width: 0;
}

.app-header-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.app-header-actions,
.app-header-profile-btn {
    flex-shrink: 0;
}

.section-header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.quick-action-card .quick-action-input-group {
    flex-wrap: nowrap;
    align-items: stretch;
}

.quick-action-card .quick-action-country-select {
    width: 156px;
    max-width: 156px;
}

.quick-action-card .quick-action-phone-local {
    flex: 1 1 auto;
    min-width: 0;
}

.quick-action-card .quick-action-submit {
    align-self: stretch;
}

.quick-action-card .quick-action-submit-btn {
    width: 100%;
    min-height: 56px;
    justify-content: center;
}

.menu-qr-wrapper-container {
    display: flex;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

.menu-qr-wrapper {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: min(100%, 320px);
    max-width: 100%;
}

.menu-qr-wrapper canvas,
.menu-qr-wrapper img,
.menu-qr-wrapper svg {
    display: block;
    width: 100% !important;
    max-width: 100%;
    height: auto !important;
}

.program-card {
    overflow: hidden;
}

.program-card .card-body,
.program-option .col,
.program-option .col-12,
.program-option .col-lg-auto {
    min-width: 0;
}

.program-option .row {
    width: 100%;
}

.program-option .visual-card {
    min-width: 0;
    width: 100%;
    max-width: 100%;
}

.reward-card span {
    overflow-wrap: anywhere;
}

.team-avatar {
    flex: 0 0 56px;
    min-width: 56px;
    min-height: 56px;
}

.team-card h5,
.team-card .text-muted,
.pending-invite-meta .fw-semibold {
    overflow-wrap: anywhere;
}

.subscription-manage-card {
    border: 1px solid rgba(38, 208, 168, 0.3);
    background: linear-gradient(135deg, rgba(38, 208, 168, 0.08), rgba(0, 137, 123, 0.04));
}

.subscription-manage-card .btn-primary {
    font-weight: var(--font-weight-semibold);
}

.branch-quantity-stepper {
    width: 100%;
}

.plan-management-mobile-nav {
    display: none;
}

.customer-portal-page {
    --customer-portal-cta-height: 56px;
    background:
        radial-gradient(1200px 360px at 20% -10%, rgba(38, 208, 168, 0.2), transparent 60%),
        radial-gradient(900px 280px at 100% 0%, rgba(72, 111, 255, 0.14), transparent 58%),
        var(--color-neutral-darkest);
    color: var(--color-white);
    min-height: 100vh;
    margin: 0;
    padding: 0;
}

.customer-portal-shell {
    width: 100%;
    max-width: 720px;
    margin: 0 auto;
    padding: var(--space-4) var(--space-4) var(--space-6);
}

.customer-portal-header {
    margin-bottom: var(--space-4);
}

.customer-portal-brand-link {
    display: inline-block;
}

.customer-portal-logo {
    width: 124px;
    height: auto;
}

.customer-portal-subtitle {
    color: var(--color-neutral-light);
    font-size: 0.95rem;
}

.customer-portal-nav {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    overflow-x: auto;
    padding-bottom: var(--space-2);
    margin-bottom: var(--space-3);
}

.customer-portal-nav a,
.customer-portal-nav .customer-portal-logout-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 0.35rem 0.8rem;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    color: var(--color-neutral-light);
    text-decoration: none;
    white-space: nowrap;
    background: rgba(255, 255, 255, 0.03);
    font-size: 0.86rem;
}

.customer-portal-nav a {
    gap: 0.35rem;
}

.customer-portal-nav a i,
.customer-portal-nav .customer-portal-logout-link i {
    width: 14px;
    height: 14px;
}

.customer-portal-nav a.is-active {
    color: var(--color-primary-light);
    border-color: var(--color-primary-light);
    background: rgba(38, 208, 168, 0.05);
}

.customer-portal-nav .customer-portal-logout-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: #fca5a5;
    border-color: rgba(252, 165, 165, 0.35);
}

.customer-portal-nav form {
    margin: 0;
}

.customer-portal-content {
    display: grid;
    gap: var(--space-3);
}

.customer-portal-card {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    box-shadow: var(--shadow-soft);
}

.customer-portal-kicker {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.75rem;
    color: var(--color-primary-light);
    margin-bottom: 0.4rem;
}

.customer-portal-icon-badge {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(38, 208, 168, 0.18);
    color: var(--color-primary-light);
}

.customer-portal-linktree {
    display: grid;
    gap: var(--space-2);
}

.customer-portal-linktree-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    color: var(--color-white);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-lg);
    padding: 0.85rem 1rem;
    background: rgba(10, 17, 27, 0.54);
}

.customer-portal-linktree-icon {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: rgba(38, 208, 168, 0.16);
    color: var(--color-primary-light);
    display: grid;
    place-items: center;
}

.customer-portal-linktree-label {
    font-weight: var(--font-weight-semibold);
}

.customer-portal-linktree-meta {
    color: var(--color-neutral-light);
    font-size: 0.85rem;
}

.customer-portal-preview-card {
    margin-top: var(--space-1);
}

.customer-portal-preview-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-2) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.customer-portal-preview-row:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.customer-portal-program-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-2);
}

.customer-portal-metric {
    font-size: 1.1rem;
    font-weight: var(--font-weight-semibold);
}

.customer-portal-history-item time {
    white-space: nowrap;
}

.customer-portal-history-item {
    border-left: 3px solid rgba(38, 208, 168, 0.4);
}

.customer-portal-history-icon {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    color: var(--color-primary-light);
    background: rgba(38, 208, 168, 0.12);
    flex-shrink: 0;
}

.customer-portal-history-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.customer-portal-search-form .input-group-text {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.2);
    color: var(--color-neutral-light);
}

.customer-portal-history-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    color: var(--color-neutral-light);
    padding: var(--space-2) 0;
}

.customer-portal-history-sentinel {
    height: 1px;
}

.customer-portal-card .form-control,
.customer-portal-card .form-select {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.2);
    color: var(--color-white);
}

.customer-portal-card .form-control::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.customer-portal-card .form-check-input:checked {
    background-color: var(--color-primary-light);
    border-color: var(--color-primary-light);
}

.customer-portal-checkbox .form-check-input {
    margin-top: 0.18rem;
}

.customer-portal-consent-modal .modal-dialog {
    max-width: 420px;
    padding: var(--space-3);
}

.customer-portal-consent-modal .modal-content {
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: var(--radius-xl);
    background:
        linear-gradient(160deg, rgba(38, 208, 168, 0.1), rgba(10, 17, 27, 0.95)),
        rgba(10, 17, 27, 0.96);
}

.customer-portal-consent-modal .modal-body {
    padding: 1.5rem 1.25rem 1.25rem;
}

.customer-portal-consent-icon {
    width: 52px;
    height: 52px;
    margin: 0 auto 0.85rem;
    border-radius: 999px;
    display: grid;
    place-items: center;
    color: var(--color-primary-light);
    background: rgba(38, 208, 168, 0.16);
    border: 1px solid rgba(38, 208, 168, 0.35);
}

.customer-portal-consent-dismiss {
    color: var(--color-neutral-light);
    text-decoration: none;
}

.customer-portal-consent-dismiss:hover,
.customer-portal-consent-dismiss:focus {
    color: var(--color-white);
}

.customer-portal-whatsapp-cta {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    min-height: var(--customer-portal-cta-height);
    border-radius: 0;
    background: linear-gradient(135deg, #22c55e, #16a34a);
    color: #ffffff;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    font-weight: var(--font-weight-semibold);
    box-shadow: 0 14px 28px rgba(22, 163, 74, 0.3);
    z-index: 20;
}

.customer-portal-whatsapp-cta span {
    color: #ffffff;
}

.customer-portal-footer {
    text-align: center;
    color: var(--color-neutral-light);
    font-size: 0.75rem;
    padding: 0 var(--space-4) var(--space-5);
    margin-bottom: 20px;
}

.customer-portal-page.has-portal-whatsapp-cta .customer-portal-footer {
    margin-bottom: calc(var(--customer-portal-cta-height) + 20px);
}

.customer-portal-footer a {
    color: var(--color-primary-light);
}

@media (min-width: 768px) {
    .quick-action-card .quick-action-submit-addon {
        min-height: 56px;
    }
}

@media (min-width: 992px) {
    .quick-action-modal .modal-body.loyalty-confirmation-body {
        min-height: 420px;
    }

    .quick-action-modal .loyalty-confirmation-full {
        flex: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

}

@media (max-width: 992px) {
    .program-option {
        padding: var(--space-3);
    }

    .program-option .visual-card {
        min-height: 228px;
    }

    .points-display {
        font-size: 3rem;
    }

    .progress-ring {
        width: 150px;
        height: 150px;
    }
}

@media (max-width: 768px) {
    .customer-portal-shell {
        padding: var(--space-3) var(--space-3) var(--space-5);
    }

    .customer-portal-program-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .app-header {
        padding: 0 var(--space-3);
        gap: var(--space-2);
    }

    .app-header-title {
        font-size: 1.5rem;
    }

    .section-header {
        gap: var(--space-3);
    }

    .section-header-actions {
        width: 100%;
    }

    .quick-action-card .quick-action-input-group {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--space-2);
    }

    .quick-action-card .quick-action-country-select {
        width: 100%;
        max-width: 100%;
        border-left: 1px solid rgba(255, 255, 255, 0.08);
        border-right: 1px solid rgba(255, 255, 255, 0.08);
        border-radius: var(--radius-md);
    }

    .quick-action-card .quick-action-phone-local {
        width: 100%;
        border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
        border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
        border-radius: var(--radius-md);
    }

    .menu-items-actions {
        justify-content: flex-start;
    }

    .menu-items-actions .menu-action-btn {
        min-width: 52px;
        justify-content: center;
        padding-inline: 0.75rem;
    }

    .menu-items-actions .menu-action-btn .btn-label {
        display: none;
    }

    .program-option .row {
        margin-left: 0;
        margin-right: 0;
    }

    .program-option .row>[class*='col'] {
        padding-left: 0;
        padding-right: 0;
    }

    .stamps-visual {
        gap: 0.65rem;
    }

    .stamp {
        width: 52px;
        height: 52px;
    }

    .tier {
        padding: 0.65rem 1rem;
    }

    .pending-invite-item {
        flex-direction: column;
        align-items: flex-start !important;
        gap: var(--space-3);
    }

    .pending-invite-actions {
        width: 100%;
        flex-direction: column;
    }

    .pending-invite-actions .btn {
        width: 100%;
    }

    .subscription-manage-card {
        position: sticky;
        top: calc(var(--navbar-height) + var(--space-2));
        z-index: 25;
    }

    .subscription-manage-main-icon {
        display: none;
    }

    .subscription-summary-card .card-body,
    .subscription-cancel-card .card-body {
        padding: var(--space-3) !important;
    }

    .subscription-summary-card .report-stat-card {
        padding: var(--space-3);
        min-height: auto;
    }

    .subscription-summary-card .stat-value {
        font-size: 1.3rem;
    }

    .plan-summary-card .card-body {
        padding: var(--space-3) !important;
    }

    .branch-quantity-stepper {
        display: grid !important;
        grid-template-columns: minmax(56px, 72px) minmax(0, 1fr) minmax(56px, 72px);
        align-items: center;
        gap: var(--space-2);
    }

    .branch-quantity-input {
        max-width: 100%;
        min-height: 56px;
    }

    .quantity-btn {
        width: 100%;
        height: 56px;
    }

    .price-preview-card {
        margin-top: 0;
    }

    #plan-management-form {
        padding-bottom: 9rem;
    }

    .plan-management-mobile-nav {
        display: block;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1030;
        padding: var(--space-3);
        background: rgba(10, 22, 40, 0.94);
        border-top: 1px solid rgba(255, 255, 255, 0.12);
        box-shadow: 0 -12px 24px rgba(0, 0, 0, 0.35);
        backdrop-filter: blur(8px);
    }

    .plan-management-mobile-nav .btn {
        width: 100%;
    }
}

@media (min-width: 769px) {
    .plan-management-mobile-nav {
        display: none !important;
    }
}
