.puzzle-bg{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;position:relative;background-color:#fff;overflow:hidden;font-family:Roboto,sans-serif}.puzzle-bg:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:url(/assets/login-background-4707f387.svg) center center / cover no-repeat;z-index:0}.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:#f0efed;border-radius:32px;box-shadow:none;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:#f0efed;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:180px;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:#61A6B7;color:#fff;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:#4e8f9e}.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:#f0efed;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:#f0efed;border-radius:32px;box-shadow:none;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;font-family:Roboto,sans-serif}.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;position:relative;z-index:1}.signup-card{background:#f0efed;border-radius:32px;box-shadow:none;padding:2.5rem 2rem 2rem;width:420px;max-width:100%;display:flex;flex-direction:column;align-items:center;box-sizing:border-box;font-family:Roboto,sans-serif}.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:#61A6B7;color:#fff;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:#4e8f9e}.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:auto;width:100%;max-width:100vw;min-width:0;margin-top:0;flex:1 1 auto;align-items:stretch;font-family:Roboto,sans-serif}#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;font-family:Roboto,sans-serif}.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;border-bottom-left-radius:32px;border-bottom-right-radius:32px;font-family:Roboto,sans-serif}.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{opacity:.85;transition:opacity .2s}.puzzle-piece-hoverable{cursor:pointer;transition:filter .2s;z-index:1}.puzzle-piece-hoverable:hover{filter:brightness(.92) saturate(1.3);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:#ffffff;width:100%;flex:1 1 0;min-height:0;overflow:auto;overflow-x:hidden;position:fixed;top:38vh;left:0;right:0;box-sizing:border-box;display:flex;align-items:flex-start;justify-content:center;height:62vh;font-family:Roboto,sans-serif}.playground-section.question-mode{align-items:flex-start;padding-top:4vh;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:12px;margin-top:12px;padding-top:16px;border-top:1px solid #e9ecef;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:38vh;bottom:10vh;height:auto;max-height:none;transform:none;width:40vw;background:white;border-radius:12px;padding:24px;z-index:2;overflow-y:auto;box-sizing:border-box;display:flex;flex-direction:column;font-family:Roboto,sans-serif}.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:0}.submit-section{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:0;margin-bottom:4vh;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 #61A6B7;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.loading-state p{color:#888;font-size:1.8vh;margin:0;font-family:Roboto,sans-serif}.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:1.8vh;margin-bottom:16px;font-family:Roboto,sans-serif}.retry-button{padding:8px 16px;background:#61A6B7;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1.6vh;transition:background-color .3s ease;font-family:Roboto,sans-serif;font-weight:500}.retry-button:hover{background:#4f8f9e}.no-task-selected{text-align:center;padding:40px 20px;color:#888;font-family:Roboto,sans-serif}.no-task-selected h3{color:#333;margin-bottom:12px;font-size:2.6vh;font-weight:600;font-family:Roboto,sans-serif}.no-task-selected p{font-size:1.8vh;line-height:1.5;max-width:400px;margin:0 auto;color:#888;font-weight:400;font-family:Roboto,sans-serif}.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:.85rem 2rem;background-color:#61a6b7;color:#fff;border:none;border-radius:16px;cursor:pointer;font-size:1.1rem;font-weight:700;transition:background .2s;min-width:160px;font-family:Roboto,sans-serif;letter-spacing:.01em}.submit-button:hover:not(.disabled):not(.loading){background-color:#4e8f9e}.submit-button:active:not(.disabled):not(.loading){background-color:#3d7a89}.submit-button.disabled{background-color:#61a6b7;opacity:.45;cursor:not-allowed}.submit-button.loading{cursor:not-allowed;background-color:#7bbcc9}.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 24px 8px;background:white;border-radius:12px;font-family:Roboto,sans-serif}.question-container.readonly{background:#f8f9fa;border:2px solid #e9ecef}.question-text{font-size:2vh;font-weight:400;color:#333;margin-bottom:20px;line-height:1.6;font-family:Roboto,sans-serif}.required-indicator{color:#d97706;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:1.8vh;font-family:Roboto,sans-serif;resize:vertical;min-height:120px;transition:border-color .3s ease;color:#333}.text-answer-input:focus{outline:none;border-color:#61a6b7;box-shadow:0 0 0 3px #61a6b71a}.text-answer-input.invalid{border-color:#61a6b7}.character-count{text-align:right;font-size:1.4vh;color:#888;margin-top:8px}.radio-options{display:flex;flex-direction:column;gap:12px;padding:8px 0}.radio-options.invalid{border:2px solid #61A6B7;border-radius:8px;padding:16px;background:#f0f9fb}.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:#61a6b7;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:#61a6b7;background:#61A6B7}.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:1.8vh;color:#333;line-height:1.4;font-family:Roboto,sans-serif}.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:#61A6B7;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1.6vh;font-weight:500;transition:background-color .3s ease;font-family:Roboto,sans-serif}.select-all-btn:hover{background:#4f8f9e}.selection-count{font-size:1.6vh;color:#888;font-weight:500;font-family:Roboto,sans-serif}.multiselect-options{display:flex;flex-direction:column;gap:12px;padding:8px 0;max-height:400px;overflow-y:auto}.multiselect-options.invalid{border:2px solid #61A6B7;border-radius:8px;padding:16px;background:#f0f9fb}.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:#61a6b7;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:#61a6b7;background:#61A6B7}.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:1.8vh;color:#333;line-height:1.4;flex:1;font-family:Roboto,sans-serif}.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:#61a6b7;background:#f0f9fb}.file-upload-label.disabled{cursor:not-allowed;opacity:.6}.upload-icon{font-size:48px;margin-bottom:12px}.upload-text{font-size:1.8vh;color:#333;margin-bottom:8px;font-family:Roboto,sans-serif}.upload-hint{font-size:1.6vh;color:#888;font-family:Roboto,sans-serif}.upload-progress{margin-top:16px}.progress-bar{width:100%;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#61A6B7;transition:width .3s ease}.progress-text{text-align:center;margin-top:8px;font-size:1.6vh;color:#888}.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:#333;font-family:Roboto,sans-serif}.file-status{font-size:14px;color:#27ae60}.remove-file-btn{padding:8px 16px;background:#6b7280;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .3s ease}.remove-file-btn:hover{background:#4b5563}.readonly-content{background:#f8f9fa;border-radius:8px;padding:20px}.readonly-instruction{text-align:center;font-style:italic;color:#888;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:#333;font-size:2.2vh;font-family:Roboto,sans-serif}.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:1.6vh;color:#888;margin-bottom:4px;font-family:Roboto,sans-serif}.stat-value{font-size:2.6vh;font-weight:700;color:#333;font-family:Roboto,sans-serif}.columns-info h5,.missing-values h5,.data-preview h5{margin:0 0 12px;color:#333;font-size:1.8vh;font-family:Roboto,sans-serif}.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:#333;margin-bottom:4px;font-family:Roboto,sans-serif}.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:#61A6B7;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:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.missing-column{font-weight:600;color:#333}.missing-count{color:#d97706;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:#b184e5}.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:#61A6B7;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:#61A6B7;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,#61A6B7,#4f8f9e);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;transition:width .3s ease}.test-section{background:linear-gradient(135deg,#B184E5,#9a6dd4);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:1.6vh;font-weight:600;color:#888}.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:#61a6b7}.hyperparameter-label{display:block;margin-bottom:12px}.param-name{display:block;font-weight:600;font-size:1.8vh;color:#333;margin-bottom:4px;font-family:Roboto,sans-serif}.param-description{display:block;font-size:1.6vh;color:#888;margin-bottom:6px;line-height:1.4;font-family:Roboto,sans-serif}.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:1.8vh;font-family:Roboto,sans-serif;transition:border-color .3s ease;background:white;color:#333}.hyperparameter-input:focus,.hyperparameter-select:focus{outline:none;border-color:#61a6b7;box-shadow:0 0 0 3px #61a6b71a;color:#333}.hyperparameter-input.error,.hyperparameter-select.error{border-color:#61a6b7;background:#f0f9fb;color:#333}.param-error{margin-top:8px;color:#d97706;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:#61A6B7;color:#fff}.copy-btn:hover{background:#4f8f9e}.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:#333;font-size:1.8vh;font-weight:600;font-family:Roboto,sans-serif}.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:#333;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}html,body{background:#ffffff!important;min-height:100vh}.dashboard-root{width:100vw;min-height:92vh;background:#ffffff;display:flex;flex-direction:column;align-items:center;color:#404040}.profile-section{width:70vw;margin-left:15vw;margin-right:15vw;display:flex;align-items:flex-start;border-bottom:1px solid #e8e8e8;padding-bottom:5vh;position:relative}.profile-content{display:flex;align-items:center;width:100%;padding-top:10vh;box-sizing:border-box}.profile-icon-wrapper{position:relative;height:14vh;width:14vh;flex-shrink:0;margin-right:2.5vw;cursor:pointer}.profile-icon-wrapper:hover .profile-upload-overlay{opacity:1}.profile-icon{height:100%;width:100%;border-radius:50%;background:#f5f5f5;object-fit:cover;border:3px solid #eee}.profile-upload-overlay{position:absolute;bottom:0;left:0;right:0;height:40%;background:rgba(0,0,0,.45);border-radius:0 0 50% 50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;pointer-events:none}.profile-upload-overlay span{color:#fff;font-size:1.4vh;font-weight:500}.profile-upload-input{display:none}.profile-details{display:flex;flex-direction:column;gap:.6vh}.profile-name{margin:0;font-size:4vh;font-weight:600;color:#333;line-height:1.3}.profile-email{margin:0;font-size:2vh;font-weight:400;color:#888;line-height:1.4}.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;margin-top:4vh;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.6vh;font-weight:600;margin-bottom:2.5vh;color:#333}.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:#f7f6f5;color:#404040;padding:1vh;border:2px dashed #ccc}.project-card-create:hover{background:#eee;border-color:#aaa}.project-card-existing{background:var(--card-color, #B184E5);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:2.2vh;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:2.8vh;font-weight:600;margin:0 0 .8vh;word-break:break-word;line-height:1.2;color:#0000008c;text-align:center;max-height:7vh;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,.project-type.expert{background:rgba(255,255,255,.25);color:#fff;border:1px solid rgba(255,255,255,.4)}.project-date{font-size:1.6vh;font-weight:400;color:#0006}.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 #eee;border-top:.4vh solid #B184E5;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-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-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:2.4vh}.project-date{font-size:1.4vh}}@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}}.review-page{min-height:100vh;background:#f7f8fa;padding-top:8vh}.review-container{max-width:900px;margin:0 auto;padding:40px 24px 80px}.review-hero{text-align:center;margin-bottom:48px}.review-hero h1{font-size:2.2rem;font-weight:700;color:#1a1a2e;margin:0 0 8px}.review-hero p{font-size:1.05rem;color:#666;margin:0}.review-filters{display:flex;gap:10px;justify-content:center;margin-bottom:36px;flex-wrap:wrap}.review-filter-btn{padding:8px 20px;border-radius:20px;border:1.5px solid #ddd;background:#fff;color:#555;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.review-filter-btn:hover{border-color:#aaa;color:#333}.review-filter-btn.active{background:#1a1a2e;color:#fff;border-color:#1a1a2e}.review-timeline{position:relative;padding-left:32px}.review-timeline:before{content:"";position:absolute;left:11px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#FFCB05,#F1969B,#5AA888,#B184E5,#61A6B7);border-radius:2px}.review-version-group{margin-bottom:40px}.review-version-header{display:flex;align-items:center;gap:14px;margin-bottom:16px;position:relative}.review-version-dot{width:22px;height:22px;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 2px #ccc;position:absolute;left:-32px;top:2px;z-index:2}.review-version-label{font-size:1.25rem;font-weight:700;color:#1a1a2e}.review-version-date{font-size:.85rem;color:#999;font-weight:400}.review-card{background:#fff;border-radius:12px;padding:20px 24px;margin-bottom:12px;box-shadow:0 1px 4px #0000000f;border-left:4px solid transparent;transition:box-shadow .2s,transform .15s}.review-card:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-1px)}.review-card.type-feature{border-left-color:#5aa888}.review-card.type-improvement{border-left-color:#61a6b7}.review-card.type-fix{border-left-color:#f1969b}.review-card.type-infrastructure{border-left-color:#b184e5}.review-card.type-ui{border-left-color:#ffcb05}.review-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.review-tag{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.review-tag.tag-feature{background:#e8f5e9;color:#2e7d32}.review-tag.tag-improvement{background:#e0f2f1;color:#00695c}.review-tag.tag-fix{background:#fce4ec;color:#c62828}.review-tag.tag-infrastructure{background:#f3e5f5;color:#6a1b9a}.review-tag.tag-ui{background:#fff8e1;color:#f57f17}.review-card-title{font-size:1rem;font-weight:600;color:#222;margin:0}.review-card-description{font-size:.9rem;color:#555;line-height:1.6;margin:0}.review-card-details{margin-top:12px;padding-top:12px;border-top:1px solid #f0f0f0}.review-card-detail-item{display:flex;align-items:flex-start;gap:8px;font-size:.85rem;color:#666;margin-bottom:4px}.review-card-detail-item:before{content:"•";color:#999;font-weight:700;margin-top:-1px}.review-card-files{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.review-file-chip{padding:2px 8px;background:#f5f5f5;border-radius:6px;font-size:.75rem;color:#777;font-family:SF Mono,Monaco,Cascadia Code,monospace}.review-card-toggle{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:#888;font-size:.82rem;cursor:pointer;padding:4px 0;margin-top:8px;transition:color .2s}.review-card-toggle:hover{color:#333}.review-stats{display:flex;justify-content:center;gap:32px;margin-bottom:40px;flex-wrap:wrap}.review-stat{text-align:center}.review-stat-number{font-size:1.8rem;font-weight:700;color:#1a1a2e;display:block}.review-stat-label{font-size:.82rem;color:#888;text-transform:uppercase;letter-spacing:.5px}.review-back-link{display:inline-flex;align-items:center;gap:6px;color:#555;text-decoration:none;font-size:.9rem;margin-bottom:24px;transition:color .2s}.review-back-link:hover{color:#1a1a2e}.review-empty{text-align:center;padding:60px 20px;color:#999}.review-empty-icon{font-size:3rem;margin-bottom:12px}@media (max-width: 640px){.review-container{padding:24px 16px 60px}.review-hero h1{font-size:1.6rem}.review-stats{gap:20px}.review-stat-number{font-size:1.4rem}.review-card{padding:16px 18px}.review-timeline{padding-left:28px}}:root{font-family:Roboto,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}}
