﻿/* BS COLORS OVERRIDE */
:root {
    --bs-link-color-rgb: 16, 69, 181;
    --bs-primary-rgb: 16, 69, 181;
}

/* NEW SECTIONS */

/* SECONDARY PAGE HERO */
.page-hero {
    --hero-overlay-opacity: 0.5;
    --hero-min-height: 60dvh;
    position: relative;
    width: 100%;
    min-height: var(--hero-min-height);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    overflow: hidden;
    color: #fff;
    text-wrap: balance;
}

.page-hero-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    overflow: hidden;
}

.page-hero-background::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(60deg, black, transparent 70%);
    opacity: var(--hero-overlay-opacity);
}

.page-hero-background img,
.page-hero-background video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.page-hero-content {
    position: relative;
    z-index: 2;
    width: 100%;
    padding: 5rem 0;
    display: flex;
    align-items: center;
}

.page-hero h1 {
    font-size: 2.5rem;
    font-weight: 700;
}

.page-hero h1:has(+ h2) {
    margin-bottom: 2rem;
}

.page-hero h2 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.page-hero p {
    margin-bottom: 0;
}

.page-hero strong {
    font-weight: 700;
    color: inherit;
}

.page-hero .dark-button {
    display: inline-block;
    margin-top: 1rem;
}

@media (max-width: 768px) {
    .page-hero {
        --hero-min-height: 70dvh;
    }

    .page-hero-content {
        padding: 10rem 0 3rem;
    }
}

/* CONTENT SECTION */
.content-section {
    padding: 4rem 0;
    text-wrap: balance;
}

.content-section .row {
    gap: 0;
}

.content-section .content-section-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}

.content-section .content-section-media {
    overflow: hidden;
    border-radius: 10px;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.05);
}

.content-section .content-section-title {
    font-weight: 700;
    font-size: 2.25rem;
    color: #1045B5;
    margin-bottom: 1rem;
}

@media (max-width: 768px) {
    .content-section {
        padding: 2rem 0;
    }
}

/* CARDS SECTION */
.cards-section .card {
    padding: 0 !important;
    height: 100%;
    border-radius: 10px;
    background: #E8EDF8;
    --bs-card-border-width: 0;
    --bs-card-title-spacer-y: 1rem;
    --bs-card-title-color: #1045B5;

}
.cards-section .card .card-img-top {
    border-radius: 10px 10px 0 0;
    aspect-ratio: 16/9;
    object-fit: cover;
}
.cards-section .card .card-body {
    padding: 30px;
    display: flex;
    flex-direction: column;
}

.cards-section .card .card-title {
    font-weight: 700;
    font-size: 1.25rem;
    color: #1045B5;
}

.cards-section .card .btn {
    width: 100%;
    margin-top: auto;
}
.cards-section .card .card-text:has(+ .btn) {
    margin-bottom: 2rem;
}

/* TEXT HIGHLIGHT SECTION */
.text-highlight-section {
    padding: 4rem 0;
}

.text-highlight-section .row {
    gap: 0 !important;
    display: flex !important;
}

.text-highlight-section h2 {
    text-align: center;
    text-wrap: balance;
    margin-bottom: 3rem;

}

.text-highlight-section h2 i {
    color: #1045B5;
    font-style: normal;
    font-weight: 700;
}

.text-highlight-section img {
    border-radius: 10px;
    aspect-ratio: 1;
    object-fit: cover;
}

/* CTA BANNER */
.cta-banner {
    padding: 5rem 0;
    margin-inline: 1rem;
    border-radius: 1rem;
    text-align: center;
    background: #E8EDF8;
    text-wrap: balance;
}

.cta-banner h2 {
    font-weight: 700;
    text-align: center;
}

.cta-banner .cta-banner-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

/* POLICIES SECTION */
.policies-section .list-group-item {
    padding: 1rem 0;
}

