:root {
    --primary: #0000d2;
    --primary-dark: #02007e;
    --primary-soft: #2f3aff;
    --accent-yellow: #ffe300;
    --accent-magenta: #ff3bc4;
    --accent-cyan: #71feef;
    --text: #ffffff;
    --text-muted: rgba(255, 255, 255, 0.72);
    --background: linear-gradient(135deg, #02007e 0%, #0000d2 45%, #02007e 100%);
    --surface: linear-gradient(140deg, rgba(0, 0, 210, 0.82), rgba(16, 22, 255, 0.65));
    --surface-deep: linear-gradient(160deg, rgba(0, 0, 145, 0.85), rgba(0, 0, 90, 0.88));
    --surface-bright: linear-gradient(140deg, rgba(0, 0, 210, 0.9), rgba(47, 58, 255, 0.8));
    --border: rgba(113, 126, 255, 0.36);
    --shadow: 0 32px 90px rgba(0, 0, 70, 0.55);
    --radius-lg: 32px;
    --radius-md: 20px;
    --radius-sm: 12px;
    --transition: all 0.3s ease;
    scroll-behavior: smooth;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: 'Inter', sans-serif;
    background: var(--background);
    color: var(--text);
    line-height: 1.6;
    min-height: 100vh;
}

body::before,
body::after {
    content: '';
    position: fixed;
    inset: -30% -20% auto -20%;
    height: 140vh;
    pointer-events: none;
    opacity: 0.4;
    filter: blur(90px) saturate(140%);
    z-index: -2;
}

body::before {
    background:
        linear-gradient(130deg, rgba(255, 227, 0, 0.25) 0%, rgba(0, 0, 210, 0) 60%),
        radial-gradient(circle at 15% 20%, rgba(255, 59, 196, 0.28) 0%, transparent 55%);
}

body::after {
    inset: auto -25% -40% -15%;
    background:
        radial-gradient(circle at 65% 35%, rgba(113, 254, 239, 0.32) 0%, transparent 45%),
        linear-gradient(120deg, rgba(0, 0, 210, 0.4) 0%, rgba(0, 0, 120, 0.15) 100%);
}

h1, h2, h3, h4 {
    font-family: 'Space Grotesk', sans-serif;
    font-weight: 600;
    margin: 0;
    line-height: 1.2;
}

p {
    margin: 0;
}

a {
    color: inherit;
    text-decoration: none;
}

.container {
    width: min(1180px, 90vw);
    margin: 0 auto;
}

.nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: rgba(1, 1, 120, 0.75);
    backdrop-filter: blur(26px);
    border-bottom: 1px solid rgba(113, 126, 255, 0.35);
    box-shadow: 0 18px 40px rgba(0, 0, 70, 0.42);
}

.nav__container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.2rem 5vw;
    width: min(1180px, 100%);
    margin: 0 auto;
}

.nav__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    font-family: 'Space Grotesk', sans-serif;
    font-weight: 700;
    font-size: 1.25rem;
    letter-spacing: 0.05em;
}

.nav__logo {
    width: 34px;
    height: 34px;
    object-fit: contain;
    filter: drop-shadow(0 6px 18px rgba(0, 0, 0, 0.35));
}

.nav__brand-text {
    background: linear-gradient(120deg, #ffffff 20%, #71feef 60%, #ffe300 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    display: inline-block;
}

.nav__menu {
    display: flex;
    gap: 1.75rem;
    align-items: center;
}

.nav__toggle {
    display: none;
    flex-direction: column;
    gap: 0.4rem;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.55);
    cursor: pointer;
    transition: var(--transition);
}

.nav__toggle span {
    display: block;
    width: 18px;
    height: 2px;
    background: #ffffff;
    border-radius: 999px;
    transition: var(--transition);
}

.nav__toggle:hover {
    border-color: rgba(255, 227, 0, 0.55);
    background: rgba(0, 0, 90, 0.6);
}

.nav__toggle.is-active span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}

.nav__toggle.is-active span:nth-child(2) {
    opacity: 0;
}

.nav__toggle.is-active span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

.nav__link {
    font-weight: 500;
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.68);
    transition: var(--transition);
    text-shadow: 0 0 16px rgba(113, 254, 239, 0.3);
}

.nav__link:hover,
.nav__link:focus-visible {
    color: var(--text);
}

.nav__link--cta {
    padding: 0.6rem 1.25rem;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(0, 0, 210, 0.55), rgba(113, 254, 239, 0.4));
    border: 1px solid rgba(113, 254, 239, 0.55);
    color: var(--text);
    box-shadow: 0 12px 30px rgba(0, 0, 100, 0.4);
}

main {
    padding-top: 96px;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.85rem 1.65rem;
    border-radius: 16px;
    font-weight: 600;
    transition: var(--transition);
    border: none;
    cursor: pointer;
}

.btn-primary {
    background: linear-gradient(135deg, #0000d2 0%, #71feef 60%, #ff3bc4 100%);
    color: #ffffff;
    box-shadow: 0 22px 60px rgba(0, 0, 120, 0.48);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 28px 70px rgba(0, 0, 130, 0.52);
}

.btn-outline {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(113, 254, 239, 0.35);
    color: var(--text);
}

.btn-outline:hover {
    background: rgba(255, 59, 196, 0.18);
    border-color: rgba(113, 254, 239, 0.45);
}

.btn-ghost {
    background: rgba(0, 0, 80, 0.4);
    border: 1px solid rgba(255, 227, 0, 0.4);
    color: var(--text);
    padding: 0.75rem 1.5rem;
}

.btn-ghost:hover {
    border-color: rgba(255, 59, 196, 0.55);
    background: rgba(0, 0, 90, 0.5);
}

.hero {
    position: relative;
    overflow: hidden;
    min-height: 92vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 6.5rem 0 5.5rem;
    background:
        radial-gradient(circle at 22% 20%, rgba(255, 227, 0, 0.18) 0%, transparent 42%),
        radial-gradient(circle at 78% 28%, rgba(255, 59, 196, 0.22) 0%, transparent 55%),
        radial-gradient(circle at 52% 82%, rgba(113, 254, 239, 0.26) 0%, transparent 52%),
        linear-gradient(140deg, #010046 0%, #0000a6 45%, #0000d2 80%, #010029 100%);
}

.hero__backdrop {
    position: absolute;
    inset: -20%;
    background:
        radial-gradient(circle at 12% 28%, rgba(255, 227, 0, 0.32), transparent 55%),
        radial-gradient(circle at 70% 10%, rgba(255, 59, 196, 0.3), transparent 58%),
        radial-gradient(circle at 45% 85%, rgba(113, 254, 239, 0.38), transparent 60%),
        linear-gradient(120deg, rgba(0, 0, 150, 0.9), rgba(0, 0, 230, 0.75));
    filter: blur(16px) saturate(180%);
    opacity: 0.88;
    animation: heroFlow 16s ease-in-out infinite alternate;
}

.hero__container::before {
    content: '';
    position: absolute;
    inset: -55% 5% 56% 5%;
    background: linear-gradient(120deg, rgba(255, 227, 0, 0.45), rgba(113, 254, 239, 0.5));
    filter: blur(130px);
    opacity: 0.42;
    pointer-events: none;
}

.hero__container::after {
    content: '';
    position: absolute;
    inset: 45% -30% -40% -30%;
    background: linear-gradient(105deg, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0) 65%);
    opacity: 0.25;
    transform: rotate(-6deg);
    pointer-events: none;
}

.hero__container {
    position: relative;
    text-align: center;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
    backdrop-filter: blur(6px);
}

.hero__badge {
    align-self: center;
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.45rem 1.25rem;
    border-radius: 999px;
    background: rgba(0, 0, 100, 0.6);
    border: 1px solid rgba(113, 254, 239, 0.5);
    font-size: 0.85rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: 0 14px 30px rgba(0, 0, 210, 0.4);
}

.hero__badge-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: linear-gradient(135deg, #71feef, #ffe300);
}

.hero__title {
    font-size: clamp(2.8rem, 7vw, 4.4rem);
    background: linear-gradient(128deg,
        #71feef 0%,
        #a4e9ff 25%,
        #ffffff 55%,
        #d9ceff 75%,
        #ff3bc4 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin: 0 auto;
    max-width: 900px;
    text-shadow: 0 0 45px rgba(0, 0, 110, 0.65);
}

.hero__subtitle {
    font-size: clamp(1.05rem, 2.2vw, 1.35rem);
    color: rgba(255, 255, 255, 0.85);
    max-width: 780px;
    margin: 0 auto;
    text-shadow: 0 0 28px rgba(0, 0, 120, 0.4);
}

.hero__actions {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.section {
    padding: 6rem 0;
    position: relative;
    background: var(--surface-deep);
}

.section::after {
    content: '';
    position: absolute;
    inset: auto 10% -32% 10%;
    height: 180px;
    background: radial-gradient(circle, rgba(113, 254, 239, 0.2), transparent 70%);
    opacity: 0.35;
    pointer-events: none;
}

.section::before {
    content: '';
    position: absolute;
    inset: 5% 12% auto 12%;
    height: 48px;
    border-radius: 999px;
    background: linear-gradient(120deg, rgba(113, 254, 239, 0.12), rgba(255, 59, 196, 0.08));
    opacity: 0.5;
    filter: blur(40px);
    pointer-events: none;
}

.section__header {
    text-align: center;
    margin-bottom: 3rem;
    display: grid;
    gap: 1rem;
    justify-items: center;
}

.section__title {
    font-size: clamp(2.2rem, 4.5vw, 3rem);
    background: linear-gradient(125deg, #ffffff 0%, #71feef 40%, #ffe300 85%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    max-width: 780px;
}

.section__description {
    max-width: 720px;
    color: var(--text-muted);
    font-size: 1.05rem;
}

.eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.76rem;
    color: rgba(255, 255, 255, 0.6);
}

.about {
    background: linear-gradient(150deg, rgba(0, 0, 120, 0.92), rgba(47, 58, 255, 0.65));
}

.about::after {
    inset: auto 15% -35% 15%;
    background: radial-gradient(circle, rgba(255, 227, 0, 0.22), transparent 75%);
}

.about::before {
    inset: 6% 20% auto 20%;
    background: linear-gradient(115deg, rgba(113, 254, 239, 0.2), rgba(255, 59, 196, 0.16));
}

.about__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: 3rem;
    position: relative;
    z-index: 1;
}

.about__column {
    position: relative;
    border-radius: var(--radius-lg);
    padding: 2.6rem 2.4rem;
    border: 1px solid rgba(113, 126, 255, 0.32);
    background: linear-gradient(145deg, rgba(0, 0, 90, 0.82), rgba(0, 0, 140, 0.68));
    box-shadow: 0 28px 70px rgba(0, 0, 80, 0.5);
    overflow: hidden;
    backdrop-filter: blur(18px);
}

.about__column::before {
    content: '';
    position: absolute;
    inset: -40% -20% 55% 35%;
    background: radial-gradient(circle, rgba(113, 254, 239, 0.4), transparent 65%);
    opacity: 0.6;
    pointer-events: none;
}

.about__column--story {
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.82), rgba(0, 0, 160, 0.72));
}

