﻿/*Saved to Visual studios 11/11/2025 22:36pm
==========================================================================
ASFA Theme Modern - Table of Contents
==========================================================================
1. Core Variables & Settings
2. Base Typography
3. Header Styles
   3.1 Header Container
   3.2 Header Links & Icons
4. Navigation
   4.1 Navbar Container
   4.2 Brand/Logo
   4.3 Navigation Links
   4.4 Dropdown Menus
   4.5 Mobile Menu
   4.6 Buttons
5. Hero Section
6. Responsive Styles
7. Utility Classes
8. Footer Styles
9. Info Popup
10. Link styles
11. Button styles
12. Spinner (loading)
========================================================================== */

/*
==========================================================================
1. Core Variables & Settings
==========================================================================
*/

/* Core Variables */
:root {
    /* Colors */
    --asfa-primary: #02C1D3;
    --asfa-primary-hover: #01A9B9;
    --asfa-consumer: #9E713C;
    --asfa-consumer-hover: #86602F;
    --asfa-text: #212529;
    --asfa-white: #ffffff;
    --asfa-black: #000000;
    --asfa-navy: #03173E;
    --asfa-link: #02c1d3;
    --asfa-link-hover: rgba(0, 134, 168, 1);
    --color-overlay: rgba(0, 0, 0, 0.43);
    --color-border: rgba(0, 0, 0, 0.1);
    --color-shadow: rgba(0, 0, 0, 0.1);
    --color-primary-light: rgba(2, 193, 211, 0.05);
    /* Spacing */
    --navbar-padding: 2rem 1rem;
    --navbar-mobile-padding: 0.5rem 1rem;
    --header-height: 62px;
    --navbar-height: calc(70px + var(--spacing-xl) * 2);
    --logo-height: 70px;
    --logo-height-mobile: 65px;
    --logo-height-hero: 82px;
    --icon-size-base: 20px;
    --icon-size-large: 42px;
    --icon-size-social: 35px;
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 0.75rem;
    --spacing-base: 1rem;
    --spacing-lg: 1.25rem;
    --spacing-xl: 2rem;
    /* Layout */
    --border-radius-sm: 0.25rem;
    --border-radius-base: 5px;
    --border-radius-circle: 50%;
    --container-max-width: 1344px;
    --dropdown-min-width: 200px;
    --mobile-min-width: 150px;
    --hero-height: 400px;
    /* Effects */
    --transition-fast: 0.2s ease;
    --transition-base: 0.3s ease;
    --transition-specific: 0.3s ease-in-out;
    --blur-overlay: blur(10px);
    /* Z-index */
    --z-header: 1031;
    --z-navbar: 1030;
    --z-dropdown: 1040;
    /* Typography */
    --font-family-base: "Inter", Sans-serif;
    --font-size-base: 20px;
    --font-weight-normal: 400;
    --line-height-base: 26px;
    /* Breakpoints - Using Bootstrap 5 standard breakpoints */
    --breakpoint-sm: 576px; /* Small devices */
    --breakpoint-md: 768px; /* Medium devices */
    --breakpoint-lg: 1200px; /* Large devices */
    --breakpoint-xl: 1200px; /* Extra large devices */
    --breakpoint-xxl: 1400px; /* Extra extra large devices */
}

/*
==========================================================================
2. Base Typography
==========================================================================
*/

body {
    font-family: var(--font-family-base);
    font-size: 140%;
    color: #333;
}

/*
==========================================================================
3. Header Styles
==========================================================================
*/
/* 3.1 Header Container */
.header-container {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--header-height);
    z-index: var(--z-header);
    background-color: #F2F2F2 !important;
}

    /* 3.2 Header Links & Icons */
    .header-container a {
        font-family: var(--font-family-base);
        font-size: var(--font-size-base);
        font-weight: var(--font-weight-normal);
    }

    .header-container .social-icon-link {
        display: flex !important;
        align-items: center !important;
        color: var(--asfa-text) !important;
        transition: opacity var(--transition-base) !important;
    }

        .header-container .social-icon-link > svg {
            width: var(--icon-size-base) !important;
            height: var(--icon-size-base) !important;
        }

/* Hover effects */
.text-dark.text-decoration-underline:hover {
    color: var(--asfa-text) !important;
    opacity: 0.7 !important;
    transition: opacity 0.2s ease;
    text-decoration: underline !important;
}

.text-dark.text-decoration-underline {
    text-decoration: underline !important;
    color: var(--asfa-text) !important;
    font-family: var(--font-family-base) !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 20px !important;
}

table tbody tr th a:not(.btn) {
    font-weight: 500 !important;
}

/*
==========================================================================
4. Navigation
==========================================================================
*/

/* 4.1 Navbar Container */
.navbar-container {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: var(--z-navbar);
    background-color: var(--color-overlay);
    backdrop-filter: var(--blur-overlay);
}

/* Desktop positioning */
@media (min-width: 1200px) {
    .navbar-container {
        top: 62px;
        height: var(--navbar-height);
    }

    .navbar-custom {
        height: 100%;
    }
}

/* Mobile collapsed state */
@media (max-width: 1199.98px) {
    .navbar-container {
        min-height: var(--navbar-height);
        height: auto;
    }

    .navbar-custom {
        min-height: var(--navbar-height);
        height: auto;
    }

    .mobile-controls {
        display: flex !important;
        align-items: center !important;
        gap: 1rem !important;
    }

        .mobile-controls .search-icon-link {
            padding: 0.5rem !important;
            color: var(--asfa-white) !important;
            display: flex !important;
            align-items: center !important;
            justify-content: center !important;
        }

            .mobile-controls .search-icon-link svg {
                width: 42px !important;
                height: 42px !important;
                fill: currentColor !important;
            }
}

/* Header Links and Icons */
.header-container a {
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-normal);
}

.header-container .social-icon-link {
    display: flex !important;
    align-items: center !important;
    color: white !important;
    transition: opacity 0.3s ease !important;
}

    .header-container .social-icon-link > svg {
        width: 20px !important;
        height: 20px !important;
    }

/* Hover effects */
/*.text-dark.text-decoration-underline:hover {
    color: var(--asfa-text) !important;
    opacity: 0.7 !important;
    transition: opacity 0.2s ease;
}*/

/* Hide header on mobile */
@media (max-width: 1199.98px) {
    .header-container {
        display: none !important;
    }
}

/* Top Navigation Links */
[data-id="topleftnav"] ul.navbar-nav > li.nav-item > a.nav-link,
[data-id="toprightnav"] ul.navbar-nav > li.nav-item > a.nav-link {
    display: block;
    padding: 9px 9px;
    text-decoration: underline;
    color: var(--asfa-black);
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-normal);
    background-color: var(--asfa-white);
}

/* Main Navigation */
:root {
    --navbar-height: calc(70px + 2rem + 2rem); /* logo height + top padding + bottom padding */
    --navbar-content-height: calc(70px + 2rem); /* logo height + bottom padding - for dropdown positioning */
    --nav-item-height: 38px; /* Height of nav items (adjust if needed) */
}

.navbar-custom {
    font-family: var(--font-family-base) !important;
    font-size: var(--font-size-base) !important;
    font-weight: var(--font-weight-normal) !important;
    line-height: var(--line-height-base) !important;
    display: flex !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: var(--navbar-padding) !important;
    text-decoration: none !important;
    width: 100% !important;
    transition: height var(--transition-base);
}

    /* Hamburger Menu Icon */

    .navbar-custom .navbar-toggler,
    .navbar-dark .navbar-toggler,
    .navbar-custom .navbar-toggler:hover,
    .navbar-custom .navbar-toggler:focus,
    .navbar-custom .navbar-toggler:active {
        border: none !important;
        padding: 0.5rem !important;
        color: var(--asfa-white) !important;
        background-color: transparent !important;
        box-shadow: none !important;
        outline: none !important;
        border-radius: 0 !important;
        margin: 8px 0 8px 0 !important;
        display: block !important;
    }

