/* ================================================================
   PAGES — Home-specific layout + scroll snap
   ================================================================ */

/* ── Scroll-snap container ── */
body[data-nav-root="home"] {
    --page-mouse-x: 50%;
    --page-mouse-y: 42%;
    --page-shift-x: 0px;
    --page-shift-y: 0px;
    --page-scroll-ratio: 0;
    --page-depth-opacity: 0.62;
    --page-grid-x: 0px;
    --page-grid-y: 0px;
    --page-glow-primary-x: 0px;
    --page-glow-primary-y: 0px;
    --page-glow-secondary-x: 0px;
    --page-glow-secondary-y: 0px;
    --page-signal-a-x: 0px;
    --page-signal-a-y: 0px;
    --page-signal-b-x: 0px;
    --page-signal-b-y: 0px;
}

.page-atmosphere {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
    opacity: var(--page-depth-opacity);
}

.page-atmosphere__grid,
.page-atmosphere__glow,
.page-atmosphere__signal {
    position: absolute;
    display: block;
}

.page-atmosphere__grid {
    inset: -12% -8%;
    background:
        linear-gradient(rgba(183, 243, 107, 0.026) 1px, transparent 1px),
        linear-gradient(90deg, rgba(107, 203, 255, 0.024) 1px, transparent 1px);
    background-size: 96px 96px;
    -webkit-mask-image: radial-gradient(circle at var(--page-mouse-x) var(--page-mouse-y), black 0, transparent 72%);
    mask-image: radial-gradient(circle at var(--page-mouse-x) var(--page-mouse-y), black 0, transparent 72%);
    transform:
        perspective(1200px)
        rotateX(62deg)
        translate3d(var(--page-grid-x), var(--page-grid-y), 0);
    transform-origin: center top;
}

.page-atmosphere__glow {
    width: clamp(18rem, 42vw, 34rem);
    aspect-ratio: 1;
    border-radius: 50%;
    filter: blur(32px);
    mix-blend-mode: screen;
}

.page-atmosphere__glow--primary {
    left: calc(var(--page-mouse-x) - 15rem);
    top: calc(var(--page-mouse-y) - 15rem);
    background: radial-gradient(circle, rgba(183, 243, 107, 0.11), transparent 64%);
    transform: translate3d(var(--page-glow-primary-x), var(--page-glow-primary-y), 0);
}

.page-atmosphere__glow--secondary {
    right: 4%;
    bottom: 4%;
    background: radial-gradient(circle, rgba(107, 203, 255, 0.08), transparent 62%);
    transform: translate3d(var(--page-glow-secondary-x), var(--page-glow-secondary-y), 0);
}

.page-atmosphere__signal {
    height: 1px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(183, 243, 107, 0.2), rgba(107, 203, 255, 0.1), transparent);
    box-shadow: 0 0 18px rgba(183, 243, 107, 0.08);
}

.page-atmosphere__signal--a {
    left: 6%;
    right: 46%;
    top: 38%;
    transform: translate3d(var(--page-signal-a-x), var(--page-signal-a-y), 0);
}

.page-atmosphere__signal--b {
    left: 48%;
    right: 7%;
    bottom: 22%;
    transform: translate3d(var(--page-signal-b-x), var(--page-signal-b-y), 0);
}

.snap-container {
    /* Use the document as the only vertical scroller; an internal scroller here creates a second scrollbar beside body. */
    position: relative;
    z-index: 1;
    min-height: 100vh;
    overflow: visible;
    scroll-snap-type: y proximity;
    scroll-behavior: smooth;
}

.snap-section {
    scroll-snap-align: start;
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    z-index: 1;
    overflow: clip;
}

.snap-section:not(.hero--home)::before,
.snap-section:not(.hero--home)::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 0;
}

.snap-section:not(.hero--home)::before {
    inset: 10% max(1rem, calc((100vw - var(--shell)) / 2)) auto auto;
    width: min(26rem, 50vw);
    height: min(18rem, 42vh);
    border-radius: 999px;
    background:
        radial-gradient(circle at var(--page-mouse-x) var(--page-mouse-y), rgba(183, 243, 107, 0.085), transparent 58%),
        radial-gradient(circle at 70% 30%, rgba(107, 203, 255, 0.052), transparent 52%);
    filter: blur(28px);
    opacity: 0.68;
    transform: translate3d(var(--page-glow-secondary-x), var(--page-glow-secondary-y), 0);
}

.snap-section:not(.hero--home)::after {
    left: max(1.25rem, calc((100vw - var(--shell)) / 2));
    right: max(1.25rem, calc((100vw - var(--shell)) / 2));
    bottom: 12%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(183, 243, 107, 0.12), rgba(107, 203, 255, 0.08), transparent);
    opacity: 0.58;
    transform: translate3d(var(--page-signal-b-x), var(--page-signal-b-y), 0);
}

.snap-section > .shell {
    position: relative;
    z-index: 1;
}

.section-anchor {
    position: absolute;
    inset-block-start: 0;
    inline-size: 1px;
    block-size: 1px;
    pointer-events: none;
}

/* ── Hero ── */
.hero--home {
    position: relative;
    padding: clamp(7rem, 12vh, 9rem) 0 clamp(5rem, 9vh, 7rem);
    overflow: clip;
    isolation: isolate;
    --hero-mouse-x: 50%;
    --hero-mouse-y: 44%;
    --hero-shift-x: 0px;
    --hero-shift-y: 0px;
    --hero-orbit-opacity: 1;
    --hero-aura-opacity: 0.76;
    --hero-line-opacity: 0.55;
    --hero-scroll-lift: 0px;
    --hero-aura-x: 0px;
    --hero-aura-y: 0px;
    --hero-line-x: 0px;
    --hero-line-y: 0px;
    --hero-grid-x: 0px;
    --hero-grid-y: 0px;
    --hero-secondary-x: 0px;
    --hero-secondary-y: 0px;
    --hero-line-a-x: 0px;
    --hero-line-a-y: 0px;
    --hero-line-b-x: 0px;
    --hero-line-b-y: 0px;
    --hero-panel-x: 0px;
    --hero-panel-y: 0px;
    --map-pointer-x: 50%;
    --map-pointer-y: 50%;
    background-color: #05070b;
    background:
        linear-gradient(90deg, rgba(3, 6, 11, 0.9) 0%, rgba(4, 8, 14, 0.72) 42%, rgba(3, 8, 13, 0.48) 100%),
        linear-gradient(180deg, rgba(5, 8, 13, 0.42) 0%, rgba(5, 7, 11, 0.74) 72%, rgba(5, 7, 11, 0.92) 100%),
        radial-gradient(circle at var(--hero-mouse-x) var(--hero-mouse-y), rgba(107, 203, 255, 0.15), transparent 34%),
        url("../assets/background_inicio.webp") center / cover no-repeat,
        #05070b;
}

.hero--home::before {
    content: "";
    position: absolute;
    left: max(0rem, calc((100vw - var(--shell)) / 2 - 5rem));
    top: 8%;
    width: min(64rem, 82vw);
    height: min(42rem, 68vh);
    background:
        radial-gradient(ellipse at 34% 48%, rgba(183, 243, 107, 0.22), rgba(107, 203, 255, 0.12) 30%, transparent 68%),
        radial-gradient(circle at var(--hero-mouse-x) var(--hero-mouse-y), rgba(255, 255, 255, 0.12), transparent 42%);
    filter: blur(54px);
    opacity: var(--hero-aura-opacity);
    pointer-events: none;
    z-index: 0;
    mix-blend-mode: screen;
    transform: translate3d(
        var(--hero-aura-x),
        var(--hero-aura-y),
        0
    );
    transition: opacity 180ms ease;
}

.hero--home::after {
    content: "";
    position: absolute;
    left: -20%;
    right: -20%;
    top: 18%;
    height: 24rem;
    background:
        linear-gradient(105deg, transparent 18%, rgba(183, 243, 107, 0.08) 42%, rgba(107, 203, 255, 0.09) 52%, transparent 76%),
        linear-gradient(90deg, rgba(2, 5, 9, 0.68), transparent 46%, rgba(2, 5, 9, 0.36));
    opacity: var(--hero-line-opacity);
    pointer-events: none;
    z-index: 0;
    transform: translate3d(-8%, var(--hero-line-y), 0);
    animation: hero-ambient-scan 18s ease-in-out infinite alternate;
}

.hero-orbit {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: var(--hero-orbit-opacity);
    transition: opacity 180ms ease;
}

.hero-orbit__grid,
.hero-orbit__glow,
.hero-orbit__line {
    position: absolute;
    display: block;
}

.hero-orbit__grid {
    inset: -8% -4%;
    background:
        linear-gradient(rgba(183, 243, 107, 0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(107, 203, 255, 0.016) 1px, transparent 1px);
    background-size: 92px 92px;
    -webkit-mask-image: radial-gradient(ellipse at 38% 46%, black 0, transparent 72%);
    mask-image: radial-gradient(ellipse at 38% 46%, black 0, transparent 72%);
    opacity: 0.38;
    transform:
        perspective(900px)
        rotateX(58deg)
        translate3d(var(--hero-grid-x), var(--hero-grid-y), 0);
    transform-origin: center top;
}

.hero-orbit__glow {
    width: clamp(13rem, 32vw, 25rem);
    aspect-ratio: 1;
    border-radius: 50%;
    filter: blur(20px);
    mix-blend-mode: screen;
    opacity: 0;
}

.hero-orbit__glow--primary {
    left: calc(var(--hero-mouse-x) - 12rem);
    top: calc(var(--hero-mouse-y) - 12rem);
    background: radial-gradient(circle, rgba(183, 243, 107, 0.18), transparent 64%);
    opacity: 0;
}

.hero-orbit__glow--secondary {
    right: 10%;
    bottom: 11%;
    background: radial-gradient(circle, rgba(107, 203, 255, 0.11), transparent 62%);
    opacity: 0;
    transform: translate3d(var(--hero-secondary-x), var(--hero-secondary-y), 0);
}

.hero-orbit__line {
    height: 1px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(183, 243, 107, 0.1), rgba(107, 203, 255, 0.06), transparent);
    box-shadow: 0 0 18px rgba(183, 243, 107, 0.04);
    opacity: 0;
}

.hero-orbit__line--a {
    left: 8%;
    right: 42%;
    top: 27%;
    transform: translate3d(var(--hero-line-a-x), var(--hero-line-a-y), 0);
}

.hero-orbit__line--b {
    left: 54%;
    right: 7%;
    bottom: 27%;
    opacity: 0.72;
    transform: translate3d(var(--hero-line-b-x), var(--hero-line-b-y), 0);
}

@keyframes hero-ambient-scan {
    0% {
        opacity: 0.36;
        transform: translate3d(-16%, -4%, 0);
    }

    50% {
        opacity: 0.72;
    }

    100% {
        opacity: 0.42;
        transform: translate3d(16%, 8%, 0);
    }
}

.hero__grid {
    position: relative;
    z-index: 1;
    display: grid;
    width: min(1320px, calc(100vw - 2.5rem));
    grid-template-columns: minmax(300px, 0.78fr) minmax(520px, 1.22fr);
    gap: clamp(1.75rem, 4.5vw, 4.75rem);
    align-items: center;
}

.hero__content {
    position: relative;
    display: grid;
    gap: 0;
    max-width: 42rem;
}

.hero__content::before {
    content: "";
    position: absolute;
    inset: -10% -9% -9% -10%;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: calc(var(--radius-lg) + 0.35rem);
    background:
        linear-gradient(105deg, rgba(3, 7, 12, 0.82), rgba(3, 7, 12, 0.5) 68%, transparent),
        radial-gradient(circle at 16% 35%, rgba(183, 243, 107, 0.1), transparent 44%),
        radial-gradient(circle at 58% 88%, rgba(107, 203, 255, 0.08), transparent 36%);
    box-shadow:
        0 28px 90px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    pointer-events: none;
    z-index: -1;
}

.hero__content h1 {
    max-width: 740px;
    margin-top: var(--space-4);
    color: #f8fbff;
    font-size: clamp(2.75rem, 4.6vw, 5rem);
    line-height: 0.96;
    text-shadow:
        0 2px 18px rgba(0, 0, 0, 0.34),
        0 18px 64px rgba(0, 0, 0, 0.4);
    text-wrap: balance;
}

.hero__lead {
    max-width: 35rem;
    margin-top: var(--space-4);
    color: rgba(235, 244, 255, 0.78);
    font-size: clamp(1.05rem, 1.7vw, 1.32rem);
    text-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

.hero__signal-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-5);
}