.about__column--story::after {
    content: '';
    position: absolute;
    inset: 50% 50% -35% -20%;
    background: radial-gradient(circle, rgba(255, 59, 196, 0.32), transparent 65%);
    opacity: 0.5;
    pointer-events: none;
}

.about__column--pillars {
    background: linear-gradient(150deg, rgba(0, 0, 80, 0.78), rgba(0, 0, 140, 0.76));
}

.about__column--pillars::before {
    inset: -25% 30% 40% -35%;
    background: radial-gradient(circle, rgba(255, 227, 0, 0.32), transparent 60%);
}

.about__column--pillars::after {
    content: '';
    position: absolute;
    inset: auto -20% -35% 35%;
    height: 60%;
    background: radial-gradient(circle, rgba(113, 254, 239, 0.35), transparent 65%);
    opacity: 0.6;
    pointer-events: none;
    filter: blur(30px);
}

.about__signal {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.55rem 1.3rem;
    border-radius: 18px;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.55);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.78);
    box-shadow: 0 16px 36px rgba(0, 0, 120, 0.45);
}

.about__signal-dot {
    width: 12px;
    height: 12px;
    border-radius: 40%;
    background: linear-gradient(135deg, #71feef, #ff3bc4);
    box-shadow: 0 0 16px rgba(113, 254, 239, 0.75);
}

.about__headline {
    font-size: clamp(1.9rem, 3.8vw, 2.8rem);
    margin: 1.9rem 0 1.2rem;
    background: linear-gradient(128deg, #ffffff 0%, #71feef 35%, #ff3bc4 90%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.about__lead {
    font-size: 1.05rem;
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: 1.6rem;
}

.about__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.9rem;
}

.about__list li {
    position: relative;
    padding-left: 1.9rem;
    color: var(--text-muted);
}

.about__list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.45rem;
    width: 12px;
    height: 12px;
    border-radius: 45%;
    background: linear-gradient(135deg, #71feef, #ffe300);
    box-shadow: 0 0 18px rgba(113, 254, 239, 0.65);
    opacity: 0.9;
}

.about__stats {
    margin-top: 2.4rem;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1.2rem;
}

.about__stat {
    padding: 1.6rem 1.4rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: linear-gradient(145deg, rgba(0, 0, 120, 0.85), rgba(47, 58, 255, 0.65));
    box-shadow: 0 22px 60px rgba(0, 0, 80, 0.5);
}

.about__stat-number {
    display: block;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 2.35rem;
    margin-bottom: 0.35rem;
    background: linear-gradient(120deg, #71feef 0%, #ffffff 55%, #ff3bc4 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.about__stat-label {
    font-size: 0.92rem;
    color: rgba(255, 255, 255, 0.7);
    letter-spacing: 0.03em;
}

.about__timeline {
    position: relative;
    display: grid;
    gap: 2.1rem;
    margin-top: 0.4rem;
}

.about__timeline::before {
    content: '';
    position: absolute;
    left: 1.25rem;
    top: 0.6rem;
    bottom: 0.6rem;
    width: 2px;
    background: linear-gradient(180deg,
        rgba(113, 254, 239, 0),
        rgba(113, 254, 239, 0.85) 35%,
        rgba(255, 227, 0, 0.8) 60%,
        rgba(255, 59, 196, 0.85) 85%,
        rgba(255, 59, 196, 0));
    opacity: 0.85;
}

.about__timeline-node {
    position: relative;
    padding-left: 3.8rem;
}

.about__timeline-index {
    position: absolute;
    left: 0;
    top: 0;
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 18px;
    background: linear-gradient(135deg, #71feef, #ff3bc4);
    color: #04003b;
    font-family: 'Space Grotesk', sans-serif;
    font-weight: 600;
    display: grid;
    place-items: center;
    box-shadow: 0 16px 36px rgba(0, 0, 120, 0.55);
}

.about__timeline-index::after {
    content: '';
    position: absolute;
    inset: -18px;
    border-radius: 24px;
    background: radial-gradient(circle, rgba(113, 254, 239, 0.3), transparent 70%);
    z-index: -1;
}

.about__timeline-body {
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.38);
    background: linear-gradient(145deg, rgba(0, 0, 120, 0.82), rgba(0, 0, 175, 0.68));
    padding: 1.45rem 1.65rem;
    box-shadow: 0 22px 58px rgba(0, 0, 80, 0.52);
}

.about__timeline-body h3 {
    font-size: 1.22rem;
    margin-bottom: 0.65rem;
}

.about__timeline-body p {
    color: var(--text-muted);
}

@media (max-width: 1080px) {
    .about__layout {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }
}

@media (max-width: 720px) {
    .about__column {
        padding: 2.2rem 2rem;
    }

    .about__stats {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .about__timeline::before {
        left: 1.05rem;
    }

    .about__timeline-node {
        padding-left: 3.3rem;
    }

    .about__timeline-index {
        width: 2.4rem;
        height: 2.4rem;
        border-radius: 16px;
        font-size: 0.92rem;
    }
}

@media (max-width: 540px) {
    .about__column {
        padding: 1.9rem 1.6rem;
    }

    .about__headline {
        margin: 1.4rem 0 1rem;
    }

    .about__timeline-node {
        padding-left: 3rem;
    }

    .about__timeline::before {
        left: 0.9rem;
    }
}

.divisions {
    background: linear-gradient(160deg, rgba(0, 0, 110, 0.9), rgba(0, 0, 70, 0.95));
}

.divisions::after {
    background:
        radial-gradient(circle at 20% 35%, rgba(71, 254, 239, 0.2), transparent 70%),
        radial-gradient(circle at 80% 65%, rgba(255, 59, 196, 0.18), transparent 75%),
        radial-gradient(circle at 50% 90%, rgba(255, 227, 0, 0.16), transparent 75%);
    opacity: 0.55;
}

.divisions__layout {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 3rem;
    position: relative;
    z-index: 1;
}

.divisions__column {
    position: relative;
    border-radius: var(--radius-lg);
    padding: 2.6rem 2.4rem;
    border: 1px solid rgba(113, 126, 255, 0.32);
    background: linear-gradient(145deg, rgba(0, 0, 90, 0.82), rgba(0, 0, 140, 0.68));
    box-shadow: 0 26px 66px rgba(0, 0, 70, 0.52);
    overflow: hidden;
    backdrop-filter: blur(14px);
}

.divisions__column::before {
    content: '';
    position: absolute;
    inset: -35% 35% 55% -25%;
    background: radial-gradient(circle, rgba(113, 254, 239, 0.5), transparent 65%);
    opacity: 0.55;
    pointer-events: none;
}

.divisions__column--map {
    background: linear-gradient(150deg, rgba(0, 0, 100, 0.82), rgba(0, 0, 160, 0.7));
    display: grid;
    gap: 2.2rem;
    align-content: start;
}

.divisions__column--map::after {
    content: '';
    position: absolute;
    inset: auto -20% -30% 30%;
    height: 60%;
    background: radial-gradient(circle, rgba(255, 227, 0, 0.35), transparent 70%);
    opacity: 0.6;
    pointer-events: none;
}

.divisions__column--details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.35rem;
    background: linear-gradient(150deg, rgba(0, 0, 90, 0.82), rgba(0, 0, 130, 0.68));
}

.divisions__column--details::before {
    inset: -25% -15% 60% 40%;
    background: radial-gradient(circle, rgba(255, 59, 196, 0.35), transparent 65%);
}

.division-panel-group {
    display: grid;
    gap: 1.35rem;
}

.division-panel-group--left {
    margin-top: 1.2rem;
}

.divisions__constellation {
    position: relative;
    width: min(420px, 90%);
    aspect-ratio: 1 / 1;
    margin: 0 auto 2.4rem;
    border-radius: 50%;
    border: 1px dashed rgba(113, 126, 255, 0.4);
    display: grid;
    place-items: center;
    background: radial-gradient(circle, rgba(0, 0, 90, 0.65), transparent 70%);
    box-shadow: inset 0 0 60px rgba(0, 0, 110, 0.55);
}

.divisions__core {
    position: relative;
    width: 160px;
    height: 160px;
    border-radius: 50%;
    background: linear-gradient(140deg, rgba(113, 254, 239, 0.45), rgba(255, 59, 196, 0.4));
    border: 1px solid rgba(113, 254, 239, 0.5);
    display: grid;
    place-items: center;
    text-align: center;
    gap: 0.35rem;
    box-shadow: 0 22px 60px rgba(0, 0, 120, 0.5);
}

.divisions__core::after {
    content: '';
    position: absolute;
    inset: -20px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(113, 254, 239, 0.2), transparent 70%);
    filter: blur(10px);
}

.divisions__core-title {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 1rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(4, 0, 40, 0.8);
}

.divisions__core-subtitle {
    font-size: 0.9rem;
    color: rgba(4, 0, 40, 0.75);
    font-weight: 600;
}

.divisions__orbit {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 1.45rem;
    border-radius: 999px;
    background: rgba(0, 0, 80, 0.72);
    border: 1px solid rgba(113, 126, 255, 0.5);
    box-shadow: 0 16px 36px rgba(0, 0, 110, 0.45);
    font-size: 0.85rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.82);
}

