/*
-----------
Footer Grid
-----------
*/
.footer__grid { display: grid; grid-template-columns: 1fr 1fr 1fr; align-items: start; max-width: 860px; width: 100%; margin: 0 auto 44px; padding: 0 40px; }
.footer__col { justify-self: center; text-align: left; }
.footer__col nav { align-items: flex-start; }
/*
-----------
Responsive
-----------
*/
@media (max-width: 768px) {
    .site-nav { height: 64px; padding: 12px 16px; }
    .nav__logo img { height: 34px; }
    .hero { height: auto; min-height: calc(100svh - 64px); margin-top: 64px; }
    .hero__left,
    .hero__right { position: relative; left: auto !important; right: auto !important; width: 100% !important; height: auto; min-height: 320px; filter: none !important; }
    .hero.hover-left .hero__right,
    .hero.hover-right .hero__left { filter: none !important; }
    .hero.hover-left .hero__right-content,
    .hero.hover-right .hero__left-content { opacity: 1 !important; }
    .hero__left-content,
    .hero__right-content {
        width: 100% !important;
        max-width: none;
        margin: 0;
        padding: 28px 28px 32px !important;
        min-height: 0 !important;
        justify-content: flex-start !important;
        gap: 16px;
    }
    .hero__right { display: flex; align-items: center; justify-content: center; }
    .hero__right-content { margin: 0 !important; align-items: flex-start; }
    .hero__right-content .hero__tagline { align-self: center; text-align: center; white-space: normal; font-size: 1.3rem; }
    .hero__left-content .btn-outline,
    .hero__right-content .btn-outline { align-self: flex-start; margin-top: 12px; }
    .footer__grid { grid-template-columns: 1fr; padding: 0; gap: 32px; justify-items: center; }
    .footer__col { width: 180px; }
    .footer__col--contact { order: -1; }
    .footer__col h2 { font-size: 0.85rem; font-weight: 600; color: rgba(255,255,255,0.75); letter-spacing: 0.2em; }
}
@media (max-width: 480px) {
    .hero__tagline { white-space: normal; }
    .hero__left-content, .hero__right-content { min-height: 0 !important; }
}
@media (max-width: 360px) {
    .hero__left,
    .hero__right { min-height: 280px; }
    .hero__left-content,
    .hero__right-content { width: 100% !important; max-width: none !important; padding: 22px 16px 24px !important; }
    .hero__label { font-size: 1.2rem; letter-spacing: 0.14em; }
    .hero__sub { font-size: 0.92rem; margin-bottom: 18px; }
    .hero__statement { font-size: clamp(1.8rem, 9vw, 2.2rem); margin-bottom: 20px; }
    .hero__right-content .hero__tagline { font-size: 1.1rem; }
    .btn-outline { padding: 10px 14px; font-size: 0.68rem; letter-spacing: 0.14em; }
}