/* Mobile Controls Container */
.mobile-controls {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

@media (min-width: 1200px) {
    .mobile-controls {
        display: none !important;
    }
}

.navbar-custom .navbar-toggler-icon,
.navbar-dark .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255,255,255, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E") !important;
    width: 24px !important;
    height: 24px !important;
    opacity: 1 !important;
}

.navbar-custom .navbar-toggler:focus {
    box-shadow: none !important;
}

/* Brand/Logo */
.navbar-brand {
    padding: 0;
    margin: 0;
    display: flex;
    align-items: center;
    height: 100%;
    color: var(--asfa-white) !important;
}

.asfa-logo-wrapper {
    position: relative;
    display: inline-block;
    height: var(--logo-height);
    vertical-align: middle;
    line-height: var(--logo-height);
}

    .asfa-logo-wrapper svg {
        height: var(--logo-height-hero);
        width: auto;
        vertical-align: middle;
    }

/* 3.3 Hero Section */
.header-hero {
    position: relative;
    width: 100%;
    height: var(--hero-height);
    padding-top: calc(1 * var(--header-height));
    z-index: 1;
    background-image: url('https://www.superannuation.asn.au/wp-content/uploads/2025/03/AdobeStock_871290314-2-scaled.avif');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

    .header-hero .overlay {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background-color: var(--color-overlay);
    }

    .header-hero .container {
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 9999;
    }

section.header-hero .card .card-body,
section.header-hero .card#HeroHeadingSection {
    background-color: transparent !important;
}

/* Desktop logo positioning */
@media (min-width: 1200px) {
    .navbar-brand {
        display: flex;
        align-items: center;
    }
}

/* Navigation Links */
@media (min-width: 1200px) {
    .navbar-collapse {
        justify-content: flex-end;
        overflow-x: visible;
        border-top: none !important;
        box-shadow: none !important;
    }
}

/* Full Screen Mobile Menu */
@media (max-width: 1199.98px) {
    body.modal-open {
        overflow: hidden !important;
    }

    .navbar-collapse {
        position: fixed !important;
        top: 0 !important;
        right: -100% !important;
        bottom: 0 !important;
        width: 100% !important;
        height: 100vh !important;
        background-color: var(--asfa-white) !important;
        padding: var(--spacing-base) !important;
        overflow-y: auto !important;
        transition: right var(--transition-specific) !important;
        z-index: var(--z-navbar) !important;
    }

        .navbar-collapse.show {
            right: 0 !important;
        }

    .mobile-nav-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: var(--spacing-xl) var(--spacing-lg) 0 var(--spacing-lg) !important;
        margin: calc(-1 * var(--spacing-base)) calc(-1 * var(--spacing-base)) var(--spacing-base) calc(-1 * var(--spacing-base)) !important;
    }

        .mobile-nav-header .navbar-brand {
            margin: 0 !important;
        }

        .mobile-nav-header .navbar-brand-logo svg {
            fill: var(--asfa-primary) !important;
            color: var(--asfa-primary) !important;
        }

        .mobile-nav-header .navbar-brand-logo path {
            fill: var(--asfa-primary) !important;
        }

    .navbar-close {
        background: transparent !important;
        border: none !important;
        padding: var(--spacing-md) !important;
        color: var(--asfa-primary) !important;
        cursor: pointer !important;
    }

        .navbar-close svg {
            width: var(--icon-size-large) !important;
            height: var(--icon-size-large) !important;
        }

        .navbar-close:focus {
            outline: none !important;
        }

    /* Active/selected states - must come first to take precedence */
    .navbar-custom .navbar-nav .nav-item > .nav-link.active,
    .navbar-custom .navbar-nav .nav-item > .nav-link.dropdown-toggle.show,
    .navbar-custom .navbar-nav .nav-item > a.nav-link.active,
    .navbar-custom .navbar-nav .nav-item > a.nav-link.dropdown-toggle.show {
        color: var(--asfa-primary) !important;
        opacity: 1 !important;
        transition: none !important;
    }

    /* Mobile nav links colors */
    @media (max-width: 1199.98px) {
        /* Only apply borders to main navigation items */
        /* Apply borders to main navigation items and mobile My Account */
        .navbar-custom .navbar-nav > .nav-item:not(.nav-item--search):not(.mobile-buttons):not(.text-white):not(.mt-4),
        .navbar-custom .navbar-nav > .nav-item.dropdown.d-xl-none {
            border-bottom: 1px solid var(--color-border) !important;
        }

        .navbar-custom .navbar-nav > .nav-item:last-child:not(.d-xl-none):not(.nav-item--search):not(.mobile-buttons):not(.text-white):not(.mt-4) {
            border-bottom: none !important;
        }
    }

    .navbar-custom .navbar-nav .nav-item > .nav-link,
    .navbar-custom .navbar-nav .nav-item > a.nav-link,
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link),
    .navbar-dark .navbar-nav > li > a,
    .navbar-dark .navbar-nav > li.dropdown > a {
        color: var(--asfa-text) !important;
        text-decoration: none !important;
        padding: var(--spacing-md) var(--spacing-base) !important; /* Increased padding for better touch targets */
        font-family: var(--font-family-base) !important;
        font-size: 20px !important;
        font-weight: 500 !important;
        line-height: 24px !important;
        background-color: transparent !important;
        white-space: nowrap !important;
        border: none !important;
        transition: color 0.3s ease !important;
    }

    /* Make room for chevron on mobile */
    .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn) {
        padding-right: 1.75rem !important;
        position: relative !important;
    }

    /* Hover states */
    .navbar-custom .navbar-nav .nav-item > .nav-link:hover,
    .navbar-custom .navbar-nav .nav-item > .nav-link:focus,
    .navbar-custom .navbar-nav .nav-item > a.nav-link:hover,
    .navbar-custom .navbar-nav .nav-item > a.nav-link:focus,
    .navbar-custom .navbar-nav .nav-item .nav-link:hover,
    .navbar-custom .navbar-nav .nav-item .nav-link:focus,
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):hover,
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):focus {
        color: var(--asfa-text) !important;
        opacity: 1 !important;
        text-decoration: none !important;
        background-color: transparent !important;
    }

    /* Mobile dropdown items */
    .navbar-custom .navbar-nav .dropdown-menu .dropdown-item,
    .navbar-custom .navbar-nav .show.dropdown-menu .dropdown-item,
    .navbar-custom .navbar-nav .dropdown-menu > li > a,
    .navbar-custom .navbar-nav .show.dropdown-menu > li > a {
        color: var(--asfa-text) !important;
        opacity: 0.7 !important;
        text-decoration: none !important;
        padding: var(--spacing-sm) var(--spacing-xl) !important;
        font-family: var(--font-family-base) !important;
        font-size: 16px !important;
        font-weight: 400 !important;
        line-height: 20px !important;
        background-color: transparent !important;
        white-space: nowrap !important;
        border: none !important;
        transition: all var(--transition-base) !important;
    }

        .navbar-custom .navbar-nav .dropdown-menu .dropdown-item:hover,
        .navbar-custom .navbar-nav .show.dropdown-menu .dropdown-item:hover,
        .navbar-custom .navbar-nav .dropdown-menu .dropdown-item:focus,
        .navbar-custom .navbar-nav .show.dropdown-menu .dropdown-item:focus {
            color: var(--asfa-primary) !important;
            opacity: 1 !important;
            background-color: transparent !important;
            text-decoration: none !important;
        }

    .navbar-nav {
        padding-top: 2rem !important;
    }
}

.navbar-custom .navbar-nav .nav-item {
    margin: 0 0.25rem !important; /* slightly increase gap between items */
}

