* { box-sizing: border-box; }

html,
body {
    margin: 0;
    min-height: 100%;
    background: #030512;
    color: #fff;
    font-family: Inter, Arial, sans-serif;
    overflow-x: hidden;
}

html.modal-open,
html.modal-open body {
    overflow: hidden;
}

.template-body {
    min-height: 100vh;
    padding: 0;
    overflow-x: hidden;
}

.launch-modal {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: grid;
    place-items: center;
    background: rgba(2, 3, 12, 0.78);
    opacity: 0;
    padding: 1.2rem;
    pointer-events: none;
    transition: opacity 180ms ease;
}

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

.launch-modal-card {
    position: relative;
    overflow: hidden;
    width: min(820px, 94vw);
    max-height: calc(100vh - 2.4rem);
    border: 1px solid rgba(56, 215, 255, 0.28);
    border-radius: 18px;
    background: rgba(3, 5, 18, 0.96);
    box-shadow: 0 34px 120px rgba(0, 0, 0, 0.62), 0 0 70px rgba(176, 38, 255, 0.18);
    transform: translateY(14px) scale(0.98);
    transition: transform 180ms ease;
}

.launch-modal.is-open .launch-modal-card {
    transform: translateY(0) scale(1);
}

.launch-modal-card picture {
    display: block;
    background: #030512;
}

.launch-modal-card img {
    display: block;
    width: auto;
    max-width: 100%;
    max-height: min(74vh, 760px);
    object-fit: contain;
    object-position: center;
    margin: 0 auto;
}

.launch-modal-copy {
    padding: 1.15rem 1.45rem 1.35rem;
    background: linear-gradient(135deg, rgba(3, 5, 18, 0.98), rgba(10, 12, 35, 0.98));
}

.launch-modal-copy h2 {
    margin: 0;
    font-size: clamp(2rem, 4.5vw, 3.8rem);
    background: linear-gradient(135deg, #fff 0%, #fff 34%, #de42ff 58%, #12c7ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.launch-close {
    position: absolute;
    top: 0.9rem;
    right: 0.9rem;
    z-index: 2;
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    background: rgba(3, 5, 18, 0.74);
    color: #fff;
    cursor: pointer;
    font: inherit;
    font-size: 1.8rem;
    line-height: 1;
}

.launch-info {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    padding: 4.2rem 0 3.2rem;
}

.launch-feature-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1.4rem;
}

.launch-feature-grid article,
.early-access {
    border: 1px solid rgba(56, 215, 255, 0.16);
    border-radius: 12px;
    background: linear-gradient(160deg, rgba(8, 12, 32, 0.92), rgba(6, 8, 25, 0.72));
    padding: 1.05rem;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
}

.launch-feature-grid strong,
.launch-feature-grid span,
.early-access span,
.early-access a {
    display: block;
}

.launch-feature-grid strong {
    color: #fff;
    line-height: 1.25;
}

.launch-feature-grid span {
    margin-top: 0.6rem;
    color: #aebbd4;
    line-height: 1.5;
}

.early-access {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-top: 0.9rem;
}

.early-access span {
    color: #b9c7df;
}

.early-access a {
    color: #38d7ff;
    font-weight: 900;
    text-decoration: none;
}

.hero-preview {
    position: relative;
    width: min(1536px, 100vw);
    aspect-ratio: 1536 / 1024;
    margin-inline: auto;
    overflow: hidden;
    background:
        radial-gradient(circle at 78% 30%, rgba(25, 161, 255, 0.24), transparent 32%),
        radial-gradient(circle at 88% 62%, rgba(222, 66, 255, 0.12), transparent 28%),
        #030512;
}

.hero-bg {
    position: absolute;
    right: 1.2%;
    top: 5.8%;
    z-index: 1;
    display: block;
    width: 64.5%;
    height: 63.5%;
    object-fit: contain;
    object-position: center;
    opacity: 0.94;
    filter: saturate(1.08) contrast(1.06);
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 10%, #000 100%), linear-gradient(180deg, #000 0%, #000 84%, transparent 100%);
    -webkit-mask-composite: source-in;
    mask-image: linear-gradient(90deg, transparent 0%, #000 10%, #000 100%), linear-gradient(180deg, #000 0%, #000 84%, transparent 100%);
    mask-composite: intersect;
    user-select: none;
    -webkit-user-drag: none;
}

.hero-preview::before,
.hero-preview::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    pointer-events: none;
}

