/*
 * Asignature Access Experience
 * Mobile first: base pensada para 320px–480px, com desktop expandindo depois.
 */

html.aae-site-locked,
body.aae-site-locked {
    width: 100% !important;
    min-height: 100% !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
}

.aae-access-root.aae-overlay-active {
    position: fixed !important;
    inset: 0 !important;
    top: var(--aae-visual-offset-top, 0px) !important;
    bottom: auto !important;
    width: 100vw !important;
    height: var(--aae-visual-height, 100dvh) !important;
    min-height: var(--aae-visual-height, 100dvh) !important;
    z-index: 2147483647 !important;
    margin: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
}

.aae-access-root.aae-is-completed {
    position: relative;
    z-index: 1;
}

.aae-access-root,
.aae-access-root * {
    box-sizing: border-box;
}

.aae-access-root {
    --aae-bg: #000000;
    --aae-panel: rgba(255, 255, 255, 0.045);
    --aae-panel-strong: rgba(255, 255, 255, 0.075);
    --aae-border: rgba(255, 255, 255, 0.14);
    --aae-border-soft: rgba(255, 255, 255, 0.075);
    --aae-text: #f5f5f5;
    --aae-muted: rgba(245, 245, 245, 0.66);
    --aae-faint: rgba(245, 245, 245, 0.42);
    --aae-good: #d9ffd9;
    --aae-danger: #ffb6b6;
    --aae-hacker: #00ff88;
    --aae-hacker-soft: rgba(0, 255, 136, 0.17);
    --aae-hacker-border: rgba(0, 255, 136, 0.34);
    --aae-shadow: 0 24px 90px rgba(0, 0, 0, 0.78);
    --aae-visual-height: 100dvh;
    --aae-visual-offset-top: 0px;

    width: 100%;
    min-height: 100svh;
    min-height: 100dvh;
    overflow-x: hidden;
    background: #000000;
    color: var(--aae-text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: max(18px, env(safe-area-inset-top)) 16px max(22px, env(safe-area-inset-bottom));
    isolation: isolate;
    position: relative;
    text-align: center;
}

.aae-access-root::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.055), transparent 19rem),
        linear-gradient(180deg, #030303 0%, #000000 64%, #000000 100%);
}

.aae-access-root::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.72));
}

.aae-access-root.aae-keyboard-open {
    height: var(--aae-visual-height, 100dvh) !important;
    min-height: var(--aae-visual-height, 100dvh) !important;
    align-items: flex-start;
    justify-content: flex-start;
    padding: max(10px, env(safe-area-inset-top)) 14px max(18px, env(safe-area-inset-bottom));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
}

.aae-shell {
    width: min(100%, 430px);
    max-height: none;
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
    animation: aaeFadeUp 420ms ease both;
}

.aae-card {
    width: 100%;
    border: 1px solid var(--aae-border);
    border-radius: 28px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.026)),
        var(--aae-panel);
    box-shadow: var(--aae-shadow);
    padding: 26px 18px;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    overflow: hidden;
}

.aae-logo-wrap {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-bottom: 16px;
}

.aae-logo {
    width: min(158px, 58vw);
    max-height: 78px;
    object-fit: contain;
    filter: invert(1) brightness(1.2);
    opacity: 0.96;
}

.aae-eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 7px 12px;
    border: 1px solid var(--aae-border-soft);
    border-radius: 999px;
    color: var(--aae-faint);
    font-size: 11px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    line-height: 1.25;
    margin-bottom: 14px;
}

.aae-title {
    margin: 0;
    color: var(--aae-text);
    font-size: clamp(28px, 10vw, 44px);
    line-height: 0.98;
    letter-spacing: -0.05em;
    text-transform: uppercase;
    text-wrap: balance;
}

.aae-title-small {
    font-size: clamp(24px, 8vw, 34px);
    line-height: 1.05;
}

.aae-copy {
    margin: 14px auto 0;
    color: var(--aae-muted);
    font-size: 15px;
    line-height: 1.55;
    max-width: 31ch;
    text-wrap: balance;
}

.aae-actions {
    width: 100%;
    margin-top: 22px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
}

.aae-btn {
    appearance: none;
    width: 100%;
    min-height: 54px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 16px;
    background: #f4f4f4;
    color: #050505;
    font: inherit;
    font-weight: 800;
    font-size: 13px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    cursor: pointer;
    touch-action: manipulation;
    transition: transform 160ms ease, opacity 160ms ease, border-color 160ms ease, background 160ms ease;
}

