:root {
    --matrix-green: #00ff41;
    --matrix-green-glow: rgba(0, 255, 65, 0.7);
    --bg-dark: #000000;
    --text-hud: #00ff41;
    --text-primary: #9cffb8;
    --border-color: rgba(0, 255, 65, 0.4);
    --font-display: 'Orbitron', sans-serif;
    --font-mono: 'Roboto Mono', monospace;
    --color-success: #00ff41;
    --color-error: #ff4d4d;
    --pyramid-size: 200px;
}
@media (max-width: 480px) { :root { --pyramid-size: 150px; } }

#matrix-canvas { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
html, body {
    background-color: var(--bg-dark); color: var(--text-primary); font-family: var(--font-mono);
    width: 100%; min-height: 100vh; margin: 0;
    display: flex; flex-direction: column; justify-content: center; align-items: center;
    overflow-x: hidden; padding: 1rem 0; box-sizing: border-box;
}
.console-container {
    position: relative; z-index: 2; width: 90%; max-width: 800px; margin: auto;
    border: 2px solid var(--border-color); background: rgba(10, 20, 10, 0.85);
    backdrop-filter: blur(8px); box-shadow: 0 0 40px var(--matrix-green-glow), inset 0 0 15px rgba(0, 255, 65, 0.3);
    padding: 1.5rem; text-align: center;
    transition: all 0.5s ease-in-out;
    overflow: hidden;
}
.console-container::after { /* Scanline effect */
    content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background: repeating-linear-gradient(0deg, rgba(0,0,0,0) 0px, rgba(0,0,0,0) 1px, rgba(0,255,65,0.1) 2px, rgba(0,255,65,0.1) 3px);
    animation: scanlines 10s linear infinite; pointer-events: none;
}
@keyframes scanlines { from { background-position: 0 0; } to { background-position: 0 -100px; } }