.policies-section .list-group-item a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    text-decoration: none;
    color: #000;
}

.policies-section .list-group-item a:hover {
    color: #1045B5;
}

.policies-section .list-group-item a i {
    color: #1045B5;
    font-size: 1.5rem;
}

/* MISCELLANEOUS */
.plyr {
    --plyr-color-main: #1045B5;
}

.plyr .plyr__control--overlaid {
    --plyr-control-icon-size: 1.5rem;
    --plyr-control-spacing: 1.25rem;
    opacity: 1;
}

.plyr .plyr__poster {
    background-color: transparent;
}


/* ENTIRE HOME PAGE*/
.app-main {
    font-family: 'Montserrat';
    font-style: normal;
}

/* ColourBar */
.colour-top-bar {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 476px;
    position: absolute;
    height: 15px;
    /* AT_Blue */
    background-color: #1045B5;
}

/* Buttons */
.login-button {
    text-decoration: none;
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 10px;
    gap: 10px;
    width: 198px;
    height: 40px;
    /* AT_Blue */
    border: 1px solid #1045B5;
    border-radius: 10px;
    flex: none;
    order: 0;
    flex-grow: 0;
}

.dark-button {
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 10px 20px;
    gap: 10px;
    /* AT_Blue */
    background: #1045B5;
    border-radius: 10px;
    flex: none;
    order: 1;
    flex-grow: 0;
    /* Button text */
    font-weight: 600;
    font-size: 16px;
    line-height: 20px;
    text-align: center;
    /* AT_White */
    color: #FFFFFF;
    flex: none;
    order: 0;
    flex-grow: 0;
    text-decoration: none;
}
.btn {
    border-radius: 6px;
    padding: 10px 20px;
    background: #1045B5;
    color: #fff;
}
.btn.btn-outline-primary {
    border: 1px solid #1045B5;
    color: #1045B5;
    background: transparent;
}

.transparent-button {
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 15px 10px;
    gap: 10px;
    height: 40px;
    border-radius: 10px;
    flex: none;
    order: 1;
    align-self: stretch;
    flex-grow: 0;
}

.transparent-button.transparent-button-white {
    /* AT_White */
    border: 1px solid #FFFFFF;
}

.transparent-button.transparent-button-blue {
    /* AT_Blue */
    border: 1px solid #1045B5;
}

.transparent-button .transparent-button-text {
    align-items: center;
    font-weight: 600;
    font-size: 14px;
    line-height: 17px;
    text-align: center;
    flex: none;
    order: 0;
    flex-grow: 0;
    text-decoration: none;
}

.transparent-button .transparent-button-text.transparent-button-text-white {
    /* AT_White */
    color: #FFFFFF;
}

.transparent-button .transparent-button-text.transparent-button-text-blue {
    /* AT_Blue */
    color: #1045B5;
}

/* Make the entire button clickable, not just the text */
.transparent-button a {
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    width: 100%;
    height: 100%;
}

/* Header */
.header-main {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
}

/* Hide header divider if the page has a banner group */
header:has(~ div main > .bannerGroup) .header-divider,
header:has(~ div main > .page-hero) .header-divider {
    display: none;
}

.header-main .logo {
    flex-shrink: 0;
}

.header-main .menu-items {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 50px;
}

.header-main .menu-items .top-menu {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 20px;
}

.header-main .menu-items .top-menu a {
    color: #7f7f7f;
    text-decoration: none;
}

.header-main .menu-items .nav-button-container {
    display: inline-flex;
    align-items: center;
    gap: 15px;
}

.header-main .menu-items .nav-button-container .navbar-toggler {
    display: none;
    padding: 10px;
    width: 40px;
    height: 40px;
    border: 1px solid #1045B5;
    background: none;
    border-radius: 10px;
}

.header-main .menu-items .cta-button {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    padding: 0px;
    gap: 15px;
}