.aae-btn:hover,
.aae-btn:focus-visible {
    transform: translateY(-1px);
    outline: none;
}

.aae-btn:active {
    transform: translateY(1px) scale(0.99);
}

.aae-progress-shell {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 22px;
}

.aae-progress-track {
    width: 100%;
    height: 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.aae-progress-fill {
    height: 100%;
    width: 0%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.54), #ffffff);
    transform: none !important;
    transition: width 70ms linear;
    will-change: width;
}

.aae-progress-row {
    width: 100%;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: var(--aae-faint);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.aae-status-message {
    min-height: 24px;
    color: var(--aae-muted);
    font-size: 14px;
    line-height: 1.45;
}

.aae-file-list {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 22px;
}

.aae-file-item {
    width: 100%;
    min-height: 58px;
    border: 1px solid var(--aae-border-soft);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.045);
    color: var(--aae-text);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 14px;
    font-size: 15px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: center;
}

button.aae-file-item {
    cursor: pointer;
    touch-action: manipulation;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
}

button.aae-file-item:hover,
button.aae-file-item:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(255, 255, 255, 0.34);
    background: rgba(255, 255, 255, 0.075);
    outline: none;
}

.aae-file-item[aria-disabled="true"] {
    opacity: 0.36;
}

.aae-meta-grid {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 22px;
}

.aae-meta-item {
    border: 1px solid var(--aae-border-soft);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.04);
    padding: 14px 12px;
}

.aae-meta-label {
    display: block;
    color: var(--aae-faint);
    font-size: 11px;
    letter-spacing: 0.17em;
    text-transform: uppercase;
    margin-bottom: 6px;
}

.aae-meta-value {
    display: block;
    color: var(--aae-text);
    font-size: 15px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    word-break: break-word;
}

.aae-meta-value.aae-locked {
    color: var(--aae-danger);
}

.aae-form {
    width: 100%;
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.aae-input {
    width: 100%;
    min-height: 54px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.07);
    color: var(--aae-text);
    font: inherit;
    font-size: 16px;
    line-height: 1.2;
    text-align: center;
    padding: 15px 16px;
    outline: none;
}

.aae-input::placeholder {
    color: rgba(255, 255, 255, 0.32);
}

.aae-input:focus {
    border-color: rgba(255, 255, 255, 0.42);
    background: rgba(255, 255, 255, 0.095);
}

.aae-error {
    min-height: 22px;
    margin: 0;
    color: var(--aae-danger);
    font-size: 13px;
    line-height: 1.45;
}

.aae-success {
    color: var(--aae-good);
}

.aae-glitch {
    position: relative;
    display: inline-block;
    animation: aaeGlitch 520ms steps(2, end) both;
}

.aae-glitch::before,
.aae-glitch::after {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    opacity: 0.22;
    pointer-events: none;
}

.aae-glitch::before {
    transform: translate(2px, -1px);
}

.aae-glitch::after {
    transform: translate(-2px, 1px);
}

.aae-terminal-hint {
    width: 100%;
    margin-top: 16px;
    border: 1px solid var(--aae-border-soft);
    border-radius: 16px;
    padding: 12px;
    color: var(--aae-faint);
    background: rgba(0, 0, 0, 0.32);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 12px;
    line-height: 1.6;
    word-break: break-word;
}

.aae-noscript {
    width: 100%;
    padding: 24px 18px;
    color: var(--aae-text);
    border: 1px solid var(--aae-border);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.05);
}

/* MINI GAME HACKER - estética verde apenas nesta etapa */
.aae-card-game {
    padding: 20px 14px 18px;
}

.aae-card-hacker {
    border-color: rgba(0, 255, 136, 0.22);
    background:
        radial-gradient(circle at 50% 0%, rgba(0, 255, 136, 0.07), transparent 17rem),
        linear-gradient(180deg, rgba(0, 255, 136, 0.045), rgba(255, 255, 255, 0.018)),
        #020202;
}

.aae-card-hacker .aae-logo {
    filter: invert(1) brightness(1.2) drop-shadow(0 0 8px rgba(0, 255, 136, 0.16));
}

.aae-hacker-eyebrow {
    color: var(--aae-hacker);
    border-color: rgba(0, 255, 136, 0.28);
    background: rgba(0, 255, 136, 0.045);
}

.aae-title-game {
    font-size: clamp(23px, 8.2vw, 34px);
    line-height: 1.02;
}