.hero-preview::before {
    top: 0;
    z-index: 3;
    height: 92px;
    background: linear-gradient(180deg, rgba(3, 5, 18, 0.98), rgba(3, 5, 18, 0.72) 64%, transparent);
}

.hero-preview::after {
    bottom: 0;
    z-index: 3;
    height: 31%;
    background: linear-gradient(180deg, transparent, rgba(3, 5, 18, 0.9) 44%, #030512 100%);
}

.hero-scrim {
    position: absolute;
    inset: 0;
    z-index: 2;
    background:
        linear-gradient(90deg, rgba(3, 5, 18, 1) 0%, rgba(3, 5, 18, 0.96) 28%, rgba(3, 5, 18, 0.34) 48%, transparent 72%),
        linear-gradient(180deg, rgba(3, 5, 18, 0.62) 0%, transparent 20%, transparent 58%, rgba(3, 5, 18, 0.9) 100%);
}

.hero-nav {
    position: absolute;
    inset: 1.3% 3.8% auto;
    z-index: 7;
    display: grid;
    grid-template-columns: 380px minmax(300px, 1fr) auto;
    align-items: center;
    gap: 1.4rem;
}

.hero-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.85rem;
    color: #fff;
    text-decoration: none;
}

.hero-brand-mark {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
}

.hero-brand-mark img {
    display: block;
    width: 58px;
    height: auto;
    filter: drop-shadow(0 0 18px rgba(222, 66, 255, 0.42)) drop-shadow(0 0 14px rgba(56, 215, 255, 0.26));
}

.hero-brand strong,
.hero-brand small {
    display: block;
    line-height: 1;
}

