.about-hero {
    position: relative;
    overflow: hidden;
    padding-block: clamp(4.75rem, 9vw, 6.5rem);
    color: #ffffff;
    background: #0c1d53;
}

.about-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(100deg, rgb(9 18 48 / 0.94) 0%, rgb(12 29 83 / 0.9) 38%, rgb(18 55 141 / 0.54) 72%, rgb(18 55 141 / 0.12) 100%),
        radial-gradient(circle at 15% 20%, rgb(255 122 26 / 0.18) 0%, rgb(255 122 26 / 0) 28%);
    z-index: 1;
}

.about-hero__media {
    position: absolute;
    inset: 0;
}

.about-hero__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.about-hero__grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(18rem, 0.75fr);
    align-items: center;
    gap: clamp(2rem, 5vw, 4rem);
    min-height: clamp(24rem, 48vw, 31rem);
}

.about-hero__content {
    max-width: 42rem;
}

.about-hero__eyebrow,
.about-section-heading__eyebrow,
.about-story__eyebrow,
.about-panel__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.about-hero__eyebrow {
    margin-bottom: 1rem;
    padding: 0.55rem 0.9rem;
    border: 1px solid rgb(255 255 255 / 0.18);
    border-radius: 999px;
    background: rgb(255 255 255 / 0.08);
    color: #c6d4ff;
}

.about-hero__title {
    margin-bottom: 1.2rem;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2.55rem, 5.4vw, 4.8rem);
    line-height: 1.02;
    letter-spacing: -0.055em;
    text-wrap: balance;
}

.about-hero__subtitle {
    max-width: 35rem;
    margin-bottom: 2rem;
    font-size: clamp(1.08rem, 2vw, 1.4rem);
    line-height: 1.75;
    color: rgb(240 244 255 / 0.88);
}

.about-hero__pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.about-hero__pills li {
    padding: 0.7rem 0.95rem;
    border: 1px solid rgb(255 255 255 / 0.14);
    border-radius: 999px;
    background: rgb(255 255 255 / 0.08);
    font-size: 0.92rem;
    font-weight: 700;
}

.about-hero__card {
    display: grid;
    gap: 1rem;
    padding: 1.3rem;
    border: 1px solid rgb(255 255 255 / 0.16);
    border-radius: 1.7rem;
    background: linear-gradient(180deg, rgb(255 255 255 / 0.16), rgb(255 255 255 / 0.08));
    box-shadow: 0 24px 60px rgb(8 16 48 / 0.22);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.about-hero__card-row {
    padding: 1rem 1rem 0.95rem;
    border-radius: 1.15rem;
    background: rgb(255 255 255 / 0.08);
}

.about-hero__card-label,
.about-hero__card-value {
    margin: 0;
}

.about-hero__card-label {
    margin-bottom: 0.35rem;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #aabdfc;
}

.about-hero__card-value {
    font-family: var(--font-heading);
    font-size: 1.08rem;
    font-weight: 800;
    line-height: 1.45;
}

.about-story {
    background: linear-gradient(180deg, #ffffff 0%, #f8f9fd 100%);
}

.about-story__grid {
    display: grid;
    grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
    align-items: center;
    gap: clamp(2rem, 5vw, 4.5rem);
}

.about-story__image {
    width: 100%;
    border-radius: 2rem;
    box-shadow: 0 28px 70px rgb(24 45 104 / 0.12);
}

.about-story__content {
    max-width: 38rem;
}

.about-story__eyebrow,
.about-section-heading__eyebrow,
.about-panel__eyebrow {
    margin-bottom: 0.95rem;
    color: var(--color-primary);
}

.about-story__eyebrow::before,
.about-section-heading__eyebrow::before,
.about-panel__eyebrow::before {
    content: "";
    width: 1.8rem;
    height: 2px;
    background: currentColor;
}

.about-story__title,
.about-section-heading__title,
.about-panel__title,
.about-cta__title {
    font-family: var(--font-heading);
    letter-spacing: -0.05em;
    color: var(--color-text);
}

.about-story__title {
    margin-bottom: 1.3rem;
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 1.08;
    text-wrap: balance;
}

.about-story__text,
.about-section-heading__text,
.about-value-card__text,
.about-panel__text,
.about-cta__text {
    color: var(--color-text-muted);
    line-height: 1.8;
}

.about-story__text {
    margin-bottom: 1rem;
    font-size: 1.02rem;
}

.about-story__text:last-child {
    margin-bottom: 0;
}

.about-mission {
    background: #ffffff;
}

.about-section-heading {
    max-width: 44rem;
    margin-bottom: 2.2rem;
}

.about-section-heading__title {
    margin-bottom: 0.85rem;
    font-size: clamp(1.9rem, 4vw, 3rem);
    line-height: 1.08;
    text-wrap: balance;
}

.about-section-heading__text {
    margin: 0;
    font-size: 1rem;
}

.about-mission__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.15rem;
}

.about-mission-card {
    position: relative;
    min-height: 100%;
    padding: 1.4rem;
    border: 1px solid #e5ebf7;
    border-radius: 1.35rem;
    background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
    box-shadow: 0 18px 48px rgb(26 51 112 / 0.08);
    transition:
        transform 220ms ease,
        box-shadow 220ms ease,
        border-color 220ms ease;
}

.about-mission-card:hover {
    transform: translateY(-0.3rem);
    border-color: #d3def8;
    box-shadow: 0 24px 56px rgb(26 51 112 / 0.12);
}

.about-mission-card__index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    margin-bottom: 1rem;
    border-radius: 999px;
    background: rgb(var(--color-primary-rgb) / 0.1);
    font-family: var(--font-heading);
    font-size: 0.94rem;
    font-weight: 800;
    color: var(--color-primary);
}

