/* ============================================================
   revyfy-modern.css
   Modern UI override layer — loaded after rev.css and webflow.css.
   Do NOT edit rev.css or webflow.css directly.
   All overrides use existing HTML class selectors.
   ============================================================ */


/* ============================================================
   1. CSS CUSTOM PROPERTIES
   ============================================================ */
:root {
    --rev-brand:        #b9006a;
    --rev-accent:       #e60e89;
    --rev-dark:         #232323;
    --rev-body:         #383838;
    --rev-surface-1:    #1f2232;
    --rev-surface-2:    #212332;
    --rev-surface-3:    #2a2d3f;
    --rev-border:       rgba(255, 255, 255, 0.07);
    --rev-border-strong: rgba(255, 255, 255, 0.12);
    --rev-text:         #ebedf0;
    --rev-text-muted:   #888ba0;
    --rev-radius-sm:    6px;
    --rev-radius-md:    10px;
    --rev-radius-lg:    14px;
    --rev-shadow-card:  0 2px 8px rgba(0, 0, 0, 0.35), 0 1px 2px rgba(0, 0, 0, 0.2);
    --rev-shadow-hover: 0 4px 16px rgba(0, 0, 0, 0.5);
    --rev-transition:   150ms cubic-bezier(0.4, 0, 0.2, 1);
}


/* ============================================================
   2. APP CHROME — TOPBAR RAIL & SIDEBAR PANEL
   ============================================================ */

/* Topbar rail */
.app-nav-layout {
    background-color: var(--rev-surface-1) !important;
    border-bottom: 2px solid var(--rev-accent) !important;
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.45) !important;
}

/* Sidebar panel */
.sidebar-navbar-menu {
    background-color: var(--rev-surface-1) !important;
    border-right: none !important;
    box-shadow: 2px 0 20px rgba(0, 0, 0, 0.35);
}

/* Accent gradient line on right edge of sidebar (desktop) */
.sidebar-navbar-menu::after {
    content: '';
    position: fixed;
    left: 260px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, var(--rev-accent) 0%, var(--rev-brand) 100%);
    pointer-events: none;
    z-index: 100;
}

/* Sidebar heading / logo area */
.sidebar-navbar-heading {
    background-color: var(--rev-surface-1) !important;
    border-bottom: none !important;
}

/* Sidebar body */
.sidebar-navbar-body {
    border-right: none !important;
    padding-top: 12px;
    padding-bottom: 12px;
}

/* Sidebar body container */
.sidebar-navbar-body-container {
    border-right: none !important;
}

/* Sidebar footer */
.sidebar-navbar-footer {
    border-right: none !important;
    border-top: 1px solid var(--rev-border) !important;
    padding-top: 8px;
    padding-bottom: 8px;
}


/* ============================================================
   3. SIDEBAR NAV LINKS
   ============================================================ */

/* Remove ALL PNG background images from sidebar links */
.sidebar-navbar-link,
.sidebar-navbar-link[class*="link-"] {
    background-image: none !important;
    position: relative;
    padding-left: 52px !important;
    padding-right: 16px !important;
    min-height: 44px;
    height: auto !important;
    display: flex !important;
    align-items: center;
    border-radius: 0 var(--rev-radius-md) var(--rev-radius-md) 0;
    margin-right: 12px;
    font-family: 'DM Sans', 'Gill Sans', sans-serif;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.2px;
    color: var(--rev-text-muted) !important;
    transition: background-color var(--rev-transition), color var(--rev-transition);
    margin-top: 2px;
    margin-bottom: 2px;
}

/* Hover state */
.sidebar-navbar-link:hover {
    background-color: rgba(255, 255, 255, 0.06) !important;
    color: var(--rev-text) !important;
}

/* Active state */
.sidebar-navbar-link.w--current {
    background-color: var(--rev-accent) !important;
    color: #fff !important;
    font-weight: 600;
}

/* FA icon inside nav links — positioned absolutely */
.sidebar-navbar-link .nav-icon {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    text-align: center;
    font-size: 15px;
    opacity: 0.7;
    transition: opacity var(--rev-transition);
}

.sidebar-navbar-link:hover .nav-icon {
    opacity: 0.9;
}

.sidebar-navbar-link.w--current .nav-icon {
    opacity: 1;
}