.divisions__orbit::after {
    content: '';
    position: absolute;
    inset: -12px;
    border-radius: 999px;
    border: 1px solid rgba(113, 254, 239, 0.35);
    opacity: 0.8;
}

.divisions__orbit--strategy { top: 12%; left: 50%; transform: translateX(-50%); }
.divisions__orbit--design { top: 30%; right: 5%; transform: translateX(10%); }
.divisions__orbit--engineering { top: 60%; right: 0; transform: translateX(15%); }
.divisions__orbit--interactive { bottom: 18%; right: 18%; }
.divisions__orbit--qa { bottom: 10%; left: 18%; }
.divisions__orbit--support { top: 45%; left: 0; transform: translateX(-20%); }

.divisions__node {
    position: relative;
    z-index: 1;
}

.divisions__note {
    color: rgba(255, 255, 255, 0.82);
    font-size: 1.02rem;
    line-height: 1.7;
    margin-bottom: 2rem;
}

.divisions__legend {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.5rem;
    color: var(--text-muted);
    font-size: 0.9rem;
}

.divisions__legend-item {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.65rem 1.1rem;
    border-radius: 18px;
    background: rgba(0, 0, 80, 0.55);
    border: 1px solid rgba(113, 126, 255, 0.32);
    box-shadow: 0 12px 32px rgba(0, 0, 110, 0.45);
}

.divisions__legend-dot {
    width: 14px;
    height: 14px;
    border-radius: 40%;
    box-shadow: 0 0 16px currentColor;
}

.divisions__legend-dot--discovery {
    background: linear-gradient(135deg, #71feef, #ffffff);
    color: rgba(113, 254, 239, 0.6);
}

.divisions__legend-dot--craft {
    background: linear-gradient(135deg, #ffffff, #ff3bc4);
    color: rgba(255, 59, 196, 0.6);
}

.divisions__legend-dot--assure {
    background: linear-gradient(135deg, #ffe300, #71feef);
    color: rgba(255, 227, 0, 0.6);
}

.division-panel {
    position: relative;
    padding: 2.1rem 2rem 2.2rem 2.6rem;
    border-radius: var(--radius-md);
    background: linear-gradient(150deg, rgba(0, 0, 100, 0.88), rgba(47, 58, 255, 0.72));
    border: 1px solid rgba(113, 126, 255, 0.4);
    box-shadow: 0 24px 58px rgba(0, 0, 90, 0.5);
    overflow: hidden;
    transition: var(--transition);
}

.division-panel::before {
    content: '';
    position: absolute;
    inset: -35% 55% 55% -20%;
    background: linear-gradient(145deg, rgba(113, 254, 239, 0.35), rgba(255, 59, 196, 0.3));
    opacity: 0;
    transition: var(--transition);
    filter: blur(50px);
}

.division-panel:hover {
    transform: translateY(-8px);
    border-color: rgba(255, 227, 0, 0.55);
}

.division-panel:hover::before {
    opacity: 1;
}

.division-panel__tag {
    position: absolute;
    left: 1.4rem;
    top: 1.4rem;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 0.85rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.55);
}

.division-panel__head {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 1.25rem;
    align-items: baseline;
    margin-bottom: 0.85rem;
}

.division-panel__head h3 {
    font-size: 1.3rem;
}

.division-panel__focus {
    padding: 0.45rem 1rem;
    border-radius: 999px;
    border: 1px solid rgba(113, 254, 239, 0.5);
    background: rgba(0, 0, 80, 0.55);
    font-size: 0.8rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.72);
}

.division-panel p {
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: 1.15rem;
}

.division-panel__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.7rem;
    color: var(--text-muted);
}

.division-panel__list li {
    position: relative;
    padding-left: 1.4rem;
}

.division-panel__list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.5rem;
    width: 9px;
    height: 9px;
    border-radius: 45%;
    background: linear-gradient(135deg, #71feef, #ff3bc4);
    box-shadow: 0 0 16px rgba(113, 254, 239, 0.65);
}

.division-panel__cta {
    margin-top: 1.4rem;
    align-self: start;
}