.about-mission-card__text {
    margin: 0;
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.55;
    color: var(--color-text);
}

.about-values {
    background: linear-gradient(180deg, #f8f9fd 0%, #ffffff 100%);
}

.about-values__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.15rem;
}

.about-value-card {
    position: relative;
    overflow: hidden;
    min-height: 100%;
    padding: 1.45rem;
    border: 1px solid #e6ecf8;
    border-radius: 1.4rem;
    background: #ffffff;
    box-shadow: 0 20px 52px rgb(23 43 96 / 0.08);
}

.about-value-card::after {
    content: "";
    position: absolute;
    inset: auto -2rem -2rem auto;
    width: 7rem;
    height: 7rem;
    border-radius: 50%;
    background: radial-gradient(circle, rgb(39 81 183 / 0.1) 0%, rgb(39 81 183 / 0) 70%);
}

.about-value-card__code {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    margin-bottom: 1rem;
    border-radius: 0.95rem;
    background: linear-gradient(135deg, var(--color-primary), #4e7cff);
    font-family: var(--font-heading);
    font-size: 0.9rem;
    font-weight: 800;
    color: #ffffff;
}

.about-value-card__title {
    margin-bottom: 0.55rem;
    font-family: var(--font-heading);
    font-size: 1.15rem;
    line-height: 1.3;
    color: var(--color-text);
}

.about-value-card__text {
    position: relative;
    z-index: 1;
    margin: 0;
    font-size: 0.96rem;
}

.about-perspective {
    background: #ffffff;
}

.about-perspective__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.3rem;
}

.about-panel {
    padding: 1.7rem;
    border-radius: 1.7rem;
    box-shadow: 0 22px 58px rgb(21 38 84 / 0.08);
}

.about-panel--primary {
    border: 1px solid #e4ebfb;
    background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);
}

.about-panel--accent {
    border: 1px solid rgb(var(--color-accent-rgb) / 0.18);
    background:
        linear-gradient(180deg, rgb(255 255 255 / 0.98), rgb(255 122 26 / 0.06)),
        #ffffff;
}

.about-panel__title {
    margin-bottom: 0.9rem;
    font-size: clamp(1.6rem, 3vw, 2.35rem);
    line-height: 1.08;
    text-wrap: balance;
}

.about-panel__text {
    margin-bottom: 1rem;
    font-size: 0.98rem;
}

.about-panel__list {
    display: grid;
    gap: 0.85rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.about-panel__list li {
    position: relative;
    padding-left: 1.45rem;
    font-size: 0.98rem;
    line-height: 1.65;
    color: var(--color-text);
}

.about-panel__list li::before {
    content: "";
    position: absolute;
    top: 0.55rem;
    left: 0;
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: var(--color-primary);
}

.about-panel--accent .about-panel__list li::before {
    background: var(--color-accent);
}

.about-panel__list--compact {
    gap: 0.65rem;
}

.about-cta {
    padding: 0 0 clamp(4.5rem, 7vw, 6rem);
    background: #ffffff;
}

.about-cta__panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 1.5rem 2rem;
    padding: clamp(1.85rem, 4vw, 2.5rem);
    border: 1px solid #dfe8fb;
    border-radius: 2rem;
    background:
        linear-gradient(135deg, rgb(39 81 183 / 0.08), rgb(255 122 26 / 0.04)),
        #ffffff;
    box-shadow: 0 24px 60px rgb(39 81 183 / 0.1);
}

.about-cta__title {
    margin-bottom: 0.75rem;
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    line-height: 1.08;
}

.about-cta__text {
    max-width: 38rem;
    margin: 0;
    font-size: 1rem;
}

.about-cta__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.85rem;
}

@media (max-width: 1100px) {
    .about-hero__grid,
    .about-story__grid,
    .about-perspective__grid,
    .about-cta__panel {
        grid-template-columns: 1fr;
    }

    .about-hero__card {
        max-width: 28rem;
    }

    .about-mission__grid,
    .about-values__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .about-cta__actions {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .about-mission__grid,
    .about-values__grid {
        grid-template-columns: 1fr;
    }

    .about-hero__title {
        font-size: clamp(2.1rem, 9vw, 3.5rem);
    }

    .about-story__title,
    .about-section-heading__title,
    .about-panel__title,
    .about-cta__title {
        font-size: clamp(1.75rem, 7vw, 2.45rem);
    }

    .about-cta__actions {
        flex-direction: column;
    }

    .about-cta__actions .button {
        width: 100%;
    }
}