/* Logout button (input[type=submit]) styled as nav link */
.sidebar-navbar-footer .sidebar-navbar-link.w-button {
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    width: 100%;
    text-align: left;
    cursor: pointer;
    box-shadow: none !important;
}

.sidebar-navbar-footer .sidebar-navbar-link.w-button:hover {
    background-color: rgba(255, 255, 255, 0.06) !important;
    color: var(--rev-text) !important;
}


/* ============================================================
   4. SIDEBAR DROPDOWN SUBMENUS (SALES / STOCK)
   ============================================================ */

.sidebar-navbar-dropdown-list {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding-left: 0 !important;
    margin-left: 0 !important;
}

/* Dropdown toggle — same style as nav link */
.sidebar-navbar-dropdown .w-dropdown-toggle {
    background-image: none !important;
    cursor: pointer;
}

/* Chevron rotation when open */
.sidebar-navbar-dropdown .w-icon-dropdown-toggle {
    transition: transform var(--rev-transition);
    border-color: var(--rev-text-muted) !important;
}

.sidebar-navbar-dropdown .w-dropdown-toggle.w--open .w-icon-dropdown-toggle {
    transform: rotate(180deg);
    border-color: #fff !important;
}


/* ============================================================
   5. TOPBAR CONTAINER & CONTROLS
   ============================================================ */

.app-navbar-container {
    background-color: var(--rev-surface-1);
}

.app-navbar-menu {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 16px;
    height: 100%;
}

.app-navbar-menu-item {
    display: flex;
    align-items: center;
}

/* Menu dropdown toggle buttons */
.menu-dropdown-toggle {
    background-image: none !important;
    width: 36px;
    height: 36px;
    border-radius: var(--rev-radius-sm);
    display: flex !important;
    align-items: center;
    justify-content: center;
    color: var(--rev-text-muted);
    font-size: 17px;
    transition: background-color var(--rev-transition), color var(--rev-transition);
    cursor: pointer;
}

.menu-dropdown-toggle:hover,
.menu-dropdown-toggle.w--open {
    background-color: rgba(255, 255, 255, 0.08);
    color: var(--rev-text);
}

/* Remove PNG backgrounds from specific dropdown toggles */
.menu-dropdown-toggle.dropdown-notification,
.menu-dropdown-toggle.dropdown-message,
.menu-dropdown-toggle.dropdown-search {
    background-image: none !important;
}


/* ============================================================
   6. TOPBAR — IDENTITY DISPLAY & PROFILE AVATAR
   ============================================================ */

/* Business name + user name block */
.rev-topbar-identity {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    margin-right: 8px;
    line-height: 1.2;
}

.rev-topbar-tenant {
    font-family: 'Montserrat', sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: var(--rev-text);
    letter-spacing: 0.2px;
    white-space: nowrap;
}

.rev-topbar-user {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 400;
    color: var(--rev-text-muted);
    white-space: nowrap;
}

/* Profile avatar circle */
.navbar-dropdown-avatar,
.rev-avatar {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background-color: var(--rev-brand) !important;
    background-image: none !important;
    border: 2px solid var(--rev-accent) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #fff !important;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: border-color var(--rev-transition), box-shadow var(--rev-transition);
}

.navbar-dropdown-avatar:hover,
.rev-avatar:hover {
    border-color: #fff !important;
    box-shadow: 0 0 0 3px rgba(230, 14, 137, 0.25);
}

/* Profile dropdown menu */
.menu-dropdown-link {
    display: flex !important;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    border-radius: var(--rev-radius-sm);
    color: var(--rev-text) !important;
    text-decoration: none !important;
    transition: background-color var(--rev-transition);
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
}

.menu-dropdown-link:hover {
    background-color: rgba(255, 255, 255, 0.06) !important;
    color: var(--rev-text) !important;
}

.menu-dropdown-link-icon {
    width: 16px;
    text-align: center;
    color: var(--rev-text-muted);
    font-size: 14px;
}

/* Hide img icons in profile dropdown */
.menu-dropdown-link img.menu-dropdown-link-icon {
    display: none;
}

.munu-dropdown-link-container {
    display: flex;
    align-items: center;
    gap: 10px;
}


/* ============================================================
   7. DROPDOWN PANELS — SCALE + FADE ANIMATION
   ============================================================ */