.hero__signal-list span {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.36rem 0.68rem;
    border: 1px solid rgba(183, 243, 107, 0.28);
    border-radius: 999px;
    background: rgba(5, 11, 16, 0.56);
    color: rgba(236, 244, 251, 0.76);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.hero__content .button-row {
    margin-top: var(--space-5);
}

[data-hero-entrance] .hero__content > .eyebrow,
[data-hero-entrance] .hero__content > h1,
[data-hero-entrance] .hero__lead,
[data-hero-entrance] .hero__signal-list span,
[data-hero-entrance] .hero__content .button,
[data-hero-entrance] .hero__visual,
[data-hero-entrance] .hero__panel {
    opacity: 0;
    transition-property: opacity, transform;
    transition-duration: 620ms;
    transition-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
    will-change: opacity, transform;
}

[data-hero-entrance] .hero__content > .eyebrow,
[data-hero-entrance] .hero__lead,
[data-hero-entrance] .hero__content .button {
    transform: none;
}

[data-hero-entrance] .hero__content > h1 {
    transform: translateY(24px);
}

[data-hero-entrance] .hero__signal-list span {
    transform: translateY(12px);
}

[data-hero-entrance] .hero__visual,
[data-hero-entrance] .hero__panel {
    transform: translate3d(var(--hero-panel-x), var(--hero-panel-y), 0) scale(0.96);
    transform-origin: center;
}

[data-hero-entrance].hero--entered .hero__content > .eyebrow,
[data-hero-entrance].hero--entered .hero__content > h1,
[data-hero-entrance].hero--entered .hero__lead,
[data-hero-entrance].hero--entered .hero__signal-list span,
[data-hero-entrance].hero--entered .hero__content .button,
[data-hero-entrance].hero--entered .hero__visual,
[data-hero-entrance].hero--entered .hero__panel {
    opacity: 1;
}

[data-hero-entrance].hero--entered .hero__content > h1,
[data-hero-entrance].hero--entered .hero__signal-list span {
    transform: translateY(0);
}

[data-hero-entrance].hero--entered .hero__visual,
[data-hero-entrance].hero--entered .hero__panel {
    transform: translate3d(var(--hero-panel-x), var(--hero-panel-y), 0) scale(1);
}

[data-hero-entrance] .hero__content > .eyebrow {
    transition-delay: 80ms;
}

[data-hero-entrance] .hero__content > h1 {
    transition-delay: 220ms;
}

[data-hero-entrance] .hero__lead {
    transition-delay: 440ms;
}

[data-hero-entrance] .hero__signal-list span:nth-child(1) {
    transition-delay: 620ms;
}

[data-hero-entrance] .hero__signal-list span:nth-child(2) {
    transition-delay: 700ms;
}

[data-hero-entrance] .hero__signal-list span:nth-child(3) {
    transition-delay: 780ms;
}

[data-hero-entrance] .hero__signal-list span:nth-child(4) {
    transition-delay: 860ms;
}

[data-hero-entrance] .hero__content .button {
    transition-delay: 1040ms;
}

[data-hero-entrance] .hero__visual,
[data-hero-entrance] .hero__panel {
    transition-delay: 1160ms;
}

.hero__visual {
    position: relative;
    justify-self: end;
    width: min(100%, 54rem);
    transform: translate3d(var(--hero-panel-x), var(--hero-panel-y), 0);
    transition: transform 180ms ease;
}

.hero__visual::before {
    content: "";
    position: absolute;
    inset: 6% -6% 4%;
    z-index: 0;
    border-radius: 999px;
    background:
        radial-gradient(circle at 62% 46%, rgba(107, 203, 255, 0.2), transparent 48%),
        radial-gradient(circle at 36% 58%, rgba(183, 243, 107, 0.13), transparent 46%);
    filter: blur(40px);
    opacity: 0.86;
    pointer-events: none;
}

.system-map {
    --map-tilt-x: 0deg;
    --map-tilt-y: 0deg;
    position: relative;
    min-height: clamp(35rem, 48vw, 44rem);
    padding: clamp(1.05rem, 2vw, 1.4rem);
    border: 1px solid rgba(205, 235, 255, 0.24);
    border-radius: calc(var(--radius-lg) + 0.1rem);
    background:
        radial-gradient(circle at var(--map-pointer-x) var(--map-pointer-y), rgba(107, 203, 255, 0.24), transparent 28%),
        linear-gradient(rgba(183, 243, 107, 0.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(107, 203, 255, 0.042) 1px, transparent 1px),
        radial-gradient(circle at 20% 18%, rgba(255, 107, 107, 0.12), transparent 30%),
        radial-gradient(circle at 82% 78%, rgba(183, 243, 107, 0.18), transparent 38%),
        linear-gradient(150deg, rgba(4, 9, 15, 0.86), rgba(3, 7, 12, 0.72));
    background-color: rgba(3, 9, 15, 0.82);
    background-size: auto, 42px 42px, 42px 42px, auto, auto, auto;
    box-shadow:
        0 34px 110px rgba(0, 0, 0, 0.48),
        0 0 0 1px rgba(107, 203, 255, 0.05),
        0 0 58px rgba(107, 203, 255, 0.13),
        inset 0 1px 0 rgba(255, 255, 255, 0.16),
        inset 0 -42px 100px rgba(2, 5, 9, 0.32);
    -webkit-backdrop-filter: blur(15px) saturate(1.1);
    backdrop-filter: blur(15px) saturate(1.1);
    overflow: hidden;
    isolation: isolate;
    z-index: 1;
    transform:
        perspective(1200px)
        rotateX(var(--map-tilt-y))
        rotateY(var(--map-tilt-x));
    transform-style: preserve-3d;
    transition:
        border-color 260ms ease,
        box-shadow 260ms ease,
        transform 220ms cubic-bezier(0.16, 1, 0.3, 1);
}

.system-map:hover,
.system-map:focus-within {
    border-color: rgba(232, 249, 255, 0.42);
    box-shadow:
        0 40px 120px rgba(0, 0, 0, 0.52),
        0 0 0 1px rgba(107, 203, 255, 0.14),
        0 0 72px rgba(107, 203, 255, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.2),
        inset 0 -42px 100px rgba(2, 5, 9, 0.3);
}

.system-map::before,
.system-map::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 0;
}

.system-map::before {
    inset: 6% 7%;
    border: 1px solid rgba(183, 243, 107, 0.14);
    border-radius: calc(var(--radius-md) + 0.2rem);
    background:
        linear-gradient(90deg, transparent 0 48%, rgba(183, 243, 107, 0.11) 48% 49%, transparent 49%),
        linear-gradient(180deg, transparent 0 49%, rgba(107, 203, 255, 0.12) 49% 50%, transparent 50%);
    opacity: 0.68;
    transform: skewX(-5deg) translateZ(8px);
}

.system-map::after {
    left: 8%;
    right: 8%;
    top: 50%;
    height: 2px;
    background: linear-gradient(90deg, rgba(255, 107, 107, 0.16), rgba(183, 243, 107, 0.55), rgba(107, 203, 255, 0.4));
    box-shadow:
        0 0 24px rgba(183, 243, 107, 0.16),
        0 0 32px rgba(107, 203, 255, 0.12);
    opacity: 0.78;
    transform: translateY(-50%);
}

.system-map__status,
.system-map__legend {
    position: relative;
    z-index: 3;
    display: flex;
    justify-content: space-between;
    gap: var(--space-2);
    color: rgba(236, 247, 255, 0.72);
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.system-map__rail {
    position: absolute;
    z-index: 2;
    left: clamp(1.15rem, 4vw, 2.6rem);
    right: clamp(1.15rem, 4vw, 2.6rem);
    top: 4.6rem;
    display: grid;
    grid-template-columns: 0.4fr 1fr auto;
    align-items: center;
    gap: 0.86rem;
}

.system-map__rail-noise,
.system-map__rail-flow,
.system-map__rail-lock {
    display: block;
}

.system-map__rail-noise {
    height: 1px;
    background: repeating-linear-gradient(90deg, rgba(255, 107, 107, 0.74) 0 4px, transparent 4px 9px);
    opacity: 0.86;
}

.system-map__rail-flow {
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(255, 107, 107, 0.08), rgba(183, 243, 107, 0.78), rgba(107, 203, 255, 0.72));
    box-shadow:
        0 0 18px rgba(183, 243, 107, 0.22),
        0 0 28px rgba(107, 203, 255, 0.14);
    transform-origin: left center;
    animation: system-flow 4.8s ease-in-out infinite;
}

.system-map__rail-lock {
    width: 0.72rem;
    aspect-ratio: 1;
    border-radius: 50%;
    background: var(--accent);
    box-shadow:
        0 0 0 7px rgba(183, 243, 107, 0.08),
        0 0 22px rgba(183, 243, 107, 0.64);
}

.system-map__field {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.system-map__signal {
    position: absolute;
    display: block;
    height: 1px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(183, 243, 107, 0.36), rgba(107, 203, 255, 0.28), transparent);
    opacity: 0.84;
    box-shadow: 0 0 20px rgba(107, 203, 255, 0.12);
}

.system-map__signal--a {
    left: 13%;
    right: 18%;
    top: 35%;
    transform: rotate(18deg);
}

.system-map__signal--b {
    left: 15%;
    right: 20%;
    bottom: 34%;
    transform: rotate(-18deg);
}

.system-map__signal--c {
    left: 49%;
    top: 20%;
    bottom: 18%;
    width: 1px;
    height: auto;
    background: linear-gradient(180deg, transparent, rgba(183, 243, 107, 0.2), rgba(107, 203, 255, 0.14), transparent);
}

.system-map__core {
    position: absolute;
    left: 50%;
    top: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: clamp(7.5rem, 10vw, 9.2rem);
    aspect-ratio: 1;
    border: 1px solid rgba(183, 243, 107, 0.42);
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(183, 243, 107, 0.2), rgba(5, 9, 14, 0.86) 62%),
        rgba(5, 10, 16, 0.76);
    color: var(--text);
    font-family: var(--font-heading);
    font-size: clamp(0.86rem, 1.05vw, 1rem);
    font-weight: 800;
    letter-spacing: 0.04em;
    transform: translate(-50%, -50%) translateZ(34px);
    box-shadow:
        0 0 0 1px rgba(107, 203, 255, 0.12),
        0 0 0 12px rgba(183, 243, 107, 0.035),
        0 0 54px rgba(183, 243, 107, 0.24);
}

.system-map__nodes {
    position: absolute;
    inset: 6.4rem clamp(1.05rem, 3.6vw, 2.6rem) 4.35rem;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(2, minmax(0, 1fr));
    gap: clamp(4rem, 7vw, 6.4rem) clamp(3rem, 5vw, 5rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.system-node {
    --node-color: var(--accent);
    position: relative;
    display: grid;
    align-content: center;
    gap: 0.42rem;
    min-height: clamp(8.9rem, 11vw, 10.4rem);
    padding: clamp(1rem, 2vw, 1.25rem);
    border: 1px solid rgba(224, 244, 255, 0.17);
    border-radius: var(--radius-md);
    background:
        radial-gradient(circle at var(--map-pointer-x) var(--map-pointer-y), color-mix(in srgb, var(--node-color) 18%, transparent), transparent 46%),
        radial-gradient(circle at 90% 0%, color-mix(in srgb, var(--node-color) 16%, transparent), transparent 40%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.095), rgba(255, 255, 255, 0.032)),
        rgba(5, 10, 16, 0.78);
    box-shadow:
        0 18px 52px rgba(0, 0, 0, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.11);
    outline: 0;
    transform: translateZ(22px);
    transition:
        opacity 260ms ease,
        transform 300ms cubic-bezier(0.16, 1, 0.3, 1),
        border-color 260ms ease,
        background 260ms ease,
        box-shadow 260ms ease;
}

.system-node::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(120deg, transparent 16%, rgba(255, 255, 255, 0.18) 46%, transparent 68%);
    opacity: 0;
    transform: translateX(-28%);
    pointer-events: none;
    transition:
        opacity 260ms ease,
        transform 520ms cubic-bezier(0.16, 1, 0.3, 1);
}

.system-node::before {
    content: "";
    position: absolute;
    width: 0.66rem;
    aspect-ratio: 1;
    border-radius: 50%;
    background: var(--node-color);
    box-shadow:
        0 0 0 7px color-mix(in srgb, var(--node-color) 9%, transparent),
        0 0 22px color-mix(in srgb, var(--node-color) 64%, transparent);
}

