@import '_content/RV_Share_UI_Component/RV_Share_UI_Component.mvn1plkt9l.bundle.scp.css';

/* /Components/Layout/MainLayout.razor.rz.scp.css */
#blazor-error-ui[b-dtwae8c3xu] {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss[b-dtwae8c3xu] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }
/* /Components/Layout/TopMenu.razor.rz.scp.css */
.header-container[b-uocqkef0z7] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 2rem;
    background: white;
    border-bottom: 1px solid #e0e0e0;
}

.brand-link[b-uocqkef0z7] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
    color: inherit;
    white-space: nowrap;
}

.brand-mascot-image[b-uocqkef0z7] {
    width: 40px;
    height: 40px;
    border-radius: 50%;
}

.brand-name[b-uocqkef0z7] {
    font-size: 1.25rem;
    font-weight: 700;
    color: #333;
}

.navigation-list[b-uocqkef0z7] {
    display: flex;
    list-style: none;
    gap: 2rem;
    margin: 0;
    padding: 0;
    align-items: center;
}

.navigation-link[b-uocqkef0z7] {
    text-decoration: none;
    color: var(--capybara-text-0);
    font-weight: 500;
    transition: color 0.2s;
}

.navigation-link:hover[b-uocqkef0z7] {
    color: var(--capybara-primary);
}

.header-cta-group[b-uocqkef0z7] {
    display: flex;
    gap: 1rem;
    align-items: center;
}

.header-profile-link[b-uocqkef0z7] {
    white-space: nowrap;
}

.header-cta-button[b-uocqkef0z7] {
    padding: 0.5rem 1rem;
    border-radius: 0.25rem;
    text-decoration: none;
    transition: all 0.2s;
    cursor: pointer;
    border: none;
    font-weight: 500;
}

.secondary-cta-button[b-uocqkef0z7] {
    background-color: var(--capybara-secondary) !important;
    color: var(--capybara-text-inverse) !important;
    border-radius: var(--capybara-radius-md);
    transition: all 150ms ease;
}

.secondary-cta-button:hover[b-uocqkef0z7] {
    opacity: 0.9;
    transform: translateY(-1px);
    box-shadow: var(--capybara-shadow);
}

.mobile-nav-toggle[b-uocqkef0z7] {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    align-items: center;
    gap: 0.5rem;
}

.mobile-icon[b-uocqkef0z7] {
    width: 24px;
    height: 24px;
}

.mobile-icon-close[b-uocqkef0z7] {
    display: none;
}

[data-menu-open="true"] .mobile-icon-open[b-uocqkef0z7] {
    display: none;
}

[data-menu-open="true"] .mobile-icon-close[b-uocqkef0z7] {
    display: block;
}

.mobile-nav-layer[b-uocqkef0z7] {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
}

[data-menu-open="true"] .mobile-nav-layer[b-uocqkef0z7] {
    display: flex;
}

.mobile-nav-overlay[b-uocqkef0z7] {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
}

.mobile-nav-panel[b-uocqkef0z7] {
    position: relative;
    background: white;
    max-width: 80%;
    height: 100%;
    margin-left: auto;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.mobile-panel-header[b-uocqkef0z7] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid #e0e0e0;
}

.mobile-brand[b-uocqkef0z7] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.mobile-brand-icon[b-uocqkef0z7] {
    width: 28px;
    height: 28px;
    border-radius: 50%;
}

.mobile-brand-name[b-uocqkef0z7] {
    font-size: 1rem;
    color: #333;
}

.mobile-close-btn[b-uocqkef0z7] {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
}

.mobile-nav-list[b-uocqkef0z7] {
    display: flex;
    flex-direction: column;
    list-style: none;
    padding: 1rem 0;
    margin: 0;
    flex: 1;
}

.mobile-nav-link[b-uocqkef0z7] {
    display: block;
    padding: 1rem 1.5rem;
    text-decoration: none;
    color: #333;
    font-weight: 500;
    transition: background-color 0.2s;
}

.mobile-nav-link:hover[b-uocqkef0z7] {
    background-color: #f5f5f5;
}

.mobile-cta-button[b-uocqkef0z7] {
    padding: 0.75rem 1.5rem;
    margin: 0 1rem 1rem 1rem;
    width: calc(100% - 2rem);
}

.mobile-profile-link[b-uocqkef0z7] {
    display: block;
    text-align: center;
}

@media (max-width: 992px) {
    .header-container[b-uocqkef0z7] {
        padding: 1rem;
    }

    .navigation-list[b-uocqkef0z7] {
        display: none;
    }

    .header-cta-group[b-uocqkef0z7] {
        display: none;
    }

    .mobile-nav-toggle[b-uocqkef0z7] {
        display: flex;
    }
}
/* /Components/Pages/About.razor.rz.scp.css */
.about-page-container[b-xwuaov4ht6] {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    padding: 2rem 1rem;
    background: #F5F1ED;
    position: relative;
}

.about-page-header[b-xwuaov4ht6] {
    text-align: center;
    margin-bottom: 2rem;
    background: #8B5E3C;
    padding: 2rem 1rem;
    border-radius: 12px;
    margin: 0 -1rem 2rem -1rem;
}

.about-page-header h1[b-xwuaov4ht6] {
    color: #FFFFFF;
    margin: 0;
    font-size: 2rem;
    font-weight: 600;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.about-page-header p[b-xwuaov4ht6] {
    color: rgba(255, 255, 255, 0.9);
    margin: 0.5rem 0 0 0;
    font-size: 1rem;
}

.about-content[b-xwuaov4ht6] {
    flex: 1;
    border: 1px solid #DCC9B8;
    border-radius: 12px;
    margin-bottom: 2rem;
    background: #FFFFFF;
    box-shadow: 0 4px 12px rgba(74, 59, 50, 0.1);
    padding: 1.5rem;
    position: relative;
    z-index: 2;
}

.about-content p[b-xwuaov4ht6] {
    margin-bottom: 1rem;
    line-height: 1.7;
    color: #2F241E;
}

.about-content p:last-child[b-xwuaov4ht6] {
    margin-bottom: 0;
}

.about-page-actions[b-xwuaov4ht6] {
    display: flex;
    gap: 1rem;
    justify-content: center;
    padding-bottom: 1rem;
    position: relative;
    z-index: 2;
}

.back-button[b-xwuaov4ht6] {
    min-width: 140px;
    background-color: #8B5E3C !important;
    color: #FFFFFF !important;
    font-weight: 600;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}
/* /Components/Pages/Admin/ResortApprovalPage.razor.rz.scp.css */
.approval-container[b-dpl6j8pyb7] {
    padding: 2rem;
    max-width: 1400px;
    margin: 0 auto;
}

.approval-header[b-dpl6j8pyb7] {
    margin-bottom: 2rem;
    text-align: center;
}

.approval-header h1[b-dpl6j8pyb7] {
    font-size: 2.5rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.subtitle[b-dpl6j8pyb7] {
    font-size: 1.1rem;
    color: #666;
}

.loading-container[b-dpl6j8pyb7] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    gap: 1rem;
}

.action-buttons[b-dpl6j8pyb7] {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

@media (max-width: 768px) {
    .approval-container[b-dpl6j8pyb7] {
        padding: 1rem;
    }

    .approval-header h1[b-dpl6j8pyb7] {
        font-size: 1.75rem;
    }

    .action-buttons[b-dpl6j8pyb7] {
        flex-direction: column;
    }
}
/* /Components/Pages/Admin/ResortForm.razor.rz.scp.css */
.resort-form-container[b-e1vy13bj57] {
    padding: 2rem;
    max-width: 1000px;
    margin: 0 auto;
}

.form-header[b-e1vy13bj57] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
}

.form-header h1[b-e1vy13bj57] {
    font-size: 2rem;
    font-weight: 600;
    margin: 0;
}

.form-actions[b-e1vy13bj57] {
    display: flex;
    gap: 1rem;
    margin-top: 2rem;
}

.loading-container[b-e1vy13bj57] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    gap: 1rem;
}

@media (max-width: 768px) {
    .resort-form-container[b-e1vy13bj57] {
        padding: 1rem;
    }

    .form-header[b-e1vy13bj57] {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }

    .form-header h1[b-e1vy13bj57] {
        font-size: 1.5rem;
    }
}
/* /Components/Pages/CheckList/CheckListsName.razor.rz.scp.css */
.checklist-toolbar[b-956brk8fl5] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.form-input[b-956brk8fl5] {
    width: 100%;
    padding: 0.7rem 0.9rem;
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    background: var(--surface-1);
    color: var(--text-0);
    font-size: 1rem;
    transition: border-color 150ms ease, box-shadow 150ms ease;
}

.form-input:focus[b-956brk8fl5] {
    outline: none;
    border-color: var(--gjs-t-color-primary);
    box-shadow: 0 0 0 3px rgba(139, 94, 60, 0.12);
}