.aae-hack-panel {
    width: 100%;
    position: relative;
    margin-top: 18px;
    border: 1px solid var(--aae-hacker-border);
    border-radius: 22px;
    background:
        linear-gradient(rgba(0, 255, 136, 0.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0, 255, 136, 0.035) 1px, transparent 1px),
        radial-gradient(circle at 50% 30%, rgba(0, 255, 136, 0.11), transparent 12rem),
        #020302;
    background-size: 24px 24px, 24px 24px, auto, auto;
    overflow: hidden;
    box-shadow:
        inset 0 0 0 1px rgba(0, 255, 136, 0.05),
        inset 0 0 34px rgba(0, 255, 136, 0.055);
    touch-action: manipulation;
    user-select: none;
    -webkit-user-select: none;
}

.aae-hack-panel:focus {
    outline: none;
}

.aae-hack-panel::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(180deg, transparent 0%, rgba(0, 255, 136, 0.045) 50%, transparent 100%);
    transform: translateY(-100%);
    animation: aaeSafeScan 2.2s linear infinite;
}

.aae-hack-hud {
    width: 100%;
    min-height: 38px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 10px 12px;
    color: rgba(0, 255, 136, 0.72);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 10px;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: rgba(0, 0, 0, 0.58);
    border-bottom: 1px solid rgba(0, 255, 136, 0.14);
}

.aae-hack-hud strong {
    color: var(--aae-hacker);
    font-weight: 900;
}

.aae-safe-visual {
    width: 100%;
    min-height: 156px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 14px 12px;
}

.aae-safe-ring {
    width: 116px;
    height: 116px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(0, 255, 136, 0.34);
    background:
        conic-gradient(from 0deg, rgba(0, 255, 136, 0.1), rgba(0, 255, 136, 0.38), rgba(0, 255, 136, 0.07), rgba(0, 255, 136, 0.25), rgba(0, 255, 136, 0.1)),
        #030303;
    box-shadow:
        0 0 26px rgba(0, 255, 136, 0.14),
        inset 0 0 24px rgba(0, 0, 0, 0.76);
    animation: aaeSafeRotate 8s linear infinite;
}

.aae-safe-core {
    width: 72px;
    height: 72px;
    border-radius: 999px;
    border: 1px solid rgba(0, 255, 136, 0.34);
    background: #000000;
    display: grid;
    place-items: center;
    color: var(--aae-hacker);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 19px;
    font-weight: 900;
    letter-spacing: 0.14em;
    box-shadow: inset 0 0 20px rgba(0, 255, 136, 0.07);
    transform: rotate(0deg);
    animation: aaeSafeRotateReverse 8s linear infinite;
}

.aae-safe-leds {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
}

.aae-safe-leds span {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    box-shadow: none;
}

.aae-safe-leds span.is-on {
    background: var(--aae-hacker);
    box-shadow: 0 0 12px rgba(0, 255, 136, 0.62);
}

.aae-safe-scan {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at 50% 44%, rgba(0, 255, 136, 0.08), transparent 36%);
}

.aae-timing-wrap {
    width: 100%;
    padding: 0 12px 14px;
}

.aae-timing-label {
    margin: 0 0 10px;
    color: rgba(245, 245, 245, 0.72);
    font-size: 12px;
    line-height: 1.45;
    text-wrap: balance;
}

.aae-timing-track {
    position: relative;
    width: 100%;
    height: 38px;
    border: 1px solid rgba(0, 255, 136, 0.22);
    border-radius: 999px;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.055), rgba(0, 255, 136, 0.06), rgba(255, 255, 255, 0.055)),
        #010101;
    overflow: hidden;
}

.aae-timing-zone {
    position: absolute;
    top: 5px;
    bottom: 5px;
    left: 42%;
    width: 24%;
    border-radius: 999px;
    background: rgba(0, 255, 136, 0.3);
    border: 1px solid rgba(0, 255, 136, 0.56);
    box-shadow: 0 0 18px rgba(0, 255, 136, 0.18);
}

.aae-timing-cursor {
    position: absolute;
    top: 2px;
    left: 0%;
    width: 4px;
    height: calc(100% - 4px);
    border-radius: 999px;
    background: #ffffff;
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.24),
        0 0 16px rgba(255, 255, 255, 0.52),
        0 0 26px rgba(0, 255, 136, 0.42);
    transform: translateX(-2px);
}

