*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden}canvas{display:block}.door-label{text-align:center;white-space:nowrap;background:#000000b3;border-radius:8px;padding:8px 16px;font-family:Arial,sans-serif}.door-title{color:#fff;margin-bottom:4px;font-size:16px;font-weight:700}.door-subtitle{color:#aaa;font-size:12px}.hud-container{color:#fff;pointer-events:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#2a2a3ab3;border-radius:12px;padding:16px;font-family:Arial,sans-serif;transition:opacity .3s;position:fixed;bottom:20px;right:20px}.hud-shortcuts{flex-direction:column;gap:10px;display:flex}.hud-item{align-items:center;gap:12px;display:flex}.hud-key{color:#fff;background:#4a90d9;border:1px solid #fff3;border-radius:6px;justify-content:center;align-items:center;min-width:36px;height:36px;padding:0 8px;font-size:14px;font-weight:700;display:flex;box-shadow:0 2px 4px #0000004d}.hud-description{color:#e0e0e0;white-space:nowrap;font-size:14px}.overlay-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;cursor:pointer;background-color:#0009;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.overlay-container{cursor:default;background:linear-gradient(135deg,#2a2a3a 0%,#3a3a4a 100%);border-radius:12px;max-width:90%;max-height:90%;padding:32px;font-family:Arial,sans-serif;position:relative;overflow:auto;box-shadow:0 -5px 40px #00000080,0 0 0 1px #ffffff1a}.overlay-close{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:24px;font-weight:700;line-height:1;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.overlay-close:hover{background:#ff4d4dcc;border-color:#ff4d4d;transform:scale(1.1)}.overlay-close:active{transform:scale(.95)}.overlay-content{color:#fff;min-width:300px}.overlay-container::-webkit-scrollbar{width:8px}.overlay-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.overlay-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.overlay-container::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.contact-form{box-sizing:border-box;width:550px;max-width:90vw;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.contact-form-header{justify-content:center;margin-bottom:24px;display:flex}.theme-toggle{cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:8px 16px;font-size:18px;transition:all .2s}.theme-toggle:hover{background:#fff3;transform:scale(1.05)}.theme-toggle:active{transform:scale(.95)}.contact-form-content{flex-direction:column;display:flex}.form-group{box-sizing:border-box;flex-direction:column;gap:8px;max-width:100%;display:flex}.error-message{word-wrap:break-word;overflow-wrap:break-word;white-space:normal;max-width:100%;min-height:50px;line-height:1.4;display:block;overflow:hidden}.contact-form[data-theme=minimalist]{color:#333}.contact-form[data-theme=minimalist] label{color:#555;margin-bottom:4px;font-size:14px;font-weight:600}.contact-form[data-theme=minimalist] input,.contact-form[data-theme=minimalist] textarea{color:#333;box-sizing:border-box;background:#fff;border:1px solid #d0d0d0;border-radius:8px;width:100%;padding:12px 16px;font-family:inherit;font-size:15px;transition:all .2s}.contact-form[data-theme=minimalist] input:focus,.contact-form[data-theme=minimalist] textarea:focus{border-color:#4a90d9;outline:none;box-shadow:0 0 0 3px #4a90d91a}.contact-form[data-theme=minimalist] textarea{resize:vertical;min-height:120px;max-height:300px;font-family:inherit}.contact-form[data-theme=minimalist] textarea::-webkit-scrollbar{width:8px}.contact-form[data-theme=minimalist] textarea::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.contact-form[data-theme=minimalist] textarea::-webkit-scrollbar-thumb{background:#4a90d9;border-radius:4px}.contact-form[data-theme=minimalist] textarea::-webkit-scrollbar-thumb:hover{background:#357abd}.contact-form[data-theme=minimalist] .form-group.has-error input,.contact-form[data-theme=minimalist] .form-group.has-error textarea{border-color:#f44}.contact-form[data-theme=minimalist] .error-message{color:#f44;min-height:50px;margin-top:4px;font-size:13px}.contact-form[data-theme=minimalist] .submit-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4a90d9 0%,#357abd 100%);border:none;border-radius:8px;padding:14px 24px;font-family:inherit;font-size:16px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #4a90d94d}.contact-form[data-theme=minimalist] .submit-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4a90d966}.contact-form[data-theme=minimalist] .submit-button:active{transform:translateY(0)}.contact-form[data-theme=minimalist] .submit-button:disabled{cursor:not-allowed;box-shadow:none;background:#ccc}.contact-form[data-theme=minimalist] .form-error{color:#c00;text-align:center;background:#ffe6e6;border:1px solid #f44;border-radius:8px;padding:12px 16px;font-size:14px;display:none}.contact-form[data-theme=terminal]{color:#0f0}.contact-form[data-theme=terminal] label{color:#3f3;letter-spacing:1px;text-shadow:0 0 8px #0f09;font-family:Courier New,Consolas,Monaco,monospace;font-size:14px;font-weight:700}.contact-form[data-theme=terminal] input,.contact-form[data-theme=terminal] textarea{color:#0f0;box-sizing:border-box;background:#0a0a0a;border:2px solid #0f0;border-radius:4px;width:100%;padding:12px 16px;font-family:Courier New,Consolas,Monaco,monospace;font-size:15px;transition:all .2s;box-shadow:0 0 10px #00ff004d}.contact-form[data-theme=terminal] input:focus,.contact-form[data-theme=terminal] textarea:focus{border-color:#3f3;outline:none;box-shadow:0 0 20px #0f09,inset 0 0 8px #0f03}.contact-form[data-theme=terminal] textarea{resize:vertical;min-height:120px;max-height:300px}.contact-form[data-theme=terminal] textarea::-webkit-scrollbar{width:10px}.contact-form[data-theme=terminal] textarea::-webkit-scrollbar-track{background:#0a0a0a;border:1px solid #0f0;border-radius:2px}.contact-form[data-theme=terminal] textarea::-webkit-scrollbar-thumb{background:#0f0;border-radius:2px;box-shadow:0 0 8px #0f09}.contact-form[data-theme=terminal] textarea::-webkit-scrollbar-thumb:hover{background:#3f3;box-shadow:0 0 12px #0f0c}.contact-form[data-theme=terminal] .form-group.has-error input,.contact-form[data-theme=terminal] .form-group.has-error textarea{border-color:#f33;box-shadow:0 0 10px #f336}.contact-form[data-theme=terminal] .error-message{color:#f33;text-shadow:0 0 8px #f339;min-height:60px;margin-top:4px;font-family:Courier New,Consolas,Monaco,monospace;font-size:13px}.contact-form[data-theme=terminal] .submit-button{color:#0f0;cursor:pointer;text-shadow:0 0 8px #0f09;letter-spacing:1px;background:#0a0a0a;border:2px solid #0f0;border-radius:4px;padding:14px 24px;font-family:Courier New,Consolas,Monaco,monospace;font-size:16px;font-weight:700;transition:all .3s;box-shadow:0 0 15px #0f06}.contact-form[data-theme=terminal] .submit-button:hover{text-shadow:0 0 12px #0f0c;background:#00ff001a;box-shadow:0 0 25px #0f09}.contact-form[data-theme=terminal] .submit-button:active{transform:scale(.98)}.contact-form[data-theme=terminal] .submit-button:disabled{color:#666;box-shadow:none;text-shadow:none;cursor:not-allowed;background:#0a0a0a;border-color:#666}.contact-form[data-theme=terminal] .form-error{color:#f33;text-align:center;text-shadow:0 0 8px #f339;background:#1a0000;border:2px solid #f33;border-radius:4px;padding:12px 16px;font-family:Courier New,Consolas,Monaco,monospace;font-size:14px;display:none;box-shadow:0 0 15px #f336}.spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.contact-form[data-theme=terminal] .spinner{border-color:#0f0 #00ff004d #00ff004d;box-shadow:0 0 10px #0f06}@media (max-width:768px){.contact-form{width:100%;max-width:100%}}.success-notification{color:#fff;z-index:2000;-webkit-user-select:none;user-select:none;cursor:default;background:linear-gradient(135deg,#2ecc71 0%,#27ae60 100%);border-radius:12px;align-items:center;gap:12px;padding:16px 24px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;font-weight:600;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:-100px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0000004d,0 0 0 1px #fff3}.success-notification.show{bottom:40px}.success-icon{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;display:flex}.success-message{white-space:nowrap}@media (max-width:768px){.success-notification{padding:12px 20px;font-size:14px}.success-notification.show{bottom:20px}}.key-button{color:#2a2a3a;cursor:default;-webkit-user-select:none;user-select:none;background:linear-gradient(#fff 0%,#e0e0e0 100%);border:2px solid #ccc;border-radius:6px;justify-content:center;align-items:center;font-family:monospace;font-weight:700;transition:all .1s;display:inline-flex;box-shadow:0 4px #999,0 6px 8px #0003}.key-button--small{width:32px;height:32px;font-size:14px}.key-button--medium{width:48px;height:48px;font-size:18px}.key-button--large{width:64px;height:64px;font-size:24px}.key-button:hover{transform:translateY(2px);box-shadow:0 2px #999,0 3px 4px #0003}.key-button.pressed{transform:translateY(4px);box-shadow:0 0 #999,0 2px 2px #0000001a}.key-button__label{-webkit-user-select:none;user-select:none}.keyboard-indicator{z-index:100;opacity:0;pointer-events:none;padding-bottom:4vh;position:fixed;bottom:0;left:50%;transform:translate(-50%)translateY(100%)}.keyboard-indicator.visible{animation:.3s ease-out forwards slideUpIndicator}.keyboard-indicator.hiding{animation:.3s ease-in forwards slideDownIndicator}.keyboard-indicator__content{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;border-radius:12px;flex-direction:column;gap:12px;padding:20px 32px;display:flex}.keyboard-indicator__row{justify-content:center;align-items:center;gap:16px;display:flex}.keyboard-indicator__key-group{flex-direction:column;align-items:center;gap:8px;display:flex}.keyboard-indicator__label{color:#fff;text-transform:uppercase;letter-spacing:.5px;-webkit-user-select:none;user-select:none;font-family:Arial,sans-serif;font-size:12px}@keyframes slideUpIndicator{0%{opacity:0;transform:translate(-50%)translateY(100%)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes slideDownIndicator{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(100%)}}@media (max-height:600px){.keyboard-indicator{padding-bottom:2vh}.keyboard-indicator__content{gap:8px;padding:12px 20px}.keyboard-indicator__row{gap:12px}.keyboard-indicator__label{font-size:10px}}.project-cube-label{color:#fff;pointer-events:none;white-space:nowrap;background:#0009;border-radius:4px;padding:4px 8px;font-family:Arial,sans-serif;font-size:14px}.competence-trophy-label{color:#d4af37;pointer-events:none;background:#00000080;border-radius:3px;padding:3px 6px;font-family:Arial,sans-serif;font-size:12px;font-weight:700}.teleporter-label{color:#4a90d9;pointer-events:none;text-align:center;background:#000000b3;border-radius:8px;padding:8px 16px;font-family:Arial,sans-serif;font-size:16px;font-weight:700}.project-overlay h1{color:#4a90d9;margin-bottom:16px}.project-overlay h3{color:#ccc;margin-top:16px;margin-bottom:8px}.project-overlay p{color:#e0e0e0;line-height:1.6}.project-overlay ul{flex-wrap:wrap;gap:8px;padding:0;list-style:none;display:flex}.project-overlay li{background:#4a90d933;border:1px solid #4a90d966;border-radius:4px;padding:6px 12px;font-size:14px}