/* Desktop nav links */
@media (min-width: 1200px) {
    .navbar-custom .navbar-nav .nav-item > .nav-link,
    .navbar-dark .navbar-nav > li > a,
    .navbar-dark .navbar-nav > li.dropdown > a,
    .navbar-custom .navbar-nav .nav-item > a.nav-link,
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link),
    .navbar-custom .navbar-nav .nav-item .nav-link {
        color: var(--asfa-white) !important;
        padding: 0.5rem 0.5rem !important;
        transition: color 0.3s ease !important;
        text-decoration: none !important;
        font-family: var(--font-family-base) !important;
        font-size: 16px !important;
        line-height: 20px !important;
        font-weight: 500 !important;
        background-color: transparent !important;
        white-space: nowrap !important;
        border: none !important;
    }

        /* Hover and active states */
        .navbar-custom .navbar-nav .nav-item > .nav-link:hover,
        .navbar-custom .navbar-nav .nav-item > .nav-link:focus,
        .navbar-custom .navbar-nav .nav-item > .nav-link.active,
        .navbar-custom .navbar-nav .nav-item > a.nav-link:hover,
        .navbar-custom .navbar-nav .nav-item > a.nav-link:focus,
        .navbar-custom .navbar-nav .nav-item > a.nav-link.active,
        .navbar-custom .navbar-nav .nav-item .nav-link:hover,
        .navbar-custom .navbar-nav .nav-item .nav-link:focus,
        .navbar-custom .navbar-nav .nav-item .nav-link.active,
        .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):hover,
        .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):focus,
        .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):not(.text-decoration-underline).active {
            color: var(--asfa-white) !important;
        }
}


/* Dropdown Menus */
.navbar-custom .navbar-nav .dropdown-menu {
    display: none;
    background-color: var(--asfa-white);
    border: 1px solid var(--color-border);
    border-radius: 0 0 var(--border-radius-sm) var(--border-radius-sm);
    box-shadow: 0 2px 4px var(--color-shadow);
    padding: 0.5rem 0;
    margin: 0;
    float: none;
    position: absolute;
    text-decoration: none;
    z-index: var(--z-dropdown);
}

    .navbar-custom .navbar-nav .dropdown-menu.show {
        display: block;
    }

@media (max-width: 1199.98px) {
    .navbar-custom .navbar-nav .dropdown-menu {
        position: static;
        float: none;
        width: 100%;
        background-color: transparent;
        border: none;
        box-shadow: none;
        margin-top: 0;
        padding: 0;
        max-height: none;
        overflow: visible;
    }

        .navbar-custom .navbar-nav .dropdown-menu > li > a,
        .navbar-custom .navbar-nav .dropdown-menu .dropdown-item {
            padding: 0.75rem 2rem;
            color: var(--asfa-text);
        }
}

.navbar-custom .navbar-nav .dropdown-menu .dropdown-item,
.navbar-custom .navbar-nav .show.dropdown-menu .dropdown-item,
.navbar-custom .navbar-nav .dropdown-menu > li > a,
.navbar-custom .navbar-nav .show.dropdown-menu > li > a,
.navbar-dark .navbar-nav .show.dropdown-menu > li > a,
.navbar-custom .nav-item .dropdown-menu .dropdown-item,
.navbar-custom .nav-item.show .dropdown-menu .dropdown-item,
.navbar-custom .dropdown-menu > li > a,
.navbar-custom .dropdown-menu a:not(.btn),
.navbar-custom .navbar-nav .dropdown-menu a:not(.btn) {
    color: #858f8d !important;
    opacity: 0.7 !important;
    padding: 6px 2rem !important;
    text-decoration: none !important;
    background-color: transparent !important;
    font-family: var(--font-family-base) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
    border: none !important;
    transition: all 0.3s ease !important;
}

    .navbar-custom .navbar-nav .dropdown-menu .dropdown-item:hover,
    .navbar-custom .navbar-nav .show.dropdown-menu .dropdown-item:hover,
    .navbar-custom .navbar-nav .dropdown-menu .dropdown-item:focus,
    .navbar-custom .navbar-nav .show.dropdown-menu .dropdown-item:focus,
    .navbar-custom .navbar-nav .dropdown-menu > li > a:hover,
    .navbar-custom .navbar-nav .show.dropdown-menu > li > a:hover,
    .navbar-dark .navbar-nav .show.dropdown-menu > li > a:hover,
    .navbar-custom .nav-item .dropdown-menu .dropdown-item:hover,
    .navbar-custom .nav-item.show .dropdown-menu .dropdown-item:hover,
    .navbar-custom .nav-item .dropdown-menu .dropdown-item:focus,
    .navbar-custom .nav-item.show .dropdown-menu .dropdown-item:focus,
    .navbar-custom .dropdown-menu > li > a:hover,
    .navbar-custom .dropdown-menu > li > a:focus,
    .navbar-custom .dropdown-menu a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):not(.dropdown-item):hover,
    .navbar-custom .navbar-nav .dropdown-menu a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):not(.dropdown-item):hover {
        color: var(--asfa-text) !important;
        opacity: 1 !important;
        background-color: transparent !important;
        text-decoration: none !important;
    }

/* Desktop dropdown positioning */
@media (min-width: 1200px) {
    .navbar-custom .nav-item {
        position: relative !important;
    }

        .navbar-custom .nav-item .dropdown-menu {
            position: absolute !important;
            top: 237% !important;
            min-width: var(--dropdown-min-width) !important;
            left: 0 !important;
            z-index: var(--z-dropdown) !important;
        }

    .navbar-custom .btn-primary + .dropdown-menu {
        position: absolute !important;
        top: 160% !important;
        right: 0 !important;
        left: auto !important;
        z-index: var(--z-dropdown) !important;
    }
}

/* Desktop dropdown items */
@media (min-width: 1200px) {
    .navbar-custom .navbar-nav .dropdown-menu > li > .dropdown-item,
    .navbar-custom .navbar-nav .show.dropdown-menu > li > .dropdown-item {
        color: var(--asfa-text) !important;
        padding: 0.5rem 1rem !important;
        transition: all 0.2s ease !important;
        text-decoration: none !important;
        font-weight: 400 !important;
        font-size: 12px !important;
        line-height: 20px !important;
        font-family: var(--font-family-base) !important;
        background-color: transparent !important;
        border: none !important;
        width: auto !important;
        white-space: nowrap !important;
        display: block !important;
    }
}

