@import"https://fonts.googleapis.com/css2?family=Oxanium:wght@500;700;800&family=JetBrains+Mono:wght@400;600&display=swap";:root {
    --bg-0: #030611;
    --bg-1: #071126;
    --bg-2: #0f1c31;
    --panel: rgba(4, 17, 10, .84);
    --panel-line: rgba(138, 255, 90, .28);
    --ink: #eaffdf;
    --ink-dim: #9ac694;
    --cyan: #57e96d;
    --lime: #b8ff6a;
    --rose: #ff5f7f;
    --violet: #7b8cff
}

* {
    box-sizing: border-box
}

html,body,#app {
    margin: 0;
    width: 100%;
    min-height: 100%
}

body {
    font-family: JetBrains Mono,monospace;
    color: var(--ink);
    background: radial-gradient(circle at 20% 16%,rgba(138,255,90,.16),transparent 34%),radial-gradient(circle at 82% 86%,rgba(73,215,87,.13),transparent 38%),linear-gradient(145deg,#030806,#06110b 50%,#070f08);
    overflow-x: hidden
}

.page {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    padding: 34px clamp(14px,4vw,42px) 52px
}

.hacker-intro {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 50;
    display: grid;
    place-items: center;
    overflow: hidden;
    background: radial-gradient(circle at 16% 16%,rgba(90,255,90,.15),transparent 42%),radial-gradient(circle at 88% 78%,rgba(90,255,140,.08),transparent 40%),#040807
}

.hacker-intro:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: linear-gradient(120deg,#04120a38,#020a07d1),repeating-linear-gradient(90deg,rgba(140,255,145,.04) 0,rgba(140,255,145,.04) 1px,transparent 1px,transparent 34px),repeating-linear-gradient(180deg,rgba(140,255,145,.03) 0,rgba(140,255,145,.03) 1px,transparent 1px,transparent 34px);
    pointer-events: none
}

.matrix-hud {
    position: absolute;
    left: 24px;
    top: 22px;
    z-index: 2;
    border-radius: 10px;
    border: 1px solid rgba(138,255,90,.32);
    border-left: 3px solid rgba(138,255,90,.75);
    background: #020e07bd;
    padding: 10px 12px;
    box-shadow: 0 0 24px #8aff5a26
}

.matrix-hud p {
    margin: 0;
    color: #9dff98;
    font-size: .72rem;
    line-height: 1.7;
    letter-spacing: .08em
}

.matrix-hud p:last-child {
    color: #ff4f5f;
    text-shadow: 0 0 8px rgba(255,79,95,.75)
}

.matrix-rain {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden
}

.matrix-rain span {
    position: absolute;
    top: -40%;
    left: calc(6% + var(--col) * 13%);
    color: #7eff783b;
    font-size: .72rem;
    letter-spacing: .15em;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    animation: rainDrop 9s linear infinite;
    animation-delay: calc(var(--col) * -1.1s)
}

.hacker-noise {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    pointer-events: none
}

.hacker-noise {
    opacity: .12;
    background-image: radial-gradient(rgba(255,255,255,.92) .45px,transparent .45px);
    background-size: 3px 3px;
    animation: noiseShift .32s steps(2,end) infinite
}

.intro-glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(34px);
    pointer-events: none
}