.aae-timing-scale {
    width: 100%;
    display: flex;
    justify-content: space-between;
    margin-top: 8px;
    color: rgba(0, 255, 136, 0.42);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 10px;
}

.aae-hack-log {
    margin: 0 12px 14px;
    min-height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(0, 255, 136, 0.13);
    border-radius: 12px;
    background: rgba(0, 0, 0, 0.42);
    color: rgba(0, 255, 136, 0.76);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 11px;
    line-height: 1.35;
    padding: 9px 10px;
    word-break: break-word;
}

.aae-hack-panel.aae-hack-success {
    border-color: rgba(0, 255, 136, 0.72);
    animation: aaeHackSuccess 420ms ease both;
}

.aae-hack-panel.aae-hack-miss {
    border-color: rgba(255, 74, 74, 0.5);
    animation: aaeHackMiss 260ms ease both;
}

.aae-hack-panel.aae-hack-complete {
    animation: aaeHackComplete 520ms ease both;
}

.aae-game-controls {
    width: 100%;
    margin-top: 12px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.aae-game-control {
    appearance: none;
    width: 100%;
    min-height: 52px;
    border: 1px solid rgba(0, 255, 136, 0.36);
    border-radius: 16px;
    background: rgba(0, 255, 136, 0.1);
    color: var(--aae-hacker);
    font: inherit;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-weight: 900;
    font-size: 12px;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    cursor: pointer;
    touch-action: manipulation;
    transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}

.aae-game-control:active,
.aae-game-control:focus-visible {
    transform: translateY(1px) scale(0.99);
    border-color: rgba(0, 255, 136, 0.7);
    background: rgba(0, 255, 136, 0.16);
    outline: none;
}

.aae-game-help {
    margin: 10px auto 0;
    color: rgba(245, 245, 245, 0.42);
    font-size: 11px;
    line-height: 1.45;
}

.aae-key-found {
    margin: 16px auto 0;
    color: var(--aae-hacker);
    font-size: 14px;
    line-height: 1.45;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-wrap: balance;
}

.aae-key-found strong {
    color: #ffffff;
}

.aae-terminal-hacker {
    color: rgba(0, 255, 136, 0.72);
    border-color: rgba(0, 255, 136, 0.18);
    background: rgba(0, 255, 136, 0.04);
}



/* Tela de senha: compacta por padrão no mobile para não ficar atrás do teclado. */
.aae-access-root.aae-key-entry-mode {
    align-items: flex-start;
    justify-content: flex-start;
    padding-top: max(12px, env(safe-area-inset-top));
    padding-bottom: max(18px, env(safe-area-inset-bottom));
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
}

.aae-access-root.aae-key-entry-mode .aae-shell {
    width: min(100%, 430px);
    margin: 0 auto;
    padding-bottom: 28px;
}

.aae-card-key {
    padding: 18px 14px 16px;
    border-radius: 22px;
}

.aae-card-key .aae-logo-wrap {
    margin-bottom: 10px;
}

.aae-card-key .aae-logo {
    width: min(118px, 45vw);
    max-height: 52px;
}

.aae-card-key .aae-title-small {
    font-size: clamp(22px, 7.4vw, 30px);
}

.aae-card-key .aae-meta-grid {
    margin-top: 14px;
    gap: 8px;
}

.aae-card-key .aae-meta-item {
    padding: 10px 9px;
    border-radius: 13px;
}

.aae-card-key .aae-meta-label {
    font-size: 9px;
    margin-bottom: 4px;
}

.aae-card-key .aae-meta-value {
    font-size: 12px;
}

.aae-card-key .aae-terminal-hint {
    margin-top: 10px;
    padding: 9px;
    font-size: 11px;
    line-height: 1.45;
}

.aae-card-key .aae-copy {
    margin-top: 10px;
    font-size: 13px;
}

.aae-card-key .aae-form {
    margin-top: 12px;
    gap: 9px;
}

.aae-card-key .aae-input,
.aae-card-key .aae-btn {
    min-height: 52px;
}

@media (max-width: 480px) {
    .aae-access-root.aae-key-entry-mode .aae-logo-wrap,
    .aae-access-root.aae-key-entry-mode .aae-terminal-hint {
        display: none;
    }

    .aae-access-root.aae-key-entry-mode .aae-meta-grid {
        grid-template-columns: 1fr 1fr;
    }

    .aae-access-root.aae-key-entry-mode .aae-meta-item:nth-child(3),
    .aae-access-root.aae-key-entry-mode .aae-meta-item:nth-child(4) {
        display: none;
    }
}

/* Proteção mobile: quando o teclado abre, a tela da senha fica compacta e rolável. */
.aae-access-root.aae-keyboard-open .aae-shell {
    width: min(100%, 430px);
    min-height: auto;
    margin: 0 auto;
    padding-bottom: 26px;
}

.aae-access-root.aae-keyboard-open .aae-card {
    padding: 16px 14px 14px;
    border-radius: 22px;
}

.aae-access-root.aae-keyboard-open .aae-logo-wrap,
.aae-access-root.aae-keyboard-open .aae-terminal-hint,
.aae-access-root.aae-keyboard-open .aae-copy,
.aae-access-root.aae-keyboard-open .aae-meta-grid {
    display: none;
}

.aae-access-root.aae-keyboard-open .aae-eyebrow {
    min-height: 26px;
    padding: 6px 10px;
    margin-bottom: 10px;
    font-size: 10px;
}

.aae-access-root.aae-keyboard-open .aae-title-small {
    font-size: clamp(21px, 7vw, 28px);
    line-height: 1;
}

.aae-access-root.aae-keyboard-open .aae-form {
    margin-top: 14px;
    gap: 10px;
}

.aae-access-root.aae-keyboard-open .aae-input,
.aae-access-root.aae-keyboard-open .aae-btn {
    min-height: 54px;
}

.aae-access-root.aae-keyboard-open .aae-error {
    min-height: 18px;
    font-size: 12px;
}


.aae-access-root.aae-key-entry-mode.aae-keyboard-open {
    padding-top: max(8px, env(safe-area-inset-top));
}

.aae-access-root.aae-key-entry-mode.aae-keyboard-open .aae-card-key {
    padding: 12px 12px 12px;
    border-radius: 18px;
}

.aae-access-root.aae-key-entry-mode.aae-keyboard-open .aae-card-key .aae-copy,
.aae-access-root.aae-key-entry-mode.aae-keyboard-open .aae-card-key .aae-meta-grid,
.aae-access-root.aae-key-entry-mode.aae-keyboard-open .aae-card-key .aae-logo-wrap,
.aae-access-root.aae-key-entry-mode.aae-keyboard-open .aae-card-key .aae-terminal-hint {
    display: none !important;
}

.aae-access-root.aae-key-entry-mode.aae-keyboard-open .aae-card-key .aae-title-small {
    font-size: clamp(20px, 6.6vw, 26px);
}

@keyframes aaeFadeUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes aaeGlitch {
    0% { transform: translate(0); filter: none; }
    18% { transform: translate(-2px, 1px); filter: contrast(1.4); }
    32% { transform: translate(2px, -1px); }
    50% { transform: translate(-1px, 2px); }
    70% { transform: translate(1px, -1px); }
    100% { transform: translate(0); filter: none; }
}

@keyframes aaeSafeScan {
    from { transform: translateY(-100%); }
    to { transform: translateY(100%); }
}

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

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

@keyframes aaeHackSuccess {
    0% { transform: scale(1); }
    42% { transform: scale(1.012); box-shadow: inset 0 0 40px rgba(0, 255, 136, 0.12); }
    100% { transform: scale(1); }
}

@keyframes aaeHackMiss {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-3px); }
    50% { transform: translateX(3px); }
    75% { transform: translateX(-2px); }
}