.system-node--context {
    --node-color: var(--accent-red);
}

.system-node--product {
    --node-color: var(--accent-blue);
}

.system-node--interface {
    --node-color: var(--accent);
}

.system-node--operation {
    --node-color: var(--accent-amber);
}

.system-node--context::before,
.system-node--interface::before {
    right: -0.3rem;
    top: 50%;
}

.system-node--product::before,
.system-node--operation::before {
    left: -0.3rem;
    top: 50%;
}

.system-map.is-inspecting .system-node:not(.is-active) {
    opacity: 0.68;
}

.system-node:hover,
.system-node:focus-visible,
.system-node.is-active {
    opacity: 1;
    outline: 2px solid color-mix(in srgb, var(--node-color) 72%, white);
    outline-offset: 4px;
    transform: translateY(-8px) translateZ(42px) scale(1.025);
    border-color: color-mix(in srgb, var(--node-color) 42%, rgba(255, 255, 255, 0.14));
    background:
        radial-gradient(circle at var(--map-pointer-x) var(--map-pointer-y), color-mix(in srgb, var(--node-color) 26%, transparent), transparent 42%),
        radial-gradient(circle at 90% 0%, color-mix(in srgb, var(--node-color) 24%, transparent), transparent 42%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.042)),
        rgba(5, 12, 18, 0.92);
    box-shadow:
        0 28px 74px rgba(0, 0, 0, 0.46),
        0 0 38px color-mix(in srgb, var(--node-color) 23%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.system-node:hover::after,
.system-node:focus-visible::after,
.system-node.is-active::after {
    opacity: 1;
    transform: translateX(24%);
}

.system-node__index {
    color: color-mix(in srgb, var(--node-color) 74%, var(--text-muted));
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
}

.system-node__title {
    color: var(--text);
    font-family: var(--font-heading);
    font-size: clamp(1.05rem, 1.45vw, 1.32rem);
    font-weight: 800;
    line-height: 1.08;
}

.system-node__note {
    max-width: 16rem;
    color: rgba(229, 239, 247, 0.72);
    font-size: clamp(0.83rem, 1vw, 0.95rem);
    line-height: 1.4;
}

.system-map__legend {
    position: absolute;
    left: clamp(1.15rem, 4vw, 2.6rem);
    right: clamp(1.15rem, 4vw, 2.6rem);
    bottom: 1.25rem;
}

@keyframes system-flow {
    0%, 100% {
        transform: scaleX(0.72);
        opacity: 0.58;
    }

    48% {
        transform: scaleX(1);
        opacity: 1;
    }
}

.hero__panel {
    position: relative;
    justify-self: end;
    width: min(100%, 20.75rem);
    transform: translate3d(var(--hero-panel-x), var(--hero-panel-y), 0);
    transition: transform 180ms ease;
}

.hero__panel::before {
    content: "";
    position: absolute;
    inset: 14% -10% 16% -8%;
    border-radius: 999px;
    background:
        radial-gradient(circle at 58% 48%, rgba(183, 243, 107, 0.075), transparent 50%),
        radial-gradient(circle at 36% 28%, rgba(107, 203, 255, 0.052), transparent 40%);
    filter: blur(34px);
    opacity: 0.62;
    pointer-events: none;
}

/* ── Portrait profile block ── */
.portrait-card--premium {
    position: relative;
    display: grid;
    justify-items: center;
    gap: var(--space-3);
    padding: 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.065);
    border-radius: calc(var(--radius-lg) + 0.35rem);
    background:
        linear-gradient(90deg, rgba(183, 243, 107, 0.035) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255, 255, 255, 0.034), rgba(255, 255, 255, 0.012)),
        rgba(9, 11, 15, 0.66);
    background-size: 72px 100%, auto, auto;
    box-shadow:
        0 18px 52px rgba(0, 0, 0, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.055);
    transition:
        transform 240ms ease,
        border-color 240ms ease,
        box-shadow 240ms ease,
        background 240ms ease;
}

.portrait-card--premium:hover,
.portrait-card--premium:focus-within {
    transform: translateY(-3px);
    border-color: rgba(183, 243, 107, 0.38);
    background:
        radial-gradient(circle at 14% 0%, rgba(183, 243, 107, 0.095), transparent 36%),
        linear-gradient(180deg, rgba(183, 243, 107, 0.052), rgba(255, 255, 255, 0.018)),
        rgba(9, 11, 15, 0.66);
    box-shadow:
        0 30px 86px rgba(0, 0, 0, 0.44),
        0 0 0 1px rgba(183, 243, 107, 0.08),
        0 0 34px rgba(183, 243, 107, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.09);
}

.portrait-card__glow {
    position: absolute;
    inset: 12% -8% auto;
    height: 42%;
    background:
        radial-gradient(circle at 50% 35%, rgba(107, 203, 255, 0.095), transparent 50%),
        radial-gradient(circle at 18% 20%, rgba(183, 243, 107, 0.08), transparent 42%);
    pointer-events: none;
    z-index: 0;
    filter: blur(18px);
    opacity: 0.54;
    transition:
        opacity 240ms ease,
        filter 240ms ease;
}

.portrait-card__status-strip {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 0.15rem 0.35rem 0;
    color: rgba(243, 245, 247, 0.48);
    font-size: 0.64rem;
    font-weight: 800;
    letter-spacing: 0.16em;
}

.portrait-card--premium:hover .portrait-card__glow,
.portrait-card--premium:focus-within .portrait-card__glow {
    opacity: 0.95;
    filter: blur(20px);
}

.portrait-card__image-frame {
    position: relative;
    z-index: 1;
    margin: 0;
    width: clamp(160px, 18vw, 248px);
    aspect-ratio: 1 / 1;
    border: 1px solid rgba(183, 243, 107, 0.16);
    border-radius: 50%;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.018)),
        rgba(9, 11, 15, 0.72);
    box-shadow:
        0 16px 42px rgba(0, 0, 0, 0.3),
        0 0 24px rgba(183, 243, 107, 0.055),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
    overflow: hidden;
    transition:
        transform 240ms ease,
        border-color 240ms ease,
        box-shadow 240ms ease;
}

.portrait-card__image-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        radial-gradient(circle at 50% 14%, rgba(255, 255, 255, 0.18), transparent 28%),
        linear-gradient(180deg, transparent 62%, rgba(9, 11, 15, 0.28));
    pointer-events: none;
}

.portrait-card__image-frame img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center center;
    filter: contrast(1.06) brightness(0.96) saturate(1.02);
    transition:
        transform 260ms ease,
        filter 260ms ease;
}

.portrait-card--premium:hover .portrait-card__image-frame,
.portrait-card--premium:focus-within .portrait-card__image-frame {
    transform: translateY(-2px);
    border-color: rgba(183, 243, 107, 0.42);
    box-shadow:
        0 22px 58px rgba(0, 0, 0, 0.42),
        0 0 42px rgba(183, 243, 107, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.portrait-card--premium:hover .portrait-card__image-frame img,
.portrait-card--premium:focus-within .portrait-card__image-frame img {
    transform: scale(1.018);
    filter: contrast(1.08) brightness(1) saturate(1.04);
}

.profile-hub {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 0;
    width: 100%;
    padding: var(--space-3);
    border: 1px solid rgba(255, 255, 255, 0.085);
    border-radius: var(--radius-md);
    background:
        radial-gradient(circle at 92% 0%, rgba(183, 243, 107, 0.055), transparent 38%),
        linear-gradient(155deg, rgba(17, 21, 28, 0.78), rgba(9, 11, 15, 0.74));
    box-shadow:
        0 14px 42px rgba(0, 0, 0, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.07);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    transition:
        transform 240ms ease,
        border-color 240ms ease,
        box-shadow 240ms ease,
        background 240ms ease;
}

.portrait-card--premium:hover .profile-hub,
.portrait-card--premium:focus-within .profile-hub {
    transform: translateY(-2px);
    border-color: rgba(183, 243, 107, 0.28);
    background:
        radial-gradient(circle at 92% 0%, rgba(183, 243, 107, 0.16), transparent 38%),
        linear-gradient(155deg, rgba(22, 28, 36, 0.92), rgba(9, 11, 15, 0.78));
    box-shadow:
        0 20px 60px rgba(0, 0, 0, 0.38),
        0 0 34px rgba(183, 243, 107, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.profile-hub__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid rgba(255, 255, 255, 0.075);
}

.profile-hub__name {
    margin: 0;
    font-family: var(--font-heading);
    font-size: clamp(1.28rem, 2vw, 1.58rem);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.035em;
    color: var(--text);
}

.profile-hub__role {
    margin: 0.35rem 0 0;
    color: var(--text-muted);
    font-size: 0.8rem;
    line-height: 1.35;
}

.profile-hub__mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    border: 1px solid rgba(183, 243, 107, 0.22);
    border-radius: 999px;
    background: rgba(183, 243, 107, 0.08);
    color: var(--accent);
    font-family: var(--font-heading);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.profile-hub__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    padding: var(--space-3) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.075);
}

.profile-hub__tags span {
    position: relative;
    display: inline-flex;
    align-items: center;
    min-height: 1.82rem;
    padding: 0.32rem 0.6rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.035);
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    overflow: hidden;
    transition:
        transform 220ms ease,
        border-color 220ms ease,
        background 220ms ease,
        color 220ms ease,
        box-shadow 220ms ease;
}

.profile-hub__tags span::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    background: linear-gradient(120deg, transparent, rgba(255, 255, 255, 0.12), transparent);
    opacity: 0;
    transform: translateX(-24%);
    transition:
        opacity 220ms ease,
        transform 220ms ease;
}

.profile-hub__tags span:hover,
.profile-hub__tags span:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(107, 203, 255, 0.34);
    background: rgba(107, 203, 255, 0.08);
    color: var(--text);
    box-shadow:
        0 8px 18px rgba(0, 0, 0, 0.12),
        0 0 20px rgba(107, 203, 255, 0.08);
}

.profile-hub__tags span:hover::before,
.profile-hub__tags span:focus-visible::before {
    opacity: 1;
    transform: translateX(24%);
}

.profile-hub__status {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    width: fit-content;
    margin-top: var(--space-3);
    padding: 0.58rem 0.8rem;
    border: 1px solid rgba(183, 243, 107, 0.14);
    border-radius: 999px;
    background: rgba(183, 243, 107, 0.055);
    color: var(--text-muted);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    transition:
        transform 220ms ease,
        border-color 220ms ease,
        background 220ms ease,
        color 220ms ease,
        box-shadow 220ms ease;
}

.profile-hub__status:hover,
.profile-hub__status:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(183, 243, 107, 0.4);
    background: rgba(183, 243, 107, 0.11);
    color: var(--text);
    box-shadow: 0 0 26px rgba(183, 243, 107, 0.1);
}

.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--text-soft);
    flex-shrink: 0;
}

.status-dot--active {
    background: var(--accent);
    box-shadow: 0 0 8px rgba(183, 243, 107, 0.5);
    animation: statusPulse 2s ease-in-out infinite;
}

@keyframes statusPulse {
    0%, 100% { box-shadow: 0 0 4px rgba(183, 243, 107, 0.3); }
    50% { box-shadow: 0 0 12px rgba(183, 243, 107, 0.6); }
}

/* ── Author scene ── */
.author-scene {
    --author-paper: #fbfcfd;
    --author-ink: #111827;
    --author-muted: #4f5f70;
    --author-soft: #738195;
    --author-blue: #256fa8;
    --author-green: #4f8f20;
    --author-amber: #b76514;
    color: var(--author-ink);
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.58) 0%, rgba(255, 255, 255, 0.36) 34%, rgba(255, 255, 255, 0.86) 58%, rgba(255, 255, 255, 0.96) 100%),
        radial-gradient(circle at 19% 48%, rgba(37, 111, 168, 0.13), transparent 29%),
        radial-gradient(circle at 84% 68%, rgba(79, 143, 32, 0.1), transparent 30%),
        url("../assets/background_sobremi.webp") center / cover no-repeat,
        var(--author-paper);
}

.author-scene.snap-section::before {
    inset: 8% auto auto 3%;
    width: min(34rem, 45vw);
    height: min(22rem, 44vh);
    background:
        radial-gradient(circle at 42% 48%, rgba(37, 111, 168, 0.12), transparent 62%),
        radial-gradient(circle at 68% 22%, rgba(79, 143, 32, 0.11), transparent 56%);
    filter: blur(24px);
    opacity: 0.62;
    mix-blend-mode: multiply;
}

