html {
    --opacity: 0;
}

@media only screen and (min-width: 800px) {
    main:not(.has-cta), .section-cta-wrapper {
        position: relative;
        border-bottom-left-radius: var(--default-border-radius-big) !important;
        border-bottom-right-radius: var(--default-border-radius-big) !important;
        overflow: hidden;
        z-index: 1;
    }
    
    .footer-container-outer {
        margin-top: auto;
        position: relative;
        overflow: hidden;
    }
    .footer-container-outer::after {
        content: "";
        position: absolute;
        inset: calc(-1 * var(--default-border-radius-big));
        background: linear-gradient(var(--clr-primary-100), transparent);
        opacity: calc(var(--opacity) * 0.45);
        pointer-events: none;
    }
    html.footer-dark .footer-container-outer::after {
        background: linear-gradient(var(--clr-primary-900), transparent);
        opacity: calc(var(--opacity) * 0.75);
    }
}
.footer-container {
    padding-left: 0;
    padding-right: 0;
}

footer.footer-primary {
    background-color: var(--clr-primary-100);
    color: var(--clr-primary-900);
    padding-left: var(--default-padding-side);
    padding-right: var(--default-padding-side);
}
footer.dark {
    background-color: var(--clr-primary-900);
    color: var(--clr-primary-100);
}
footer .logo-primary path {
    fill: var(--clr-primary-900);
}
footer.dark .logo-primary path {
    fill: var(--clr-primary-100);
}
footer.footer-secondary {
    color: var(--clr-primary-900);
    background-color: var(--clr-secondary-150);
    padding-left: var(--default-padding-side);
    padding-right: var(--default-padding-side);
}
footer.dark.footer-secondary {
    color: var(--clr-primary-100);
    background-color: var(--clr-secondary-850);
}
footer nav.secondary ul {
    gap: 6.4rem;
}
footer.dark button {
    color: var(--clr-primary-100) !important;
}

.footer-main {
    grid-column: 2 / 9;
    margin-top: var(--default-margin);
    justify-content: space-between;
}
.footer-cta {
    gap: 1.2rem;
}
.footer-links {
    grid-column: 9 / -2;
    gap: 4.8rem;
}
.footer-links .h4 {
    margin-bottom: 1.6rem;
}
.footer-links ul {
    gap: 0.6rem;
}
.footer-links li {
    width: fit-content;
}
footer.dark .footer-links li :is(a, button), footer.dark .footer-links li {
    color: var(--clr-primary-100-75) !important;
}
.footer-start {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: var(--grid);
    column-gap: var(--grid-gap);
}
footer > section > :is(.logo, span, .footer-subtext) {
    grid-column: 2 / 9;
}
footer > section > :is(a, span) {
    margin-bottom: 1.6rem !important;
}
footer .logo svg {
    width: 7.2rem;
}
.footer-subtext {
    max-width: 38ch;
}
footer.dark .footer-subtext {
    color: var(--clr-primary-100-75);
}
.footer-socials {
    grid-row: 1;
    grid-column: 9 / -2;
    gap: 1.2rem;
}
.footer-socials li {
    height: fit-content;
    background-color: var(--clr-secondary-150);
}
footer.dark .footer-socials li {
    background-color: var(--clr-secondary-750);
    border-radius: var(--default-border-radius);
}

.footer-socials .h3 {
    width: 5.6rem;
    aspect-ratio: 1 / 1;
    place-items: center;
}
.footer-secondary > section {
    padding-top: 2.4rem;
    padding-bottom: 2.4rem;
}
footer.footer-secondary > section > div {
    grid-column: 2 / -2;
    grid-template-columns: 1fr auto;
    align-items: center;
}
footer.footer-secondary > section > div > p { 
    height: fit-content;
}
.footer-secondary a {
    gap: 1.2rem;
}
.footer-secondary a > svg {
    height: 3.2rem;
}
.footer-secondary .flex {
    gap: 1rem;
    align-items: center;
}
.footer-feature {
    padding: 0.5rem;
    place-self: center end;
}
.footer-feature > div {
    overflow: hidden;
    height: 2.55rem;
    align-items: flex-end;
}
.footer-feature > div p {
    height: 2.55rem;
}
.footer-feature > div p {
    transform: translateY(-100%);
    transition: transform 0.25s;
}
.footer-feature.active > div p {
    transform: translateY(0);
}
.footer-feature > div p span {
    font-style: italic;
}
.footer-feature svg {
    width: 1.6rem;
}


@media only screen and (max-width: 1199px) {
    footer .footer-primary > section {
        padding-bottom: 6.4rem;
    }
    footer > section > :is(.logo, span, .footer-subtext) {
        grid-column: 1 / 6;
    }
    footer > section > :is(.logo, span) {
        grid-row: 1;
    }
    footer > section > .footer-subtext {
        grid-row: 2;
    }

    .footer-cta {
        margin-bottom: 9.6rem;
    }
    footer nav.secondary {
        margin-bottom: 9.6rem;
    }
    .footer-links {
        flex-direction: row;
        gap: 9.6rem;
    }
    .footer-socials {
        grid-column: 5 / -1;
        justify-content: flex-end;
    }
    .footer-main, .footer-links {
        grid-column: 1 / -1;
    }
    footer.footer-secondary > section div {
        grid-column: 1 / -1;
    }
    footer.footer-secondary > section div > * {
        grid-row: 1;
    }
    footer.footer-secondary > section div .footer-feature {
        grid-column: 3;
    }
}

@media only screen and (max-width: 800px) {
    footer.footer-primary {
        padding-bottom: 2.4rem;
    }
    footer .footer-primary > section {
        padding-bottom: 3.2rem;
    }
    .footer-cta {
        margin-bottom: 4.8rem;
    }
    footer nav.secondary {
        margin-bottom: 6.4rem;
    }
    footer nav.secondary ul {
        display: flex;
        flex-wrap: wrap;
        gap: 1.6rem;
    }
    footer nav.secondary ul > * {
        min-width: min-content;
    }
    .footer-links {
        display: flex;
        flex-wrap: wrap;
        gap: 3.2rem;
    }
    .footer-links .collapse-tablet-reverse ul {
        display: block;
        columns: 2;
    }
    .footer-links ul {
        gap: 0;
        margin-top: -0.3rem;
        margin-bottom: -0.3rem;
    }
    .footer-links ul :is(a, button) {
        padding-top: 0.3rem;
        padding-bottom: 0.3rem;
    }
    .footer-socials {
        grid-column: 1 / -1;
        grid-row: 3;
        margin-top: 3.2rem;
        justify-content: flex-start;
    }
    footer.footer-secondary > section div {
        grid-column: 1 / -1;
        grid-template-columns: auto 1fr;
        place-items: start;
    }
    .footer-secondary .flex {
        align-items: flex-start;
    }
    footer.footer-secondary > section div .footer-feature {
        grid-row: 2;
        grid-column: 1 / -1;
        place-self: start;
        height: 2.4em;
        padding-left: 0;
        padding-right: 0;
    }
}
@media only screen and (min-width: 2561px) {
    .footer-socials, .footer-links {
        grid-column: 10 / -1;
    }
    footer.footer-secondary > section > div {
        grid-column: 1 / -1;
    }
}