.hero-brand strong {
    font-size: 2rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.hero-brand small {
    margin-top: 0.45rem;
    color: #38d7ff;
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.hero-nav nav {
    display: flex;
    justify-content: center;
    gap: clamp(1rem, 1.45vw, 1.7rem);
    white-space: nowrap;
}

.hero-nav nav a {
    position: relative;
    color: #fff;
    text-decoration: none;
    font-weight: 700;
}

.hero-nav nav a:first-child { color: #de42ff; }

.hero-nav nav a:first-child::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -0.9rem;
    height: 2px;
    background: linear-gradient(90deg, #de42ff, #38d7ff);
}

.hero-nav-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.hero-phone,
.hero-quote,
.hero-primary,
.hero-secondary,
.tracking-panel button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    border-radius: 10px;
    padding: 0.85rem 1.35rem;
    color: #fff;
    text-decoration: none;
    font-weight: 900;
}

.hero-phone,
.hero-secondary {
    border: 1px solid rgba(222, 66, 255, 0.42);
    background: rgba(5, 7, 22, 0.72);
    color: #c8d4ff;
}

.hero-quote,
.hero-primary,
.tracking-panel button {
    border: 0;
    background: linear-gradient(135deg, #de20ff, #12c7ff);
    box-shadow: 0 18px 45px rgba(18, 199, 255, 0.16), 0 14px 36px rgba(222, 32, 255, 0.18);
}

.hero-copy-real {
    position: absolute;
    left: 4.1%;
    top: 19.2%;
    z-index: 6;
    width: min(575px, 40%);
}

.hero-pill-real {
    display: inline-flex;
    margin: 0 0 2rem;
    border: 1px solid rgba(222, 66, 255, 0.5);
    border-radius: 999px;
    background: rgba(5, 7, 22, 0.68);
    color: #c9b8ff;
    padding: 0.65rem 1.15rem;
}

.hero-copy-real h1 {
    margin: 0;
    color: #fff;
    font-size: clamp(2.8rem, 4.7vw, 5rem);
    line-height: 1.08;
}

.hero-copy-real h1 {
    color: #fff;
}

.hero-copy-real h1 span {
    background: linear-gradient(135deg, #de42ff 0%, #7c4dff 45%, #12c7ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    white-space: nowrap;
}

.hero-copy-real p:not(.hero-pill-real) {
    max-width: 520px;
    color: #c8cce0;
    font-size: 1.12rem;
    line-height: 1.7;
}

.hero-buttons {
    display: flex;
    gap: 1.1rem;
    margin-top: 1.75rem;
}

.hero-service-cards {
    position: absolute;
    left: 4.1%;
    bottom: 0.8%;
    z-index: 7;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    width: min(760px, 51%);
}

.hero-service-cards article {
    min-height: 188px;
    border: 1px solid rgba(56, 215, 255, 0.14);
    border-radius: 12px;
    background: linear-gradient(160deg, rgba(8, 12, 32, 0.94), rgba(6, 8, 25, 0.76));
    padding: 1.25rem;
    box-shadow: 0 22px 60px rgba(0, 0, 0, 0.32);
}

.hero-service-cards strong,
.hero-service-cards p,
.hero-service-cards a,
.icon-line {
    display: block;
}

.icon-line {
    color: #de42ff;
    font-size: 2.35rem;
    line-height: 1;
    text-shadow: 0 0 18px rgba(222, 66, 255, 0.8);
}

.icon-line.cyan {
    color: #38d7ff;
    text-shadow: 0 0 18px rgba(56, 215, 255, 0.8);
}

.hero-service-cards strong {
    margin-top: 0.95rem;
    color: #fff;
    font-size: 1.05rem;
}

.hero-service-cards p {
    color: #bdc7dc;
    line-height: 1.45;
    margin-bottom: 0.65rem;
}

.hero-service-cards a {
    color: #38d7ff;
    text-decoration: none;
    font-size: 1.4rem;
}

.tracking-panel {
    position: absolute;
    right: 5.9%;
    bottom: 0.8%;
    z-index: 7;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.2rem;
    width: min(540px, 37%);
    border: 1px solid rgba(56, 215, 255, 0.14);
    border-radius: 16px;
    background: rgba(8, 12, 32, 0.72);
    padding: 1.5rem;
    backdrop-filter: blur(8px);
}

.tracking-panel div,
.tracking-panel label {
    grid-column: 1 / -1;
}

.tracking-panel strong,
.tracking-panel span {
    display: block;
}

.tracking-panel strong {
    color: #fff;
    font-size: 1.3rem;
}

.tracking-panel span {
    color: #bdc7dc;
}

.tracking-panel input {
    width: 100%;
    min-height: 54px;
    margin-top: 0.6rem;
    border: 1px solid rgba(56, 215, 255, 0.18);
    border-radius: 10px;
    background: rgba(3, 5, 18, 0.68);
    color: #fff;
    padding: 0 1rem;
    font: inherit;
}

.globe-overlay {
    position: absolute;
    left: 39.1%;
    top: 8.4%;
    width: 53.6%;
    height: 57.2%;
    overflow: hidden;
    border-radius: 50% / 48%;
    mix-blend-mode: screen;
    pointer-events: none;
    z-index: 4;
}

.globe-rim,
.globe-sheen,
.globe-scan,
.globe-fog,
.overlay-svg {
    position: absolute;
    inset: 0;
}

.globe-rim {
    border: 1px solid rgba(85, 205, 255, 0.22);
    border-radius: 50% / 48%;
    box-shadow:
        0 0 22px rgba(61, 194, 255, 0.35),
        0 0 65px rgba(213, 47, 255, 0.22),
        inset 0 0 22px rgba(255, 255, 255, 0.08);
}

.globe-sheen {
    border-radius: 50% / 48%;
    background:
        conic-gradient(from 140deg at 50% 50%,
            transparent 0deg 24deg,
            rgba(45, 218, 255, 0.05) 38deg 62deg,
            transparent 78deg 160deg,
            rgba(226, 59, 255, 0.045) 188deg 212deg,
            transparent 240deg 360deg),
        radial-gradient(circle at 22% 23%, rgba(255, 255, 255, 0.09), transparent 14%),
        radial-gradient(circle at 68% 18%, rgba(49, 193, 255, 0.07), transparent 12%),
        radial-gradient(circle at 52% 54%, rgba(215, 70, 255, 0.05), transparent 28%);
    animation: spinSheen 36s linear infinite;
}

.globe-scan {
    border-radius: 50% / 48%;
    background: repeating-linear-gradient(
        180deg,
        rgba(79, 115, 255, 0.07) 0,
        rgba(79, 115, 255, 0.07) 1px,
        transparent 1px,
        transparent 22px
    );
    opacity: 0.14;
    animation: scanMove 9s linear infinite;
}

.globe-fog {
    border-radius: 50% / 48%;
    background:
        radial-gradient(circle at 50% 58%, rgba(146, 61, 255, 0.13), transparent 42%),
        radial-gradient(circle at 56% 40%, rgba(0, 217, 255, 0.08), transparent 36%),
        radial-gradient(circle at 84% 45%, rgba(0, 154, 255, 0.05), transparent 18%);
    filter: blur(16px);
    animation: fogPulse 10s ease-in-out infinite;
}

.overlay-svg { overflow: hidden; }

.route-glow {
    fill: none;
    stroke: rgba(255, 255, 255, 0.055);
    stroke-width: 7;
    filter: blur(6px);
}

.route {
    fill: none;
    stroke-linecap: round;
    stroke-width: 2.4;
    stroke-dasharray: 10 18;
    opacity: 0.9;
    will-change: stroke-dashoffset, opacity;
    animation: dashFlow 5.6s linear infinite;
}

.route.cyan {
    stroke: #38d7ff;
    filter: drop-shadow(0 0 4px rgba(56, 215, 255, 0.88)) drop-shadow(0 0 10px rgba(56, 215, 255, 0.34));
}

.route.magenta {
    stroke: #de42ff;
    filter: drop-shadow(0 0 4px rgba(222, 66, 255, 0.88)) drop-shadow(0 0 10px rgba(222, 66, 255, 0.34));
    animation-duration: 6.1s;
}

.route.violet {
    stroke: #8f63ff;
    filter: drop-shadow(0 0 4px rgba(143, 99, 255, 0.88)) drop-shadow(0 0 10px rgba(143, 99, 255, 0.32));
    animation-duration: 6.6s;
}

.route.blue {
    stroke: #4fa9ff;
    filter: drop-shadow(0 0 4px rgba(79, 169, 255, 0.88)) drop-shadow(0 0 10px rgba(79, 169, 255, 0.32));
    animation-duration: 7s;
}

.route.warm {
    stroke: #ff8bdd;
    filter: drop-shadow(0 0 4px rgba(255, 139, 221, 0.88)) drop-shadow(0 0 10px rgba(255, 139, 221, 0.32));
    animation-duration: 5.9s;
}

.route.long {
    stroke-width: 2.1;
    stroke-dasharray: 12 20;
}

.node {
    fill: #fff;
    stroke: rgba(255, 255, 255, 0.35);
    stroke-width: 0.9;
    filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.88)) drop-shadow(0 0 20px rgba(222, 66, 255, 0.58));
    transform-box: fill-box;
    transform-origin: center;
    animation: pulseNode 3.4s ease-in-out infinite;
}

.node.major { r: 5.8; }
.node.minor { r: 4.2; }

.packet {
    fill: #fff;
    filter: drop-shadow(0 0 8px rgba(56, 215, 255, 0.9)) drop-shadow(0 0 18px rgba(222, 66, 255, 0.52));
    will-change: transform, opacity;
}

.spark {
    fill: rgba(255, 255, 255, 0.92);
    filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.75));
    transform-box: fill-box;
    transform-origin: center;
    animation: twinkle 3.8s ease-in-out infinite;
}

