/* ========================================
   REVAMP GLOBAL STYLES
   Shared styles for all revamped templates
   ======================================== */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

/* ========================================
   HOME REVAMP - MODERN HEADER STYLES
   ======================================== */

/* Reset and base styles for header */
.header {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%) !important;
    background-color: transparent !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15) !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
    /* Removed transition from background to prevent white flash during fast scroll */
    transition: box-shadow 0.3s ease !important;
    margin: 0 !important;
    padding: 0 !important;
    /* Force hardware acceleration */
    will-change: box-shadow;
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}

/* Remove any default margins/padding from body and wrapper */
* {
    box-sizing: border-box;
}

html, body {
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.wrapper {
    margin: 0;
    padding: 0;
}

/* Ensure header starts at the very top */
.header {
    margin-top: 0;
    padding-top: 0;
    top: 0!important;
}

/* Main content styling */
.main {
    padding-top: 0!important;
}

.header .shell {
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 120px;
}

/* Logo styling */
.header .logo {
    display: flex;
    align-items: center;
    text-decoration: none;
    transition: all 0.3s ease;
}

.header .logo:hover {
    transform: translateX(5px);
}

.header .logo img {
    transition: all 0.3s ease;
    height: 55px;
}
    
/* Mobile logo adjustments */
@media (max-width: 768px) {
    .header .logo img {
        max-width: 150px;
        height: auto;
    }
}

/* Navigation styling */
.header__actions {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: space-evenly!important;
}

.nav-header {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 4px;
    align-items: center;
}

.nav-header li {
    position: relative;
}

.nav-header a {
    color: #ffffff;
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 15px;
    padding: 12px 0;
    transition: all 0.3s ease, transform 0.3s ease;
    position: relative;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.nav-header a:hover {
    color: #00d4ff;
    transform: translateY(-2px);
}

.nav-header a::after {
    content: '';
    position: absolute;
    bottom: 8px;
    left: 0;
    width: 0;
    height: 2px;
    background: linear-gradient(90deg, #00d4ff, #0099cc);
    transition: width 0.3s ease;
}

.nav-header a:hover::after {
    width: 100%;
}

/* Ensure hover works on parent menu items even when they have mega menu */
.nav-header > li > a:hover {
    color: #00d4ff !important;
    transform: translateY(-2px) !important;
}

.nav-header > li > a:hover::after {
    width: 100% !important;
}

/* Specifically target has-mega-menu items to override bundle.css */
.nav-header li.has-mega-menu > a:hover {
    color: #00d4ff !important;
    transform: translateY(-2px) !important;
}

.nav-header li.has-mega-menu > a:hover::after {
    width: 100% !important;
    opacity: 1 !important;
}

/* Contact button in right actions */
.contact-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #ffffff;
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 14px;
    padding: 10px 20px;
    border-radius: 25px;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.contact-btn:hover {
    background: rgba(0, 212, 255, 0.2);
    border-color: #00d4ff;
    color: #00d4ff;
    transform: translateY(-2px);
}

/* Right side actions */
.header-actions-right {
    display: flex;
    align-items: center;
    gap: 20px;
}

/* Login button - same style as Contact */
.login-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #ffffff;
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 14px;
    padding: 10px 20px;
    border-radius: 25px;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.login-btn:hover {
    background: rgba(0, 212, 255, 0.2);
    border-color: #00d4ff;
    color: #00d4ff;
    transform: translateY(-2px);
}

.login-btn i {
    font-size: 16px;
}

/* Search button styling */
.search-trigger {
    background: #ff6b35;
    color: #fff;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(255, 107, 53, 0.3);
}

.search-trigger:hover {
    background: #e55a2b;
    transform: translateY(-2px) scale(1.05);
    box-shadow: 0 8px 25px rgba(255, 107, 53, 0.4);
}

/* Mobile header */
.header__actions-mobile {
    display: none;
    align-items: center;
    gap: 15px;
}

.nav-trigger {
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 30px;
    height: 30px;
    justify-content: center;
    cursor: pointer;
}

.nav-trigger span {
    width: 100%;
    height: 3px;
    background: #fff;
    border-radius: 2px;
    transition: all 0.3s ease;
}

.nav-trigger:hover span {
    background: #00d4ff;
}

/* Search form styling */
.form-header {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(26, 26, 46, 0.98);
    backdrop-filter: blur(10px);
    padding: 20px 0;
    transform: translateY(-100%);
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    z-index: 999;
}

.form-header.active {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
}

.form-header form {
    max-width: 600px;
    margin: 0 auto;
    display: flex;
    gap: 15px;
    align-items: center;
}

.form-header .input input {
    width: 100%;
    padding: 15px 20px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    font-size: 16px;
    transition: all 0.3s ease;
}

.form-header .input input:focus {
    outline: none;
    border-color: #00d4ff;
    background: rgba(255, 255, 255, 0.15);
    box-shadow: 0 0 20px rgba(0, 212, 255, 0.2);
}

.form-header .input input::placeholder {
    color: rgba(255, 255, 255, 0.7);
}

.form-header .hs-button {
    background: linear-gradient(135deg, #00d4ff, #0099cc);
    border: none;
    color: #fff;
    padding: 15px 25px;
    border-radius: 30px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 16px;
}

.form-header .hs-button:hover {
    background: linear-gradient(135deg, #0099cc, #0077aa);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 212, 255, 0.3);
}

.searchTrigger {
    position: absolute;
    top: 20px;
    right: 20px;
    color: #fff;
    font-size: 24px;
    text-decoration: none;
    font-weight: bold;
    transition: all 0.3s ease;
}

.searchTrigger:hover {
    color: #00d4ff;
    transform: scale(1.1);
}

/* ========================================
   MEGAMENU REVAMP STYLES
   ======================================== */

/* Body overlay when megamenu is open */
body.megamenu-open::before {
    content: '';
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    z-index: 998;
    pointer-events: none;
    opacity: 0;
    animation: fadeInOverlay 0.3s ease forwards;
}

@keyframes fadeInOverlay {
    to {
        opacity: 1;
    }
}

/* Ensure header and megamenu are above overlay */
.header {
    position: relative;
    z-index: 1000;
}

.nav-header .nav__mega-menu {
    position: relative;
    z-index: 999;
}

/* Mega menu container - NO backdrop-filter for instant performance */
.nav-header .nav__mega-menu {
    position: absolute !important;
    top: 100% !important;
    left: 10px !important;
    right: 10px !important;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%) !important;
    padding: 30px 30px 30px 20px !important;
    border-radius: 0 0 16px 16px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    border-top: 2px solid rgba(182, 255, 58, 0.3);
    z-index: 999;
}

/* Remove all blue lines/underlines from megamenu */
/* Only target links INSIDE the mega menu dropdown, not the parent trigger link */
.nav-header .nav__mega-menu > * a {
    border-bottom: none !important;
}

.nav-header .nav__mega-menu > * a:hover {
    border-bottom: none !important;
    text-decoration: none !important;
}

/* Only target links INSIDE the mega menu dropdown, not the parent trigger link */
.nav-header .nav__mega-menu .menu__aside a::after,
.nav-header .nav__mega-menu .menu__aside a::before,
.nav-header .nav__mega-menu .menu__content a::after,
.nav-header .nav__mega-menu .menu__content a::before {
    border-bottom: none !important;
}

/* Sidebar navigation */
.nav-header .nav__mega-menu .menu__aside {
    flex: 0 0 240px;
    max-width: 240px;
    list-style: none;
    margin: 0;
    padding: 0;
}

/* "Find your course" heading button */
.nav-header .nav__mega-menu .menu__aside h6 {
    background: linear-gradient(#1a1a2e, #1a1a2e) padding-box,
                linear-gradient(90deg, #b6ff3a, #00d4ff) border-box !important;
    background-color: transparent !important;
    color: #dfefff !important;
    text-transform: uppercase;
    text-align: center;
    font-size: 13px;
    font-weight: 700;
    border-radius: 25px;
    border: 2px solid transparent;
    margin-right: 20px;
    margin-bottom: 20px;
    padding: 14px 20px !important;
    letter-spacing: 1px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
    position: relative;
    isolation: isolate;
}

.nav-header .nav__mega-menu .menu__aside h6:hover {
    background: linear-gradient(90deg, #b6ff3a, #00d4ff) padding-box,
                linear-gradient(90deg, #b6ff3a, #00d4ff) border-box !important;
    color: #06202c !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(182, 255, 58, 0.3);
}

.nav-header .nav__mega-menu .menu__aside h6 a {
    color: inherit !important;
    text-decoration: none;
    display: block;
    background-color: transparent !important;
}

.nav-header .nav__mega-menu .menu__aside h6 a:hover {
    background-color: transparent !important;
    color: inherit !important;
}

/* Sidebar menu items */
.nav-header .nav__mega-menu .menu__aside li + li {
    margin-top: 8px;
}

.nav-header .nav__mega-menu .menu__aside a {
    padding: 12px 18px;
    display: block;
    color: rgba(255, 255, 255, 0.9);
    text-decoration: none;
    border-radius: 8px;
    font-family: 'Poppins', sans-serif;
    font-size: 14px;
    font-weight: 500;
    border-left: 3px solid transparent;
}

.nav-header .nav__mega-menu .menu__aside a:hover,
.nav-header .nav__mega-menu .menu__aside li.active a {
    background: rgba(255, 255, 255, 0.15) !important;
    background-color: rgba(255, 255, 255, 0.15) !important;
    color: #b6ff3a !important;
    border-left-color: #b6ff3a;
    border-bottom: none !important;
    border-top: none !important;
    border-right: none !important;
    text-decoration: none !important;
    transform: translateX(5px);
}

/* Remove any blue lines/underlines from hover states */
.nav-header .nav__mega-menu .menu__aside a:hover::after,
.nav-header .nav__mega-menu .menu__aside a:hover::before,
.nav-header .nav__mega-menu .menu__aside li.active a::after,
.nav-header .nav__mega-menu .menu__aside li.active a::before {
    display: none !important;
    content: none !important;
}

/* Content area */
.nav-header .nav__mega-menu .menu__content {
    flex: 1 1;
    margin-left: 20px;
}

.nav-header .nav__mega-menu .menu__content ul {
    list-style: none;
    margin: 0;
    padding: 0;
    height: 100%;
}

.nav-header .nav__mega-menu .menu__content li {
    background: rgba(255, 255, 255, 0.05) !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    margin-left: 0;
    height: 100%;
    border-radius: 12px;
    padding: 25px;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Tab items (Brand/Topic) */
.nav-header .nav__mega-menu .tabs__item {
    display: block;
}

.nav-header .nav__mega-menu .tabs__item h5 {
    font-family: 'Poppins', sans-serif;
    font-size: 18px;
    font-weight: 700;
    color: #b6ff3a;
    margin: 0 0 20px 0;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding-bottom: 10px;
    border-bottom: 2px solid rgba(182, 255, 58, 0.3);
}

.nav-header .nav__mega-menu .tabs__item ul {
    columns: 3 auto;
    column-gap: 20px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.nav-header .nav__mega-menu .tabs__item ul li {
    margin: 0 0 12px 0;
    padding: 0;
    background: transparent;
    border: none;
    height: auto;
    break-inside: avoid;
    width: 100%;
    display: inline-block;
}

.nav-header .nav__mega-menu .tabs__item ul li a {
    display: block;
    width: 100%;
    padding: 8px 14px;
    background: rgba(182, 255, 58, 0.1);
    color: #ffffff;
    text-decoration: none !important;
    border-radius: 6px;
    font-family: 'Poppins', sans-serif;
    font-size: 14px;
    font-weight: 500;
    border: 1px solid rgba(182, 255, 58, 0.2);
    border-bottom: 1px solid rgba(182, 255, 58, 0.2) !important;
    box-sizing: border-box;
}

.nav-header .nav__mega-menu .tabs__item ul li a:hover {
    background: rgba(182, 255, 58, 0.2);
    color: #b6ff3a;
    border-color: #b6ff3a;
    border-bottom: 1px solid #b6ff3a !important;
    text-decoration: none !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(182, 255, 58, 0.2);
}

/* Remove any blue lines from content area links */
.nav-header .nav__mega-menu .tabs__item ul li a:hover::after,
.nav-header .nav__mega-menu .tabs__item ul li a:hover::before,
.nav-header .nav__mega-menu .tabs__item ul li a::after,
.nav-header .nav__mega-menu .tabs__item ul li a::before {
    display: none !important;
    content: none !important;
}

/* Secondary tabs (Upcoming Classes, Guaranteed to Run) */
.nav-header .nav__mega-menu .tabs__item-secondary {
    padding: 0;
}

.nav-header .nav__mega-menu .tabs__item-secondary ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.nav-header .nav__mega-menu .tabs__item-secondary ul li {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    padding: 0;
    height: auto;
}

.nav-header .nav__mega-menu .tabs__item-secondary ul li:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(182, 255, 58, 0.3);
}

.nav-header .nav__mega-menu .tabs__item-secondary ul li a {
    display: block;
    padding: 16px 20px;
    text-decoration: none !important;
    color: #ffffff;
    font-family: 'Poppins', sans-serif;
    border-bottom: none !important;
}

.nav-header .nav__mega-menu .tabs__item-secondary ul li a:hover {
    text-decoration: none !important;
    border-bottom: none !important;
}

/* Remove any blue lines from secondary tabs */
.nav-header .nav__mega-menu .tabs__item-secondary ul li a:hover::after,
.nav-header .nav__mega-menu .tabs__item-secondary ul li a:hover::before,
.nav-header .nav__mega-menu .tabs__item-secondary ul li a::after,
.nav-header .nav__mega-menu .tabs__item-secondary ul li a::before {
    display: none !important;
    content: none !important;
}

.nav-header .nav__mega-menu .tabs__item-secondary ul li a p {
    margin: 0 0 8px 0;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 400;
}

.nav-header .nav__mega-menu .tabs__item-secondary ul li a h6 {
    margin: 0;
    font-size: 15px;
    font-weight: 600;
    color: #b6ff3a !important;
    background: none !important;
    background-color: transparent !important;
    padding: 0 !important;
    border-radius: 0;
    text-align: left;
    text-transform: none;
    letter-spacing: 0;
    box-shadow: none;
}

.nav-header .nav__mega-menu .tabs__item-secondary ul li a:hover h6 {
    color: #8bdfff;
}

/* Tertiary tabs (Locations) */
.nav-header .nav__mega-menu .tabs__item-tertiary {
    color: rgba(255, 255, 255, 0.9);
    font-family: 'Poppins', sans-serif;
    line-height: 1.6;
    display: flex;
}

.nav-header .nav__mega-menu .tabs__item-tertiary ul {
    flex: 0 0 36.5%;
    max-width: 36.5%;
    border-right: 1px solid rgba(182, 255, 58, 0.2);
    font-size: 14px;
    padding-right: 54px;
    padding-bottom: 70px;
    list-style: none;
    margin: 0;
}

.nav-header .nav__mega-menu .tabs__item-tertiary li + li {
    margin-top: 23px;
}

/* State titles (h6) */
.nav-header .nav__mega-menu .tabs__item-tertiary h6 {
    text-transform: uppercase;
    letter-spacing: 0.125em;
    color: #b6ff3a !important;
    margin-bottom: 15px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
}

/* Location links */
.nav-header .nav__mega-menu .tabs__item-tertiary a {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.9) !important;
    display: block;
    position: relative;
    z-index: 2;
    text-decoration: none !important;
    padding: 8px 0;
    border-bottom: none !important;
}

.nav-header .nav__mega-menu .tabs__item-tertiary a::after {
    content: '';
    position: absolute;
    z-index: -1;
    top: 0;
    left: -10px;
    right: -10px;
    bottom: 0;
    border-radius: 6px;
    background: rgba(182, 255, 58, 0.15) !important;
    background-color: rgba(182, 255, 58, 0.15) !important;
    opacity: 0;
}

.nav-header .nav__mega-menu .tabs__item-tertiary a:hover {
    color: #b6ff3a !important;
}

.nav-header .nav__mega-menu .tabs__item-tertiary a:hover::after {
    opacity: 1;
}

/* Description section */
.nav-header .nav__mega-menu .tabs__item-tertiary .tab__entry {
    margin-top: 0;
    padding-top: 0;
    padding-left: 60px;
    color: rgba(255, 255, 255, 0.85) !important;
    font-weight: 400;
    font-size: 16px;
    font-family: 'Poppins', sans-serif;
    letter-spacing: -0.027em;
    line-height: 1.6;
    border-top: none;
}

.nav-header .nav__mega-menu .tabs__item-tertiary .tab__entry h4 {
    font-size: 20px;
    margin-bottom: 15px;
    letter-spacing: 0;
    color: #ff6b35 !important;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
}

.nav-header .nav__mega-menu .tabs__item-tertiary .tab__entry p {
    color: rgba(255, 255, 255, 0.8) !important;
    font-family: 'Poppins', sans-serif;
}

/* Active state - removed arrow, let default sliding line work */
/* .nav-header li.has-mega-menu.active > a:after {
    border-color: transparent transparent #16213e transparent;
} */

/* Responsive megamenu */
@media (max-width: 1200px) {
    .nav-header .nav__mega-menu .tabs__item ul {
        columns: 2 auto;
    }
}

@media (max-width: 900px) {
    .nav-header .nav__mega-menu .tabs__item ul {
        columns: 1 auto;
    }
}

@media (max-width: 1023px) {
    .nav-header .nav__mega-menu {
        display: none !important;
    }
}

/* ========================================
   SUBMENU STYLES (Training Solutions, etc.)
   Matching megamenu design system
   ======================================== */

/* Standard dropdown submenu */
.nav-header .sub-menu {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    min-width: 320px;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%) !important;
    border: 1px solid rgba(182, 255, 58, 0.2) !important;
    border-radius: 12px !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4) !important;
    padding: 16px !important;
    margin: 0 !important;
    list-style: none !important;
    z-index: 1000 !important;
    display: none;
}

/* Show submenu on click (via .active class added by JavaScript) */
.nav-header .menu-item.active > .sub-menu {
    display: block;
}

/* Submenu items */
.nav-header .sub-menu li {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.nav-header .sub-menu li + li {
    margin-top: 2px !important;
}

/* Submenu links */
.nav-header .sub-menu a {
    display: block !important;
    padding: 10px 18px !important;
    padding-left: 22px !important;
    color: rgba(255, 255, 255, 0.9) !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    position: relative;
    overflow: visible;
    border-left: 3px solid transparent !important;
}

/* Remove default link behaviors */
.nav-header .sub-menu a::before,
.nav-header .sub-menu a::after {
    display: none !important;
    content: none !important;
}

/* Hover effect for submenu links */
.nav-header .sub-menu a:hover {
    background: rgba(182, 255, 58, 0.15) !important;
    color: #b6ff3a !important;
    border-left-color: #b6ff3a !important;
    box-shadow: none !important;
}

/* Current/active menu item */
.nav-header .sub-menu .current-menu-item > a,
.nav-header .sub-menu .current_page_item > a {
    background: transparent !important;
    color: #b6ff3a !important;
    border-left-color: #b6ff3a !important;
}

/* Parent menu item - keep same style as other items (no arrow, use default sliding line) */
/* The default .nav-header a::after already handles the sliding line effect */

/* Ensure mega menu parent link has the sliding line effect */
.nav-header li.has-mega-menu > a::after {
    content: '' !important;
    position: absolute !important;
    bottom: 8px !important;
    left: 0 !important;
    width: 0 !important;
    height: 2px !important;
    background: linear-gradient(90deg, #00d4ff, #0099cc) !important;
    opacity: 1 !important;
    transition: width 0.3s ease !important;
}

.nav-header li.has-mega-menu > a:hover::after {
    width: 100% !important;
    opacity: 1 !important;
}

/* Submenu positioning adjustments for different parent items */
.nav-header > .menu-item:nth-child(n+3) > .sub-menu {
    left: auto;
    right: 0;
}

/* Hide submenu on mobile */
@media (max-width: 1023px) {
    .nav-header .sub-menu {
        display: none !important;
    }
}

/* Responsive design */
@media (max-width: 1024px) {
    .header .shell {
        padding: 0 15px;
    }
    
    .nav-header {
        gap: 20px;
    }
    
    .nav-header a {
        font-size: 15px;
    }
    
    .header-actions-right {
        gap: 15px;
    }
    
    .login-btn {
        padding: 10px 20px;
        font-size: 13px;
    }
}

@media (max-width: 768px) {
    .header__actions {
        display: none;
    }
    
    .header__actions-mobile {
        display: flex;
    }
    
    .header .shell {
        height: 70px;
    }
    
    .header .logo {
        font-size: 20px;
    }
    
    .form-header form {
        flex-direction: column;
        gap: 10px;
    }
    
    .form-header .input input {
        padding: 12px 16px;
        font-size: 14px;
    }
    
    .form-header .hs-button {
        padding: 12px 20px;
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .header .shell {
        padding: 0 10px;
    }
    
    .header .logo {
        font-size: 18px;
    }
    
    .header .logo .label {
        margin-left: 8px;
    }
}

/* Removed header scroll effect - no longer needed */

/* ===============================
   FOOTER REVAMP (reference1.png)
   =============================== */
.footer{
    background: linear-gradient(180deg, #0b1e2a 0%, #081720 100%);
    color: #dfe7ee;
    padding: 6rem 0;
    border-top: 1px solid rgba(255,255,255,.06);
}
.footer .shell{ max-width: 1240px; margin: 0 auto; padding: 0 20px; }
.footer__inner{ display:flex; flex-wrap:wrap; gap: 40px; }
.footer__col{ flex: 1 1 220px; min-width: 220px; }
.footer__col--logo{ flex: 1 1 320px; min-width: 300px; }
.footer .logo{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.footer .logo .label{ color:#fff; display: none; }
.footer .nav-footer{ list-style:none; padding:0; margin: 16px 0 0; display:grid; gap:5px; }
.footer .nav-footer a{ color:#c7d5e1; text-decoration:none; font-size:14px; }
.footer .nav-footer a:hover{ color:#00d4ff; }
.footer a{ color:#c7d5e1; }
.footer a:hover{ color:#00d4ff; }
.footer__col p{ margin: 6px 0; }

/* Socials - lime circles like reference */
.footer .socials{ list-style:none; display:flex; gap:10px; padding:0; margin:2rem 0 0!important;  justify-content: flex-start;}
.footer .socials a{ width:36px; height:36px; display:grid; place-items:center; border-radius:50%; background:#74d62e; color:#0a1f2b; text-decoration:none; }
.footer .socials a:hover{ background:#89e142; transform: translateY(-2px); }
.footer .socials i{ font-size:15px; }
.socials li{padding: 0!important;}

/* Address block spacing/typography */
.footer__col--logo p{ color:#c7d5e1; font-size:14px; line-height:1.6; }
.footer__col--logo a[href^="tel"]{ font-weight:700; color:#fff; text-decoration:none; }
.footer__col--logo a[href^="tel"]:hover{ color:#00d4ff; }

/* Bottom wrap spacing */
.wrapper + .footer{ margin-top: 0; }

/* ===============================
   SUBSCRIBE CALLOUT REVAMP
   =============================== */
.section-callout--revamp{
    position: relative;
    background: radial-gradient(1200px 500px at 0% 0%, rgba(0, 212, 255, .08) 0%, rgba(0,0,0,0) 60%),
                linear-gradient(180deg, #0c2836 0%, #093142 100%);
    padding: 4.5rem 0 4rem;
    color: #eaf6ff;
    overflow: hidden;
    border-bottom: 1px solid rgba(255,255,255,.05);
}
.section-callout--revamp:before{
    content:'';
    position:absolute; inset:0;
    background: radial-gradient(800px 300px at 10% 20%, rgba(116,214,46,.08), rgba(0,0,0,0) 60%),
                radial-gradient(700px 260px at 60% 0%, rgba(0,212,255,.08), rgba(0,0,0,0) 70%);
    pointer-events:none;
}
/* Decorative SVG positioning */
.revamp-deco{ position:absolute; left:0; top:-40px; width:min(42%, 520px); height:auto; opacity:.4; pointer-events:none; }
.section-callout--revamp .shell{ max-width:1240px; margin:0 auto; padding:0 20px; position: relative; z-index: 999; }
.callout--revamp{ display:grid; grid-template-columns: 1.1fr 1fr; gap: 60px; align-items:center; }
.revamp-eyebrow{ 
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 80%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
    letter-spacing:.28em; text-transform:uppercase; font-weight:700; margin:0 0 6px; font-size:14px;
}
.revamp-title{ 
    background: linear-gradient(90deg, #b6ff3a 0%, #bbeaff 70%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
    font-size: clamp(36px, 5vw, 60px); line-height:1.25; margin:0 0 12px; max-width: 680px; font-weight:800;
}
.revamp-subcopy{ color:#cfe6f5; font-size: clamp(16px, 2vw, 20px); margin:.5rem 0 0; }

/* Gravity Forms overrides inside callout */
.section-callout--revamp .gform_wrapper{ --border: rgba(255,255,255,.25); --accent:#00d4ff; --accent2:#89e142; }
.section-callout--revamp .gform_heading, 
.section-callout--revamp .gform_title, 
.section-callout--revamp .gform_description{ display:none; }
.section-callout--revamp .gform_wrapper form{ display:block; }
.section-callout--revamp .gform_wrapper .gfield_label{ 
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
    font-weight:700; text-transform:uppercase; letter-spacing:.15em; font-size:14px; 
}
.section-callout--revamp .gform_wrapper input[type="text"],
.section-callout--revamp .gform_wrapper input[type="email"],
.section-callout--revamp .gform_wrapper input[type="search"]{
    width:100%;
    border:none; border-bottom:2px solid transparent;
    background: transparent; color:#fff; padding:.9rem .2rem; border-radius:0;
    box-shadow:none; outline:none;
    border-image: linear-gradient(90deg, #b6ff3a, #00d4ff) 1;
}
.section-callout--revamp .gform_wrapper input[type="text"]:focus,
.section-callout--revamp .gform_wrapper input[type="email"]:focus{
    border-image: linear-gradient(90deg, var(--accent2), var(--accent)) 1; border-bottom:2px solid transparent;
}
/* Outline pill button with gradient stroke */
.section-callout--revamp .gform_wrapper .gform_footer input[type="submit"],
.section-callout--revamp .gform_wrapper .gform_button{
    appearance:none; cursor:pointer; color:#dfefff; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
    background: transparent; padding:1rem 2rem; border-radius: 999px; border:2px solid transparent;
    position:relative; isolation:isolate;
}
.section-callout--revamp .gform_wrapper .gform_footer input[type="submit"]{
    background: linear-gradient(#0c2836,#0c2836) padding-box,
                linear-gradient(90deg, #b6ff3a, #00d4ff) border-box;
    border:2px solid transparent;
}
.section-callout--revamp .gform_wrapper .gform_footer input[type="submit"]:hover{
    background: linear-gradient(90deg, #b6ff3a, #00d4ff) padding-box,
                linear-gradient(90deg, #b6ff3a, #00d4ff) border-box;
    color:#06202c; transform: translateY(-1px);
}
.section-callout--revamp .gform_wrapper .gfield_description{ color: rgba(255,255,255,.8); font-size:14px; line-height:1.5; }

.gform_wrapper.gravity-theme .gfield_required {
    display: none!important;
}

/* ===============================
   HERO REVAMP (static like reference)
   =============================== */
.hero-ref{ position:relative; min-height: clamp(520px, 70vh, 760px); display:grid; align-items:center; overflow:hidden; }
.hero-ref:before{ /* background image */
    content:''; position:absolute; inset:0; 
    background:
        linear-gradient(180deg, rgba(4,25,36,.65) 0%, rgba(6,30,44,.75) 60%, rgba(6,30,44,.85) 100%),
        var(--hero-bg-image, url('../images/hero-bg.webp')) center/cover no-repeat;
    z-index:0; filter: saturate(.95);
    animation: bgFloat 15s ease-in-out infinite;
    will-change: transform;
    /* Slightly larger to prevent edges showing on movement */
    width: 100%;
    height: 110%;
    top: -5%;
}
@keyframes bgFloat{
    0%, 100%{ 
        transform: translateY(0);
    }
    50%{ 
        transform: translateY(-20px);
    }
}
.hero-ref__overlay{ position:absolute; inset:0; background:
        radial-gradient(900px 360px at 20% 20%, rgba(0,212,255,.15), rgba(0,0,0,0) 60%),
        radial-gradient(1000px 420px at 65% 30%, rgba(124,255,58,.12), rgba(0,0,0,0) 70%);
    z-index:1; pointer-events:none; }
.hero-ref__deco{ position:absolute; left:0; top:0; bottom:0; width:40%; background:
        radial-gradient(800px 320px at 2% 30%, rgba(0,212,255,.18) 0%, rgba(0,0,0,0) 60%);
    mask: linear-gradient(90deg, #000 0 85%, transparent 100%); -webkit-mask: linear-gradient(90deg, #000 0 85%, transparent 100%);
    z-index:1; pointer-events:none; }
.hero-ref .shell{ position:relative; z-index:2; max-width:1240px; margin:0 auto; padding:0 20px; }
.hero-ref__title{ font-weight:800; line-height:1.1; margin:0 0 16px; font-size: clamp(32px, 4.4vw, 64px); }
.hero-ref__title span{ 
    display:block; 
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 60%);
    -webkit-background-clip: text; 
    background-clip: text; 
    color: transparent;
    margin-bottom: -0.1em;
}
.hero-ref__title span:last-child {
    margin-bottom: 0;
}
.hero-ref__sub{ color:#e8f3fb; font-size: clamp(16px, 1.6vw, 20px); max-width: 900px; opacity:.95; }
.hero-ref__actions{ display:flex; gap:24px; margin-top:28px; align-items:center; flex-wrap:wrap; }
.hero-btn{ text-decoration:none; font-weight:700; letter-spacing:.16em; text-transform:uppercase; }
.hero-btn--outline{ padding:14px 26px; border-radius:999px; color:#dff7ff; background:linear-gradient(#0b1e2a,#0b1e2a) padding-box,
    linear-gradient(90deg,#b6ff3a,#00d4ff) border-box; border:2px solid transparent; }
.hero-btn--outline:hover{ background:linear-gradient(90deg,#b6ff3a,#00d4ff) padding-box, linear-gradient(90deg,#b6ff3a,#00d4ff) border-box; color:#06202c; }
.hero-btn--underline{ 
    color:#cfe6f5; 
    position:relative; 
    padding:12px 6px; 
    transition: color 0.3s ease;
}
.hero-btn--underline::after{ 
    content:''; 
    position:absolute;
    bottom: 8px;
    left: 6px;
    right: 6px;
    height: 3px;
    width: 0;
    background: linear-gradient(90deg, #b6ff3a, #00d4ff);
    transition: width 0.3s ease;
    opacity: 1;
}
.hero-btn--underline:hover {
    color: #00d4ff;
}
.hero-btn--underline:hover::after {
    width: calc(100% - 12px);
}

/* Floating Shapes Animation */
.hero-ref__floating-shapes{
    position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden;
}
.floating-shape{
    position:absolute; border-radius:50%; filter:blur(60px); 
    will-change: transform; /* Optimize animation performance */
}
.floating-shape--1{
    width:250px; height:250px; 
    background:radial-gradient(circle, rgba(182,255,58,.8) 0%, rgba(182,255,58,.4) 40%, rgba(182,255,58,.1) 70%, rgba(182,255,58,0) 100%);
    top:15%; left:10%; 
    animation: float1 7s ease-in-out infinite;
    animation-delay:0s;
    opacity:.36;
}
.floating-shape--2{
    width:200px; height:200px; 
    background:radial-gradient(circle, rgba(0,212,255,.8) 0%, rgba(0,212,255,.4) 40%, rgba(0,212,255,.1) 70%, rgba(0,212,255,0) 100%);
    top:60%; right:15%; 
    animation: float2 8s ease-in-out infinite;
    animation-delay:1s;
    opacity:.36;
}
.floating-shape--3{
    width:220px; height:220px; 
    background:radial-gradient(circle, rgba(182,255,58,.75) 0%, rgba(182,255,58,.35) 40%, rgba(182,255,58,.1) 70%, rgba(182,255,58,0) 100%);
    top:40%; right:25%; 
    animation: float3 9s ease-in-out infinite;
    animation-delay:2s;
    opacity:.32;
}
.floating-shape--4{
    width:180px; height:180px; 
    background:radial-gradient(circle, rgba(0,212,255,.75) 0%, rgba(0,212,255,.35) 40%, rgba(0,212,255,.1) 70%, rgba(0,212,255,0) 100%);
    bottom:20%; left:20%; 
    animation: float4 6.5s ease-in-out infinite;
    animation-delay:0.5s;
    opacity:.32;
}
.floating-shape--5{
    width:200px; height:200px; 
    background:radial-gradient(circle, rgba(182,255,58,.75) 0%, rgba(182,255,58,.35) 40%, rgba(182,255,58,.1) 70%, rgba(182,255,58,0) 100%);
    top:25%; left:50%; 
    animation: float5 8.5s ease-in-out infinite;
    animation-delay:1.5s;
    opacity:.34;
}
.floating-shape--6{
    width:190px; height:190px; 
    background:radial-gradient(circle, rgba(0,212,255,.75) 0%, rgba(0,212,255,.35) 40%, rgba(0,212,255,.1) 70%, rgba(0,212,255,0) 100%);
    bottom:30%; right:35%; 
    animation: float6 7.5s ease-in-out infinite;
    animation-delay:2.5s;
    opacity:.34;
}
/* Random movements - each shape has unique path */
@keyframes float1{
    0%, 100%{ transform:translate(0, 0) scale(1); }
    20%{ transform:translate(80px, -60px) scale(1.2); }
    40%{ transform:translate(-70px, 90px) scale(0.8); }
    60%{ transform:translate(120px, 50px) scale(1.15); }
    80%{ transform:translate(-50px, -80px) scale(0.9); }
}
@keyframes float2{
    0%, 100%{ transform:translate(0, 0) scale(1); }
    25%{ transform:translate(-90px, 70px) scale(1.1); }
    50%{ transform:translate(100px, -50px) scale(0.85); }
    75%{ transform:translate(-60px, -100px) scale(1.2); }
}
@keyframes float3{
    0%, 100%{ transform:translate(0, 0) scale(1); }
    15%{ transform:translate(70px, 80px) scale(0.9); }
    35%{ transform:translate(-110px, -40px) scale(1.25); }
    55%{ transform:translate(50px, -90px) scale(0.8); }
    75%{ transform:translate(-80px, 60px) scale(1.1); }
}
@keyframes float4{
    0%, 100%{ transform:translate(0, 0) scale(1); }
    30%{ transform:translate(-100px, -70px) scale(1.15); }
    60%{ transform:translate(90px, 80px) scale(0.85); }
    90%{ transform:translate(-50px, 100px) scale(1.05); }
}
@keyframes float5{
    0%, 100%{ transform:translate(0, 0) scale(1); }
    20%{ transform:translate(110px, -80px) scale(0.9); }
    45%{ transform:translate(-70px, 90px) scale(1.2); }
    70%{ transform:translate(60px, -50px) scale(0.95); }
}
@keyframes float6{
    0%, 100%{ transform:translate(0, 0) scale(1); }
    25%{ transform:translate(-80px, 100px) scale(1.1); }
    50%{ transform:translate(100px, -60px) scale(0.8); }
    75%{ transform:translate(-90px, -70px) scale(1.15); }
}

/* ===============================
   OFFERS SECTION REVAMP
   =============================== */
.section-offers--revamp{
    position: relative;
    background: linear-gradient(180deg, #0c2836 0%, #0a1f2b 100%);
    padding: 5rem 0;
    overflow: hidden;
}
.section-offers--revamp:before{
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(1200px 400px at 50% 50%, rgba(0,212,255,.06), rgba(0,0,0,0) 70%);
    pointer-events: none;
}
.section-offers--revamp .shell{
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
    z-index: 1;
}
.offers-grid{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin-top: 2rem;
}
.offer-card{
    position: relative;
}
.offer-card__link{
    display: block;
    text-decoration: none;
    background: rgba(255,255,255,.02);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 16px;
    overflow: hidden;
    transition: all 0.4s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.offer-card__link:hover{
    transform: translateY(-8px);
    border-color: rgba(182,255,58,.4);
    box-shadow: 0 12px 32px rgba(0,212,255,.15);
    background: rgba(255,255,255,.04);
}
.offer-card__image{
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    overflow: hidden;
    background: linear-gradient(135deg, #1a2f3d, #0f1f2a);
}
.offer-card__image img{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}
.offer-card__overlay{
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(4,25,36,.85) 100%);
    z-index: 1;
}
.offer-card__link:hover .offer-card__image img{
    transform: scale(1.08);
}
.offer-card__body{
    padding: 24px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.offer-card__title{
    font-size: clamp(20px, 2.2vw, 26px);
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 12px;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.offer-card__content{
    color: #cfe6f5;
    font-size: 15px;
    line-height: 1.6;
    margin-bottom: 16px;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}
.offer-card__content p{
    margin: 0 0 8px;
}
.offer-card__content p:last-child{
    margin-bottom: 0;
}
.offer-card__cta{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #00d4ff;
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-top: auto;
    position: relative;
}
.offer-card__cta:after{
    content: '→';
    transition: transform 0.3s ease;
}
.offer-card__link:hover .offer-card__cta{
    color: #b6ff3a;
}
.offer-card__link:hover .offer-card__cta:after{
    transform: translateX(4px);
}
@media (max-width: 1024px){
    .offers-grid{
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 768px){
    .offers-grid{
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .section-offers--revamp{
        padding: 3.5rem 0;
    }
}

/* ===============================
   TESTIMONIALS SECTION REVAMP
   =============================== */
.section-testimonials--revamp{
    position: relative;
    background: linear-gradient(180deg, #0a1f2b 0%, #0c2836 100%);
    padding: 6rem 0;
    overflow: hidden;
}
.section-testimonials--revamp:before{
    content: '';
    position: absolute;
    inset: 0;
    background: 
        radial-gradient(1000px 350px at 20% 30%, rgba(182,255,58,.05), rgba(0,0,0,0) 60%),
        radial-gradient(900px 300px at 80% 70%, rgba(0,212,255,.05), rgba(0,0,0,0) 60%);
    pointer-events: none;
}
.section-testimonials--revamp .shell{
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
    z-index: 1;
}
.testimonials-header{
    text-align: center;
    margin-bottom: 4rem;
}
.testimonials-title{
    font-size: clamp(36px, 5vw, 56px);
    font-weight: 800;
    line-height: 1.25;
    margin: 0 0 16px;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.testimonials-intro{
    color: #cfe6f5;
    font-size: clamp(16px, 2vw, 20px);
    line-height: 1.6;
    margin: 0;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}
.testimonials-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-top: 2rem;
}
.testimonial-card{
    position: relative;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 20px;
    padding: 40px 32px;
    transition: all 0.4s ease;
    display: flex;
    flex-direction: column;
}
.testimonial-card:hover{
    transform: translateY(-8px);
    border-color: rgba(182,255,58,.3);
    box-shadow: 0 16px 40px rgba(0,212,255,.12);
    background: rgba(255,255,255,.05);
}
.testimonial-card__quote-mark{
    position: absolute;
    top: 20px;
    right: 24px;
    opacity: 0.4;
}
.testimonial-card__quote{
    font-size: clamp(18px, 2vw, 22px);
    line-height: 1.7;
    color: #eaf6ff;
    font-style: italic;
    margin: 0 0 32px;
    flex: 1;
    position: relative;
    padding-top: 24px;
}
.testimonial-card__quote:before{
    content: '"';
    position: absolute;
    top: -8px;
    left: -12px;
    font-size: 80px;
    line-height: 1;
    color: rgba(182,255,58,.2);
    font-family: serif;
    font-weight: 700;
}
.testimonial-card__author{
    margin-top: auto;
    padding-top: 24px;
    border-top: 1px solid rgba(255,255,255,.1);
}
.testimonial-card__name{
    display: block;
    font-size: 15px;
    font-weight: 600;
    color: #b6ff3a;
    font-style: normal;
    margin-bottom: 4px;
    font-family: Georgia, 'Times New Roman', serif;
}
.testimonial-card__title{
    display: block;
    font-size: 12px;
    color: #8fb8d1;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 500;
}
@media (max-width: 1024px){
    .testimonials-grid{
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }
}
@media (max-width: 768px){
    .testimonials-grid{
        grid-template-columns: 1fr;
        gap: 24px;
    }
    .section-testimonials--revamp{
        padding: 4rem 0;
    }
    .testimonials-header{
        margin-bottom: 3rem;
    }
    .testimonial-card{
        padding: 32px 24px;
    }
}

/* ===============================
   ABOUT SECTION REVAMP
   =============================== */
.section-about--revamp{
    position: relative;
    background: linear-gradient(180deg, #0c2836 0%, #0a1f2b 100%);
    padding: 6rem 0;
    overflow: hidden;
}
.section-about--revamp:before{
    content: '';
    position: absolute;
    inset: 0;
    background: 
        radial-gradient(1000px 400px at 80% 20%, rgba(0,212,255,.06), rgba(0,0,0,0) 60%),
        radial-gradient(900px 350px at 20% 80%, rgba(182,255,58,.05), rgba(0,0,0,0) 60%);
    pointer-events: none;
}
.section-about--revamp .shell{
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
    z-index: 1;
}
.about-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
    align-items: center;
}
.about-content{
    position: relative;
}
.about-image{
    display: none;
}
.about-eyebrow{
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 80%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    font-weight: 700;
    margin: 0 0 12px;
    font-size: 14px;
}
.about-title{
    background: linear-gradient(90deg, #b6ff3a 0%, #bbeaff 70%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1.25;
    margin: 0 0 40px;
    font-weight: 800;
}
.about-title h1,
.about-title h2,
.about-title h3,
.about-title h4,
.about-title h5,
.about-title h6{
    background: linear-gradient(90deg, #b6ff3a 0%, #bbeaff 70%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-size: inherit;
    line-height: inherit;
    margin: 0;
    font-weight: inherit;
}
.about-title p{
    color: #cfe6f5;
    font-size: clamp(16px, 2vw, 20px);
    line-height: 1.6;
    margin: 0;
    background: none;
    -webkit-background-clip: unset;
    background-clip: unset;
    font-weight: 400;
    max-width: 100%;
}
.perks-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-top: 2rem;
}
.perk-card{
    background: rgba(255,255,255,.02);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 16px;
    padding: 28px;
    transition: all 0.4s ease;
}
.perk-card:hover{
    transform: translateY(-4px);
    border-color: rgba(182,255,58,.3);
    box-shadow: 0 12px 32px rgba(0,212,255,.1);
    background: rgba(255,255,255,.04);
}
.perk-icon{
    margin-bottom: 16px;
    display: flex;
    align-items: center;
}
.perk-icon img{
    height: 48px;
    width: auto;
    filter: brightness(1.1);
    transition: transform 0.3s ease;
}
.perk-card:hover .perk-icon img{
    transform: scale(1.1);
}
.perk-title{
    font-size: 20px;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 12px;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.perk-content{
    color: #cfe6f5;
    font-size: 15px;
    line-height: 1.6;
}
.perk-content p{
    margin: 0 0 8px;
}
.perk-content p:last-child{
    margin-bottom: 0;
}
.about-image{
    position: relative;
}
.about-figure{
    position: relative;
    width: 100%;
    padding-top: 75%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
.about-figure__overlay{
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0,212,255,.1) 0%, rgba(182,255,58,.05) 100%);
    border-radius: 20px;
}
@media (max-width: 1024px){
    .about-grid{
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .about-image{
        order: -1;
    }
    .about-figure{
        padding-top: 60%;
    }
}
@media (max-width: 768px){
    .section-about--revamp{
        padding: 4rem 0;
    }
    .perks-grid{
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .about-title{
        margin-bottom: 32px;
    }
}

/* ===============================
   PARTNERS SECTION REVAMP
   =============================== */
.section-partners--revamp{
    position: relative;
    background: linear-gradient(180deg, #0a1f2b 0%, #081720 100%);
    padding: 5rem 0 4rem;
    overflow: hidden;
}
.section-partners--revamp:before{
    content: '';
    position: absolute;
    inset: 0;
    background: 
        radial-gradient(1200px 300px at 50% 50%, rgba(0,212,255,.03), rgba(0,0,0,0) 70%);
    pointer-events: none;
}
.section-partners--revamp .shell{
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
    z-index: 1;
}
.partners-header{
    text-align: center;
    margin-bottom: 3rem;
}
.partners-title{
    font-size: clamp(32px, 4.5vw, 48px);
    font-weight: 800;
    line-height: 1.25;
    margin: 0;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
/* Slider container */
.list-logos--revamp{
    list-style: none;
    margin: 0;
    padding: 3rem 0;
    display: flex;
    overflow: hidden;
}
.list-logos--revamp .slick-list{
    overflow: visible;
}
.list-logos--revamp .slick-track{
    display: flex;
    align-items: center;
}
.partner-logo-item{
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 30px;
    height: 200px;
    flex-shrink: 0;
}
.partner-logo__link{
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    background: #ffffff;
    border-radius: 12px;
    padding: 32px 48px;
    height: 160px;
    width: 100%;
    box-sizing: border-box;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.partner-logo__link:hover{
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(255,255,255,.2);
}
/* Keep images original - no filters */
.partner-logo__img{
    max-width: 260px;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}
@media (max-width: 768px){
    .section-partners--revamp{
        padding: 4rem 0 3rem;
    }
    .partners-header{
        margin-bottom: 2rem;
    }
    .partner-logo-item{
        padding: 0 20px;
        height: 180px;
    }
    .partner-logo__link{
        padding: 24px 32px;
        height: 140px;
    }
    .partner-logo__img{
        max-width: 220px;
        max-height: 100%;
    }
}

/* ===============================
   SCHEDULE PAGE REVAMP
   =============================== */

/* Schedule page wrapper */
.main--schedule {
    background: linear-gradient(180deg, #0c2836 0%, #0a1f2b 100%) !important;
    min-height: 100vh;
}

/* Global text contrast improvements for schedule page */
.main--schedule * {
    color: inherit;
}

.main--schedule {
    color: #ffffff;
}

/* Override any light backgrounds */
.main--schedule .section-courses,
.main--schedule .section__content,
.main--schedule .section__content--secondary {
    background: transparent !important;
}

/* Ensure wrapper doesn't have white backgrounds */
.main--schedule > * {
    background-color: transparent !important;
}

/* Hero intro section - matching course catalog style */
.main--schedule .intro-alt--secondary {
    background: linear-gradient(180deg, rgba(4,25,36,.65) 0%, rgba(6,30,44,.75) 60%, rgba(6,30,44,.85) 100%) !important;
    padding: 4rem 0 3rem;
    position: relative;
    overflow: hidden;
    margin: 0 !important;
    min-height: clamp(400px, 50vh, 600px);
    display: grid;
    align-items: center;
}

/* Decorative overlays like course catalog */
.main--schedule .intro-alt--secondary:before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(900px 360px at 20% 20%, rgba(0,212,255,.15), rgba(0,0,0,0) 60%),
        radial-gradient(1000px 420px at 65% 30%, rgba(124,255,58,.12), rgba(0,0,0,0) 70%);
    pointer-events: none;
    z-index: 1;
}

/* Floating shapes container */
.main--schedule .intro-alt--secondary__floating-shapes {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

.main--schedule .intro-alt--secondary .shell {
    position: relative;
    z-index: 2;
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.main--schedule .intro-alt--secondary__content {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.main--schedule .intro-alt--secondary h1,
.main--schedule .intro-alt--secondary h2 {
    font-family: 'Poppins', sans-serif !important;
    font-size: clamp(36px, 5vw, 56px) !important;
    font-weight: 800 !important;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 60%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    margin: 0 0 12px !important;
    line-height: 1.25 !important;
    text-transform: none !important;
}

.main--schedule .intro-alt--secondary p,
.main--schedule .intro-alt--secondary .intro-content {
    font-family: 'Poppins', sans-serif !important;
    font-size: clamp(16px, 1.6vw, 20px) !important;
    color: #ffffff !important;
    margin: 0 0 1rem !important;
    line-height: 1.5 !important;
    opacity: 0.95;
}

/* Form intro section */
.main--schedule .form-intro {
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
}

/* Form tags styling */
.main--schedule .form-intro .form-tags {
    width: 100%;
    max-width: 500px;
}

.main--schedule .form-intro .form__controls {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.main--schedule .form-intro .select {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(255, 255, 255, 0.08);
    padding: 0px 5px 4px 30px;
    border-radius: 50px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    transition: all 0.3s ease;
}

.main--schedule .form-intro .select:focus-within {
    background: rgba(255, 255, 255, 0.12);
    border-color: #b6ff3a;
    box-shadow: 0 0 20px rgba(182, 255, 58, 0.15);
}

.main--schedule .form-intro .select em {
    flex-shrink: 0;
}

.main--schedule .form-intro .select em img {
    width: 18px;
    height: 18px;
    filter: brightness(0) invert(1);
    opacity: 0.7;
}

.main--schedule .form-intro .form__actions {
    margin-left: 0;
    margin-top: 0;
}

/* Schedule actions (Download/Print) */
.main--schedule .schedule-actions {
    margin-top: 0.5rem;
}

.main--schedule .schedule-actions .list-actions {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 12px;
    justify-content: center;
}

.main--schedule .schedule-actions .list-actions li {
    margin: 0;
}

.main--schedule .schedule-actions .list-actions a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: rgba(0, 212, 255, 0.15);
    border: 2px solid rgba(0, 212, 255, 0.3);
    border-radius: 30px;
    color: #ffffff;
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all 0.3s ease;
}

.main--schedule .schedule-actions .list-actions a:hover {
    background: rgba(0, 212, 255, 0.25);
    border-color: #00d4ff;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 212, 255, 0.3);
}

.main--schedule .schedule-actions .list-actions a .ico-pdf {
    display: flex;
    align-items: center;
}

.main--schedule .schedule-actions .list-actions a .ico-pdf svg {
    width: 16px;
    height: 16px;
}

/* Courses section container */
.main--schedule .section-courses {
    padding: 4rem 0;
    position: relative;
    background: transparent;
}

.main--schedule .section-courses .shell {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 40px;
    align-items: start;
}

/* Sidebar filters */
.main--schedule .section__aside {
    position: sticky;
    top: 140px;
    background: rgba(255,255,255,.05) !important;
    border: 1px solid rgba(255,255,255,.12) !important;
    border-radius: 20px;
    padding: 32px 24px;
    backdrop-filter: blur(10px);
}

/* Remove the old background from ::before pseudo-element */
.main--schedule .section-courses .section__aside:before,
.main--schedule .section__aside:before {
    display: none !important;
    background: none !important;
    content: none !important;
}

/* Filters trigger button (mobile) */
.main--schedule .filters-trigger {
    display: none;
    margin-bottom: 20px;
}

@media (max-width: 1024px) {
    .main--schedule .filters-trigger {
        display: inline-flex;
    }
}

.main--schedule .section__aside h3,
.main--schedule .section__aside h4,
.main--schedule .section__aside h5,
.main--schedule .section__aside h6,
.main--schedule .section__aside .aside__head,
.main--schedule .section__aside .aside__head h4,
.main--schedule .section__aside .form__group h6 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 18px !important;
    font-weight: 800 !important;
    color: #b6ff3a !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    margin: 0 0 20px !important;
    padding-bottom: 12px !important;
    border-bottom: 2px solid rgba(182,255,58,.3) !important;
}

.main--schedule .section__aside .form-filters {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.main--schedule .section__aside .form__group {
    margin-bottom: 0;
    border-top: none;
    padding-top: 0;
}

.main--schedule .section__aside label,
.main--schedule .section__aside .form__label,
.main--schedule .section__aside .form__head {
    font-family: 'Poppins', sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    margin-bottom: 12px !important;
    display: block !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
}

.main--schedule .section__aside input[type="checkbox"],
.main--schedule .section__aside input[type="radio"] {
    position: absolute !important;
    opacity: 0 !important;
    cursor: pointer;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
}

.main--schedule .section__aside .checkbox-label,
.main--schedule .section__aside .radio-label,
.main--schedule .section__aside label span,
.main--schedule .section__aside .form__group label span,
.main--schedule .section__aside li label span {
    font-family: 'Poppins', sans-serif !important;
    font-size: 15px !important;
    color: #ffffff !important;
    cursor: pointer;
    display: inline-flex !important;
    align-items: center;
    padding: 8px 0;
    transition: color 0.3s ease;
    font-weight: 400 !important;
}

.main--schedule .section__aside .checkbox-label:hover,
.main--schedule .section__aside .radio-label:hover,
.main--schedule .section__aside label:hover span {
    color: #b6ff3a !important;
}

/* Force white text for all sidebar list items */
.main--schedule .section__aside li,
.main--schedule .section__aside ul li {
    color: #ffffff !important;
}

/* Remove o checkbox :before e :after do bundle.css para schedule */
.main--schedule .section__aside .list-checks label:before,
.main--schedule .section__aside .list-checks label:after {
    display: none !important;
    content: none !important;
    width: 0 !important;
    height: 0 !important;
    border: none !important;
    background: none !important;
}

.main--schedule .section__aside li label,
.main--schedule .section__aside .list-checks li label {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    cursor: pointer;
    transition: color 0.3s ease;
    display: flex !important;
    align-items: center;
    gap: 10px;
    padding: 3px 0 !important;
    padding-left: 0 !important;
    line-height: 1.4;
    position: relative;
}

.main--schedule .section__aside li label:hover,
.main--schedule .section__aside .list-checks li label:hover {
    color: #b6ff3a !important;
}

/* View more/fewer toggle links */
.main--schedule .section__aside .checks-toggle a {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    color: #00d4ff !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: color 0.3s ease;
}

.main--schedule .section__aside .checks-toggle a:hover {
    color: #b6ff3a !important;
}

.main--schedule .section__aside .checks-toggle strong {
    color: #00d4ff !important;
}

/* Custom checkbox para schedule - mesmo estilo das outras páginas */
.main--schedule .section__aside .checkbox-custom {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
    max-width: 18px !important;
    max-height: 18px !important;
    border: 2px solid rgba(255,255,255,.3);
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: all 0.3s ease;
    flex-shrink: 0;
    background: rgba(0,0,0,.2);
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
    aspect-ratio: 1 / 1;
    line-height: 0;
    font-size: 0;
}

.main--schedule .section__aside .list-checks label:hover .checkbox-custom {
    border-color: rgba(255,255,255,.5);
}

.main--schedule .section__aside .list-checks input[type="checkbox"]:checked + label .checkbox-custom {
    background: linear-gradient(135deg, #b6ff3a 0%, #00d4ff 100%);
    border-color: #b6ff3a;
}

.main--schedule .section__aside .list-checks input[type="checkbox"]:checked + label .checkbox-custom:after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #06202c;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

/* Main content area */
.main--schedule .section__content--secondary {
    background: transparent !important;
    border: none !important;
    border-radius: 0;
    padding: 0;
}

/* Search bar and actions header */
.main--schedule .section__content-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    margin-bottom: 32px;
    padding: 32px;
    background: rgba(255,255,255,.03) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    border-radius: 20px;
    flex-wrap: wrap;
}

.main--schedule .section__form {
    flex: 1 1 400px;
}

/* Form intro section */
.main--schedule .form-intro {
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
    width: 100%;
}

.main--schedule .form-tags {
    width: 100%;
    max-width: 500px;
}

/* Select2 search field styling */
.main--schedule .form-intro .form-tags .select {
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    background: rgba(255, 255, 255, 0.08);
    padding: 0px 5px 4px 30px;
    border-radius: 50px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    transition: all 0.3s ease;
    min-height: 52px;
}

.main--schedule .form-intro .form-tags .select:focus-within,
.main--schedule .form-intro .form-tags .select .select2-container--open {
    background: rgba(255, 255, 255, 0.12);
    border-color: #b6ff3a;
    box-shadow: 0 0 20px rgba(182, 255, 58, 0.15);
}

.main--schedule .form-intro .form-tags .select em {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    display: flex;
    align-items: center;
    pointer-events: none;
}

.main--schedule .form-intro .form-tags .select em img {
    width: 18px;
    height: 18px;
    filter: brightness(0) invert(1);
    opacity: 0.7;
}

.main--schedule .form-intro .form__controls {
    width: 100%;
    border: none!important;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Select2 dentro do hero - remove bordas duplicadas do select2 */
.main--schedule .form-intro .form-tags .select .select2-container {
    flex: 1;
    background: transparent;
    border: none;
}

.main--schedule .form-intro .form-tags .select .select2-container .select2-selection {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    min-height: auto !important;
}

.main--schedule .form-intro .form-tags .select .select2-container.select2-container--open .select2-selection {
    background: transparent !important;
    border: none !important;
}

.main--schedule .js-select2 {
    width: 100%;
}

.form-tags .select .select2-container {
    flex: 1;
}

/* Select2 dentro do hero - remove bordas duplicadas, usa apenas o container pai */
.main--schedule .form-intro .form-tags .select .select2-container {
    flex: 1;
    background: transparent;
    border: none;
}

.main--schedule .form-intro .form-tags .select .select2-container .select2-selection {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    min-height: auto !important;
    color: #ffffff !important;
    transition: all 0.3s ease !important;
    font-family: 'Poppins', sans-serif !important;
}

.main--schedule .form-intro .form-tags .select .select2-container.select2-container--open .select2-selection {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.main--schedule .form-tags .select .select2-container .select2-selection,
.main--schedule .select2-container .select2-selection {
    background: rgba(255,255,255,.08) !important;
    border: 2px solid rgba(255,255,255,.2) !important;
    border-radius: 30px !important;
    padding: 0px 20px 0px 48px !important;
    min-height: 52px !important;
    color: #ffffff !important;
    transition: all 0.3s ease !important;
    font-family: 'Poppins', sans-serif !important;
}

.main--schedule .form-tags .select .select2-container .select2-selection:focus,
.main--schedule .form-tags .select .select2-container.select2-container--open .select2-selection,
.main--schedule .select2-container.select2-container--open .select2-selection {
    border-color: #b6ff3a !important;
    background: rgba(255,255,255,.12) !important;
    box-shadow: 0 0 20px rgba(182,255,58,.15) !important;
}

.main--schedule .form-tags .select .select2-container .select2-selection__placeholder,
.main--schedule .select2-container .select2-selection__placeholder {
    color: rgba(255,255,255,.7) !important;
}

.main--schedule .select2-container .select2-selection__rendered {
    color: #ffffff !important;
}

.main--schedule .select2-container .select2-search__field {
    color: #ffffff !important;
}

/* Select2 dropdown styling - Override style.schedule.css with higher specificity */
.main--schedule .select2-container--default .select2-results__option,
body.select2-schedule-open .select2-container--default .select2-results__option {
    background: #0c2836 !important;
    color: #ffffff !important;
    padding: 12px 20px !important;
}

/* Override the highlighted option with higher specificity than style.schedule.css */
.main--schedule .select2-container--default .select2-results__option--highlighted[aria-selected],
body.select2-schedule-open .select2-container--default .select2-results__option--highlighted[aria-selected] {
    background: rgba(0,128,255,.25) !important;
    background-color: rgba(0,128,255,.25) !important;
    color: #00d4ff !important;
}

/* Target Select2 dropdown when schedule page is active */
body.select2-schedule-open .select2-dropdown,
.main--schedule .select2-dropdown {
    background: #0c2836 !important;
    border: 2px solid rgba(182,255,58,.3) !important;
    border-radius: 16px !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4) !important;
    overflow: hidden !important;
    width: 500px !important;
    min-width: 500px !important;
    margin-top: 12px !important;
    transform: translateX(-10px) translateY(8px) !important;
}

/* Ensure dropdown aligns with the select container */
.main--schedule .form-intro .form-tags .select2-container {
    width: 100% !important;
}

/* Select2 results container */
.main--schedule .select2-results {
    max-height: 300px !important;
    overflow-y: auto !important;
}

/* Custom scrollbar styling - remove white borders */
.main--schedule .select2-results__options::-webkit-scrollbar,
body.select2-schedule-open .select2-results__options::-webkit-scrollbar {
    width: 8px !important;
}

.main--schedule .select2-results__options::-webkit-scrollbar-track,
body.select2-schedule-open .select2-results__options::-webkit-scrollbar-track {
    background: transparent !important;
}

.main--schedule .select2-results__options::-webkit-scrollbar-thumb,
body.select2-schedule-open .select2-results__options::-webkit-scrollbar-thumb {
    background-color: rgba(182, 255, 58, 0.3) !important;
    border-radius: 4px !important;
    border: none !important;
}

.main--schedule .select2-results__options::-webkit-scrollbar-thumb:hover,
body.select2-schedule-open .select2-results__options::-webkit-scrollbar-thumb:hover {
    background-color: rgba(182, 255, 58, 0.5) !important;
}

.main--schedule .select2-results__option {
    white-space: normal !important;
    word-wrap: break-word !important;
}

.main--schedule .select2-search--dropdown .select2-search__field {
    background: rgba(255,255,255,.08) !important;
    border: 1px solid rgba(255,255,255,.2) !important;
    color: #ffffff !important;
}

/* Search button */
.main--schedule .form-intro .form__actions {
    display: inline-flex;
    margin-left: 0;
    margin-top: 0;
    flex-shrink: 0;
    align-items: center;
}

/* Search button styling - same as course catalog */
.main--schedule .form-intro .btn-pill--red {
    background: linear-gradient(135deg, #00d4ff 0%, #b6ff3a 100%) !important;
    color: #06202c !important;
    border: none !important;
    padding: 12px 28px !important;
    border-radius: 30px !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    cursor: pointer;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 15px rgba(0, 212, 255, 0.3) !important;
    height: unset;
    line-height: unset;
    position: relative;
}

.main--schedule .form-intro .btn-pill--red:hover {
    background: linear-gradient(135deg, #00b8e6 0%, #9ee62a 100%) !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(182, 255, 58, 0.4) !important;
    color: #06202c !important;
}

.btn-pill--red {
    background: linear-gradient(135deg, #ff6b35 0%, #e55a2b 100%);
    color: #ffffff;
    border: none;
    padding: 14px 32px;
    border-radius: 30px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 15px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(255,107,53,.3);
}

.btn-pill--red:hover {
    background: linear-gradient(135deg, #e55a2b 0%, #d4491a 100%);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(255,107,53,.4);
}

/* Download/Print actions */
.section__content-actions {
    flex: 0 0 auto;
}

.list-actions {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 12px;
}

.list-actions li a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 24px;
    background: rgba(0,212,255,.1);
    border: 2px solid rgba(0,212,255,.3);
    border-radius: 30px;
    color: #00d4ff;
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 14px;
    transition: all 0.3s ease;
}

.list-actions li a:hover {
    background: rgba(0,212,255,.2);
    border-color: #00d4ff;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0,212,255,.2);
}

.list-actions em {
    display: flex;
    align-items: center;
    width: 18px;
    height: 18px;
}

.list-actions em svg {
    width: 100%;
    height: 100%;
    fill: currentColor;
}

/* Course cards */
.main--schedule .courses--secondary {
    background: rgba(255,255,255,.03) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    border-radius: 16px;
    padding: 28px;
    margin-bottom: 24px;
    transition: all 0.4s ease;
}

.main--schedule .courses--secondary:hover {
    border-color: rgba(182,255,58,.3) !important;
    box-shadow: 0 12px 32px rgba(0,212,255,.1) !important;
    background: rgba(255,255,255,.05) !important;
}

/* Course header row */
.main--schedule .row--head {
    padding-bottom: 20px !important;
    margin-bottom: 20px !important;
    border-bottom: 2px solid rgba(182,255,58,.3) !important;
    display: block !important;
    grid-template-columns: 1fr !important;
}

.main--schedule .row--head .col,
.main--schedule .row--head .col--alt {
    width: 100% !important;
    max-width: 100% !important;
    flex: 1 !important;
}

.main--schedule .row--head h4,
.main--schedule .row--head .col h4 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    margin: 0 !important;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 100%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    letter-spacing: 0.01em !important;
    white-space: nowrap !important;
    line-height: 1.3 !important;
    overflow: visible !important;
    text-overflow: clip !important;
}

/* Course class rows */
.main--schedule .courses--secondary .row {
    display: grid;
    grid-template-columns: 1.5fr 1.2fr 0.8fr;
    gap: 20px;
    align-items: center;
    padding: 20px 0;
    border-bottom: 1px solid rgba(255,255,255,.06) !important;
    transition: background 0.3s ease;
}

.main--schedule .courses--secondary .row:last-child {
    border-bottom: none !important;
}

.main--schedule .courses--secondary .row:hover {
    background: rgba(255,255,255,.05) !important;
    border-radius: 8px;
    padding-left: 12px;
    padding-right: 12px;
}

.main--schedule .courses--secondary .col h5 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    margin: 0 0 6px !important;
    white-space: nowrap !important;
    display: inline !important;
}

.main--schedule .courses--secondary .col h5 span {
    font-size: 12px !important;
    color: rgba(255,255,255,.75) !important;
    font-weight: 400 !important;
    white-space: nowrap !important;
    display: inline !important;
    margin-left: 4px !important;
}

.main--schedule .courses--secondary .col p {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    color: #ffffff !important;
    margin: 0 !important;
}

/* Badges */
.main--schedule .badge {
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    padding: 6px 14px !important;
    border-radius: 20px !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.main--schedule .badge--active {
    background: rgba(182,255,58,.2) !important;
    color: #d4ff6b !important;
    border: 1px solid rgba(182,255,58,.5) !important;
}

.main--schedule .badge--active i {
    color: #d4ff6b !important;
}

.main--schedule .badge--active em {
    color: #d4ff6b !important;
    font-style: normal !important;
}

.main--schedule .badge--limited {
    background: rgba(255,167,38,.3) !important;
    color: #ffd54f !important;
    border: 1px solid rgba(255,167,38,.6) !important;
}

.main--schedule .badge--disabled {
    background: rgba(244,67,54,.2) !important;
    color: #ff8a80 !important;
    border: 1px solid rgba(244,67,54,.4) !important;
}

.main--schedule .badge:not(.badge--active):not(.badge--limited):not(.badge--disabled) {
    background: rgba(0,212,255,.2) !important;
    color: #80e8ff !important;
    border: 1px solid rgba(0,212,255,.5) !important;
}

/* Action buttons */
.main--schedule .btn-pill,
.main--schedule .btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 10px 18px !important;
    border-radius: 30px !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
    cursor: pointer;
    border: none !important;
}

.main--schedule .btn-pill--gradient,
.main--schedule .btn.btn-pill--gradient {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%) !important;
    color: #06202c !important;
    box-shadow: 0 4px 15px rgba(182,255,58,.3) !important;
}

.main--schedule .btn-pill--gradient:hover,
.main--schedule .btn.btn-pill--gradient:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(182,255,58,.4) !important;
    filter: brightness(1.1);
}

/* Replace orange button styles with Download/Print Schedule button styles */
.main--schedule .btn-outline--orange,
.main--schedule .btn.btn-outline--orange {
    background: rgba(0, 128, 255, 0.15) !important;
    color: #00d4ff !important;
    border: 1px solid rgba(0, 212, 255, 0.4) !important;
    border-radius: 8px !important;
    padding: 12px 24px !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    transition: all 0.3s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.main--schedule .btn-outline--orange:hover,
.main--schedule .btn.btn-outline--orange:hover {
    background: rgba(0, 212, 255, 0.25) !important;
    color: #00d4ff !important;
    border-color: rgba(0, 212, 255, 0.6) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 20px rgba(0, 212, 255, 0.3) !important;
}

/* No results message */
.main--schedule .section__content--secondary > p,
.main--schedule .section__content--secondary > p em {
    font-family: 'Poppins', sans-serif !important;
    font-size: 18px !important;
    color: #ffffff !important;
    font-style: italic !important;
    background: rgba(255,255,255,.05);
    padding: 40px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.1);
    text-align: center;
}

.main--schedule .section__content--secondary > p em a {
    color: #00d4ff !important;
    text-decoration: underline;
    transition: color 0.3s ease;
    font-weight: 600;
}

.main--schedule .section__content--secondary > p em a:hover {
    color: #b6ff3a !important;
}

/* Responsive schedule page */
@media (max-width: 1200px) {
    .main--schedule .section-courses .shell {
        grid-template-columns: 240px 1fr;
        gap: 30px;
    }
}

@media (max-width: 1024px) {
    .main--schedule .section-courses .shell {
        grid-template-columns: 1fr;
    }
    
    .main--schedule .section__aside {
        position: relative;
        top: 0;
    }
    
    .main--schedule .courses--secondary .row {
        grid-template-columns: 1fr;
        gap: 12px;
    }
}

@media (max-width: 768px) {
    .main--schedule .intro-alt--secondary {
        padding: 3rem 0 2rem !important;
    }
    
    .main--schedule .section-courses {
        padding: 3rem 0;
    }
    
    .main--schedule .section__content-head {
        flex-direction: column;
        align-items: stretch;
        padding: 24px !important;
    }
    
    .main--schedule .form-tags .select {
        flex-direction: column;
        align-items: stretch;
    }
    
    .main--schedule .form__actions {
        margin-left: 0 !important;
        margin-top: 12px;
    }
    
    .main--schedule .list-actions {
        flex-direction: column;
    }
    
    .main--schedule .section__content--secondary {
        padding: 0 !important;
    }
    
    .main--schedule .courses--secondary {
        padding: 20px !important;
    }
}

/* ===============================
   COURSE CATALOG PAGE REVAMP
   =============================== */

/* Catalog page wrapper */
.main--catalog {
    background: linear-gradient(180deg, #0c2836 0%, #0a1f2b 100%) !important;
    min-height: 100vh;
}

/* Global text contrast improvements for catalog page */
.main--catalog * {
    color: inherit;
}

.main--catalog {
    color: #ffffff;
}

/* Override any light backgrounds */
.main--catalog .section-courses,
.main--catalog .section__content,
.main--catalog .section__content--catalog {
    background: transparent !important;
    padding-left: 2rem;
}

/* Ensure wrapper doesn't have white backgrounds */
.main--catalog > * {
    background-color: transparent !important;
}

.intro-alt {
    background: linear-gradient(135deg, #ffff83 0%, #cbfc77 100%) !important;

}

.intro-alt p {  color: #000000 !important; }

.article .row .article__image img {

    border-radius: 16px;
}

/* Hero intro section - matching homepage hero style */
.main--catalog .intro-alt--secondary {
    background: linear-gradient(180deg, rgba(4,25,36,.65) 0%, rgba(6,30,44,.75) 60%, rgba(6,30,44,.85) 100%) !important;
    padding: 4rem 0 3rem;
    position: relative;
    overflow: hidden;
    margin: 0 !important;
    min-height: clamp(400px, 50vh, 600px);
    display: grid;
    align-items: center;
}

/* Decorative overlays like homepage */
.main--catalog .intro-alt--secondary:before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(900px 360px at 20% 20%, rgba(0,212,255,.15), rgba(0,0,0,0) 60%),
        radial-gradient(1000px 420px at 65% 30%, rgba(124,255,58,.12), rgba(0,0,0,0) 70%);
    pointer-events: none;
    z-index: 1;
}

/* Floating shapes container */
.main--catalog .intro-alt--secondary__floating-shapes {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

.main--catalog .intro-alt--secondary .shell {
    position: relative;
    z-index: 2;
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.main--catalog .intro-alt--secondary__content {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.main--catalog .intro-alt--secondary .intro-content {
    margin-top: 0;
    margin-bottom: 1rem;
    color: #ffffff !important;
    font-size: clamp(16px, 1.6vw, 20px);
    opacity: 0.95;
}

.main--catalog .intro-alt--secondary .intro-content p {
    color: #ffffff !important;
}

.main--catalog .intro-alt--secondary h1 {
    font-family: 'Poppins', sans-serif !important;
    font-size: clamp(36px, 5vw, 56px) !important;
    font-weight: 800 !important;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 60%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    margin: 0 0 12px !important;
    line-height: 1.25 !important;
    text-transform: none !important;
}

/* Search form */
.main--catalog .form-intro {
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.main--catalog .catalog-search-form {
    margin-bottom: 2rem;
    width: 100%;
    display: flex;
    justify-content: center;
}

.main--catalog .search-input-wrapper {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(255, 255, 255, 0.08);
    padding: 0px 5px 4px 30px;
    border-radius: 50px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    transition: all 0.3s ease;
    max-width: 500px;
    width: 100%;
}

.main--catalog .search-input-wrapper:focus-within {
    background: rgba(255, 255, 255, 0.12);
    border-color: #b6ff3a;
    box-shadow: 0 0 20px rgba(182, 255, 58, 0.15);
}

.main--catalog .search-input-wrapper i {
    color: rgba(255, 255, 255, 0.7);
    position: unset;
    font-size: 18px;
    flex-shrink: 0;
}

.main--catalog .search-input-wrapper .field {
    flex: 1;
    height: unset;
    border: none;
    background: transparent;
    font-family: 'Poppins', sans-serif;
    font-size: 16px;
    color: #ffffff;
    padding: 8px 12px 8px 0px;
    outline: none;
}

.main--catalog .search-input-wrapper .field::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.main--catalog .search-input-wrapper .btn-pill--red {
    background: linear-gradient(135deg, #00d4ff 0%, #b6ff3a 100%);
    color: #06202c;
    height: unset;
    line-height: unset;
    position: relative;
    border: none;
    padding: 12px 28px;
    border-radius: 30px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(0, 212, 255, 0.3);
    flex-shrink: 0;
}

.main--catalog .search-input-wrapper .btn-pill--red:hover {
    background: linear-gradient(135deg, #00b8e6 0%, #9ee62a 100%);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(182, 255, 58, 0.4);
    color: #06202c;
}

/* Popular & Recent courses */
.main--catalog .intro-popular-recent {
    display: flex;
    gap: 60px;
    margin-top: 2rem;
    flex-wrap: wrap;
    width: 100%;
}

.main--catalog .popular-courses,
.main--catalog .recent-courses {
    display: flex;
    flex-direction: column;
}

.main--catalog .intro-popular-recent h5 {
    font-family: 'Poppins', sans-serif;
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 80%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin: 0 0 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.main--catalog .intro-popular-recent h5 i {
    color: #ff6b35;
    font-size: 16px;
}

.main--catalog .intro-popular-recent ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 20px 24px;
}

.main--catalog .intro-popular-recent ul li {
    margin: 0;
    max-width: none !important;
    width: auto !important;
}

.main--catalog .intro-popular-recent ul li a {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    font-family: 'Poppins', sans-serif;
    font-size: 15px;
    font-weight: 500;
    transition: all 0.3s ease;
    position: relative;
    line-height: 1.4;
    max-height: calc(15px * 1.4 * 2);
    height: auto;
    max-width: 100%;
    word-break: break-word;
}

.main--catalog .intro-popular-recent ul li a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background: linear-gradient(90deg, #b6ff3a, #00d4ff);
    transition: width 0.3s ease;
}

.main--catalog .intro-popular-recent ul li a:hover {
    color: #b6ff3a;
    transform: none;
    box-shadow: none;
}

.main--catalog .intro-popular-recent ul li a:hover::after {
    width: 100%;
}

/* Courses section container */
.main--catalog .section-courses {
    padding: 4rem 0;
    position: relative;
    background: transparent;
}

.main--catalog .section-courses .shell {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 40px;
    align-items: start;
}

/* Sidebar filters */
.main--catalog .section__aside--catalog {
    position: sticky;
    top: 140px;
    background: rgba(255,255,255,.05) !important;
    border: 1px solid rgba(139, 223, 255, 0.25) !important;
    border-radius: 20px;
    padding: 0;
    backdrop-filter: blur(10px);
    overflow: hidden;
}

/* Remove the old background from ::before pseudo-element */
.main--catalog .section-courses .section__aside--catalog:before,
.main--catalog .section__aside--catalog:before {
    display: none !important;
    background: none !important;
    content: none !important;
}

/* Filters header */
.main--catalog .form-filters__header {
    padding: 20px 0 10px;
    background: none;
    border-bottom: 2px solid rgba(182, 255, 58, .3);
    margin-bottom: 20px;
}

.main--catalog .form-filters__header h4 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    color: #b6ff3a !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    margin: 0 !important;
}

/* Filters trigger button (mobile) */
.main--catalog .filters-trigger {
    display: none;
    margin-bottom: 20px;
}

@media (max-width: 1024px) {
    .main--catalog .filters-trigger {
        display: inline-flex;
        align-items: center;
        gap: 10px;
    }
}

.main--catalog .form-filters {
    padding: 24px;
}

.main--catalog .form-filters form {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.main--catalog .section__aside--catalog h6,
.main--catalog .section__aside--catalog .form__group h6 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    margin: 0 0 12px !important;
    padding-bottom: 8px !important;
    border: none !important;
}

.main--catalog .section__aside--catalog .form__group {
    margin-bottom: 0;
}

.main--catalog .section__aside--catalog .list-checks {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.main--catalog .section__aside--catalog .list-checks li {
    margin: 0;
    padding: 0;
    position: relative;
}

.main--catalog .section__aside--catalog .list-checks input[type="checkbox"] {
    position: absolute !important;
    opacity: 0 !important;
    cursor: pointer;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
}

/* Remove o checkbox :before e :after do bundle.css */
.main--catalog .section__aside--catalog .list-checks label:before,
.main--catalog .section__aside--catalog .list-checks label:after {
    display: none !important;
    content: none !important;
    width: 0 !important;
    height: 0 !important;
    border: none !important;
    background: none !important;
}

.main--catalog .section__aside--catalog .list-checks label {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    cursor: pointer;
    transition: color 0.3s ease;
    display: flex !important;
    align-items: center;
    gap: 10px;
    padding: 3px 0 !important;
    padding-left: 0 !important;
    line-height: 1.4;
    position: relative;
}

.main--catalog .section__aside--catalog .list-checks label:hover {
    color: #b6ff3a !important;
}

/* Custom checkbox */
.main--catalog .section__aside--catalog .checkbox-custom {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
    max-width: 18px !important;
    max-height: 18px !important;
    border: 2px solid rgba(255,255,255,.3);
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: all 0.3s ease;
    flex-shrink: 0;
    background: rgba(0,0,0,.2);
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
    aspect-ratio: 1 / 1;
    line-height: 0;
    font-size: 0;
}

.main--catalog .section__aside--catalog .list-checks label:hover .checkbox-custom {
    border-color: rgba(255,255,255,.5);
}

.main--catalog .section__aside--catalog .list-checks input[type="checkbox"]:checked + label .checkbox-custom {
    background: linear-gradient(135deg, #b6ff3a 0%, #00d4ff 100%);
    border-color: #b6ff3a;
}

.main--catalog .section__aside--catalog .list-checks input[type="checkbox"]:checked + label .checkbox-custom:after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #06202c;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

/* View more/fewer toggle links */
.main--catalog .section__aside--catalog .checks-toggle {
    margin-top: 10px;
}

.main--catalog .section__aside--catalog .checks-toggle a {
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    color: #00d4ff !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: color 0.3s ease;
    display: flex;
    align-items: center;
    gap: 6px;
}

.main--catalog .section__aside--catalog .checks-toggle a:hover {
    color: #b6ff3a !important;
}

.main--catalog .section__aside--catalog .checks-toggle strong {
    color: #00d4ff !important;
    font-size: 16px;
}

/* Main content area */
.main--catalog .section__content--catalog {
    background: transparent !important;
    border: none !important;
    border-radius: 0;
}

/* Search results header */
.main--catalog .search-results-header {
    margin-bottom: 32px;
    padding: 24px;
    background: rgba(255,255,255,.03) !important;
    border: 1px solid rgba(139, 223, 255, 0.2) !important;
    border-radius: 16px;
}

.main--catalog .search-results-header h6 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: #cfe6f5 !important;
    margin: 0 !important;
}

.main--catalog .search-results-header h6 strong {
    font-weight: 700 !important;
    color: #b6ff3a !important;
}

.main--catalog .search-results-header h6 span {
    font-weight: 600 !important;
    color: #00d4ff !important;
}

/* Course vendor cards */
.main--catalog .courses--catalog,
.main--catalog .courses--alt {
    background: rgba(255,255,255,.03) !important;
    border: 1px solid rgba(139, 223, 255, 0.2) !important;
    border-radius: 16px;
    padding: 28px;
    margin-bottom: 4rem;
    transition: all 0.4s ease;
    position: relative; /* Necessário para o pseudo-elemento ::after */
}

/* Wrapper para cursos ocultos - aplica grid de 2 colunas aqui */
.main--catalog .courses--catalog .component--hidden,
.main--catalog .courses--alt .component--hidden {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
}

/* Quando não há component--hidden (menos de 7 cursos), aplica grid diretamente nos cursos */
.main--catalog .courses--catalog:not(.component--view-more),
.main--catalog .courses--alt:not(.component--view-more) {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
}

.main--catalog .courses--catalog:hover,
.main--catalog .courses--alt:hover {
    border-color: rgba(182,255,58,.2) !important;
    box-shadow: 0 8px 24px rgba(0,212,255,.08) !important;
    background: rgba(255,255,255,.04) !important;
}

/* Gradiente no final do container quando tem "View More" - só aparece quando não está expandido */
.main--catalog .courses--catalog.component--view-more:not(.expanded)::after,
.main--catalog .courses--alt.component--view-more:not(.expanded)::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 80px;
    background: linear-gradient(to top, #0e1c23d1, #132c38, rgb(19 44 57 / 0%));
    pointer-events: none;
    border-radius: 0 0 16px 16px;
    z-index: 1;
}

/* Course vendor header row */
.main--catalog .courses--catalog .row--head,
.main--catalog .courses--alt .row--head {
    padding-bottom: 20px !important;
    margin-bottom: 20px !important;
    border-bottom: 2px solid rgba(139, 223, 255, 0.15) !important;
    display: flex !important;
    align-items: center;
    gap: 16px;
    grid-column: 1 / -1; /* Ocupa toda a largura nas 2 colunas */
}

.main--catalog .courses--catalog .row--head .col,
.main--catalog .courses--alt .row--head .col {
    display: flex;
    align-items: center;
    gap: 16px;
    width: 100% !important;
    max-width: 100% !important;
    flex: 1 !important;
    position: relative; /* Necessário para posicionar o logo com absolute */
    padding: 20px 10px 15px 0px;
}

/* Logo para courses--catalog - posicionado no topo, no meio da linha da borda */
.main--catalog .courses--catalog .row--head figure,
.main--catalog .courses--catalog .row--head .vendor-logo {
    width: 80px;
    height: 80px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    flex-shrink: 0;
    border-radius: 50%;
    background-color: rgba(255,255,255,.95);
    padding: 8px;
    margin: 0;
    position: absolute;
    top: 0px;
    left: -68px; /* Metade da largura (80px/2) para centralizar na borda */
}

/* Logo para courses--alt - posicionado no topo, no meio da linha da borda */
.main--catalog .courses--alt .row--head figure,
.main--catalog .courses--alt .row--head .vendor-logo {
    width: 80px;
    height: 80px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    flex-shrink: 0;
    border-radius: 50%;
    background-color: rgba(255,255,255,.95);
    padding: 8px;
    margin: 0;
    position: absolute;
    top: 0px;
    left: -68px; /* Metade da largura (80px/2) para centralizar na borda */
}

.main--catalog .courses--alt a.col:hover {
    background: none !important;
}

.main--catalog .courses--catalog .row--head h3,
.main--catalog .courses--alt .row--head h3 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    padding-left: 30px !important;
    margin: 0 !important;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 100%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    letter-spacing: 0.01em !important;
    line-height: 1.3 !important;
}

/* Course rows */
.main--catalog .courses .row:not(.row--head) {
    border-top: 1px solid #112e3c;
}

.courses {
    overflow: visible !important;
}


.courses .courses__actions .btn.active {
    display: none !important;
}

.main--catalog .courses--catalog .row--course,
.main--catalog .courses--alt .row:not(.row--head) {
    padding: 12px 20px;
    transition: background 0.3s ease;
    border-top: 1px solid #112e3c;
}

.main--catalog .courses--catalog .row--course:last-child,
.main--catalog .courses--alt .row:not(.row--head):last-child {
    border-bottom: none !important;
}

.main--catalog .courses--catalog .row--course:hover,
.main--catalog .courses--alt .row:not(.row--head):hover {
    background: rgba(255,255,255,.03) !important;
    border-radius: 8px;
    padding-left: 12px;
    padding-right: 12px;
}

.main--catalog .courses--catalog .course-link,
.main--catalog .courses--alt .row:not(.row--head) a.col {
    display: block;
    text-decoration: none !important;
    transition: all 0.3s ease;
    padding: 10px 10px 5px 10px;
    min-height: unset;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    flex: 1 1 auto !important;
    max-width: 100% !important;
    width: 100% !important;
}

/* Sobrescreve regras de flex do bundle.css */
.main--catalog .courses--catalog .row--course .col,
.main--catalog .courses--alt .row:not(.row--head) .col {
    flex: 1 1 auto !important;
    max-width: 100% !important;
    width: 100% !important;
    -webkit-box-flex: 1 !important;
    -ms-flex: 1 1 auto !important;
}

/* Style topics and titles in courses--alt */
.main--catalog .courses--alt .row:not(.row--head) a.col p {
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    color: #8fb8d1 !important;
    margin: 0 0 8px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.main--catalog .courses--alt .row:not(.row--head) a.col:hover p {
    color: #00d4ff !important;
}

.main--catalog .courses--alt .row:not(.row--head) a.col h5 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    margin: 0 !important;
    line-height: 1.4 !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-wrap: break-word;
    word-break: break-word;
}

.main--catalog .courses--alt .row:not(.row--head) a.col:hover h5 {
    color: #b6ff3a !important;
}

.main--catalog .courses--catalog .course-topics {
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    color: #8fb8d1 !important;
    margin: 0 0 8px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.main--catalog .courses--catalog .course-link:hover .course-topics {
    color: #00d4ff !important;
}

.main--catalog .courses--catalog .course-title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    margin: 0 !important;
    line-height: 1.4 !important;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-wrap: break-word;
    word-break: break-word;
}

.main--catalog .courses--catalog .course-link:hover .course-title {
    color: #b6ff3a !important;
}

/* Certification badge */
.main--catalog .badge--cert {
    display: inline-flex !important;
    align-items: center;
    padding: 4px 12px !important;
    border-radius: 16px !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    background: rgba(0, 212, 255, 0.2) !important;
    color: #80e8ff !important;
    border: 1px solid rgba(0, 212, 255, 0.5) !important;
}

/* View More button - agora está fora do container courses */
.main--catalog .courses__actions {
    text-align: center;
    margin: -6rem auto 2rem; /* Move para cima, metade da altura do botão (~50px / 2) */
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 100%;
}

.main--catalog .courses__actions .btn-pill--gradient,
.main--catalog .courses__actions .btn-pill--blue {
    background: linear-gradient(135deg, #00d4ff 0%, #b6ff3a 100%) !important;
    color: #06202c !important;
    padding: 12px 28px !important;
    border-radius: 30px !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
    cursor: pointer;
    border: none !important;
    box-shadow: 0 4px 15px rgba(0, 212, 255, 0.3) !important;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0 auto;
}

.main--catalog .courses__actions .btn-pill--gradient:hover,
.main--catalog .courses__actions .btn-pill--blue:hover {
    background: linear-gradient(135deg, #00b8e6 0%, #9ee62a 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(182, 255, 58, 0.4) !important;
    color: #06202c !important;
}

/* Remove o overlay laranja do bundle.css */
.main--catalog .courses__actions .btn-pill--gradient:hover:after,
.main--catalog .courses__actions .btn-pill--blue:hover:after {
    display: none !important;
    opacity: 0 !important;
}

.main--catalog .courses__actions .toggle-icon {
    font-size: 18px;
    font-weight: 700;
}

/* No results message */
.main--catalog .no-results {
    background: rgba(255,255,255,.05);
    padding: 60px 40px;
    border-radius: 16px;
    border: 1px solid rgba(139, 223, 255, 0.2);
    text-align: center;
}

.main--catalog .no-results p {
    font-family: 'Poppins', sans-serif !important;
    font-size: 18px !important;
    color: #ffffff !important;
    font-style: italic !important;
    margin: 0;
}

/* Responsive catalog page */
@media (max-width: 1200px) {
    .main--catalog .section-courses .shell {
        grid-template-columns: 240px 1fr;
        gap: 30px;
    }
}

@media (max-width: 1024px) {
    .main--catalog .section-courses .shell {
        grid-template-columns: 1fr;
    }
    
    .main--catalog .section__aside--catalog {
        position: relative;
        top: 0;
    }
    
    .main--catalog .intro-popular-recent {
        gap: 40px;
    }
}

@media (max-width: 768px) {
    .main--catalog .intro-alt--secondary {
        padding: 3rem 0 2rem !important;
    }
    
    .main--catalog .section-courses {
        padding: 3rem 0;
    }
    
    .main--catalog .search-input-wrapper {
        flex-direction: column;
        align-items: stretch;
        padding: 16px;
    }
    
    .main--catalog .search-input-wrapper .btn-pill--red {
        width: 100%;
        justify-content: center;
    }
    
    .main--catalog .intro-popular-recent {
        flex-direction: column;
    }
}

/* ============================================
   Interior Pages Hero - Revamp Style
   ============================================ */

/* Hero intro section - matching course catalog/schedule style */
.main--interior .intro-alt--secondary {
    background: linear-gradient(180deg, rgba(4,25,36,.65) 0%, rgba(6,30,44,.75) 60%, rgba(6,30,44,.85) 100%) !important;
    padding: 3rem 0 2rem;
    position: relative;
    overflow: hidden;
    margin: 0 !important;
    min-height: clamp(250px, 35vh, 400px);
    display: grid;
    align-items: center;
}

/* Decorative overlays */
.main--interior .intro-alt--secondary:before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(900px 360px at 20% 20%, rgba(0,212,255,.15), rgba(0,0,0,0) 60%),
        radial-gradient(1000px 420px at 65% 30%, rgba(124,255,58,.12), rgba(0,0,0,0) 70%);
    pointer-events: none;
    z-index: 1;
}

/* Floating shapes container */
.main--interior .intro-alt--secondary__floating-shapes {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

.main--interior .intro-alt--secondary .shell {
    position: relative;
    z-index: 2;
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.main--interior .intro-alt--secondary__content {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.main--interior .intro-alt--secondary h1 {
    font-family: 'Poppins', sans-serif !important;
    font-size: clamp(36px, 5vw, 56px) !important;
    font-weight: 800 !important;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 60%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    margin: 0 0 12px !important;
    line-height: 1.25 !important;
    text-transform: none !important;
}

.main--interior .intro-alt--secondary p,
.main--interior .intro-alt--secondary .intro-content,
.main--interior .intro-alt--secondary .intro__content p {
    font-family: 'Poppins', sans-serif !important;
    font-size: clamp(16px, 1.6vw, 20px) !important;
    color: #ffffff !important;
    margin: 0 0 1rem !important;
    line-height: 1.5 !important;
    opacity: 0.95;
}

/* For left-image hero type - adjust layout */
.main--interior .intro-alt--secondary.intro-alt--flexed .intro-alt--secondary__content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
    text-align: left;
}

.main--interior .intro-alt--secondary.intro-alt--flexed .intro-alt--secondary__content .intro__content {
    order: 1;
}

.main--interior .intro-alt--secondary.intro-alt--flexed .intro-alt--secondary__content .intro__image {
    order: 2;
    border-radius: 16px;
    overflow: hidden;
    min-height: 400px;
    background-size: cover;
    background-position: center;
}

/* Center hero type - keep centered */
.main--interior .intro-alt--secondary.intro-alt--center .intro-alt--secondary__content {
    text-align: center;
}

/* Responsive for interior pages */
@media (max-width: 1024px) {
    .main--interior .intro-alt--secondary {
        padding: 2rem 0 1.5rem !important;
        min-height: clamp(200px, 30vh, 350px) !important;
    }
    
    .main--interior .intro-alt--secondary.intro-alt--flexed .intro-alt--secondary__content {
        grid-template-columns: 1fr;
        gap: 2rem;
        text-align: center;
    }
    
    .main--interior .intro-alt--secondary.intro-alt--flexed .intro-alt--secondary__content .intro__image {
        order: 1;
        min-height: 300px;
    }
    
    .main--interior .intro-alt--secondary.intro-alt--flexed .intro-alt--secondary__content .intro__content {
        order: 2;
    }
}

/* ===============================
   INTERIOR PAGES REVAMP
   =============================== */

/* Interior page wrapper - ONLY COLORS */
.main--interior {
    background: linear-gradient(180deg, #0c2836 0%, #0a1f2b 100%) !important;
}

/* Hero sections - ONLY VISUAL CHANGES */
.main--interior .intro-alt:before {
    background: linear-gradient(135deg, rgba(10,31,43,.85) 0%, rgba(12,40,54,.75) 100%);
}

.main--interior .intro-alt h1 {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 800 !important;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent !important;
}

.main--interior .intro-alt h2,
.main--interior .intro-alt h3,
.main--interior .intro-alt p {
    font-family: 'Poppins', sans-serif !important;
    color: #cfe6f5 !important;
}

/* Article container - wider width to match header */
.main--interior .article {
    color: #ffffff;
    max-width: 1400px;
    margin: 4rem auto;
    padding: 1rem 20px;
}

/* Ensure article content sections also use wider width */
.main--interior .article > * {
    max-width: 100%;
}

/* Force animate elements to be visible - override bundle.css animation hiding */
.main--interior .animate {
    opacity: 1 !important;
    transform: none !important;
    -webkit-transform: none !important;
}

.main--interior .animate.animate-btt,
.main--interior .animate.animate-rtl,
.main--interior .animate.animate-ltr {
    opacity: 1 !important;
    transform: none !important;
    -webkit-transform: none !important;
}

.main--interior .animate .animate-btt,
.main--interior .animate .animate-rtl,
.main--interior .animate .animate-ltr {
    opacity: 1 !important;
    transform: none !important;
    -webkit-transform: none !important;
}

.main--interior .article > h1,
.main--interior .article > h2 {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    text-align: center;
}

.main--interior .article > p {
    font-family: 'Poppins', sans-serif !important;
    color: #cfe6f5 !important;
    text-align: center;
    font-size: 18px !important;
}

.main--interior .article h1,
.main--interior .article h2,
.main--interior .article h3 {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    color: #b6ff3a !important;
}

.main--interior .article h4 {
    font-family: 'Poppins', sans-serif !important;
    color: #00d4ff !important;
}

.main--interior .article p {
    font-family: 'Poppins', sans-serif !important;
    color: #cfe6f5 !important;
}

.main--interior .article ul {
    list-style-type: disc !important;
    list-style-position: outside !important;
    padding-left: 1.5rem !important;
    margin: 1rem 0 !important;
}

.main--interior .article li {
    font-family: 'Poppins', sans-serif !important;
    color: #cfe6f5 !important;
    list-style-type: disc !important;
    display: list-item !important;
    margin-bottom: 0.5rem;
}

.main--interior .article li::before {
    display: none !important;
    content: none !important;
}

.main--interior .article a {
    color: #00d4ff !important;
    transition: color 0.3s ease;
}

.main--interior .article a:hover {
    color: #b6ff3a !important;
}

/* Form Article - ONLY VISUAL STYLING */
.main--interior .form-article {
    background: rgba(255,255,255,.05) !important;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 20px;
    box-shadow: 0 8px 32px rgba(0,0,0,.2);
}


/* Gravity Forms - ONLY COLORS AND BORDERS */
.main--interior .gform_wrapper .gform_title {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    color: #b6ff3a !important;
}

.main--interior .gform_wrapper .gform_description {
    font-family: 'Poppins', sans-serif !important;
    color: #cfe6f5 !important;
}

.main--interior .gform_wrapper .gfield_label {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 600 !important;
    color: #ffffff !important;
}

.main--interior .gform_wrapper input[type="text"],
.main--interior .gform_wrapper input[type="email"],
.main--interior .gform_wrapper input[type="tel"],
.main--interior .gform_wrapper input[type="url"],
.main--interior .gform_wrapper textarea,
.main--interior .gform_wrapper select {
    background: rgba(255,255,255,.08) !important;
    border: 2px solid rgba(255,255,255,.2) !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    font-family: 'Poppins', sans-serif !important;
    transition: all 0.3s ease !important;
}

.main--interior .gform_wrapper input:focus,
.main--interior .gform_wrapper textarea:focus,
.main--interior .gform_wrapper select:focus {
    border-color: #b6ff3a !important;
    background: rgba(255,255,255,.12) !important;
    box-shadow: 0 0 20px rgba(182,255,58,.15) !important;
}

.main--interior .gform_wrapper ::placeholder {
    color: rgba(255,255,255,.5) !important;
}

.main--interior .gform_wrapper .gform_button,
.main--interior .gform_wrapper input[type="submit"] {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%) !important;
    color: #06202c !important;
    border: none !important;
    border-radius: 30px !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 15px rgba(182,255,58,.3) !important;
}

.main--interior .gform_wrapper .gform_button:hover,
.main--interior .gform_wrapper input[type="submit"]:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(182,255,58,.4) !important;
}

/* Content Columns - Layout and Visual Styling */
.main--interior .content-row--content-columns {
    margin-bottom: 3rem;
}

.main--interior .content-row--content-columns .article__inner {
    max-width: 100% !important;
    padding: 0 !important;
}

.main--interior .content-row--content-columns .row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 24px !important;
    margin-bottom: 2rem !important;
    align-items: flex-start !important;
}

.main--interior .content-row--content-columns .row--col-2 .col {
    flex: 1 1 calc(50% - 12px) !important;
    min-width: 0;
    max-width: calc(50% - 12px) !important;
}

.main--interior .content-row--content-columns .row--col-1 .col {
    flex: 1 1 100% !important;
    max-width: 100% !important;
}

/* Title outside columns - full width */
.main--interior .content-row--content-columns .row h2.primary,
.main--interior .content-row--content-columns .row h2,
.main--interior .content-row--content-columns .row h3:first-child {
    width: 100% !important;
    flex-basis: 100% !important;
    flex: 0 0 100% !important;
    margin-bottom: 2rem !important;
    text-align: center;
}

.main--interior .content-row--content-columns .col {
    background: transparent !important;
    border: none;
    border-radius: 16px;
    padding: 2rem;
    transition: all 0.4s ease;
}

.main--interior .content-row--content-columns .col:hover {
    box-shadow: none;
    transform: none;
    background: transparent !important;
}

.main--interior .content-row--content-columns .col h3,
.main--interior .content-row--content-columns .col h4 {
    color: #ffffff !important;
    font-weight: 700 !important;
    margin-top: 0;
    margin-bottom: 1rem;
}

.main--interior .content-row--content-columns .col p {
    color: #cfe6f5 !important;
    margin-bottom: 0.75rem;
}

.main--interior .content-row--content-columns .col ul {
    color: #cfe6f5 !important;
    margin: 0;
    padding-left: 1.5rem;
}

.main--interior .content-row--content-columns .col li {
    color: #cfe6f5 !important;
    margin-bottom: 0.5rem;
}

.main--interior .content-row--content-columns .col a {
    color: #00d4ff !important;
}

.main--interior .content-row--content-columns .col a:hover {
    color: #b6ff3a !important;
}

.main--interior .content-row--content-columns .col .btn,
.main--interior .content-row--content-columns .col a.btn {
    background: #ffffff !important;
    color: #89e142 !important;
    border: none !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.15) !important;
}

.main--interior .content-row--content-columns .col .btn:hover,
.main--interior .content-row--content-columns .col a.btn:hover {
    background: #f0f0f0 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 16px rgba(0,0,0,.2) !important;
}

/* Features Section - COLORS ONLY */
.main--interior .content-row--features {
    background: linear-gradient(180deg, #0a1f2b 0%, #0c2836 100%);
}

.main--interior .features li {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 16px;
    transition: all 0.4s ease;
}

.main--interior .features li:hover {
    transform: translateY(-8px);
    border-color: rgba(182,255,58,.3);
    box-shadow: 0 12px 32px rgba(0,212,255,.1);
    background: rgba(255,255,255,.05);
}

.main--interior .feature__body h3 {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    color: #b6ff3a !important;
    font-size: 21px!important;
}

.main--interior .feature__body p {
    color: #cfe6f5 !important;
}

.main--interior .feature__body .btn {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    color: #06202c;
    border-radius: 30px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: all 0.3s ease;
}

.main--interior .feature__body .btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(182,255,58,.4);
}

/* Banner Callout - VISUAL ONLY */
.main--interior .section-callout--alt:before {
    background: linear-gradient(135deg, rgba(10,31,43,.85) 0%, rgba(12,40,54,.75) 100%);
}

.main--interior .callout--alt h4 {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.2em !important;
    color: #00d4ff !important;
}

.main--interior .callout--alt h1 {
    font-family: 'Poppins', sans-serif !important;
    font-weight: 800 !important;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent !important;
}

.main--interior .callout--alt p {
    color: #cfe6f5 !important;
}

.main--interior .callout--alt .btn-pill--gradient {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    color: #06202c;
    border-radius: 30px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(182,255,58,.3);
}

.main--interior .callout--alt .btn-pill--gradient:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(182,255,58,.4);
}


.section-features {
    color: #b6ff3a!important;
}

.features {
    gap: 30px;
}

.section-features .features .feature__body {
    background: none!important;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: space-between;
}

.features .feature__body {
    margin: 0!important;
    padding: 2rem!important;
}

.features .feature__body h5 {
    font-size: 20px;
}

.features li {
    padding: 0!important;
    max-width: 31%;
}

.features .feature__body .btn {
    padding:  10px 14px!important;
    position: relative!important;
    left: unset!important;
    transform: unset!important;
}

.features .feature__head {
    background-color: white!important;
}



/* Partners Page - Clean Grid Layout FIX */
.page-id-102147 .content-row--alternating-blocks {
    padding: 60px 0;
}

.page-id-102147 .content-row--alternating-blocks .row {
    display: inline-flex !important;
    flex-direction: row !important;
    width: auto !important;
    max-width: 250px !important;
    margin: 15px !important;
    vertical-align: top !important;
    flex-direction: column;
    float: left !important;
}

.page-id-102147 .content-row--alternating-blocks {
    text-align: center;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0px 40px 60px;
    display: flex;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
}

.page-id-102147 .content-row--alternating-blocks::after {
    content: '';
    display: table;
    clear: both;
}

.page-id-102147 .content-row--alternating-blocks .article__image {
    flex: 1;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 30px !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08) !important;
    transition: all 0.3s ease !important;
    min-height: 180px !important;
    border: 1px solid rgba(0, 0, 0, 0.06) !important;
    width: 100% !important;
}

.page-id-102147 .content-row--alternating-blocks .article__image:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 8px 24px rgba(0, 148, 218, 0.15) !important;
    border-color: rgba(0, 148, 218, 0.3) !important;
}

.page-id-102147 .content-row--alternating-blocks .article__image img {
    max-width: 100% !important;
    max-height: 160px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    transition: all 0.3s ease !important;
}

.page-id-102147 .content-row--alternating-blocks .article__image:hover img {
    transform: scale(1.05) !important;
}

.page-id-102147 .content-row--alternating-blocks .article__content {
    display: none !important;
}

/* Responsive */
@media (max-width: 1200px) {
    .page-id-102147 .content-row--alternating-blocks .row {
        max-width: 220px !important;
        margin: 12px !important;
    }
}

@media (max-width: 768px) {
    .page-id-102147 .content-row--alternating-blocks {
        padding: 40px 20px;
    }
    
    .page-id-102147 .content-row--alternating-blocks .row {
        max-width: 45% !important;
        margin: 10px 2% !important;
    }
    
    .page-id-102147 .content-row--alternating-blocks .article__image {
        padding: 20px !important;
        min-height: 150px !important;
    }
}

@media (max-width: 480px) {
    .page-id-102147 .content-row--alternating-blocks .row {
        max-width: 100% !important;
        margin: 10px 0 !important;
        float: none !important;
    }
    
    .page-id-102147 .content-row--alternating-blocks .article__image {
        min-height: 140px !important;
    }
}

/* Improve header section */
.page-id-102147 .intro-alt--secondary {
    background: linear-gradient(135deg, #0F2C4C 0%, #1a4d7a 100%);
    position: relative;
    overflow: hidden;
}

.page-id-102147 .intro-alt--secondary__content {
    text-align: center;
    position: relative;
    z-index: 2;
    padding: 80px 20px;
}

.page-id-102147  .article .row .article__image:after {
    display: none!important;
}

.page-id-102147 .article .row .article__image {
    max-width: unset!important;
}

.page-id-102147 .intro-alt--secondary__content h1 {
    font-size: 3.5rem;
    margin-bottom: 25px;
    color: #ffffff;
    font-weight: 700;
}

.page-id-102147 .intro-alt--secondary__content p {
    font-size: 1.25rem;
    max-width: 800px;
    margin: 0 auto;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.95);
}

@media (max-width: 768px) {
    .page-id-102147 .intro-alt--secondary__content h1 {
        font-size: 2.5rem;
    }
    
    .page-id-102147 .intro-alt--secondary__content p {
        font-size: 1.1rem;
    }
}

/* ==========================================================================
   BLOG PAGE REVAMP STYLES
   ========================================================================== */

/* Blog Main Layout */
.main--blog {
    background: linear-gradient(180deg, #0c2836 0%, #0a1f2b 100%);
}

/* Blog Hero Section - Matching Catalog Page Style */
.main--blog .intro-alt--secondary {
    background: linear-gradient(180deg, rgba(4,25,36,.65) 0%, rgba(6,30,44,.75) 60%, rgba(6,30,44,.85) 100%) !important;
    padding: 4rem 0 3rem;
    position: relative;
    overflow: hidden;
    margin: 0 !important;
    min-height: clamp(400px, 50vh, 600px);
    display: grid;
    align-items: center;
}

/* Decorative overlays like catalog page */
.main--blog .intro-alt--secondary:before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(900px 360px at 20% 20%, rgba(0,212,255,.15), rgba(0,0,0,0) 60%),
        radial-gradient(1000px 420px at 65% 30%, rgba(124,255,58,.12), rgba(0,0,0,0) 70%);
    pointer-events: none;
    z-index: 1;
}

/* Floating shapes container */
.main--blog .intro-alt--secondary__floating-shapes {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

.main--blog .intro-alt--secondary .shell {
    position: relative;
    z-index: 2;
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 20px;
}

.main--blog .intro-alt--secondary__content {
    text-align: center;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.main--blog .intro-alt--secondary__content .eyebrow-label {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.28em;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 80%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: 16px;
    display: inline-block;
}

.main--blog .intro-alt--secondary__content h1 {
    font-family: 'Poppins', sans-serif !important;
    font-size: clamp(36px, 5vw, 56px) !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    margin: 0 0 12px !important;
    line-height: 1.25 !important;
    text-transform: none !important;
}

.main--blog .intro-alt--secondary__content h1 .gradient-text {
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 60%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
}

.main--blog .intro-alt--secondary__content p {
    font-size: clamp(16px, 1.6vw, 20px) !important;
    color: #ffffff !important;
    opacity: 0.95;
    max-width: 800px;
    margin: 0 auto;
    line-height: 1.6;
}

/* Section Blog */
.section-blog {
    padding: 5rem 0;
}

/* Featured Post */
.featured-post {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 60px;
    align-items: center;
    margin-bottom: 80px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 20px;
    padding: 40px;
    transition: all 0.4s ease;
}

.featured-post:hover {
    transform: translateY(-4px);
    border-color: rgba(182, 255, 58, 0.3);
    box-shadow: 0 12px 32px rgba(0, 212, 255, 0.1);
    background: rgba(255, 255, 255, 0.05);
}

.featured-post__image {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
}

.featured-post__image a {
    display: block;
}

.featured-post__image img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.5s ease;
}

.featured-post:hover .featured-post__image img {
    transform: scale(1.05);
}

.featured-post__content {
    padding: 20px 0;
}

.post-category {
    margin-bottom: 16px;
}

.post-category a {
    display: inline-block;
    padding: 6px 16px;
    background: rgba(182, 255, 58, 0.15);
    color: #b6ff3a;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    transition: all 0.3s ease;
}

.post-category a:hover {
    background: rgba(182, 255, 58, 0.25);
    color: #d4ff6b;
}

.featured-post__content h2 {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 16px;
}

.featured-post__content h2 a {
    color: #ffffff;
    text-decoration: none;
    transition: color 0.3s ease;
}

.featured-post__content h2 a:hover {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.post-meta {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 20px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.6);
}

.post-meta .post-date,
.post-meta .post-author {
    display: flex;
    align-items: center;
    gap: 6px;
}

.post-excerpt {
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.6;
    margin-bottom: 24px;
    font-size: 16px;
}

/* Blog Section Header */
.blog-section-header {
    text-align: left;
    margin-bottom: 60px;
}

.blog-section-header .eyebrow-label {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.28em;
    background: linear-gradient(90deg, #b6ff3a 0%, #8bdfff 80%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: 16px;
    display: inline-block;
}

.blog-section-header h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    color: #ffffff;
    line-height: 1.2;
}

.blog-section-header h2 .gradient-text {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

/* Blog Grid */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-bottom: 60px;
}

/* Blog Card */
.blog-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    overflow: hidden;
    transition: all 0.4s ease;
    display: flex;
    flex-direction: column;
}

.blog-card:hover {
    transform: translateY(-8px);
    border-color: rgba(182, 255, 58, 0.3);
    box-shadow: 0 12px 32px rgba(0, 212, 255, 0.1);
    background: rgba(255, 255, 255, 0.05);
}

.blog-card__image {
    position: relative;
    width: 100%;
    height: 240px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.02);
}

.blog-card__image a {
    display: block;
    height: 100%;
}

.blog-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.blog-card:hover .blog-card__image img {
    transform: scale(1.08);
}

.blog-card__image--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(182, 255, 58, 0.1) 0%, rgba(0, 212, 255, 0.1) 100%);
}

.blog-card__image--placeholder .placeholder-icon {
    font-size: 48px;
    color: rgba(255, 255, 255, 0.3);
}

.blog-card__content {
    padding: 28px 24px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.blog-card__content .post-category {
    margin-bottom: 12px;
}

.blog-card__content h3 {
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 12px;
}

.blog-card__content h3 a {
    color: #ffffff;
    text-decoration: none;
    transition: color 0.3s ease;
}

.blog-card__content h3 a:hover {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.blog-card__content .post-meta {
    margin-bottom: 16px;
}

.blog-card__content .post-excerpt {
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.5;
    margin-bottom: 20px;
    font-size: 15px;
    flex-grow: 1;
}

.blog-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #00d4ff;
    font-weight: 600;
    font-size: 15px;
    text-decoration: none;
    transition: all 0.3s ease;
    position: relative;
}

.blog-card__cta .arrow {
    transition: transform 0.3s ease;
}

.blog-card__cta:hover {
    color: #b6ff3a;
}

.blog-card__cta:hover .arrow {
    transform: translateX(4px);
}

/* Pagination */
.blog-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 60px;
}

.blog-pagination .page-numbers {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.blog-pagination .page-numbers li {
    list-style: none;
    margin: 0;
    padding: 0;
}

.blog-pagination .page-numbers li::before {
    display: none !important;
    content: none !important;
}

.blog-pagination a,
.blog-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    height: 48px;
    padding: 0 16px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    color: #ffffff;
    text-decoration: none;
    font-weight: 600;
    font-size: 15px;
    transition: all 0.3s ease;
}

.blog-pagination a:hover {
    background: rgba(182, 255, 58, 0.15);
    border-color: rgba(182, 255, 58, 0.3);
    color: #b6ff3a;
    transform: translateY(-2px);
}

.blog-pagination .current {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%) !important;
    border-color: transparent !important;
    color: #06202c !important;
    font-weight: 700;
}

.blog-pagination .prev,
.blog-pagination .next {
    gap: 8px;
    padding: 0 20px;
}

.blog-pagination .dots {
    border: none !important;
    background: transparent !important;
    color: rgba(255, 255, 255, 0.3) !important;
    min-width: 40px !important;
}

/* No Posts Message */
.no-posts {
    text-align: center;
    padding: 80px 20px;
    color: rgba(255, 255, 255, 0.7);
    font-size: 18px;
}

/* Responsive Design */
@media (max-width: 1200px) {
    .blog-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 28px;
    }
}

@media (max-width: 1024px) {
    .featured-post {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 32px;
    }
    
    .section-blog {
        padding: 4rem 0;
    }
}

@media (max-width: 768px) {
    .blog-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    
    .featured-post {
        margin-bottom: 60px;
        padding: 24px;
    }
    
    .blog-section-header {
        margin-bottom: 40px;
    }
    
    .main--blog .intro-alt--secondary {
        padding: 3rem 0 2.5rem;
        min-height: clamp(350px, 45vh, 500px);
    }
    
    .main--blog .intro-alt--secondary__content {
        padding: 0 20px;
    }
    
    .blog-pagination {
        margin-top: 40px;
    }
    
    .blog-pagination a,
    .blog-pagination span {
        min-width: 40px;
        height: 40px;
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .featured-post {
        padding: 20px;
    }
    
    .blog-card__content {
        padding: 20px;
    }
    
    .post-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
}

/* ==========================================================================
   SINGLE POST PAGE STYLES
   ========================================================================== */

/* Single Post Main Layout */
.main--single-post {
    background: linear-gradient(180deg, #0c2836 0%, #0a1f2b 100%);
}

/* Single Post Hero - Same as blog listing */
.main--single-post .intro-alt--secondary {
    background: linear-gradient(180deg, rgba(4,25,36,.65) 0%, rgba(6,30,44,.75) 60%, rgba(6,30,44,.85) 100%) !important;
    padding: 4rem 0 3rem;
    position: relative;
    overflow: hidden;
    margin: 0 !important;
    min-height: clamp(350px, 45vh, 500px);
    display: grid;
    align-items: center;
}

.main--single-post .intro-alt--secondary:before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(900px 360px at 20% 20%, rgba(0,212,255,.15), rgba(0,0,0,0) 60%),
        radial-gradient(1000px 420px at 65% 30%, rgba(124,255,58,.12), rgba(0,0,0,0) 70%);
    pointer-events: none;
    z-index: 1;
}

.main--single-post .intro-alt--secondary__floating-shapes {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

.main--single-post .intro-alt--secondary .shell {
    position: relative;
    z-index: 2;
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 20px;
}

.main--single-post .intro-alt--secondary__content {
    text-align: center;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
}

.main--single-post .breadcrumb-back {
    margin-bottom: 20px;
}

.main--single-post .back-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 15px;
    font-weight: 500;
    transition: all 0.3s ease;
}

.main--single-post .back-link:hover {
    color: #b6ff3a;
    transform: translateX(-4px);
}

.main--single-post .intro-alt--secondary h1 {
    font-family: 'Poppins', sans-serif !important;
    font-size: clamp(32px, 4.5vw, 48px) !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    margin: 20px 0 !important;
    line-height: 1.2 !important;
}

.main--single-post .intro-alt--secondary .post-meta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin-top: 16px;
    font-size: 15px;
    color: rgba(255, 255, 255, 0.7);
}

.main--single-post .intro-alt--secondary .post-meta i {
    margin-right: 6px;
    color: #00d4ff;
}

/* Single Post Content Section */
.section-single-post {
    padding: 5rem 0;
}

.single-post-container {
    display: grid;
    grid-template-columns: 1fr 350px;
    gap: 60px;
    align-items: start;
}

/* Post Content */
.post-content {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 20px;
    padding: 0;
    overflow: hidden;
}

.post-featured-image {
    width: 100%;
    overflow: hidden;
}

.post-featured-image img {
    width: 100%;
    height: auto;
    display: block;
}

.post-content-body {
    padding: 48px;
    color: rgba(255, 255, 255, 0.85);
    font-size: 17px;
    line-height: 1.8;
}

.post-content-body h2,
.post-content-body h3,
.post-content-body h4 {
    color: #ffffff;
    font-weight: 700;
    margin-top: 32px;
    margin-bottom: 16px;
}

.post-content-body h2 {
    font-size: 32px;
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.post-content-body h3 {
    font-size: 26px;
}

.post-content-body h4 {
    font-size: 22px;
}

.post-content-body p {
    margin-bottom: 24px;
}

.post-content-body ul,
.post-content-body ol {
    margin: 24px 0;
    padding-left: 32px;
}

.post-content-body li {
    margin-bottom: 12px;
}

.post-content-body a {
    color: #00d4ff;
    text-decoration: underline;
    transition: color 0.3s ease;
}

.post-content-body a:hover {
    color: #b6ff3a;
}

.post-content-body blockquote {
    border-left: 4px solid #b6ff3a;
    padding-left: 24px;
    margin: 32px 0;
    font-style: italic;
    color: rgba(255, 255, 255, 0.9);
}

.post-content-body img {
    max-width: 100%;
    height: auto;
    border-radius: 12px;
    margin: 32px 0;
}

.post-content-body code {
    background: rgba(182, 255, 58, 0.1);
    color: #b6ff3a;
    padding: 2px 8px;
    border-radius: 4px;
    font-family: 'Courier New', monospace;
    font-size: 0.9em;
}

.post-content-body pre {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    padding: 20px;
    overflow-x: auto;
    margin: 32px 0;
}

.post-content-body pre code {
    background: none;
    padding: 0;
}

/* Post Sidebar */
.post-sidebar {
    position: sticky;
    top: 140px;
}

.subscribe-box {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    padding: 28px;
}

.subscribe-box h5 {
    font-size: 18px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 20px;
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.subscribe-box p {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 20px;
    line-height: 1.5;
}

/* Subscribe Form Styling */
.subscribe-box input[type="email"],
.subscribe-box input[type="text"] {
    background: rgba(255, 255, 255, 0.08);
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-radius: 8px;
    padding: 12px 16px;
    width: 100%;
    color: #ffffff;
    font-size: 15px;
    font-family: 'Poppins', sans-serif;
    transition: all 0.3s ease;
}

.subscribe-box input[type="email"]::placeholder,
.subscribe-box input[type="text"]::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.subscribe-box input[type="email"]:focus,
.subscribe-box input[type="text"]:focus {
    outline: none;
    border-color: #b6ff3a;
    background: rgba(255, 255, 255, 0.12);
    box-shadow: 0 0 20px rgba(182, 255, 58, 0.15);
}

.subscribe-box .gform_button,
.subscribe-box button[type="submit"],
.subscribe-box input[type="submit"] {
    width: 100%;
    background: linear-gradient(135deg, #00d4ff 0%, #b6ff3a 100%);
    color: #06202c;
    border: none;
    padding: 14px 24px;
    border-radius: 8px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 15px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: 12px;
}

.subscribe-box .gform_button:hover,
.subscribe-box button[type="submit"]:hover,
.subscribe-box input[type="submit"]:hover {
    background: linear-gradient(135deg, #00b8e6 0%, #9ee62a 100%);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(182, 255, 58, 0.4);
}

/* Related Posts Section */
.section-related-posts {
    background: linear-gradient(180deg, #0a1f2b 0%, #081720 100%);
    padding: 5rem 0;
}

.section-related-posts .section-header {
    text-align: center;
    margin-bottom: 60px;
}

.section-related-posts .section-header h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    color: #ffffff;
    line-height: 1.2;
}

.section-related-posts .section-header h2 .gradient-text {
    background: linear-gradient(90deg, #b6ff3a 0%, #00d4ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.related-posts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}

/* Responsive Design for Single Post */
@media (max-width: 1200px) {
    .single-post-container {
        grid-template-columns: 1fr 300px;
        gap: 40px;
    }
    
    .related-posts-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 1024px) {
    .single-post-container {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    
    .post-sidebar {
        position: relative;
        top: 0;
    }
}

@media (max-width: 768px) {
    .section-single-post {
        padding: 4rem 0;
    }
    
    .post-content-body {
        padding: 32px 24px;
        font-size: 16px;
    }
    
    .related-posts-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    
    .main--single-post .intro-alt--secondary {
        min-height: clamp(300px, 40vh, 450px);
        padding: 3rem 0 2.5rem;
    }
    
    .main--single-post .intro-alt--secondary .post-meta {
        flex-direction: column;
        gap: 12px;
    }
}

@media (max-width: 480px) {
    .post-content-body {
        padding: 24px 20px;
    }
    
    .author-box,
    .subscribe-box {
        padding: 20px;
    }
}
