/* 
    
	Styles
	
--------------------------------------- */


/* ----- Fonts ----- */

@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter/static/Inter-Regular.woff2') format('woff2'),
        url('../fonts/Inter/static/Inter-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter/static/Inter-Medium.woff2') format('woff2'),
        url('../fonts/Inter/static/Inter-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter/static/Inter-SemiBold.woff2') format('woff2'),
        url('../fonts/Inter/static/Inter-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter/static/Inter-Bold.woff2') format('woff2'),
        url('../fonts/Inter/static/Inter-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}


/* ----- Variables ----- */

:root {

    /* typography */

    --font-family: 'Inter', 'sans-serif';
    --font-family-code: ui-monospace, Consolas, monospace;

    --text-base: 1rem;      /* 16px (browsers default) */
    --text-sm: 0.875rem;    /* 14px */
    --text-md: 1.125rem;    /* 18px */

    --text-h1: 2.25rem;     /* 36px */
    --text-h2: 2rem;        /* 32px */
    --text-h3: 1.75rem;     /* 28px */
    --text-h4: 1.5rem;      /* 24px */
    --text-h5: 1.25rem;     /* 20px */
    --text-h6: 1.125rem;    /* 18px */

    @media (min-width: 1024px) {
        --text-h1: 3.75rem;     /* 60px */
        --text-h2: 3.25rem;     /* 52px */
        --text-h3: 2.25rem;     /* 36px */
        --text-h4: 1.5rem;      /* 24px */
        --text-h5: 1.375rem;    /* 22px */
        --text-h6: 1.25rem;     /* 20px */
    }
    
    --tracking-tight: -0.25px;
    --tracking-tighter: -0.5px;
    --tracking-super-tight: -1px;
    --tracking-mega-tight: -2px;

    @media (min-width: 1024px) {
        --tracking-super-tight: -0.75px;
        --tracking-mega-tight: -1.25px;
    }

    --line-height: normal;
    --line-height-p: 1.375;

    /* spacing */

    --spacing-05: 0.3125rem;     /* 5px */
    --spacing-1: 0.625rem;       /* 10px */
    --spacing-1-5: 0.9375rem;    /* 15px */
    --spacing-2: 1.25rem;        /* 20px */
    --spacing-2-5: 1.5625rem;    /* 25px */
    --spacing-3: 1.875rem;       /* 30px */
    --spacing-4: 2.5rem;         /* 40px */
    --spacing-4-5: 2.8125rem;    /* 45px */
    --spacing-6: 3.75rem;        /* 60px */
    --spacing-9: 5.625rem;       /* 90px */
    --spacing-12: 7.5rem;        /* 20px */

    --spacing-sm: var(--spacing-1-5);
    --spacing-md: var(--spacing-4);
    --spacing-lg: var(--spacing-6);
    --spacing-xl: var(--spacing-9);

    @media (min-width: 1024px) {
        --spacing-sm: var(--spacing-3);
        --spacing-md: var(--spacing-6);
        --spacing-lg: var(--spacing-9);
        --spacing-xl: var(--spacing-12);
    }

    --spacing-col-gap: var(--spacing-sm);

    /* roundness */

    --rounded: var(--spacing-1-5);
    --rounded-sm: var(--spacing-1);
    --rounded-lg: var(--spacing-2);
    --rounded-xl: var(--spacing-2-5);
    --rounded-full: 999px;

    /* transition */

    --transition: 325ms ease;
    --transition-fast: 175ms ease;

    /* colors */

    --color-primary: 210, 100%, 43%;   /* #006EDB */
    --color-white: 0, 0%, 100%;        /* #ffffff */
    --color-light: 0, 0%, 96%;         /* #f4f4f4 */
    --color-light-gray: 0, 0%, 93%;    /* #ececec */
    --color-dark: 0, 0%, 13%;          /* #222222 */
    --color-black: 0, 0%, 0%;          /* #000000 */

    --color-body: hsl(var(--color-white));
    --color-headings: hsl(var(--color-dark));
    --color-text: hsla(var(--color-dark), 0.7);
    --color-links: hsl(var(--color-primary));

    &:is(.site-theme-dark) {
        --color-body: hsl(var(--color-dark));
        --color-headings: hsl(var(--color-light));
        --color-text: hsla(var(--color-light), 0.7);
    }

    /* shadows */

    --shadow-dark: 0px var(--spacing-05) var(--spacing-3) hsla(var(--color-dark), 0.15);
    --shadow-dark-md: 0px var(--spacing-1) var(--spacing-4-5) hsla(var(--color-dark), 0.15);
    --shadow-dark-lg: 0px var(--spacing-1-5) var(--spacing-6) hsla(var(--color-dark), 0.15);

}


/* ----- Base - Reset ----- */

*,
::before,
::after {
	box-sizing: border-box;
}

* {
    margin: 0; /* 1. Remove margin from all elements */
}

html {
    -webkit-text-size-adjust: 100%; /* 2. Prevent adjustments of font size after orientation changes in iOS. */
	tab-size: 4; /* 3. Use a more readable tab size (opinionated). */
    scroll-behavior: smooth;
}

body {
    -webkit-font-smoothing: antialiased;
    background-color: hsl(var(--color-white));
}

table {
	border-color: currentcolor;
}

button,
[type='button'],
[type='reset'],
[type='submit'] {
	-webkit-appearance: button;
    cursor: pointer;
}

legend {
	padding: 0;
}

progress {
	vertical-align: baseline;
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
	height: auto;
}

[type='search'] {
	-webkit-appearance: textfield; /* 1 */
	outline-offset: -2px; /* 2 */
}

::-webkit-search-decoration {
	-webkit-appearance: none;
}

::-webkit-file-upload-button {
	-webkit-appearance: button; /* 1 */
	font: inherit; /* 2 */
}


/* ----- Typography ----- */

html {
    font-family: var(--font-family);
    font-size: var(--text-base);
}

h1,h2,h3,h4,h5,h6 {
    display: block;
    margin: 0;
    padding: 0;
    color: var(--color-headings);
    font-weight: 600;
    overflow-wrap: break-word;
    text-wrap: balance;
}

h1 {
    font-size: var(--text-h1);
    letter-spacing: var(--tracking-mega-tight);
}

h2 {
    font-size: var(--text-h2);
    letter-spacing: var(--tracking-super-tight);
}

h3 {
    font-size: var(--text-h3);
    letter-spacing: var(--tracking-tighter);
}

h4 {
    font-size: var(--text-h4);
    letter-spacing: var(--tracking-tighter);
}

h5 {
    font-size: var(--text-h5);
    letter-spacing: var(--tracking-tight);
}

h6 {
    font-size: var(--text-h6);
    letter-spacing: var(--tracking-tight);
}

p {
    color: var(--color-text);
    overflow-wrap: break-word;
    text-wrap: pretty;
}

a {
    color: var(--color-links);
}

small {
    font-size: var(--text-sm);
}

b, strong {
    font-weight: bold;
}

code,
kbd,
samp,
pre {
	font-family: var(--font-family-code);
	font-size: var(--text-base); /* 2 */
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

summary {
	display: list-item;
}

button,
input,
optgroup,
select,
textarea {
	font-family: inherit; /* 1 */
	font-size: 100%; /* 1 */
	margin: 0; /* 2 */
}


/* ----- Utility ----- */

/* visibility */

.screen-reader-text {
    display: none;
    visibility: hidden;
    opacity: 0;
}

@media (max-width: 1024px) {
    .invisible-mobile {
        display: none !important;
    }
}

@media (min-width: 1024px) {
    .invisible-desktop {
        display: none !important;
    }
}

/* spacing */

.mt-none {
    margin-top: 0;
}

.mt-sm {
    margin-top: var(--spacing-sm);
}

.mt-md {
    margin-top: var(--spacing-md);
}

.mt-lg {
    margin-top: var(--spacing-lg);
}

.mt-xl {
    margin-top: var(--spacing-xl);
}

/* grid */


.container {
    width: 100%;
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--spacing-sm);
	padding-right: var(--spacing-sm);
}

@media (min-width: 640px) {
    .container {
        max-width: 640px;
    }
}

@media (min-width: 768px) {
    .container {
        max-width: 768px;
    }
}

@media (min-width: 1024px) {
    .container {
        max-width: 1024px;
    }
}

@media (min-width: 1280px) {
    .container {
        max-width: 1280px;
    }
}

@media (min-width: 1460px) {
    .container {
        max-width: 1460px;
    }
}


/* ----- Buttons ----- */

.btn {
    --btn-padding-x: var(--spacing-3);
    --btn-padding-y: var(--spacing-1-5);
    --btn-radius: var(--rounded-full);
    --btn-border-color: transparent;
    --btn-border-color-h: transparent;
    --btn-border: 3px solid var(--btn-border-color);
    --btn-bg-color: hsl(var(--color-primary));
    --btn-bg-color-h: hsl(var(--color-dark));
    --btn-text-color: hsl(var(--color-white));
    --btn-text-color-h: hsl(var(--color-white));
    --btn-text-size: var(--text-h5);

    & a {
        position: relative;
        display: inline-flex;
        gap: var(--spacing-1);
        align-items: center;
        justify-content: center;
        padding: var(--btn-padding-y) var(--btn-padding-x);
        border-radius: var(--btn-radius);
        border: var(--btn-border);
        background-color: var(--btn-bg-color);
        color: var(--btn-text-color);
        font-size: var(--btn-text-size);
        font-weight: 600;
        letter-spacing: var(--tracking-tight);
        text-decoration: none;
        cursor: pointer;
        transition: all var(--transition);

        &:hover {
            border-color: var(--btn-border-color-h);
            background-color: var(--btn-bg-color-h);
            color: var(--btn-text-color-h);
        }
    }
}

@media (min-width: 1024px) {
    .btn {
        --btn-padding-x: var(--spacing-4);
        --btn-padding-y: var(--spacing-2);
    }
}

/* primary */

.btn-primary {
    --btn-text-color: hsl(var(--color-light));
    --btn-text-color-h: hsl(var(--color-white));
    --btn-bg-color-h: hsl(var(--color-primary));
    --btn-bg-grad: linear-gradient(90deg, #006EDB 0%, #0361BE 100%);

    & a {
        position: relative;
        box-shadow: var(--shadow-dark-md);
        overflow: hidden;
        z-index: 1;

        &:before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: var(--btn-bg-grad);
            opacity: 1;
            transition: opacity var(--transition);
            z-index: -1;
        }

        &:hover {
            box-shadow: 0px 2px 2px hsla(var(--color-dark), 0.15);
            transform: translateY(calc(-1 * var(--spacing-05)));

            &:before {
                opacity: 0;
            }
        }
    }
}

/* ghost */

.btn-ghost {
    --btn-bg-color: transparent;
    --btn-border-color: var(--color-headings);
    --btn-text-color: var(--color-headings);
}

.btn-ghost-light {
    --btn-border-color: hsl(var(--color-light));
    --btn-bg-color-h: hsl(var(--color-light));
    --btn-text-color: hsl(var(--color-light));
    --btn-text-color-h: hsl(var(--color-dark));
}

/* sizes */

.btn-lg {
    --btn-padding-x: var(--spacing-md);
    --btn-padding-y: var(--spacing-sm);
    --btn-text-size: var(--text-h4);
}

.btn-sm {
    --btn-padding-x: var(--spacing-3);
    --btn-padding-y: var(--spacing-1-5);
    --btn-text-size: var(--text-md);
}

/* utility */

.btn-center {
    display: flex;
    justify-content: center;
}

.btn-right {
    display: flex;
    justify-content: end;
}

.btn-center,
.btn-right {

    & a {
        flex-shrink: 0;
    }
}

.btn-block {

    & a {
        display: flex;
        justify-content: center;
        width: 100%;
    }
}


/* ----- Section Title ----- */

.sec-title {

    & .st-badge {
        display: inline-block;
        margin-bottom: var(--spacing-1-5);
        padding: var(--spacing-1) var(--spacing-2);
        border-radius: var(--rounded-full);
        background-color: hsl(var(--color-primary));
        color: hsl(var(--color-light));
        font-weight: 500;
        letter-spacing: var(--tracking-tighter);
    }

    & .st-title {
        display: block;
        font-weight: normal;
    }

    & .st-desc {
        display: block;
        margin-top: var(--spacing-1-5);
        max-width: 757px;
        line-height: var(--line-height-p);

        &:is(.st-desc-lg) {
            max-width: 945px;
            font-weight: 500;
            font-size: var(--text-h6);
        }
    }

    & .btn {
        margin-top: var(--spacing-4);
    }
}

/* utility */

.sec-title-center {
    text-align: center;

    & .st-desc {
        margin-left: auto;
        margin-right: auto;
    }
}

.sec-title-right {
    text-align: right;

    & .st-desc {
        margin-right: auto;
    }
}

.sec-title-light {

    & .st-badge {
        background-color: hsl(var(--color-light));
        color: var(--color-headings);
    }

    & .st-title {
        color: hsl(var(--color-light));
    }

    & .st-desc {
        color: hsla(var(--color-light), 0.7);
    }
}


/* ----- Header ----- */

header.lp-header {
    position: relative;
    margin: var(--spacing-col-gap);
    border-radius: var(--rounded-xl);
    background: linear-gradient(180deg, #006EDB 0%, #0063C6 100%);
    z-index: 1;

    &:before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border-radius: var(--rounded-xl);
        background-image: url('../img/carts-pattern.svg');
        background-repeat: repeat;
        background-position: center;
        z-index: -2;
    }

    &:after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border-radius: var(--rounded-xl);
        background: radial-gradient(28.9% 41.61% at 50% 40.1%, rgba(0, 110, 219, 0.75) 0%, #0054A7 100%);
        opacity: 0.93;
        z-index: -1;
    }
}


/* ----- Navigation ----- */

.navbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--spacing-sm);

    & a.brand {
        display: inline-block;
        text-decoration: none;
        transition: all var(--transition);
        
        &:hover {
            opacity: 0.8;
        }
        

        & img {
            height: auto;
        }
    }

    & nav.lp-main-menu {
        margin-top: 5px;
        
        & ul {
            list-style: none;
            display: flex;
            gap: var(--spacing-4);
            margin: 0;
            padding: 0;

            & li.lp-menu-item {
                color: hsl(var(--color-light));
                font-weight: 600;
                font-size: var(--text-md);

                & a {
                    display: inline-block;
                    padding-bottom: 4px;
                    border-bottom: 3px solid hsla(var(--color-light), 0);
                    color: inherit;
                    font-weight: inherit;
                    text-decoration: none;
                    transition: all var(--transition);

                    &:hover {
                        border-bottom-color: hsla(var(--color-light), 0.8);
                        color: hsl(var(--color-white));
                        text-decoration: none;
                    }
                }
            }
        }
    }

    & .cta-header {

        & .btn-ghost {
            --btn-border-color: hsl(var(--color-light), 0.25);
        }
    }
}


