/* --- ANIMATION-SPECIFIC STYLES for privilege-escalation.js --- */

/* Base nodes used across scenes */
.node {
    position: absolute; padding: 15px; border: 2px solid var(--secondary-surface);
    background-color: var(--dark-bg); border-radius: 8px;
    text-align: center; box-shadow: 0 5px 15px rgba(0,0,0,0.2); z-index: 10;
}
.user { width: 90px; height: 60px; }
.user.compromised { border-color: var(--color-warning); }
.user.admin { border-color: var(--color-bad); background-color: #332020; }
.user.system { border-color: #fff; background-color: #4a4a4a; font-weight: bold; }
.server { width: 120px; height: 120px; border-radius: 12px; }
.callout { font-size: 12px; padding: 5px 8px; border-color: var(--color-neutral); color: var(--text-muted); }
.terminal, .linux-terminal {
    font-size: 14px; text-align: left; min-height: 80px; width: 550px;
    background-color: #0c0c0c; border: 1px solid var(--secondary-surface);
}
.terminal .prompt, .linux-terminal .prompt { color: var(--accent-color); }
.terminal-cursor { display: inline-block; background-color: var(--accent-color); width: 8px; height: 16px; animation: blink 1s infinite; vertical-align: middle;}
@keyframes blink { 50% { opacity: 0; } }
.arrow { position: absolute; fill: var(--text-muted); z-index: 5; transition: fill 0.5s; }
.arrow.attack { fill: var(--color-bad); }

/* --- Specific Scenes Styles --- */

/* Avoiding Alerts */
.security-gate { font-size: 48px; border-color: var(--color-defense); display: flex; align-items: center; justify-content: center; width: 100px; height: 100px;}
.traffic { font-size: 24px; border-radius: 8px; padding: 10px; border: 1px solid; }
.traffic.malware { color: var(--color-bad); border-color: var(--color-bad); }
.traffic.powershell { color: var(--accent-color); border-color: var(--accent-color); }

/* Kernel Exploit */
.kernel { background: #5a2a2a; color: var(--color-bad); font-size: 12px; border: 1px solid var(--color-bad); padding: 5px; }
.exploit-code { color: var(--color-warning); font-size: 24px; padding: 0; background: transparent; border: none; }

/* Access Token */
.process { width: 150px; text-align: center; }
.token { position: absolute; font-size: 24px; z-index: 15; transform-origin: center; }

/* Accessibility Exploit */
.login-screen { position: absolute; width: 350px; height: 250px; background-color: #0d2e4e; border: 2px solid var(--color-neutral); border-radius: 10px; display: flex; flex-direction: column; align-items: center; padding-top: 30px; }
.login-screen input { width: 70%; padding: 10px; margin-top: 20px; border-radius: 4px; border: none; }
.access-icon { position: absolute; bottom: 15px; left: 15px; font-size: 24px; cursor: pointer; transition: transform 0.2s; }
.access-icon:hover { transform: scale(1.1); }
.login-terminal { z-index: 20; position: absolute; top: 100px; left: 600px; width: 450px; }

/* DLL Hijacking */
.program { width: 120px; height: 80px; border-color: var(--accent-color); }
.dll-file { font-family: 'Courier New', monospace; font-size: 12px; padding: 8px; border-radius: 4px; border: 1px solid var(--text-muted); }
.dll-file.malicious { border-color: var(--color-bad); background-color: #332020; }
.search-path { stroke: var(--text-muted); stroke-width: 2; fill: none; stroke-dasharray: 5; }

/* SAM Dump */
.database { font-size: 32px; background-color: var(--dark-bg); padding: 15px; border-radius: 50%; }
.sam-file { font-size: 14px; background: var(--color-data); color: var(--dark-bg); padding: 8px; border-radius: 4px; }
.cracker { font-size: 24px; width: 100px; height: 100px; border: 2px dashed var(--secondary-surface); display: grid; place-content: center; }

/* Application Shimming */
.os-kernel { border-color: var(--color-neutral); width: 400px; height: 100px; }
.shim-db { border: 1px solid; padding: 10px; font-size: 14px; width: 180px; text-align: center; }
.shim-db.legit { border-color: var(--color-good); }
.shim-db.malicious { border-color: var(--color-bad); }

/* Bypassing UAC */
.uac-prompt { position: absolute; z-index: 20; width: 400px; background: #ddd; color: #111; padding: 15px; border-radius: 8px; border-top: 20px solid #005a9e; box-shadow: 0 10px 30px rgba(0,0,0,0.5); font-size: 14px; }
.uac-prompt strong { color: #005a9e; }
.uac-prompt .buttons { text-align: right; margin-top: 20px; }
.uac-prompt button { padding: 8px 15px; border-radius: 4px; border: 1px solid #999; margin-left: 5px; cursor: pointer; }
.uac-prompt button.yes { background-color: #0078d4; color: white; border: none; }
.trusted-process { border-color: var(--color-good); }

/* Sudo Caching */
.timer { position: absolute; font-size: 18px; color: var(--color-warning); font-family: monospace; }

/* Sub-step Navigation */
.sub-step-nav { position: absolute; bottom: 15px; right: 20px; z-index: 100; }
.sub-step-button { background-color: var(--secondary-surface); color: var(--text-muted); border: 1px solid #555; padding: 8px 15px; border-radius: 8px; cursor: pointer; transition: all 0.2s; margin-left: 5px; }
.sub-step-button:hover:not(:disabled) { background-color: var(--accent-color); color: var(--dark-bg); }
.sub-step-button:disabled { cursor: not-allowed; opacity: 0.3; }