/* Desktop dropdown hover styles */
@media (min-width: 1200px) {
    .navbar-custom .navbar-nav .dropdown-menu > li > .dropdown-item:hover,
    .navbar-custom .navbar-nav .dropdown-menu > li > .dropdown-item:focus,
    .navbar-custom .navbar-nav .show.dropdown-menu > li > .dropdown-item:hover,
    .navbar-custom .navbar-nav .show.dropdown-menu > li > .dropdown-item:focus,
    .navbar-custom .navbar-nav .show.dropdown-menu > .active > a,
    .navbar-custom .navbar-nav .show.dropdown-menu > .active > a:hover,
    .navbar-custom .navbar-nav .show.dropdown-menu > .active > a:focus {
        color: var(--asfa-primary) !important;
        background-color: white !important;
        text-decoration: none !important;
        border: none !important;
    }

    /* Extra spacing on right to accommodate chevron */
    .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn) {
        position: relative !important;
        display: inline-flex !important;
        align-items: center !important;
        padding-right: 1.75rem !important; /* ensure text never overlaps chevron */
        color: var(--asfa-white) !important; /* ensure chevron (currentColor) is white */
    }

        /* Keep white color across interactive states */
        .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn):hover,
        .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn):focus,
        .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn):active,
        .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn).active,
        .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn).dropdown-toggle.show {
            color: var(--asfa-white) !important;
        }

        .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn)::after {
            top: 50% !important;
            transform: translateY(-50%) rotate(0deg) !important;
            width: 0.95em !important;
            height: 0.95em !important;
            /* Force white chevron on desktop menu items */
            background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512' aria-hidden='true'><path fill='%23ffffff' d='M207.029 381.476L12.686 187.132c-9.373-9.373-9.373-24.569 0-33.941l22.667-22.667c9.357-9.357 24.522-9.375 33.901-.04L224 284.505l154.745-154.021c9.379-9.335 24.544-9.317 33.901.04l22.667 22.667c9.373 9.373 9.373 24.569 0 33.941L240.971 381.476c-9.373 9.372-24.569 9.372-33.942 0z'/></svg>") !important;
        }

        .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn).show::after,
        .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn)[aria-expanded="true"]::after {
            transform: translateY(-50%) rotate(180deg) !important;
        }

    /* Profile button (My Account) chevron override for desktop */
    .navbar-custom .btn-primary.dropdown-toggle {
        position: relative !important;
        padding-right: 2.5rem !important; /* room for chevron inside the button */
        padding-left: 1.25rem !important; /* keep base left padding */
        padding-top: 0.75rem !important;
        padding-bottom: 0.75rem !important;
        display: inline-flex !important;
        align-items: center !important;
        color: var(--asfa-white) !important; /* ensure text and chevron color base is white */
    }

        .navbar-custom .btn-primary.dropdown-toggle::after {
            right: 1.25rem !important; /* position chevron inside button */
            top: 50% !important;
            transform: translateY(-50%) rotate(0deg) !important;
            width: 0.9em !important;
            height: 0.9em !important;
            /* Force white chevron by embedding white fill directly (avoids currentColor issues) */
            background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512' aria-hidden='true'><path fill='%23ffffff' d='M207.029 381.476L12.686 187.132c-9.373-9.373-9.373-24.569 0-33.941l22.667-22.667c9.357-9.357 24.522-9.375 33.901-.04L224 284.505l154.745-154.021c9.379-9.335 24.544-9.317 33.901.04l22.667 22.667c9.373 9.373 9.373 24.569 0 33.941L240.971 381.476c-9.373 9.372-24.569 9.372-33.942 0z'/></svg>") !important;
        }

        .navbar-custom .btn-primary.dropdown-toggle.show::after,
        .navbar-custom .btn-primary.dropdown-toggle[aria-expanded="true"]::after {
            transform: translateY(-50%) rotate(180deg) !important;
        }

        /* Keep padding consistent across interactive states for the profile button */
        .navbar-custom .btn-primary.dropdown-toggle:hover,
        .navbar-custom .btn-primary.dropdown-toggle:focus,
        .navbar-custom .btn-primary.dropdown-toggle:active,
        .navbar-custom .btn-primary.dropdown-toggle.active,
        .navbar-custom .btn-primary.dropdown-toggle.dropdown-toggle.show,
        .navbar-custom .show > .btn-primary.dropdown-toggle,
        .navbar-custom .btn-primary.dropdown-toggle:focus-visible,
        .navbar-custom .btn-primary.dropdown-toggle:active:focus,
        .navbar-custom .btn-primary.dropdown-toggle:active:focus-visible,
        .navbar-custom .show > .btn-primary.dropdown-toggle:focus,
        .navbar-custom .show > .btn-primary.dropdown-toggle:active {
            padding-right: 2.5rem !important;
            padding-left: 1.25rem !important;
            padding-top: 0.75rem !important;
            padding-bottom: 0.75rem !important;
            display: inline-flex !important;
            align-items: center !important;
            color: var(--asfa-white) !important;
        }
}

/* Buttons */
.navbar-custom .btn,
.navbar-custom .btn:active,
.navbar-custom .btn.active,
.navbar-custom .btn:focus,
.navbar-custom .btn.focus,
.navbar-custom .btn:active:focus {
    padding: 0.75rem 1.25rem !important;
    height: 60px !important;
    border: none !important;
    border-radius: 5px !important;
    transition: background-color 0.3s ease !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: none !important;
    outline: none !important;
}

.navbar-custom .nav-item .btn-consumer,
.navbar-custom .nav-item .btn-consumer:active,
.navbar-custom .nav-item .btn-consumer.active,
.navbar-custom .nav-item .btn-consumer:focus,
.navbar-custom .nav-item .btn-consumer.focus,
.navbar-custom .nav-item .btn-consumer:active:focus {
    background-color: var(--asfa-consumer) !important;
    color: var(--asfa-white) !important;
    border-color: var(--asfa-consumer) !important;
    min-width: 140px !important;
    white-space: nowrap !important;
}

/* Handle button visibility and nav alignment */
/* Desktop view (≥1200px) */
@media (min-width: 1200px) {
    .nav-item > .btn-consumer {
        display: inline-flex;
    }
}

/* Mobile/collapsed view (≤991.98px) */
@media (max-width: 1199.98px) {
    .nav-item > .btn-consumer {
        display: inline-flex;
    }
}

/* Ensure right alignment of nav items */
.navbar-nav {
    margin-left: auto;
}

.navbar-custom .btn-consumer:hover,
.navbar-custom .btn-consumer:focus,
.navbar-custom .btn-consumer:active {
    background-color: var(--asfa-consumer-hover) !important;
    color: var(--asfa-white) !important;
    border-color: var(--asfa-consumer-hover) !important;
}

.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
.btn-primary:active:hover,
.btn-primary:active:focus,
.btn-primary:active.focus,
.btn-primary.active:hover,
.btn-primary.active:focus,
.btn-primary.active.focus,
.btn-primary.focus,
.btn-primary.dropdown-toggle,
.btn-primary.dropdown-toggle.show,
.btn-primary.dropdown-toggle:hover,
.btn-primary.dropdown-toggle:focus,
.btn-primary.dropdown-toggle:active,
.show > .btn-primary.dropdown-toggle,
.show > .btn-primary.dropdown-toggle:hover,
.show > .btn-primary.dropdown-toggle:focus,
.show > .btn-primary.dropdown-toggle.focus {
    background-color: var(--asfa-primary) !important;
    color: var(--asfa-white) !important;
    border-color: var(--asfa-primary) !important;
    border-radius: 5px !important;
    text-decoration: none !important;
    box-shadow: none !important;
    outline: none !important;
}

    .btn-primary:hover,
    .btn-primary:focus,
    .btn-primary:active,
    .btn-primary.active,
    .btn-primary:active:hover,
    .btn-primary:active:focus,
    .btn-primary:active.focus,
    .btn-primary.active:hover,
    .btn-primary.active:focus,
    .btn-primary.active.focus,
    .btn-primary.focus,
    .btn-primary.dropdown-toggle:hover,
    .btn-primary.dropdown-toggle:focus,
    .btn-primary.dropdown-toggle:active,
    .show > .btn-primary.dropdown-toggle:hover,
    .show > .btn-primary.dropdown-toggle:focus,
    .show > .btn-primary.dropdown-toggle.focus {
        background-color: var(--asfa-primary-hover) !important;
        color: var(--asfa-white) !important;
        border-color: var(--asfa-primary-hover) !important;
    }

.btn-outline-secondary {
    background-color: #ffffff !important;
    color: var(--asfa-primary) !important;
    border-color: var(--asfa-primary) !important;
    border-radius: 5px !important;
    font-family: var(--font-family-base) !important;
    font-weight: var(--font-weight-normal) !important;
    font-size: var(--font-size-base) !important;
    text-decoration: none !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Icons */
.nav-item--search .search-icon-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem;
    color: var(--asfa-white);
    transition: color 0.3s ease;
    background: transparent !important;
}

    .nav-item--search .search-icon-link:hover {
        color: var(--asfa-primary);
    }

.nav-item--search svg {
    width: 42px;
    height: 42px;
    display: block;
}

/* Global social icon button - black circle with white icon */
.social-icon-link,
.social-icon-link:hover,
.social-icon-link:focus,
.social-icon-link:active {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: var(--icon-size-social) !important; /* 50px */
    height: var(--icon-size-social) !important; /* 50px */
    border-radius: 50% !important;
    background-color: var(--asfa-black) !important;
    color: var(--asfa-white) !important;
}

    .social-icon-link > svg {
        width: var(--icon-size-base) !important; /* 20px */
        height: var(--icon-size-base) !important;
        fill: currentColor !important;
        stroke: currentColor !important;
    }

.profile-icon {
    font-size: 0.8em;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
    color: currentColor;
}

/* Dropdown arrow styles */
.dropdown-toggle::after {
    content: "" !important;
    position: absolute !important;
    right: 0.5rem !important;
    top: 50% !important;
    transform: translateY(-50%) rotate(0deg) !important;
    width: 0.75em !important;
    height: 0.75em !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: contain !important;
    /* FontAwesome-style chevron down using provided SVG path, color via currentColor */
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512' aria-hidden='true'><path fill='currentColor' d='M207.029 381.476L12.686 187.132c-9.373-9.373-9.373-24.569 0-33.941l22.667-22.667c9.357-9.357 24.522-9.375 33.901-.04L224 284.505l154.745-154.021c9.379-9.335 24.544-9.317 33.901.04l22.667 22.667c9.373 9.373 9.373 24.569 0 33.941L240.971 381.476c-9.373 9.372-24.569 9.372-33.942 0z'/></svg>") !important;
    border: none !important;
    pointer-events: none !important;
}