/* ----- Hero ----- */

.lp-hero {
    position: relative;
    max-width: 945px;
    margin: var(--spacing-md) auto 0 auto;
    padding-bottom: 262px;

    & .hero-cta {
        position: absolute;
        left: 0;
        right: 0;
        margin-top: var(--spacing-4);
        text-align: center;

        & .hero-graphic {
            max-width: 1024px;
            margin-bottom: var(--spacing-4-5);
            margin-left: -100px;

            & img {
                width: 100%;
                height: auto;
            }
        }

        & .btn-info-text {
            margin-top: var(--spacing-sm);
        }
    }
}


/* ----- Demo Cards & Grid ----- */

.lg-demos {
    position: relative;
    margin: var(--spacing-col-gap);
    padding-bottom: var(--spacing-lg);
    border-radius: var(--rounded-xl);
    background: linear-gradient(180deg, hsL(var(--color-white)) 0%, hsl(var(--color-light)) 100%);
}

.demos-grid {
    display: grid;
    gap: var(--spacing-3);
    grid-template-columns: repeat(1, 1fr);
}

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

@media (min-width: 1024px) {
    .demos-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.demo-card {

    & a {
        text-decoration: none;
        outline: none;
        
        &:hover,
        &:focus {

            & figure {

                &:before {
                    opacity: 1;
                }

                & .demo-img {
                    box-shadow: var(--shadow-dark-md);
                    transform: translateY(-10px);
                }

                & figcaption {

                    & .demo-meta {

                        & .demo-desc {
                            color: hsl(var(--color-dark), 0.7);
                        }
                    }

                    & .demo-arrow {
                        border-color: transparent;
                        background-color: hsl(var(--color-primary));
                        color: hsl(var(--color-light));

                        & i {
                            transform: rotate(45deg);
                        }
                    }
                }
            }
        }
    }

    & figure {
        position: relative;
        z-index: 1;

        &:before {
            content: '';
            position: absolute;
            bottom: 0;
            left: calc(-1 * var(--spacing-1-5));
            width: calc(100% + var(--spacing-3));
            height: 60%;
            border-radius: var(--rounded-lg);
            background-color: hsla(var(--color-dark), 0.07);
            opacity: 0;
            transition: opacity var(--transition);
            z-index: -1;
        }
        
        & .demo-img {
            position: relative;
            display: flex;
            border-radius: var(--rounded);
            box-shadow: 0px 1px 1px hsla(var(--color-dark), 0.15);
            overflow: hidden;
            transition: all var(--transition);
            
            & img {
                width: 100%;
                height: auto;
                transform: scale(1.02);
            }
        }

        & figcaption {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-2) var(--spacing-3) var(--spacing-3) var(--spacing-3);

            & .demo-meta {

                & .demo-title {
                    display: block;
                    font-size: var(--text-h6);
                    letter-spacing: var(--tracking-tight);
                    transition: color var(--transition);

                    &:hover {
                        color: hsl(var(--color-primary));
                    }
                }

                & .demo-desc {
                    display: block;
                    margin-top: var(--spacing-05);
                    color: hsla(var(--color-dark), 0.5);
                    font-size: 0.9375rem; /* 15px */
                    letter-spacing: var(--tracking-tight);
                    transition: color var(--transition);
                }
            }

            & .demo-arrow {
                display: flex;
                align-items: center;
                justify-content: center;
                width: var(--spacing-4);
                height: var(--spacing-4);
                border-radius: var(--rounded-full);
                border: 2px solid hsla(var(--color-dark), 0.15);
                background-color: transparent;
                color: var(--color-text);
                transition: all var(--transition);

                &:hover {
                    transform: scale(1.1);
                }

                & i {
                    display: block;
                    font-weight: normal;
                    font-size: var(--spacing-2);
                    line-height: 0;
                    transition: transform var(--transition);
                }
            }
        }
    }
}