@media (max-width: 1080px) {
    .divisions__layout {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }

    .divisions__constellation {
        width: min(360px, 80%);
    }

    .divisions__column {
        padding: 2.3rem 2.1rem;
    }
}

@media (max-width: 820px) {
    .divisions__column--details {
        grid-template-columns: 1fr;
    }

    .division-panel {
        padding: 2rem 1.75rem 2rem 2.4rem;
    }
}

@media (max-width: 620px) {
    .divisions__constellation {
        width: 100%;
        aspect-ratio: 1 / 1.1;
    }

    .divisions__orbit {
        font-size: 0.72rem;
        padding: 0.45rem 1.1rem;
    }

    .division-panel {
        padding: 1.8rem 1.6rem 1.8rem 2.2rem;
    }

    .division-panel__head h3 {
        font-size: 1.15rem;
    }
}

.process {
    background: linear-gradient(160deg, rgba(0, 0, 145, 0.95), rgba(0, 0, 70, 0.92));
}

.process::after {
    background: radial-gradient(circle at 20% 40%, rgba(255, 227, 0, 0.18), transparent 70%),
                radial-gradient(circle at 70% 60%, rgba(113, 254, 239, 0.18), transparent 65%);
}

.process__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.6rem;
    position: relative;
    z-index: 1;
}

.process-card {
    position: relative;
    padding: 2.1rem 2rem 2.4rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.36);
    background: linear-gradient(150deg, rgba(0, 0, 120, 0.88), rgba(0, 0, 70, 0.7));
    box-shadow: 0 20px 52px rgba(4, 14, 44, 0.45);
    display: grid;
    gap: 1rem;
    overflow: hidden;
    transition: var(--transition);
}

.process-card::before {
    content: '';
    position: absolute;
    inset: -40% 58% 60% -25%;
    background: linear-gradient(135deg, rgba(113, 254, 239, 0.35), rgba(255, 227, 0, 0.35));
    opacity: 0;
    filter: blur(40px);
    transition: var(--transition);
}

.process-card:hover {
    transform: translateY(-6px);
    border-color: rgba(255, 227, 0, 0.6);
}

.process-card:hover::before {
    opacity: 1;
}

.process-card--lead {
    grid-column: span 2;
    background: linear-gradient(155deg, rgba(0, 0, 145, 0.92), rgba(47, 58, 255, 0.7));
    border-color: rgba(113, 254, 239, 0.38);
}

.process-card__step {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 0.82rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.55);
}

.process-card h3 {
    font-size: 1.2rem;
    margin: 0;
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.process-card p {
    color: rgba(255, 255, 255, 0.82);
    margin: 0;
}

.process-card__cta {
    margin-top: auto;
    align-self: start;
}

@media (max-width: 980px) {
    .process-card--lead {
        grid-column: span 1;
    }
}

@media (max-width: 640px) {
    .process-card {
        padding: 1.9rem 1.7rem 2.2rem;
    }
}

.solutions {
    background: linear-gradient(145deg, rgba(0, 0, 110, 0.92), rgba(47, 58, 255, 0.65));
}

.solutions::after {
    background: radial-gradient(circle at 25% 35%, rgba(255, 227, 0, 0.16), transparent 70%),
                radial-gradient(circle at 80% 55%, rgba(255, 59, 196, 0.18), transparent 75%);
}

.solutions__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.6rem;
    position: relative;
    z-index: 1;
}

.solution-feature {
    grid-column: span 2;
    padding: 2.4rem;
    border-radius: var(--radius-lg);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.9), rgba(47, 58, 255, 0.65));
    border: 1px solid rgba(113, 126, 255, 0.38);
    box-shadow: 0 24px 60px rgba(0, 0, 80, 0.48);
    display: grid;
    gap: 1.2rem;
}

.solution-feature__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.5rem 1.2rem;
    border-radius: 18px;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.55);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.78);
}

.solution-feature h3 {
    font-size: clamp(1.8rem, 3.2vw, 2.5rem);
    background: linear-gradient(128deg, #ffffff 0%, #71feef 35%, #ff3bc4 90%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin: 0;
}

.solution-feature p {
    color: rgba(255, 255, 255, 0.88);
    font-size: 1.05rem;
}

.solution-feature ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.8rem;
    color: var(--text-muted);
}

.solution-feature ul li {
    position: relative;
    padding-left: 1.6rem;
}

.solution-feature ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.4rem;
    width: 10px;
    height: 10px;
    border-radius: 45%;
    background: linear-gradient(135deg, #71feef, #ffe300);
    box-shadow: 0 0 16px rgba(113, 254, 239, 0.6);
}

.solution-feature__cta {
    width: fit-content;
}

.solution-item {
    padding: 1.9rem 1.7rem;
    border-radius: var(--radius-md);
    background: linear-gradient(150deg, rgba(0, 0, 120, 0.88), rgba(47, 58, 255, 0.7));
    border: 1px solid rgba(113, 126, 255, 0.38);
    box-shadow: 0 18px 48px rgba(5, 16, 46, 0.45);
    display: grid;
    gap: 0.8rem;
    transition: var(--transition);
}

.solution-item:hover {
    transform: translateY(-6px);
    border-color: rgba(255, 227, 0, 0.55);
}

.solution-item__tag {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.9rem;
    border-radius: 999px;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.6);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.75);
}

.solution-item h3 {
    font-size: 1.25rem;
    margin: 0;
}

.solution-item p {
    color: rgba(255, 255, 255, 0.85);
    margin: 0;
}

.solution-item ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.55rem;
    color: var(--text-muted);
}

.solution-item ul li {
    position: relative;
    padding-left: 1.3rem;
}

.solution-item ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.4rem;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, #71feef, #ff3bc4);
    box-shadow: 0 0 14px rgba(113, 254, 239, 0.6);
}

@media (max-width: 980px) {
    .solution-feature {
        grid-column: span 1;
    }
}

@media (max-width: 640px) {
    .solution-feature {
        padding: 2rem;
    }

    .solution-item {
        padding: 1.7rem 1.5rem;
    }
}

.industries {
    background: linear-gradient(150deg, rgba(0, 0, 90, 0.95), rgba(0, 0, 140, 0.88));
}

.industries::after {
    background: radial-gradient(circle at 30% 35%, rgba(113, 254, 239, 0.18), transparent 70%),
                radial-gradient(circle at 78% 65%, rgba(255, 227, 0, 0.14), transparent 75%);
}

.industries__container {
    display: grid;
    gap: 3rem;
}

.industries__content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 2rem;
}

.industries__list, .industries__culture {
    background: linear-gradient(145deg, rgba(0, 0, 120, 0.9), rgba(47, 58, 255, 0.7));
    border-radius: var(--radius-md);
    padding: 2.3rem;
    border: 1px solid rgba(113, 126, 255, 0.38);
    display: grid;
    gap: 1.2rem;
    box-shadow: 0 16px 44px rgba(4, 16, 46, 0.45);
}

.industries__list ul {
    list-style: none;
    display: grid;
    gap: 0.65rem;
    padding: 0;
    margin: 0;
    color: var(--text-muted);
}

.industries__culture p {
    color: var(--text-muted);
}

.contact {
    background: linear-gradient(165deg, rgba(0, 0, 90, 0.92), rgba(0, 0, 40, 0.98));
}

.contact::after {
    background: radial-gradient(circle at 20% 50%, rgba(113, 254, 239, 0.2), transparent 70%),
                radial-gradient(circle at 75% 60%, rgba(255, 59, 196, 0.16), transparent 75%);
}

.legal {
    background: linear-gradient(155deg, rgba(0, 0, 120, 0.9), rgba(0, 0, 65, 0.95));
    overflow: hidden;
}

.legal::after {
    background:
        radial-gradient(circle at 18% 32%, rgba(113, 254, 239, 0.24), transparent 70%),
        radial-gradient(circle at 76% 68%, rgba(255, 59, 196, 0.2), transparent 75%),
        radial-gradient(circle at 48% 90%, rgba(255, 227, 0, 0.18), transparent 78%);
    opacity: 0.6;
}

.legal__container {
    display: grid;
    gap: 2.6rem;
    position: relative;
    z-index: 1;
}