.author-scene.snap-section::after {
    left: max(1.25rem, calc((100vw - var(--shell)) / 2));
    right: max(1.25rem, calc((100vw - var(--shell)) / 2));
    bottom: 15%;
    background: linear-gradient(90deg, transparent, rgba(37, 111, 168, 0.26), rgba(79, 143, 32, 0.18), transparent);
    opacity: 0.5;
}

.author-scene__layout {
    display: grid;
    grid-template-columns: minmax(300px, 0.72fr) minmax(0, 1.28fr);
    gap: clamp(4rem, 8vw, 7.25rem);
    align-items: center;
}

.author-scene__portrait {
    position: relative;
    display: grid;
    justify-items: center;
    gap: 0.9rem;
    margin-left: clamp(-5.5rem, -7vw, -2.5rem);
}

.author-portrait {
    position: relative;
    display: grid;
    place-items: center;
    width: min(100%, 27rem);
    min-height: clamp(23rem, 40vw, 31rem);
    margin: 0;
    isolation: isolate;
    transition:
        transform 460ms cubic-bezier(0.16, 1, 0.3, 1),
        filter 460ms ease;
}

.author-portrait::before,
.author-portrait::after,
.author-portrait__halo,
.author-portrait__axis {
    content: "";
    position: absolute;
    pointer-events: none;
}

.author-portrait::before {
    width: min(100%, 24.5rem);
    aspect-ratio: 1;
    border: 1px solid rgba(79, 143, 32, 0.24);
    border-radius: 50%;
    background:
        linear-gradient(rgba(79, 143, 32, 0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(37, 111, 168, 0.05) 1px, transparent 1px);
    background-size: 34px 34px;
    transform: rotate(-10deg);
    opacity: 0.78;
    transition:
        border-color 460ms ease,
        transform 620ms cubic-bezier(0.16, 1, 0.3, 1),
        opacity 460ms ease;
}

.author-portrait::after {
    width: min(88%, 20rem);
    aspect-ratio: 1;
    border: 1px dashed rgba(37, 111, 168, 0.32);
    border-radius: 50%;
    transform: rotate(18deg);
    transition:
        border-color 460ms ease,
        transform 680ms cubic-bezier(0.16, 1, 0.3, 1),
        opacity 460ms ease;
}

.author-portrait__halo {
    width: min(92%, 22rem);
    aspect-ratio: 1;
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 35%, rgba(79, 143, 32, 0.19), transparent 42%),
        radial-gradient(circle at 34% 62%, rgba(37, 111, 168, 0.16), transparent 44%);
    filter: blur(24px);
    opacity: 0.7;
    z-index: 0;
    transition:
        opacity 460ms ease,
        transform 620ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-portrait__axis {
    z-index: 1;
    height: 1px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(79, 143, 32, 0.32), rgba(37, 111, 168, 0.2), transparent);
    opacity: 0.82;
    transition:
        opacity 360ms ease,
        transform 580ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-portrait__axis--a {
    left: 2%;
    right: 2%;
    top: 38%;
    transform: rotate(14deg);
}

.author-portrait__axis--b {
    left: 6%;
    right: 6%;
    bottom: 31%;
    transform: rotate(-18deg);
}

.author-portrait img {
    position: relative;
    z-index: 2;
    width: min(72%, 18rem);
    height: min(72%, 18rem);
    aspect-ratio: 1;
    object-fit: cover;
    object-position: center;
    border: 1px solid rgba(17, 24, 39, 0.16);
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.92);
    box-shadow:
        0 26px 70px rgba(17, 24, 39, 0.24),
        0 0 0 10px rgba(255, 255, 255, 0.7),
        0 0 42px rgba(37, 111, 168, 0.16);
    filter: contrast(1.04) brightness(1.01) saturate(1.02);
    transition:
        border-color 420ms ease,
        box-shadow 420ms ease,
        filter 420ms ease,
        transform 520ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-portrait figcaption {
    position: absolute;
    z-index: 3;
    right: 4%;
    bottom: 9%;
    display: grid;
    gap: 0.18rem;
    min-width: min(14rem, 72%);
    padding: 0.85rem 1rem;
    border: 1px solid rgba(17, 24, 39, 0.12);
    border-radius: 8px;
    background:
        radial-gradient(circle at 92% 0%, rgba(79, 143, 32, 0.14), transparent 36%),
        rgba(17, 24, 39, 0.9);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow:
        0 18px 48px rgba(17, 24, 39, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
    transition:
        border-color 360ms ease,
        box-shadow 360ms ease,
        transform 480ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-portrait figcaption span:first-child {
    color: var(--text);
    font-family: var(--font-heading);
    font-weight: 800;
    line-height: 1;
}

.author-portrait figcaption span:last-child {
    color: #b7f36b;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.author-portrait:hover {
    transform: translateY(-0.4rem);
    filter: saturate(1.02);
}

.author-portrait:hover::before {
    border-color: rgba(79, 143, 32, 0.4);
    opacity: 0.95;
    transform: rotate(-16deg) scale(1.025);
}

.author-portrait:hover::after {
    border-color: rgba(37, 111, 168, 0.52);
    opacity: 0.92;
    transform: rotate(26deg) scale(1.035);
}

.author-portrait:hover .author-portrait__halo {
    opacity: 0.95;
    transform: scale(1.06);
}

.author-portrait:hover .author-portrait__axis--a {
    opacity: 1;
    transform: rotate(9deg) translateX(0.55rem);
}

.author-portrait:hover .author-portrait__axis--b {
    opacity: 1;
    transform: rotate(-12deg) translateX(-0.55rem);
}

.author-portrait:hover img {
    border-color: rgba(37, 111, 168, 0.34);
    box-shadow:
        0 34px 82px rgba(17, 24, 39, 0.28),
        0 0 0 10px rgba(255, 255, 255, 0.82),
        0 0 52px rgba(79, 143, 32, 0.2);
    filter: contrast(1.06) brightness(1.03) saturate(1.05);
    transform: translateY(-0.45rem) scale(1.025);
}

.author-portrait:hover figcaption {
    border-color: rgba(37, 111, 168, 0.28);
    box-shadow:
        0 22px 58px rgba(17, 24, 39, 0.26),
        0 0 28px rgba(37, 111, 168, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    transform: translate3d(0.45rem, -0.25rem, 0);
}

.author-expertise {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.55rem;
    max-width: 22rem;
}

.author-expertise span {
    --pill-accent: var(--author-blue);
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.2rem;
    padding: 0.46rem 0.86rem;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--pill-accent) 30%, rgba(17, 24, 39, 0.12));
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.76);
    color: color-mix(in srgb, var(--pill-accent) 78%, var(--author-ink));
    box-shadow:
        0 10px 26px rgba(17, 24, 39, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.8);
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition:
        background 260ms ease,
        border-color 260ms ease,
        box-shadow 260ms ease,
        color 260ms ease,
        transform 320ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-expertise span:nth-child(2) {
    --pill-accent: var(--author-green);
}

.author-expertise span:nth-child(3) {
    --pill-accent: var(--author-amber);
}

.author-expertise span:nth-child(4) {
    --pill-accent: #5b67c9;
}

.author-expertise span::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent 0%, rgba(255, 255, 255, 0.72) 44%, transparent 68%);
    opacity: 0;
    transform: translateX(-80%);
    transition:
        opacity 260ms ease,
        transform 620ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-expertise span:hover {
    border-color: color-mix(in srgb, var(--pill-accent) 52%, rgba(17, 24, 39, 0.18));
    background: color-mix(in srgb, var(--pill-accent) 92%, #111827);
    color: #ffffff;
    box-shadow:
        0 16px 34px color-mix(in srgb, var(--pill-accent) 22%, transparent),
        0 0 0 4px color-mix(in srgb, var(--pill-accent) 13%, transparent);
    transform: translateY(-0.24rem) scale(1.04);
}

.author-expertise span:hover::before {
    opacity: 1;
    transform: translateX(82%);
}

.author-availability {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.62rem;
    width: fit-content;
    min-height: 2.55rem;
    padding: 0.58rem 1rem;
    overflow: hidden;
    border: 1px solid rgba(79, 143, 32, 0.28);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--author-ink);
    box-shadow:
        0 12px 28px rgba(17, 24, 39, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.82);
    font-size: 0.88rem;
    font-weight: 850;
    transition:
        background 260ms ease,
        border-color 260ms ease,
        box-shadow 260ms ease,
        color 260ms ease,
        transform 320ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-availability span {
    width: 0.62rem;
    height: 0.62rem;
    border-radius: 50%;
    background: var(--author-green);
    box-shadow: 0 0 0 0 rgba(79, 143, 32, 0.22);
    transition:
        background 260ms ease,
        box-shadow 260ms ease,
        transform 320ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-availability::before {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    background: linear-gradient(110deg, transparent 0%, rgba(79, 143, 32, 0.16) 44%, transparent 68%);
    opacity: 0;
    transform: translateX(-55%);
    transition:
        opacity 260ms ease,
        transform 620ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-availability:hover,
.author-availability:focus-visible {
    border-color: rgba(79, 143, 32, 0.48);
    background: #111827;
    color: #ffffff;
    box-shadow:
        0 18px 40px rgba(17, 24, 39, 0.18),
        0 0 0 4px rgba(79, 143, 32, 0.1);
    transform: translateY(-0.18rem);
}

.author-availability:hover::before,
.author-availability:focus-visible::before {
    opacity: 1;
    transform: translateX(58%);
}

.author-availability:hover span,
.author-availability:focus-visible span {
    background: #b7f36b;
    box-shadow:
        0 0 0 0.42rem rgba(183, 243, 107, 0.14),
        0 0 18px rgba(183, 243, 107, 0.28);
    transform: scale(1.12);
}

.author-scene__content {
    display: grid;
    gap: var(--space-3);
    color: var(--author-ink);
}

.author-scene__content h2 {
    max-width: 13ch;
    margin: 0;
    font-family: var(--font-heading);
    font-size: clamp(2.25rem, 4.35vw, 4.45rem);
    line-height: 1;
    letter-spacing: -0.03em;
    text-wrap: balance;
    color: var(--author-ink);
}

.author-scene__content p {
    max-width: 44rem;
    margin: 0;
    color: var(--author-muted);
}

.author-scene__statement {
    color: var(--author-ink) !important;
    font-size: clamp(1.05rem, 1.7vw, 1.28rem);
    line-height: 1.55;
}

.author-scene .eyebrow {
    color: var(--author-green);
}

.author-skill-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(0.9rem, 1.6vw, 1.25rem);
    margin-top: var(--space-3);
}

.author-skill-card {
    --skill-accent: var(--author-blue);
    --skill-x: 50%;
    --skill-y: 50%;
    position: relative;
    display: grid;
    align-content: start;
    gap: 0.62rem;
    min-height: 12.25rem;
    padding: clamp(1rem, 1.8vw, 1.22rem);
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--skill-accent) 24%, rgba(17, 24, 39, 0.11));
    border-radius: 8px;
    background:
        radial-gradient(circle at var(--skill-x) var(--skill-y), color-mix(in srgb, var(--skill-accent) 13%, transparent), transparent 42%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.5));
    box-shadow:
        0 18px 40px rgba(17, 24, 39, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.78);
    outline: 0;
    transform: translateZ(0);
    transition:
        background 280ms ease,
        border-color 280ms ease,
        box-shadow 280ms ease,
        transform 360ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-skill-card:nth-child(2) {
    --skill-accent: var(--author-green);
}

.author-skill-card:nth-child(3) {
    --skill-accent: var(--author-amber);
}

.author-skill-card:nth-child(4) {
    --skill-accent: #5b67c9;
}

.author-skill-card::before,
.author-skill-card::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.author-skill-card::before {
    inset: 0;
    background:
        linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.72) 44%, transparent 68%),
        radial-gradient(circle at var(--skill-x) var(--skill-y), color-mix(in srgb, var(--skill-accent) 28%, transparent), transparent 36%);
    opacity: 0;
    transform: translateX(-32%);
    transition:
        opacity 280ms ease,
        transform 720ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-skill-card::after {
    left: 1rem;
    right: 1rem;
    bottom: 0;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, var(--skill-accent), transparent);
    opacity: 0.22;
    transform: scaleX(0.45);
    transition:
        opacity 280ms ease,
        transform 360ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-skill-card > * {
    position: relative;
    z-index: 1;
}