/* ----- Feature Cards ----- */

.lp-ft-grid {
    display: grid;
    gap: var(--spacing-3);
    grid-template-columns: repeat(1, 1fr);
}

@media (min-width: 1024px) {
    .lp-ft-grid {
        grid-template-columns: repeat(6, 1fr);

        & .ft-card {
            grid-column: span 2;
        }

        & .ft-fw-card {
            grid-column: span 3;
        }
    }
}

.ft-card {
    padding: var(--spacing-4) var(--spacing-4) 0 var(--spacing-4);
    border-radius: var(--rounded-lg);
    border: 2px solid hsl(var(--color-light-gray));
    border-bottom: none;
    background: linear-gradient(180deg, hsl(var(--color-light)) 0%, hsl(var(--color-light-gray)) 100%);
    overflow: hidden;

    & .ft-card-title {
        display: block;
        font-size: 32px;
        letter-spacing: var(--tracking-super-tight);
    }

    & .ft-card-desc {
        margin-top: var(--spacing-1-5);
        line-height: var(--line-height-p);
    }

    & .ft-card-graphic {
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        bottom: -4px;
        margin-top: var(--spacing-md);
        border-radius: var(--rounded) var(--rounded) 0 0;
        overflow: hidden;

        & .ft-card-icon {
            position: absolute;
        }

        & img {
            width: 100%;
            height: auto;
            line-height: 0;
        }
    }

    & .icon-lg-bubble {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 160px;
        height: 160px;
        border-radius: var(--rounded-full);
        background-color: hsl(var(--color-primary));
        box-shadow: var(--shadow-dark);
        color: hsl(var(--color-light));
        font-size: 78px;
    }

    & .icon-bubble-text {
        display: flex;
        align-items: center;
        padding: 6px;
        border-radius: var(--rounded-full);
        background-color: hsl(var(--color-primary));
        box-shadow: var(--shadow-dark);
        color: hsl(var(--color-light));

        & i {
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: center;
            width: 56px;
            height: 56px;
            border-radius: var(--rounded-full);
            background-color: hsl(var(--color-light));
            color: hsl(var(--color-primary));
            font-size: 30px;
        }

        & .ft-card-icon-text {
            display: inline-block;
            margin-left: 18px;
            margin-right: 35px;
            font-size: var(--text-h6);
            font-weight: 600;
            letter-spacing: var(--tracking-tighter);
        }
    }
}