.legal__intro {
    display: grid;
    gap: 1.3rem;
    text-align: center;
    justify-items: center;
    max-width: 780px;
    margin: 0 auto;
}

.legal__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.55rem 1.35rem;
    border-radius: 999px;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.55);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.78);
}

.legal__title {
    font-size: clamp(2.4rem, 4.6vw, 3.2rem);
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin: 0;
}

.legal__lead {
    font-size: 1.08rem;
    color: rgba(255, 255, 255, 0.82);
}

.legal__cards {
    display: grid;
    gap: 1.6rem;
}

.legal__card {
    padding: 2.1rem 2.2rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.36);
    background: linear-gradient(148deg, rgba(0, 0, 110, 0.88), rgba(47, 58, 255, 0.7));
    box-shadow: 0 22px 58px rgba(5, 16, 46, 0.45);
    display: grid;
    gap: 1rem;
}

.legal__card h2 {
    font-size: 1.35rem;
    margin: 0;
}

.legal__card p {
    color: rgba(255, 255, 255, 0.85);
    margin: 0;
}

.legal__card a {
    color: var(--accent-cyan);
    text-decoration: underline;
}

.legal__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.7rem;
    color: var(--text-muted);
}

.legal__list li {
    position: relative;
    padding-left: 1.5rem;
}

.legal__list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.5rem;
    width: 9px;
    height: 9px;
    border-radius: 45%;
    background: linear-gradient(135deg, #71feef, #ffe300);
    box-shadow: 0 0 14px rgba(113, 254, 239, 0.6);
}

.legal__cta {
    display: flex;
    flex-wrap: wrap;
    gap: 1.2rem;
    align-items: center;
    justify-content: center;
    background: linear-gradient(150deg, rgba(0, 0, 90, 0.82), rgba(0, 0, 130, 0.68));
    border: 1px solid rgba(113, 126, 255, 0.36);
    border-radius: var(--radius-md);
    padding: 1.9rem 2.2rem;
    box-shadow: 0 18px 48px rgba(5, 16, 46, 0.38);
    text-align: center;
    color: rgba(255, 255, 255, 0.85);
}

.legal__cta p {
    margin: 0;
    font-size: 1rem;
}

.security-hero {
    background: linear-gradient(170deg, rgba(0, 0, 120, 0.92), rgba(0, 0, 45, 0.96));
}

.security-hero::after {
    background:
        radial-gradient(circle at 20% 35%, rgba(113, 254, 239, 0.24), transparent 70%),
        radial-gradient(circle at 78% 70%, rgba(255, 59, 196, 0.18), transparent 72%);
    opacity: 0.65;
}

.security-hero__container {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    gap: 3rem;
    align-items: center;
    position: relative;
    z-index: 1;
}

.security-hero__intro {
    display: grid;
    gap: 1.5rem;
}

.security-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.55rem 1.35rem;
    border-radius: 999px;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.6);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.78);
    width: fit-content;
}

.security-hero__title {
    font-size: clamp(2.6rem, 5vw, 3.6rem);
    margin: 0;
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.security-hero__lead {
    font-size: 1.12rem;
    color: rgba(255, 255, 255, 0.85);
    max-width: 640px;
}

.security-hero__stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1.5rem;
}

.security-stat {
    padding: 1.4rem 1.3rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.88), rgba(47, 58, 255, 0.68));
    box-shadow: 0 18px 48px rgba(5, 16, 46, 0.45);
    display: grid;
    gap: 0.4rem;
}

.security-stat__number {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 2.2rem;
    background: linear-gradient(125deg, #71feef 0%, #ffffff 55%, #ff3bc4 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.security-stat__label {
    font-size: 0.92rem;
    color: rgba(255, 255, 255, 0.7);
    letter-spacing: 0.04em;
}

.security-hero__panel {
    padding: 2.4rem 2.2rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: linear-gradient(155deg, rgba(0, 0, 110, 0.9), rgba(0, 0, 60, 0.72));
    box-shadow: 0 28px 70px rgba(0, 0, 70, 0.52);
    display: grid;
    gap: 1.2rem;
}

.security-hero__panel h2 {
    margin: 0;
    font-size: 1.5rem;
}

.security-hero__panel ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.8rem;
    color: var(--text-muted);
}

.security-hero__panel ul li {
    position: relative;
    padding-left: 1.6rem;
}

.security-hero__panel ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.45rem;
    width: 10px;
    height: 10px;
    border-radius: 45%;
    background: linear-gradient(135deg, #71feef, #ffe300);
    box-shadow: 0 0 15px rgba(113, 254, 239, 0.65);
}

.security-hero__cta {
    justify-self: flex-start;
}

.security-posture {
    background: linear-gradient(160deg, rgba(0, 0, 110, 0.92), rgba(0, 0, 55, 0.95));
}

.security-posture::after {
    background:
        radial-gradient(circle at 18% 30%, rgba(113, 254, 239, 0.22), transparent 70%),
        radial-gradient(circle at 70% 72%, rgba(255, 59, 196, 0.18), transparent 75%);
}

.security-posture__container {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 3rem;
    position: relative;
    z-index: 1;
}

.security-posture__column {
    display: grid;
    gap: 1.4rem;
}

.security-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.76rem;
    color: rgba(255, 255, 255, 0.6);
}

.security-posture__title {
    font-size: clamp(2.1rem, 4.2vw, 3rem);
    margin: 0;
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.security-posture__lead {
    font-size: 1.05rem;
    color: rgba(255, 255, 255, 0.82);
    max-width: 640px;
}

.security-pillars {
    display: grid;
    gap: 1.2rem;
}

.security-pillar {
    padding: 1.6rem 1.5rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.36);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.85), rgba(47, 58, 255, 0.68));
    box-shadow: 0 20px 52px rgba(5, 16, 46, 0.4);
}

.security-pillar h3 {
    margin: 0 0 0.7rem;
    font-size: 1.15rem;
}

.security-pillar p {
    margin: 0;
    color: rgba(255, 255, 255, 0.8);
}

.security-posture__column--timeline {
    align-self: stretch;
}

.security-timeline {
    display: grid;
    gap: 1.4rem;
    position: relative;
}

.security-timeline::before {
    content: '';
    position: absolute;
    left: 1.1rem;
    top: 0.4rem;
    bottom: 0.4rem;
    width: 2px;
    background: linear-gradient(180deg, rgba(113, 254, 239, 0.6), rgba(255, 59, 196, 0.5));
}

.security-timeline__node {
    position: relative;
    padding: 1.4rem 1.6rem 1.4rem 3.4rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.35);
    background: linear-gradient(150deg, rgba(0, 0, 100, 0.85), rgba(0, 0, 60, 0.7));
    box-shadow: 0 18px 48px rgba(5, 16, 46, 0.38);
}

.security-timeline__index {
    position: absolute;
    left: 0.8rem;
    top: 1.3rem;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    border: 1px solid rgba(113, 254, 239, 0.5);
    display: grid;
    place-items: center;
    font-size: 0.82rem;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.75);
    background: rgba(0, 0, 80, 0.55);
}

.security-timeline__node h4 {
    margin: 0 0 0.45rem;
    font-size: 1.12rem;
}

.security-timeline__node p {
    margin: 0;
    color: rgba(255, 255, 255, 0.78);
}

.security-grid {
    background: linear-gradient(150deg, rgba(0, 0, 105, 0.92), rgba(0, 0, 55, 0.92));
}

.security-grid::after {
    background:
        radial-gradient(circle at 15% 30%, rgba(113, 254, 239, 0.2), transparent 70%),
        radial-gradient(circle at 80% 65%, rgba(255, 59, 196, 0.2), transparent 75%);
}

.security-grid__layout {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.6rem;
    position: relative;
    z-index: 1;
}

.security-card {
    padding: 2rem 1.9rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.38);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.88), rgba(47, 58, 255, 0.7));
    box-shadow: 0 20px 52px rgba(5, 16, 46, 0.4);
    display: grid;
    gap: 1rem;
    transition: var(--transition);
}

.security-card:hover {
    transform: translateY(-6px);
    border-color: rgba(255, 227, 0, 0.6);
}

.security-card--primary {
    grid-column: span 2;
    background: linear-gradient(160deg, rgba(0, 0, 125, 0.92), rgba(47, 58, 255, 0.68));
}