.menu-dropdown-list {
    background-color: var(--rev-surface-1) !important;
    border: 1px solid var(--rev-border-strong) !important;
    border-radius: var(--rev-radius-md) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.55) !important;
    min-width: 220px;
    padding: 6px !important;
    /* Animation base state */
    opacity: 0;
    transform: scale(0.96) translateY(-4px);
    transform-origin: top right;
    transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1),
                transform 150ms cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
}

.menu-dropdown-list.w--open {
    opacity: 1;
    transform: scale(1) translateY(0);
    pointer-events: auto;
}

/* Sidebar submenus open downward */
.sidebar-navbar-dropdown-list {
    transform-origin: top left;
    border: none !important;
    box-shadow: none !important;
    min-width: unset;
    padding: 0 !important;
}

.sidebar-navbar-dropdown-list.w--open {
    opacity: 1;
    transform: scale(1) translateY(0);
    pointer-events: auto;
}

/* Notification content */
.notification-content-heading {
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: var(--rev-text-muted);
    padding: 8px 12px 4px;
}


/* ============================================================
   8. PAGE HEADER BAR
   ============================================================ */

.app-main-layout-header {
    background-color: var(--rev-surface-1) !important;
    border-bottom: 1px solid var(--rev-border) !important;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.02);
}

.app-main-layout-wrapper.header {
    background-color: var(--rev-surface-1) !important;
}

.page-heading h2,
.page-heading h1 {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    letter-spacing: -0.3px;
    color: var(--rev-text) !important;
    margin-bottom: 0;
}

/* Page tab links in header */
.page-tab-link {
    background-image: none !important;
    padding-left: 10px !important;
    color: var(--rev-text-muted) !important;
    border-bottom: 2px solid transparent;
    transition: color var(--rev-transition), border-color var(--rev-transition);
}

.page-tab-link:hover {
    color: var(--rev-text) !important;
    border-bottom-color: rgba(230, 14, 137, 0.4);
}

.page-tab-link.w--current {
    color: var(--rev-accent) !important;
    border-bottom-color: var(--rev-accent);
    background-image: none !important;
}

/* Null all page-tab-link PNG backgrounds */
.page-tab-link[class*=" "] {
    background-image: none !important;
}


/* ============================================================
   9. CARDS
   ============================================================ */

.card {
    background-color: var(--rev-surface-2) !important;
    border-radius: var(--rev-radius-md) !important;
    border: 1px solid var(--rev-border) !important;
    box-shadow: var(--rev-shadow-card) !important;
    color: var(--rev-text) !important;
    transition: box-shadow var(--rev-transition);
}

.card:hover {
    box-shadow: var(--rev-shadow-hover) !important;
}

.card.dark {
    background-color: var(--rev-surface-1) !important;
}

.card-heading {
    margin-bottom: 16px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    color: var(--rev-text);
}


/* ============================================================
   10. BUTTONS
   ============================================================ */

.button {
    border-radius: var(--rev-radius-sm) !important;
    font-family: 'DM Sans', sans-serif !important;
    font-weight: 600 !important;
    letter-spacing: 0.3px;
    transition: background-color var(--rev-transition),
                transform var(--rev-transition),
                box-shadow var(--rev-transition) !important;
}

.button.button-primary {
    background-color: var(--rev-accent) !important;
    box-shadow: 0 2px 8px rgba(230, 14, 137, 0.35) !important;
    border: none !important;
}

.button.button-primary:hover {
    background-color: var(--rev-brand) !important;
    box-shadow: 0 4px 14px rgba(230, 14, 137, 0.45) !important;
    transform: translateY(-1px);
}

.button.button-primary:active {
    transform: translateY(0);
    box-shadow: 0 1px 4px rgba(230, 14, 137, 0.3) !important;
}

.button.button-outline,
.button.button-secondary {
    border: 1px solid var(--rev-border-strong) !important;
    background-color: transparent !important;
    color: var(--rev-text) !important;
}

.button.button-outline:hover {
    background-color: rgba(255, 255, 255, 0.06) !important;
}

/* Minimum touch target on mobile */
@media (max-width: 768px) {
    .button { min-height: 44px; }
}


/* ============================================================
   11. INPUTS & TEXTAREAS — FIX BLUE FOCUS BUG
   ============================================================ */