.author-skill-card__index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 1.8rem;
    padding: 0.24rem 0.48rem;
    border: 1px solid color-mix(in srgb, var(--skill-accent) 28%, rgba(17, 24, 39, 0.12));
    border-radius: 999px;
    background: color-mix(in srgb, var(--skill-accent) 11%, rgba(255, 255, 255, 0.8));
    color: color-mix(in srgb, var(--skill-accent) 82%, var(--author-ink));
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
    font-size: 0.68rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    transition:
        background 260ms ease,
        color 260ms ease,
        transform 320ms cubic-bezier(0.16, 1, 0.3, 1);
}

.author-skill-card h3 {
    margin: 0;
    color: var(--author-ink);
    font-family: var(--font-heading);
    font-size: clamp(1.1rem, 1.6vw, 1.34rem);
    line-height: 1.08;
}

.author-skill-card p {
    margin: 0;
    color: var(--author-muted);
    font-size: 0.92rem;
    line-height: 1.48;
}

.author-skill-card:hover,
.author-skill-card:focus-visible {
    border-color: color-mix(in srgb, var(--skill-accent) 46%, rgba(17, 24, 39, 0.14));
    background:
        radial-gradient(circle at var(--skill-x) var(--skill-y), color-mix(in srgb, var(--skill-accent) 18%, transparent), transparent 42%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.62));
    box-shadow:
        0 24px 54px rgba(17, 24, 39, 0.12),
        0 0 0 4px color-mix(in srgb, var(--skill-accent) 10%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.92);
    transform: translateY(-0.45rem) scale(1.018);
}

.author-skill-card:hover::before,
.author-skill-card:focus-visible::before {
    opacity: 1;
    transform: translateX(28%);
}

.author-skill-card:hover::after,
.author-skill-card:focus-visible::after {
    opacity: 0.68;
    transform: scaleX(1);
}

.author-skill-card:hover .author-skill-card__index,
.author-skill-card:focus-visible .author-skill-card__index {
    background: color-mix(in srgb, var(--skill-accent) 92%, var(--author-ink));
    color: #ffffff;
    transform: translateY(-0.16rem);
}

/* ── Copy block ── */
.copy-block {
    display: grid;
    gap: var(--space-3);
}

.blog-preview,
.faq-section {
    isolation: isolate;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.018), rgba(255, 255, 255, 0)),
        radial-gradient(circle at 18% 18%, rgba(183, 243, 107, 0.06), transparent 32%),
        radial-gradient(circle at 82% 40%, rgba(107, 203, 255, 0.045), transparent 34%);
}

.blog-preview__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-4);
}

.blog-card {
    position: relative;
    display: grid;
    align-content: start;
    gap: var(--space-3);
    min-height: 100%;
    padding: clamp(1.1rem, 2vw, 1.5rem);
    border: 1px solid rgba(232, 249, 255, 0.12);
    border-radius: 0.75rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02)),
        rgba(6, 11, 17, 0.58);
    box-shadow:
        0 22px 70px rgba(0, 0, 0, 0.24),
        inset 0 1px 0 rgba(255, 255, 255, 0.065);
    overflow: hidden;
    transition:
        transform 260ms cubic-bezier(0.16, 1, 0.3, 1),
        border-color 260ms ease,
        box-shadow 260ms ease;
}

.blog-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 18% 0%, rgba(183, 243, 107, 0.12), transparent 36%),
        linear-gradient(90deg, transparent, rgba(107, 203, 255, 0.05), transparent);
    opacity: 0;
    pointer-events: none;
    transition: opacity 260ms ease;
}

.blog-card:hover,
.blog-card:focus-within {
    border-color: rgba(183, 243, 107, 0.28);
    box-shadow:
        0 28px 90px rgba(0, 0, 0, 0.34),
        0 0 34px rgba(183, 243, 107, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    transform: translateY(-4px);
}

.blog-card:hover::before,
.blog-card:focus-within::before {
    opacity: 1;
}

.blog-card > * {
    position: relative;
    z-index: 1;
}

.blog-card__meta {
    color: var(--accent);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.blog-card h3 {
    margin: 0;
    color: #f8fbff;
    font-family: var(--font-heading);
    font-size: clamp(1.2rem, 1.6vw, 1.55rem);
    line-height: 1.12;
}

.blog-card p {
    margin: 0;
    color: rgba(220, 230, 240, 0.72);
}

.faq-section__layout {
    display: grid;
    grid-template-columns: minmax(0, 0.78fr) minmax(22rem, 1.1fr);
    gap: clamp(2rem, 5vw, 5rem);
    align-items: start;
}

.faq-list {
    display: grid;
    gap: 0.8rem;
}

.faq-item {
    border: 1px solid rgba(232, 249, 255, 0.12);
    border-radius: 0.75rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.018)),
        rgba(6, 11, 17, 0.64);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.055);
    overflow: hidden;
}

.faq-item[open] {
    border-color: rgba(183, 243, 107, 0.28);
    box-shadow:
        0 18px 54px rgba(0, 0, 0, 0.22),
        0 0 28px rgba(183, 243, 107, 0.065),
        inset 0 1px 0 rgba(255, 255, 255, 0.075);
}

.faq-item summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    min-height: 3.5rem;
    padding: 0.95rem 1.15rem;
    color: #f8fbff;
    cursor: pointer;
    font-weight: 750;
    line-height: 1.25;
}

.faq-item summary::-webkit-details-marker {
    display: none;
}

.faq-item summary::after {
    content: "+";
    display: inline-grid;
    flex: 0 0 auto;
    place-items: center;
    width: 1.55rem;
    aspect-ratio: 1;
    border: 1px solid rgba(183, 243, 107, 0.28);
    border-radius: 50%;
    color: var(--accent);
    font-weight: 800;
    transition:
        transform 220ms ease,
        background 220ms ease;
}

.faq-item[open] summary::after {
    background: rgba(183, 243, 107, 0.1);
    transform: rotate(45deg);
}

.faq-item p {
    margin: 0;
    padding: 0 1.15rem 1.15rem;
    color: rgba(220, 230, 240, 0.72);
}

.contact-scene {
    --contact-pointer-x: 50%;
    --contact-pointer-y: 50%;
    --contact-depth-x: 0px;
    --contact-depth-y: 0px;
    --contact-glow-a-x: 0px;
    --contact-glow-a-y: 0px;
    --contact-glow-b-x: 0px;
    --contact-glow-b-y: 0px;
    isolation: isolate;
    min-height: 100vh;
    padding: clamp(7rem, 13vh, 9rem) 0 clamp(5.5rem, 10vh, 7rem);
    background:
        linear-gradient(90deg, rgba(4, 7, 11, 0.94), rgba(4, 8, 13, 0.68) 48%, rgba(4, 7, 11, 0.92)),
        radial-gradient(circle at var(--contact-pointer-x) var(--contact-pointer-y), rgba(183, 243, 107, 0.13), transparent 28%),
        url("../assets/background_general.webp") center / cover no-repeat,
        #05070b;
}

.contact-scene::before,
.contact-scene::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.contact-scene::before {
    background:
        radial-gradient(ellipse at 50% 45%, rgba(5, 8, 12, 0.05), rgba(5, 8, 12, 0.84) 68%, rgba(5, 8, 12, 0.96)),
        linear-gradient(180deg, rgba(5, 8, 12, 0.2), rgba(5, 8, 12, 0.88));
}

.contact-scene::after {
    background:
        linear-gradient(rgba(183, 243, 107, 0.028) 1px, transparent 1px),
        linear-gradient(90deg, rgba(107, 203, 255, 0.024) 1px, transparent 1px);
    background-size: 92px 92px;
    opacity: 0.2;
    transform: translate3d(var(--contact-depth-x), var(--contact-depth-y), 0);
    -webkit-mask-image: radial-gradient(ellipse at center, black 0, transparent 72%);
    mask-image: radial-gradient(ellipse at center, black 0, transparent 72%);
}

.contact-scene__backdrop {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

.contact-scene__glow,
.contact-scene__signal {
    position: absolute;
    display: block;
}

.contact-scene__glow {
    width: clamp(16rem, 38vw, 32rem);
    aspect-ratio: 1;
    border-radius: 50%;
    filter: blur(38px);
    mix-blend-mode: screen;
}

.contact-scene__glow--primary {
    left: 11%;
    bottom: 11%;
    background: radial-gradient(circle, rgba(183, 243, 107, 0.16), transparent 64%);
    transform: translate3d(var(--contact-glow-a-x), var(--contact-glow-a-y), 0);
}

.contact-scene__glow--secondary {
    right: 10%;
    top: 12%;
    background: radial-gradient(circle, rgba(107, 203, 255, 0.13), transparent 62%);
    transform: translate3d(var(--contact-glow-b-x), var(--contact-glow-b-y), 0);
}

.contact-scene__signal {
    height: 1px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(183, 243, 107, 0.42), rgba(107, 203, 255, 0.22), transparent);
    box-shadow: 0 0 22px rgba(183, 243, 107, 0.12);
    opacity: 0.54;
}

.contact-scene__signal--a {
    left: 8%;
    right: 48%;
    top: 34%;
}

.contact-scene__signal--b {
    left: 48%;
    right: 8%;
    bottom: 24%;
}

.contact-layout--focused {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    justify-items: center;
    text-align: center;
}

.contact-copy {
    justify-items: center;
    max-width: min(760px, 100%);
}

.contact-copy h2 {
    max-width: 18ch;
    margin: 0;
    color: #f8fbff;
    font-family: var(--font-heading);
    font-size: clamp(2.55rem, 5.2vw, 5.8rem);
    line-height: 0.96;
    text-wrap: balance;
    text-shadow:
        0 2px 18px rgba(0, 0, 0, 0.38),
        0 24px 78px rgba(0, 0, 0, 0.5);
}

.contact-copy__actions {
    justify-content: center;
    margin-top: clamp(1.25rem, 3vw, 2.5rem);
}

.contact-whatsapp {
    gap: 0.74rem;
    min-height: 3.6rem;
    padding-inline: 1.15rem 1.45rem;
    box-shadow:
        0 20px 48px rgba(183, 243, 107, 0.22),
        0 0 0 1px rgba(255, 255, 255, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.28);
    will-change: transform;
}

.contact-whatsapp__icon {
    display: inline-grid;
    place-items: center;
    width: 2rem;
    aspect-ratio: 1;
    border-radius: 50%;
    background: rgba(5, 8, 12, 0.14);
    color: #071007;
}

.contact-whatsapp__icon svg {
    width: 1.26rem;
    height: 1.26rem;
    fill: currentColor;
}

.contact-whatsapp:hover,
.contact-whatsapp:focus-visible {
    box-shadow:
        0 24px 58px rgba(183, 243, 107, 0.28),
        0 0 0 6px rgba(183, 243, 107, 0.11),
        inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

/* ── Split callout ── */
.split-callout__body {
    max-width: 42rem;
}

/* ── Flagship layout ── */
.flagship-layout {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    gap: var(--space-5);
    align-items: start;
    padding: clamp(1.25rem, 3vw, 2.5rem);
    border: 1px solid rgba(183, 243, 107, 0.12);
    border-radius: calc(var(--radius-lg) + 0.4rem);
    background:
        radial-gradient(circle at 12% 12%, rgba(183, 243, 107, 0.09), transparent 32%),
        radial-gradient(circle at 88% 18%, rgba(107, 203, 255, 0.06), transparent 30%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.012));
    box-shadow:
        0 26px 80px rgba(0, 0, 0, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.055);
    overflow: hidden;
}

.flagship-layout::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    border: 1px solid transparent;
    background: linear-gradient(135deg, rgba(183, 243, 107, 0.2), transparent 36%, rgba(107, 203, 255, 0.1)) border-box;
    opacity: 0.42;
    pointer-events: none;
    -webkit-mask:
        linear-gradient(#000 0 0) padding-box,
        linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

.flagship-layout > * {
    position: relative;
    z-index: 1;
}

.flagship-visual {
    display: grid;
    gap: var(--space-4);
}

.flagship-visual img {
    width: 100%;
    border-radius: var(--radius-md);
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.025);
    box-shadow:
        0 18px 54px rgba(0, 0, 0, 0.3),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

/* ── Page hero leads ── */
.page-hero__lead,
.detail-hero__lead {
    max-width: 48rem;
}

/* ── Summary grid ── */
.summary-grid {
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.8fr);
    align-items: start;
}

/* ── Detail grid ── */
.detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* ── Status strip ── */
.status-strip {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
}