/* ----- Pages Box - Slider ----- */

.lp-theme-pages {
    position: relative;
    padding-top: var(--spacing-md);
    border-radius: var(--rounded-xl);
    background-color: hsl(var(--color-primary));
    overflow: hidden;
    z-index: 1;

    &:before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border-radius: var(--rounded-xl);
        background-image: url('../img/carts-pattern.svg');
        background-repeat: repeat;
        background-position: center;
        z-index: -2;
    }   

    &:after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border-radius: var(--rounded-xl);
        background: radial-gradient(28.9% 41.61% at 50% 40.1%, rgba(0, 110, 219, 0.75) 0%, #0054A7 100%);
        opacity: 0.93;
        z-index: -1;
    }

    & .sec-title {
        margin-left: var(--spacing-sm);
        margin-right: var(--spacing-sm);
    }

    & .lp-thumbs-slider {

        & ul {
            list-style: none;
            margin: 0;
            padding: 0;

            & li.swiper-slide {
                display: block;
                width: 100%;
                max-width: 410px;
                border-radius: var(--rounded);
                line-height: 0;
                overflow: hidden;

                & img {
                    width: 100%;
                    height: auto;
                }
            }
        }

        &:is(.lp-thumbs-slider-bottom) {

            & ul li.swiper-slide {
                border-bottom-left-radius: 0;
                border-bottom-right-radius: 0;
            }
        }
    }
}