.input,
.textarea,
.w-input,
.w-select {
    background-color: var(--rev-surface-2) !important;
    border-color: var(--rev-border-strong) !important;
    border-radius: var(--rev-radius-sm) !important;
    color: var(--rev-text) !important;
    font-family: 'DM Sans', sans-serif !important;
    transition: border-color var(--rev-transition), box-shadow var(--rev-transition);
}

.input:focus,
.textarea:focus,
.w-input:focus,
.w-select:focus {
    border-color: var(--rev-accent) !important;
    box-shadow: 0 0 0 3px rgba(230, 14, 137, 0.15) !important;
    outline: none !important;
}

.input::placeholder,
.textarea::placeholder,
.w-input::placeholder {
    color: var(--rev-text-muted) !important;
}


/* ============================================================
   12. CHECKBOX — MAGENTA BRAND OVERRIDE
   ============================================================ */

.w-checkbox-input--inputType-custom.w--redirected-checked {
    background-color: var(--rev-accent) !important;
    border-top-color: var(--rev-accent) !important;
    border-bottom-color: var(--rev-accent) !important;
    border-left-color: var(--rev-accent) !important;
    border-right-color: var(--rev-accent) !important;
}

.w-checkbox-input--inputType-custom.w--redirected-focus {
    box-shadow: 0 0 0 3px rgba(230, 14, 137, 0.15) !important;
}


/* ============================================================
   13. TABLE / LIST ROWS
   ============================================================ */

.row.table-row {
    transition: background-color var(--rev-transition);
}

.row.table-row:hover {
    background-color: rgba(255, 255, 255, 0.04) !important;
}

.row.table-row.table-header {
    border-bottom: 1px solid var(--rev-border) !important;
    background-color: transparent !important;
}

.row.table-row.table-header .column-heading,
.row.table-row.table-header div,
.row.table-row.table-header td {
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.7px !important;
    text-transform: uppercase !important;
    color: var(--rev-text-muted) !important;
}


/* ============================================================
   14. STATUS BADGES
   ============================================================ */

.status {
    display: inline-flex !important;
    align-items: center;
    gap: 5px;
    padding: 3px 10px !important;
    border-radius: 99px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.4px;
}

.status.green {
    background-color: rgba(34, 197, 94, 0.12) !important;
    color: #4ade80 !important;
}

.status.red {
    background-color: rgba(239, 68, 68, 0.12) !important;
    color: #f87171 !important;
}

.status.blue {
    background-color: rgba(230, 14, 137, 0.12) !important;
    color: var(--rev-accent) !important;
}

.status.orange {
    background-color: rgba(251, 146, 60, 0.12) !important;
    color: #fb923c !important;
}


/* ============================================================
   15. MODAL
   ============================================================ */

.modal-container {
    background-color: var(--rev-surface-1) !important;
    border-radius: var(--rev-radius-lg) !important;
    border: 1px solid var(--rev-border-strong) !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.65) !important;
    padding: 28px 32px !important;
}

.modal-mask {
    background-color: rgba(0, 0, 0, 0.65) !important;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.modal-close {
    background-image: none !important;
    background-color: rgba(255, 255, 255, 0.08) !important;
    border-radius: 50% !important;
    width: 28px !important;
    height: 28px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer;
    transition: background-color var(--rev-transition);
    color: var(--rev-text-muted);
    font-size: 14px;
}

.modal-close:hover {
    background-color: rgba(255, 255, 255, 0.16) !important;
    color: var(--rev-text);
}


/* ============================================================
   16. BUSY SPINNER (new classes — BusySpinner.razor updated)
   ============================================================ */

.rev-spinner-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(27, 29, 42, 0.75);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.rev-spinner-ring {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 4px solid rgba(255, 255, 255, 0.1);
    border-top-color: var(--rev-accent);
    animation: rev-spin 0.75s linear infinite;
}


/* ============================================================
   17. TAB CONTROL
   ============================================================ */

.w-tab-menu {
    border-bottom: 1px solid var(--rev-border) !important;
}

.w-tab-menu .w-tab-link,
.tabs-menu .w-tab-link {
    font-family: 'DM Sans', sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--rev-text-muted) !important;
    border-bottom: 2px solid transparent !important;
    padding: 10px 16px !important;
    margin-bottom: -1px;
    background-color: transparent !important;
    border-radius: var(--rev-radius-sm) var(--rev-radius-sm) 0 0;
    transition: color var(--rev-transition), border-color var(--rev-transition),
                background-color var(--rev-transition) !important;
    background-image: none !important;
}