.header-main .menu-items .cta-button a {
    font-weight: 600;
    font-size: 16px;
    line-height: 20px;
    text-align: center;
    color: #000000;
    text-decoration: none;
}

.header-sub {
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 30px 0;
    border-top: 1px solid #EEEEEE;
}

.header-sub .header-sub-items {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    align-items: center;
    flex-grow: 1;
    gap: 30px;
}

.header-sub .header-sub-items a {
    font-weight: 600;
    font-size: 18px;
    line-height: 22px;
    text-align: center;
    /* AT_Black */
    color: #1D1D1D;
    /* Menu Item */
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    gap: 10px;
}

.mobile-menu {
    --bs-offcanvas-padding-x: 2rem;
}

.mobile-menu .offcanvas-title {
    font-weight: 700;
    color: #1045B5;
}

.mobile-menu .navbar-nav {
    --bs-nav-link-padding-x: 0rem;
    --bs-nav-link-font-weight: 600;
}

.mobile-menu .navbar-nav .nav-link {
    font-weight: var(--bs-nav-link-font-weight);
    padding-inline: var(--bs-nav-link-padding-x);
}

@media (max-width: 768px) {

    .header-main .menu-items .top-menu,
    .header-sub {
        display: none;
    }

    .header-main .menu-items .nav-button-container .navbar-toggler {
        display: block;
    }
}

/* Banner */
.banner-1 {
    width: 100%;
    position: relative;
    height: 620px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    flex: none;
    align-self: stretch;
    flex-grow: 0;
}

.banner-1 .background-video {
    z-index: 0;
    /* Sends the video to the back */
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.banner-1 .caption {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    padding-top: 50px;
    padding-bottom: 12vw;
    gap: 10px;
}

.banner-1 h1 {
    font-weight: 700;
    font-size: 36px;
    line-height: 44px;
    color: #FFFFFF;
}

.banner-2 {
    margin-top: -8vw;
}

.banner-2 .frame {
    position: relative;
    display: grid;
    grid-template-columns: 30% 1fr;
    gap: 2rem;
    padding: 30px;
    background: #FFFFFF;
    border: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color);
    box-shadow: 0 1rem 3rem rgba(0,0,0,.175), 12px 12px 0px #1045B5;
    border-radius: 10px;
    z-index: 1;
}

.banner-2 .frame .ImSearching {
    font-weight: 700;
    font-size: 28px;
    line-height: 34px;
    color: #1045B5;
}

.banner-2 .frame .text {
    margin-bottom: 3rem;
}

.banner-2 .frame .gsc-clear-button {
    display: none;
}

.banner-2 .frame .gsc-control {
    width: auto;
}

.banner-2 .frame .gsc-input {
    background: none !important;
}

.banner-2 .frame .text {
    font-weight: 400;
    font-size: 16px;
    line-height: 140%;
    /* or 22px */
    color: #000000;
}

.banner-2 .frame .quikcSelectMenu .quickSelectFrame {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    /* Two equal-width columns */
    grid-template-rows: repeat(4, auto);
    /* Allow for 4 items per column */
    overflow: hidden;
    gap: 0 1.25rem;
}

.banner-2 .frame .quikcSelectMenu .quickSelectFrame .qsItem {
    display: flex;
    flex-direction: row;
    align-items: center;
    border-bottom-width: 1px;
    padding: 0.75rem 0;
    border-style: solid;
    border-color: #AAAAAA;
}

.banner-2 .frame .quikcSelectMenu .quickSelectFrame .qsItem:nth-child(-n+2) {
    border-top-width: 1px;
}

.banner-2 .frame .quikcSelectMenu .quickSelectFrame .qsItem a {
    text-decoration: none;
    width: 100%;
}

.banner-2 .frame .quikcSelectMenu .quickSelectFrame .qsItem a .qsText {
    display: flex;
    align-items: center;
    font-weight: 700;
    font-size: 16px;
    line-height: 20px;
    color: #000000;
    gap: 0.5rem;
}