@keyframes aaeHackComplete {
    0% { filter: brightness(1); }
    38% { filter: brightness(1.8) contrast(1.4); }
    100% { filter: brightness(1); }
}

@media (max-width: 360px) {
    .aae-card {
        padding: 22px 14px;
        border-radius: 24px;
    }

    .aae-card-game {
        padding: 18px 12px 16px;
    }

    .aae-hack-hud {
        font-size: 9px;
        padding-inline: 9px;
    }

    .aae-safe-visual {
        min-height: 142px;
    }

    .aae-safe-ring {
        width: 104px;
        height: 104px;
    }

    .aae-safe-core {
        width: 64px;
        height: 64px;
        font-size: 17px;
    }
}

@media (min-width: 600px) {
    .aae-access-root {
        padding: 42px 24px;
    }

    .aae-shell {
        width: min(100%, 520px);
    }

    .aae-card {
        border-radius: 34px;
        padding: 36px 34px;
    }

    .aae-card-game {
        padding: 30px 28px 26px;
    }

    .aae-copy {
        font-size: 16px;
        max-width: 38ch;
    }

    .aae-meta-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .aae-hack-hud {
        font-size: 11px;
        padding-inline: 14px;
    }

    .aae-safe-visual {
        min-height: 176px;
    }

    .aae-safe-ring {
        width: 136px;
        height: 136px;
    }

    .aae-safe-core {
        width: 84px;
        height: 84px;
        font-size: 22px;
    }

    .aae-game-controls {
        max-width: 280px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media (prefers-reduced-motion: reduce) {
    .aae-shell,
    .aae-glitch,
    .aae-btn,
    button.aae-file-item,
    .aae-progress-fill,
    .aae-safe-ring,
    .aae-safe-core,
    .aae-hack-panel::after,
    .aae-hack-panel,
    .aae-game-control {
        animation: none !important;
        transition: none !important;
    }
}

/* ROTA EXTRA DE DESCONTO */
.aae-route-grid {
    width: 100%;
    margin-top: 18px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.aae-route-card {
    appearance: none;
    width: 100%;
    min-height: 118px;
    border: 1px solid rgba(0, 255, 136, 0.22);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(0, 255, 136, 0.075), rgba(255, 255, 255, 0.018)),
        rgba(0, 0, 0, 0.38);
    color: var(--aae-text);
    font: inherit;
    cursor: pointer;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 16px 14px;
    touch-action: manipulation;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, opacity 160ms ease;
}

.aae-route-card:focus-visible,
.aae-route-card:hover {
    outline: none;
    transform: translateY(-1px);
    border-color: rgba(0, 255, 136, 0.48);
    background:
        linear-gradient(180deg, rgba(0, 255, 136, 0.11), rgba(255, 255, 255, 0.025)),
        rgba(0, 0, 0, 0.48);
}

.aae-route-card:active {
    transform: translateY(1px) scale(0.99);
}

.aae-route-card[disabled] {
    cursor: not-allowed;
    opacity: 0.48;
    transform: none !important;
}

.aae-route-kicker {
    color: rgba(0, 255, 136, 0.66);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 10px;
    line-height: 1.3;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.aae-route-card strong {
    color: #ffffff;
    font-size: 13px;
    line-height: 1.2;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.aae-route-card small {
    max-width: 30ch;
    color: rgba(245, 245, 245, 0.54);
    font-size: 11px;
    line-height: 1.42;
}

.aae-route-risk {
    border-color: rgba(0, 255, 136, 0.34);
    background:
        radial-gradient(circle at 50% 0%, rgba(0, 255, 136, 0.16), transparent 10rem),
        linear-gradient(180deg, rgba(0, 255, 136, 0.1), rgba(255, 255, 255, 0.018)),
        rgba(0, 0, 0, 0.48);
}

.aae-hack-panel.aae-hack-risk {
    border-color: rgba(0, 255, 136, 0.42);
    box-shadow:
        inset 0 0 0 1px rgba(0, 255, 136, 0.08),
        inset 0 0 42px rgba(0, 255, 136, 0.075),
        0 0 28px rgba(0, 255, 136, 0.06);
}

.aae-hack-risk .aae-timing-zone {
    background: rgba(0, 255, 136, 0.26);
    border-color: rgba(0, 255, 136, 0.72);
    box-shadow: 0 0 22px rgba(0, 255, 136, 0.23);
}

.aae-safe-leds-risk {
    gap: 6px;
}

.aae-discount-found,
.aae-unlocked-coupon {
    width: 100%;
    margin: 16px auto 0;
    border: 1px solid rgba(0, 255, 136, 0.26);
    border-radius: 16px;
    background: rgba(0, 255, 136, 0.055);
    color: rgba(0, 255, 136, 0.76);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 12px;
    line-height: 1.45;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 12px;
    word-break: break-word;
}

.aae-discount-found strong,
.aae-unlocked-coupon strong {
    display: block;
    margin-top: 4px;
    color: #ffffff;
    font-size: 16px;
    letter-spacing: 0.12em;
}

.aae-unlocked-coupon span {
    display: block;
    color: rgba(245, 245, 245, 0.54);
    font-size: 10px;
}

@media (min-width: 600px) {
    .aae-route-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .aae-route-card {
        min-height: 138px;
    }
}

.aae-hack-hud {
    flex-wrap: wrap;
    justify-content: center;
}

.aae-hack-hud > span {
    white-space: nowrap;
}