.w-tab-menu .w-tab-link:hover,
.tabs-menu .w-tab-link:hover {
    color: var(--rev-text) !important;
    background-color: rgba(255, 255, 255, 0.04) !important;
}

.w-tab-menu .w-tab-link.w--current,
.tabs-menu .w-tab-link.w--current {
    color: var(--rev-accent) !important;
    border-bottom-color: var(--rev-accent) !important;
    background-color: transparent !important;
    font-weight: 600 !important;
}

/* Tab page icons */
.tab-link .fa-solid {
    margin-right: 6px;
    font-size: 13px;
    opacity: 0.75;
}

.tab-link.w--current .fa-solid {
    opacity: 1;
}


/* ============================================================
   18. FOOTER
   ============================================================ */

.footer {
    border-top: 1px solid var(--rev-border) !important;
    background-color: transparent !important;
    padding: 16px 0 !important;
    color: var(--rev-text-muted) !important;
    font-size: 12px !important;
    font-family: 'DM Sans', sans-serif;
}

.footer-link {
    color: var(--rev-text-muted) !important;
    transition: color var(--rev-transition);
}

.footer-link:hover {
    color: var(--rev-accent) !important;
}


/* ============================================================
   19. BLAZORED TOAST
   ============================================================ */

.blazored-toast-container .blazored-toast {
    border-radius: var(--rev-radius-md) !important;
    font-family: 'DM Sans', sans-serif !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4) !important;
    border: 1px solid var(--rev-border-strong) !important;
}


/* ============================================================
   20. SYNCFUSION SCHEDULER — BRAND COLOUR HARMONISATION
   ============================================================ */

.e-schedule .e-appointment {
    background-color: var(--rev-brand) !important;
    border-color: var(--rev-accent) !important;
    border-radius: var(--rev-radius-sm) !important;
}

.e-schedule .e-appointment:hover {
    background-color: var(--rev-accent) !important;
}

.e-schedule .e-selected-cell {
    background-color: rgba(230, 14, 137, 0.15) !important;
}

.e-schedule .e-header-cells.e-current-day,
.e-schedule .e-current-time {
    color: var(--rev-accent) !important;
}


/* ============================================================
   21. LOGIN PAGE (.single-layout)
   ============================================================ */

.single-layout {
    min-height: 100vh !important;
    background-color: var(--rev-body) !important;
}

.single-layout-row {
    min-height: 100vh;
}

/* Left branded panel */
.single-layout-col.left {
    background: linear-gradient(135deg, var(--rev-brand) 0%, var(--rev-surface-1) 100%) !important;
}

.single-layout-left {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    padding: 40px;
}

/* Right form panel */
.single-layout-col.right {
    background-color: var(--rev-body) !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.single-layout-right {
    background-color: var(--rev-body) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 100vh;
}

.single-layout-right-content {
    background-color: var(--rev-surface-1) !important;
    border-radius: var(--rev-radius-lg) !important;
    border: 1px solid var(--rev-border-strong) !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.45) !important;
    padding: 40px !important;
    width: 100%;
    max-width: 420px;
}

/* Hide left panel on mobile */
@media (max-width: 767px) {
    .single-layout-col.left {
        display: none !important;
    }
    .single-layout-col.right {
        width: 100% !important;
        padding: 20px !important;
    }
    .single-layout-right {
        padding: 0 !important;
    }
    .single-layout-right-content {
        padding: 28px 24px !important;
        box-shadow: none !important;
        border: none !important;
    }
}


/* ============================================================
   22. MOBILE RESPONSIVE SIDEBAR — SMOOTH DRAWER
   ============================================================ */