.security-card header {
    display: grid;
    gap: 0.5rem;
}

.security-card header span {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.6);
}

.security-card header h3 {
    margin: 0;
    font-size: 1.25rem;
}

.security-card p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
}

.security-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.6rem;
    color: var(--text-muted);
}

.security-card ul li {
    position: relative;
    padding-left: 1.4rem;
}

.security-card ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.45rem;
    width: 9px;
    height: 9px;
    border-radius: 45%;
    background: linear-gradient(135deg, #71feef, #ff3bc4);
    box-shadow: 0 0 14px rgba(113, 254, 239, 0.6);
}

.security-certifications {
    background: linear-gradient(170deg, rgba(0, 0, 120, 0.92), rgba(0, 0, 50, 0.94));
}

.security-certifications__container {
    display: grid;
    gap: 2.8rem;
    position: relative;
    z-index: 1;
}

.security-certifications__intro {
    display: grid;
    gap: 1.2rem;
    max-width: 640px;
}

.security-certifications__title {
    margin: 0;
    font-size: clamp(2.2rem, 4.5vw, 3rem);
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.security-certifications__intro p:last-child {
    color: rgba(255, 255, 255, 0.82);
}

.security-certifications__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.4rem;
}

.security-badge {
    padding: 1.6rem 1.5rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.36);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.86), rgba(47, 58, 255, 0.68));
    box-shadow: 0 20px 48px rgba(5, 16, 46, 0.38);
    display: grid;
    gap: 0.6rem;
}

.security-badge span {
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.7);
}

.security-badge p {
    margin: 0;
    color: var(--text-muted);
}

.security-cta {
    background: linear-gradient(160deg, rgba(0, 0, 100, 0.92), rgba(0, 0, 40, 0.96));
}

.security-cta__container {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    gap: 3rem;
    align-items: center;
    position: relative;
    z-index: 1;
}

.security-cta__content {
    display: grid;
    gap: 1.1rem;
}

.security-cta__content h2 {
    margin: 0;
    font-size: clamp(2.1rem, 4vw, 3rem);
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.security-cta__content p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
}

.security-cta__actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: flex-start;
}

.pricing-hero {
    background: linear-gradient(170deg, rgba(0, 0, 120, 0.92), rgba(0, 0, 40, 0.96));
}

.pricing-hero::after {
    background:
        radial-gradient(circle at 22% 28%, rgba(113, 254, 239, 0.24), transparent 70%),
        radial-gradient(circle at 78% 70%, rgba(255, 59, 196, 0.2), transparent 72%);
    opacity: 0.62;
}

.pricing-hero__container {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: 3rem;
    align-items: center;
    position: relative;
    z-index: 1;
}

.pricing-hero__intro {
    display: grid;
    gap: 1.5rem;
}

.pricing-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.55rem 1.35rem;
    border-radius: 999px;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.6);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.78);
    width: fit-content;
}

.pricing-hero__title {
    font-size: clamp(2.5rem, 4.8vw, 3.5rem);
    margin: 0;
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.pricing-hero__lead {
    font-size: 1.08rem;
    color: rgba(255, 255, 255, 0.85);
    max-width: 650px;
}

.pricing-hero__stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1.5rem;
}

.pricing-stat {
    padding: 1.4rem 1.3rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.88), rgba(47, 58, 255, 0.7));
    box-shadow: 0 18px 48px rgba(5, 16, 46, 0.45);
    display: grid;
    gap: 0.35rem;
}

.pricing-stat__number {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 2.2rem;
    background: linear-gradient(125deg, #71feef 0%, #ffffff 55%, #ff3bc4 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.pricing-stat__label {
    font-size: 0.92rem;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.72);
}

.pricing-hero__panel {
    padding: 2.4rem 2.2rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: linear-gradient(155deg, rgba(0, 0, 110, 0.9), rgba(0, 0, 55, 0.7));
    box-shadow: 0 28px 70px rgba(0, 0, 70, 0.52);
    display: grid;
    gap: 1.2rem;
}

.pricing-hero__panel h2 {
    margin: 0;
    font-size: 1.5rem;
}

.pricing-hero__panel ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.8rem;
    color: var(--text-muted);
}

.pricing-hero__panel li {
    position: relative;
    padding-left: 1.6rem;
}

.pricing-hero__panel li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.45rem;
    width: 10px;
    height: 10px;
    border-radius: 45%;
    background: linear-gradient(135deg, #71feef, #ffe300);
    box-shadow: 0 0 15px rgba(113, 254, 239, 0.65);
}

.pricing-hero__cta {
    justify-self: flex-start;
}

.pricing-plans {
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.9), rgba(0, 0, 60, 0.94));
}

.pricing-plans::after {
    background:
        radial-gradient(circle at 20% 35%, rgba(113, 254, 239, 0.2), transparent 70%),
        radial-gradient(circle at 75% 65%, rgba(255, 59, 196, 0.18), transparent 75%);
}

.pricing-plan__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.6rem;
    position: relative;
    z-index: 1;
}

.pricing-plan {
    padding: 2.1rem 2rem;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(113, 126, 255, 0.38);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.88), rgba(47, 58, 255, 0.72));
    box-shadow: 0 22px 58px rgba(5, 16, 46, 0.45);
    display: grid;
    gap: 1.2rem;
    transition: var(--transition);
}

.pricing-plan--focus {
    background: linear-gradient(160deg, rgba(0, 0, 125, 0.92), rgba(47, 58, 255, 0.7));
    border-color: rgba(113, 254, 239, 0.5);
}

.pricing-plan:hover {
    transform: translateY(-8px);
    border-color: rgba(255, 227, 0, 0.6);
}

.pricing-plan header {
    display: grid;
    gap: 0.4rem;
}

.pricing-plan header span {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.65);
}

.pricing-plan header h3 {
    margin: 0;
    font-size: 1.5rem;
}

.pricing-plan p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
}

.pricing-plan ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.7rem;
    color: var(--text-muted);
}

.pricing-plan li {
    position: relative;
    padding-left: 1.5rem;
}

.pricing-plan li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.45rem;
    width: 9px;
    height: 9px;
    border-radius: 45%;
    background: linear-gradient(135deg, #71feef, #ff3bc4);
    box-shadow: 0 0 14px rgba(113, 254, 239, 0.6);
}

.pricing-plan__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.pricing-plan__price {
    font-size: 1rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.7);
}

.pricing-comparison {
    background: linear-gradient(155deg, rgba(0, 0, 120, 0.9), rgba(0, 0, 55, 0.95));
}

.pricing-comparison__container {
    display: grid;
    gap: 2.6rem;
    position: relative;
    z-index: 1;
}

.pricing-comparison__intro {
    max-width: 760px;
}

.pricing-comparison__title {
    margin: 0;
    font-size: clamp(2.2rem, 4.4vw, 3rem);
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.pricing-table {
    display: grid;
    gap: 0.8rem;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.88), rgba(47, 58, 255, 0.68));
    box-shadow: 0 24px 60px rgba(5, 16, 46, 0.45);
    overflow: hidden;
    position: relative;
}

.pricing-table__header,
.pricing-table__row {
    display: grid;
    grid-template-columns: 1.4fr repeat(3, minmax(0, 1fr));
    padding: 1.1rem 1.4rem;
    align-items: center;
    gap: 1rem;
}

.pricing-table__header {
    background: rgba(0, 0, 60, 0.55);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.7);
}

.pricing-table__row:nth-child(even) {
    background: rgba(0, 0, 60, 0.35);
}

.pricing-table__row span {
    color: rgba(255, 255, 255, 0.85);
}

.pricing-testimonials {
    background: linear-gradient(160deg, rgba(0, 0, 110, 0.9), rgba(0, 0, 50, 0.96));
}

.pricing-testimonials__container {
    display: grid;
    gap: 2.8rem;
    position: relative;
    z-index: 1;
}

.pricing-testimonials__intro {
    max-width: 620px;
}

.pricing-testimonials__title {
    margin: 0;
    font-size: clamp(2.1rem, 4.2vw, 3rem);
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.pricing-testimonials__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.6rem;
}