.ig-1 {
    width: 330px;
    height: 330px;
    left: 18%;
    top: 12%;
    background: radial-gradient(circle at center,#8aff5a33,#8aff5a00);
    animation: glowDrift 8s ease-in-out infinite
}

.ig-2 {
    width: 290px;
    height: 290px;
    right: 16%;
    bottom: 14%;
    background: radial-gradient(circle at center,#43dcff29,#43dcff00);
    animation: glowDrift 8.8s ease-in-out infinite reverse
}

.decrypt-shell {
    position: relative;
    z-index: 2;
    width: min(880px,calc(100vw - 24px));
    border-radius: 18px;
    border: 1px solid rgba(138,255,90,.36);
    background: linear-gradient(145deg,#020a08f2,#030e0ae0);
    box-shadow: 0 24px 80px #00000080,0 0 38px #8aff5a24;
    padding: 16px;
    isolation: isolate
}

.decrypt-shell:before {
    content: "";
    position: absolute;
    top: -1px;
    right: -1px;
    bottom: -1px;
    left: -1px;
    border-radius: inherit;
    padding: 1px;
    background: conic-gradient(from 0deg,#8aff5a70,#34b54857,#8aff5a66);
    -webkit-mask: linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: .7;
    animation: borderSpin 10s linear infinite;
    z-index: -1
}

.decrypt-head {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 14px;
    align-items: center
}

.skull-badge {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    border: 1px solid rgba(138,255,90,.45);
    display: grid;
    place-items: center;
    color: #c8ffb8;
    font-size: 1.25rem;
    background: linear-gradient(145deg,#102d13c7,#09170a9e);
    box-shadow: inset 0 0 18px #8aff5a3d
}

.threat-chip {
    border: 1px solid rgba(138,255,90,.42);
    border-radius: 999px;
    padding: 7px 11px;
    font-size: .62rem;
    letter-spacing: .13em;
    color: #d6ffc8;
    text-transform: uppercase;
    background: #1034149e
}

.boot-text {
    margin: 0;
    font-size: .68rem;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: #bcffb2e0;
    animation: blink 1.2s steps(2,end) infinite
}

.boot-text.alt {
    margin-top: 8px
}

.decrypt-title {
    position: relative;
    margin: 8px 0 0;
    font-family: Oxanium,sans-serif;
    font-weight: 800;
    letter-spacing: .12em;
    font-size: clamp(1.1rem,3.2vw,2.1rem);
    color: #d4ffc8;
    text-shadow: 0 0 14px rgba(138,255,90,.45)
}

.decrypt-title:after {
    content: attr(data-text);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    color: #46e95f9e;
    transform: translate(1px);
    opacity: 0;
    animation: titleGlitch 2.8s steps(2,end) infinite
}

.decrypt-grid {
    margin-top: 14px;
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 14px
}

.decrypt-main,.decrypt-side {
    border: 1px solid rgba(138,255,90,.18);
    border-radius: 12px;
    background: #0412088f;
    padding: 12px
}

.status-row {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px
}

.status-row span {
    border-radius: 999px;
    border: 1px solid rgba(138,255,90,.34);
    background: #8aff5a14;
    padding: 4px 9px;
    font-size: .62rem;
    color: #cbffbe;
    text-transform: uppercase;
    letter-spacing: .07em
}

.alert-card {
    border: 1px solid rgba(255,95,127,.5);
    border-radius: 10px;
    background: linear-gradient(140deg,#4a1121ad,#1c0b148a);
    padding: 10px;
    margin-bottom: 10px
}

.alert-card strong {
    display: block;
    font-size: .74rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #ffd7e0
}

.alert-card span {
    display: block;
    margin-top: 3px;
    font-size: .66rem;
    color: #ffb9c9
}

.hacker-progress {
    margin-top: 4px;
    height: 10px;
    border-radius: 999px;
    border: 1px solid rgba(138,255,90,.34);
    background: #051608b8;
    overflow: hidden
}

.hacker-progress-fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg,#4edb68,#97ff64 56%,#e9ff8d);
    box-shadow: 0 0 16px #8aff5a8f;
    transition: width .12s linear
}

.boot-percent {
    margin: 8px 0 0;
    font-size: .7rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #d7ffca
}

.hacker-log {
    margin-top: 0;
    border: 1px dashed rgba(138,255,90,.34);
    border-radius: 8px;
    min-height: 118px;
    padding: 8px 10px;
    text-align: left;
    background: #030e08c2
}

.hacker-log p {
    margin: 0 0 4px;
    font-size: .65rem;
    letter-spacing: .08em;
    color: #b8ffac;
    animation: lineFlash .26s ease
}

.hacker-log p:last-child {
    margin-bottom: 0
}

.intro-fade-enter-active,.intro-fade-leave-active {
    transition: opacity .42s ease
}

.intro-fade-enter-from,.intro-fade-leave-to {
    opacity: 0
}

.aurora {
    position: absolute;
    border-radius: 50%;
    filter: blur(40px);
    pointer-events: none
}

.a1 {
    width: 430px;
    height: 430px;
    left: -140px;
    top: -120px;
    background: radial-gradient(circle at center,#33d2ff4d,#33d2ff00);
    animation: floatA 15s ease-in-out infinite
}

.a2 {
    width: 420px;
    height: 420px;
    right: -160px;
    top: 24%;
    background: radial-gradient(circle at center,#ff5f7f47,#ff5f7f00);
    animation: floatB 14s ease-in-out infinite
}

.grid-overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    pointer-events: none;
    background: repeating-linear-gradient(0deg,rgba(138,255,90,.05),rgba(138,255,90,.05) 1px,transparent 1px,transparent 36px),repeating-linear-gradient(90deg,rgba(138,255,90,.04),rgba(138,255,90,.04) 1px,transparent 1px,transparent 36px);
    -webkit-mask-image: radial-gradient(circle at center,black 33%,transparent 100%);
    mask-image: radial-gradient(circle at center,black 33%,transparent 100%)
}

.hero,.content {
    position: relative;
    z-index: 2
}

.hero {
    position: relative;
    overflow: hidden;
    max-width: 1100px;
    margin-inline:auto;border: 1px solid var(--panel-line);
    border-radius: 24px;
    padding: clamp(20px,3vw,30px);
    background: linear-gradient(140deg,#040f08e6,#07140bc2);
    box-shadow: 0 26px 60px #0000006b,0 0 26px #8aff5a1f;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px)
}

.hero:after {
    content: "";
    position: absolute;
    top: -32%;
    right: -32%;
    bottom: -32%;
    left: -32%;
    background: conic-gradient(from 120deg,transparent,rgba(138,255,90,.12),transparent 30%,transparent 66%,rgba(83,217,98,.12),transparent);
    animation: heroSweep 11s linear infinite;
    pointer-events: none
}

.eyebrow {
    margin: 0;
    font-size: .8rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: #beffb1
}

.hero h1 {
    margin: 9px 0 10px;
    font-family: Oxanium,sans-serif;
    font-weight: 800;
    letter-spacing: .03em;
    line-height: 1.06;
    font-size: clamp(1.55rem,4vw,3.2rem);
    max-width: 16ch
}

.subtitle {
    margin: 0;
    max-width: 74ch;
    color: var(--ink-dim);
    line-height: 1.45
}

.chips {
    margin-top: 16px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px
}

.chips span {
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid rgba(138,255,90,.35);
    background: #8aff5a17;
    font-size: .77rem
}

.controls {
    margin-top: 16px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px
}

.controls button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: 1px solid rgba(138,255,90,.3);
    border-radius: 12px;
    padding: 9px 14px;
    color: var(--ink);
    background: #040e08d6;
    font-family: inherit;
    font-size: .8rem;
    min-height: 42px;
    cursor: pointer;
    transition: transform .18s ease,border-color .18s ease,background .18s ease
}

.controls button:hover {
    transform: translateY(-1px);
    border-color: #8aff5ab8
}

.controls button.active {
    border-color: #8aff5ae6;
    background: linear-gradient(135deg,#68f4583d,#8aff5a1f)
}

.content {
    width: min(100%,360px);
    max-width: 360px;
    margin: 52px auto 0;
    display: flex;
    flex-direction: column;
    align-items: center
}

.unlock-panel {
    margin: 0 0 16px;
    width: 100%
}

.unlock-card {
    border: 1px solid rgba(138,255,90,.34);
    border-radius: 16px;
    padding: 16px;
    background: radial-gradient(circle at 50% 0%,rgba(138,255,90,.15),transparent 45%),linear-gradient(145deg,#040f08eb,#07120ad1);
    box-shadow: 0 18px 40px #00000057,0 0 24px #8aff5a24
}

.unlock-tag {
    margin: 0;
    font-size: .68rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #afffa3
}

.unlock-card h2 {
    margin: 8px 0 12px;
    font-family: Oxanium,sans-serif;
    font-size: clamp(1rem,2.7vw,1.5rem);
    letter-spacing: .08em;
    color: #e8ffdf;
    text-shadow: 0 0 12px rgba(138,255,90,.35)
}

.unlock-cta-wrap {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.unlock-cta {
    position: relative;
    width: fit-content;
    max-width: 100%;
    min-height: 56px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 10px 24px;
    text-align: center;
    text-decoration: none;
    font-family: Oxanium,sans-serif;
    border-radius: 12px;
    border: 1px solid rgba(255,245,160,.9);
    background: linear-gradient(180deg,#ffef5c,#d4a017);
    box-shadow: 0 6px #8b6508,0 10px 20px #0009,inset 0 2px 4px #fffc;
    color: #3b2a00;
    text-shadow: 0 1px 1px rgba(255,255,255,.5);
    overflow: hidden;
    transition: all .1s ease;
    cursor: pointer;
    margin-bottom: 6px;
    animation: ctaHeartbeat 2.5s infinite
}

@keyframes ctaHeartbeat {
    0% {
        transform: scale(1)
    }

    10% {
        transform: scale(1.03)
    }

    20% {
        transform: scale(1)
    }

    30% {
        transform: scale(1.03)
    }

    40% {
        transform: scale(1)
    }

    to {
        transform: scale(1)
    }
}

@keyframes fingerPoint {
    0%,to {
        transform: translateY(0)
    }

    50% {
        transform: translateY(4px)
    }
}

.hand-icon {
    display: inline-block;
    animation: fingerPoint .6s infinite ease-in-out;
    margin: 0 4px
}

.cta-main {
    font-size: 1.25rem;
    font-weight: 900;
    letter-spacing: .05em;
    text-transform: uppercase;
    margin-bottom: 2px
}

.cta-sub {
    font-size: .72rem;
    font-weight: 700;
    opacity: .85;
    letter-spacing: .02em
}

.unlock-cta:hover {
    filter: brightness(1.08);
    transform: translateY(2px);
    box-shadow: 0 4px #8b6508,0 6px 15px #00000080,inset 0 2px 4px #fffc;
    animation: none
}

.unlock-cta:active {
    transform: translateY(6px);
    box-shadow: 0 0 #8b6508,0 2px 5px #00000080,inset 0 2px 4px #fffc
}

.unlock-cta:before {
    content: "";
    position: absolute;
    left: -20%;
    top: -6%;
    width: 18%;
    height: 112%;
    transform: skew(-16deg);
    background: linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);
    animation: unlockSweep 2.5s ease-in-out infinite
}

.unlock-hint {
    margin: 8px 0 2px;
    color: #b8ff9f;
    font-size: .72rem;
    letter-spacing: .04em;
    animation: hintBlink 1.2s steps(2,end) infinite
}

.unlock-card ul {
    margin: 12px 0 0;
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px dashed rgba(138,255,90,.36);
    background: #041007b3;
    list-style: none
}

.unlock-card li {
    position: relative;
    margin: 0 0 8px;
    padding-left: 22px;
    color: #d5ffc8;
    font-size: .88rem;
    line-height: 1.45
}

.unlock-card li:before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    color: #75ff61;
    font-weight: 700;
    text-shadow: 0 0 8px rgba(138,255,90,.58)
}

.unlock-card li:last-child {
    margin-bottom: 0
}

.info {
    margin: 0 0 14px;
    color: #d3efff
}

.info.warn {
    color: #ffcf9f
}

.game-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(3,minmax(0,1fr));
    width: 100%
}

.game-card {
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100%;
    border: 1px solid var(--panel-line);
    border-radius: 18px;
    overflow: hidden;
    background: linear-gradient(145deg,#041009e6,#07130ac7);
    box-shadow: 0 15px 34px #00000057;
    transform: translateY(12px);
    opacity: 0;
    animation: reveal .56s ease forwards;
    animation-delay: calc(var(--idx) * 30ms);
    isolation: isolate
}

.game-card:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: inherit;
    background: linear-gradient(130deg,rgba(138,255,90,.07),transparent 30%,transparent 70%,rgba(69,212,90,.08));
    pointer-events: none;
    z-index: 0
}

.game-card:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(120deg,#8aff5a57,#4eb94e33,#8aff5a2e);
    -webkit-mask: linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: .42;
    pointer-events: none
}

.game-card:hover {
    border-color: #8aff5a99;
    transform: translateY(-2px);
    box-shadow: 0 20px 38px #00000061,0 0 26px #8aff5a33
}

.thumb-wrap {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: #122415
}

.thumb-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .36s ease
}

.thumb-wrap:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    pointer-events: none;
    background: linear-gradient(180deg,#08132400 46%,#08132457)
}

.game-card:hover .thumb-wrap img {
    transform: scale(1.06)
}

.source {
    position: absolute;
    left: 10px;
    top: 10px;
    border-radius: 999px;
    padding: 4px 10px;
    border: 1px solid rgba(138,255,90,.32);
    background: #030f05d1;
    font-size: .7rem;
    font-weight: 700
}

.body {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 11px
}

.optimized-title {
    margin: 0 0 6px;
    font-size: .55rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #b8ff99
}

.body h2 {
    margin: 0;
    font-family: Oxanium,sans-serif;
    font-weight: 700;
    font-size: .82rem;
    line-height: 1.3;
    min-height: 2.45em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow-wrap: anywhere;
    word-break: break-word;
    overflow: hidden
}

.stats {
    margin-top: 8px;
    display: grid;
    grid-template-columns: minmax(0,1fr) auto;
    align-items: baseline;
    column-gap: 6px;
    font-size: .7rem;
    color: var(--ink-dim)
}

.rate-label {
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.stats strong {
    white-space: nowrap;
    flex-shrink: 0;
    font-size: .88rem;
    color: #eaffdf
}

.status-row-card {
    margin-top: 6px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-height: 24px
}

.status-label {
    font-size: .4rem;
    color: var(--ink-dim)
}

.status-badge {
    border-radius: 999px;
    padding: 2px 7px;
    font-size: .52rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase
}

.status-badge.tone-ok {
    border: 1px solid rgba(138,255,90,.5);
    background: #8aff5a24;
    color: #cfffbd
}

.status-badge.tone-hold {
    border: 1px solid rgba(255,216,120,.5);
    background: #ffd87824;
    color: #ffe8ad
}

.status-badge.tone-off {
    border: 1px solid rgba(255,95,127,.52);
    background: #ff5f7f24;
    color: #ffc2cf
}

.meter {
    margin-top: auto;
    height: 8px;
    border-radius: 999px;
    background: #94ff7324;
    overflow: hidden
}

.fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg,#52e86c,#a5ff68);
    box-shadow: 0 0 14px #8aff5a85
}

.action {
    position: relative;
    margin-top: 10px;
    width: 100%;
    display: inline-flex;
    justify-content: center;
    text-decoration: none;
    color: #052209;
    font-family: Oxanium,sans-serif;
    font-weight: 700;
    border-radius: 11px;
    padding: 9px 11px;
    min-height: 44px;
    background: linear-gradient(130deg,#57e96d,#8fff63 62%,#d8ff79);
    transition: transform .19s ease,filter .19s ease;
    overflow: hidden
}

.action:after {
    content: "";
    position: absolute;
    left: -22%;
    top: -8%;
    width: 18%;
    height: 116%;
    transform: skew(-18deg);
    background: linear-gradient(90deg,transparent,rgba(255,255,255,.75),transparent);
    animation: ctaSweep 2.8s ease-in-out infinite
}

.action:hover {
    transform: translateY(-1px);
    filter: brightness(1.04)
}

@keyframes reveal {
    to {
        transform: translateY(0);
        opacity: 1
    }
}

@keyframes noiseShift {
    0% {
        transform: translate(0)
    }

    25% {
        transform: translate(-1px,1px)
    }

    50% {
        transform: translate(1px,-1px)
    }

    75% {
        transform: translate(1px,1px)
    }

    to {
        transform: translate(0)
    }
}

@keyframes blink {
    0%,42%,to {
        opacity: 1
    }

    50%,92% {
        opacity: .36
    }
}

@keyframes titleGlitch {
    0%,84%,to {
        opacity: 0;
        clip-path: inset(0 0 0 0)
    }

    85% {
        opacity: .78;
        clip-path: inset(52% 0 18% 0)
    }

    87% {
        opacity: .5;
        clip-path: inset(16% 0 62% 0)
    }
}

@keyframes glowDrift {
    0%,to {
        transform: translate(0) scale(1)
    }

    50% {
        transform: translate(18px,-12px) scale(1.08)
    }
}

@keyframes rainDrop {
    to {
        transform: translateY(150%)
    }
}

@keyframes lineFlash {
    0% {
        opacity: 0;
        transform: translateY(3px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@keyframes ctaSweep {
    0% {
        left: -24%
    }

    55%,to {
        left: 118%
    }
}

@keyframes unlockPulse {
    0%,to {
        transform: translateY(0);
        filter: brightness(1) saturate(1)
    }

    50% {
        transform: translateY(-1px);
        filter: brightness(1.22) saturate(1.25)
    }
}

@keyframes unlockSweep {
    0% {
        left: -22%
    }

    60%,to {
        left: 118%
    }
}

@keyframes unlockArrow {
    0%,to {
        transform: translate(0)
    }

    50% {
        transform: translate(3px)
    }
}

@keyframes hintBlink {
    0%,45%,to {
        opacity: 1
    }

    50%,95% {
        opacity: .45
    }
}

@keyframes pointerTap {
    0%,to {
        transform: translate(-50%,-50%) scale(1)
    }

    50% {
        transform: translate(-50%,-46%) scale(.9)
    }
}

@keyframes pointerRing {
    0% {
        opacity: 0;
        transform: translate(-50%,-50%) scale(.5)
    }

    45% {
        opacity: 1;
        transform: translate(-50%,-50%) scale(1.9)
    }

    to {
        opacity: 0;
        transform: translate(-50%,-50%) scale(2.9)
    }
}

@keyframes floatA {
    0%,to {
        transform: translate(0)
    }

    50% {
        transform: translate(30px,24px)
    }
}

@keyframes floatB {
    0%,to {
        transform: translate(0)
    }

    50% {
        transform: translate(-22px,-26px)
    }
}

@media(max-width: 760px) {
    .page {
        padding-inline:10px;
        padding-top: 14px;
        padding-bottom: 26px
    }

    .hero {
        border-radius: 18px;
        padding: 14px
    }

    .subtitle {
        font-size: .93rem
    }

    .hero h1 {
        font-size: clamp(1.35rem,7.4vw,1.85rem);
        max-width: none
    }

    .chips {
        gap: 7px
    }

    .chips span {
        font-size: .72rem;
        padding: 5px 10px;
        white-space: nowrap
    }

    .controls {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px
    }

    .controls button {
        width: 100%;
        min-height: 44px;
        font-size: .78rem;
        padding: 10px 8px
    }

    .controls button:last-child {
        grid-column: 1 / -1
    }

    .game-grid {
        grid-template-columns: repeat(3,minmax(0,1fr));
        gap: 12px
    }

    .game-card {
        border-radius: 13px
    }

    .body {
        padding: 9px
    }

    .body h2 {
        font-size: .82rem;
        min-height: 2.45em
    }

    .optimized-title {
        font-size: .55rem;
        margin-bottom: 4px
    }

    .stats {
        margin-top: 8px;
        font-size: .7rem
    }

    .rate-label {
        white-space: nowrap
    }

    .stats strong {
        font-size: .88rem
    }

    .status-label,.status-badge {
        font-size: .6rem
    }

    .action {
        margin-top: 8px;
        min-height: 38px;
        padding: 8px;
        font-size: .76rem
    }

    .decrypt-shell {
        width: calc(100vw - 14px);
        padding: 12px
    }

    .matrix-hud {
        left: 10px;
        top: 10px;
        padding: 7px 8px
    }

    .matrix-hud p {
        font-size: .58rem;
        line-height: 1.45
    }

    .matrix-rain span {
        font-size: .6rem
    }

    .decrypt-main,.decrypt-side {
        padding: 10px
    }

    .decrypt-head {
        grid-template-columns: 1fr;
        text-align: center
    }

    .skull-badge,.threat-chip {
        margin-inline:auto}

    .decrypt-grid {
        grid-template-columns: 1fr
    }

    .unlock-card {
        padding: 12px
    }

    .unlock-hint {
        font-size: .66rem
    }

    .unlock-card li {
        font-size: .78rem
    }

    .status-row {
        justify-content: center
    }
}

@media(max-width: 420px) {
    .hero {
        border-radius:14px
    }

    .eyebrow {
        font-size: .7rem
    }

    .subtitle {
        font-size: .86rem
    }

    .game-grid {
        grid-auto-columns: minmax(160px,1fr)
    }

    .source {
        font-size: .64rem;
        padding: 4px 8px
    }
}

@media(prefers-reduced-motion:reduce) {
    .hacker-noise,.matrix-rain span,.intro-glow,.boot-text,.decrypt-title:after,.decrypt-shell:before,.hero:after,.unlock-cta,.unlock-cta:before,.unlock-cta:after,.unlock-hint,.action:after,.game-card {
        animation: none
    }

    .game-card {
        opacity: 1;
        transform: none
    }
}