/* Rotate chevron when expanded */
.dropdown-toggle.show::after,
.dropdown-toggle[aria-expanded="true"]::after {
    transform: translateY(-50%) rotate(180deg) !important;
}

/* Responsive Styles */
/* Large devices (desktops, less than 992px) */
@media (max-width: 1199.98px) {
    .navbar-custom {
        padding: var(--navbar-mobile-padding);
        height: auto;
    }

    .navbar-collapse {
        padding: 1rem;
        transform: translateY(-10px);
        opacity: 0;
        transition: all 0.3s ease;
    }

        .navbar-collapse.show {
            transform: translateY(0);
            opacity: 1;
        }

    .navbar-nav {
        padding: 1rem 0;
        flex-direction: column;
    }

    .nav-item {
        width: 100%;
    }

    /* Mobile menu styles */
    .navbar-custom .btn {
        text-align: center !important;
        justify-content: center !important;
    }

    /* Desktop Navigation */
    .navbar-custom .d-lg-flex.align-items-center {
        margin-left: auto !important;
    }

    /* Mobile menu structure */
    .navbar-custom .mobile-buttons {
        padding-top: 0.5rem !important;
        margin-top: 1rem !important;
    }

        .navbar-custom .mobile-buttons .button-row {
            display: flex !important;
            justify-content: center !important;
            gap: 0.5rem !important;
        }

            .navbar-custom .mobile-buttons .button-row .nav-item {
                flex: 1 !important;
                min-width: 150px !important;
            }

            .navbar-custom .mobile-buttons .button-row .btn {
                width: 100% !important;
                font-family: var(--font-family-base) !important;
                font-size: 14px !important;
                padding: 0.5rem 0.75rem !important;
            }

    @media (max-width: 375px) {
        .navbar-custom .mobile-buttons .button-row {
            flex-direction: column !important;
        }

            .navbar-custom .mobile-buttons .button-row .nav-item {
                width: 100% !important;
            }
    }

    /* Mobile My Account alignment */
    .navbar-custom .nav-item.d-xl-none .nav-link.dropdown-toggle {
        text-align: left !important;
    }

    /* Mobile social media and header links */
    .navbar-custom .nav-item.d-xl-none .nav-link {
        padding: 0.5rem 1rem !important;
        white-space: nowrap !important;
    }

    /* Social media icon - match website styles */
    .social-icon-link {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: var(--icon-size-social) !important;
        height: var(--icon-size-social) !important;
        background-color: var(--asfa-black) !important;
        border-radius: 50% !important;
        transition: opacity 0.3s ease !important;
    }

        .social-icon-link > svg {
            width: var(--icon-size-base) !important;
            height: var(--icon-size-base) !important;
            color: var(--asfa-white) !important;
        }

    /* Ensure nav link base styles do not override social icon sizing */
    .navbar-custom .navbar-nav .nav-item > a.social-icon-link {
        padding: 0 !important;
        line-height: 1 !important;
    }


    /* Welcome text */
    .navbar-custom .nav-item.d-xl-none.text-white {
        color: var(--asfa-text) !important;
        text-decoration: none !important;
    }

    /* Mobile menu links */
    .navbar-custom .nav-item.d-xl-none .nav-link,
    .navbar-custom .nav-item.d-xl-none .d-flex .nav-link,
    .navbar-custom .nav-item.d-lg-none .text-white {
        text-decoration: none !important;
    }

    /* Tap/click feedback on mobile: make nav-links ASFA blue when pressed */
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):active,
    .navbar-custom .navbar-nav .nav-item > a.nav-link:active,
    .navbar-custom .navbar-nav .nav-item > .nav-link:active,
    .navbar-custom .navbar-nav .nav-item .nav-link:active {
        color: var(--asfa-primary) !important;
    }

    /* Keyboard focus on mobile: make nav-links ASFA blue */
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):focus,
    .navbar-custom .navbar-nav .nav-item > a.nav-link:focus,
    .navbar-custom .navbar-nav .nav-item > .nav-link:focus,
    .navbar-custom .navbar-nav .nav-item .nav-link:focus,
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):focus-visible,
    .navbar-custom .navbar-nav .nav-item > a.nav-link:focus-visible,
    .navbar-custom .navbar-nav .nav-item > .nav-link:focus-visible,
    .navbar-custom .navbar-nav .nav-item .nav-link:focus-visible {
        color: var(--asfa-primary) !important;
    }

    /* Override generic hover/focus rules on mobile to ASFA blue */
    .navbar-custom .navbar-nav .nav-item > .nav-link:hover,
    .navbar-custom .navbar-nav .nav-item > .nav-link:focus,
    .navbar-custom .navbar-nav .nav-item > a.nav-link:hover,
    .navbar-custom .navbar-nav .nav-item > a.nav-link:focus,
    .navbar-custom .navbar-nav .nav-item .nav-link:hover,
    .navbar-custom .navbar-nav .nav-item .nav-link:focus,
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):hover,
    .navbar-custom .navbar-nav .nav-item > a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):focus {
        color: var(--asfa-primary) !important;
        opacity: 1 !important;
        text-decoration: none !important;
        background-color: transparent !important;
    }

    /* Header links (mobile): mimic .text-dark.text-decoration-underline:hover */
    .navbar-custom .nav-item.d-xl-none .d-flex .nav-link:hover {
        color: var(--asfa-text) !important;
        opacity: 0.7 !important;
        text-decoration: underline !important;
        background-color: transparent !important;
    }

    /* Make dropdown toggle and chevron ASFA blue when expanded on mobile */
    .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle[aria-expanded="true"],
    .navbar-custom .navbar-nav .nav-item > .nav-link.dropdown-toggle.show {
        color: var(--asfa-primary) !important;
    }

    /* Force chevron SVG to ASFA blue on mobile interactive states */
    .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn):hover::after,
    .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn):focus::after,
    .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn):active::after,
    .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn).show::after,
    .navbar-custom .navbar-nav .nav-item > a.dropdown-toggle:not(.btn)[aria-expanded="true"]::after {
        background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 448 512' aria-hidden='true'><path fill='%2302C1D3' d='M207.029 381.476L12.686 187.132c-9.373-9.373-9.373-24.569 0-33.941l22.667-22.667c9.357-9.357 24.522-9.375 33.901-.04L224 284.505l154.745-154.021c9.379-9.335 24.544-9.317 33.901.04l22.667 22.667c9.373 9.373 9.373 24.569 0 33.941L240.971 381.476c-9.373 9.372-24.569 9.372-33.942 0z'/></svg>") !important;
    }

    /* Header links container */
    .navbar-custom .nav-item.d-xl-none .d-flex {
        margin: 0 -0.5rem !important;
    }

    /* Mobile buttons */
    .navbar-custom .mobile-buttons .btn,
    .navbar-custom .mobile-buttons .nav-item .btn {
        text-decoration: none !important;
    }

    .navbar-custom .nav-item.d-xl-none .d-flex .nav-link {
        font-weight: 400 !important;
        line-height: 26px !important;
        font-family: var(--font-family-base) !important;
        padding: 0.5rem !important;
        font-size: var(--font-size-base) !important;
        color: var(--asfa-black) !important;
        text-decoration: underline !important;
    }

    @media (max-width: 375px) {
        .navbar-custom .nav-item.d-xl-none .d-flex {
            flex-direction: column !important;
            align-items: center !important;
            text-align: center !important;
        }

            .navbar-custom .nav-item.d-xl-none .d-flex .nav-link {
                font-size: 13px !important;
            }
    }

    /* Add dividers between sections */
    .navbar-custom .nav-item.d-xl-none.mt-4 {
        padding-top: 1rem !important;
    }

    .navbar-nav.align-items-center {
        gap: 0.5rem !important;
    }

    .btn {
        width: 100%;
        text-align: center;
    }

    /* Move search to bottom in mobile */
    .nav-item--search {
        order: 999;
        width: 100% !important;
        border-bottom: none !important;
        margin-top: 1rem;
    }

        /* Center search icon link */
        .nav-item--search .search-icon-link {
            justify-content: center;
            width: 100%;
        }

    /* Center profile button text */
    .btn-primary.dropdown-toggle {
        justify-content: center;
        text-align: center;
    }

    /* Hide top navigation on tablets and mobile */
    .navbartop {
        display: none !important;
    }

    /* Show specific links on mobile/tablet */
    li.weblink a[title="ASFA Learning Hub"],
    li.weblink a[title="Home"] {
        display: block !important;
    }
}