.empty-state[b-956brk8fl5] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.95rem;
}

.checklist-input-group[b-956brk8fl5] {
    display: flex;
    flex: 1;
    gap: 0.75rem;
    min-width: 240px;
}

.checklist-toggle-group[b-956brk8fl5] {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.checklist-list[b-956brk8fl5] {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.checklist-list li[b-956brk8fl5] {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: var(--surface-1);
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    padding: 0.85rem 1rem;
    cursor: grab;
    transition: border 0.2s ease, box-shadow 0.2s ease;
}

.checklist-list li:hover[b-956brk8fl5] {
    border-color: rgba(139, 94, 60, 0.4);
    box-shadow: var(--shadow-sm, 0 8px 20px rgba(0, 0, 0, 0.08));
}

.checklist-list li.dragging[b-956brk8fl5] {
    opacity: 0.5;
}

.checklist-list li.drop-target[b-956brk8fl5] {
    border-top: 2px solid var(--gjs-t-color-primary);
}

.checklist-open[b-956brk8fl5] {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    flex: 1;
    width: 100%;
}

.checklist-open-title[b-956brk8fl5] {
    color: var(--text-0);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.3;
    text-align: left;
}

.checklist-open-hint[b-956brk8fl5] {
    color: var(--text-1);
    font-size: 0.86rem;
}

.checklist-actions[b-956brk8fl5] {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    flex-shrink: 0;
}

.checklist-edit-row[b-956brk8fl5] {
    display: flex;
    gap: 0.75rem;
    width: 100%;
    align-items: center;
}

@media (max-width: 640px) {
    .checklist-input-group[b-956brk8fl5] {
        flex-direction: column;
        align-items: stretch;
    }

    .checklist-edit-row[b-956brk8fl5] {
        flex-direction: column;
        align-items: stretch;
    }

    .checklist-list li[b-956brk8fl5] {
        flex-wrap: wrap;
    }

    .checklist-actions[b-956brk8fl5] {
        justify-content: flex-end;
    }
}
/* /Components/Pages/CheckList/CheckListTemplet.razor.rz.scp.css */
.checklist-complete-bar[b-rb3sjke170] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: var(--surface-1);
    border: 1px solid rgba(139, 94, 60, 0.35);
    border-radius: var(--radius-sm);
    padding: 0.85rem 1rem;
    margin-bottom: 1.25rem;
    font-weight: 600;
    color: var(--text-0);
}

.checklist-toolbar[b-rb3sjke170] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.form-input[b-rb3sjke170] {
    width: 100%;
    padding: 0.7rem 0.9rem;
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    background: var(--surface-1);
    color: var(--text-0);
    font-size: 1rem;
    transition: border-color 150ms ease, box-shadow 150ms ease;
}

.form-input:focus[b-rb3sjke170] {
    outline: none;
    border-color: var(--gjs-t-color-primary);
    box-shadow: 0 0 0 3px rgba(139, 94, 60, 0.12);
}

.empty-state[b-rb3sjke170] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.95rem;
}

.checklist-input-group[b-rb3sjke170] {
    display: flex;
    flex: 1;
    gap: 0.75rem;
    min-width: 240px;
}

.checklist-toggle-group[b-rb3sjke170] {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.checklist-list[b-rb3sjke170] {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.checklist-list li[b-rb3sjke170] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: var(--surface-1);
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    padding: 0.85rem 1rem;
    cursor: grab;
    transition: border 0.2s ease, box-shadow 0.2s ease;
}

.checklist-list li:hover[b-rb3sjke170] {
    border-color: rgba(139, 94, 60, 0.4);
    box-shadow: var(--shadow-sm, 0 8px 20px rgba(0, 0, 0, 0.08));
}

.checklist-list li.dragging[b-rb3sjke170] {
    opacity: 0.5;
}

.checklist-list li.drop-target[b-rb3sjke170] {
    border-top: 2px solid var(--gjs-t-color-primary);
}

.checklist-actions[b-rb3sjke170] {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    align-items: center;
}

.checklist-edit-row[b-rb3sjke170] {
    display: flex;
    gap: 0.75rem;
    width: 100%;
    align-items: center;
}

.checklist-detail-header[b-rb3sjke170] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.checklist-detail-title h2[b-rb3sjke170] {
    margin: 0;
    font-size: 1.4rem;
    color: var(--text-0);
}

.checklist-detail-title span[b-rb3sjke170] {
    display: inline-block;
    margin-top: 0.25rem;
    color: var(--text-1);
    font-size: 0.9rem;
}

.checklist-checkbox[b-rb3sjke170] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
}

.checklist-checkbox input[b-rb3sjke170] {
    width: 18px;
    height: 18px;
}

.checklist-item-text[b-rb3sjke170] {
    color: var(--text-0);
    font-weight: 600;
}

@media (max-width: 640px) {
    .checklist-input-group[b-rb3sjke170] {
        flex-direction: column;
        align-items: stretch;
    }

    .checklist-edit-row[b-rb3sjke170] {
        flex-direction: column;
        align-items: stretch;
    }

    .checklist-list li[b-rb3sjke170] {
        flex-direction: column;
        align-items: stretch;
    }

    .checklist-actions[b-rb3sjke170] {
        justify-content: flex-end;
    }

    .checklist-detail-header[b-rb3sjke170] {
        flex-direction: column;
        align-items: flex-start;
    }
}
/* /Components/Pages/CheckList/CheckListView.razor.rz.scp.css */
.checklist-page[b-46t3c8q262] {
    min-height: 100vh;
    padding: 2.5rem 1rem 3rem;
    background: linear-gradient(135deg, var(--surface-0) 0%, var(--surface-2) 100%);
    display: flex;
    justify-content: center;
}

.checklist-card[b-46t3c8q262] {
    background: var(--surface-1);
    border-radius: var(--radius-lg);
    border: 1px solid var(--ring);
    box-shadow: var(--shadow);
    padding: 2.5rem;
    width: 100%;
    max-width: 980px;
}

.checklist-header[b-46t3c8q262] {
    text-align: center;
    margin-bottom: 2rem;
}

.checklist-header h1[b-46t3c8q262] {
    margin: 0 0 0.5rem;
    font-size: 2rem;
    color: var(--gjs-t-color-primary);
    font-family: "Poppins", sans-serif;
}

.checklist-header p[b-46t3c8q262] {
    margin: 0;
    color: var(--text-1);
    font-size: 1rem;
}

.profile-status[b-46t3c8q262] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    padding: 2.5rem 1rem;
    text-align: center;
    color: var(--text-0);
}

.loading-spinner[b-46t3c8q262] {
    width: 1.2rem;
    height: 1.2rem;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin-b-46t3c8q262 1s linear infinite;
}

.loading-spinner.large[b-46t3c8q262] {
    width: 1.8rem;
    height: 1.8rem;
    border-width: 3px;
}

.error-message[b-46t3c8q262] {
    background: rgba(220, 53, 69, 0.1);
    color: #b02a37;
    padding: 1rem 1.25rem;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(220, 53, 69, 0.3);
    text-align: center;
}

@keyframes spin-b-46t3c8q262 {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 720px) {
    .checklist-card[b-46t3c8q262] {
        padding: 2rem 1.25rem;
    }
}
/* /Components/Pages/ForgotPassword.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════
   FORGOT PASSWORD PAGE - Styles
   ═══════════════════════════════════════════════════════════════ */

