:root {
    --agc-blue: #0997d5;
    --agc-blue-dark: #056d9d;
    --agc-charcoal: #22272f;
    --agc-gray: #5b626d;
    --agc-steel: #c8d3dc;
    --agc-silver: #eef3f6;
    --agc-white: #ffffff;
    --agc-line: rgba(9, 151, 213, 0.18);
    --agc-shadow: 0 22px 60px rgba(16, 31, 45, 0.16);
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: 92px;
}

body {
    font-family: "Instrument Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--agc-charcoal);
    background: var(--agc-white);
}

img {
    max-width: 100%;
    height: auto;
}

a {
    text-decoration: none;
}

.agc-navbar {
    padding: 14px 0;
    background: rgba(255, 255, 255, 0.92);
    border-bottom: 1px solid rgba(34, 39, 47, 0.08);
    backdrop-filter: blur(18px);
    transition: all 0.25s ease;
}

.agc-navbar.is-scrolled {
    padding: 9px 0;
    box-shadow: 0 12px 35px rgba(18, 30, 44, 0.09);
}

.brand-logo {
    width: 58px;
    height: 58px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: 0 10px 24px rgba(34, 39, 47, 0.16);
}

.brand-text {
    color: var(--agc-charcoal);
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.navbar-nav .nav-link {
    color: #2c333d;
    font-weight: 700;
    padding: 10px 15px;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
    color: var(--agc-blue);
}

.navbar-toggler {
    border-color: rgba(34, 39, 47, 0.16);
}

.nav-cta {
    color: var(--agc-white) !important;
    background: linear-gradient(135deg, var(--agc-blue), var(--agc-blue-dark));
    border-radius: 999px;
    padding: 10px 20px !important;
    box-shadow: 0 12px 25px rgba(9, 151, 213, 0.25);
}

.hero-section,
.company-hero {
    position: relative;
    isolation: isolate;
    color: var(--agc-white);
    background: linear-gradient(115deg, rgba(19, 26, 34, 0.88), rgba(5, 109, 157, 0.58)), var(--hero-image, var(--company-image));
    background-size: cover;
    background-position: center;
}

.company-hero {
    background-image: linear-gradient(115deg, rgba(19, 26, 34, 0.9), rgba(5, 109, 157, 0.52)), var(--company-image);
}

.hero-overlay {
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        linear-gradient(90deg, rgba(6, 11, 17, 0.25), rgba(6, 11, 17, 0)),
        repeating-linear-gradient(90deg, rgba(255,255,255,0.05) 0, rgba(255,255,255,0.05) 1px, transparent 1px, transparent 90px);
}

.hero-content {
    position: relative;
    z-index: 2;
}

.min-vh-75 {
    min-height: 75vh;
    padding-top: 110px;
}

.eyebrow,
.section-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--agc-blue);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.eyebrow {
    color: #d8f3ff;
    margin-bottom: 22px;
}

.eyebrow::before,
.section-kicker::before {
    content: "";
    width: 42px;
    height: 2px;
    background: currentColor;
}

.hero-section h1,
.company-hero h1 {
    max-width: 920px;
    margin: 0;
    font-size: clamp(3rem, 7vw, 6.8rem);
    font-weight: 800;
    line-height: 0.98;
    letter-spacing: 0;
}

.hero-tagline,
.company-hero p {
    max-width: 760px;
    margin: 24px 0 0;
    color: rgba(255, 255, 255, 0.88);
    font-size: clamp(1.1rem, 2vw, 1.45rem);
    line-height: 1.6;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 36px;
}

.btn {
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: 0;
    padding: 13px 24px;
}

.btn-primary {
    background: linear-gradient(135deg, var(--agc-blue), var(--agc-blue-dark));
    border-color: var(--agc-blue);
    box-shadow: 0 16px 32px rgba(9, 151, 213, 0.26);
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--agc-blue-dark), #044c6f);
    border-color: var(--agc-blue-dark);
    transform: translateY(-1px);
}

.btn-outline-light {
    border-color: rgba(255, 255, 255, 0.72);
}