/* ── Media stack ── */
.media-stack {
    display: grid;
    gap: var(--space-4);
}

/* ── Status card ── */
.status-card {
    position: relative;
    display: grid;
    gap: 0.35rem;
    overflow: hidden;
    border-color: rgba(183, 243, 107, 0.18);
    background:
        radial-gradient(circle at 90% 0%, rgba(183, 243, 107, 0.12), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.052), rgba(255, 255, 255, 0.018));
}

.status-card::after {
    content: "";
    position: absolute;
    left: var(--space-5);
    right: var(--space-5);
    bottom: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(183, 243, 107, 0.6), transparent);
    opacity: 0.55;
}

.status-value {
    font-family: var(--font-heading);
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--accent);
}

/* ── Path list ── */
.path-list {
    display: grid;
    gap: var(--space-3);
}

.path-list a {
    padding: var(--space-4);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.03);
}

.path-list strong {
    display: block;
    margin-bottom: 0.35rem;
}

/* Projects hub layout */
.progression-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-4);
}

.domain-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
}

.domain-card--wide {
    grid-column: 1 / -1;
}

.path-list--compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* ── Responsive ── */
@media (max-width: 960px) {
    .hero__grid,
    .author-scene__layout,
    .blog-preview__grid,
    .faq-section__layout,
    .summary-grid,
    .detail-grid,
    .flagship-layout,
    .flagship-card,
    .domain-grid,
    .path-list--compact {
        grid-template-columns: 1fr;
    }

    .progression-strip {
        grid-template-columns: 1fr;
    }

    .progression-step::after {
        top: auto;
        right: auto;
        left: var(--space-4);
        bottom: calc(var(--space-4) * -1);
        width: 1px;
        height: var(--space-4);
        background: linear-gradient(180deg, rgba(183, 243, 107, 0.5), transparent);
    }

    .domain-card--wide {
        grid-column: auto;
    }

    .hero__visual,
    .hero__panel {
        justify-self: start;
        width: 100%;
        transform: none;
    }

    .system-map {
        min-height: clamp(34rem, 78vw, 42rem);
    }

    .author-scene__layout {
        gap: var(--space-5);
    }

    .author-scene__portrait {
        margin-left: 0;
    }

    .author-portrait {
        min-height: clamp(22rem, 78vw, 30rem);
    }

    .hero--home::before {
        width: min(36rem, 92vw);
        opacity: 0.58;
    }

    .hero--home::after {
        opacity: 0.28;
    }

    .hero-orbit__grid {
        transform: none;
        background-size: 54px 54px;
        opacity: 0.34;
    }

    .hero-orbit__line--a {
        right: 16%;
        top: 22%;
    }

    .hero-orbit__line--b {
        left: 20%;
        bottom: 20%;
    }

    .page-atmosphere__grid {
        background-size: 72px 72px;
        transform: none;
    }

    .page-atmosphere__signal--a {
        right: 16%;
        top: 34%;
    }

    .page-atmosphere__signal--b {
        left: 18%;
        bottom: 18%;
    }

    .portrait-card__image-frame {
        width: clamp(160px, 48vw, 220px);
    }

    .profile-hub__header {
        align-items: center;
    }

    .snap-container {
        scroll-snap-type: y proximity;
    }

    .snap-section {
        min-height: auto;
        padding-top: var(--space-7);
        padding-bottom: var(--space-7);
    }

    .hero--home {
        padding-top: calc(var(--space-7) + 1rem);
        background-position: 58% center;
    }

    .contact-scene {
        background-position: center;
    }

    .faq-section__layout {
        gap: var(--space-5);
    }
}

@media (max-width: 620px) {
    .hero__grid {
        width: min(100%, calc(100vw - 2rem));
    }

    .hero--home {
        padding-top: calc(var(--space-7) + 0.75rem);
    }

    .hero__content h1 {
        margin-top: var(--space-3);
        font-size: 2.45rem;
        line-height: 1.02;
    }

    .hero__lead {
        margin-top: var(--space-3);
        font-size: 1rem;
        line-height: 1.55;
    }

    .hero__signal-list {
        gap: 0.55rem;
        margin-top: var(--space-4);
    }

    .hero__signal-list span {
        min-height: 1.85rem;
        padding: 0.3rem 0.58rem;
        font-size: 0.68rem;
        letter-spacing: 0.04em;
    }

    .hero__content .button-row {
        margin-top: var(--space-4);
        gap: var(--space-2);
    }

    .blog-card,
    .faq-item summary,
    .faq-item p {
        padding-inline: 1rem;
    }

    .hero__content::before {
        inset: -8% -5% -7%;
    }

    .system-map {
        min-height: 45rem;
        padding: 0.9rem;
        border-radius: var(--radius-md);
        transform: none;
    }

    .system-map__rail {
        top: 4rem;
    }

    .system-map__nodes {
        inset: 5.4rem 0.9rem 4rem;
        grid-template-columns: 1fr;
        grid-template-rows: repeat(4, minmax(0, 1fr));
        gap: 0.9rem;
    }

    .system-map__signal--a,
    .system-map__signal--b,
    .system-map__signal--c,
    .system-map__core {
        opacity: 0.36;
    }

    .system-map__core {
        width: 5.9rem;
        font-size: 0.72rem;
    }

    .system-node {
        min-height: 6.7rem;
        padding: 0.85rem;
        transform: none;
    }

    .system-node::before {
        left: auto;
        right: 0.85rem;
        top: 0.85rem;
    }

    .system-node:hover,
    .system-node:focus-visible,
    .system-node.is-active {
        transform: translateY(-3px);
    }

    .system-map__status,
    .system-map__legend {
        font-size: 0.58rem;
        letter-spacing: 0.08em;
    }

    .author-portrait figcaption {
        right: 0;
        bottom: 5%;
    }

    .author-skill-grid {
        grid-template-columns: 1fr;
    }

    .author-skill-card {
        min-height: auto;
    }

    .contact-copy h2 {
        max-width: 12ch;
        font-size: clamp(2.4rem, 13vw, 3.8rem);
    }

    .contact-whatsapp {
        width: 100%;
        max-width: 20rem;
        justify-content: center;
    }
}

@media (prefers-reduced-motion: reduce) {
    body[data-nav-root="home"],
    .page-atmosphere,
    .page-atmosphere__grid,
    .page-atmosphere__glow,
    .page-atmosphere__signal,
    .snap-section:not(.hero--home)::before,
    .snap-section:not(.hero--home)::after,
    .hero--home,
    .hero--home::before,
    .hero--home::after,
    .hero-orbit,
    .hero-orbit__grid,
    .hero-orbit__glow,
    .hero-orbit__line,
    .hero__visual,
    .hero__panel,
    .system-map,
    .system-map__rail-flow,
    .system-node:hover,
    .system-node:focus-visible,
    .system-node.is-active,
    .author-portrait,
    .author-portrait::before,
    .author-portrait::after,
    .author-portrait:hover,
    .author-portrait:hover::before,
    .author-portrait:hover::after,
    .author-portrait:hover .author-portrait__axis,
    .author-portrait:hover .author-portrait__halo,
    .author-portrait:hover img,
    .author-portrait:hover figcaption,
    .author-expertise span:hover,
    .author-availability:hover,
    .author-availability:focus-visible,
    .author-skill-card:hover,
    .author-skill-card:focus-visible,
    .author-skill-card:hover .author-skill-card__index,
    .author-skill-card:focus-visible .author-skill-card__index,
    .contact-scene,
    .contact-scene::after,
    .contact-scene__glow,
    .contact-scene__signal,
    .contact-whatsapp,
    .contact-whatsapp:hover,
    .contact-whatsapp:focus-visible,
    .portrait-card--premium:hover,
    .portrait-card--premium:focus-within,
    .portrait-card--premium:hover .portrait-card__image-frame,
    .portrait-card--premium:focus-within .portrait-card__image-frame,
    .portrait-card--premium:hover .portrait-card__image-frame img,
    .portrait-card--premium:focus-within .portrait-card__image-frame img,
    .portrait-card--premium:hover .profile-hub,
    .portrait-card--premium:focus-within .profile-hub,
    .profile-hub__tags span:hover,
    .profile-hub__tags span:focus-visible,
    .profile-hub__status:hover,
    .profile-hub__status:focus-visible {
        animation: none;
        transform: none;
        transition: none;
    }

    [data-hero-entrance] .hero__content > .eyebrow,
    [data-hero-entrance] .hero__content > h1,
    [data-hero-entrance] .hero__lead,
    [data-hero-entrance] .hero__signal-list span,
    [data-hero-entrance] .hero__content .button,
    [data-hero-entrance] .hero__visual,
    [data-hero-entrance] .hero__panel,
    [data-hero-entrance].hero--entered .hero__content > h1,
    [data-hero-entrance].hero--entered .hero__signal-list span,
    [data-hero-entrance].hero--entered .hero__visual,
    [data-hero-entrance].hero--entered .hero__panel {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .hero--home {
        --hero-mouse-x: 50%;
        --hero-mouse-y: 44%;
        --hero-shift-x: 0px;
        --hero-shift-y: 0px;
        --hero-orbit-opacity: 1;
        --hero-aura-opacity: 0.76;
        --hero-line-opacity: 0.55;
        --hero-scroll-lift: 0px;
        --hero-aura-x: 0px;
        --hero-aura-y: 0px;
        --hero-line-x: 0px;
        --hero-line-y: 0px;
        --hero-grid-x: 0px;
        --hero-grid-y: 0px;
        --hero-secondary-x: 0px;
        --hero-secondary-y: 0px;
        --hero-line-a-x: 0px;
        --hero-line-a-y: 0px;
        --hero-line-b-x: 0px;
        --hero-line-b-y: 0px;
        --hero-panel-x: 0px;
        --hero-panel-y: 0px;
        --page-mouse-x: 50%;
        --page-mouse-y: 42%;
        --page-shift-x: 0px;
        --page-shift-y: 0px;
        --page-scroll-ratio: 0;
        --page-depth-opacity: 0.62;
        --page-grid-x: 0px;
        --page-grid-y: 0px;
        --page-glow-primary-x: 0px;
        --page-glow-primary-y: 0px;
        --page-glow-secondary-x: 0px;
        --page-glow-secondary-y: 0px;
        --page-signal-a-x: 0px;
        --page-signal-a-y: 0px;
        --page-signal-b-x: 0px;
        --page-signal-b-y: 0px;
    }
}

/* Freelance conversion foundation */
.hero__grid--editorial {
    grid-template-columns: minmax(0, 45rem);
    justify-content: start;
}

.hero__grid--editorial .hero__content {
    max-width: 39rem;
}

.hero__grid--editorial .hero__content h1 {
    max-width: 12ch;
    font-size: clamp(2.55rem, 4.15vw, 4.65rem);
}

.hero__grid--editorial .hero__lead {
    max-width: 31rem;
    font-size: clamp(1rem, 1.35vw, 1.18rem);
}

.hero__grid--editorial .hero__signal-list {
    max-width: 33rem;
}

.hero__grid--editorial .hero__signal-list span {
    flex: 1 1 auto;
}

.hero__grid--editorial .button-row {
    max-width: 34rem;
}

[data-hero-entrance] .hero__grid--editorial .hero__signal-list span,
[data-hero-entrance] .hero__grid--editorial .hero__content .button {
    opacity: 1;
    transform: none;
}

/* AI Product Control Room
   Customize the hero palette here if the personal brand direction changes. */
.hero--control-room {
    --hero-control-lime: #b7f36b;
    --hero-control-cyan: #6bcbff;
    --hero-control-amber: #ffb84d;
    --hero-core-shadow: rgba(183, 243, 107, 0.22);
    display: flex;
    align-items: center;
    min-height: calc(100svh - 3rem);
    padding: 7.5rem 0 4.5rem;
    background:
        radial-gradient(circle at var(--hero-mouse-x) var(--hero-mouse-y), rgba(183, 243, 107, 0.16), transparent 28rem),
        radial-gradient(circle at 78% 42%, rgba(107, 203, 255, 0.18), transparent 26rem),
        radial-gradient(circle at 15% 18%, rgba(255, 184, 77, 0.09), transparent 24rem),
        linear-gradient(115deg, rgba(2, 4, 8, 0.98) 0%, rgba(5, 10, 16, 0.92) 46%, rgba(4, 8, 13, 0.98) 100%),
        #05070b;
}

.hero--control-room::before {
    left: max(-2rem, calc((100vw - var(--shell)) / 2 - 8rem));
    top: 1%;
    width: min(70rem, 94vw);
    height: min(46rem, 78vh);
    background:
        radial-gradient(ellipse at 32% 38%, rgba(183, 243, 107, 0.24), transparent 54%),
        radial-gradient(circle at 72% 54%, rgba(107, 203, 255, 0.16), transparent 45%),
        radial-gradient(circle at var(--hero-mouse-x) var(--hero-mouse-y), rgba(255, 255, 255, 0.1), transparent 42%);
    filter: blur(62px);
}

.hero--control-room::after {
    top: 16%;
    height: 28rem;
    background:
        linear-gradient(105deg, transparent 18%, rgba(183, 243, 107, 0.11) 43%, rgba(107, 203, 255, 0.12) 55%, transparent 78%),
        linear-gradient(90deg, rgba(2, 5, 9, 0.76), transparent 48%, rgba(2, 5, 9, 0.4));
}

.hero--control-room .hero-orbit__grid {
    inset: -12% -7%;
    background:
        linear-gradient(rgba(183, 243, 107, 0.032) 1px, transparent 1px),
        linear-gradient(90deg, rgba(107, 203, 255, 0.028) 1px, transparent 1px);
    background-size: 72px 72px;
    -webkit-mask-image: radial-gradient(ellipse at 58% 48%, black 0, transparent 72%);
    mask-image: radial-gradient(ellipse at 58% 48%, black 0, transparent 72%);
    opacity: 0.58;
}

.hero--control-room .hero-orbit__glow--primary {
    opacity: 0.72;
}

.hero--control-room .hero-orbit__glow--secondary {
    opacity: 0.68;
}

.hero--control-room .hero-orbit__line {
    opacity: 0.74;
}

.hero-orbit__particle {
    position: absolute;
    width: 0.34rem;
    aspect-ratio: 1;
    border-radius: 999px;
    background: var(--hero-control-lime);
    box-shadow:
        0 0 18px rgba(183, 243, 107, 0.55),
        0 0 38px rgba(107, 203, 255, 0.18);
    opacity: 0.58;
    animation: hero-particle-drift 9s ease-in-out infinite alternate;
}

.hero-orbit__particle--a {
    left: 16%;
    top: 28%;
}

.hero-orbit__particle--b {
    right: 22%;
    top: 18%;
    animation-delay: -2.6s;
}

.hero-orbit__particle--c {
    right: 12%;
    bottom: 24%;
    animation-delay: -4.8s;
}

.hero-orbit__particle--d {
    left: 48%;
    bottom: 17%;
    animation-delay: -6.2s;
}

@keyframes hero-particle-drift {
    from {
        transform: translate3d(-8px, 6px, 0) scale(0.82);
        opacity: 0.36;
    }

    to {
        transform: translate3d(10px, -12px, 0) scale(1.12);
        opacity: 0.78;
    }
}

.hero__grid--control-room {
    grid-template-columns: minmax(0, 0.92fr) minmax(23rem, 0.96fr);
    gap: clamp(2rem, 5vw, 5rem);
    align-items: center;
}

.hero__content--control {
    max-width: 41rem;
}

.hero__content--control::before {
    display: none;
}

.hero__content--control .eyebrow {
    color: rgba(217, 255, 177, 0.92);
    text-shadow: 0 0 22px rgba(183, 243, 107, 0.22);
}

.hero__content--control h1 {
    max-width: 12ch;
    margin-top: 1.35rem;
    font-size: 4.65rem;
    line-height: 0.96;
    letter-spacing: 0;
}

.hero__title-accent {
    display: block;
    color: var(--hero-control-lime);
    text-shadow:
        0 0 24px rgba(183, 243, 107, 0.24),
        0 18px 64px rgba(0, 0, 0, 0.38);
}

.hero__content--control .hero__lead {
    max-width: 37rem;
    margin-top: 1.45rem;
    color: rgba(234, 243, 250, 0.78);
    font-size: 1.14rem;
    line-height: 1.72;
}

.hero__signal-list--chips {
    max-width: 39rem;
    gap: 0.7rem;
}

.hero__signal-list--chips span {
    --magnetic-x: 0px;
    --magnetic-y: 0px;
    min-height: 2.25rem;
    padding: 0.42rem 0.78rem;
    border-color: rgba(183, 243, 107, 0.24);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025)),
        rgba(6, 13, 18, 0.58);
    color: rgba(239, 247, 252, 0.84);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.07),
        0 0 0 1px rgba(107, 203, 255, 0.035);
    transition:
        border-color 220ms ease,
        color 220ms ease,
        box-shadow 220ms ease,
        transform 220ms cubic-bezier(0.16, 1, 0.3, 1);
}