/* ----- Icon Cards ----- */

.ft-icons-grid {
    display: grid;
    gap: var(--spacing-col-gap);
    grid-template-columns: repeat(1, 1fr);
}

@media (min-width: 640px) {
    .ft-icons-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 768px) {
    .ft-icons-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1024px) {
    .ft-icons-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.ft-icon-card {
    display: flex;
    flex-flow: column;
    padding: var(--spacing-sm);
    border-radius: var(--rounded);
    border: 2px solid hsl(var(--color-light-gray));
    background-color: hsl(var(--color-white));
    text-align: center;
    transition: all var(--transition);

    &:hover {
        border-color: transparent;
        box-shadow: var(--shadow-dark-md);

        & .ft-ic-icon {
            transform: scale(1.1);
        }
    }

    & .ft-ic-icon {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 72px;
        height: 72px;
        margin: 0 auto;
        border-radius: var(--rounded-full);
        background-color: hsl(var(--color-primary));
        color: hsl(var(--color-light));
        font-size: var(--text-h3);
        transition: transform var(--transition);
    }

    & .ft-ic-title {
        display: block;
        margin-top: var(--spacing-2);
        font-size: var(--text-h4);
        letter-spacing: var(--tracking-super-tight);
    }

    & .ft-ic-desc {
        display: block;
        margin-top: var(--spacing-1);
    }
}


/* ----- Accordions ----- */

.lp-faq {
    position: relative;
    margin-left: var(--spacing-col-gap);
    margin-right: var(--spacing-col-gap);
    padding-bottom: var(--spacing-lg);
    border-radius: var(--rounded-xl);
    background: linear-gradient(180deg, hsL(var(--color-white)) 0%, hsl(var(--color-light)) 100%);
}

.faq-grid {
    display: grid;
    align-items: start;
    gap: var(--spacing-col-gap);
    margin-top: var(--spacing-md);

    & .faq-col {
        display: flex;
        flex-flow: column;
        gap: var(--spacing-col-gap);
    }
}

@media (min-width: 1024px) {
    .faq-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.ft-accordion {

    &:is(.open) {

        & .ft-acc-title {

            & button {
                box-shadow: var(--shadow-dark);

                & .ft-acc-i i {
                    transform: rotate(180deg);
                }
            }

        }
        
        & .ft-acc-content {
            height: 100%;
            max-height: 300px;
            opacity: 1;
            visibility: visible;
        }
    }
    
    & .ft-acc-title {
        display: block;
        width: 100%;
        font-size: var(--text-h5);

        & button {
            display: flex;
            flex-flow: column;
            align-items: center;
            justify-content: center;
            gap: var(--spacing-1);
            width: 100%;
            padding: var(--spacing-sm);
            border-radius: var(--rounded);
            border: 3px solid hsla(var(--color-dark), 0.1);
            background-color: var(--color-body);
            box-shadow: none;
            color: inherit;
            font-weight: inherit;
            font-size: inherit;
            transition: all var(--transition);
            z-index: 1;

            & > * {
                z-index: 0;
            }

            & .ft-acc-count {
                display: inline-block;
                margin-right: var(--spacing-1);
            }

            & .ft-acc-i {
                flex-shrink: 0;
                display: flex;
                align-items: center;
                justify-content: center;
                width: 45px;
                height: 45px;
                border-radius: var(--rounded-full);
                background-color: hsla(var(--color-dark), 0.05);
                color: var(--color-headings);
                font-size: 26px;
                transition: all var(--transition);

                &:hover {
                    background-color: hsl(var(--color-primary));
                    color: hsl(var(--color-light));
                }

                & i {
                    transition: all var(--transition);
                }
            }
        }
    }

    & .ft-acc-content {
        display: block;
        max-height: 0;
        line-height: var(--line-height-p);
        opacity: 0;
        visibility: visible;
        transition: all var(--transition);

        & .acc-content-wrapper {
            padding: var(--spacing-2-5) var(--spacing-4) 0 var(--spacing-4);
        }
    }
}

@media (min-width: 640px) {
    .ft-accordion {

        & .ft-acc-title button {
            flex-flow: row;
            justify-content: start;
            padding: var(--spacing-3) var(--spacing-4);
            text-align: left;

            & .ft-acc-i {
                margin-left: auto;
            }
        }
    }
}


/* ----- CTA Banner ----- */

.cta-banner {
    position: relative;
    display: flex;
    flex-flow: column;
    border-radius: var(--rounded-lg);
    background-color: hsl(var(--color-primary));
    box-shadow: var(--shadow-dark-lg);
    overflow: hidden;
    z-index: 1;
    
    &:before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border-radius: var(--rounded-xl);
        background-image: url('../img/carts-pattern.svg');
        background-repeat: repeat;
        background-position: center;
        z-index: -2;
    }

    &:after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border-radius: var(--rounded-xl);
        background: radial-gradient(28.9% 41.61% at 50% 40.1%, rgba(0, 110, 219, 0.75) 0%, #0054A7 100%);
        opacity: 0.93;
        z-index: -1;
    }

    & .cta-banner-content {
        display: flex;
        flex-flow: column;
        justify-content: center;
        align-items: center;
        height: auto;
        padding: var(--spacing-md) var(--spacing-sm);
        text-align: center;

        & .cta-title {
            color: hsl(var(--color-light));
            font-weight: normal;
        }

        & .cta-button {
            margin-top: var(--spacing-md);

            & .btn-info-text {
                display: block;
                margin-top: var(--spacing-1-5);
                color: hsla(var(--color-light), 0.7);
                line-height: var(--line-height-p);
                font-size: var(--text-sm);

                & br {
                    display: none;
                }
            }
        }
    }

    & .cta-banner-graphic {
        line-height: 0;
        display: none;
        
        & img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            object-position: top left;
        }
    }
}