.banner-2 .frame .quikcSelectMenu .quickSelectFrame .qsItem a .qsText i {
    margin-left: auto;
    color: #1045B5;
    font-size: 25px;
}

@media (max-width: 768px) {
    .banner-1 {
        height: 70svh;
    }

    .banner-2 {
        margin-top: -1rem;
    }

    .banner-2 .frame {
        grid-template-columns: 1fr;
    }

    .banner-2 .frame .quikcSelectMenu .quickSelectFrame {
        grid-template-columns: 1fr;
    }

    .banner-2 .frame .quikcSelectMenu .quickSelectFrame .qsItem:nth-child(2) {
        border-top-width: 0px;
    }
}

/* Title */
.contentSection {
    margin: 5rem 0;
}

.cardTitle .cardTitleText {
    font-weight: 700;
    font-size: 32px;
    line-height: 40px;
    margin-bottom: 1rem;
    text-align: center;
    /* AT_Blue */
    color: #1045B5;
}

.tilesContainer {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 30px;
    background: #FFFFFF;
}

.tilesContainer .newTile {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    border-radius: 10px;
    overflow: hidden;
}

.tilesContainer .newTile.industryTile {
    justify-content: flex-end;
    gap: 20px;
    padding: 30px;
}

.tilesContainer .newTile .tileTitle {
    font-weight: 700;
    font-size: 18px;
    line-height: 22px;
    flex: none;
    order: 0;
    align-self: stretch;
    flex-grow: 0;
}

.tilesContainer .newTile .tileTitle.tileTitle-white {
    height: 22px;
    color: #FFFFFF;
}

.tilesContainer .newTile .tileTitle.tileTitle-blue {
    height: 44px;
    /* AT_Blue */
    color: #1045B5;
}

.tilesContainer .courseTile .tileImage {
    width: 100%;
    max-inline-size: none;
    height: 160px;
    object-fit: cover;
}

.tilesContainer .courseTile .tileFrame {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 30px 15px 15px;
    gap: 15px;
    /* AT_Blue@10% */
    background: #E8EDF8;
    flex: none;
    order: 1;
    align-self: stretch;
    flex-grow: 0;
}