/* Container Widths - Fluid below xxl breakpoint */
@media (min-width: 576px) and (max-width: 1399px) {
    .container,
    .container-sm,
    .container-md,
    .container-lg,
    .container-xl,
    .container-xxl {
        max-width: none;
        width: 100%;
    }

    .header-container .container {
        padding: 0 28px !important;
    }
}

@media (min-width: 1400px) {
    .container,
    .container-sm,
    .container-md,
    .container-lg,
    .container-xl,
    .container-xxl {
        max-width: 1320px; /* Bootstrap XXL default */
    }
}

/* Utility Classes */
.gap-2 {
    gap: 0.5rem !important;
}

.gap-3 {
    gap: 1rem !important;
}

/* Footer Styles */
#mainContent > div > div.container, .wrapper-body {
    min-height: calc(100vh - var(--hero-height) - (1 * 100px));
}

footer .footer-bottom {
    height: 100px !important;
    background-color: #03173E !important;
    color: #fff !important;
    border-top: 1px solid #015c71 !important;
    padding-top: 10px !important;
}

.footer-bottom p {
    color: #fff !important;
    font: arial,verdana,sans-serif !important;
    text-align: right !important;
    text-decoration: none !important;
    clear: both !important;
    font-size: 12px !important;
    margin-top: 20px !important;
}

