.puzzle-bg{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;position:relative;background-color:#000;overflow:hidden;background:url(/assets/close-up-puzzle-background-0f7e5166.jpg) center center/cover no-repeat fixed;will-change:transform;transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden;perspective:1000;-webkit-perspective:1000}.puzzle-bg:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:url(/assets/close-up-puzzle-background-0f7e5166.jpg) center center/cover no-repeat fixed;opacity:0;z-index:-1;filter:blur(10px);transform:scale(1.1);transition:opacity .5s ease-out}.puzzle-bg.loaded:before{opacity:1;filter:blur(0);transform:scale(1)}.puzzle-bg:after{content:"";position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite;opacity:1;transition:opacity .3s ease-out}.puzzle-bg.loaded:after{opacity:0}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.login-container,.forgot-password-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:1;visibility:visible;z-index:1;pointer-events:auto}.login-container.hidden,.forgot-password-container.hidden{opacity:0;visibility:hidden;pointer-events:none;z-index:0}.login-container{background:#eaf6fb;border-radius:32px;box-shadow:0 8px 32px #0000001f;padding:2.5rem 2rem 2rem;min-width:340px;max-width:370px;width:100%;display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.login-container.success-message{background:#eaf6fb;color:#222}.login-container.success-message h3{color:#222;font-size:1.5rem;margin-bottom:1rem}.login-container.success-message p{color:#222;opacity:.9;font-size:1.1rem;margin-bottom:1.5rem}.login-container.success-message .spinner{border:3px solid rgba(255,255,255,.3);border-top-color:#fff}.login-logo{width:120px;margin-bottom:1.2rem}.login-title{font-size:2.2rem;color:#3a3a3a;margin-bottom:1.2rem;font-weight:700;letter-spacing:1px}.login-form{width:100%;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.2rem;box-sizing:border-box}.login-input{width:100%;padding:.9rem 2.5rem .9rem 1.1rem;border-radius:16px;border:none;font-size:1.1rem;background:#fff;box-shadow:0 2px 8px #0000000a;outline:none;transition:box-shadow .2s;color:#222;box-sizing:border-box}.login-input::placeholder{color:#888;opacity:1}.login-input:focus{box-shadow:0 0 0 2px #f9a34c}.password-wrapper{position:relative;width:100%;box-sizing:border-box}.toggle-password{position:absolute;right:1.1rem;top:50%;transform:translateY(-50%);font-size:1.2rem;color:#888;cursor:pointer;-webkit-user-select:none;user-select:none;background:none;border:none;padding:0;display:flex;align-items:center}.error-msg{color:#e74c3c;font-size:.95rem;margin-top:-.7rem;margin-bottom:.3rem;padding-left:.2rem}.login-options{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:.2rem}.remember-me{color:#222;font-size:1rem;display:flex;align-items:center;gap:.3rem}.login-btn{background:#f97c4c;color:#fffbe7;font-size:1.2rem;font-weight:700;border:none;border-radius:16px;padding:.9rem 0;cursor:pointer;margin-top:.5rem;transition:background .2s}.login-btn:hover{background:#f9a34c}.forgot-password{color:#3a3a3a;font-size:1rem;text-decoration:underline;cursor:pointer;font-weight:500;margin:0}.or-separator{width:100%;text-align:center;color:#888;margin:1.2rem 0 .7rem;font-size:1rem;position:relative}.or-separator span{background:#eaf6fb;padding:0 .7rem;position:relative;z-index:1}.or-separator:before{content:"";display:block;position:absolute;top:50%;left:0;width:100%;height:1px;background:#d0d0d0;z-index:0}.social-login-btns{display:flex;gap:.7rem;justify-content:center;margin-bottom:.7rem}.social-btn{background:#222;color:#fff;border:2px solid #fff;border-radius:10px;padding:.5rem 1.1rem;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;transition:background .2s,color .2s;justify-content:center;min-width:44px;min-height:44px}.social-btn:focus,.social-btn:hover{background:#f97c4c;color:#fffbe7;border-color:#f97c4c}.social-icon{font-weight:700;font-size:1.1rem;display:flex;align-items:center;justify-content:center}.signup-text{width:100%;text-align:center;color:#888;font-size:1rem;margin-top:.5rem;margin-bottom:.2rem}.signup-link{color:#222;font-size:1rem;text-decoration:underline;margin-top:.2rem;cursor:pointer;font-weight:600;display:inline}.forgot-password-container.success-message{background:#eaf6fb;border-radius:32px;color:#222;box-shadow:0 8px 32px #0000001f;padding:2.5rem 2rem 2rem;min-width:340px;max-width:370px;width:100%;display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.forgot-password-container{background:#eaf6fb;border-radius:32px;box-shadow:0 8px 32px #0000001f;padding:2.5rem 2rem 2rem;min-width:340px;max-width:370px;width:100%;display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.forgot-password-title{font-size:1.8rem;color:#3a3a3a;margin:1rem 0;font-weight:700;letter-spacing:.5px}.forgot-password-text{color:#666;text-align:center;margin-bottom:1.5rem;line-height:1.5;font-size:1rem}.forgot-password-form{width:100%;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.2rem}.success-message{text-align:center;color:#2ecc71;margin:1rem 0;padding:1rem;background:rgba(46,204,113,.1);border-radius:16px;width:100%}.success-message p{margin:.5rem 0}.check-email{font-weight:600;color:#27ae60}.back-to-login{background:none;border:none;color:#3a3a3a;font-size:1rem;cursor:pointer;text-decoration:underline;margin-top:1rem;padding:.5rem;transition:color .2s}.back-to-login:hover{color:#f97c4c}.password-wrapper{position:relative;display:flex;align-items:center}.password-wrapper input{flex:1;padding-right:3rem}.toggle-password{position:absolute;right:1rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:1.2rem}.centered-auth{min-height:100vh;display:flex;align-items:center;justify-content:center}.signup-card{background:#eaf6fb;border-radius:32px;box-shadow:0 8px 32px #0000001f;padding:2.5rem 2rem 2rem;width:420px;max-width:100%;display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.login-logo{width:120px;margin-bottom:.5rem}.logo{font-size:2rem;color:#3a3a3a;margin-bottom:.5rem;font-weight:700;letter-spacing:1px;text-align:center}.ai-green{color:#4caf50}h3{text-align:center;margin-bottom:1.5rem;color:#3a3a3a;font-size:1.6rem;font-weight:700}form{width:100%;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.2rem;box-sizing:border-box}input[type=text],input[type=email],input[type=password]{width:100%;padding:.9rem 1.1rem;border-radius:16px;border:none;font-size:1.1rem;background:#fff;box-shadow:0 2px 8px #0000000a;outline:none;transition:box-shadow .2s;color:#222;box-sizing:border-box}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder{color:#888;opacity:1}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus{box-shadow:0 0 0 2px #f9a34c}small{color:#888;margin-bottom:-.5rem;margin-top:-.7rem;font-size:.95rem;padding-left:.2rem}.slider-label{font-size:1rem;color:#3a3a3a;margin-bottom:.7rem;font-weight:500}.slider-section{width:100%;margin-bottom:.7rem}input[type=range].slider{width:100%;margin:0 0 .7rem}.slider-labels{display:flex;justify-content:space-between;font-size:1rem;margin-top:0;margin-bottom:.2rem}.slider-labels span{color:#888;font-weight:500;font-size:1rem;transition:color .2s,font-weight .2s}.active-label{color:#3a3a3a;font-weight:700}.slider-desc{text-align:center;font-size:1.08rem;color:#f97c4c;margin-top:.3rem;margin-bottom:.5rem;font-style:italic;font-weight:500}.create-account-btn{background:#f97c4c;color:#fffbe7;font-size:1.2rem;font-weight:700;border:none;border-radius:16px;padding:.9rem 0;cursor:pointer;margin-top:.5rem;transition:background .2s}.create-account-btn:hover{background:#f9a34c}.terms{font-size:.8rem;color:#888;text-align:center;margin:1rem 0 .5rem}.terms a{color:#f97c4c;text-decoration:none}.or-divider{width:100%;text-align:center;color:#888;margin:1.2rem 0 .7rem;font-size:1rem;position:relative}.or-divider span{background:#eaf6fb;padding:0 .7rem;position:relative;z-index:1}.or-divider:before{content:"";display:block;position:absolute;top:50%;left:0;width:100%;height:1px;background:#d0d0d0;z-index:0}.social-buttons{display:flex;gap:.7rem;justify-content:center;margin-bottom:.7rem}.google-btn,.github-btn{background:#222;color:#fff;border:2px solid #fff;border-radius:10px;padding:.5rem 1.1rem;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;transition:background .2s,color .2s;justify-content:center;min-width:44px;min-height:44px}.google-btn:focus,.github-btn:focus,.google-btn:hover,.github-btn:hover{background:#f97c4c;color:#fffbe7;border-color:#f97c4c}.signin-link span{color:#222;font-size:1rem;text-decoration:underline;margin-top:.2rem;cursor:pointer;font-weight:600;display:inline}.signin-link span:hover{color:#f97c4c;transition:color .2s}@media (max-width: 500px){.signup-card{padding:1rem .5rem;max-width:98vw;border-radius:16px}.login-logo{width:90px}.logo{font-size:1.3rem}h3{font-size:1rem}.slider-labels,.slider-desc{font-size:.7rem}}.or-divider-alt{width:100%;display:flex;align-items:center;text-align:center;color:#aaa;font-size:1rem;margin:1.2rem 0 .7rem}.or-divider-alt span{padding:0 1rem;background:transparent;position:relative;z-index:1}.or-divider-alt:before,.or-divider-alt:after{content:"";flex:1;border-bottom:1.5px solid #e0e0e0;margin-top:.1em}.google-signup-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.7rem;background:#fff;color:#222;border:1.5px solid #bbb;border-radius:10px;padding:.7rem 0;font-size:1.08rem;font-weight:500;cursor:pointer;margin-bottom:.7rem;transition:border-color .2s,box-shadow .2s}.google-signup-btn:hover,.google-signup-btn:focus{border-color:#f97c4c;box-shadow:0 2px 8px #f97c4c14}.google-icon{font-size:1.2rem}.google-img-icon{width:1.7rem;height:1.7rem;display:inline-block;vertical-align:middle}.signin-link{width:100%;text-align:center;color:#888;font-size:1rem;margin-top:.5rem;margin-bottom:.2rem}.spinner{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;display:inline-block;margin-right:8px}.error-msg{color:#dc3545;font-size:.9rem;margin-top:.5rem;text-align:center;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;padding:.5rem}button:disabled{opacity:.6;cursor:not-allowed}input:-webkit-autofill,input:-webkit-autofill:focus,input:-webkit-autofill:hover,input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px #fff inset!important;box-shadow:0 0 0 1000px #fff inset!important;-webkit-text-fill-color:#222!important;color:#222!important;transition:background-color 5000s ease-in-out 0s}html,body,#root{height:100%;width:100vw;margin:0;padding:0;box-sizing:border-box}.main-sections{display:flex;flex-direction:column;height:100vh;width:100%;max-width:100vw;min-width:0;margin-top:0;flex:1 1 auto;align-items:stretch}#root{padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.header-bar{position:fixed;top:0;left:0;width:100%;z-index:100;height:8vh;background:#fff;box-shadow:0 2px 4px #0000000a;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:flex-end}.header-logo-container{position:absolute;left:50%;top:0;height:100%;display:flex;align-items:center;transform:translate(-50%)}.header-logo{height:5vh;display:block}.header-profile-icon{width:6vh;height:6vh;padding:.7vh;box-sizing:border-box;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff;box-shadow:0 2px 8px #00000014;border:none;cursor:pointer;transition:box-shadow .2s}.header-profile-icon:active,.header-profile-icon:focus{box-shadow:0 0 0 2px #8882;outline:none}.header-coin-counter{display:flex;align-items:center;background:#aaa;border-radius:999px;padding:.1vh 1.2vh;margin-right:1.2vw;height:6vh;min-width:8vh;box-sizing:border-box}.header-coin-icon{width:3vh;height:3vh;margin-right:1.2vh;background:none;border-radius:50%;box-shadow:0 0 0 2px #fff}.header-coin-number{font-size:2.5vh;font-family:Roboto Mono,monospace;color:#fff;font-weight:400;letter-spacing:.1em;line-height:1}.progress-section{background:#FFFAED;position:fixed;top:8vh;left:0;width:100vw;z-index:10;transition:height .3s cubic-bezier(.4,0,.2,1);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:0 12px 32px #00000040;border-bottom-left-radius:32px;border-bottom-right-radius:32px}.drag-handle{position:absolute;left:50%;bottom:0;transform:translate(-50%,50%);background:#bbb;border-radius:50%;width:4vh;height:4vh;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001f;cursor:pointer;z-index:100;pointer-events:auto}.drag-handle.bottom{top:auto;bottom:0;transform:translate(-50%,50%)}.collapse-btn{background:#fff;border:none;border-radius:50%;width:3vh;height:3vh;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0000001f;transition:box-shadow .2s}.collapse-btn:active,.collapse-btn:focus{box-shadow:0 0 0 2px #8882;outline:none}.puzzle-lock-hover:hover{filter:drop-shadow(0 0 8px #222);transition:filter .2s}@keyframes blink-shadow{0%,to{filter:drop-shadow(0 0 10px #222a)}50%{filter:drop-shadow(0 0 20px #222c)}}.puzzle-piece-hoverable{cursor:pointer;filter:drop-shadow(0 0 10px #222a);transition:filter .2s;z-index:1}.puzzle-piece-hoverable:hover{filter:drop-shadow(0 0 32px #111b);z-index:2}.vertical-dashed-separator{border-left:2px dashed #6C6C6C;height:100%;position:absolute;top:0;z-index:2}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.playground-section{background:#D3D1CE;width:100%;flex:1 1 0;min-height:0;overflow:auto;overflow-x:hidden;position:relative;box-sizing:border-box;display:flex;align-items:flex-start;justify-content:center;margin-top:33vh;padding-top:2vh;height:67vh}.playground-section.question-mode{align-items:flex-start;margin-top:33vh;padding-top:7vh;padding-left:20px;padding-right:20px;padding-bottom:20px;overflow-y:auto;justify-content:flex-start}.vertical-separator{position:absolute;top:-40%;left:50%;transform:translate(-50%);width:3px;height:200%;background:repeating-linear-gradient(to bottom,#aaa,#aaa 8px,transparent 8px,transparent 16px);z-index:1;border-radius:2px;opacity:.7;pointer-events:none}.puzzle-blocks-container{transition:transform .5s cubic-bezier(.4,0,.2,1)}.puzzle-area-wrapper{position:relative;width:38.7vh;height:38.7vh;display:flex;align-items:center;justify-content:center}.question-submit-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;margin-top:auto;padding-top:20px;border-top:1px solid #e0e0e0;flex-shrink:0}.question-submit-section .submit-button{position:static;transform:none;margin:0;display:inline-block}.question-submit-section .submit-error{margin-top:0;text-align:center}.question-section{position:fixed;top:35vh;bottom:10vh;height:auto;max-height:none;transform:none;width:40vw;background:white;border-radius:12px;padding:24px;box-shadow:0 8px 32px #00000026;z-index:2;overflow-y:auto;box-sizing:border-box;display:flex;flex-direction:column}.question-section.question-left{left:5vw}.question-section.question-right{right:5vw}.question-content{flex:1;display:flex;flex-direction:column;min-height:0;word-wrap:break-word;overflow-wrap:break-word}.question-section *{max-width:100%;box-sizing:border-box}.question-container-wrapper{width:100%;max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.submit-section{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:24px;margin-bottom:10vh;position:relative}.submit-error{background:#f8d7da;color:#721c24;padding:12px 16px;border-radius:8px;border:1px solid #f5c6cb;font-size:14px;text-align:center;max-width:400px}.submit-error-overlay{position:absolute;bottom:60px;left:50%;transform:translate(-50%);background:#f8d7da;color:#721c24;padding:12px 16px;border-radius:8px;border:1px solid #f5c6cb;font-size:14px;text-align:center;max-width:400px;z-index:15}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;height:100%;min-height:200px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.loading-state p{color:#6c757d;font-size:16px;margin:0}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;height:100%;min-height:200px}.error-message{color:#e74c3c;font-size:16px;margin-bottom:16px}.retry-button{padding:8px 16px;background:#3498db;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .3s ease}.retry-button:hover{background:#2980b9}.no-task-selected{text-align:center;padding:40px 20px;color:#6c757d}.no-task-selected h3{color:#2c3e50;margin-bottom:12px;font-size:24px}.no-task-selected p{font-size:16px;line-height:1.5;max-width:400px;margin:0 auto}.subtask-piece{filter:drop-shadow(0 0 .5vh #fff) drop-shadow(0 0 1.2vh #fff)}@media (max-width: 1200px){.question-section{width:35vw;top:35vh;bottom:10vh;padding:24px}.question-section.question-left{left:7.5vw}.question-section.question-right{right:7.5vw}}@media (max-width: 1000px){.playground-section{flex-direction:column;align-items:center;padding-top:20px}.puzzle-area-wrapper{position:relative;margin-bottom:30px}.question-section{position:relative;top:auto;right:auto;left:auto;transform:none;width:100%;max-width:500px;margin-top:30px}.question-section.question-left,.question-section.question-right{position:relative;top:auto;right:auto;left:auto;transform:none}.puzzle-blocks-container{transform:none!important}.vertical-separator{width:100%;height:3px;top:auto;left:0;transform:none;background:repeating-linear-gradient(to right,#aaa,#aaa 8px,transparent 8px,transparent 16px)}}@media (max-width: 768px){.playground-section.question-mode{padding:16px}.question-container-wrapper{max-width:100%}.question-section{padding:16px;max-width:100%}.puzzle-area-wrapper{width:90vw;height:90vw;max-width:350px;max-height:350px}}.submit-button{padding:12px 24px;background-color:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #4caf504d;min-width:100px}.submit-button:hover:not(.disabled):not(.loading){background-color:#45a049;box-shadow:0 6px 16px #4caf5066}.submit-button:active:not(.disabled):not(.loading){box-shadow:0 2px 8px #4caf504d}.submit-button.disabled{background-color:#a9a8a7;cursor:not-allowed;box-shadow:none}.submit-button.loading{cursor:not-allowed;background-color:#5cbf60}.submit-loading{display:flex;align-items:center;gap:8px}.loading-spinner-small{width:16px;height:16px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.question-container{width:100%;max-width:800px;margin:0 auto;padding:24px;background:white;border-radius:12px;box-shadow:0 4px 16px #0000001a}.question-container.readonly{background:#f8f9fa;border:2px solid #e9ecef}.question-text{font-size:18px;font-weight:600;color:#2c3e50;margin-bottom:20px;line-height:1.5}.required-indicator{color:#e74c3c;margin-left:4px}.answer-container{width:100%;box-sizing:border-box;overflow:visible}.text-answer-input{width:100%;box-sizing:border-box;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;font-family:inherit;resize:vertical;min-height:120px;transition:border-color .3s ease}.text-answer-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.text-answer-input.invalid{border-color:#e74c3c}.character-count{text-align:right;font-size:12px;color:#6c757d;margin-top:8px}.radio-options{display:flex;flex-direction:column;gap:12px;padding:8px 0}.radio-options.invalid{border:2px solid #e74c3c;border-radius:8px;padding:16px;background:#fff5f5}.radio-option{display:flex;align-items:center;cursor:pointer;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;transition:all .3s ease;background:white}.radio-option:hover{border-color:#3498db;background:#f8f9fa}.radio-input{display:none}.radio-custom{width:20px;height:20px;border:2px solid #dee2e6;border-radius:50%;margin-right:12px;position:relative;transition:all .3s ease}.radio-input:checked+.radio-custom{border-color:#3498db;background:#3498db}.radio-input:checked+.radio-custom:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:white;border-radius:50%}.radio-label{font-size:16px;color:#2c3e50;line-height:1.4}.radio-input:checked+.radio-custom+.radio-label{font-weight:600}.multiselect-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.select-all-btn{padding:6px 12px;background:#3498db;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .3s ease}.select-all-btn:hover{background:#2980b9}.selection-count{font-size:14px;color:#6c757d;font-weight:500}.multiselect-options{display:flex;flex-direction:column;gap:12px;padding:8px 0;max-height:400px;overflow-y:auto}.multiselect-options.invalid{border:2px solid #e74c3c;border-radius:8px;padding:16px;background:#fff5f5}.multiselect-option{display:flex;align-items:center;cursor:pointer;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;transition:all .3s ease;background:white}.multiselect-option:hover{border-color:#3498db;background:#f8f9fa}.multiselect-input{display:none}.multiselect-custom{width:20px;height:20px;border:2px solid #dee2e6;border-radius:4px;margin-right:12px;position:relative;transition:all .3s ease}.multiselect-input:checked+.multiselect-custom{border-color:#3498db;background:#3498db}.multiselect-input:checked+.multiselect-custom:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:14px}.multiselect-label{font-size:16px;color:#2c3e50;line-height:1.4;flex:1}.multiselect-input:checked+.multiselect-custom+.multiselect-label{font-weight:600}.file-upload-area{position:relative}.file-input{display:none}.file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border:2px dashed #bdc3c7;border-radius:12px;background:#f8f9fa;cursor:pointer;transition:all .3s ease;text-align:center}.file-upload-label:hover:not(.disabled){border-color:#3498db;background:#e3f2fd}.file-upload-label.disabled{cursor:not-allowed;opacity:.6}.upload-icon{font-size:48px;margin-bottom:12px}.upload-text{font-size:16px;color:#2c3e50;margin-bottom:8px}.upload-hint{font-size:14px;color:#6c757d}.upload-progress{margin-top:16px}.progress-bar{width:100%;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#3498db;transition:width .3s ease}.progress-text{text-align:center;margin-top:8px;font-size:14px;color:#6c757d}.uploaded-file{display:flex;align-items:center;justify-content:space-between;padding:16px;border:2px solid #27ae60;border-radius:8px;background:#f0fff4}.file-info{display:flex;align-items:center;gap:12px}.file-icon{font-size:24px}.file-name{font-weight:600;color:#2c3e50}.file-status{font-size:14px;color:#27ae60}.remove-file-btn{padding:8px 16px;background:#e74c3c;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .3s ease}.remove-file-btn:hover{background:#c0392b}.readonly-content{background:#f8f9fa;border-radius:8px;padding:20px}.readonly-instruction{text-align:center;font-style:italic;color:#6c757d;margin-top:20px;padding:16px;background:white;border-radius:8px;border:1px solid #dee2e6}.dataset-summary{background:white;border-radius:8px;padding:20px;border:1px solid #dee2e6}.summary-header h4{margin:0 0 16px;color:#2c3e50;font-size:20px}.summary-stats{display:flex;gap:24px;margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px}.stat-item{display:flex;flex-direction:column;text-align:center}.stat-label{font-size:14px;color:#6c757d;margin-bottom:4px}.stat-value{font-size:24px;font-weight:700;color:#2c3e50}.columns-info h5,.missing-values h5,.data-preview h5{margin:0 0 12px;color:#2c3e50;font-size:16px}.columns-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-bottom:24px}.column-item{padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.column-name{font-weight:600;color:#2c3e50;margin-bottom:4px}.column-details{display:flex;flex-wrap:wrap;gap:8px;font-size:12px}.column-type,.column-unique,.column-semantic,.column-mean,.column-mode{display:inline-block;margin-right:8px;margin-top:8px;padding:4px 14px;border-radius:16px;font-size:15px;font-weight:500;vertical-align:middle;line-height:1.2}.column-type{background:#3498db;color:#fff}.column-unique{background:#b0b8b8;color:#fff}.column-semantic{background:#e3eafc;color:#2a4365}.column-mean{background:#e6f4ea;color:#256029}.column-mode{background:#fceee3;color:#7c4700}.column-details>span:last-child{margin-right:0}.missing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px;margin-bottom:24px}.missing-item{display:flex;justify-content:space-between;padding:8px 12px;background:#fff5f5;border-radius:6px;border:1px solid #f8d7da}.missing-column{font-weight:600;color:#721c24}.missing-count{color:#e74c3c;font-weight:600}.preview-table-container{overflow-x:auto;border:1px solid #dee2e6;border-radius:6px}.preview-table{width:100%;border-collapse:collapse;font-size:14px}.preview-table th{background:#f8f9fa;color:#495057;font-weight:600;padding:12px 8px;text-align:left;border-bottom:2px solid #dee2e6;white-space:nowrap}.preview-table td{padding:8px;border-bottom:1px solid #dee2e6;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-table tr:last-child td{border-bottom:none}.preview-table tr:nth-child(2n){background:#f8f9fa}.preview-table td,.preview-table th{color:#222!important;background:#fff!important;opacity:1!important}.slider-container{padding:20px;background:#f8f9fa;border-radius:12px;border:2px solid #e9ecef}.slider-labels{display:flex;justify-content:space-between;margin-bottom:16px;font-weight:600;font-size:16px}.slider-label-left{color:#2980b9}.slider-label-right{color:#e74c3c}.slider-wrapper{position:relative;margin-bottom:24px}.slider-input{width:100%;height:8px;border-radius:4px;background:#dee2e6;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#3498db;cursor:pointer;border:3px solid white;box-shadow:0 2px 8px #0003}.slider-input::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#3498db;cursor:pointer;border:3px solid white;box-shadow:0 2px 8px #0003}.train-test-visual{margin-top:20px}.visual-container{display:flex;height:60px;border-radius:8px;overflow:hidden;border:2px solid #dee2e6;margin-bottom:8px}.train-section{background:linear-gradient(135deg,#3498db,#2980b9);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;transition:width .3s ease}.test-section{background:linear-gradient(135deg,#e74c3c,#c0392b);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;transition:width .3s ease}.section-label{font-size:14px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.visual-percentages{display:flex;font-size:14px;font-weight:600;color:#6c757d}.slider-info{margin-top:16px;padding:16px;background:white;border-radius:8px;border:1px solid #dee2e6}.slider-info p{margin:0;color:#495057;line-height:1.5}.hyperparameters-container{padding:20px;background:#f8f9fa;border-radius:12px;border:2px solid #e9ecef}.hyperparameters-info{margin-bottom:24px;padding:16px;background:white;border-radius:8px;border:1px solid #dee2e6}.hyperparameters-info p{margin:0;color:#495057;line-height:1.5}.hyperparameters-grid{display:flex;flex-direction:column;gap:20px}.hyperparameter-item{background:white;padding:20px;border-radius:8px;border:2px solid #e9ecef;transition:border-color .3s ease}.hyperparameter-item:hover{border-color:#3498db}.hyperparameter-label{display:block;margin-bottom:12px}.param-name{display:block;font-weight:600;font-size:16px;color:#2c3e50;margin-bottom:4px}.param-description{display:block;font-size:14px;color:#6c757d;margin-bottom:6px;line-height:1.4}.param-range{display:block;font-size:12px;color:#8e8e93;font-style:italic}.hyperparameter-input,.hyperparameter-select{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;font-family:inherit;transition:border-color .3s ease;background:white;color:#2c3e50}.hyperparameter-input:focus,.hyperparameter-select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;color:#2c3e50}.hyperparameter-input.error,.hyperparameter-select.error{border-color:#e74c3c;background:#fff5f5;color:#721c24}.param-error{margin-top:8px;color:#e74c3c;font-size:14px;font-weight:500}.code-display-container{background:#f8f9fa;border-radius:12px;border:2px solid #e9ecef;overflow:hidden}.code-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#2c3e50;color:#fff;border-bottom:2px solid #34495e}.code-header h4{margin:0;font-size:18px;font-weight:600}.code-actions{display:flex;gap:12px}.code-action-btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease}.copy-btn{background:#3498db;color:#fff}.copy-btn:hover{background:#2980b9}.download-btn{background:#27ae60;color:#fff}.download-btn:hover{background:#2ecc71}.code-content{max-height:500px;overflow-y:auto;background:#2c3e50}.code-block{margin:0;padding:20px;background:#2c3e50;color:#ecf0f1;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word}.python-code{color:#ecf0f1}.code-info{padding:20px;background:white}.info-section{margin-bottom:20px}.info-section:last-child{margin-bottom:0}.info-section h5{margin:0 0 12px;color:#2c3e50;font-size:16px;font-weight:600}.info-section p{margin:0 0 12px;color:#495057;line-height:1.5}.info-section ul{margin:0 0 12px;padding-left:20px;color:#495057}.info-section li{margin-bottom:4px}.install-command{padding:12px 16px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;color:#2c3e50;margin-top:8px}.validation-message{margin-top:8px;padding:8px 12px;border-radius:6px;font-size:14px}.validation-message:not(.error){background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.validation-message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width: 768px){.question-container{padding:16px;margin:0 16px}.summary-stats{flex-direction:column;gap:16px}.columns-grid,.missing-grid{grid-template-columns:1fr}.uploaded-file{flex-direction:column;gap:12px;text-align:center}.multiselect-header{flex-direction:column;gap:8px;text-align:center}.multiselect-options{max-height:300px}.slider-labels{flex-direction:column;gap:8px;text-align:center}.visual-container{height:80px}.code-header{flex-direction:column;gap:12px;text-align:center}.code-actions{justify-content:center}.hyperparameters-grid{gap:16px}.hyperparameter-item{padding:16px}}.column-unique-tag{display:inline-block;margin-right:8px;margin-top:8px;padding:4px 14px;border-radius:16px;font-size:15px;font-weight:500;vertical-align:middle;line-height:1.2;background:#ffeaa7;color:#856404}.chatbot-section{background:#FFFAED;position:fixed;left:0;bottom:0;width:100vw;z-index:10;transition:height .3s cubic-bezier(.4,0,.2,1);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;box-shadow:0 -12px 32px #00000040;border-top-left-radius:32px;border-top-right-radius:32px}html,body{background:#D3D1CE!important;min-height:100vh}.dashboard-root{width:100vw;min-height:92vh;background:#D3D1CE;display:flex;flex-direction:column;align-items:center;color:#404040}.profile-section{width:70vw;min-height:42vh;margin-left:15vw;margin-right:15vw;display:flex;align-items:flex-start;border-bottom:2px solid #888;position:relative}.profile-content{display:flex;align-items:flex-start;width:100%;height:100%;padding-top:10vh;box-sizing:border-box}.profile-icon{height:22vh;aspect-ratio:1/1;border-radius:50%;background:#fff;margin-right:3vw;margin-top:0}.profile-details{flex:1;display:flex;flex-direction:column;justify-content:flex-start;height:100%}.profile-info{height:16vh;display:flex;flex-direction:column;justify-content:flex-start;font-size:2.2vh;margin-bottom:0vh}.profile-level-label{margin-top:1vh;margin-bottom:0}.profile-level-bar-container{height:6vh;display:flex;flex-direction:column;justify-content:center;margin:0 0 1vh}.profile-level-bar{position:relative;width:90%;height:1.5vh;background:#f0f0f0;border-radius:1vh;margin-bottom:.5vh}.profile-level-bar-progress{position:absolute;height:100%;background:#888;border-radius:1vh 0 0 1vh}.profile-level-knob{position:absolute;top:50%;transform:translateY(-50%);width:2.5vh;height:2.5vh;background:#bdbdbd;border-radius:50%;border:2px solid #888}.profile-level-labels{display:flex;justify-content:space-between;font-size:1.7vh;width:90%;margin-top:0}.badges-section{display:flex;align-items:center;height:10vh;margin-top:0}.badges-label{font-size:2vh;margin-right:1vw}.badges-list{display:flex;align-items:center;gap:1vw}.badge-icon{height:7vh;width:7vh;border-radius:50%;background:#fff;border:2px solid #bdbdbd}.projects-section{width:70vw;min-height:50vh;margin-left:15vw;margin-right:15vw;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start}.projects-content{width:100%;height:100%;display:flex;flex-direction:column}.projects-title{font-size:2.5vh;font-weight:500;margin-bottom:2vh;color:#404040}.projects-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(auto-fit,25vh);gap:10vh 4vw;justify-content:space-between;width:100%;min-height:60vh;max-width:70vw}.project-card{width:100%;max-width:13vw;height:25vh;border-radius:1.5vh;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000000a;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;padding:1vh;box-sizing:border-box}.project-card:hover{box-shadow:0 4px 16px #0000001a}.project-card-create{background:#A9A8A7;color:#404040;padding:1vh}.project-card-create:hover{background:#9a9998}.project-card-existing{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:1vh;position:relative}.project-card-existing:hover{box-shadow:0 6px 20px #00000026}.project-card-existing:hover .project-delete-btn{opacity:1;pointer-events:auto}.project-delete-btn{position:absolute;top:1vh;right:1vh;background:rgba(255,255,255,.95);border:1px solid rgba(0,0,0,.1);border-radius:50%;width:4vh;height:4vh;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;pointer-events:none;transition:all .2s ease;z-index:10;padding:.2vh}.project-delete-btn:hover{background:rgba(244,67,54,.95);border-color:#f44336;transform:scale(1.1)}.delete-icon-img{width:100%;height:100%;object-fit:contain;filter:brightness(0) saturate(100%);transition:filter .2s ease}.project-delete-btn:hover .delete-icon-img{filter:brightness(0) invert(1)}.delete-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(64,64,64,.5);display:flex;align-items:center;justify-content:center;z-index:1001}.delete-modal-content{background:#f7f6f5;border-radius:1.5vh;box-shadow:0 4px 32px #0000002e;padding:3vh 4vw;min-width:300px;max-width:400px;text-align:center}.delete-modal-content h3{margin:0 0 2vh;color:#404040;font-size:2.2vh}.delete-modal-content p{margin:0 0 3vh;color:#404040;font-size:1.8vh;line-height:1.4}.delete-modal-buttons{display:flex;gap:2vw;justify-content:center}.delete-cancel-btn,.delete-confirm-btn{padding:1vh 3vw;border:none;border-radius:.7vh;font-size:1.8vh;font-weight:500;cursor:pointer;transition:background .2s;min-width:8vw}.delete-cancel-btn{background:#888;color:#fff}.delete-cancel-btn:hover:not(:disabled){background:#666}.delete-confirm-btn{background:#E57373;color:#fff}.delete-confirm-btn:hover:not(:disabled){background:#C62828}.delete-cancel-btn:disabled,.delete-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.project-plus-icon{width:10vh;height:10vh;margin-bottom:1vh}.project-label{font-size:1.8vh;text-align:center;margin-top:.5vh;color:inherit;font-weight:500}.project-content{text-align:center;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.project-name{font-size:1.8vh;font-weight:600;margin:0 0 .8vh;word-break:break-word;line-height:1.2;color:#fff;text-align:center;max-height:4vh;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.project-meta{display:flex;flex-direction:column;gap:.5vh;align-items:center}.project-type{padding:.3vh 1vh;border-radius:1.5vh;font-size:1.3vh;font-weight:500;text-transform:capitalize}.project-type.beginner{background:rgba(76,175,80,.3);color:#4caf50;border:1px solid rgba(76,175,80,.5)}.project-type.expert{background:rgba(244,67,54,.3);color:#f44336;border:1px solid rgba(244,67,54,.5)}.project-date{font-size:1.2vh;opacity:.9;color:#fffc}.projects-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5vh;color:#404040;grid-column:1 / -1}.loading-spinner{width:5vh;height:5vh;border:.4vh solid #D3D1CE;border-top:.4vh solid #888;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:2vh}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.projects-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5vh;color:#dc3545;text-align:center;grid-column:1 / -1}.retry-button{margin-top:2vh;padding:1vh 2vh;background:#888;color:#fff;border:none;border-radius:.7vh;cursor:pointer;font-size:1.8vh;transition:background .3s ease}.retry-button:hover{background:#666}.profile-name,.profile-email,.profile-level-label,.profile-level-labels span,.badges-label{color:#404040}.edit-profile-icon{position:absolute;top:10vh;right:2vw;width:2.5vw;height:2.5vw;min-width:28px;min-height:28px;max-width:40px;max-height:40px;cursor:pointer;opacity:.85;transition:opacity .2s;z-index:2}.edit-profile-icon:hover{opacity:1}.badge-tooltip-container{position:relative;display:inline-block}.badge-tooltip{visibility:hidden;background:#404040;color:#fff;text-align:center;border-radius:6px;padding:.5vh 1vw;position:absolute;z-index:10;top:110%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .2s;font-size:1.7vh;white-space:nowrap}.badge-tooltip-container:hover .badge-tooltip{visibility:visible;opacity:1}.profile-name{display:flex;align-items:center;gap:1vw;font-size:2.2vh}.profile-name-input{font-size:2.2vh;padding:.5vh 1vw;border:1px solid #A9A8A7;border-radius:.5vh;color:#404040;background:#fff;margin-bottom:0}.profile-slider-input{width:90%;margin:1vh 0 .5vh;accent-color:#888;height:1.5vh;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;position:relative;top:0}.profile-slider-input::-webkit-slider-runnable-track{height:1.5vh;background:linear-gradient(to right,#404040 0%,#404040 calc(var(--percent, 50%) * 1%),#fff calc(var(--percent, 50%) * 1%),#fff 100%);border-radius:.75vh}.profile-slider-input::-moz-range-track{height:1.5vh;background:#fff;border-radius:.75vh}.profile-slider-input::-moz-range-progress{height:1.5vh;background:#404040;border-radius:.75vh}.profile-slider-input::-ms-fill-lower{background:#404040;border-radius:.75vh}.profile-slider-input::-ms-fill-upper{background:#fff;border-radius:.75vh}.profile-slider-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:3vh;height:3vh;margin-top:-.75vh;border-radius:50%;background:#404040;border:2px solid #A9A8A7;cursor:pointer;box-shadow:0 0 2px #888;transition:background .2s}.profile-slider-input:disabled::-webkit-slider-thumb{background:#404040;border:2px solid #A9A8A7;cursor:default;opacity:1}.profile-slider-input::-moz-range-thumb{width:3vh;height:3vh;border-radius:50%;background:#404040;border:2px solid #A9A8A7;cursor:pointer;box-shadow:0 0 2px #888;transition:background .2s;margin-top:-.75vh}.profile-slider-input:disabled::-moz-range-thumb{background:#404040;border:2px solid #A9A8A7;cursor:default;opacity:1}.profile-slider-input::-ms-thumb{width:3vh;height:3vh;border-radius:50%;background:#404040;border:2px solid #A9A8A7;cursor:pointer;box-shadow:0 0 2px #888;transition:background .2s;margin-top:-.75vh}.profile-slider-input:disabled::-ms-thumb{background:#404040;border:2px solid #A9A8A7;cursor:default;opacity:1}.profile-slider-input:disabled::-webkit-slider-runnable-track{background:linear-gradient(to right,#404040 0%,#404040 calc(var(--percent, 50%) * 1%),#fff calc(var(--percent, 50%) * 1%),#fff 100%)!important;opacity:1}.profile-slider-input:disabled::-moz-range-track{background:#fff!important;opacity:1}.profile-slider-input:disabled::-ms-fill-lower{background:#404040!important;opacity:1}.profile-slider-input:disabled::-ms-fill-upper{background:#fff!important;opacity:1}.profile-edit-buttons{display:flex;gap:2vw;margin:1vh 0}.profile-modify-btn,.profile-cancel-btn{font-size:2vh;padding:.7vh 2vw;border:none;border-radius:.7vh;cursor:pointer;transition:background .2s}.profile-modify-btn{background:#4CAF50;color:#fff}.profile-modify-btn:hover{background:#388E3C}.profile-cancel-btn{background:#E57373;color:#fff}.profile-cancel-btn:hover{background:#C62828}.profile-level-current{font-size:1.8vh;margin-top:.5vh;color:#404040;font-weight:500}.badge-count-circle{position:absolute;bottom:0%;right:0%;background:#fff;color:#222;border-radius:50%;width:2.45vh;height:2.45vh;min-width:35%;min-height:35%;display:flex;align-items:center;justify-content:center;font-size:1vh;font-weight:500;box-shadow:0 2px 8px #0000001a;border:2px solid #eee;z-index:11}@media (max-width: 768px){.projects-grid{grid-template-columns:repeat(2,1fr);gap:3vh 3vw}.project-card{width:100%;height:20vh}.project-name{font-size:1.8vh}.project-type{font-size:1.4vh;padding:.4vh 1.2vh}.project-date{font-size:1.2vh}}@media (max-width: 480px){.projects-grid{grid-template-columns:1fr;gap:2vh}.project-card{height:18vh}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(64,64,64,.25);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#f7f6f5;border-radius:1.5vh;box-shadow:0 4px 32px #0000002e;padding:3vh 4vw;min-width:320px;min-height:180px;position:relative;display:flex;flex-direction:column;align-items:center;gap:2vh}.modal-close-btn{position:absolute;top:1.2vh;right:1.2vw;background:none;border:none;font-size:2.5vh;color:#404040;cursor:pointer;opacity:.7;transition:opacity .2s}.modal-close-btn:hover{opacity:1}.modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.modal-title{font-size:2.2vh;color:#404040;font-weight:600;text-align:center;margin-top:1vh}.modal-subtitle{font-size:1.8vh;color:#404040;text-align:center;margin-top:1vh}.modal-input-group{width:100%;display:flex;flex-direction:column;gap:.5vh}.modal-input{width:100%;padding:1vh 1.5vw;font-size:1.8vh;border:1px solid #ccc;border-radius:.7vh;outline:none;transition:border-color .2s;box-sizing:border-box}.modal-input:focus{border-color:#4caf50}.modal-input:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.6}.modal-error{color:#c62828;font-size:1.4vh;text-align:center;margin-top:.5vh;padding:1vh;background:rgba(198,40,40,.1);border-radius:.5vh;border:1px solid rgba(198,40,40,.2)}.modal-btn-group{display:flex;gap:3vw;margin-top:1vh}.modal-btn{font-size:2vh;padding:1vh 3vw;border:none;border-radius:.7vh;cursor:pointer;font-weight:500;transition:background .2s,color .2s,opacity .2s;min-width:8vw}.modal-btn.beginner{background:#4CAF50;color:#fff}.modal-btn.beginner:hover:not(:disabled){background:#388E3C}.modal-btn.expert{background:#E57373;color:#fff}.modal-btn.expert:hover:not(:disabled){background:#C62828}.modal-btn:disabled,.modal-btn.creating{opacity:.6;cursor:not-allowed;pointer-events:none}.modal-loading{display:flex;align-items:center;justify-content:center;gap:1.5vh;margin-top:2vh;color:#404040;font-size:1.8vh}.modal-spinner{width:2.5vh;height:2.5vh;border:.3vh solid #f3f3f3;border-top:.3vh solid #4CAF50;border-radius:50%;animation:modal-spin 1s linear infinite}@keyframes modal-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.modal-content{padding:2vh 3vw;min-width:280px}.modal-btn-group{gap:4vw}.modal-btn{min-width:12vw;padding:1.2vh 4vw}.modal-title{font-size:2vh}.modal-subtitle,.modal-input,.modal-loading{font-size:1.6vh}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