@media screen and (max-width: 1024px) {
    /* Slide sidebar off-screen by default */
    .sidebar-navbar-menu {
        transform: translateX(-100%);
        transition: transform 300ms cubic-bezier(0.4, 0, 0.2, 1);
        will-change: transform;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        height: 100vh !important;
        z-index: 9000 !important;
        width: 260px !important;
    }

    /* Webflow sets data-nav-menu-open on the .w-nav element when hamburger is tapped */
    [data-nav-menu-open] .sidebar-navbar-menu {
        transform: translateX(0);
        display: flex !important; /* override webflow's display:none on .w-nav[data-collapse="medium"] .w-nav-menu */
    }

    /* Semi-transparent backdrop */
    .sidebar-navbar-menu::before {
        content: '';
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.55);
        z-index: -1;
        opacity: 0;
        transition: opacity 300ms ease;
        pointer-events: none;
    }

    [data-nav-menu-open] .sidebar-navbar-menu::before {
        opacity: 1;
        pointer-events: auto;
    }

    /* Hide the desktop accent line pseudo-element */
    .sidebar-navbar-menu::after {
        display: none !important;
    }
}

@media screen and (max-width: 479px) {
    .sidebar-navbar-link {
        min-height: 52px !important;
        font-size: 15px !important;
    }

    .page-heading h2,
    .page-heading h1 {
        font-size: 18px !important;
    }

    .app-main-layout-wrapper.header {
        padding-top: 16px !important;
        padding-bottom: 12px !important;
    }
}


/* ============================================================
   23. ANIMATIONS
   ============================================================ */

/* --- Page content fade-in on navigation --- */
.app-main-layout {
    animation: rev-page-in 150ms cubic-bezier(0.4, 0, 0.2, 1) both;
}

@keyframes rev-page-in {
    from {
        opacity: 0;
        transform: translateY(6px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* --- Spinner rotation --- */
@keyframes rev-spin {
    to { transform: rotate(360deg); }
}

/* --- Modal slide-up + fade on open --- */
.modal-container {
    animation: rev-modal-in 180ms cubic-bezier(0.4, 0, 0.2, 1) both;
}

@keyframes rev-modal-in {
    from {
        opacity: 0;
        transform: translateY(16px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.modal-mask {
    animation: rev-fade-in 180ms ease both;
}

@keyframes rev-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* --- Card entrance stagger --- */
.card {
    animation: rev-card-in 200ms cubic-bezier(0.4, 0, 0.2, 1) both;
}

@keyframes rev-card-in {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.card:nth-child(1)  { animation-delay: 0ms; }
.card:nth-child(2)  { animation-delay: 40ms; }
.card:nth-child(3)  { animation-delay: 80ms; }
.card:nth-child(4)  { animation-delay: 120ms; }
.card:nth-child(n+5){ animation-delay: 160ms; }

/* --- Table row entrance stagger --- */
.row.table-row {
    animation: rev-card-in 150ms cubic-bezier(0.4, 0, 0.2, 1) both;
}

.row.table-row:nth-child(1)  { animation-delay: 0ms; }
.row.table-row:nth-child(2)  { animation-delay: 20ms; }
.row.table-row:nth-child(3)  { animation-delay: 40ms; }
.row.table-row:nth-child(4)  { animation-delay: 60ms; }
.row.table-row:nth-child(5)  { animation-delay: 80ms; }
.row.table-row:nth-child(n+6){ animation-delay: 100ms; }


/* ============================================================
   24. MISC REFINEMENTS
   ============================================================ */

/* Search input in pages */
.searchinput,
input[type="search"].w-input {
    background-color: var(--rev-surface-2) !important;
    border-color: var(--rev-border-strong) !important;
    border-radius: var(--rev-radius-sm) !important;
    color: var(--rev-text) !important;
}

.searchinput:focus,
input[type="search"].w-input:focus {
    border-color: var(--rev-accent) !important;
    box-shadow: 0 0 0 3px rgba(230, 14, 137, 0.15) !important;
}

/* Validation errors */
.validation-error,
.field-validation-error,
span.text-danger {
    color: #f87171 !important;
    font-size: 12px;
    font-family: 'DM Sans', sans-serif;
}

/* Hint / helper text */
.hint {
    color: var(--rev-text-muted) !important;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
}

/* Links */
a.custom-link,
a.link {
    color: var(--rev-accent) !important;
    transition: color var(--rev-transition);
}

a.custom-link:hover,
a.link:hover {
    color: var(--rev-brand) !important;
}

/* Dividers */
.divider,
.section-divider {
    border-color: var(--rev-border) !important;
}

/* Error boundary message */
.error-message {
    color: #f87171;
    font-family: 'DM Sans', sans-serif;
    padding: 20px;
    text-align: center;
}
