        /* Hero */
        .hero {
            position: relative;
            height: 100vh;
            padding-top: 72px;
            display: flex;
            align-items: center;
            justify-content: center;
            text-align: center;
            color: var(--color-white);
            background: linear-gradient(rgba(0,47,95,0.45), rgba(0,47,95,0.55)),
                url("../img/hero.webp") center/cover no-repeat;
        }
        .hero__inner {
            max-width: 800px;
            padding: 0 20px;
        }
        .hero__subtitle {
            font-size: 1rem;
            font-weight: 700;
            letter-spacing: .15em;
            margin-bottom: 16px;
            opacity: .9;
            text-shadow: 0 1px 4px rgba(0,0,0,.2);
        }
        .hero__title {
            font-size: 2.75rem;
            font-weight: 700;
            margin-bottom: 20px;
            line-height: 1.3;
            text-shadow: 0 2px 8px rgba(0,0,0,.3);
        }
        .hero__text {
            font-size: 1.125rem;
            margin-bottom: 36px;
            opacity: .95;
            text-shadow: 0 1px 4px rgba(0,0,0,.2);
        }
        .hero__buttons {
            display: flex;
            gap: 16px;
            justify-content: center;
            flex-wrap: wrap;
        }

        /* About section */
        .about-flex {
            display: flex;
            gap: 40px;
            align-items: center;
        }
        .about-flex__img {
            flex: 0 0 45%;
            border-radius: var(--radius);
            overflow: hidden;
        }
        .about-flex__body {
            flex: 1;
        }
        .about-flex__body h3 {
            font-size: 1.5rem;
            font-weight: 700;
            color: var(--color-heading);
            margin-bottom: 16px;
        }
        .about-flex__body p {
            margin-bottom: 20px;
            font-size: .9375rem;
            line-height: 1.8;
        }

        /* Works grid on top */
        .works-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 20px;
        }
        .works-grid__item {
            border-radius: var(--radius);
            box-shadow: var(--shadow-sm);
            transition: transform var(--transition), box-shadow var(--transition);
            display: flex;
            flex-direction: column;
        }
        .works-grid__item > svg,
        .works-grid__item > img {
            display: block;
            width: 100%;
            border-radius: var(--radius) var(--radius) 0 0;
        }
        .works-grid__item:hover {
            transform: translateY(-2px);
            box-shadow: var(--shadow-md);
        }
        .works-grid__caption {
            padding: 12px 16px;
            font-size: .875rem;
            font-weight: 700;
            color: var(--color-heading);
            background: var(--color-white);
            min-height: 72px;
            display: flex;
            align-items: center;
            line-height: 1.5;
        }

        /* Section navy */
        .section--navy {
            background: linear-gradient(135deg, var(--color-main) 0%, #003366 100%);
            color: var(--color-white);
        }
        .section--navy .section__title {
            color: var(--color-white);
        }
        .section--navy .section__lead {
            color: rgba(255,255,255,.9);
        }

        @media (max-width: 1024px) {
            .works-grid {
                grid-template-columns: repeat(3, 1fr);
            }
            .works-grid__caption {
                min-height: 80px;
                font-size: 0.8125rem;
            }
        }

        @media (max-width: 800px) {
            .works-grid {
                grid-template-columns: repeat(2, 1fr);
            }
            .works-grid__caption {
                min-height: 64px;
            }
        }

        @media (max-width: 767px) {
            .hero {
                height: 100vh;
                padding-top: 60px;
            }
            .hero__logo {
                max-width: 200px;
                margin-bottom: 16px;
            }
            .hero__title {
                font-size: 1.75rem;
            }
            .hero__text {
                font-size: 1rem;
            }
            .about-flex {
                flex-direction: column;
            }
            .about-flex__img {
                flex: none;
                width: 100%;
            }
        }