.hero--control-room.hero--entered .hero__signal-list--chips span {
    transform: translate3d(var(--magnetic-x), var(--magnetic-y), 0);
}

.hero--control-room.hero--entered .hero__signal-list--chips span:hover,
.hero--control-room.hero--entered .hero__signal-list--chips span:focus-visible {
    border-color: rgba(220, 255, 182, 0.62);
    color: #f8fbff;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        0 0 26px rgba(183, 243, 107, 0.14),
        0 0 44px rgba(107, 203, 255, 0.06);
    transform: translate3d(var(--magnetic-x), calc(var(--magnetic-y) - 3px), 0);
}

.hero-cta {
    --magnetic-x: 0px;
    --magnetic-y: 0px;
    min-height: 3.1rem;
    isolation: isolate;
}

.hero--control-room.hero--entered .hero-cta {
    transform: translate3d(var(--magnetic-x), var(--magnetic-y), 0);
}

.hero--control-room.hero--entered .hero-cta:hover,
.hero--control-room.hero--entered .hero-cta:focus-visible {
    transform: translate3d(var(--magnetic-x), calc(var(--magnetic-y) - 2px), 0);
}

.hero-cta--primary {
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.55), transparent 36%),
        linear-gradient(135deg, #d8ff9a, var(--hero-control-lime) 46%, #82d541);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.42),
        0 18px 44px rgba(183, 243, 107, 0.18),
        0 0 0 1px rgba(244, 255, 225, 0.24);
}

.hero-cta--primary::after {
    content: "";
    position: absolute;
    inset: -32% -20%;
    z-index: -1;
    background: linear-gradient(90deg, transparent, rgba(244, 255, 225, 0.68), transparent);
    opacity: 0;
    transform: translateX(-45%) rotate(8deg);
    transition:
        opacity 220ms ease,
        transform 520ms cubic-bezier(0.16, 1, 0.3, 1);
}

.hero-cta--primary:hover::after,
.hero-cta--primary:focus-visible::after {
    opacity: 0.52;
    transform: translateX(45%) rotate(8deg);
}

.hero-cta__energy {
    position: absolute;
    inset: -0.35rem;
    z-index: -2;
    border-radius: inherit;
    background: radial-gradient(circle, rgba(183, 243, 107, 0.22), transparent 62%);
    opacity: 0;
    filter: blur(10px);
    transition: opacity 220ms ease;
}

.hero-cta--primary:hover .hero-cta__energy,
.hero-cta--primary:focus-visible .hero-cta__energy {
    opacity: 1;
}

.hero__ai-stage {
    position: relative;
    justify-self: stretch;
    min-height: clamp(28rem, 43vw, 40rem);
    width: 100%;
    overflow: visible;
    transform-style: preserve-3d;
}

.hero__ai-stage::before {
    content: "";
    position: absolute;
    inset: 8% 0 2%;
    z-index: 0;
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 50%, rgba(183, 243, 107, 0.22), transparent 44%),
        radial-gradient(circle at 58% 45%, rgba(107, 203, 255, 0.22), transparent 52%);
    filter: blur(34px);
    opacity: 0.72;
}

.hero__ai-stage::after {
    content: "";
    position: absolute;
    left: 16%;
    right: 16%;
    bottom: 9%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(183, 243, 107, 0.48), rgba(107, 203, 255, 0.32), transparent);
    box-shadow: 0 0 26px rgba(183, 243, 107, 0.22);
    opacity: 0.8;
}

.hero__ai-canvas {
    position: absolute;
    inset: -7%;
    z-index: 2;
    display: block;
    width: 114%;
    height: 114%;
    opacity: 0;
    filter: saturate(1.08);
    transition: opacity 620ms ease;
}

.hero__ai-stage.ai-core--webgl .hero__ai-canvas {
    opacity: 1;
}

.ai-core-fallback {
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 1;
    width: min(31rem, 92%);
    aspect-ratio: 1;
    transform: translate(-50%, -50%);
    transition: opacity 480ms ease;
}

.hero__ai-stage.ai-core--webgl .ai-core-fallback {
    opacity: 0;
}

.ai-core-fallback__ring,
.ai-core-fallback__core,
.ai-core-fallback__node {
    position: absolute;
    display: block;
    border-radius: 999px;
}

.ai-core-fallback__ring {
    inset: 12%;
    border: 1px solid rgba(183, 243, 107, 0.42);
    box-shadow:
        0 0 34px rgba(183, 243, 107, 0.12),
        inset 0 0 28px rgba(107, 203, 255, 0.08);
    animation: ai-core-fallback-spin 18s linear infinite;
}

.ai-core-fallback__ring--middle {
    inset: 22%;
    border-color: rgba(107, 203, 255, 0.38);
    transform: rotateX(64deg) rotateZ(18deg);
    animation-duration: 14s;
    animation-direction: reverse;
}

.ai-core-fallback__ring--inner {
    inset: 34%;
    border-color: rgba(255, 255, 255, 0.22);
    transform: rotateY(68deg) rotateZ(-22deg);
    animation-duration: 11s;
}