.stats-band {
    padding: 28px 0;
    background: #121923;
    color: var(--agc-white);
}

.stat-item {
    height: 100%;
    padding: 22px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
    border-radius: 8px;
}

.stat-item strong {
    display: block;
    color: #d9f5ff;
    font-size: clamp(1.9rem, 4vw, 3rem);
    line-height: 1;
}

.stat-item span {
    display: block;
    margin-top: 9px;
    color: rgba(255, 255, 255, 0.72);
    font-weight: 700;
}

.section-pad {
    padding: 96px 0;
}

.section-heading {
    max-width: 760px;
    margin: 0 auto 46px;
}

.section-heading h2,
.about-section h2,
.services-section h2,
.contact-section h2,
.company-detail h2,
.image-cta-section h2 {
    margin-top: 14px;
    color: var(--agc-charcoal);
    font-size: clamp(2rem, 4.5vw, 3.6rem);
    font-weight: 800;
    line-height: 1.08;
    letter-spacing: 0;
}

.about-section p,
.contact-section p,
.company-detail p,
.image-cta-section p {
    color: var(--agc-gray);
    font-size: 1.05rem;
    line-height: 1.85;
}

.image-panel {
    overflow: hidden;
    border-radius: 8px;
    box-shadow: var(--agc-shadow);
}

.image-panel img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    transition: transform 0.8s ease;
}

.image-panel:hover img {
    transform: scale(1.045);
}

.companies-section,
.related-companies {
    background: linear-gradient(180deg, #f6f9fb, #ffffff);
}

.company-card {
    display: block;
    height: 100%;
    overflow: hidden;
    color: inherit;
    background: var(--agc-white);
    border: 1px solid rgba(34, 39, 47, 0.08);
    border-radius: 8px;
    box-shadow: 0 16px 42px rgba(26, 40, 55, 0.08);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.company-card:hover {
    color: inherit;
    border-color: var(--agc-line);
    box-shadow: var(--agc-shadow);
    transform: translateY(-9px);
}

.company-image {
    overflow: hidden;
}

.company-image img {
    width: 100%;
    aspect-ratio: 16 / 11;
    object-fit: cover;
    transition: transform 0.7s ease;
}

.company-card:hover .company-image img {
    transform: scale(1.08);
}

.company-body {
    position: relative;
    padding: 54px 24px 26px;
}

.company-icon {
    display: grid;
    place-items: center;
    width: 58px;
    height: 58px;
    color: var(--agc-white);
    background: linear-gradient(145deg, var(--agc-blue), var(--agc-blue-dark));
    border: 5px solid var(--agc-white);
    border-radius: 8px;
    box-shadow: 0 13px 28px rgba(9, 151, 213, 0.22);
}

.company-body .company-icon {
    position: absolute;
    top: -29px;
}

.company-icon.large {
    width: 74px;
    height: 74px;
    margin-bottom: 24px;
    border: 0;
    font-size: 1.6rem;
}

.company-body h3,
.service-card h3,
.related-card h3,
.contact-panel h3,
.capability-panel h3 {
    margin: 0 0 12px;
    color: var(--agc-charcoal);
    font-size: 1.16rem;
    font-weight: 800;
    letter-spacing: 0;
}

.company-body p,
.service-card p {
    min-height: 122px;
    color: var(--agc-gray);
    line-height: 1.7;
}

.company-body span,
.related-card span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--agc-blue-dark);
    font-weight: 800;
}

.image-cta-section {
    position: relative;
    padding: 110px 0;
    color: var(--agc-white);
    background: linear-gradient(90deg, rgba(13, 20, 28, 0.35), rgba(13, 20, 28, 0.88)), var(--cta-image);
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
}

.image-cta-section h2,
.image-cta-section p {
    color: var(--agc-white);
}

.image-cta-section p {
    color: rgba(255, 255, 255, 0.78);
}

.services-section {
    background: var(--agc-white);
}

.service-card,
.contact-panel,
.capability-panel,
.related-card {
    height: 100%;
    padding: 32px;
    background: var(--agc-white);
    border: 1px solid rgba(34, 39, 47, 0.08);
    border-radius: 8px;
    box-shadow: 0 14px 38px rgba(26, 40, 55, 0.07);
    transition: transform 0.22s ease, border-color 0.22s ease;
}