.screen-content { animation: fadeIn 1s ease-in-out; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.screen-header { margin-bottom: 1.5rem; }
.header-logo { display: block; margin: 0 auto 1rem auto; max-width: 150px; opacity: 0.9; }
.title { font-family: var(--font-display); color: var(--matrix-green); font-size: clamp(1.5rem, 8vw, 2.5rem); margin: 0; letter-spacing: 5px; text-shadow: 0 0 15px var(--matrix-green); animation: text-flicker 3s infinite; }
.subtitle { font-size: clamp(0.9rem, 3vw, 1rem); margin: 0.5rem 0 1.5rem 0; color: var(--text-hud); text-transform: uppercase; letter-spacing: 2px; }
@keyframes text-flicker { 0%, 18%, 22%, 25%, 53%, 57%, 100% { text-shadow: 0 0 4px #fff, 0 0 11px #fff, 0 0 19px #fff, 0 0 40px var(--matrix-green), 0 0 80px var(--matrix-green), 0 0 90px var(--matrix-green), 0 0 100px var(--matrix-green), 0 0 150px var(--matrix-green); } 20%, 24%, 55% { text-shadow: none; } }

.input-field { width: 100%; max-width: 400px; padding: 0.8rem; border: 1px solid var(--border-color); background-color: rgba(0,0,0,0.5); color: var(--text-primary); font-family: var(--font-mono); font-size: 1.2rem; text-align: center; margin: 1.5rem 0; }
.input-field::placeholder { color: rgba(0, 255, 65, 0.3); }
.input-field:focus { outline: none; border-color: var(--matrix-green); box-shadow: 0 0 10px var(--matrix-green-glow); }
.action-button { font-family: var(--font-display); font-size: clamp(1rem, 4vw, 1.5rem); padding: 1rem 2rem; border: 3px solid var(--matrix-green); color: var(--matrix-green); background: transparent; cursor: pointer; text-shadow: 0 0 5px var(--matrix-green); box-shadow: 0 0 15px var(--matrix-green-glow), inset 0 0 10px rgba(0, 255, 65, 0.3); transition: all 0.3s ease; margin: 0.5rem; }
.action-button:hover:not(:disabled) { background: var(--matrix-green); color: #000; text-shadow: none; transform: scale(1.05); }
.action-button:disabled { border-color: #555; color: #555; cursor: not-allowed; text-shadow: none; box-shadow: none; }

.date-input-container { display: flex; justify-content: center; gap: 0.5rem; margin: 1.5rem 0; align-items: center; }
.date-input-box { width: 80px; padding: 0.8rem; border: 1px solid var(--border-color); background-color: rgba(0,0,0,0.5); color: var(--text-primary); font-family: var(--font-mono); font-size: 1.2rem; text-align: center; -moz-appearance: textfield; }
.date-input-box::-webkit-outer-spin-button, .date-input-box::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.date-input-box::placeholder { color: rgba(0, 255, 65, 0.3); }
.date-input-box:focus { outline: none; border-color: var(--matrix-green); box-shadow: 0 0 10px var(--matrix-green-glow); }
.date-separator { font-size: 1.5rem; color: var(--border-color); padding: 0 0.5rem; }

#blueprint-panel { text-align: left; height: 35vh; max-height: 400px; overflow-y: auto; border: 1px solid var(--border-color); padding: 1rem; margin-top: 1.5rem; background: rgba(0,0,0,0.3); position: relative; }
#blueprint-panel::before { /* Animated grid background */
    content: ''; position: absolute; top: 0; left: 0; width: 200%; height: 200%; z-index: -1;
    background-image: linear-gradient(var(--border-color) 1px, transparent 1px), linear-gradient(90deg, var(--border-color) 1px, transparent 1px);
    background-size: 30px 30px; opacity: 0.2;
    animation: bg-scroll 20s linear infinite;
}
@keyframes bg-scroll { from { transform: translate(0, 0); } to { transform: translate(-50%, -50%); } }
#blueprint-text { white-space: pre-wrap; font-size: 1rem; line-height: 1.6; }
#blueprint-text strong { color: var(--matrix-green); font-weight: bold; }
.blinking-cursor { animation: blink 1s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }

#button-dock { margin-top: 1.5rem; border-top: 1px dashed var(--border-color); padding-top: 1.5rem; display: flex; justify-content: center; flex-wrap: wrap; gap: 1rem; }
.dock-button { font-family: var(--font-display); font-size: 0.9rem; padding: 0.8rem 1.5rem; border: 2px solid var(--matrix-green); color: var(--matrix-green); background: transparent; cursor: pointer; text-shadow: 0 0 5px var(--matrix-green); box-shadow: inset 0 0 8px rgba(0, 255, 65, 0.2); transition: all 0.2s ease; text-decoration: none; }
.dock-button:hover:not(:disabled) { background: var(--matrix-green); color: #000; text-shadow: none; }

/* --- ANALYSIS & DECODER SCREENS --- */
.analysis-container, .decoder-grid { display: grid; place-items: center; width: 100%; margin: 2rem 0; min-height: 200px; }
.analysis-orb { width: 150px; height: 150px; transform-style: preserve-3d; animation: rotateOrb 20s linear infinite; }
.orb-ring { position: absolute; width: 100%; height: 100%; border: 2px solid; border-radius: 50%; animation: pulse 2s infinite alternate; }
.orb-ring:nth-child(1) { transform: rotateY(75deg); border-color: rgba(0,255,65,0.4); }
.orb-ring:nth-child(2) { transform: rotateX(75deg); border-color: rgba(0,255,65,0.6); animation-delay: -1s; }
.orb-ring:nth-child(3) { transform: rotateX(30deg) rotateY(45deg); border-color: rgba(0,255,65,0.8); animation-delay: -0.5s; }
@keyframes rotateOrb { from { transform: rotateY(0) rotateX(0); } to { transform: rotateY(360deg) rotateX(360deg); } }
@keyframes pulse { from { transform: scale(0.9); opacity: 0.7; } to { transform: scale(1.1); opacity: 1; } }

.decoder-grid { grid-template-columns: 1fr 2fr 1fr; gap: 1rem; }
.data-stream { font-size: 0.8rem; height: 150px; overflow: hidden; text-align: left; writing-mode: vertical-rl; text-orientation: upright; color: rgba(0, 255, 65, 0.5); }
.central-glyph { font-family: var(--font-mono); font-size: 100px; color: var(--matrix-green); text-shadow: 0 0 25px var(--matrix-green); animation: glyph-flicker 100ms infinite; }
@keyframes glyph-flicker { 0% { opacity: 0.8; transform: scale(1); } 50% { opacity: 1; transform: scale(1.02); } 100% { opacity: 0.8; transform: scale(1); } }
.progress-label { text-transform: uppercase; letter-spacing: 2px; margin-top: 1rem; font-size: 0.9em; color: var(--text-hud); min-height: 1.2em; }

/* --- Success Message & Pyramid Styles --- */
.success-message { text-align: center; font-size: clamp(1rem, 2.5vw, 1.1rem); line-height: 1.8; color: var(--text-primary); }
.success-message .highlight { color: var(--matrix-green); font-family: var(--font-display); letter-spacing: 2px; text-shadow: 0 0 8px var(--matrix-green-glow); font-size: clamp(1.1rem, 3vw, 1.3rem); display: block; margin: 1rem 0; }
#result-panel { position: relative; display: flex; flex-direction: column; align-items: center; gap: 1.5rem; }
.win-text { z-index: 10; font-size: 1.1rem; line-height: 1.6; text-align: center; padding: 0 1rem; }
.pyramid-container { z-index: 5; position: relative; width: calc(var(--pyramid-size) * 1.5); height: calc(var(--pyramid-size) * 1.2); perspective: 1200px; margin: 1rem 0; }
.pyramid { position: absolute; top: 50%; left: 50%; width: var(--pyramid-size); height: var(--pyramid-size); transform-style: preserve-3d; animation: rotatePyramid 25s linear infinite; }
@keyframes rotatePyramid { from { transform: translate(-50%, -50%) rotateX(10deg) rotateY(0deg); } to { transform: translate(-50%, -50%) rotateX(10deg) rotateY(360deg); } }
.pyramid-face { position: absolute; width: 100%; height: 100%; clip-path: polygon(50% 0, 0 100%, 100% 100%); background: radial-gradient(ellipse at 50% 30%, rgba(0, 255, 65, 0.4), transparent 80%); border: 1px solid var(--matrix-green-glow); box-shadow: 0 0 25px var(--matrix-green-glow), inset 0 0 15px rgba(0, 255, 65, 0.3); transform-origin: bottom; }
.pyramid-face.front { transform: rotateY(0deg) translateZ(calc(var(--pyramid-size) / 2)) rotateX(60deg); }
.pyramid-face.back { transform: rotateY(180deg) translateZ(calc(var(--pyramid-size) / 2)) rotateX(60deg); }
.pyramid-face.left { transform: rotateY(-90deg) translateZ(calc(var(--pyramid-size) / 2)) rotateX(60deg); }
.pyramid-face.right { transform: rotateY(90deg) translateZ(calc(var(--pyramid-size) / 2)) rotateX(60deg); }
.eye { position: absolute; top: 50%; left: 50%; width: calc(var(--pyramid-size) * 0.25); height: calc(var(--pyramid-size) * 0.175); background: var(--matrix-green); border-radius: 50%; border: 2px solid #fff; box-shadow: 0 0 30px 10px var(--matrix-green-glow), inset 0 0 10px #fff; transform: translate(-50%, -130%) translateZ(calc(var(--pyramid-size) * 0.25)); animation: eyeGlow 2.5s infinite alternate ease-in-out; }
.eye::before { content: ''; position: absolute; top: 50%; left: 50%; width: 30%; height: 60%; background: #000; border-radius: 50%; transform: translate(-50%, -50%); border: 1px solid var(--matrix-green); }
@keyframes eyeGlow { from { transform: translate(-50%, -130%) translateZ(calc(var(--pyramid-size) * 0.25)) scale(1); box-shadow: 0 0 30px 10px var(--matrix-green-glow), inset 0 0 10px #fff; } to { transform: translate(-50%, -130%) translateZ(calc(var(--pyramid-size) * 0.25)) scale(1.05); box-shadow: 0 0 45px 15px var(--matrix-green-glow), inset 0 0 15px #fff; } }