/* ── Hero Banner ─────────────────────────────────────────────── */
.password-page-hero[b-ap595pvcz2] {
    background: linear-gradient(135deg, #8B5E3C 0%, #C69C72 100%);
    padding: 3rem 1.5rem 2.5rem;
    text-align: center;
}

.password-page-hero-inner[b-ap595pvcz2] {
    max-width: 600px;
    margin: 0 auto;
}

.password-page-title[b-ap595pvcz2] {
    color: #fff;
    font-size: 2rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
    letter-spacing: -0.5px;
}

.password-page-subtitle[b-ap595pvcz2] {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.95rem;
    margin: 0;
    font-weight: 400;
}

/* ── Main Layout ─────────────────────────────────────────────── */
.password-page-layout[b-ap595pvcz2] {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    min-height: calc(100vh - 200px);
    padding: 2.5rem 1.5rem 3rem;
    background: #fafaf8;
}

.password-content-card[b-ap595pvcz2] {
    width: 100%;
    max-width: 420px;
    background: #fff;
    border: 1px solid #e8ddd4;
    border-radius: 12px;
    box-shadow: 0 4px 16px rgba(139, 94, 60, 0.08);
    overflow: hidden;
}

.password-content-inner[b-ap595pvcz2] {
    padding: 2.5rem 2rem;
}

/* ── Form Wrapper ────────────────────────────────────────────── */
.password-form-wrapper[b-ap595pvcz2] {
    animation: fadeIn-b-ap595pvcz2 0.3s ease-in-out;
}

@keyframes fadeIn-b-ap595pvcz2 {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.password-intro-text[b-ap595pvcz2] {
    font-size: 0.9rem;
    color: #666;
    line-height: 1.5;
    margin: 0 0 1.5rem;
    text-align: center;
}

/* ── Form Group ──────────────────────────────────────────────── */
.password-form-group[b-ap595pvcz2] {
    margin-bottom: 1.25rem;
}

.password-label[b-ap595pvcz2] {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: #5a3e28;
    margin-bottom: 0.5rem;
    letter-spacing: 0.3px;
}

/* ── Form Actions ────────────────────────────────────────────── */
.password-form-actions[b-ap595pvcz2] {
    margin-top: 2rem;
    margin-bottom: 1rem;
}

:deep(.password-form-actions .mud-button)[b-ap595pvcz2] {
    height: 44px;
    font-weight: 600;
    font-size: 0.95rem;
    border-radius: 8px;
    text-transform: none;
}

:deep(.password-form-actions .mud-button-filled-primary)[b-ap595pvcz2] {
    background: linear-gradient(135deg, #C69C72 0%, #8B5E3C 100%);
}

:deep(.password-form-actions .mud-button-filled-primary:hover)[b-ap595pvcz2] {
    background: linear-gradient(135deg, #8B5E3C 0%, #6d4524 100%);
    box-shadow: 0 4px 12px rgba(139, 94, 60, 0.2);
}

/* ── Form Help Text ──────────────────────────────────────────── */
.password-form-help[b-ap595pvcz2] {
    text-align: center;
    padding-top: 0.75rem;
    border-top: 1px solid #e8ddd4;
}

.password-form-help p[b-ap595pvcz2] {
    font-size: 0.85rem;
    color: #999;
    margin: 0.75rem 0 0;
}

.password-link[b-ap595pvcz2] {
    color: #8B5E3C;
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
    cursor: pointer;
}

.password-link:hover[b-ap595pvcz2] {
    color: #C69C72;
    text-decoration: underline;
}

/* ── Alert Messages ──────────────────────────────────────────── */
.password-alert-error[b-ap595pvcz2] {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.95rem 1rem;
    background: #fff5f5;
    border: 1px solid #f5d7d7;
    border-radius: 8px;
    margin-bottom: 1.5rem;
    font-size: 0.9rem;
    color: #c1271b;
    animation: slideDown-b-ap595pvcz2 0.3s ease-out;
}

@keyframes slideDown-b-ap595pvcz2 {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.password-alert-error .error-icon[b-ap595pvcz2] {
    flex-shrink: 0;
    font-size: 1.1rem;
    line-height: 1;
}

/* ── Success Box ─────────────────────────────────────────────── */
.password-success-box[b-ap595pvcz2] {
    text-align: center;
    animation: fadeIn-b-ap595pvcz2 0.4s ease-out;
}

.success-icon[b-ap595pvcz2] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background: #e8f5e9;
    border-radius: 50%;
    font-size: 2rem;
    color: #4caf50;
    margin-bottom: 1rem;
}

.success-title[b-ap595pvcz2] {
    font-size: 1.5rem;
    font-weight: 700;
    color: #2e7d32;
    margin: 0 0 0.75rem;
}

.success-message[b-ap595pvcz2] {
    font-size: 0.9rem;
    color: #666;
    line-height: 1.6;
    margin: 0 0 1.5rem;
}

:deep(.password-success-box .mud-button)[b-ap595pvcz2] {
    height: 44px;
    font-weight: 600;
    font-size: 0.95rem;
    border-radius: 8px;
    text-transform: none;
    margin-top: 0.5rem;
}

:deep(.password-success-box .mud-button-filled-primary)[b-ap595pvcz2] {
    background: linear-gradient(135deg, #C69C72 0%, #8B5E3C 100%);
}

/* ── Text Field Customization ────────────────────────────────── */
:deep(.password-content-card .mud-input-control)[b-ap595pvcz2] {
    margin: 0;
}

:deep(.password-content-card .mud-input-outlined)[b-ap595pvcz2] {
    border-color: #e8ddd4;
}

:deep(.password-content-card .mud-input-outlined:hover)[b-ap595pvcz2] {
    border-color: #C69C72;
}

:deep(.password-content-card .mud-input-outlined.mud-focused)[b-ap595pvcz2] {
    border-color: #8B5E3C;
}

:deep(.password-content-card .mud-input-outlined input)[b-ap595pvcz2] {
    font-size: 0.95rem;
}

/* ── Responsive Design ───────────────────────────────────────── */
@media (max-width: 480px) {
    .password-page-hero[b-ap595pvcz2] {
        padding: 2.5rem 1rem 2rem;
    }

    .password-page-title[b-ap595pvcz2] {
        font-size: 1.65rem;
    }

    .password-page-subtitle[b-ap595pvcz2] {
        font-size: 0.9rem;
    }

    .password-page-layout[b-ap595pvcz2] {
        padding: 1.5rem 1rem 2rem;
        min-height: auto;
    }

    .password-content-card[b-ap595pvcz2] {
        max-width: 100%;
        border-radius: 8px;
    }

    .password-content-inner[b-ap595pvcz2] {
        padding: 1.75rem 1.25rem;
    }

    .password-form-group[b-ap595pvcz2] {
        margin-bottom: 1rem;
    }

    .password-intro-text[b-ap595pvcz2] {
        font-size: 0.85rem;
        margin-bottom: 1.25rem;
    }

    .password-label[b-ap595pvcz2] {
        font-size: 0.8rem;
    }

    :deep(.password-form-actions .mud-button)[b-ap595pvcz2] {
        height: 40px;
        font-size: 0.9rem;
    }

    .success-icon[b-ap595pvcz2] {
        width: 50px;
        height: 50px;
        font-size: 1.75rem;
    }

    .success-title[b-ap595pvcz2] {
        font-size: 1.25rem;
    }
}

@media (max-width: 360px) {
    .password-page-title[b-ap595pvcz2] {
        font-size: 1.5rem;
    }

    .password-content-inner[b-ap595pvcz2] {
        padding: 1.5rem 1rem;
    }

    .password-intro-text[b-ap595pvcz2] {
        font-size: 0.8rem;
    }
}

/* ── Dark Mode Support ──────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
    .password-page-layout[b-ap595pvcz2] {
        background: #1a1a18;
    }

    .password-content-card[b-ap595pvcz2] {
        background: #2a2a28;
        border-color: #3a3a38;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
    }

    .password-label[b-ap595pvcz2] {
        color: #d4af9d;
    }

    .password-intro-text[b-ap595pvcz2],
    .success-message[b-ap595pvcz2],
    .password-form-help p[b-ap595pvcz2] {
        color: #bbb;
    }

    .password-link[b-ap595pvcz2] {
        color: #d4af9d;
    }

    .password-link:hover[b-ap595pvcz2] {
        color: #e8ddd4;
    }

    .password-form-help[b-ap595pvcz2] {
        border-top-color: #3a3a38;
    }

    .password-alert-error[b-ap595pvcz2] {
        background: #3a2020;
        border-color: #5a3030;
        color: #ff9999;
    }

    :deep(.password-content-card .mud-input-outlined)[b-ap595pvcz2] {
        border-color: #3a3a38;
        background: #1a1a18;
    }

    :deep(.password-content-card .mud-input-outlined:hover)[b-ap595pvcz2] {
        border-color: #8B5E3C;
    }
}
/* /Components/Pages/Legal.razor.rz.scp.css */
/* ── Hero banner ─────────────────────────────────────────────── */
.legal-page-hero[b-osn8vgd90a] {
    background: linear-gradient(135deg, #8B5E3C 0%, #C69C72 100%);
    padding: 3rem 1.5rem;
    text-align: center;
}

.legal-page-hero-inner[b-osn8vgd90a] {
    max-width: 800px;
    margin: 0 auto;
}

.legal-page-title[b-osn8vgd90a] {
    color: #fff;
    font-size: 2.25rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
}

.legal-page-subtitle[b-osn8vgd90a] {
    color: rgba(255, 255, 255, 0.85);
    font-size: 1rem;
    margin: 0;
}

/* ── Two-column layout ───────────────────────────────────────── */
.legal-page-layout[b-osn8vgd90a] {
    display: flex;
    align-items: flex-start;
    gap: 2rem;
    max-width: 1200px;
    margin: 2.5rem auto;
    padding: 0 1.5rem 3rem;
}

/* ── Sidebar TOC ─────────────────────────────────────────────── */
.legal-toc[b-osn8vgd90a] {
    flex: 0 0 220px;
    position: sticky;
    top: 80px;
}

.legal-toc-inner[b-osn8vgd90a] {
    background: #fff;
    border: 1px solid #e8ddd4;
    border-radius: 8px;
    padding: 1.25rem;
    box-shadow: 0 2px 8px rgba(139,94,60,0.08);
}

.legal-toc-heading[b-osn8vgd90a] {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #9e9e9e;
    margin: 0 0 0.75rem;
}

.legal-toc-link[b-osn8vgd90a] {
    display: block;
    padding: 0.45rem 0.5rem;
    font-size: 0.88rem;
    color: #5a3e28;
    text-decoration: none;
    border-left: 3px solid transparent;
    border-radius: 0 4px 4px 0;
    transition: background 0.15s, border-color 0.15s;
    margin-bottom: 0.1rem;
    cursor: pointer;
}

.legal-toc-link:hover[b-osn8vgd90a] {
    background: #fdf6f0;
    border-left-color: #C69C72;
    color: #8B5E3C;
}

.legal-toc-back[b-osn8vgd90a] {
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid #e8ddd4;
}

/* ── Main content card ───────────────────────────────────────── */
.legal-content-area[b-osn8vgd90a] {
    flex: 1;
    min-width: 0;
}

.legal-content-card[b-osn8vgd90a] {
    background: #fff;
    border: 1px solid #e8ddd4;
    border-radius: 10px;
    padding: 0.5rem 2rem 2rem;
    box-shadow: 0 2px 12px rgba(139,94,60,0.07);
}

/* ── Bottom back button ──────────────────────────────────────── */
.legal-page-actions[b-osn8vgd90a] {
    display: flex;
    justify-content: center;
    margin-top: 2rem;
}

/* ── Responsive: stack on small screens ─────────────────────── */
@media (max-width: 768px) {
    .legal-page-layout[b-osn8vgd90a] {
        flex-direction: column;
        padding: 0 1rem 2rem;
    }

    .legal-toc[b-osn8vgd90a] {
        flex: none;
        width: 100%;
        position: static;
    }

    .legal-toc-inner[b-osn8vgd90a] {
        display: flex;
        flex-wrap: wrap;
        gap: 0.25rem;
        align-items: center;
    }

    .legal-toc-heading[b-osn8vgd90a] {
        width: 100%;
        margin-bottom: 0.25rem;
    }

    .legal-toc-link[b-osn8vgd90a] {
        border-left: none;
        border-radius: 20px;
        padding: 0.3rem 0.75rem;
        background: #fdf6f0;
        border: 1px solid #e8ddd4;
        font-size: 0.82rem;
        white-space: nowrap;
    }

    .legal-toc-back[b-osn8vgd90a] {
        width: 100%;
        margin-top: 0.75rem;
        padding-top: 0.75rem;
    }

    .legal-content-card[b-osn8vgd90a] {
        padding: 0.5rem 1rem 1.5rem;
    }

    .legal-page-title[b-osn8vgd90a] {
        font-size: 1.75rem;
    }
}
/* /Components/Pages/Login.razor.rz.scp.css */
.auth-container[b-gpcjo7tp5z] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    background: linear-gradient(135deg, var(--surface-0) 0%, var(--surface-2) 100%);
}

.auth-card[b-gpcjo7tp5z] {
    background: var(--surface-1);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 2.5rem;
    width: 100%;
    max-width: 480px;
    border: 1px solid var(--ring);
}

.auth-header[b-gpcjo7tp5z] {
    text-align: center;
    margin-bottom: 2rem;
}

.auth-title[b-gpcjo7tp5z] {
    color: var(--gjs-t-color-primary);
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    font-family: "Poppins", sans-serif;
}

.auth-subtitle[b-gpcjo7tp5z] {
    color: var(--text-1);
    font-size: 1.1rem;
    margin: 0;
}

.auth-form[b-gpcjo7tp5z] {
    width: 100%;
}

.form-group[b-gpcjo7tp5z] {
    margin-bottom: 1.5rem;
}

.form-label[b-gpcjo7tp5z] {
    display: block;
    color: var(--text-0);
    font-weight: 600;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
}

.form-label-group[b-gpcjo7tp5z] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.form-link[b-gpcjo7tp5z] {
    color: var(--gjs-t-color-primary);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.85rem;
}

.form-link:hover[b-gpcjo7tp5z] {
    text-decoration: underline;
}

.form-input[b-gpcjo7tp5z] {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    background: var(--surface-1);
    color: var(--text-0);
    font-size: 1rem;
    transition: border-color 150ms ease, box-shadow 150ms ease;
}

.form-input:focus[b-gpcjo7tp5z] {
    outline: none;
    border-color: var(--gjs-t-color-primary);
    box-shadow: 0 0 0 3px rgba(139, 94, 60, 0.1);
}

.form-input[b-gpcjo7tp5z]::placeholder {
    color: var(--text-1);
    opacity: 0.7;
}

.validation-message[b-gpcjo7tp5z] {
    color: var(--gjs-t-color-error);
    font-size: 0.875rem;
    margin-top: 0.25rem;
    display: block;
}

.error-message[b-gpcjo7tp5z] {
    background: rgba(229, 115, 115, 0.1);
    color: var(--gjs-t-color-error);
    padding: 1rem;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(229, 115, 115, 0.3);
    margin-bottom: 1.5rem;
    text-align: center;
}

.success-message[b-gpcjo7tp5z] {
    background: rgba(92, 196, 124, 0.1);
    color: var(--gjs-t-color-success);
    padding: 1rem;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(92, 196, 124, 0.3);
    margin-bottom: 1.5rem;
    text-align: center;
}

.form-actions[b-gpcjo7tp5z] {
    text-align: center;
}

.form-actions.column[b-gpcjo7tp5z] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.auth-button[b-gpcjo7tp5z] {
    background: var(--gjs-t-color-primary);
    color: var(--text-inverse);
    border: none;
    padding: 0.9rem 2rem;
    border-radius: var(--radius-md);
    font-size: 1.05rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 150ms ease, transform 150ms ease;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 200px;
    justify-content: center;
}

.auth-button:hover:not(:disabled)[b-gpcjo7tp5z] {
    opacity: 0.9;
    transform: translateY(-1px);
}

.auth-button:disabled[b-gpcjo7tp5z] {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.loading-spinner[b-gpcjo7tp5z] {
    width: 1rem;
    height: 1rem;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin-b-gpcjo7tp5z 1s linear infinite;
}

.alt-route[b-gpcjo7tp5z] {
    color: var(--text-1);
    font-size: 0.9rem;
    margin: 0;
}

@keyframes spin-b-gpcjo7tp5z {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 640px) {
    .auth-card[b-gpcjo7tp5z] {
        padding: 2rem 1.5rem;
    }

    .auth-title[b-gpcjo7tp5z] {
        font-size: 1.75rem;
    }
}





/* /Components/Pages/Register.razor.rz.scp.css */
.register-container[b-5vy087l9un] {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    background: linear-gradient(135deg, var(--surface-0) 0%, var(--surface-2) 100%);
}

.register-card[b-5vy087l9un] {
    background: var(--surface-1);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 2.5rem;
    width: 100%;
    max-width: 1000px;
    border: 1px solid var(--ring);
}

.register-header[b-5vy087l9un] {
    text-align: center;
    margin-bottom: 2rem;
}

.register-title[b-5vy087l9un] {
    color: var(--gjs-t-color-primary);
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    font-family: "Poppins", sans-serif;
}

.register-subtitle[b-5vy087l9un] {
    color: var(--text-1);
    font-size: 1.1rem;
    margin: 0;
}

.form-grid[b-5vy087l9un] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2rem;
    margin-bottom: 2rem;
}

.compact-grid[b-5vy087l9un] {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: .75rem;
}

.form-section[b-5vy087l9un] {
    background: var(--surface-2);
    padding: 1.5rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--ring);
}

.section-title[b-5vy087l9un] {
    color: var(--gjs-t-color-primary);
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 1rem;
    font-family: "Poppins", sans-serif;
}

.section-subtitle[b-5vy087l9un] {
    color: var(--text-0);
    font-size: 1.05rem;
    font-weight: 600;
    margin: .25rem 0 1rem;
}

.rv-card[b-5vy087l9un], .insurance-card[b-5vy087l9un] {
    background: var(--surface-1);
    padding: 1rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--ring);
    margin-bottom: 1rem;
}

.form-group[b-5vy087l9un] {
    margin-bottom: 1rem;
}

.form-label[b-5vy087l9un] {
    color: var(--text-0);
    font-weight: 600;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
}

.form-input[b-5vy087l9un], .form-select[b-5vy087l9un], textarea.form-input[b-5vy087l9un] {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    background: var(--surface-1);
    color: var(--text-0);
    font-size: 1rem;
    transition: border-color 150ms ease, box-shadow 150ms ease;
}

.form-input:focus[b-5vy087l9un], .form-select:focus[b-5vy087l9un] {
    outline: none;
    border-color: var(--gjs-t-color-primary);
    box-shadow: 0 0 0 3px rgba(139,94,60,0.1);
}

.validation-message[b-5vy087l9un] {
    color: var(--gjs-t-color-error);
    font-size: 0.875rem;
    margin-top: 0.25rem;
}

.alert-error-capybara[b-5vy087l9un], .alert-success-capybara[b-5vy087l9un] {
    padding: 1rem;
    border-radius: var(--radius-sm);
    margin-bottom: 1rem;
    text-align: center;
}

.alert-error-capybara[b-5vy087l9un] {
    background: rgba(229,115,115,0.1);
    color: var(--gjs-t-color-error);
    border: 1px solid rgba(229,115,115,0.3);
}

.alert-success-capybara[b-5vy087l9un] {
    background: rgba(92,196,124,0.1);
    color: var(--gjs-t-color-success);
    border: 1px solid rgba(92,196,124,0.3);
}

.label-capybara[b-5vy087l9un] {
    color: var(--text-0);
    font-weight: 600;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
    display: block;
}

.input-capybara[b-5vy087l9un] {
    width: 100%;
}

.form-actions[b-5vy087l9un] {
    display: flex;
    justify-content: center;
    gap: .5rem;
}

.form-actions.right[b-5vy087l9un] {
    justify-content: flex-end;
}

.form-actions.column[b-5vy087l9un] {
    flex-direction: column;
}

.register-button[b-5vy087l9un] {
    background: var(--gjs-t-color-primary);
    color: var(--text-inverse);
    border: none;
    padding: 1rem 2rem;
    border-radius: var(--radius-md);
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 150ms ease, transform 150ms ease;
}

.register-button:hover:not(:disabled)[b-5vy087l9un] {
    opacity: 0.9;
    transform: translateY(-1px);
}

.loading-spinner[b-5vy087l9un] {
    width: 1rem;
    height: 1rem;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin-b-5vy087l9un 1s linear infinite;
    display: inline-block;
}

.select-loading[b-5vy087l9un] {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .75rem 1rem;
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    background: var(--surface-1);
    color: var(--text-1);
    font-size: .9rem;
}

.loading-text[b-5vy087l9un] {
    font-size: .9rem;
    color: var(--text-1);
}

@keyframes spin-b-5vy087l9un {
    to {
        transform: rotate(360deg);
    }
}

.login-link[b-5vy087l9un] {
    color: var(--text-1);
    font-size: 0.9rem;
}


.login-link-text[b-5vy087l9un] {
    color: var(--gjs-t-color-primary);
    text-decoration: none;
    font-weight: 600;
    margin-left: 0.25rem;
}

.login-link-text:hover[b-5vy087l9un] {
    text-decoration: underline;
}

@media (max-width: 768px) {
    .register-container[b-5vy087l9un] {
        padding: 1rem;
    }

    .register-card[b-5vy087l9un] {
        padding: 1.5rem;
    }

    .form-grid[b-5vy087l9un] {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }
}
/* /Components/Pages/ResetPassword.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════
   RESET PASSWORD PAGE - Styles
   ═══════════════════════════════════════════════════════════════ */

/* ── Hero Banner ─────────────────────────────────────────────── */
.password-page-hero[b-ap24cqjfjx] {
    background: linear-gradient(135deg, #8B5E3C 0%, #C69C72 100%);
    padding: 3rem 1.5rem 2.5rem;
    text-align: center;
}

.password-page-hero-inner[b-ap24cqjfjx] {
    max-width: 600px;
    margin: 0 auto;
}

.password-page-title[b-ap24cqjfjx] {
    color: #fff;
    font-size: 2rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
    letter-spacing: -0.5px;
}

.password-page-subtitle[b-ap24cqjfjx] {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.95rem;
    margin: 0;
    font-weight: 400;
}

/* ── Main Layout ─────────────────────────────────────────────── */
.password-page-layout[b-ap24cqjfjx] {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    min-height: calc(100vh - 200px);
    padding: 2.5rem 1.5rem 3rem;
    background: #fafaf8;
}

.password-content-card[b-ap24cqjfjx] {
    width: 100%;
    max-width: 420px;
    background: #fff;
    border: 1px solid #e8ddd4;
    border-radius: 12px;
    box-shadow: 0 4px 16px rgba(139, 94, 60, 0.08);
    overflow: hidden;
}

.password-content-inner[b-ap24cqjfjx] {
    padding: 2.5rem 2rem;
}

/* ── Form Wrapper ────────────────────────────────────────────── */
.password-form-wrapper[b-ap24cqjfjx] {
    animation: fadeIn-b-ap24cqjfjx 0.3s ease-in-out;
}

@keyframes fadeIn-b-ap24cqjfjx {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.password-intro-text[b-ap24cqjfjx] {
    font-size: 0.9rem;
    color: #666;
    line-height: 1.5;
    margin: 0 0 1.5rem;
    text-align: center;
}

/* ── Form Group ──────────────────────────────────────────────── */
.password-form-group[b-ap24cqjfjx] {
    margin-bottom: 1.25rem;
}

.password-label[b-ap24cqjfjx] {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: #5a3e28;
    margin-bottom: 0.5rem;
    letter-spacing: 0.3px;
}

/* ── Form Actions ────────────────────────────────────────────── */
.password-form-actions[b-ap24cqjfjx] {
    margin-top: 2rem;
    margin-bottom: 1rem;
}

:deep(.password-form-actions .mud-button)[b-ap24cqjfjx] {
    height: 44px;
    font-weight: 600;
    font-size: 0.95rem;
    border-radius: 8px;
    text-transform: none;
}

:deep(.password-form-actions .mud-button-filled-primary)[b-ap24cqjfjx] {
    background: linear-gradient(135deg, #C69C72 0%, #8B5E3C 100%);
}

:deep(.password-form-actions .mud-button-filled-primary:hover)[b-ap24cqjfjx] {
    background: linear-gradient(135deg, #8B5E3C 0%, #6d4524 100%);
    box-shadow: 0 4px 12px rgba(139, 94, 60, 0.2);
}

/* ── Form Help Text ──────────────────────────────────────────── */
.password-form-help[b-ap24cqjfjx] {
    text-align: center;
    padding-top: 0.75rem;
    border-top: 1px solid #e8ddd4;
}

.password-form-help p[b-ap24cqjfjx] {
    font-size: 0.85rem;
    color: #999;
    margin: 0.75rem 0 0;
}

.password-link[b-ap24cqjfjx] {
    color: #8B5E3C;
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
    cursor: pointer;
}

.password-link:hover[b-ap24cqjfjx] {
    color: #C69C72;
    text-decoration: underline;
}

/* ── Alert Messages ──────────────────────────────────────────── */
.password-alert-error[b-ap24cqjfjx] {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.95rem 1rem;
    background: #fff5f5;
    border: 1px solid #f5d7d7;
    border-radius: 8px;
    margin-bottom: 1.5rem;
    font-size: 0.9rem;
    color: #c1271b;
    animation: slideDown-b-ap24cqjfjx 0.3s ease-out;
}

@keyframes slideDown-b-ap24cqjfjx {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.password-alert-error .error-icon[b-ap24cqjfjx] {
    flex-shrink: 0;
    font-size: 1.1rem;
    line-height: 1;
}

/* ── Success Box ─────────────────────────────────────────────── */
.password-success-box[b-ap24cqjfjx] {
    text-align: center;
    animation: fadeIn-b-ap24cqjfjx 0.4s ease-out;
}

.success-icon[b-ap24cqjfjx] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background: #e8f5e9;
    border-radius: 50%;
    font-size: 2rem;
    color: #4caf50;
    margin-bottom: 1rem;
}

.success-title[b-ap24cqjfjx] {
    font-size: 1.5rem;
    font-weight: 700;
    color: #2e7d32;
    margin: 0 0 0.75rem;
}

.success-message[b-ap24cqjfjx] {
    font-size: 0.9rem;
    color: #666;
    line-height: 1.6;
    margin: 0 0 1.5rem;
}

:deep(.password-success-box .mud-button)[b-ap24cqjfjx] {
    height: 44px;
    font-weight: 600;
    font-size: 0.95rem;
    border-radius: 8px;
    text-transform: none;
    margin-top: 0.5rem;
}

:deep(.password-success-box .mud-button-filled-primary)[b-ap24cqjfjx] {
    background: linear-gradient(135deg, #C69C72 0%, #8B5E3C 100%);
}

/* ── Error Box ───────────────────────────────────────────────── */
.password-error-box[b-ap24cqjfjx] {
    text-align: center;
    animation: fadeIn-b-ap24cqjfjx 0.4s ease-out;
}

.error-icon-large[b-ap24cqjfjx] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background: #ffebee;
    border-radius: 50%;
    font-size: 2rem;
    color: #f44336;
    margin-bottom: 1rem;
}

.error-title[b-ap24cqjfjx] {
    font-size: 1.5rem;
    font-weight: 700;
    color: #c62828;
    margin: 0 0 0.75rem;
}

.error-message[b-ap24cqjfjx] {
    font-size: 0.9rem;
    color: #666;
    line-height: 1.6;
    margin: 0 0 1.5rem;
}

:deep(.password-error-box .mud-button)[b-ap24cqjfjx] {
    height: 44px;
    font-weight: 600;
    font-size: 0.95rem;
    border-radius: 8px;
    text-transform: none;
    margin-top: 0.5rem;
}

:deep(.password-error-box .mud-button-filled-primary)[b-ap24cqjfjx] {
    background: linear-gradient(135deg, #C69C72 0%, #8B5E3C 100%);
}

/* ── Text Field Customization ────────────────────────────────── */
:deep(.password-content-card .mud-input-control)[b-ap24cqjfjx] {
    margin: 0;
}

:deep(.password-content-card .mud-input-outlined)[b-ap24cqjfjx] {
    border-color: #e8ddd4;
}

:deep(.password-content-card .mud-input-outlined:hover)[b-ap24cqjfjx] {
    border-color: #C69C72;
}

:deep(.password-content-card .mud-input-outlined.mud-focused)[b-ap24cqjfjx] {
    border-color: #8B5E3C;
}

:deep(.password-content-card .mud-input-outlined input)[b-ap24cqjfjx] {
    font-size: 0.95rem;
}

/* ── Responsive Design ───────────────────────────────────────── */
@media (max-width: 480px) {
    .password-page-hero[b-ap24cqjfjx] {
        padding: 2.5rem 1rem 2rem;
    }

    .password-page-title[b-ap24cqjfjx] {
        font-size: 1.65rem;
    }

    .password-page-subtitle[b-ap24cqjfjx] {
        font-size: 0.9rem;
    }

    .password-page-layout[b-ap24cqjfjx] {
        padding: 1.5rem 1rem 2rem;
        min-height: auto;
    }

    .password-content-card[b-ap24cqjfjx] {
        max-width: 100%;
        border-radius: 8px;
    }

    .password-content-inner[b-ap24cqjfjx] {
        padding: 1.75rem 1.25rem;
    }

    .password-form-group[b-ap24cqjfjx] {
        margin-bottom: 1rem;
    }

    .password-intro-text[b-ap24cqjfjx] {
        font-size: 0.85rem;
        margin-bottom: 1.25rem;
    }

    .password-label[b-ap24cqjfjx] {
        font-size: 0.8rem;
    }

    :deep(.password-form-actions .mud-button)[b-ap24cqjfjx] {
        height: 40px;
        font-size: 0.9rem;
    }

    .success-icon[b-ap24cqjfjx],
    .error-icon-large[b-ap24cqjfjx] {
        width: 50px;
        height: 50px;
        font-size: 1.75rem;
    }

    .success-title[b-ap24cqjfjx],
    .error-title[b-ap24cqjfjx] {
        font-size: 1.25rem;
    }
}

@media (max-width: 360px) {
    .password-page-title[b-ap24cqjfjx] {
        font-size: 1.5rem;
    }

    .password-content-inner[b-ap24cqjfjx] {
        padding: 1.5rem 1rem;
    }

    .password-intro-text[b-ap24cqjfjx] {
        font-size: 0.8rem;
    }
}

/* ── Dark Mode Support ──────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
    .password-page-layout[b-ap24cqjfjx] {
        background: #1a1a18;
    }

    .password-content-card[b-ap24cqjfjx] {
        background: #2a2a28;
        border-color: #3a3a38;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
    }

    .password-label[b-ap24cqjfjx] {
        color: #d4af9d;
    }

    .password-intro-text[b-ap24cqjfjx],
    .success-message[b-ap24cqjfjx],
    .error-message[b-ap24cqjfjx],
    .password-form-help p[b-ap24cqjfjx] {
        color: #bbb;
    }

    .password-link[b-ap24cqjfjx] {
        color: #d4af9d;
    }

    .password-link:hover[b-ap24cqjfjx] {
        color: #e8ddd4;
    }

    .password-form-help[b-ap24cqjfjx] {
        border-top-color: #3a3a38;
    }

    .password-alert-error[b-ap24cqjfjx] {
        background: #3a2020;
        border-color: #5a3030;
        color: #ff9999;
    }

    :deep(.password-content-card .mud-input-outlined)[b-ap24cqjfjx] {
        border-color: #3a3a38;
        background: #1a1a18;
    }

    :deep(.password-content-card .mud-input-outlined:hover)[b-ap24cqjfjx] {
        border-color: #8B5E3C;
    }
}
/* /Components/Pages/ResortDetails.razor.rz.scp.css */
.resort-details-container[b-sk35etncg0] {
    padding: 2rem;
    max-width: 1200px;
    margin: 0 auto;
}

.back-button[b-sk35etncg0] {
    margin-bottom: 2rem;
    display: flex;
    gap: 1rem;
}

.resort-details-grid[b-sk35etncg0] {
    margin-top: 2rem;
}

.resort-header-card[b-sk35etncg0] {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
}

.resort-header[b-sk35etncg0] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 2rem;
    flex-wrap: wrap;
}

.resort-title[b-sk35etncg0] {
    font-size: 2rem;
    font-weight: 700;
    margin: 0 0 1rem 0;
}

.resort-location[b-sk35etncg0] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.1rem;
}

.resort-badges[b-sk35etncg0] {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.contact-item[b-sk35etncg0] {
    margin-bottom: 1rem;
}

.contact-item strong[b-sk35etncg0] {
    display: block;
    margin-bottom: 0.25rem;
    color: #333;
}

.contact-item a[b-sk35etncg0] {
    color: #1976d2;
    text-decoration: none;
}

.contact-item a:hover[b-sk35etncg0] {
    text-decoration: underline;
}

.amenities-grid[b-sk35etncg0] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.loading-container[b-sk35etncg0] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    gap: 1rem;
}

@media (max-width: 768px) {
    .resort-header[b-sk35etncg0] {
        flex-direction: column;
    }

    .resort-title[b-sk35etncg0] {
        font-size: 1.5rem;
    }

    .resort-badges[b-sk35etncg0] {
        width: 100%;
    }
}
/* /Components/Pages/Resorts.razor.rz.scp.css */
.resorts-container[b-50o96m46jz] {
    padding: 2rem;
    max-width: 1400px;
    margin: 0 auto;
}

.resorts-header[b-50o96m46jz] {
    margin-bottom: 2rem;
    text-align: center;
}

.resorts-header h1[b-50o96m46jz] {
    font-size: 2.5rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.subtitle[b-50o96m46jz] {
    font-size: 1.1rem;
    color: #666;
}

.resorts-controls[b-50o96m46jz] {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 2rem;
    align-items: center;
}

.search-field[b-50o96m46jz] {
    flex: 1;
    min-width: 250px;
}

.filter-checkbox[b-50o96m46jz] {
    white-space: nowrap;
}

.resorts-grid[b-50o96m46jz] {
    margin-top: 2rem;
}

.resort-card[b-50o96m46jz] {
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.resort-card:hover[b-50o96m46jz] {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.resort-card-content[b-50o96m46jz] {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.resort-card-header[b-50o96m46jz] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1rem;
}

.resort-name[b-50o96m46jz] {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
    flex-grow: 1;
}

.resort-card-details[b-50o96m46jz] {
    flex-grow: 1;
}

.detail-item[b-50o96m46jz] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    font-size: 0.95rem;
    color: #555;
}

.loading-container[b-50o96m46jz] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    gap: 1rem;
}

@media (max-width: 768px) {
    .resorts-controls[b-50o96m46jz] {
        flex-direction: column;
    }

    .search-field[b-50o96m46jz] {
        width: 100%;
        min-width: unset;
    }

    .resorts-header h1[b-50o96m46jz] {
        font-size: 1.75rem;
    }
}
/* /Components/Pages/Rules.razor.rz.scp.css */
/* ── Hero banner ─────────────────────────────────────────────── */
.rules-page-hero[b-wl94d7nu2d] {
    background: linear-gradient(135deg, #8B5E3C 0%, #C69C72 100%);
    padding: 3rem 1.5rem;
    text-align: center;
}

.rules-page-hero-inner[b-wl94d7nu2d] {
    max-width: 800px;
    margin: 0 auto;
}

.rules-page-title[b-wl94d7nu2d] {
    color: #fff;
    font-size: 2.25rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
}

.rules-page-subtitle[b-wl94d7nu2d] {
    color: rgba(255, 255, 255, 0.85);
    font-size: 1rem;
    margin: 0;
}

/* ── Two-column layout ───────────────────────────────────────── */
.rules-page-layout[b-wl94d7nu2d] {
    display: flex;
    align-items: flex-start;
    gap: 2rem;
    max-width: 1200px;
    margin: 2.5rem auto;
    padding: 0 1.5rem 3rem;
}

/* ── Sidebar TOC ─────────────────────────────────────────────── */
.rules-toc[b-wl94d7nu2d] {
    flex: 0 0 220px;
    position: sticky;
    top: 80px;
}

.rules-toc-inner[b-wl94d7nu2d] {
    background: #fff;
    border: 1px solid #e8ddd4;
    border-radius: 8px;
    padding: 1.25rem;
    box-shadow: 0 2px 8px rgba(139,94,60,0.08);
}

.rules-toc-heading[b-wl94d7nu2d] {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #9e9e9e;
    margin: 0 0 0.75rem;
}

.rules-toc-link[b-wl94d7nu2d] {
    display: block;
    padding: 0.45rem 0.5rem;
    font-size: 0.88rem;
    color: #5a3e28;
    text-decoration: none;
    border-left: 3px solid transparent;
    border-radius: 0 4px 4px 0;
    transition: background 0.15s, border-color 0.15s;
    margin-bottom: 0.1rem;
    cursor: pointer;
}

.rules-toc-link:hover[b-wl94d7nu2d] {
    background: #fdf6f0;
    border-left-color: #C69C72;
    color: #8B5E3C;
}

/* ── Main content area ───────────────────────────────────────── */
.rules-content-area[b-wl94d7nu2d] {
    flex: 1;
    min-width: 0;
}

.rules-content-card[b-wl94d7nu2d] {
    background: #fff;
    border: 1px solid #e8ddd4;
    border-radius: 10px;
    padding: 0.5rem 2rem 2rem;
    box-shadow: 0 2px 12px rgba(139,94,60,0.07);
    max-height: 600px;
    overflow-y: auto;
}

.rules-content-card[b-wl94d7nu2d]::-webkit-scrollbar {
    width: 8px;
}

.rules-content-card[b-wl94d7nu2d]::-webkit-scrollbar-track {
    background: #f5f5f5;
    border-radius: 10px;
}

.rules-content-card[b-wl94d7nu2d]::-webkit-scrollbar-thumb {
    background: #C69C72;
    border-radius: 10px;
}

.rules-content-card[b-wl94d7nu2d]::-webkit-scrollbar-thumb:hover {
    background: #8B5E3C;
}

/* ── Agree section ───────────────────────────────────────────── */
.rules-agree-section[b-wl94d7nu2d] {
    margin-top: 1.5rem;
    background: #fff;
    border: 1px solid #e8ddd4;
    border-radius: 10px;
    padding: 1.5rem 2rem;
    box-shadow: 0 2px 8px rgba(139,94,60,0.07);
}

.rules-agree-row[b-wl94d7nu2d] {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #5a3e28;
    font-size: 0.95rem;
    margin-bottom: 1.25rem;
}

.rules-agree-actions[b-wl94d7nu2d] {
    display: flex;
    justify-content: center;
}

.rules-agree-button[b-wl94d7nu2d] {
    min-width: 220px;
}

/* ── Error message ───────────────────────────────────────────── */
.rules-error-message[b-wl94d7nu2d] {
    background: rgba(229, 115, 115, 0.1);
    color: #E57373;
    padding: 1rem;
    border-radius: 6px;
    border: 1px solid rgba(229, 115, 115, 0.3);
    margin-top: 1rem;
    text-align: center;
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 768px) {
    .rules-page-layout[b-wl94d7nu2d] {
        flex-direction: column;
        padding: 0 1rem 2rem;
    }

    .rules-toc[b-wl94d7nu2d] {
        flex: none;
        width: 100%;
        position: static;
    }

    .rules-toc-inner[b-wl94d7nu2d] {
        display: flex;
        flex-wrap: wrap;
        gap: 0.25rem;
        align-items: center;
    }

    .rules-toc-heading[b-wl94d7nu2d] {
        width: 100%;
        margin-bottom: 0.25rem;
    }

    .rules-toc-link[b-wl94d7nu2d] {
        border-left: none;
        border-radius: 20px;
        padding: 0.3rem 0.75rem;
        background: #fdf6f0;
        border: 1px solid #e8ddd4;
        font-size: 0.82rem;
        white-space: nowrap;
    }

    .rules-content-card[b-wl94d7nu2d] {
        padding: 0.5rem 1rem 1.5rem;
        max-height: 400px;
    }

    .rules-page-title[b-wl94d7nu2d] {
        font-size: 1.75rem;
    }

    .rules-agree-section[b-wl94d7nu2d] {
        padding: 1.25rem 1rem;
    }
}
/* /Components/Pages/User.razor.rz.scp.css */
.profile-container[b-lf10q3qoer] {
    min-height: 100vh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 2.5rem 1rem 3rem;
    background: linear-gradient(135deg, var(--surface-0) 0%, var(--surface-2) 100%);
}

.profile-card[b-lf10q3qoer] {
    background: var(--surface-1);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 2.75rem;
    width: 100%;
    max-width: 1024px;
    border: 1px solid var(--ring);
}

.profile-header[b-lf10q3qoer] {
    text-align: center;
    margin-bottom: 2.5rem;
}

.profile-title[b-lf10q3qoer] {
    color: var(--gjs-t-color-primary);
    font-size: 2.25rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    font-family: "Poppins", sans-serif;
}

.profile-subtitle[b-lf10q3qoer] {
    color: var(--text-1);
    font-size: 1rem;
    margin: 0;
}

.section-subtitle[b-lf10q3qoer] {
    color: var(--text-1);
    font-size: 0.95rem;
    margin: -0.5rem 0 1.25rem;
}

.profile-section[b-lf10q3qoer] {
    background: var(--surface-2);
    border-radius: var(--radius-md);
    border: 1px solid var(--ring);
    padding: 1.75rem 1.5rem;
    margin-bottom: 1.75rem;
}

.profile-section.accent[b-lf10q3qoer] {
    background: var(--surface-1);
    border: 1px solid rgba(139, 94, 60, 0.35);
}

.dashboard-section[b-lf10q3qoer] {
    background: linear-gradient(135deg, rgba(139, 94, 60, 0.08), rgba(139, 94, 60, 0.02));
    border: 1px solid rgba(139, 94, 60, 0.25);
}

.dashboard-grid[b-lf10q3qoer] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
}

.dashboard-card[b-lf10q3qoer] {
    background: var(--surface-1);
    border-radius: var(--radius-md);
    border: 1px solid var(--ring);
    padding: 1.4rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    box-shadow: var(--shadow-sm, 0 10px 24px rgba(0, 0, 0, 0.08));
}

.dashboard-card-header[b-lf10q3qoer] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.dashboard-card-header h3[b-lf10q3qoer] {
    margin: 0;
    font-size: 1.1rem;
    color: var(--text-0);
}

.dashboard-icon[b-lf10q3qoer] {
    width: 28px;
    height: 28px;
    color: var(--gjs-t-color-primary);
}

.dashboard-card p[b-lf10q3qoer] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.95rem;
}

.dashboard-button[b-lf10q3qoer] {
    align-self: flex-start;
}

.section-header[b-lf10q3qoer] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
}

.form-grid[b-lf10q3qoer] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem 1.25rem;
    margin-bottom: 1rem;
}

.form-group[b-lf10q3qoer] {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.form-label[b-lf10q3qoer] {
    color: var(--text-1);
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.form-input[b-lf10q3qoer],
.form-select[b-lf10q3qoer],
.form-grid .form-input[b-lf10q3qoer],
.form-grid .form-select[b-lf10q3qoer],
.form-grid textarea.form-input[b-lf10q3qoer] {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    background: var(--surface-1);
    color: var(--text-0);
    font-size: 1rem;
    transition: border-color 150ms ease, box-shadow 150ms ease;
}

.form-input:focus[b-lf10q3qoer],
.form-select:focus[b-lf10q3qoer],
.form-grid .form-input:focus[b-lf10q3qoer],
.form-grid .form-select:focus[b-lf10q3qoer],
.form-grid textarea.form-input:focus[b-lf10q3qoer] {
    outline: none;
    border-color: var(--gjs-t-color-primary);
    box-shadow: 0 0 0 3px rgba(139, 94, 60, 0.1);
}

.form-select[b-lf10q3qoer] {
    appearance: none;
    background-image: url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23626262' d='M6 8 0 0h12z'/%3E%3C/svg%3E\");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 0.6rem;
}

.card-actions[b-lf10q3qoer] {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.75rem;
    margin: 1rem 0;
}

.text-button[b-lf10q3qoer] {
    border: none;
    background: transparent;
    color: var(--gjs-t-color-primary);
    font-weight: 600;
    cursor: pointer;
    padding: 0;
}

.text-button:hover[b-lf10q3qoer] {
    text-decoration: underline;
}

.section-title[b-lf10q3qoer] {
    color: var(--gjs-t-color-primary);
    font-size: 1.35rem;
    font-weight: 600;
    margin-bottom: 1.25rem;
    font-family: "Poppins", sans-serif;
}

.profile-grid[b-lf10q3qoer] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem 1.5rem;
    margin: 0;
}

.profile-item[b-lf10q3qoer] {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.profile-item dt[b-lf10q3qoer] {
    color: var(--text-1);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0;
}

.profile-item dd[b-lf10q3qoer] {
    color: var(--text-0);
    font-size: 1.05rem;
    margin: 0;
    word-break: break-word;
}

.action-grid[b-lf10q3qoer] {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.action-card[b-lf10q3qoer] {
    background: var(--surface-1);
    border-radius: var(--radius-md);
    border: 1px solid var(--ring);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    box-shadow: var(--shadow-sm, 0 8px 20px rgba(0, 0, 0, 0.08));
}

.action-card h3[b-lf10q3qoer] {
    margin: 0;
    font-size: 1.15rem;
    color: var(--text-0);
}

.action-card p[b-lf10q3qoer] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.95rem;
    flex: 1;
}

.secondary-cta-button[b-lf10q3qoer] {
    align-self: flex-start;
}

.empty-state[b-lf10q3qoer] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.95rem;
}

.empty-state.compact[b-lf10q3qoer] {
    font-size: 0.85rem;
}

.rv-grid[b-lf10q3qoer] {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.rv-card[b-lf10q3qoer] {
    background: var(--surface-1);
    border-radius: var(--radius-md);
    border: 1px solid var(--ring);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.rv-card-header[b-lf10q3qoer] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.rv-card-header h3[b-lf10q3qoer] {
    margin: 0;
    font-size: 1.2rem;
    color: var(--text-0);
}

.rv-tag[b-lf10q3qoer] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    background: rgba(139, 94, 60, 0.12);
    border: 1px solid rgba(139, 94, 60, 0.3);
    color: var(--gjs-t-color-primary);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
}

.rv-details[b-lf10q3qoer] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.75rem 1rem;
    margin: 0;
}

.rv-details dt[b-lf10q3qoer] {
    color: var(--text-1);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin: 0;
}

.rv-details dd[b-lf10q3qoer] {
    color: var(--text-0);
    font-size: 0.95rem;
    margin: 0;
}

.rv-subtitle[b-lf10q3qoer] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.95rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.insurance-list[b-lf10q3qoer],
.insurance-editor-list[b-lf10q3qoer] {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.insurance-editor-list li[b-lf10q3qoer] {
    padding: 1rem 1.1rem;
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    background: var(--surface-1);
}

.insurance-line[b-lf10q3qoer] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    color: var(--text-0);
}

.insurance-line span[b-lf10q3qoer] {
    color: var(--text-1);
    font-size: 0.9rem;
}

.insurance-meta[b-lf10q3qoer] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    color: var(--text-1);
    font-size: 0.85rem;
}

.insurance-notes[b-lf10q3qoer] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.9rem;
}

.membership-list[b-lf10q3qoer] {
    display: grid;
    gap: 1.1rem;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.membership-card[b-lf10q3qoer] {
    background: var(--surface-1);
    border-radius: var(--radius-md);
    border: 1px solid var(--ring);
    padding: 1.25rem 1.4rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.membership-card-header[b-lf10q3qoer] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.membership-card-header h3[b-lf10q3qoer] {
    margin: 0;
    color: var(--text-0);
    font-size: 1.1rem;
}

.membership-id[b-lf10q3qoer] {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-1);
}

.membership-description[b-lf10q3qoer] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.9rem;
}

.membership-meta[b-lf10q3qoer] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    color: var(--text-1);
    font-size: 0.85rem;
    flex-wrap: wrap;
}

.transaction-table[b-lf10q3qoer] {
    border: 1px solid var(--ring);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.transaction-header[b-lf10q3qoer],
.transaction-row[b-lf10q3qoer] {
    display: grid;
    grid-template-columns: 1.3fr 1.4fr 1fr 1.1fr 1fr;
    gap: 0.5rem;
    padding: 0.85rem 1.1rem;
    font-size: 0.9rem;
}

.transaction-header[b-lf10q3qoer] {
    background: rgba(139, 94, 60, 0.12);
    color: var(--gjs-t-color-primary);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.transaction-row[b-lf10q3qoer] {
    background: var(--surface-1);
    color: var(--text-0);
    border-top: 1px solid var(--ring);
}

.profile-status[b-lf10q3qoer] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    padding: 3rem 1rem;
    text-align: center;
    color: var(--text-0);
}

.loading-spinner[b-lf10q3qoer] {
    width: 1rem;
    height: 1rem;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin-b-lf10q3qoer 1s linear infinite;
}

.loading-spinner.large[b-lf10q3qoer] {
    width: 1.75rem;
    height: 1.75rem;
    border-width: 3px;
}

.success-message[b-lf10q3qoer] {
    background: rgba(92, 196, 124, 0.1);
    color: var(--gjs-t-color-success);
    padding: 1rem 1.25rem;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(92, 196, 124, 0.3);
    margin-bottom: 1.5rem;
    text-align: center;
}

.info-message[b-lf10q3qoer] {
    background: rgba(139, 94, 60, 0.1);
    color: var(--text-0);
    padding: 1rem 1.25rem;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(139, 94, 60, 0.25);
    margin-bottom: 1.5rem;
}

.info-message.compact[b-lf10q3qoer] {
    margin-top: 1rem;
    margin-bottom: 0;
    text-align: center;
}

.status-actions[b-lf10q3qoer] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.75rem;
}

.form-link[b-lf10q3qoer] {
    color: var(--gjs-t-color-primary);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
}

.form-link:hover[b-lf10q3qoer] {
    text-decoration: underline;
}

.link-button[b-lf10q3qoer] {
    border: none;
    background: transparent;
    color: var(--gjs-t-color-primary);
    font-weight: 600;
    cursor: pointer;
    padding: 0;
}

.link-button:hover[b-lf10q3qoer] {
    text-decoration: underline;
}

.modal-backdrop[b-lf10q3qoer] {
    position: fixed;
    inset: 0;
    background: rgba(13, 14, 16, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    z-index: 1000;
}

.modal-panel[b-lf10q3qoer] {
    background: var(--surface-1);
    border-radius: var(--radius-lg);
    border: 1px solid var(--ring);
    padding: 2rem;
    width: min(500px, 100%);
    color: var(--text-0);
    box-shadow: var(--shadow);
}

.modal-panel.modal-scroll[b-lf10q3qoer] {
    max-height: min(80vh, 640px);
    overflow-y: auto;
}

.modal-panel h3[b-lf10q3qoer] {
    margin-top: 0;
    margin-bottom: 0.75rem;
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--text-0);
}

.modal-panel p[b-lf10q3qoer] {
    margin-top: 0;
    margin-bottom: 1rem;
    color: var(--text-1);
    font-size: 0.95rem;
}

.modal-list[b-lf10q3qoer] {
    margin: 0 0 1.5rem 1.25rem;
    padding: 0;
    color: var(--text-1);
    font-size: 0.95rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.modal-actions[b-lf10q3qoer] {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    margin-top: 1.5rem;
}

.plan-grid[b-lf10q3qoer] {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.plan-card[b-lf10q3qoer] {
    border: 1px solid var(--ring);
    border-radius: var(--radius-md);
    padding: 1.25rem 1.4rem;
    background: var(--surface-1);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    box-shadow: var(--shadow-sm, 0 8px 18px rgba(13, 14, 16, 0.08));
}

.plan-card-current[b-lf10q3qoer] {
    border-color: rgba(92, 196, 124, 0.6);
    box-shadow: 0 12px 26px rgba(92, 196, 124, 0.18);
}

.plan-card-header[b-lf10q3qoer] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.plan-card-header h4[b-lf10q3qoer] {
    margin: 0;
    font-size: 1.1rem;
    color: var(--text-0);
}

.plan-tag[b-lf10q3qoer] {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    background: rgba(92, 196, 124, 0.18);
    color: var(--gjs-t-color-success);
    border: 1px solid rgba(92, 196, 124, 0.3);
}

.plan-price[b-lf10q3qoer] {
    margin: 0;
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--text-0);
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
}

.plan-price-period[b-lf10q3qoer] {
    font-size: 0.85rem;
    color: var(--text-1);
}

.plan-description[b-lf10q3qoer] {
    margin: 0;
    color: var(--text-1);
    font-size: 0.9rem;
    flex: 1;
}

@keyframes spin-b-lf10q3qoer {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 920px) {
    .profile-card[b-lf10q3qoer] {
        padding: 2.25rem 1.75rem;
    }
}

@media (max-width: 640px) {
    .profile-card[b-lf10q3qoer] {
        padding: 2rem 1.25rem;
    }

    .profile-title[b-lf10q3qoer] {
        font-size: 1.85rem;
    }

    .profile-section[b-lf10q3qoer] {
        padding: 1.35rem 1.1rem;
    }

    .transaction-header[b-lf10q3qoer],
    .transaction-row[b-lf10q3qoer] {
        grid-template-columns: 1.2fr 1.2fr 0.9fr 0.9fr 0.8fr;
        font-size: 0.8rem;
        padding: 0.75rem 0.85rem;
    }

    .modal-panel[b-lf10q3qoer] {
        padding: 1.5rem 1.25rem;
    }
}