/* 9. Info Popup */
.info-popup {
    position: relative;
    display: inline-block;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    /* The actual popup */
    .info-popup .info-popuptext {
        visibility: hidden;
        width: 350px;
        background-color: #02c1d3;
        color: #fff;
        text-align: left;
        border-radius: 6px;
        padding: 10px;
        position: absolute;
        z-index: 99 !important;
        bottom: 125%;
        margin-left: -185px;
        font-size: 0.9rem !important;
        font-weight: 400 !important;
    }

        /* Popup arrow */
        .info-popup .info-popuptext::after {
            content: "";
            position: absolute;
            top: 100%;
            left: 50%;
            margin-left: -5px;
            border-width: 5px;
            border-style: solid;
            border-color: #02c1d3 transparent transparent transparent;
        }

    /* Toggle this class - hide and show the info-popup */
    .info-popup .show {
        visibility: visible;
        -webkit-animation: fadeIn 1s;
        animation: fadeIn 1s;
    }

/* Add animation (fade in the info-popup) */
@-webkit-keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* 10. Link styles */
a, .a {
    font-family: var(--font-family-base) !important;
    font-size: inherit !important;
}

    a:not(.btn) {
        text-decoration: none !important;
        color: var(--asfa-link) !important;
    }

        a:not(.btn):not(.social-icon-link):not(.text-decoration-underline):hover {
            text-decoration: none !important;
            color: var(--asfa-link-hover) !important;
            background-color: transparent !important;
        }

.input-group:not(.has-validation):not(.datetimepicker):not(.input-append) > .dropdown-toggle:nth-last-child(n+3),
.input-group:not(.has-validation):not(.datetimepicker):not(.input-append) > .form-floating:not(:last-child) > .form-control,
.input-group:not(.has-validation):not(.datetimepicker):not(.input-append) > .form-floating:not(:last-child) > .form-select,
.input-group:not(.has-validation):not(.datetimepicker):not(.input-append) > :not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating) {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

/* 11. Filter styles */
.entitylist-filter {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

    .entitylist-filter .card-body {
        padding: 1.5rem 0 !important;
    }

    .entitylist-filter .card-body {
        display: flex !important;
        align-items: flex-end !important;
        gap: 1rem !important;
    }

        .entitylist-filter .card-body > ul {
            display: flex !important;
            flex: 1 !important;
            align-items: flex-end !important;
            gap: 1rem !important;
            margin-bottom: 0 !important;
            flex-wrap: nowrap !important;
            padding-left: 0 !important;
        }

    .entitylist-filter .list-inline-item {
        margin-right: 0 !important;
        padding: 0 !important;
    }

    .entitylist-filter .float-end {
        margin: 0 !important;
        display: flex !important;
        align-items: center !important;
        margin-bottom: 0 !important;
        height: 38px !important; /* Match input height */
    }

.entitylist-filter-option-group {
    display: inline-flex !important;
    flex-direction: column !important;
    margin-bottom: 0 !important;
    min-width: 200px !important;
}

.entitylist-filter-option-group-label {
    font-size: 0.9rem !important;
    color: #6c757d !important;
    margin-bottom: 0.5rem !important;
    font-weight: normal !important;
}

.entitylist-filter .input-group {
    position: relative !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    width: 100% !important;
    border: 1px solid #ced4da !important;
    border-radius: 0.375rem !important;
    height: 38px !important;
}

    .entitylist-filter .input-group .input-group-addon {
        position: absolute !important;
        left: 0 !important;
        top: 0 !important;
        bottom: 0 !important;
        display: flex !important;
        align-items: center !important;
        padding: 0 0.75rem !important;
        background: transparent !important;
        border: none !important;
        z-index: 4 !important;
    }

        .entitylist-filter .input-group .input-group-addon .fa-calendar {
            color: var(--asfa-primary) !important;
        }

    .entitylist-filter .input-group .form-control {
        border: none !important;
        background: transparent !important;
        padding-left: 2.5rem !important;
    }

/* Position datepicker dropdown */
.datepicker.dropdown-menu {
    position: absolute !important;
    top: calc(100% + 2px) !important;
    left: 0 !important;
    z-index: 1000 !important;
    min-width: 250px !important;
    padding: 0.5rem !important;
    margin: 0 !important;
    background-color: #fff !important;
    border: 1px solid #ced4da !important;
    border-radius: 0.375rem !important;
    box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.1) !important;
}

.entitylist-filter-option {
    height: 100% !important;
}

.entitylist-filter .input-group-text {
    background: transparent !important;
    border: none !important;
    color: var(--asfa-primary) !important;
    padding-right: 0 !important;
    cursor: pointer !important;
}

.entitylist-filter .form-control {
    border: none !important;
    box-shadow: none !important;
}

.entitylist-filter .form-select {
    border: none !important;
    box-shadow: none !important;
    padding: 0.375rem 2rem 0.375rem 0.75rem !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%2302C1D3' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 0.75rem center !important;
    background-size: 16px 12px !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    cursor: pointer !important;
    font-size: 0.95rem !important;
    color: var(--asfa-text) !important;
    transition: background-color 0.15s ease-in-out !important;
}

    .entitylist-filter .form-select:hover {
        background-color: #f8f9fa !important;
    }

    .entitylist-filter .form-select:focus {
        outline: none !important;
        background-color: #f8f9fa !important;
    }

.entitylist-filter .btn-entitylist-filter-submit {
    background-color: var(--asfa-primary) !important;
    color: white !important;
    border: none !important;
    padding: 0.5rem 1.5rem !important;
    border-radius: 0.375rem !important;
    transition: background-color 0.2s ease !important;
    margin-bottom: 3px !important;
}

    .entitylist-filter .btn-entitylist-filter-submit:hover {
        background-color: var(--asfa-primary-hover) !important;
    }

@media (max-width: 768px) {
    .entitylist-filter .card-body {
        flex-direction: column !important;
        gap: 1.5rem !important;
    }

        .entitylist-filter .card-body > ul {
            flex-direction: column !important;
            gap: 1.5rem !important;
            width: 100% !important;
        }

    .entitylist-filter .list-inline-item {
        width: 100% !important;
    }

    .entitylist-filter .float-end {
        width: 100% !important;
        margin: 0 !important;
    }

    .entitylist-filter .btn-entitylist-filter-submit {
        width: 100% !important;
        margin-top: 0.5rem !important;
    }

    .entitylist-filter-option-group {
        min-width: 100% !important;
    }
}

/* Download Statement Button */
.entitylist-download.btn-info {
    background-color: var(--asfa-primary) !important;
    border-color: var(--asfa-primary) !important;
    color: #fff !important;
    margin-right: 10px !important;
    font-size: 16px !important;
    line-height: 20px !important;
    font-weight: 400 !important;
    border-radius: 0.375rem !important;
    transition: background-color 0.2s ease !important;
    margin-bottom: 0px !important;
    height: 38px !important;
    display: inline-flex !important;
    align-items: center !important;
}

    .entitylist-download.btn-info:hover {
        background-color: var(--asfa-primary-hover) !important;
    }

.toolbar-actions {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

    .toolbar-actions .input-group {
        margin: 0 !important;
    }

/* 12. Button styles */
input[type=date],
input[type=email],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text]:not(.msos-input),
input[type=url],
select:not([readonly]):not([disabled]),
textarea {
    padding: .375rem .75rem !important;
    border-radius: .375rem !important;
    border: 1px solid #ced4da !important;
}

input[type=text].msos-input {
    padding: 0 !important;
    border-radius: .375rem !important;
    border: none !important;
}

input.form-control:not([readonly]):not([disabled]):not(.msos-input) {
    border: 1px solid #ced4da !important;
}

/* Readonly field text style (exclude lookup inputs) */
.crmEntityFormView input.form-control[readonly]:not(.lookup),
.crmEntityFormView textarea.form-control[readonly]:not(.lookup) {
    font-family: "Inter", Sans-serif !important;
    font-weight: 400 !important;
    font-size: 20px !important;
    color: #2A2C2E !important;
    padding-left: 0 !important;
    border: none !important;
}

.msos-caret-container {
    margin-right: 12px !important;
    background-color: transparent !important;
    margin-right: 12px !important;
}

.msos-glyph:after {
    font-size: 11px !important;
    font-weight: bold !important;
}

.msos-selection {
    max-height: 500px !important;
}

.msos-label .msos-label-text {
    padding: 8px 0px 7px 12px !important;
    word-break: break-word;
}

.crmEntityFormView label.msos-label:hover,
.crmEntityFormView label.msos-label:focus,
.crmEntityFormView label.msos-label:active {
    background-color: var(--bs-primary) !important;
    color: #ffffff !important;
    border: none !important;
}

    /* Ensure item count text turns white when label is hovered/focused/active */
    .crmEntityFormView label:hover .msos-label .msos-label-text .msos-itemcount-text,
    .crmEntityFormView label:focus .msos-label .msos-label-text .msos-itemcount-text,
    .crmEntityFormView label:active .msos-label .msos-label-text .msos-itemcount-text,
    .crmEntityFormView label.msos-label:hover .msos-label-text .msos-itemcount-text,
    .crmEntityFormView label.msos-label:focus .msos-label-text .msos-itemcount-text,
    .crmEntityFormView label.msos-label:active .msos-label-text .msos-itemcount-text {
        color: #ffffff !important;
        border: none !important;
    }

.msos-label .msos-label-text .msos-itemcount-text {
    margin-right: 24px !important;
}

.msos-label .msos-checkbox + .msos-label-text:before {
    right: 0 !important;
    top: 5px !important;
    left: auto !important;
}

.msos-selection-container {
    margin-top: 5px !important;
    padding-top: 0 !important;
}

.msos-current-selection-normal {
    max-height: 38px !important;
    padding-top: 3px !important;
}

.msos-selecteditems-expanded .msos-current-selection-normal {
    max-height: 136px !important;
}

.msos-container:not(.msos-disabled),
.msos-container:not(.msos-disabled) .msos-search,
.msos-container:not(.msos-disabled) .msos-search:focus,
.msos-container:not(.msos-disabled) .msos-search:active {
    border: 1px solid #ced4da !important;
    border-radius: .375rem !important;
    font-family: var(--font-family-base) !important;
    font-size: var(--font-size-base) !important;
    font-weight: var(--font-weight-normal) !important;
    line-height: var(--line-height-base) !important;
    color: var(--asfa-text) !important;
}

.input-group > :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.clearlookupfield,
.launchentitylookup {
    height: 39.93px !important;
}

.launchentitylookup {
    border-top-right-radius: .375rem !important;
    border-bottom-right-radius: .375rem !important;
}

.jquery-bootstrap-pagination {
    border: none !important;
}

    .jquery-bootstrap-pagination .page-item.active .page-link {
        background: var(--asfa-primary) !important;
        color: white !important;
    }

    .jquery-bootstrap-pagination .page-link:hover {
        color: var(--asfa-primary-hover) !important;
    }

.float-end .entitylist-search .btn.btn-default {
    height: 39.93px !important;
    border-top-right-radius: 5px !important;
    border-bottom-right-radius: 5px !important;
}

button.cancel.btn.btn-default,
button.btn.btn-default.float-end.remove-value {
    border-radius: 5px !important;
}

button .msos-selecteditems-toggle,
button .msos-selecteditems-toggle:hover,
button .msos-selecteditems-toggle:focus,
button .msos-selecteditems-toggle:active,
button .msos-caret-button,
button .msos-caret-button:hover,
button .msos-caret-button:focus,
button .msos-caret-button:active {
    background-color: #f2f2f2 !important;
}

.btn-primary i {
    color: #fff !important;
}

.btn,
.navbar-custom .btn,
button,
input[type=button],
input[type=submit],
input[type=reset],
.btn-primary,
.btn-primary.dropdown-toggle,
.btn-outline-secondary,
.btn-default,
.btn-consumer,
.navbar-custom .mobile-buttons .button-row .btn {
    font-family: "Inter", Sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 20px !important;
    padding: 6px 20px !important;
    border-radius: 5px !important;
}

    /* Hard-enforce button typography on interactive states as well */
    .btn:hover,
    .btn:focus,
    .btn:active,
    button:hover,
    button:focus,
    button:active,
    input[type=button]:hover,
    input[type=button]:focus,
    input[type=button]:active,
    input[type=submit]:hover,
    input[type=submit]:focus,
    input[type=submit]:active,
    input[type=reset]:hover,
    input[type=reset]:focus,
    input[type=reset]:active,
    .btn-primary:hover,
    .btn-primary.dropdown-toggle,
    .btn-primary.dropdown-toggle:hover,
    .btn-primary.dropdown-toggle:focus,
    .btn-primary.dropdown-toggle:active,
    .navbar-custom .btn:hover,
    .navbar-custom .btn:focus,
    .navbar-custom .btn:active,
    .btn-primary:focus,
    .btn-primary:active,
    .btn-outline-secondary:hover,
    .btn-outline-secondary:focus,
    .btn-outline-secondary:active,
    .btn-default:hover,
    .btn-default:focus,
    .btn-default:active,
    .btn-consumer:hover,
    .btn-consumer:focus,
    .btn-consumer:active,
    .navbar-custom .mobile-buttons .button-row .btn:hover,
    .navbar-custom .mobile-buttons .button-row .btn:focus,
    .navbar-custom .mobile-buttons .button-row .btn:active {
        font-family: "Inter", Sans-serif !important;
        font-size: 16px !important;
        font-weight: 400 !important;
        line-height: 20px !important;
    }

.badge, .badge.badgeColor {
    padding: 4px 8px;
}

#EventAmostSoldoutMessage {
    font-size: var(--font-size-base);
    padding: 12px;
}

button.form-close {
    font-family: "Inter", Sans-serif !important;
    position: relative !important;
    font-size: 32px !important;
    font-weight: 400 !important;
}

table td, table th {
    line-height: 1.5 !important;
    border: none !important;
}