.ai-core-fallback__core {
    inset: 39%;
    background:
        radial-gradient(circle at 34% 28%, #ffffff, transparent 20%),
        radial-gradient(circle, #d9ff9f 0%, #b7f36b 44%, rgba(107, 203, 255, 0.18) 72%, transparent 74%);
    box-shadow:
        0 0 34px rgba(183, 243, 107, 0.36),
        0 0 70px rgba(107, 203, 255, 0.16);
}

.ai-core-fallback__node {
    width: 0.7rem;
    aspect-ratio: 1;
    background: #f4ffe1;
    box-shadow:
        0 0 18px rgba(244, 255, 225, 0.52),
        0 0 34px rgba(183, 243, 107, 0.32);
}

.ai-core-fallback__node--a {
    left: 23%;
    top: 24%;
}

.ai-core-fallback__node--b {
    right: 20%;
    top: 32%;
}

.ai-core-fallback__node--c {
    right: 29%;
    bottom: 18%;
}

.ai-core-fallback__node--d {
    left: 21%;
    bottom: 28%;
}

@keyframes ai-core-fallback-spin {
    to {
        rotate: 360deg;
    }
}

@media (max-width: 1160px) {
    .hero__content--control h1 {
        font-size: 4rem;
    }
}

@media (min-width: 961px) and (max-height: 780px) {
    .hero--control-room {
        padding-top: 5.4rem;
        padding-bottom: 1.85rem;
    }

    .hero__grid--control-room {
        gap: clamp(1.5rem, 3.8vw, 3.5rem);
    }

    .hero__content--control h1 {
        margin-top: 0.95rem;
        font-size: clamp(3.2rem, 4.35vw, 3.8rem);
        line-height: 0.98;
    }

    .hero__content--control .hero__lead {
        margin-top: 1rem;
        font-size: 1rem;
        line-height: 1.55;
    }

    .hero__signal-list--chips {
        margin-top: 1.35rem;
    }

    .hero__signal-list--chips span {
        min-height: 2rem;
        padding: 0.32rem 0.66rem;
        font-size: 0.68rem;
    }

    .hero__content--control .button-row {
        margin-top: 1.35rem;
    }

    .hero-cta {
        min-height: 2.85rem;
        padding-block: 0.72rem;
    }

    .hero__ai-stage {
        min-height: clamp(22rem, 34vw, 27rem);
    }
}

@media (max-width: 960px) {
    .hero--control-room {
        min-height: calc(100svh - 3rem);
        padding-top: 7rem;
        padding-bottom: 3rem;
    }

    .hero__grid--control-room {
        grid-template-columns: 1fr;
        gap: 1.5rem;
        text-align: center;
    }

    .hero__content--control {
        justify-items: center;
        max-width: 44rem;
        margin: 0 auto;
    }

    .hero__content--control h1,
    .hero__content--control .hero__lead {
        max-width: 100%;
    }

    .hero__signal-list--chips,
    .hero__content--control .button-row {
        justify-content: center;
    }

    .hero__ai-stage {
        min-height: clamp(22rem, 62vw, 30rem);
        margin-top: -0.75rem;
        opacity: 0.72;
    }
}

@media (max-width: 620px) {
    .hero--control-room {
        display: grid;
        align-items: center;
        padding-top: 6.6rem;
        padding-bottom: 2.75rem;
    }

    .hero__content--control h1 {
        max-width: 11ch;
        font-size: 2.45rem;
        line-height: 1.02;
    }

    .hero__content--control .hero__lead {
        font-size: 1rem;
        line-height: 1.6;
    }

    .hero__signal-list--chips span {
        flex: 0 1 auto;
        min-height: 2rem;
        font-size: 0.66rem;
    }

    .hero__content--control .button-row {
        width: 100%;
    }

    .hero__content--control .hero-cta {
        width: 100%;
    }

    .hero__ai-stage {
        position: absolute;
        left: 4%;
        right: 4%;
        bottom: 0.8rem;
        z-index: 0;
        min-height: 17rem;
        opacity: 0.34;
        pointer-events: none;
    }

    .hero__content--control {
        position: relative;
        z-index: 2;
    }
}

@media (prefers-reduced-motion: reduce) {
    .hero-orbit__particle,
    .ai-core-fallback__ring,
    .hero-cta--primary::after,
    .hero-cta__energy,
    .hero--control-room.hero--entered .hero__signal-list--chips span,
    .hero--control-room.hero--entered .hero-cta,
    .hero--control-room.hero--entered .hero__signal-list--chips span:hover,
    .hero--control-room.hero--entered .hero__signal-list--chips span:focus-visible,
    .hero--control-room.hero--entered .hero-cta:hover,
    .hero--control-room.hero--entered .hero-cta:focus-visible {
        animation: none;
        transform: none;
        transition: none;
    }
}

.system-workflow {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 15% 25%, rgba(183, 243, 107, 0.08), transparent 30rem),
        radial-gradient(circle at 85% 70%, rgba(107, 203, 255, 0.08), transparent 28rem);
}

.system-workflow__layout {
    display: grid;
    gap: var(--space-5);
}

.system-workflow__intro {
    max-width: 48rem;
}

.system-workflow__intro h2 {
    margin-top: var(--space-2);
}

.system-workflow__intro p:last-child {
    max-width: 42rem;
    margin-top: var(--space-3);
    color: var(--text-muted);
}

.system-workflow__visual {
    width: min(100%, 72rem);
    margin-inline: auto;
}

.system-workflow .system-map {
    min-height: 38rem;
}

.system-workflow__cta {
    display: flex;
    justify-content: center;
}

@media (max-width: 620px) {
    .system-workflow .system-map {
        min-height: 45rem;
    }

    .system-workflow__cta .button {
        width: 100%;
        justify-content: center;
        text-align: center;
    }
}

.system-workflow .system-map {
    --map-pointer-x: 50%;
    --map-pointer-y: 50%;
    aspect-ratio: 1672 / 941;
    min-height: 0;
    padding: 0;
    border-color: rgba(232, 249, 255, 0.18);
    border-radius: clamp(1.1rem, 2vw, 2.2rem);
    background:
        radial-gradient(circle at var(--map-pointer-x) var(--map-pointer-y), rgba(232, 249, 255, 0.16), transparent 20%),
        linear-gradient(115deg, rgba(183, 243, 107, 0.08), transparent 28%, rgba(107, 203, 255, 0.06) 72%, transparent),
        url("../assets/method-ai-aplicada.png") center / cover no-repeat;
    box-shadow:
        0 34px 120px rgba(0, 0, 0, 0.54),
        0 0 72px rgba(107, 203, 255, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.system-workflow .system-map:hover,
.system-workflow .system-map:focus-within {
    border-color: rgba(232, 249, 255, 0.34);
    box-shadow:
        0 42px 140px rgba(0, 0, 0, 0.58),
        0 0 94px rgba(107, 203, 255, 0.18),
        0 0 58px rgba(183, 243, 107, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.system-workflow .system-map::before {
    inset: 0;
    z-index: 1;
    border: 0;
    border-radius: inherit;
    background:
        linear-gradient(90deg, transparent, rgba(183, 243, 107, 0.18), rgba(107, 203, 255, 0.2), transparent),
        repeating-linear-gradient(180deg, rgba(255, 255, 255, 0.022) 0 1px, transparent 1px 6px);
    opacity: 0.42;
    transform: translateX(-72%);
    animation: method-map-scan 7s ease-in-out infinite;
}

.system-workflow .system-map::after {
    inset: 0;
    z-index: 2;
    height: auto;
    background:
        radial-gradient(circle at var(--map-pointer-x) var(--map-pointer-y), rgba(232, 249, 255, 0.22), transparent 17%),
        radial-gradient(circle at 50% 50%, rgba(183, 243, 107, 0.12), transparent 22%),
        linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(0, 0, 0, 0.2));
    box-shadow: none;
    opacity: 0.68;
    mix-blend-mode: screen;
    transform: none;
}

.system-workflow .system-map__nodes {
    position: absolute;
    inset: 0;
    z-index: 4;
    display: block;
    margin: 0;
    padding: 0;
    list-style: none;
}

.system-workflow .system-node {
    --node-color: var(--accent);
    position: absolute;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 0.28rem;
    inline-size: 22%;
    block-size: 21.7%;
    min-height: 0;
    padding: clamp(0.72rem, 1vw, 1.05rem);
    border: 1px solid transparent;
    border-radius: clamp(0.85rem, 1.2vw, 1.35rem);
    background:
        radial-gradient(circle at var(--map-pointer-x) var(--map-pointer-y), color-mix(in srgb, var(--node-color) 10%, transparent), transparent 42%),
        linear-gradient(180deg, transparent 18%, rgba(4, 9, 14, 0.12) 58%, rgba(4, 9, 14, 0.58));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
    cursor: pointer;
    outline: 0;
    overflow: hidden;
    transform: translateZ(28px);
    transition:
        opacity 260ms ease,
        transform 320ms cubic-bezier(0.16, 1, 0.3, 1),
        border-color 260ms ease,
        background 260ms ease,
        box-shadow 260ms ease,
        filter 260ms ease;
}

.system-workflow .system-node--context {
    --node-color: var(--accent-red);
    left: 14.8%;
    top: 17.1%;
}

.system-workflow .system-node--product {
    --node-color: var(--accent-blue);
    left: 63.5%;
    top: 17.1%;
}

.system-workflow .system-node--interface {
    --node-color: var(--accent);
    left: 14.8%;
    top: 58.3%;
}

.system-workflow .system-node--operation {
    --node-color: var(--accent-amber);
    left: 63.5%;
    top: 58.3%;
}

.system-workflow .system-node::before {
    content: "";
    position: absolute;
    top: 50%;
    z-index: 3;
    inline-size: 0.62rem;
    aspect-ratio: 1;
    border-radius: 50%;
    background: var(--node-color);
    box-shadow:
        0 0 0 7px color-mix(in srgb, var(--node-color) 10%, transparent),
        0 0 26px color-mix(in srgb, var(--node-color) 72%, transparent);
    transform: translateY(-50%);
    animation: method-node-pulse 2.5s ease-in-out infinite;
}

.system-workflow .system-node--context::before,
.system-workflow .system-node--interface::before {
    right: -0.28rem;
}

.system-workflow .system-node--product::before,
.system-workflow .system-node--operation::before {
    left: -0.28rem;
}

.system-workflow .system-node::after {
    content: "";
    position: absolute;
    inset: -35% auto -35% -55%;
    z-index: 1;
    inline-size: 48%;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.32), transparent);
    opacity: 0;
    transform: skewX(-18deg) translateX(0);
    pointer-events: none;
    transition:
        opacity 260ms ease,
        transform 620ms cubic-bezier(0.16, 1, 0.3, 1);
}

.system-workflow .system-node__index,
.system-workflow .system-node__title,
.system-workflow .system-node__note {
    position: relative;
    z-index: 2;
    opacity: 0;
    transform: translateY(0.5rem);
    transition:
        opacity 220ms ease,
        transform 260ms ease;
    text-shadow: 0 1px 18px rgba(0, 0, 0, 0.76);
}

.system-workflow .system-node__index {
    color: color-mix(in srgb, var(--node-color) 78%, white);
}

.system-workflow .system-node__title {
    font-size: clamp(1rem, 1.3vw, 1.24rem);
}

.system-workflow .system-node__note {
    max-width: 16rem;
    color: rgba(237, 246, 255, 0.78);
}

.system-workflow .system-map.is-inspecting .system-node:not(.is-active) {
    opacity: 0.62;
    filter: saturate(0.76);
}

.system-workflow .system-node:hover,
.system-workflow .system-node:focus-visible,
.system-workflow .system-node.is-active {
    opacity: 1;
    outline: 0;
    border-color: color-mix(in srgb, var(--node-color) 54%, rgba(255, 255, 255, 0.22));
    background:
        radial-gradient(circle at var(--map-pointer-x) var(--map-pointer-y), color-mix(in srgb, var(--node-color) 20%, transparent), transparent 44%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(4, 9, 14, 0.76));
    box-shadow:
        0 22px 64px rgba(0, 0, 0, 0.42),
        0 0 34px color-mix(in srgb, var(--node-color) 26%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    transform: translateY(-0.42rem) translateZ(58px) scale(1.018);
}

.system-workflow .system-node:hover::after,
.system-workflow .system-node:focus-visible::after,
.system-workflow .system-node.is-active::after {
    opacity: 1;
    transform: skewX(-18deg) translateX(330%);
}

.system-workflow .system-node:hover .system-node__index,
.system-workflow .system-node:hover .system-node__title,
.system-workflow .system-node:hover .system-node__note,
.system-workflow .system-node:focus-visible .system-node__index,
.system-workflow .system-node:focus-visible .system-node__title,
.system-workflow .system-node:focus-visible .system-node__note,
.system-workflow .system-node.is-active .system-node__index,
.system-workflow .system-node.is-active .system-node__title,
.system-workflow .system-node.is-active .system-node__note {
    opacity: 1;
    transform: translateY(0);
}

@keyframes method-map-scan {
    0%, 18% {
        opacity: 0;
        transform: translateX(-76%);
    }

    42%, 54% {
        opacity: 0.48;
    }

    100% {
        opacity: 0;
        transform: translateX(76%);
    }
}

@keyframes method-node-pulse {
    0%, 100% {
        transform: translateY(-50%) scale(0.94);
    }

    50% {
        transform: translateY(-50%) scale(1.16);
    }
}

@media (max-width: 760px) {
    .system-workflow .system-map {
        aspect-ratio: auto;
        min-height: clamp(34rem, 128vw, 44rem);
        background-size: cover;
    }

    .system-workflow .system-map__nodes {
        inset: clamp(0.85rem, 3vw, 1.1rem);
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: repeat(4, minmax(0, 1fr));
        gap: 0.75rem;
    }

    .system-workflow .system-node,
    .system-workflow .system-node--context,
    .system-workflow .system-node--product,
    .system-workflow .system-node--interface,
    .system-workflow .system-node--operation {
        position: relative;
        left: auto;
        top: auto;
        inline-size: auto;
        block-size: auto;
        padding: 1rem;
        border-color: rgba(232, 249, 255, 0.18);
        background:
            radial-gradient(circle at 88% 18%, color-mix(in srgb, var(--node-color) 16%, transparent), transparent 38%),
            linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(4, 9, 14, 0.72));
        transform: none;
        -webkit-backdrop-filter: blur(8px) saturate(1.1);
        backdrop-filter: blur(8px) saturate(1.1);
    }

    .system-workflow .system-node::before,
    .system-workflow .system-node--context::before,
    .system-workflow .system-node--product::before,
    .system-workflow .system-node--interface::before,
    .system-workflow .system-node--operation::before {
        left: auto;
        right: 1rem;
        top: 1rem;
        transform: none;
    }

    .system-workflow .system-node__index,
    .system-workflow .system-node__title,
    .system-workflow .system-node__note {
        opacity: 1;
        transform: none;
    }

    .system-workflow .system-node:hover,
    .system-workflow .system-node:focus-visible,
    .system-workflow .system-node.is-active {
        transform: translateY(-3px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .system-workflow .system-map::before,
    .system-workflow .system-node::before,
    .system-workflow .system-node::after {
        animation: none;
        transition: none;
    }
}