@keyframes dashFlow {
    from { stroke-dashoffset: 0; opacity: 0.55; }
    50% { opacity: 1; }
    to { stroke-dashoffset: -130; opacity: 0.55; }
}

@keyframes pulseNode {
    0%, 100% { transform: scale(1); opacity: 0.76; }
    50% { transform: scale(1.24); opacity: 1; }
}

@keyframes twinkle {
    0%, 100% { opacity: 0.2; transform: scale(0.8); }
    50% { opacity: 1; transform: scale(1.18); }
}

@keyframes spinSheen {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes scanMove {
    from { transform: translateY(-24px); }
    to { transform: translateY(24px); }
}

@keyframes fogPulse {
    0%, 100% { opacity: 0.34; transform: scale(1); }
    50% { opacity: 0.62; transform: scale(1.025); }
}

@media (prefers-reduced-motion: reduce) {
    .route,
    .node,
    .spark,
    .globe-sheen,
    .globe-scan,
    .globe-fog {
        animation: none;
    }
}

@media (max-width: 900px) {
    .hero-preview {
        width: 100vw;
        min-height: 900px;
        background:
            radial-gradient(circle at 88% 30%, rgba(25, 161, 255, 0.15), transparent 28%),
            radial-gradient(circle at 10% 78%, rgba(222, 66, 255, 0.08), transparent 34%),
            #030512;
    }

    .hero-bg {
        top: 9.6rem;
        right: -42%;
        width: 108%;
        height: 31rem;
        opacity: 0.34;
        filter: saturate(1.08) contrast(1.08);
        -webkit-mask-image:
            radial-gradient(ellipse at 58% 42%, #000 0%, rgba(0, 0, 0, 0.8) 38%, transparent 68%),
            linear-gradient(180deg, transparent 0%, #000 20%, #000 60%, transparent 100%);
        -webkit-mask-composite: source-in;
        mask-image:
            radial-gradient(ellipse at 58% 42%, #000 0%, rgba(0, 0, 0, 0.8) 38%, transparent 68%),
            linear-gradient(180deg, transparent 0%, #000 20%, #000 60%, transparent 100%);
        mask-composite: intersect;
    }

    .hero-scrim {
        background:
            linear-gradient(90deg, rgba(3, 5, 18, 0.99) 0%, rgba(3, 5, 18, 0.92) 58%, rgba(3, 5, 18, 0.64) 100%),
            linear-gradient(180deg, rgba(3, 5, 18, 0.96) 0%, rgba(3, 5, 18, 0.9) 42%, rgba(3, 5, 18, 0.98) 100%);
    }

    .hero-nav {
        inset: 1rem 1rem auto;
        grid-template-columns: 1fr;
        gap: 0.85rem;
        padding: 0;
    }

    .hero-nav nav,
    .hero-nav-actions {
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    .hero-copy-real,
    .hero-service-cards,
    .tracking-panel {
        width: calc(100% - 2rem);
    }

    .hero-copy-real {
        left: 1rem;
        top: 14.2rem;
        z-index: 8;
    }

    .hero-pill-real {
        margin-bottom: 1.35rem;
    }

    .hero-copy-real h1 {
        font-size: clamp(2rem, 10vw, 3.4rem);
    }

    .hero-copy-real p:not(.hero-pill-real) {
        font-size: 0.98rem;
    }

    .hero-service-cards {
        grid-template-columns: 1fr;
        left: 1rem;
        bottom: 1rem;
        display: none;
    }

    .tracking-panel {
        grid-template-columns: 1fr;
        display: none;
    }

    .globe-overlay {
        left: 39%;
        top: 10.3rem;
        display: block;
        width: 62%;
        height: 25rem;
        opacity: 0.28;
        mix-blend-mode: screen;
    }

    .route {
        stroke-width: 1.35;
        opacity: 0.48;
        animation-duration: 8s;
    }

    .route-glow,
    .spark,
    .node {
        opacity: 0.38;
    }

    .packet {
        opacity: 0.55;
    }
}

.site-links,
.section,
.module-strip,
.launch-info,
.coming-soon,
.site-footer {
    width: min(1180px, calc(100% - 32px));
    margin-inline: auto;
}

.coming-soon {
    display: grid;
    grid-template-columns: minmax(260px, 0.82fr) minmax(320px, 0.9fr) auto;
    align-items: center;
    gap: 1.25rem;
    min-height: 520px;
    margin-top: 0;
    border-top: 1px solid rgba(56, 215, 255, 0.16);
    border-bottom: 1px solid rgba(168, 85, 247, 0.18);
    background:
        radial-gradient(circle at 82% 26%, rgba(56, 215, 255, 0.14), transparent 30%),
        radial-gradient(circle at 18% 80%, rgba(222, 66, 255, 0.12), transparent 34%);
    padding: 4rem 0;
}

.coming-copy {
    min-width: 0;
}

.coming-soon h2 {
    font-size: clamp(3rem, 6vw, 6.2rem);
    line-height: 0.95;
    background: linear-gradient(135deg, #fff 0%, #fff 34%, #de42ff 60%, #12c7ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.coming-soon p:not(.eyebrow) {
    max-width: 520px;
    color: #b9c7df;
    font-size: 1.1rem;
}

.coming-soon a:not(.btn) {
    color: #38d7ff;
    font-weight: 900;
    text-decoration: none;
}

.commander-art {
    position: relative;
    margin: 0;
    overflow: hidden;
    border: 1px solid rgba(56, 215, 255, 0.22);
    border-radius: 16px;
    background: rgba(3, 5, 18, 0.82);
    box-shadow: 0 28px 90px rgba(0, 0, 0, 0.42), 0 0 52px rgba(56, 215, 255, 0.11);
}

.commander-art img {
    display: block;
    width: 100%;
    max-height: 660px;
    object-fit: cover;
    object-position: center;
}

.site-links {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.35rem;
    margin-top: -1px;
    border: 1px solid rgba(168, 85, 247, 0.2);
    border-radius: 0 0 14px 14px;
    background: rgba(3, 5, 18, 0.82);
    padding: 0.7rem;
    backdrop-filter: blur(16px);
}

.site-links a {
    border: 1px solid rgba(56, 215, 255, 0.18);
    border-radius: 999px;
    color: #dbeafe;
    padding: 0.48rem 0.8rem;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 800;
}

.site-links a:hover {
    border-color: rgba(222, 66, 255, 0.55);
    color: #fff;
}

.module-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    padding: 2.2rem 0 0.5rem;
}

.module-strip span {
    border: 1px solid rgba(56, 215, 255, 0.2);
    border-radius: 999px;
    background: rgba(8, 13, 34, 0.76);
    color: #b9d7f5;
    padding: 0.58rem 0.78rem;
    font-size: 0.88rem;
}

.section {
    padding: 4rem 0;
}

.section-head,
.section-copy {
    max-width: 820px;
}

.compact-head {
    max-width: 720px;
}

.eyebrow {
    margin: 0 0 0.75rem;
    color: #de42ff;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

h1,
h2 {
    margin: 0;
    color: #fff;
    letter-spacing: 0;
}

h1 {
    font-size: clamp(2.2rem, 5vw, 4.2rem);
    line-height: 1.02;
}

h2 {
    font-size: clamp(1.7rem, 3vw, 2.8rem);
    line-height: 1.08;
}

.section p {
    color: #aebbd4;
}

.outcome-grid,
.process-grid,
.capability-grid,
.module-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1.35rem;
}

.capability-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.module-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.outcome-grid article,
.process-grid article,
.capability-grid article,
.module-grid article,
.check-list p {
    border: 1px solid rgba(168, 85, 247, 0.18);
    border-radius: 12px;
    background: rgba(6, 10, 28, 0.82);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26);
    padding: 1rem;
}

.outcome-grid span,
.process-grid span {
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 28px;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(176, 38, 255, 0.32), rgba(56, 189, 248, 0.22));
    color: #fff;
    font-weight: 900;
}

.section strong,
.module-grid strong {
    color: #fff;
}

.module-grid span {
    display: block;
    margin-top: 0.45rem;
    color: #9fb3d1;
}

.two-col {
    display: grid;
    grid-template-columns: minmax(320px, 0.82fr) minmax(0, 1.18fr);
    gap: 1.4rem;
    align-items: center;
}

.two-col.reverse {
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
}

.check-list {
    display: grid;
    gap: 0.7rem;
    margin-top: 1rem;
}

.product-shot,
.wide-shot {
    margin: 0;
    overflow: hidden;
    border: 1px solid rgba(56, 215, 255, 0.18);
    border-radius: 12px;
    background: rgba(2, 3, 12, 0.84);
    box-shadow: 0 28px 80px rgba(0, 0, 0, 0.34);
}

.product-shot img,
.wide-shot img {
    display: block;
    width: 100%;
}

.wide-shot {
    margin-top: 1rem;
}

.muted-section {
    border-top: 1px solid rgba(168, 85, 247, 0.14);
    border-bottom: 1px solid rgba(56, 215, 255, 0.1);
}

.final-cta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border: 1px solid rgba(168, 85, 247, 0.25);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(176, 38, 255, 0.18), rgba(3, 8, 24, 0.94));
    margin-bottom: 2rem;
    padding: 1.45rem;
}

.site-footer {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.8rem 0 3rem;
    color: #9fb3d1;
}

.site-footer strong {
    color: #fff;
}

@media (max-width: 1040px) {
    .launch-feature-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .coming-soon {
        grid-template-columns: 1fr;
    }

    .commander-art {
        max-width: 620px;
    }

    .two-col,
    .two-col.reverse {
        grid-template-columns: 1fr;
    }

    .outcome-grid,
    .process-grid,
    .capability-grid,
    .module-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .launch-modal {
        align-items: start;
        padding: 1rem;
        padding-top: 8vh;
    }

    .launch-modal-card {
        width: min(430px, 94vw);
        max-height: 84vh;
        border-radius: 16px;
    }

    .launch-modal-card img {
        max-height: 64vh;
    }

    .launch-modal-copy {
        padding: 1.2rem;
    }

    .outcome-grid,
    .process-grid,
    .capability-grid,
    .module-grid,
    .launch-feature-grid {
        grid-template-columns: 1fr;
    }

    .early-access {
        align-items: flex-start;
        flex-direction: column;
    }

    .final-cta,
    .coming-soon,
    .site-footer {
        align-items: stretch;
        flex-direction: column;
    }

    .commander-art img {
        max-height: none;
    }
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    border: 1px solid rgba(168, 85, 247, 0.5);
    border-radius: 999px;
    padding: 0.72rem 1rem;
    color: #fff;
    font: inherit;
    font-weight: 800;
    cursor: pointer;
}

.btn.primary {
    background: linear-gradient(135deg, #b026ff, #38bdf8);
}

.btn.secondary {
    background: rgba(255, 255, 255, 0.05);
}

.brand-mark {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(217, 70, 239, 0.62);
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(168, 85, 247, 0.36), rgba(56, 189, 248, 0.14));
    font-weight: 900;
}

.admin-body {
    min-height: 100vh;
    background:
        radial-gradient(circle at 20% 0%, rgba(168, 85, 247, 0.24), transparent 32%),
        #030512;
}

.admin-login {
    display: grid;
    min-height: 100vh;
    place-items: center;
    padding: 1rem;
}

.admin-login-card,
.admin-panel,
.admin-kpis article {
    border: 1px solid rgba(168, 85, 247, 0.25);
    border-radius: 12px;
    background: rgba(7, 5, 21, 0.9);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.36);
}

.admin-login-card {
    display: grid;
    gap: 0.9rem;
    width: min(420px, 100%);
    padding: 1.4rem;
}

.admin-login-card h1,
.admin-panel h2,
.admin-header strong { margin: 0; color: #fff; }
.admin-login-card p,
.admin-login-card label,
.admin-header span,
.admin-panel p,
.admin-kpis span { color: #9fb3d1; }
.admin-error { color: #fca5a5; }

.admin-login-card input {
    width: 100%;
    margin-top: 0.35rem;
    border: 1px solid rgba(168, 85, 247, 0.38);
    border-radius: 8px;
    background: #070b18;
    color: #fff;
    padding: 0.75rem 0.85rem;
    font: inherit;
}

.admin-header,
.admin-shell {
    width: min(1180px, calc(100% - 32px));
    margin-inline: auto;
}

.admin-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1.2rem 0;
}

.admin-header div { display: grid; }
.admin-shell { display: grid; gap: 1rem; padding-bottom: 3rem; }

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

.admin-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-kpis article,
.admin-panel { padding: 1rem; }
.admin-kpis strong { display: block; color: #fff; font-size: 2rem; }
.admin-panel.wide { grid-column: 1 / -1; }

.admin-row,
.admin-table-head,
.admin-table div {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 80px;
    gap: 0.75rem;
    padding: 0.55rem 0;
    border-top: 1px solid rgba(168, 85, 247, 0.16);
}

.admin-row-3 {
    grid-template-columns: minmax(0, 1fr) 82px 70px;
}

.admin-row span,
.admin-table span {
    min-width: 0;
    overflow: hidden;
    color: #d8e6ff;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-row strong { color: #fff; text-align: right; }
.admin-table { overflow-x: auto; }

.admin-table-head,
.admin-table div {
    grid-template-columns: 220px 160px 140px minmax(260px, 1fr);
    min-width: 840px;
}

.admin-table-head.admin-ip-head,
.admin-table .admin-ip-row {
    grid-template-columns: 190px 190px 80px minmax(230px, 1fr);
}

.admin-table-head { color: #9fb3d1; font-weight: 800; }

@media (max-width: 760px) {
    .admin-kpis,
    .admin-grid { grid-template-columns: 1fr; }
    .admin-header { align-items: stretch; flex-direction: column; }
}