.industriesTilesSection .tilesContainer {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.industriesTilesSection .tilesContainer .newTile {
    aspect-ratio: 1;
}

.coursesTilesSection .tilesContainer {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

@media (max-width: 991px) {

    .industriesTilesSection .tilesContainer,
    .coursesTilesSection .tilesContainer {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .coursesTilesSection .tilesContainer {
        grid-template-columns: repeat(1, 1fr);
    }

    .contentSection {
        margin: 3rem 0;
    }
}

@media (max-width: 576px) {
    .industriesTilesSection .tilesContainer {
        grid-template-columns: repeat(1, 1fr);
    }
}

/* SALE - Low specifity to target _CoursesList with old styles */
.onSale {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 10px 25px;
    gap: 10px;
    position: absolute;
    width: 124px;
    height: 40px;
    left: 10px;
    top: 13.27px;
    /* AT_MutedBlue */
    background: #4070D5;
    border-radius: 100px;
}

.onSale .onSale-text {
    width: 74px;
    height: 20px;
    font-weight: 700;
    font-size: 16px;
    line-height: 20px;
    /* AT_White */
    color: #FFFFFF;
    flex: none;
    order: 0;
    flex-grow: 0;
}

/* Training you can rely */
.trainingRely {
    min-height: 70svh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.trainingRely .textContainer {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    max-width: 600px;
    padding-block: 5rem;
}

.trainingRely .textContainer .title {
    height: 34px;
    font-weight: 700;
    font-size: 28px;
    line-height: 34px;
    /* AT_White */
    color: #FFFFFF;
    flex: none;
    order: 0;
    align-self: stretch;
    flex-grow: 0;
}

.trainingRely .textContainer p {
    font-weight: 400;
    font-size: 16px;
    line-height: 140%;
    /* AT_White */
    color: #FFFFFF;
    flex: none;
    order: 1;
    align-self: stretch;
    flex-grow: 0;
}

/* Testimonials */
.testimonials {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    background: #FFFFFF;
}

.testimonials .card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 30px;
    gap: 20px;
    /* AT_Blue@10% */
    background: #E8EDF8;
    border-radius: 10px;
}

.testimonials .card i {
    font-size: 48px;
    color: #1045B5;
}

.testimonials .card .text p {
    font-weight: 400;
    font-size: 16px;
    line-height: 140%;
    color: #000000;
}

.testimonials .card .author {
    margin-top: auto;
    display: flex;
    align-items: center;
    gap: 15px;
    /* AT_Blue */
    color: #1045B5;
}

.testimonials .card .author .text {
    height: 22px;
    font-weight: 700;
    font-size: 18px;
    line-height: 22px;
    text-align: center;
    flex: none;
    order: 1;
    flex-grow: 0;
}

@media (max-width: 991px) {
    .testimonials {
        grid-template-columns: repeat(1, 1fr);
    }
}

/* Contact Us */
/* In house training contact form */
.contactForm {
    padding: 4rem 0 2rem;
}

.contactForm .contactFormContainer {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
}

.contactForm .infoContainer {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 3rem;
}

.contactForm .infoContainer .title {
    font-weight: 700;
    font-size: 32px;
    line-height: 40px;
    /* AT_Blue */
    color: #1045B5;
}

.contactForm .infoContainer .disclaimer {
    font-weight: 400;
    font-size: 16px;
    line-height: 150%;
    color: #000000;
}

.contactForm .infoContainer .info {
    font-size: 18px;
    line-height: 150%;
    color: #000000;
}

.contactForm .formContainer {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 15px;
    box-sizing: border-box;
    position: relative;
    padding: 40px;
    flex: none;
    /* AT_Blue@10% */
    background: #E8EDF8;
    box-shadow: 0px 20px 20px rgba(0, 0, 0, 0.04), 0px 4px 3.25px rgba(0, 0, 0, 0.02);
    border-radius: 10px;
}

.contactForm .formContainer .formField {
    display: flex;
    flex-direction: row;
    box-sizing: border-box;
    padding: 8px 16px;
    flex-grow: 1;
    /* TGI - White */
    background: #FFFFFF;
    border-radius: 6px;
    /* field-text */
    font-weight: 500;
    font-size: 14px;
    line-height: 17px;
    resize: none;
}

.contactForm .formContainer .formField.small {
    height: 40px;
    flex: 1 1 calc(50% - 7.5px);
    order: 1;
}

.contactForm .formContainer .formField.big {
    height: 230px;
    flex: none;
    align-self: stretch;
    order: 2;
    flex-grow: 0;
}

.contactForm .formContainer .sendButton {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 10px;
    gap: 10px;
    width: 169px;
    height: 40px;
    margin: auto;
    /* AT_Blue */
    background: #1045B5;
    border-radius: 10px;
    flex: none;
    order: 3;
    flex-grow: 0;
}

@media (max-width: 991px) {
    .contactForm .contactFormContainer {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .contactForm .formContainer {
        width: 100%;
        /* Full width on smaller screens */
        height: auto;
        /* Allow height to adjust to content */
        padding: 20px;
        /* Less padding on smaller screens */
    }

    .contactForm .formContainer .formField.small {
        width: 100%;
        /* Fields will take full width on smaller screens */
        flex: 1 1 100%;
        /* Allow each field to take full width */
        order: initial;
        /* Reset the order */
    }
}

@media (max-width: 480px) {
    .contactForm .formContainer {
        padding: 15px;
        /* Even less padding on very small screens */
    }

    .contactForm .formContainer .formField.small {
        width: 100%;
        /* Fields will still take full width */
        padding: 6px 12px;
        /* Smaller padding for form fields */
        font-size: 12px;
        /* Smaller font size for better readability */
        line-height: 15px;
    }
}

/* Footer */
.app-container>.footer {
    /* AT_MutedBlue */
    background: #4070D5;
    color: #FFFFFF;
}

.footer .footer-content {
    display: grid;
    grid-template-columns: repeat(4, 1fr) minmax(auto, 27%);
    gap: 3rem;
    padding: 3rem 0;
}

.footer .logo .img {
    width: 150px;
    margin-bottom: 1rem;
}

.footer .logo .text {
    font-weight: 400;
    font-size: 16px;
    line-height: 20px;
    max-width: 230px;
}

.footer .menu {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
}

.footer .menu a {
    font-weight: 400;
    font-size: 16px;
    line-height: 20px;
    text-decoration-line: underline;
    color: inherit;
}

.footer .menu a:hover {
    color: #b8c9ee;
}

.footer .menu .title {
    font-weight: 700;
    text-decoration: none;
    width: 100%;
    font-size: 18px;
}

.footer .menu.signUp {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
}

.footer .menu.signUp>div {
    width: 100%;
}

.footer .menu .newsletter {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    padding: 5px 5px 5px 15px;
    /* AT_White */
    border: 1px solid #FFFFFF;
    border-radius: 10px;
}

.footer .menu .newsletter .mc-field-group {
    flex-grow: 1;
}

.footer .menu .newsletter .required.email {
    padding-left: 0px;
    padding-right: 0px;
    background: none;
    border: none;
    color: #FFFFFF;
}

.footer .menu .newsletter div div {
    top: 50px;
    left: 20px;
    color: red;
}

.footer .menu .newsletter .button {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 10px;
    gap: 10px;
    width: 42px;
    height: 42px;
    /* AT_Blue */
    background: #1045B5;
    border-radius: 10px;
}

.footer .menu .newsletter .button i {
    /* AT_White */
    color: #FFFFFF;
    font-weight: 900;
}

.footer .menu.signUp .icons {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 30px 0;
    gap: 20px;
}

.footer .menu.signUp .icons * {
    font-weight: 900;
    font-size: 20px;
    line-height: 20px;
    text-decoration-line: none;
    width: 20px;
}

.legal {
    /* AT_Blue */
    background: #1045B5;
}

.legal .legal-content {
    display: grid;
    padding: 2rem 0;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.legal .links {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.legal .links a {
    font-weight: 600;
    font-size: 16px;
    color: #FFFFFF;
    text-decoration: none;
}

.legal .legal-content span {
    color: #b8c9ee;
}

.legal .legal-content .version {
    text-align: center;
}

.legal .legal-content .rto {
    text-align: end;
}

.legal .links a:hover {
    color: #b8c9ee;
}


@media (max-width: 1199px) {
    .footer .footer-content {
        grid-template-columns: repeat(4, 1fr);
    }

    .footer .footer-content .signUp {
        grid-column: span 4;
    }

    .legal .legal-content {
        grid-template-columns: 1fr
    }

    .legal .links {
        justify-content: center;
    }

    .legal .legal-content .rto {
        text-align: center;
    }
}

@media (max-width: 991px) {
    .footer .footer-content {
        grid-template-columns: repeat(3, 1fr);
    }

    .footer .footer-content .signUp {
        grid-column: span 2;
        order: 2;
    }

    .footer .footer-content .logo {
        order: 1;
    }
}

@media (max-width: 768px) {
    .footer .footer-content {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer .footer-content .logo {
        order: -1;
    }
}

@media (max-width: 576px) {
    .footer .footer-content {
        grid-template-columns: repeat(1, 1fr);
    }

    .footer .footer-content .signUp {
        grid-column: span 1;
        order: 2;
    }
}