.service-card:hover,
.related-card:hover {
    border-color: var(--agc-line);
    transform: translateY(-5px);
}

.service-card > i,
.related-card > i {
    display: inline-grid;
    place-items: center;
    width: 54px;
    height: 54px;
    margin-bottom: 24px;
    color: var(--agc-blue);
    background: rgba(9, 151, 213, 0.1);
    border-radius: 8px;
    font-size: 1.2rem;
}

.contact-section {
    color: var(--agc-white);
    background:
        linear-gradient(120deg, rgba(18, 25, 35, 0.94), rgba(18, 25, 35, 0.9)),
        url("https://images.unsplash.com/photo-1566576912321-d58ddd7a6088?auto=format&fit=crop&w=1800&q=85");
    background-size: cover;
    background-position: center;
}

.contact-section h2,
.contact-section p {
    color: var(--agc-white);
}

.contact-list {
    display: grid;
    gap: 14px;
    margin-top: 28px;
}

.contact-list a,
.contact-list span {
    display: flex;
    align-items: center;
    gap: 12px;
    color: rgba(255, 255, 255, 0.82);
    font-weight: 700;
}

.contact-list i {
    color: var(--agc-blue);
}

.contact-panel {
    color: var(--agc-charcoal);
    background: rgba(255, 255, 255, 0.95);
}

.contact-panel p {
    color: var(--agc-gray);
}

.back-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 22px;
    color: rgba(255, 255, 255, 0.82);
    font-weight: 800;
}

.back-link:hover {
    color: var(--agc-white);
}

.capability-panel ul {
    display: grid;
    gap: 16px;
    padding: 0;
    margin: 22px 0 0;
    list-style: none;
}

.capability-panel li {
    display: flex;
    gap: 12px;
    color: var(--agc-gray);
    font-weight: 700;
}

.capability-panel li i {
    margin-top: 4px;
    color: var(--agc-blue);
}

.related-card {
    display: block;
    color: inherit;
}

.related-card:hover {
    color: inherit;
}

.site-footer {
    padding: 54px 0 24px;
    color: rgba(255, 255, 255, 0.72);
    background: #101721;
}

.footer-logo {
    width: 70px;
    height: 70px;
    object-fit: cover;
    border-radius: 50%;
}

.site-footer h2 {
    margin: 0 0 8px;
    color: var(--agc-white);
    font-size: 1.25rem;
    font-weight: 800;
}

.site-footer p {
    margin: 0;
}

.footer-companies {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 12px;
}

.footer-companies a {
    color: rgba(255, 255, 255, 0.76);
    padding: 9px 14px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 999px;
    font-size: 0.88rem;
    font-weight: 800;
}

.footer-companies a:hover {
    color: var(--agc-white);
    border-color: rgba(9, 151, 213, 0.55);
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    margin-top: 40px;
    padding-top: 22px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 0.92rem;
}

@media (max-width: 991.98px) {
    .navbar-collapse {
        margin-top: 12px;
        padding: 14px;
        background: var(--agc-white);
        border: 1px solid rgba(34, 39, 47, 0.08);
        border-radius: 8px;
    }

    .nav-cta {
        display: inline-flex;
        margin-top: 6px;
    }

    .section-pad {
        padding: 76px 0;
    }

    .image-cta-section {
        background-attachment: scroll;
    }

    .footer-companies {
        justify-content: flex-start;
    }
}

@media (min-width: 992px) {
    .footer-companies {
        justify-content: flex-end;
    }
}

@media (max-width: 767.98px) {
    .brand-logo {
        width: 48px;
        height: 48px;
    }

    .brand-text {
        font-size: 0.92rem;
    }

    .hero-section .min-vh-100 {
        min-height: 88vh !important;
        padding-top: 96px;
    }

    .hero-actions .btn {
        width: 100%;
    }

    .company-body p {
        min-height: auto;
    }

    .footer-bottom {
        flex-direction: column;
    }
}