/* Datetimepicker input/button layout without IDs */
.input-group.datetimepicker {
    position: relative !important;
}

    .input-group.datetimepicker > input.form-control {
        border-top-right-radius: .375rem !important;
        border-bottom-right-radius: .375rem !important;
        padding-right: 50px !important;
    }

    .input-group.datetimepicker > .input-group-addon.btn {
        position: absolute !important;
        top: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 50px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-top-right-radius: .375rem !important;
        border-bottom-right-radius: .375rem !important;
        border-color: var(--asfa-primary) !important;
        background-color: white !important;
        color: var(--asfa-primary) !important;
    }

    /* Remove inset borders/shadows on hover/focus for datetimepicker */
    .input-group.datetimepicker,
    .input-group.datetimepicker:hover,
    .input-group.datetimepicker:focus,
    .input-group.datetimepicker:focus-within {
        box-shadow: none !important;
    }

        .input-group.datetimepicker > input.form-control:hover,
        .input-group.datetimepicker > input.form-control:focus,
        .input-group.datetimepicker > input.form-control:active,
        .input-group.datetimepicker > .input-group-addon.btn:hover,
        .input-group.datetimepicker > .input-group-addon.btn:focus,
        .input-group.datetimepicker > .input-group-addon.btn:active {
            box-shadow: none !important;
            outline: none !important;
        }

.bootstrap-datetimepicker-widget table td.active, .bootstrap-datetimepicker-widget table td.active:hover,
.bootstrap-datetimepicker-widget tr td.active button,
.bootstrap-datetimepicker-widget table td.today:before {
    background-color: var(--asfa-primary) !important;
}

.button2:focus,
.button2.focus,
.button2:focus-visible,
.btn-default:focus,
.btn-default.focus,
.btn-default:focus-visible {
    color: white !important;
}

table tbody > tr:nth-child(odd) > td,
table tbody > tr:nth-child(odd) > th,
table tbody > tr:hover > td,
table tbody > tr:hover > th,
table .table-striped > tbody > tr:nth-of-type(odd) {
    background-color: white !important;
}

.columnBlockLayout {
    margin-top: 0 !important;
}

/* font styles */
h1:not(#HeroTitle), .h1,
h2, .h2,
h3, .h3 {
    margin-top: 0 !important;
    padding-top: 21px !important;
}

h1, h1#HeroTitle {
    font-family: "Inter", Sans-serif !important;
    font-size: 70px !important;
    font-weight: 400 !important;
    line-height: 80px !important;
    letter-spacing: -2px !important;
    color: #FFFFFF !important;
}

span#EventAvailabilityLabel {
    color: #FFFFFF !important;
}

h1.modal-title {
    font-family: "Inter", Sans-serif !important;
    font-size: 32px !important;
    line-height: 34px !important;
    color: black !important;
    font-weight: 400 !important;
    letter-spacing: -1px !important;
    margin-top: 0 !important;
    padding: 16px !important;
}

h2 {
    font-family: "Inter", Sans-serif !important;
    font-size: 46px !important;
    font-weight: 400 !important;
    line-height: 50px !important;
    letter-spacing: -0.46px !important;
}

h3, .crmEntityFormView .section-title {
    font-family: "Inter", Sans-serif !important;
    font-size: 32px !important;
    line-height: 34px !important;
    font-weight: 400 !important;
    letter-spacing: -1px !important;
}

h4 {
    font-family: "Inter", Sans-serif !important;
    font-size: 20px !important;
    font-weight: 500 !important;
}

label .crmEntityFormView .field-label {
    font-family: "Inter", Sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 20px !important;
}

body, p, .form-control {
    font-family: "Inter", Sans-serif !important;
    font-size: var(--font-size-base) !important;
    font-weight: var(--font-weight-normal) !important;
    line-height: var(--line-height-base) !important;
}

button#apply-promo-btn {
    height: 39.33px !important;
}

/* alert styles */
.alert-warning {
    background-color: #ffffff !important;
    border: none !important;
    color: var(--asfa-text) !important;
}


/* -----------------------------------------      CRM entity lists    --------------  */

/* removess the table outside border, leaving only the row borders*/
.entitylist {
    border: none !important;
}
    /* Keep table respecting your width overrides */
    .entitylist table,
    [id^="EntityListControl"] table {
        table-layout: fixed;
        width: 100%;
    }


    /* Let ALL headers & cells wrap as needed */
    .entitylist th,
    .entitylist td {
        white-space: normal; /* allow wrapping */
        overflow-wrap: anywhere; /* break long tokens (IDs, emails) */
        word-break: break-word; /* cross-browser support */
        overflow: visible;
        text-overflow: clip;
    }

        /* Remove built-in min-width on the primary (linked) column so it can wrap */
        .entitylist th.primary-field,
        .entitylist td.primary-field {
            min-width: 0;
        }

        /* Ensure links don�t act like wide blocks */
        .entitylist td a,
        .entitylist th a {
            display: inline;
        }

.crmEntityFormView,
.entitylist,
.modal-content,
.popover-content {
    border: none !important;
}

/* -----------------------   bread crumbs  ------------------- */


.breadcrumb {
    color: #02c1d3 !important
}

/*  -------------------- section layouts --------------------------- */
/*primary color */
.sectionPrimaryColor {
    background-color: #02c1d3 !important;
    color: #ffffff !important;
}
/*------------My invoices page custom CSS for specific elements  ------  */

/* set up the balance colum to reserve spaces for the send now and pay buttons*/
td[data-attribute='asfa_portaloutstandingbalance'] {
    position: relative;
    white-space: nowrap;
    padding-right: 144px; /* reserve ~ width of two buttons + gap */
}

    /* pin the actions to the right edge, vertically centered */
    td[data-attribute='asfa_portaloutstandingbalance'] .invoice-actions {
        position: absolute;
        right: 8px;
        top: 50%;
        transform: translateY(-50%);
        display: inline-flex;
        gap: 6px;
    }

.btn-outline-secondary:hover {
    border-color: var(--asfa-primary-hover) !important;
    color: var(--asfa-primary-hover) !important;
    background-color: white !important;
}

/* Icons */
.fa-check {
    color: var(--asfa-primary) !important;
}


/***** CPD SUMMARY *****/
#cpd-summary {
    background: #f8f9fa;
    border-radius: 8px;
    gap: 1rem;
}

    /* Each summary column */
    #cpd-summary .cpd-block {
        border-right: 0;
        padding-bottom: 1rem;
    }

@media (min-width: 768px) {
    #cpd-summary .cpd-block {
        border-right: 1px solid #dee2e6;
        padding-bottom: 0;
    }

        /* Remove right border on last column */
        #cpd-summary .cpd-block:last-child {
            border-right: 0;
        }
}

/* Value styling */
#cpd-summary .cpd-value {
    color: #02c1d3;
    font-size: 1.5rem;
    font-weight: bold;
}


/* Style the host element */
gmp-place-autocomplete {
    display: block;
    width: 100%;
    height: 48px;
    border-radius: 8px;
    box-shadow: none;
    background-color: #ffffff;
    color-scheme: light;
    font-family: "Inter", Sans-serif !important;
    font-size: 16px;
    border: 1px solid #ccc;
}

/* Use exposed CSS custom properties */
gmp-place-autocomplete {
    --gmp-mat-color-surface: #ffffff;
    --gmp-mat-color-on-surface: #333333;
    --gmp-mat-color-primary: #1a73e8;
    --gmp-mat-color-outline-decorative: #e0e0e0;
    --gmp-mat-font-family: "Inter", Sans-serif !important;
    --gmp-mat-font-body-medium: 16px;
    --gmp-mat-font-label-large: 14px;
}

    /* Optional: style exposed shadow parts if available */
    gmp-place-autocomplete::part(input) {
        font-size: 16px;
        padding: 10px 12px;
        border: none;
        box-shadow: none;
        background-color: transparent;
    }

    gmp-place-autocomplete::part(input-container) {
        background-color: #ffffff;
        border-radius: 8px;
    }
/*
==========================================================================
12. Spinner (loading)
==========================================================================
*/
#global-spinner {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(255, 255, 255, 0.8); /* Light overlay */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999; /* Ensure it stays on top */
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}

/* ? Spinner animation */
.spinner {
    width: 50px;
    height: 50px;
    border: 5px solid #02c1d3; /* Customize color */
    border-top: 5px solid transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}