.pricing-quote {
    padding: 2rem 1.9rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.35);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.88), rgba(47, 58, 255, 0.68));
    box-shadow: 0 20px 52px rgba(5, 16, 46, 0.4);
    display: grid;
    gap: 1.2rem;
}

.pricing-quote p {
    margin: 0;
    font-size: 1.05rem;
    color: rgba(255, 255, 255, 0.86);
}

.pricing-quote__meta {
    display: grid;
    gap: 0.3rem;
    color: rgba(255, 255, 255, 0.7);
}

.pricing-quote__name {
    font-weight: 600;
}

.pricing-faq {
    background: linear-gradient(165deg, rgba(0, 0, 110, 0.9), rgba(0, 0, 40, 0.96));
}

.pricing-faq__container {
    display: grid;
    gap: 2.6rem;
    position: relative;
    z-index: 1;
}

.pricing-faq__intro {
    max-width: 680px;
}

.pricing-faq__title {
    margin: 0;
    font-size: clamp(2.2rem, 4.4vw, 3rem);
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.pricing-faq__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.6rem;
}

.pricing-faq__item {
    padding: 1.8rem 1.7rem;
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.35);
    background: linear-gradient(150deg, rgba(0, 0, 110, 0.86), rgba(47, 58, 255, 0.65));
    box-shadow: 0 20px 52px rgba(5, 16, 46, 0.38);
    display: grid;
    gap: 0.7rem;
}

.pricing-faq__item h3 {
    margin: 0;
    font-size: 1.2rem;
}

.pricing-faq__item p {
    margin: 0;
    color: rgba(255, 255, 255, 0.8);
}

.pricing-inquiry {
    background: linear-gradient(170deg, rgba(0, 0, 120, 0.92), rgba(0, 0, 55, 0.96));
}

.pricing-inquiry__container {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: 3rem;
    position: relative;
    z-index: 1;
}

.pricing-inquiry__content {
    display: grid;
    gap: 1.2rem;
}

.pricing-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.76rem;
    color: rgba(255, 255, 255, 0.6);
}

.pricing-inquiry__content h2 {
    margin: 0;
    font-size: clamp(2.2rem, 4.6vw, 3.1rem);
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.pricing-inquiry__content p {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
}

.pricing-form {
    display: grid;
    gap: 1.6rem;
    padding: 2.6rem;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: linear-gradient(155deg, rgba(0, 0, 120, 0.92), rgba(47, 58, 255, 0.75));
    box-shadow: 0 28px 70px rgba(0, 0, 70, 0.52);
}

.pricing-form__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.2rem;
}

.pricing-form label {
    display: grid;
    gap: 0.45rem;
    font-size: 0.88rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.pricing-form input,
.pricing-form textarea,
.pricing-form select {
    width: 100%;
    padding: 0.9rem 1rem;
    border-radius: 12px;
    border: 1px solid rgba(113, 126, 255, 0.38);
    background: rgba(0, 0, 30, 0.78);
    color: #ffffff;
    font-size: 1rem;
    transition: var(--transition);
}

.pricing-form input:focus,
.pricing-form textarea:focus,
.pricing-form select:focus {
    outline: none;
    border-color: rgba(255, 227, 0, 0.55);
    box-shadow: 0 0 0 4px rgba(255, 59, 196, 0.2);
}

.pricing-form select {
    appearance: none;
    padding-right: 2.6rem;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.41.59 6 5.17 10.59.59 12 2l-6 6-6-6L1.41.59Z' fill='%23ffffff'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 12px 8px;
    cursor: pointer;
}

.pricing-form__services {
    display: grid;
    gap: 0.6rem;
    border: 1px solid rgba(113, 126, 255, 0.35);
    border-radius: var(--radius-md);
    padding: 1.4rem 1.6rem;
    background: rgba(0, 0, 40, 0.75);
}

.pricing-form__services legend {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: rgba(255, 255, 255, 0.72);
    margin-bottom: 0.8rem;
}

.pricing-form__services label {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    text-transform: none;
    letter-spacing: 0;
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.78);
}

.pricing-form__services input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #71feef;
}

.pricing-form__textarea {
    display: grid;
    gap: 0.5rem;
    font-size: 0.88rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.pricing-form__textarea textarea {
    resize: vertical;
    min-height: 140px;
}

.pricing-form__actions {
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
}

.pricing-form__notice {
    margin: 0;
    min-height: 1.1rem;
    font-size: 0.92rem;
    color: var(--accent-cyan);
}

.contact__container {
    display: grid;
    gap: 3rem;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    align-items: start;
}

.contact__content {
    display: grid;
    gap: 1.2rem;
}

.contact__info {
    display: grid;
    gap: 0.6rem;
    color: var(--text-muted);
}

.contact__info a {
    color: #ffffff;
    font-weight: 600;
}

.contact__form {
    background: linear-gradient(150deg, rgba(0, 0, 120, 0.92), rgba(47, 58, 255, 0.75));
    border-radius: var(--radius-md);
    padding: 2.6rem;
    border: 1px solid rgba(113, 126, 255, 0.4);
    display: grid;
    gap: 1.6rem;
    box-shadow: 0 22px 60px rgba(4, 14, 44, 0.45);
}

.form__row {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.form__group {
    display: grid;
    gap: 0.5rem;
}

.form__group label {
    font-weight: 600;
    font-size: 0.9rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.form__group input,
.form__group textarea,
.form__group select {
    width: 100%;
    padding: 0.9rem 1rem;
    border-radius: 12px;
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: rgba(0, 0, 30, 0.78);
    color: var(--text);
    font-size: 1rem;
    transition: var(--transition);
}

.form__group textarea {
    resize: vertical;
}

.form__group input:focus,
.form__group textarea:focus,
.form__group select:focus {
    outline: none;
    border-color: rgba(255, 227, 0, 0.55);
    box-shadow: 0 0 0 4px rgba(255, 59, 196, 0.2);
}

.form__group select {
    appearance: none;
    cursor: pointer;
    padding-right: 2.6rem;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.41.59 6 5.17 10.59.59 12 2l-6 6-6-6L1.41.59Z' fill='%23ffffff'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 12px 8px;
}

.form__group input[type="date"] {
    color-scheme: dark;
}

.form__submit {
    justify-self: flex-start;
}

.form__notice {
    font-size: 0.95rem;
    color: var(--accent-cyan);
    min-height: 1.2rem;
}

body.modal-open {
    overflow: hidden;
}

.modal {
    position: fixed;
    inset: 0;
    padding: 2.5rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.modal.is-open {
    opacity: 1;
    pointer-events: auto;
}

.modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(1, 4, 40, 0.82);
    backdrop-filter: blur(12px);
}

.modal__dialog {
    position: relative;
    z-index: 1;
    width: min(640px, 100%);
    border-radius: var(--radius-md);
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: linear-gradient(160deg, rgba(0, 0, 120, 0.94), rgba(47, 58, 255, 0.75));
    box-shadow: 0 32px 90px rgba(0, 0, 70, 0.62);
    padding: 2.4rem 2.6rem;
    display: grid;
    gap: 1.8rem;
}

.modal__close {
    position: absolute;
    top: 1.4rem;
    right: 1.4rem;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.5);
    display: grid;
    place-items: center;
    cursor: pointer;
    transition: var(--transition);
}

.modal__close span {
    display: block;
    width: 16px;
    height: 1.5px;
    background: #ffffff;
    transform-origin: center;
}

.modal__close span:first-child {
    transform: rotate(45deg);
}

.modal__close span:last-child {
    transform: rotate(-45deg);
}

.modal__close:hover {
    border-color: rgba(255, 227, 0, 0.6);
    background: rgba(0, 0, 90, 0.65);
}

.modal__header {
    display: grid;
    gap: 0.9rem;
}

.modal__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1.2rem;
    border-radius: 999px;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.55);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.78);
    width: fit-content;
}

.modal__header h3 {
    font-size: clamp(1.6rem, 3.2vw, 2.2rem);
    margin: 0;
    background: linear-gradient(125deg, #ffffff 0%, #71feef 45%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.modal__header p {
    color: rgba(255, 255, 255, 0.82);
    margin: 0;
}

.modal-form {
    display: grid;
    gap: 1.4rem;
}

.modal-form__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.1rem;
}