@media (min-width: 640px) {
    .cta-banner {

        & .cta-banner-content {
            padding: var(--spacing-md);
            padding-right: 0;
        }
    }
}

@media (min-width: 1024px) {
    .cta-banner {
        flex-flow: row;

        & .cta-banner-content {
            flex-shrink: 0;
            align-items: start;
            padding: var(--spacing-lg);
            padding-right: 0;
            text-align: left;

            & .cta-button .btn-info-text {
                font-size: var(--text-base);

                & br {
                    display: initial;
                }
            }
        }

        & .cta-banner-graphic {
            display: block;
            margin-left: auto;
            width: 50%;
        }
    }
}


/* ----- Footer ----- */

footer.lp-footer {
    position: relative;
    margin: var(--spacing-col-gap);
    padding: var(--spacing-md) 0;
    border-radius: var(--rounded-xl);
    background: linear-gradient(180deg, hsL(var(--color-white)) 0%, hsl(var(--color-light)) 100%);

    & .footer-copyright {
        --color-copyright-text: hsla(var(--color-dark), 0.5);
        display: flex;
        flex-flow: column-reverse;
        align-items: center;
        text-align: center;

        & .copy-text {
            color: var(--color-copyright-text);
            font-weight: 500;
            letter-spacing: var(--tracking-tighter);

            & a {
                color: inherit;
                text-decoration: none;
                transition: all var(--transition);

                &:hover {
                    color: var(--color-links);
                }
            }
        }
    }

    & nav.footer-menu {
        margin-bottom: var(--spacing-md);

        & ul {
            display: flex;
            flex-flow: column;
            align-items: center;
            justify-content: center;
            gap: var(--spacing-4-5);
            margin: 0;
            padding: 0;
            list-style: none;
            
            & li {
                color: var(--color-copyright-text);
                font-weight: 500;
                
                & a {
                    color: inherit;
                    text-decoration: none;
                    letter-spacing: var(--tracking-tighter);
                    transition: all var(--transition);

                    &:hover {
                        color: var(--color-links);
                    }
                }
            }
        }
    }
}

@media (min-width: 1024px) {
    footer.lp-footer {

        & .footer-copyright {
            flex-flow: row;
            justify-content: space-between;
        }

        & nav.footer-menu {
            margin-bottom: 0;

            & ul {
                flex-flow: row;
                justify-content: start;
            }
        }
    }
}