.modal-form label,
.modal-form__textarea {
    display: grid;
    gap: 0.45rem;
    font-size: 0.9rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.modal-form input,
.modal-form textarea,
.modal-form select {
    width: 100%;
    padding: 0.85rem 1rem;
    border-radius: 12px;
    border: 1px solid rgba(113, 126, 255, 0.4);
    background: rgba(0, 0, 30, 0.75);
    color: #ffffff;
    font-size: 1rem;
    transition: var(--transition);
}

.modal-form textarea {
    resize: vertical;
}

.modal-form input:focus,
.modal-form textarea:focus,
.modal-form select:focus {
    outline: none;
    border-color: rgba(255, 227, 0, 0.55);
    box-shadow: 0 0 0 4px rgba(255, 59, 196, 0.2);
}

.modal-form select {
    appearance: none;
    padding-right: 2.4rem;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.41.59 6 5.17 10.59.59 12 2l-6 6-6-6L1.41.59Z' fill='%23ffffff'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 12px 8px;
    cursor: pointer;
}

.modal-form__submit {
    justify-self: flex-start;
}

.modal__notice {
    margin: 0;
    min-height: 1.1rem;
    font-size: 0.92rem;
    color: var(--accent-cyan);
}

@media (max-width: 640px) {
    .modal__dialog {
        padding: 2rem 2.1rem 2.2rem;
    }

    .modal__close {
        top: 1.1rem;
        right: 1.1rem;
        width: 38px;
        height: 38px;
    }
}

@media (max-width: 520px) {
    .modal {
        padding: 2rem 1rem;
    }

    .modal-form__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1080px) {
    .security-hero__container,
    .security-cta__container,
    .pricing-hero__container,
    .pricing-inquiry__container {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }

    .security-hero__panel,
    .pricing-hero__panel,
    .pricing-form {
        max-width: 560px;
    }

    .security-posture__container {
        grid-template-columns: 1fr;
    }

    .security-card--primary {
        grid-column: span 1;
    }
}

@media (max-width: 720px) {
    .security-hero__stats {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .security-timeline::before {
        left: 0.8rem;
    }

    .security-timeline__node {
        padding: 1.3rem 1.4rem 1.3rem 3rem;
    }

    .security-timeline__index {
        left: 0.5rem;
    }

    .security-grid__layout {
        grid-template-columns: 1fr;
    }

    .security-certifications__grid {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    }

    .security-cta__actions {
        flex-direction: column;
        align-items: flex-start;
    }

    .pricing-hero__stats {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .pricing-plan__grid,
    .pricing-testimonials__grid,
    .pricing-faq__grid {
        grid-template-columns: 1fr;
    }

    .pricing-table {
        overflow-x: auto;
    }

    .pricing-table__header,
    .pricing-table__row {
        min-width: 560px;
        grid-template-columns: 1.2fr repeat(3, minmax(0, 1fr));
    }

    .pricing-quote {
        padding: 1.8rem 1.7rem;
    }

    .pricing-form {
        padding: 2.2rem;
    }
}

@media (max-width: 520px) {
    .security-hero__panel {
        padding: 2rem 1.8rem;
    }

    .security-hero__panel ul li {
        padding-left: 1.4rem;
    }

    .security-hero__stats {
        grid-template-columns: 1fr;
    }

    .security-card {
        padding: 1.8rem 1.7rem;
    }

    .pricing-hero__panel {
        padding: 2rem 1.7rem;
    }

    .pricing-form {
        padding: 2rem 1.8rem;
    }

    .pricing-form__grid {
        grid-template-columns: 1fr;
    }
}

.footer {
    position: relative;
    padding: 4rem 0 2.5rem;
    background: linear-gradient(140deg, rgba(0, 0, 110, 0.92), rgba(0, 0, 60, 0.95));
    border-top: 1px solid rgba(113, 126, 255, 0.35);
    box-shadow: 0 -24px 60px rgba(0, 0, 70, 0.48);
    overflow: hidden;
}

.footer::before {
    content: '';
    position: absolute;
    inset: -35% 40% 50% -20%;
    background: radial-gradient(circle, rgba(113, 254, 239, 0.28), transparent 65%);
    opacity: 0.6;
    pointer-events: none;
}

.footer::after {
    content: '';
    position: absolute;
    inset: 40% -25% -40% 30%;
    background: radial-gradient(circle, rgba(255, 59, 196, 0.22), transparent 70%);
    opacity: 0.5;
    pointer-events: none;
}

.footer__container {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.8fr);
    gap: 3rem;
    align-items: start;
}

.footer__brand {
    display: grid;
    gap: 1.3rem;
    color: rgba(255, 255, 255, 0.8);
    max-width: 360px;
}

.footer__logo {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}

.footer__logo-img {
    width: 46px;
    height: 46px;
    object-fit: contain;
    filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.45));
}

.footer__logo-text {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 1.35rem;
    letter-spacing: 0.08em;
    background: linear-gradient(120deg, #ffffff 20%, #71feef 55%, #ff3bc4 95%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.footer__social {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.65rem 1.2rem;
    border-radius: 999px;
    border: 1px solid rgba(113, 254, 239, 0.45);
    background: rgba(0, 0, 80, 0.55);
    color: rgba(255, 255, 255, 0.85);
    font-weight: 500;
    font-size: 0.9rem;
    transition: var(--transition);
    width: fit-content;
}

.footer__social svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
}

.footer__social:hover {
    border-color: rgba(255, 227, 0, 0.55);
    background: rgba(0, 0, 90, 0.6);
    color: #ffe300;
}

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

.footer__column {
    display: grid;
    gap: 0.75rem;
    color: rgba(255, 255, 255, 0.72);
}

.footer__column-title {
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.58);
    margin: 0 0 0.5rem;
}

.footer__link {
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.7);
    transition: var(--transition);
}

.footer__link:hover {
    color: var(--accent-cyan);
    transform: translateX(4px);
}

.footer__note {
    position: relative;
    z-index: 1;
    margin-top: 3rem;
    text-align: center;
    font-size: 0.9rem;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.6);
}

@media (max-width: 900px) {
    .nav__menu {
        display: none;
    }

    .nav__container {
        position: relative;
    }

    main {
        padding-top: 84px;
    }

    .hero {
        padding: 5.5rem 0 4.5rem;
    }

    .section {
        padding: 5rem 0;
    }

    .nav__toggle {
        display: inline-flex;
    }

    .nav__menu.is-open {
        display: flex;
        flex-direction: column;
        position: absolute;
        top: 100%;
        right: 0;
        background: rgba(0, 0, 70, 0.95);
        border: 1px solid rgba(113, 126, 255, 0.45);
        box-shadow: 0 18px 40px rgba(0, 0, 70, 0.55);
        border-radius: var(--radius-md);
        padding: 1.2rem;
        gap: 1.1rem;
        width: min(240px, 75vw);
        backdrop-filter: blur(12px);
    }

    .nav__menu.is-open .nav__link--cta {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 600px) {
    .container {
        width: min(92vw, 520px);
    }

    .hero__actions {
        flex-direction: column;
    }

    .contact__form {
        padding: 2rem;
    }

    .footer__container {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }

    .footer__brand {
        max-width: 100%;
    }

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

@media (max-width: 480px) {
    .footer {
        padding: 3.2rem 0 2rem;
    }

    .footer__grid {
        grid-template-columns: 1fr;
    }

    .footer__column {
        gap: 0.6rem;
    }
}

@media (max-width: 780px) {
    .legal__container {
        gap: 2rem;
    }

    .legal__card {
        padding: 1.8rem 1.7rem;
    }
}

@media (max-width: 520px) {
    .legal__badge {
        font-size: 0.7rem;
        padding: 0.45rem 1.1rem;
    }

    .legal__title {
        font-size: clamp(2rem, 8vw, 2.6rem);
    }
}

@keyframes heroFlow {
    0% {
        transform: translate3d(-2%, -1%, 0) scale(1.02);
    }
    50% {
        transform: translate3d(1%, 2%, 0) scale(1.03);
    }
    100% {
        transform: translate3d(-1%, 1%, 0) scale(1.01);
    }
}

