:root{--button-text:#fff;--secondary-bg:#e2e8f0;--secondary-text:#2d3748;--secondary-hover-bg:#cbd5e0;--radius:12px;--radius-sm:6px;--font-family:"Segoe UI","Roboto",Arial,sans-serif;--font-size-scale:0.94}html{font-size:15px}body{background:#f6f8fb;background:var(--bg);color:#222;color:var(--text);font-family:Segoe UI,Roboto,Arial,sans-serif;font-family:var(--font-family);line-height:1.6;margin:0}a{color:#2b6cb0;color:var(--link);text-decoration:none;transition:all .3s ease}a:hover{color:#2b6cb0;color:var(--link-hover)}h1,h2,h3,h4,h5,h6{color:#1a365d;color:var(--heading);font-weight:600;margin-bottom:.8em}h1{font-size:2rem;margin-bottom:.5em}h2{font-size:1.6rem;margin-top:1.5em}h3{font-size:1.25rem}h6{font-size:1.05rem}h5{font-size:1.15rem}ul{padding-left:1.5em}.modal-custom .modal-body ol,.modal-custom .modal-body ul{list-style:none;margin-left:0;padding-left:0}.modal-custom .modal-body li::marker{content:""}.container{background:#fff;background:var(--container-bg);border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 12px rgba(0,0,0,.08);margin:40px auto;max-width:1600px;padding:2.5em 3em}.btn{border:none;border-radius:6px;border-radius:var(--radius-sm);box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;color:var(--button-text,#fff);cursor:pointer;font-size:1em;font-weight:500;margin-top:1em;padding:.7em 1.5em;transition:all .3s ease}.btn,.btn:hover{background:#2b6cb0;background:var(--accent)}.btn:hover{box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.btn.active{background:#2b6cb0;background:var(--accent);box-shadow:inset 0 2px 4px rgba(0,0,0,.2)}.btn.secondary{background:#e2e8f0;background:var(--secondary-bg,#e2e8f0);color:#2d3748;color:var(--secondary-text,#2d3748)}.btn.secondary:hover{background:#cbd5e0;background:var(--secondary-hover-bg,#cbd5e0)}.action-btn:disabled,.btn:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;opacity:.7;position:relative;transform:none}.action-btn:disabled:after,.btn:disabled:after{background:rgba(0,0,0,.8);border-radius:4px;bottom:120%;color:#fff;content:attr(title);font-size:.8em;left:50%;max-width:200px;opacity:0;padding:.5em 1em;pointer-events:none;position:absolute;text-align:center;transform:translateX(-50%);transition:opacity .3s,visibility .3s;visibility:hidden;white-space:nowrap;z-index:10}.action-btn:disabled:hover:after,.btn:disabled:hover:after{opacity:1;visibility:visible}.hero-section{margin-bottom:2rem}.hero-buttons{gap:1rem;margin-top:1.5rem}.subtitle{font-size:1.2rem;margin-bottom:1.5rem}.features-section,.popular-subjects-section,.quick-access-section{margin-bottom:2rem}.section-title{margin-bottom:1.5rem;text-align:center}.features-grid,.subjects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.quick-links{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));text-align:center}.feature-card,.subject-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;text-align:center}.subject-card{text-align:left}.quick-link-card{border:1px solid #e0e0e0;border-radius:8px;color:inherit;padding:1rem;text-decoration:none;transition:all .3s ease}.quick-link-card:hover{box-shadow:0 4px 8px rgba(0,0,0,.1);transform:translateY(-3px)}.feature-icon,.quick-link-icon{font-size:2rem;margin-bottom:1rem}.quick-link-icon{font-size:1.5rem;margin-bottom:.5rem}.mt-1{margin-top:1rem}.mt-3{margin-top:3rem}.view-all-subjects{clear:both;display:inline-block;margin-top:1.5rem;padding:.8em 1.8em}input,select{background-color:#fff;border:1px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-size:1em;margin-bottom:1em;max-width:100%;outline:none;padding:.7em 1em;transition:all .3s ease;width:100%}input:focus,select:focus{border-color:#2b6cb0;box-shadow:0 0 0 3px rgba(43,108,176,.2)}select{-webkit-appearance:menulist;appearance:menulist;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23718096' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;padding-right:2.5rem}form{display:flex;flex-direction:column;gap:1.2em}.card-list{grid-gap:1.8em;display:grid;gap:1.8em;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:1.5em}.card{background:#f8fafc;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.06);display:flex;flex-direction:column;height:100%;justify-content:space-between;padding:1.5em 1.2em;transition:all .3s ease}.card:hover{box-shadow:0 6px 18px rgba(0,0,0,.1);transform:translateY(-3px)}.header-section{border-bottom:1px solid #edf2f7;margin-bottom:2.5em;padding-bottom:1.5em;text-align:center}.subtitle{font-size:1.1rem;margin-top:.5em}.level-selector{margin-bottom:2em}.level-buttons{display:flex;flex-wrap:wrap;gap:1em;justify-content:center}.level-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05);color:#2d3748;cursor:pointer;display:flex;font-size:1em;font-weight:500;gap:.8em;min-width:180px;padding:1em 1.5em;transition:all .3s ease}.level-btn:hover{background:#edf2f7;box-shadow:0 4px 8px rgba(0,0,0,.1);transform:translateY(-2px)}.level-btn.active{background:#ebf4ff;border-color:#4299e1;box-shadow:0 0 0 3px rgba(66,153,225,.2);color:#2b6cb0}.level-icon{font-size:1.5em}.class-list{margin:2em 0}.class-buttons{display:flex;flex-wrap:wrap;gap:1em;justify-content:center;margin-top:1em}.class-btn{background:#edf2f7;border:none;border-radius:6px;color:#2d3748;cursor:pointer;font-size:1em;font-weight:500;padding:.7em 1.5em;transition:all .3s ease}.class-btn:hover{background:#e2e8f0;transform:translateY(-2px)}.class-btn.active{background:#2b6cb0;color:#fff}.subjects-section{border-top:1px solid #edf2f7;margin-top:2.5em;padding-top:1.5em}.subject-card{background:#f8fafc;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.06);display:flex;flex-direction:column;height:100%;justify-content:space-between;padding:1.5em 1.2em;text-align:center;transition:all .3s ease}.subject-card:hover{box-shadow:0 6px 18px rgba(0,0,0,.1);transform:translateY(-3px)}.subject-icon{font-size:2.5em;margin-bottom:.5em}.view-btn{background:#2b6cb0;border:none;border-radius:6px;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff!important;cursor:pointer;display:inline-block;font-size:1em;font-weight:500;margin-top:1em;padding:.7em 1.5em;transition:all .3s ease}.view-btn:hover{background:#19416b;box-shadow:0 4px 8px rgba(0,0,0,.15);color:#fff!important;transform:translateY(-2px)}.loading{font-style:italic}.loading,.no-data{color:#4a5568;padding:2em;text-align:center}.no-data{background:#f7fafc;border:1px dashed #cbd5e0;border-radius:8px;margin:1.5em 0}.practice-filters{background:linear-gradient(180deg,#f5f8ff,#f8fbff);border:1px solid #e6efff;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.04);margin-top:20px;padding:16px 18px}.practice-filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:16px 20px}.difficulty-group{align-items:center;display:flex;gap:10px}.difficulty-label{color:#2d3748;font-weight:600}.difficulty-select{background-color:#fff;border:1px solid #cbd5e0;border-radius:8px;box-shadow:0 1px 2px rgba(0,0,0,.03);padding:10px 12px;transition:all .2s ease}.difficulty-select:focus{border-color:#4299e1;box-shadow:0 0 0 3px rgba(66,153,225,.2);outline:none}.toggle-group{align-items:center;display:flex}.toggle-checkbox{-webkit-appearance:none;appearance:none;background:#e2e8f0;border-radius:999px;cursor:pointer;height:24px;margin-right:10px;outline:none;position:relative;transition:background .2s ease;width:42px}.toggle-checkbox:checked{background:#4299e1}.toggle-checkbox:after{background:#fff;border-radius:999px;box-shadow:0 1px 2px rgba(0,0,0,.2);content:"";height:18px;left:3px;position:absolute;top:3px;transition:transform .2s ease;width:18px}.toggle-checkbox:checked:after{transform:translateX(18px)}.toggle-label{color:#2d3748}.filters-meta{color:#4a5568;font-size:.9em;margin-left:auto}.filters-meta .no-questions{color:#e53e3e;font-weight:600}@media (max-width:640px){.filters-meta{margin-left:0;width:100%}}.practice-progress{margin-bottom:2em}.progress-bar{background:#edf2f7;border-radius:5px;height:10px;margin-bottom:.5em;overflow:hidden}.progress-fill{background:#4299e1;border-radius:5px;height:100%;transition:width .3s ease}.progress-text{font-size:.9em;text-align:right}.question-navigation{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5em}.nav-btn{background:#edf2f7;border:none;border-radius:6px;color:#2d3748;cursor:pointer;font-size:.9em;padding:.5em 1em;transition:all .3s ease}.nav-btn:hover:not(:disabled){background:#e2e8f0}.nav-btn:disabled{cursor:not-allowed;opacity:.5}.question-counter{color:#4a5568;font-weight:500}.question-card{background:#f8fafc;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.05);margin-bottom:2em;padding:2em}.question-text{font-size:1.4rem;margin-bottom:1.5em;margin-top:0}.options-list{display:flex;flex-direction:column;gap:1em}.option-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;padding:1em 1.5em;position:relative;transition:all .3s ease}.option-item:hover{background:#f7fafc;border-color:#cbd5e0}.option-item.selected{background:#ebf8ff;border-color:#4299e1}.option-text{flex:1 1;padding-right:2em}.option-item input[type=radio]{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.checkmark{background-color:#fff;border:2px solid #cbd5e0;border-radius:50%;height:20px;position:absolute;right:1.5em;width:20px}.option-item:hover .checkmark{border-color:#a0aec0}.option-item.selected .checkmark{background-color:#4299e1;border-color:#4299e1}.option-item.selected .checkmark:after{background:#fff;border-radius:50%;content:"";display:block;height:8px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:8px}.practice-actions{align-items:center;display:flex;flex-direction:column;gap:1.5em;margin-bottom:2em}.question-dots{flex-wrap:wrap;gap:.5em}.question-dot,.question-dots{display:flex;justify-content:center}.question-dot{align-items:center;background:#edf2f7;border:none;border-radius:50%;color:#4a5568;cursor:pointer;font-size:.9em;height:36px;transition:all .3s ease;width:36px}.question-dot:hover{background:#e2e8f0}.question-dot.active{background:#4299e1;color:#fff}.question-dot.answered{background:#c6f6d5;color:#2f855a}.question-dot.active.answered,.submit-btn{background:#38a169;color:#fff}.submit-btn{border:none;border-radius:6px;box-shadow:0 2px 4px rgba(0,0,0,.1);cursor:pointer;font-size:1.1em;font-weight:500;padding:.8em 2em;transition:all .3s ease}.submit-btn:hover:not(:disabled){background:#2f855a;box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.submit-btn:disabled{background:#a0aec0;box-shadow:none;cursor:not-allowed;transform:none}.results-section{margin-left:auto;margin-right:auto;margin-top:2em;max-width:900px}.result-card{background:#f8fafc;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 4px 12px rgba(0,0,0,.08);padding:2em;transition:all .3s ease}.result-card.passed{border-top:5px solid #38a169}.result-card.failed{border-top:5px solid #e53e3e}.result-header{border-bottom:1px solid #edf2f7;margin-bottom:2.5em;padding-bottom:1.5em;text-align:center}.result-icon{animation:bounce 1s ease;font-size:3.5em;margin-bottom:.5em}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}.result-title{color:#2d3748;font-size:1.8em;font-weight:700;margin-bottom:1em}.result-score{flex-direction:column;gap:.8em}.result-score,.score-circle{align-items:center;display:flex}.score-circle{animation:pulse 2s infinite;background:linear-gradient(135deg,#ebf8ff,#e6fffa);border:4px solid #4299e1;border-radius:50%;box-shadow:0 4px 10px rgba(66,153,225,.2);height:120px;justify-content:center;transition:all .3s ease;width:120px}.score-value{color:#2b6cb0;font-size:2.2em;font-weight:700}.score-label{background-color:#f7fafc;border-radius:20px;box-shadow:0 2px 4px rgba(0,0,0,.05);color:#4a5568;font-size:1.3em;font-weight:600;padding:.4em 1.2em}.feedback-section{border-top:1px solid #edf2f7;margin-top:2.5em;padding-top:2em}.feedback-section h3{color:#2d3748;font-size:1.4em;margin-bottom:1.2em;padding-bottom:.5em;position:relative;text-align:center}.feedback-section h3:after{background-color:#4299e1;border-radius:3px;bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.feedback-list{display:flex;flex-direction:column;gap:1.8em;margin-top:1.5em}.feedback-item{background:#fff;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 3px 8px rgba(0,0,0,.08);padding:1.8em;transition:transform .2s ease,box-shadow .2s ease}.feedback-item:hover{box-shadow:0 5px 15px rgba(0,0,0,.1);transform:translateY(-2px)}.feedback-question{background:#f7fafc;border-left:4px solid #805ad5;border-radius:8px;color:#2d3748;font-size:1.1em;font-weight:600;margin-bottom:1.2em;padding:.6em 1em}.feedback-answer{border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.05);margin-bottom:1em;padding:1em;transition:all .2s ease}.feedback-answer:hover{box-shadow:0 2px 6px rgba(0,0,0,.1)}.feedback-answer.wrong{background:#fff5f5;border-left:4px solid #e53e3e}.feedback-answer.correct{background:#f0fff4;border-left:4px solid #38a169}.feedback-explanation{background:#f7fafc;border-left:4px solid #4299e1;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.05);margin-top:.5em;padding:1em}.feedback-label{color:#4a5568;font-weight:500;margin-right:.5em}.result-actions{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:1em;justify-content:center;margin-top:2em}.result-actions .btn{box-shadow:0 2px 5px rgba(0,0,0,.1);font-weight:600;letter-spacing:.02em;margin:.5em;min-width:180px;padding:.8em 1.5em;transition:all .2s ease}.result-actions .btn:hover{box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.result-actions .btn.primary{background-color:#4299e1;color:#fff}.result-actions .btn.primary:hover{background-color:#3182ce}.result-actions .btn.secondary{background-color:#f7fafc;border:1px solid #e2e8f0;color:#4a5568}.result-actions .btn.secondary:hover{background-color:#edf2f7}.goal-status-message,.task-status-message{align-items:center;background-color:#f7fafc;border-radius:8px;box-shadow:0 2px 6px rgba(0,0,0,.05);display:flex;flex-direction:column;gap:1em;margin:1em auto;max-width:600px;padding:1em;width:100%}.info-message{background-color:#ebf8ff;box-shadow:0 2px 4px rgba(66,153,225,.1);color:#2c5282;line-height:1.5;margin:1em 0;width:100%}.info-message p{margin-bottom:.8em}.info-message p:last-child{margin-bottom:0}.lesson-completion-details{background-color:#f0f9ff;border-left:4px solid #3182ce;border-radius:6px;margin:15px 0;padding:10px;text-align:left}.lesson-completion-details p{font-weight:500;margin-bottom:8px}.lesson-progress{background-color:#e2e8f0;height:10px;margin:10px 0}.lesson-progress .progress-fill{background-color:#4299e1;transition:width .5s ease-in-out}.success-text{color:#2f855a;font-weight:600;margin-top:.5em}.error-message{background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030;margin:1.5em 0;padding:2em;text-align:center}.btn--ghost{background:#fff;border:1px solid #e5e7eb;color:#0f172a}.btn--ghost:hover{background:#f8fafc}.btn--ghost:focus-visible{outline:3px solid rgba(59,130,246,.35);outline-offset:2px}.btn--gradient-blue{align-items:center;background:linear-gradient(90deg,#2563eb,#1d4ed8);border:1px solid #1d4ed8;border-radius:8px;box-shadow:0 6px 14px rgba(37,99,235,.25);color:#fff;cursor:pointer;display:inline-flex;gap:8px;padding:10px 14px;transition:transform .2s ease,filter .2s ease,box-shadow .2s ease}.btn--gradient-blue:hover{filter:brightness(1.05);transform:translateY(-1px)}.btn--gradient-blue:disabled,.btn--gradient-blue[disabled]{box-shadow:none;cursor:not-allowed;opacity:.75;transform:none}.form-card input,.form-card select,.form-card textarea{background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;outline:none;padding:.75em .9em;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease;width:100%}.form-card input::placeholder,.form-card textarea::placeholder{color:#a0aec0}.form-card input:focus,.form-card select:focus,.form-card textarea:focus{border-color:#90cdf4;box-shadow:0 0 0 4px rgba(66,153,225,.15)}.form-card .form-actions{align-items:center;justify-content:space-between;margin-top:.5em}.form-card .form-actions.right{gap:1em;justify-content:flex-end}.form-card .form-actions .btn{margin-top:0;min-width:140px}.form-card .btn-login{border:none;border-radius:9999px;box-shadow:0 4px 10px rgba(59,130,246,.3);color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .2s ease-in-out}.form-card .btn-login,.form-card .btn-login:hover{background:linear-gradient(135deg,#4f46e5,#3b82f6)}.form-card .btn-login:hover{box-shadow:0 6px 14px rgba(59,130,246,.4);transform:scale(1.05)}.form-card .btn-login:focus-visible{outline:3px solid rgba(99,102,241,.45);outline-offset:2px}.form-card .btn-login:disabled{background:linear-gradient(135deg,#a5b4fc,#93c5fd);box-shadow:none;transform:none}.form-card .remember{align-items:center;color:#4a5568;display:flex;font-size:.95em;gap:8px}.form-card .remember label{cursor:pointer;line-height:1.2;margin:0;-webkit-user-select:none;user-select:none}.form-card input[type=checkbox]{accent-color:#2b6cb0;height:16px;margin:0;transform:translateY(1px);width:16px}.form-card .input-wrap{position:relative}.form-card .input-wrap input[type=password],.form-card .input-wrap input[type=text]{padding-right:42px}.form-card .toggle-visibility{align-items:center;background:transparent;border:none;border-radius:6px;color:#718096;cursor:pointer;display:inline-flex;height:34px;justify-content:center;margin-top:-6px;position:absolute;right:10px;top:50%;transform:translateY(-50%);width:34px}.form-card .toggle-visibility:hover{background:#edf2f7;color:#2d3748}.form-card .toggle-visibility:focus-visible{outline:3px solid rgba(66,153,225,.35);outline-offset:2px}.form-card .login-button{align-items:center;background-color:#8dc63f;border:none;border-radius:50px;box-shadow:0 4px 6px rgba(0,0,0,.2);color:#333;cursor:pointer;display:inline-flex;font-size:18px;font-weight:700;padding:10px 25px 10px 15px;transition:transform .2s,box-shadow .2s}.form-card .login-button:before{background:linear-gradient(145deg,#4a79a7,#2e5b85);border-radius:3px;-webkit-clip-path:polygon(100% 50%,0 0,0 100%);clip-path:polygon(100% 50%,0 0,0 100%);content:"";display:inline-block;height:20px;margin-right:12px;width:20px}.form-card .login-button:hover{box-shadow:0 6px 10px rgba(0,0,0,.3);transform:scale(1.05)}.form-card .login-button:active{transform:scale(.98)}.form-card .login-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.header-section h1{margin-bottom:.2em}.header-section h1:after{background:linear-gradient(90deg,#63b3ed,#805ad5);border-radius:4px;content:"";display:block;height:4px;margin:.6em auto 0;opacity:.25;width:80px}.info-message{background:#ebf8ff;border:1px solid #bee3f8;border-radius:8px;color:#2b6cb0;margin:1.2em 0;padding:1.2em;text-align:center}.divider{align-items:center;color:#718096;display:flex;margin:2em 0;text-align:center}.divider:after,.divider:before{border-bottom:1px solid #e2e8f0;content:"";flex:1 1}.divider span{font-size:.9em;padding:0 1em}.demo-login{margin-bottom:1.5em;text-align:center}.login-link,.register-link{color:#4a5568;margin-top:1.5em;text-align:center}.login-link a,.register-link a{border-bottom:1px dashed #3182ce;color:#3182ce;font-weight:500;padding-bottom:1px;text-decoration:none;transition:all .2s ease}.login-link a:hover,.register-link a:hover{border-bottom:1px solid #2c5282;color:#2c5282}.loading-inline{color:#718096;font-style:italic}.info-text,.loading-inline{font-size:.9em;margin-top:.5em}.info-text{background:#f7fafc;border:1px dashed #e2e8f0;border-radius:4px;color:#4a5568;line-height:1.5;padding:.8em}.info-text p{margin:.5em 0}.info-text p:first-child{margin-top:0}.info-text p:last-child{margin-bottom:0}.planning-tabs{border-bottom:1px solid #edf2f7;display:flex;justify-content:center;margin-bottom:2em;padding-bottom:1em}.tab-btn{background:none;border:none;border-bottom:3px solid transparent;color:#4a5568;cursor:pointer;font-size:1.1em;font-weight:500;margin:0 .5em;padding:.8em 2em;transition:all .3s ease}.tab-btn:hover{color:#2b6cb0}.tab-btn.active{border-bottom-color:#2b6cb0;color:#2b6cb0}.section-header{justify-content:space-between;margin-bottom:1.5em}.header-right,.section-header{align-items:center;display:flex}.header-right{gap:1.5em}.monthly-progress-summary{align-items:center;background:#f8fafc;border:1px solid #edf2f7;border-radius:8px;display:flex;gap:.8em;padding:.6em 1em}.monthly-progress-summary .progress-label{color:#4a5568;font-weight:500;white-space:nowrap}.monthly-progress-summary .progress-bar{background:#e2e8f0;border-radius:4px;height:8px;overflow:hidden;width:100px}.monthly-progress-summary .progress-percentage{font-weight:600;min-width:3em;text-align:right}.add-goal-btn{background:#4299e1;border-radius:6px;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;font-weight:500;padding:.6em 1.2em;transition:all .3s ease}.add-goal-btn:hover{background:#3182ce;box-shadow:0 4px 6px rgba(0,0,0,.1);transform:translateY(-2px)}.form-card{background:#f8fafc;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.06);margin-bottom:2em;padding:1.5em}.form-group{margin-bottom:1.2em}.form-group label{color:#4a5568;display:block;font-weight:500;margin-bottom:.5em}.form-row{display:flex;flex-wrap:wrap;gap:1em;margin-bottom:1em}.form-row .form-group{flex:1 0 200px;min-width:0}.form-actions{display:flex;gap:1em;justify-content:flex-end;margin-top:1.5em}.input-with-button{align-items:center;display:flex;gap:8px}.add-item-btn{font-size:18px;height:28px;line-height:1;width:28px}.add-item-btn:hover{transform:scale(1.1)}.selected-items{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.selected-item{align-items:center;background:#ebf8ff;border:1px solid #bee3f8;border-radius:16px;display:flex;font-size:.9em;padding:4px 10px}.remove-item-btn{background:none;border:none;color:#4a5568;cursor:pointer;font-size:16px;line-height:1;margin-left:6px;padding:0 4px}.remove-item-btn:hover{color:#e53e3e}.related-items-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.related-item{align-items:center;background:#ebf8ff;border:1px solid #bee3f8;border-radius:8px;box-shadow:0 1px 2px rgba(0,0,0,.05);display:inline-flex;font-size:.9em;padding:8px 14px;transition:all .2s ease}.related-item:hover{background:#bee3f8;box-shadow:0 2px 4px rgba(0,0,0,.1);transform:translateY(-1px)}.related-item a{color:#2b6cb0;text-decoration:none}.related-item a:hover{text-decoration:underline}.add-all-button-container{display:flex;justify-content:center;margin:20px 0}.add-all-btn{background:#4299e1;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;gap:8px;justify-content:center;padding:10px 20px}.add-all-btn:hover{background:#3182ce;box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.add-all-btn:disabled{background:#a0aec0;box-shadow:none;transform:none}.selected-items h5{color:#4a5568;font-size:.9em;font-weight:600;margin:0 0 8px}.goal-type-options,.progress-calculation-options,.progress-source-options,.repeat-options{display:flex;flex-direction:column;gap:.8em;margin-top:.5em}.checkbox-label,.radio-label{align-items:center;border-radius:6px;cursor:pointer;display:flex;padding:.5em;transition:background-color .2s ease}.checkbox-label:hover,.radio-label:hover{background-color:#f0f4f8}.checkbox-label input[type=checkbox],.radio-label input[type=radio]{margin-right:.8em}.checkbox-label span,.radio-label span{font-size:.95em}.checkbox-list{border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;gap:.5em;margin-top:.5em;max-height:200px;overflow-y:auto;padding:.5em}.nested-form-group{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin-top:1em;padding:1em}.guidance-list{margin:.5em 0;padding-left:1.5em}.guidance-list li{margin-bottom:.5em}.lesson-selection{margin-top:.5em}.input-with-suffix{align-items:center;display:flex;position:relative}.input-with-suffix input{padding-right:4em;width:100%}.input-suffix{color:#718096;font-size:.9em;pointer-events:none;position:absolute;right:1em}@media (min-width:768px){.goal-type-options,.repeat-options{flex-direction:row;flex-wrap:wrap}.radio-label{flex:1 0 auto;min-width:180px}}textarea{border:1px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:1em;max-width:100%;padding:.7em 1em;resize:vertical;width:100%}textarea:focus{border-color:#2b6cb0;box-shadow:0 0 0 3px rgba(43,108,176,.2);outline:none}.task-filters{display:flex;flex-wrap:wrap;gap:.5em;margin-bottom:1.5em}.filter-btn{background:#edf2f7;border:none;border-radius:20px;color:#4a5568;cursor:pointer;font-size:.9em;padding:.5em 1em;transition:all .3s ease}.filter-btn:hover{background:#e2e8f0}.filter-btn.active{background:#2b6cb0;color:#fff}.filter-section{background:#f8fafc;border:1px solid #edf2f7;border-radius:10px;margin-bottom:2em;padding:1.5em}.class-filter,.goal-status-filter,.subject-filter{margin-bottom:1.5em}.class-filter:last-child,.goal-status-filter:last-child,.subject-filter:last-child{margin-bottom:0}.filter-section label{color:#4a5568;display:block;font-weight:500;margin-bottom:.5em}.filter-select,.subject-filter-select{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;font-size:.95em;padding:.7em 1em;transition:all .3s ease;width:100%}.filter-select:focus,.subject-filter-select:focus{border-color:#4299e1;box-shadow:0 0 0 3px rgba(66,153,225,.2);outline:none}.status-filter-tabs{display:flex;flex-wrap:wrap;gap:.5em;margin-top:.5em}.status-tab{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:.9em;padding:.5em 1em;transition:all .2s ease}.status-tab:hover{background:#e2e8f0}.status-tab.active{background:#2b6cb0;border-color:#2b6cb0;color:#fff}@media (max-width:768px){.status-filter-tabs{flex-direction:column;width:100%}.status-tab{text-align:center;width:100%}}.goal-list,.task-list{grid-gap:1.5em;display:grid;gap:1.5em;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.goal-card,.task-card{background:#fff;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.06);display:flex;flex-direction:column;padding:1.5em;transition:all .3s ease}.goal-card:hover,.task-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-3px)}.goal-header,.task-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1em}.goal-header h3,.task-header h3{font-size:1.2em;margin:0;word-break:break-word}.goal-badges,.task-badges{display:flex;flex-wrap:wrap;gap:.5em;margin-left:1em}.category-badge,.priority-badge,.status-badge{border-radius:20px;font-size:.8em;font-weight:500;padding:.3em .8em;white-space:nowrap}.status-badge.pending{background:#ebf8ff;color:#3182ce}.status-badge.in-progress{background:#fefcbf;color:#d69e2e}.status-badge.achieved,.status-badge.completed{background:#c6f6d5;color:#38a169}.status-badge.abandoned,.status-badge.cancelled{background:#fed7d7;color:#e53e3e}.status-badge.not-started{background:#e2e8f0}.priority-badge.low{background:#e2e8f0;color:#4a5568}.priority-badge.medium{background:#fefcbf;color:#d69e2e}.priority-badge.high{background:#fed7d7;color:#e53e3e}.category-badge{background:#ebf8ff;color:#3182ce}.goal-description,.task-description{color:#4a5568;font-size:.95em;margin-bottom:1em}.goal-meta,.task-meta{color:#718096;font-size:.9em;margin-bottom:1em}.meta-label{color:#4a5568;font-weight:500;margin-right:.5em}.meta-link{border-bottom:1px dashed #3182ce;color:#3182ce;padding-bottom:1px;text-decoration:none;transition:all .2s ease}.meta-link:hover{border-bottom:1px solid #2c5282;color:#2c5282}.goal-actions,.task-actions{display:flex;flex-wrap:wrap;gap:.8em;justify-content:flex-end;margin-top:auto;padding-top:1em}.action-btn{border:none;border-radius:6px;cursor:pointer;display:inline-block;font-size:.9em;font-weight:500;padding:.5em 1em;text-align:center;text-decoration:none;transition:all .3s ease}.action-btn.start{background:#fefcbf;color:#d69e2e}.action-btn.start:hover{background:#f6e05e}.action-btn.continue{background:#e3f2fd;color:#1976d2}.action-btn.continue:hover{background:#bbdefb}.action-btn.complete{background:#c6f6d5;color:#38a169}.action-btn.complete:hover{background:#9ae6b4}.action-btn.complete.ready-to-complete{animation:pulse 2s infinite;background:#48bb78;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;font-weight:700}.action-btn.complete.ready-to-complete:hover{background:#38a169;box-shadow:0 4px 6px rgba(0,0,0,.1);transform:translateY(-2px)}@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(72,187,120,.4)}70%{box-shadow:0 0 0 10px rgba(72,187,120,0)}to{box-shadow:0 0 0 0 rgba(72,187,120,0)}}.action-btn.delete{background:#fed7d7;color:#e53e3e}.action-btn.delete:hover{background:#feb2b2}.action-btn.view{background:#ebf8ff;color:#3182ce}.action-btn.view:hover{background:#bee3f8}.action-btn.practice{background:#0d9488;border:2px solid #0d9488;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;font-weight:600;overflow:hidden;position:relative;transition:all .2s ease-in-out}.action-btn.practice:hover{background:#0fb5a5;box-shadow:0 4px 8px rgba(0,0,0,.15);transform:translateY(-2px)}.action-btn.practice:active{box-shadow:0 2px 4px rgba(0,0,0,.1);transform:translateY(0)}.action-btn.practice:after{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease-in-out;width:100%}.action-btn.practice:hover:after{left:100%}.goal-title-with-icon{align-items:center;display:flex;gap:.5em}.subject-icon{align-items:center;display:flex;font-size:1.5em;justify-content:center}.goal-progress{margin-bottom:1em}.goal-details-view{margin-top:1em}.goal-detail-card{background:#fff;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.08);padding:2em}.goal-detail-header{align-items:flex-start;border-bottom:1px solid #edf2f7;display:flex;justify-content:space-between;margin-bottom:1.5em;padding-bottom:1em}.goal-detail-header h3{color:#2d3748;font-size:1.5em;margin:0}.goal-detail-content{display:flex;flex-direction:column;gap:1.5em}.goal-detail-section{margin-bottom:1em}.goal-detail-section h4{border-bottom:1px solid #edf2f7;color:#4a5568;font-size:1.1em;margin-bottom:.8em;padding-bottom:.3em}.detail-info-grid{grid-gap:1em;display:grid;gap:1em;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.detail-info-item{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;margin-bottom:1.2em;padding:12px;transition:box-shadow .2s ease}.detail-info-item:hover{box-shadow:0 2px 4px rgba(0,0,0,.05)}.detail-label{border-bottom:1px solid #edf2f7;color:#4a5568;font-size:.9em;font-weight:600;margin-bottom:.5em;padding-bottom:6px}.detail-value{color:#2d3748}.related-tasks-list{display:flex;flex-direction:column;gap:.8em}.related-task-item{background:#f8fafc;border:1px solid #edf2f7;border-radius:6px;padding:1em}.related-task-title{align-items:center;display:flex;font-weight:500;justify-content:space-between;margin-bottom:.5em}.related-task-due{color:#718096;font-size:.9em}.goal-detail-actions{border-top:1px solid #edf2f7;display:flex;flex-wrap:wrap;gap:.8em;justify-content:flex-end;margin-top:2em;padding-top:1em}.no-data-small{color:#718096;font-size:.95em;font-style:italic}.completion-instructions{margin-top:.5em}.completion-status{border-radius:8px;margin-bottom:1em;padding:1.2em;position:relative}.completion-status.achieved{background-color:#c6f6d5;border:1px solid #9ae6b4}.completion-status.ready{background-color:#e9f5fe;border:1px solid #90cdf4}.completion-status.in-progress{background-color:#fefcbf;border:1px solid #f6e05e}.completion-icon{display:inline-block;font-size:1.5em;margin-right:.5em;vertical-align:middle}.completion-status p{line-height:1.5;margin:.5em 0}.completion-status p:first-child{margin-top:0}.completion-status p:last-child{margin-bottom:0}.completion-status strong{color:#2d3748;font-weight:600}.completion-status ol{margin:.5em 0 1em 1.5em;padding-left:0}.completion-status ol li{margin-bottom:.5em;padding-left:.5em}.progress-text{color:#4a5568;font-size:.95em;margin-top:.5em}.progress-label{color:#4a5568;display:flex;font-size:.9em;justify-content:space-between;margin-bottom:.5em}.progress-status{align-items:center;display:flex;font-weight:500;gap:.3em;margin-left:auto}.progress-info{align-items:center;cursor:help;display:inline-flex;margin-left:.5em}.info-icon{color:#4299e1;font-size:.9em;font-style:normal;transition:color .2s ease}.info-icon:hover{color:#2b6cb0}.progress-hint{color:#718096;font-size:.85em;font-style:italic;line-height:1.4;margin-top:.4em}.hint-icon{display:inline-block;font-size:1.2em;margin-right:.4em;vertical-align:middle}.progress-hint strong{color:#2d3748;font-style:normal;font-weight:600}@media (max-width:768px){.container{margin:20px 10px;padding:1.5em 1em}.card-list{grid-template-columns:1fr}.level-buttons{align-items:center;flex-direction:column}.level-btn{max-width:300px;width:100%}.question-card{padding:1.5em 1em}.option-item{padding:.8em 1em}.result-actions{flex-direction:column;gap:.8em}.result-actions .btn{margin:.3em;max-width:250px;width:100%}.form-row{flex-direction:column;gap:0}.goal-list,.task-list{grid-template-columns:1fr}.completion-label{align-items:center;display:flex;flex-wrap:wrap}.progress-info{margin-left:.3em}.progress-hint{line-height:1.4;margin-top:.5em}.hero-buttons{align-items:center;flex-direction:column}.hero-buttons .btn{margin-top:.8em;max-width:250px;width:100%}.subjects-grid{gap:2rem;grid-template-columns:1fr}.subject-card{margin-bottom:1rem;padding:1.5rem;position:relative}.subject-card .btn{margin-bottom:.5rem}.mt-3{margin-top:4rem}.view-all-subjects{margin-top:2rem;max-width:300px;width:100%}.goal-card,.task-card{padding:1.2em}.goal-header,.task-header{align-items:flex-start;flex-direction:column}.goal-badges,.task-badges{margin-left:0;margin-top:.5em}.goal-actions,.task-actions{justify-content:space-between}.goal-actions button,.task-actions button{flex:1 1;font-size:.85em;min-width:0;padding:.5em .3em;text-align:center}.goal-detail-card{padding:1.2em}.goal-detail-header{align-items:flex-start;flex-direction:column}.goal-detail-header .goal-badges{margin-left:0;margin-top:.5em}.detail-info-grid{grid-template-columns:1fr}.goal-detail-actions{justify-content:space-between}.goal-detail-actions button{flex:1 1;font-size:.85em;min-width:0;padding:.5em .3em;text-align:center}}.modal-overlay{align-items:center;background-color:rgba(0,0,0,.5);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.practice-log-modal{animation:modal-fade-in .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);max-width:500px;overflow:hidden;padding:0;width:90%}@keyframes modal-fade-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:#f8fafc;border-bottom:1px solid #edf2f7;padding:1rem 1.5rem}.modal-header h3{color:#2d3748;font-size:1.25rem;margin:0}.modal-content{padding:1.5rem}.goal-info{background:#f8fafc;border:1px solid #edf2f7;border-radius:4px;color:#2d3748;font-weight:500;margin-top:.25rem;padding:.75rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem}.error-message{font-size:.9rem;margin-top:.5rem}.confirmation-dialog-overlay{align-items:center;background-color:rgba(0,0,0,.5);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.confirmation-dialog{animation:dialog-fade-in .3s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);max-width:500px;overflow:hidden;padding:0;width:90%}@keyframes dialog-fade-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.confirmation-dialog-header{background:#f8fafc;border-bottom:1px solid #edf2f7;padding:1rem 1.5rem}.confirmation-dialog-header h3{color:#2d3748;font-size:1.25rem;margin:0}.confirmation-dialog-content{padding:1.5rem}.confirmation-dialog-content p{color:#4a5568;line-height:1.5;margin:0}.validation-errors{margin:0;padding:0;text-align:left}.validation-error-item{border-bottom:1px solid #edf2f7;color:#e53e3e;font-size:.95em;margin:.5em 0;padding:.5em 0}.validation-error-item:last-child{border-bottom:none}.required-field:after{color:#e53e3e;content:" *";font-weight:700}.input-error{background-color:#fff5f5!important;border:2px solid #e53e3e!important}.input-error:focus{box-shadow:0 0 0 3px rgba(229,62,62,.3)!important;outline:none}.error-message{color:#e53e3e;display:block;font-size:.85em;margin-top:.25rem}.related-items-section.input-error{background-color:#fff5f5;border:2px solid #e53e3e;border-radius:8px;padding:10px}.empty-content-container.input-error{background-color:#fff5f5;border:2px solid #e53e3e}.empty-content-container{align-items:center;background-color:#f8fafc;border:1px dashed #cbd5e0;border-radius:8px;display:flex;flex-direction:column;justify-content:center;margin:1rem 0;padding:2rem;text-align:center}.empty-content-icon{color:#718096;font-size:3rem;margin-bottom:1rem}.empty-content-title{color:#4a5568;font-size:1.25rem;font-weight:600;margin-bottom:.75rem}.empty-content-description{color:#718096;margin:0 auto;max-width:500px;text-align:left}.empty-content-steps{margin-top:.75rem;padding-left:1.5rem;text-align:left}.empty-content-steps li{line-height:1.5;margin-bottom:.5rem}.highlight-text{background-color:#ebf8ff;border-radius:4px;color:#2b6cb0;font-weight:600;padding:.1rem .3rem}.confirmation-dialog-actions{background:#f8fafc;border-top:1px solid #edf2f7;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.confirmation-dialog-actions button{margin:0}.toast-container{max-width:350px;opacity:0;position:fixed;right:20px;top:20px;transform:translateY(-20px);transition:opacity .3s ease,transform .3s ease;z-index:1100}.toast-container.visible{opacity:1;transform:translateY(0)}.toast{align-items:center;background:#fff;border-left:4px solid #718096;border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.15);display:flex;justify-content:space-between;margin-bottom:10px;padding:12px 16px}.toast.success{background-color:#f0fff4;border-left-color:#38a169}.toast.error{background-color:#fff5f5;border-left-color:#e53e3e}.toast.info{background-color:#ebf8ff;border-left-color:#3182ce}.toast-message{color:#2d3748;flex:1 1;font-size:.95rem}.toast.success .toast-message{color:#276749}.toast.error .toast-message{color:#c53030}.toast.info .toast-message{color:#2c5282}.toast-close{align-items:center;background:none;border:none;border-radius:50%;color:#a0aec0;cursor:pointer;display:flex;font-size:1.25rem;height:24px;justify-content:center;line-height:1;margin-left:8px;padding:0;transition:background-color .2s ease;width:24px}.toast-close:hover{background-color:rgba(0,0,0,.05);color:#718096}@media (max-width:640px){.toast-container{bottom:16px;left:50%;max-width:min(560px,90vw);right:auto;top:auto;transform:translate(-50%,20px)}.toast-container.visible{transform:translate(-50%)}.confirmation-dialog{width:95%}.confirmation-dialog-actions,.confirmation-dialog-content,.confirmation-dialog-header{padding:1rem}.confirmation-dialog-actions{flex-direction:column-reverse;gap:.5rem}.confirmation-dialog-actions button{width:100%}}.related-items-section{padding:15px}.related-items-form{margin-bottom:20px}.related-item-groups{margin-top:20px}.related-item-group{padding:15px;transition:box-shadow .2s ease}.related-item-group:hover{box-shadow:0 3px 6px rgba(0,0,0,.1)}.related-item-group-content{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.related-item-field{display:flex;flex-direction:column;gap:4px;padding:4px 0}.field-label{font-size:.85em;margin-bottom:2px}.field-value{font-size:.95em}.remove-group-btn{padding:5px}.remove-group-btn:hover{transform:scale(1.1)}.add-icon{font-size:14px;margin-right:5px}.related-items-table-container{margin:20px 0;overflow-x:auto}.related-items-table{background-color:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05);min-width:640px;width:100%}.related-items-table td,.related-items-table th{border-bottom:1px solid #e2e8f0;padding:12px 15px;text-align:left}.related-items-table th{background-color:#f8fafc;color:#4a5568;font-size:.9em;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.related-items-table tr:last-child td{border-bottom:none}.related-items-table tr:hover{background-color:#f7fafc}.status-badge{border-radius:4px;display:inline-block;font-size:.8em;font-weight:500;padding:4px 8px}.status-badge.completed{background-color:#c6f6d5;color:#22543d}.status-badge.cancelled{background-color:#fed7d7;color:#822727}.status-badge.in-progress{background-color:#bee3f8;color:#2a4365}.status-badge.not-started{background-color:#e2e8f0;color:#4a5568}.select-wrapper{position:relative;width:100%}.select-with-button{align-items:center;display:flex;gap:10px}.select-with-button .select-wrapper{flex:1 1}.add-item-btn{align-items:center;background:#4299e1;border:none;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .2s ease;width:36px}.add-item-btn:hover{background:#3182ce;transform:scale(1.05)}.add-item-btn:disabled{background:#a0aec0;cursor:not-allowed;transform:none}.form-hint{color:#718096;display:flex;font-size:.85em;justify-content:flex-end;margin-top:5px}.select-wrapper select{-webkit-appearance:none;appearance:none;background-color:#fff;border:2px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05);color:#2d3748;cursor:pointer;font-size:16px;font-weight:500;padding:12px 40px 12px 16px;transition:all .3s ease;width:100%}.select-wrapper select option{color:#2d3748;font-size:16px;padding:12px}.select-wrapper:after{border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid #4a5568;content:"";height:0;pointer-events:none;position:absolute;right:16px;top:50%;transform:translateY(-50%);transition:all .3s ease;width:0}.select-wrapper:hover:after{border-top-color:#2b6cb0}.select-wrapper select:hover{border-color:#cbd5e0;box-shadow:0 4px 6px rgba(0,0,0,.1)}.select-wrapper select:focus{border-color:#4299e1;box-shadow:0 0 0 3px rgba(66,153,225,.3);outline:none}.highlight-select{background-color:#ebf8ff!important;border-color:#4299e1!important}.selection-prompt{align-items:center;background-color:#fffaf0;border-left:4px solid #ed8936;border-radius:4px;color:#744210;display:flex;font-size:14px;margin-top:8px;padding:8px 12px}.prompt-icon{margin-right:8px}.form-group.cascading-select{border-left:2px dashed #e2e8f0;margin-bottom:24px;padding-left:16px;position:relative}.form-group.cascading-select:before{background-color:#e2e8f0;border-radius:50%;content:"";height:10px;left:-6px;position:absolute;top:-10px;width:10px}.form-group.cascading-select label{align-items:center;display:flex}.form-group.cascading-select label:before{color:#718096;content:"↳";font-weight:700;margin-right:8px}.related-items-section{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.05);margin:20px 0;padding:20px}.related-items-section h4{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:18px;margin-bottom:16px;margin-top:0;padding-bottom:10px}.add-all-button-container{margin-bottom:16px}.add-all-btn{align-items:center;background-color:#ebf8ff;border:1px solid #bee3f8;border-radius:6px;color:#2b6cb0;display:flex;font-weight:500;padding:10px 16px;transition:all .3s ease}.add-all-btn:hover:not(:disabled){background-color:#bee3f8;box-shadow:0 2px 4px rgba(0,0,0,.1)}.add-all-btn:disabled{cursor:not-allowed;opacity:.6}.button-hint{color:#718096;font-size:14px;font-style:italic;margin-top:8px;text-align:center}.related-item-groups h5{color:#4a5568;font-size:16px;margin-bottom:12px;margin-top:0}.related-item-group{align-items:flex-start;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05);margin-bottom:12px;padding:16px;transition:all .3s ease}.related-item-group:hover{box-shadow:0 4px 8px rgba(0,0,0,.1);transform:translateY(-2px)}.related-item-field{margin-bottom:8px}.field-label{color:#4a5568;font-size:14px;font-weight:600;margin-bottom:4px}.field-value{color:#2d3748;font-size:16px}.remove-group-btn{align-items:center;background:none;border:none;border-radius:50%;color:#a0aec0;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;padding:8px;transition:all .2s ease;width:32px}.remove-group-btn:hover{background-color:#fff5f5;color:#e53e3e}.related-items-header{border-bottom:1px solid #e2e8f0;display:flex;font-weight:600;justify-content:space-between;margin-bottom:.5em;padding:.5em 1em}.related-item-header-content{flex:1 1}.related-item-header-status{text-align:center;width:120px}.related-item-group{align-items:center;display:flex;justify-content:space-between}.related-item-group-content{flex:1 1}.related-item-status{text-align:center;width:120px}.status-badge.status-passed{background-color:#48bb78;color:#fff}.status-badge.status-failed{background-color:#f56565;color:#fff}.status-badge.status-not-started{background-color:#a0aec0;color:#fff}.lesson-engagements-list{border:1px solid #e2e8f0;border-radius:8px;margin-top:1em;overflow:hidden}.lesson-engagements-header{background:#f8fafc;font-weight:600}.lesson-engagement-item,.lesson-engagements-header{border-bottom:1px solid #e2e8f0;display:grid;grid-template-columns:3fr 1fr 1.5fr 1.5fr;padding:.8em 1em}.lesson-engagement-item{align-items:center}.lesson-engagement-item:last-child{border-bottom:none}.lesson-engagement-item:hover{background:#f8fafc}.engagement-lesson{font-weight:500}.engagement-duration{font-weight:500;text-align:center}.engagement-date{color:#4a5568}.engagement-status .status-badge{border-radius:4px;display:inline-block;font-size:.85em;font-weight:500;padding:.3em .6em}.lesson-engagement-summary{background:#f0f9ff;border-left:4px solid #3182ce;border-radius:6px;margin-top:1em;padding:.8em}.lesson-engagement-summary p{color:#2c5282;margin:0}.auto-tracking-note{background-color:#ebf8ff;border-left:4px solid #4299e1;border-radius:4px;color:#2b6cb0;font-weight:500;margin-top:1em;padding:.8em}.auto-tracking-section{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05);margin-top:1.5em;padding:1.5em}.auto-tracking-section h4{align-items:center;color:#2c5282;display:flex;margin-top:0}.auto-tracking-section h4:before{content:"⏱️";margin-right:.5em}.auto-tracking-info{align-items:center;background-color:#ebf8ff;border-radius:6px;display:flex;margin-bottom:1.5em;padding:1em}.auto-tracking-icon{font-size:1.8em;margin-right:.8em}.auto-tracking-text p{color:#2c5282;font-weight:500;margin:0}.auto-tracking-empty{background-color:#f0f9ff;border:1px dashed #90cdf4;border-radius:8px;padding:2em;text-align:center}.auto-tracking-empty .auto-tracking-icon{font-size:2.5em;margin-bottom:.5em}.auto-tracking-empty p{color:#2c5282;margin:.5em 0}.auto-tracking-empty p:last-child{color:#4a5568;font-size:.9em}.section-header-with-actions{align-items:center;display:flex;justify-content:space-between;margin-bottom:1em}.section-header-with-actions h4{margin:0}.refresh-btn{align-items:center;background-color:#edf2f7;border:1px solid #e2e8f0;border-radius:4px;color:#4a5568;cursor:pointer;display:flex;font-size:.9em;padding:.4em .8em;transition:all .2s ease}.refresh-btn:hover{background-color:#e2e8f0;color:#2d3748}.refresh-btn span{margin-right:.4em}.refresh-btn.refreshing{cursor:wait;opacity:.7}.refresh-btn.refreshing .refresh-icon{animation:spin 1s linear infinite}@media (max-width:768px){.lesson-engagement-item,.lesson-engagements-header{font-size:.9em;grid-template-columns:2fr 1fr 1fr 1fr;padding:.6em .8em}}@media (max-width:576px){.lesson-engagements-header{display:none}.lesson-engagement-item{gap:.5em;grid-template-columns:1fr}.engagement-lesson:before{color:#718096;content:"Bài học: ";font-weight:400}.engagement-duration:before{color:#718096;content:"Thời gian: ";font-weight:400}.engagement-date:before{color:#718096;content:"Ngày: ";font-weight:400}}.app-header-inner{box-sizing:border-box;padding:0 2.5em}.app-brand-link{text-shadow:1px 1px 2px rgba(0,0,0,.2)}.app-nav{gap:1em;margin-left:2em}.app-nav,.app-nav-link{align-items:center;display:inline-flex}.app-nav-link{background:hsla(0,0%,100%,.85);border:1px solid rgba(0,0,0,.08);border-radius:8px;box-shadow:0 1px 2px rgba(0,0,0,.04);color:#1a202c;font-weight:600;gap:8px;letter-spacing:.1px;padding:8px 12px;text-decoration:none;transition:background .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease,transform .05s ease}.app-nav-link:hover{background:#fff;border-color:rgba(0,0,0,.12);box-shadow:0 2px 6px rgba(0,0,0,.08);color:#2b6cb0;color:var(--accent)}.app-nav-link:active{transform:translateY(1px)}.app-nav-link:focus-visible{outline:2px solid #2b6cb0;outline:2px solid var(--accent);outline-offset:2px}.app-nav-link.active,.app-nav-link[aria-current=page]{background:#34d399;border-color:transparent;box-shadow:0 0 0 2px rgba(0,0,0,.06);color:#fff!important}.app-nav-link.active:visited,.app-nav-link[aria-current=page]:visited{color:#fff!important}@supports not (color:color-mix(in oklab,white 10%,black)){.app-nav-link.active,.app-nav-link[aria-current=page]{background:#34d399;border-color:transparent;box-shadow:0 0 0 2px rgba(0,0,0,.06);color:#fff!important}}html[data-theme-mode=dark] .app-nav-link{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.18);box-shadow:0 1px 2px rgba(0,0,0,.25);color:#fff}html[data-theme-mode=dark] .app-nav-link:hover{background:hsla(0,0%,100%,.16);border-color:hsla(0,0%,100%,.28);color:#fff}html[data-theme-mode=dark] .app-nav-link.active,html[data-theme-mode=dark] .app-nav-link[aria-current=page]{background:#34d399;border-color:transparent;box-shadow:0 0 0 2px rgba(0,0,0,.06);color:#fff!important}@supports not (color:color-mix(in oklab,white 10%,black)){html[data-theme-mode=dark] .app-nav-link.active,html[data-theme-mode=dark] .app-nav-link[aria-current=page]{background:#34d399;border-color:transparent;box-shadow:0 0 0 2px rgba(0,0,0,.06);color:#fff!important}}.app-menu-wrapper{position:relative}.app-user{justify-content:flex-end}@media (max-width:768px){.app-header-inner{flex-wrap:wrap;gap:.75em;padding:0 1.25em}.app-brand-link{font-size:1.25em}.app-nav{gap:.75em;margin-left:1em}.container{margin:20px auto;padding:1.25em}}@media (max-width:480px){.app-header-inner{padding:0 .75em}.app-nav{margin-left:.75em}.app-user{justify-content:space-between;margin-top:.5em;width:100%}.app-menu-dropdown{border-radius:12px!important;left:12px!important;min-width:auto!important;position:fixed!important;right:12px!important;top:64px!important}.app-menu-dropdown a{font-size:1.05em;padding:14px 16px!important}}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}canvas,iframe,img,video{height:auto;max-width:100%}.table td,.table th,code,kbd,pre,samp,td,th{overflow-wrap:anywhere;word-break:break-word}code,kbd,pre,samp{max-width:100%;white-space:pre-wrap}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto;width:100%}.app-menu-dropdown{background:#fff;background:var(--modal-bg);border:1px solid rgba(0,0,0,.06);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.18);color:#222;color:var(--text);max-height:calc(100vh - 80px);max-width:90vw;min-width:200px;overflow:hidden;overflow-y:auto;position:absolute;right:0;top:44px;z-index:1000}.app-menu-item{align-items:center;border-bottom:1px solid rgba(0,0,0,.06);color:#222;color:var(--text);display:flex;gap:10px;padding:10px 14px;text-decoration:none;transition:background-color .16s ease,color .16s ease}.app-menu-item:last-child{border-bottom:none}.app-menu-item:active,.app-menu-item:hover{background:rgba(0,0,0,.04);color:#2b6cb0;color:var(--accent)}.app-menu-item.active,.app-menu-item[aria-current=page]{background:#2b6cb0;background:var(--accent);color:#fff!important}.app-menu-item.active:visited,.app-menu-item[aria-current=page]:visited{color:#fff!important}@supports not (color:color-mix(in oklab,white 10%,black)){.app-menu-item.active,.app-menu-item[aria-current=page]{background:#2b6cb0;background:var(--accent);color:#fff!important}}html[data-theme-mode=dark] .app-menu-item.active,html[data-theme-mode=dark] .app-menu-item[aria-current=page]{background:#2b6cb0;background:var(--accent);color:#fff!important}@supports not (color:color-mix(in oklab,white 10%,black)){html[data-theme-mode=dark] .app-menu-item.active,html[data-theme-mode=dark] .app-menu-item[aria-current=page]{background:#2b6cb0;background:var(--accent);color:#fff!important}}.app-menu-item:focus-visible{background:rgba(0,0,0,.04);outline:2px solid #2b6cb0;outline:2px solid var(--accent);outline-offset:-2px}.app-menu-icon{color:currentColor;flex:0 0 auto;opacity:.95}html[data-theme-mode=dark] .app-menu-dropdown{border-color:hsla(0,0%,100%,.09)}html[data-theme-mode=dark] .app-menu-item{border-bottom-color:hsla(0,0%,100%,.08)}html[data-theme-mode=dark] .app-menu-item:active,html[data-theme-mode=dark] .app-menu-item:focus-visible,html[data-theme-mode=dark] .app-menu-item:hover{background:hsla(0,0%,100%,.06)}.data-table{table-layout:fixed}.table-sticky thead th{background:inherit;position:-webkit-sticky;position:sticky;top:0;z-index:1}.app-table{background:#fff;border-collapse:separate;border-spacing:0;font-size:1.05rem;margin:0 auto;width:100%}.app-table thead th{background:linear-gradient(90deg,#3498db,#2980b9);border-bottom:2px solid #2980b9;color:#fff;font-size:1rem;font-weight:600;padding:12px 16px;text-align:left;-webkit-user-select:none;user-select:none}.app-table tbody td{border-bottom:1px solid #e3e6f0;padding:18px 25px;vertical-align:top}.app-table tbody tr:nth-child(odd){background-color:#f9fbff}.app-table tbody tr:hover{background-color:#f1f7ff}.th-sortable{cursor:pointer}.th-sortable .sort-icon{margin-left:.5rem;opacity:.7}.table-actions{display:flex;flex-direction:column;gap:12px}.table-action-btn,.table-actions{align-items:center;justify-content:center}.table-action-btn{border:none;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.12);color:#fff;display:inline-flex;height:40px;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease;width:40px}.table-action-btn:focus-visible{outline:3px solid rgba(52,152,219,.35);outline-offset:2px}.table-action-btn:hover{box-shadow:0 4px 10px rgba(0,0,0,.15);transform:translateY(-1px)}.table-action-btn.view{background:#3498db}.table-action-btn.refresh{background:#6c757d}.table-action-btn.delete{background:#e74c3c}.table-action-btn.edit{background:#3498db}@media (max-width:576px){.data-table td,.data-table th,.notes-table td,.notes-table th{font-size:.95em;padding:10px 12px;word-break:break-word}.table-actions{flex-direction:row;gap:10px}}@media (max-width:430px){.data-table td,.data-table th,.notes-table td,.notes-table th{font-size:.9em;padding:8px 10px}}@media (max-width:440px){.data-table td,.data-table th,.notes-table td,.notes-table th{font-size:.9em;padding:8px 10px}}@media (max-width:480px){.container{margin:16px auto!important;padding:1em!important}}@media (max-width:360px){.goal-list,.task-list{grid-template-columns:1fr}}@media (max-width:576px){.table-mobile-cards{border-collapse:separate!important;border-spacing:0!important;min-width:auto!important}.table-mobile-cards thead{display:none!important}.table-mobile-cards tbody tr{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.06);display:block;margin-bottom:12px;overflow:hidden}.table-mobile-cards tbody tr td{align-items:flex-start;border-bottom:1px solid #edf2f7;display:flex;gap:8px;justify-content:space-between;padding:12px 14px!important;text-align:left!important;width:100%!important}.table-mobile-cards tbody tr td:last-child{border-bottom:none}.table-mobile-cards tbody tr td:before{color:#4a5568;content:attr(data-label);flex:0 0 40%;font-weight:600;margin-right:8px;max-width:50%;white-space:nowrap}.table-mobile-cards .action-btn,.table-mobile-cards .btn{width:auto}}.selftest-toolbar .form-control{min-width:0}@media (max-width:576px){.selftest-toolbar{align-items:stretch!important;flex-direction:column!important}.selftest-toolbar .btn{width:100%!important}.table-actions{flex-direction:column!important}}@media (min-width:576px){.table-actions{flex-direction:row!important}}@media (max-width:768px){.m_4081bf90,.m_8bffd616{flex-wrap:wrap!important;gap:.5rem!important}.m_4addd315{margin-left:0!important}}@media (max-width:576px){.m_4081bf90,.m_8bffd616{justify-content:center!important}.m_46b77525{width:90px!important}.m_326d024a,.mantine-Pagination-control{min-height:34px!important;min-width:34px!important;padding:.35rem .5rem!important}}@media (max-width:480px){body{font-size:.95rem}}@media (max-width:360px){body{font-size:.9rem}}.home-container{padding-top:1.5rem}.hero-section{background:linear-gradient(135deg,#e6f0ff,#fff);border:1px solid #e2e8f0;border-radius:14px;overflow:hidden;padding:2rem;position:relative;text-align:center}.hero-badge{background:#ebf8ff;border:1px solid #bee3f8;border-radius:999px;color:#2b6cb0;display:inline-block;font-size:.9rem;margin-bottom:.75rem;padding:6px 12px}.subtitle{font-size:1.05rem;margin-bottom:1rem;margin-top:.5rem}.metrics-row{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin:1rem 0 .5rem}.metric{background:#fff;border:1px solid #edf2f7;border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.04);min-width:110px;padding:10px 14px}.metric-value{color:#1a365d;display:block;font-size:1.1rem;font-weight:700}.metric-label{color:#4a5568;font-size:.9rem}.hero-buttons{display:flex;gap:12px;justify-content:center}.helper-text{color:#64748b;font-size:.9rem;margin-top:10px}.features-section{margin-top:2rem}.section-title{margin-bottom:.25rem}.section-subtitle{color:#4a5568;margin-bottom:1rem}.features-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.feature-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);padding:16px;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{box-shadow:0 6px 16px rgba(0,0,0,.08);transform:translateY(-3px)}.feature-icon{font-size:1.8rem}.how-it-works{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:2rem;padding:16px}.steps{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr)}.step{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px}.step-number{align-items:center;background:#2b6cb0;border-radius:50%;color:#fff;display:inline-flex;font-weight:700;height:32px;justify-content:center;margin-bottom:8px;width:32px}.popular-subjects-section{margin-top:2rem}.subjects-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr)}.subject-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);padding:16px}.center-text{text-align:center}.mt-1{margin-top:.5rem}.mt-3{margin-top:1.25rem}.inline-block{display:inline-block}.testimonials{margin-top:2rem}.testimonials-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr)}.testimonial{background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#334155;font-style:italic;padding:14px 16px}.testimonial footer{color:#64748b;font-style:normal;margin-top:8px}.quick-access-section{margin-top:2rem}.quick-links{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.quick-link-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:10px;padding:14px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.quick-link-card:hover{background:#f8fafc;box-shadow:0 6px 16px rgba(0,0,0,.08);transform:translateY(-2px)}.quick-link-icon{font-size:1.4rem}.cta-banner{background:linear-gradient(90deg,#2b6cb0,#3182ce);border-radius:14px;color:#fff;margin-top:2rem;padding:24px 20px;text-align:center}.cta-content h2{color:#fff;margin-bottom:.25rem}.cta-content p{color:#e6f0ff;margin-bottom:.75rem}@media (max-width:900px){.features-grid,.quick-links,.steps,.testimonials-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.features-grid,.quick-links,.steps,.subjects-grid,.testimonials-grid{grid-template-columns:1fr}.metrics-row{gap:8px}.metric{min-width:96px;padding:8px 10px}}.input,select.input,textarea.input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;outline:none;padding:.7em .9em;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease;width:100%}.input::placeholder,textarea.input::placeholder{color:#a0aec0}.input:focus,select.input:focus,textarea.input:focus{border-color:#90cdf4;box-shadow:0 0 0 4px rgba(66,153,225,.12)}.input.error,select.input.error,textarea.input.error{border-color:#f56565;box-shadow:0 0 0 4px hsla(0,88%,68%,.15)}.input.textarea,textarea.input{line-height:1.6;min-height:140px;resize:vertical}.formGroup{margin-bottom:1rem}.formGroup label{color:#4a5568;display:block;font-weight:500;margin-bottom:.5em}.hintRow .hint{color:#718096;font-size:.9em}.fieldError{color:#c53030;font-size:.9em;font-weight:500}.counter{color:#718096;font-size:.85em}.req{color:#e53e3e}.table{background:#fff;border-collapse:separate;border-spacing:0;width:100%}.table thead th{background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#334155;font-size:13px;font-weight:600;padding:10px 12px;text-align:left}.table tbody td{border-bottom:1px solid #f1f5f9;color:#0f172a;font-size:14px;padding:10px 12px}.table tbody tr:nth-child(2n){background:#fafbfc}.table tbody tr:hover{background:#f5f7fb}.mt-0{margin-top:0!important}.mt-1{margin-top:.25rem!important}.mt-2{margin-top:.5rem!important}.mt-3{margin-top:.75rem!important}.mt-4{margin-top:1rem!important}.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:.25rem!important}.mb-2{margin-bottom:.5rem!important}.mb-3{margin-bottom:.75rem!important}.mb-4{margin-bottom:1rem!important}.login-page{background:linear-gradient(160deg,#e6f0ff,#fff 40%,#e6fffb);display:grid;min-height:100vh;padding:32px 16px;place-items:center}.login-card{grid-gap:0;background:#fff;border:1px solid #e5e7eb;border-radius:20px;box-shadow:0 20px 60px rgba(31,94,180,.15);display:grid;gap:0;grid-template-columns:1fr 1fr;max-width:1100px;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease;width:100%}.login-card:hover{box-shadow:0 16px 36px rgba(15,23,42,.16);transform:translateY(-2px)}.login-card .form-card{background:#fff;border:1px solid #edf2f7;border-radius:12px}.login-left{background:linear-gradient(135deg,#e0f2fe,#dcfce7);display:flex;flex-direction:column;justify-content:flex-end;position:relative}.login-illustration{display:block;filter:saturate(1.05);height:100%;object-fit:cover;width:100%}.login-tagline{background:linear-gradient(180deg,transparent,rgba(0,0,0,.35));bottom:0;color:#fff;left:0;padding:24px 28px;position:absolute;right:0}.login-tagline h2{font-size:1.6rem;margin:0 0 6px}.login-tagline p{margin:0;opacity:.95}.login-right{display:flex;flex-direction:column;justify-content:center;padding:28px}.branding{margin-bottom:18px;text-align:center}.branding .logo{align-items:center;background:linear-gradient(145deg,#60a5fa,#22d3ee);border-radius:16px;box-shadow:0 6px 14px rgba(3,105,161,.25);color:#0f172a;display:inline-flex;height:64px;justify-content:center;width:64px}.logo-mark{font-size:28px}.branding .title{color:#0f172a;margin:12px 0 4px}.branding .tagline{color:#475569;margin:0}.login-card .form-card input{border-radius:12px;box-shadow:inset 0 1px 2px rgba(15,23,42,.05)}.login-card .form-card input:focus{border-color:#38bdf8;box-shadow:0 0 0 4px rgba(56,189,248,.18)}.field-error{align-items:center;color:#e11d48;display:flex;font-size:.92rem;gap:6px;margin-top:8px}.field-error .alert-icon{font-size:14px}.actions-right{align-items:center;display:flex;gap:12px}.forgot-link{color:#0369a1;font-weight:500}.forgot-link:hover{color:#075985;text-decoration:underline}.login-card .login-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#14b8a6);border:none;border-radius:9999px;box-shadow:0 8px 18px rgba(20,184,166,.28);color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:700;gap:10px;padding:12px 22px;transition:transform .18s ease,filter .18s ease,box-shadow .18s ease}.login-card .login-button:hover{box-shadow:0 10px 22px rgba(20,184,166,.35);filter:brightness(1.05);transform:translateY(-1px) scale(1.03)}.login-card .login-button:disabled{box-shadow:none;opacity:.8;transform:none}.spinner{animation:spin .8s linear infinite;border:2px solid hsla(0,0%,100%,.5);border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.shake{animation:shake .3s ease-in-out}@keyframes shake{10%,90%{transform:translateX(-1px)}20%,80%{transform:translateX(2px)}30%,50%,70%{transform:translateX(-4px)}40%,60%{transform:translateX(4px)}}.fade-in{animation:fadeIn .25s ease}@media (max-width:900px){.login-card{grid-template-columns:1fr}.login-left{height:220px}}@media (max-width:640px){.branding .logo{height:56px;width:56px}.actions-right{gap:8px}}.login-card .form-actions{align-items:center;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-top:1rem;width:100%}.login-card .remember{align-items:center;display:flex;gap:8px}.login-card .actions-right{align-items:center;display:flex;flex:1 1;gap:12px;justify-content:flex-end}.login-card .login-button{min-width:160px}@media (max-width:640px){.login-card .form-actions{align-items:stretch;flex-direction:column;gap:12px}.login-card .actions-right{justify-content:space-between}.login-card .login-button{min-width:0;width:100%}}.login-card .forgot-link{color:#0369a1;display:inline-block;font-weight:500;padding:2px;-webkit-text-decoration-color:rgba(3,105,161,.35);text-decoration-color:rgba(3,105,161,.35);-webkit-text-decoration-line:underline;text-decoration-line:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:color .2s ease-in-out,-webkit-text-decoration-color .2s ease-in-out;transition:color .2s ease-in-out,text-decoration-color .2s ease-in-out;transition:color .2s ease-in-out,text-decoration-color .2s ease-in-out,-webkit-text-decoration-color .2s ease-in-out}.login-card .forgot-link:hover{color:#0d4e8c;-webkit-text-decoration-color:currentColor;text-decoration-color:currentColor}.login-card .submit-row{display:flex;justify-content:flex-end;margin-top:.5rem}@media (max-width:640px){.login-card .submit-row{justify-content:stretch}.login-card .submit-row .login-button{min-width:0;width:100%}}.login-card .submit-row .btn.register-btn{min-width:0;width:100%}:root{--accent:#2b6cb0;--bg:#f6f8fb;--container-bg:#fff;--text:#222;--heading:#1a365d;--link:var(--accent);--link-hover:var(--accent);--font-size-scale:1.0;--header-start:var(--accent);--header-end:#1e4e8c;--pattern-image:none}body[data-theme-mode=dark],html[data-theme-mode=dark] body{color:#222;color:var(--text)}body{background:#f6f8fb!important;background:var(--bg)!important;background-image:none;background-image:var(--pattern-image);background-size:auto;color:#222!important;color:var(--text)!important;font-size:1rem;font-size:calc(1rem*var(--font-size-scale))}.container{background:#fff!important;background:var(--container-bg)!important}h1,h2,h3{color:#1a365d!important;color:var(--heading)!important}a{color:#2b6cb0!important;color:var(--link)!important}a:focus,a:hover{color:#2b6cb0!important;color:var(--link-hover)!important;outline:none}.btn{background:#2b6cb0!important;background:var(--accent)!important;border-color:transparent!important;color:#fff!important}.btn:focus-visible,.btn:hover{filter:brightness(.92);outline:2px solid color-mix(in srgb,#2b6cb0,#fff 20%);outline:2px solid color-mix(in srgb,var(--accent),#fff 20%);outline-offset:2px}.btn--ghost{background:transparent!important;border:1px solid color-mix(in srgb,#2b6cb0 35%,#0000)!important;border:1px solid color-mix(in srgb,var(--accent) 35%,#0000)!important;color:#2b6cb0!important;color:var(--accent)!important}.btn--ghost:focus-visible,.btn--ghost:hover{background:color-mix(in srgb,#2b6cb0 12%,#fff)!important;background:color-mix(in srgb,var(--accent) 12%,#fff)!important;color:color-mix(in srgb,#2b6cb0 85%,#0a0a0a)!important;color:color-mix(in srgb,var(--accent) 85%,#0a0a0a)!important;outline:2px solid color-mix(in srgb,#2b6cb0,#fff 25%);outline:2px solid color-mix(in srgb,var(--accent),#fff 25%);outline-offset:2px}.btn--success{background:#16a34a!important;border:1px solid #15803d!important;color:#fff!important}.btn--success:focus-visible,.btn--success:hover{background:#15803d!important;filter:none;outline:2px solid rgba(21,128,61,.35);outline-offset:2px}.btn--warning{background:#d97706!important;border:1px solid #b45309!important;color:#fff!important}.btn--warning:focus-visible,.btn--warning:hover{background:#b45309!important;filter:none;outline:2px solid rgba(180,83,9,.35);outline-offset:2px}.btn--danger,.btn.danger{background:#dc2626!important;border:1px solid #b91c1c!important;color:#fff!important}.btn--danger:focus-visible,.btn--danger:hover,.btn.danger:focus-visible,.btn.danger:hover{background:#b91c1c!important;filter:none;outline:2px solid rgba(185,28,28,.35);outline-offset:2px}.btn.secondary{background:#e2e8f0!important;color:#2d3748!important}html[data-theme-mode=dark] .btn--ghost{border-color:#475569!important;color:#cbd5e1!important}html[data-theme-mode=dark] .btn--ghost:focus-visible,html[data-theme-mode=dark] .btn--ghost:hover{background:hsla(0,0%,100%,.08)!important;color:#e2e8f0!important;outline:2px solid rgba(148,163,184,.35);outline-offset:2px}.btn--gradient-blue{background:linear-gradient(135deg,#2b6cb0,#1e4e8c)!important;background:linear-gradient(135deg,var(--accent),var(--header-end))!important;border:none!important;color:#fff!important}.btn--gradient-blue:hover{filter:brightness(.95)}.btn--icon{align-items:center!important;display:inline-flex!important;height:34px!important;justify-content:center!important;line-height:1!important;padding:0!important;width:34px!important}button,input,select,textarea{outline-color:color-mix(in srgb,#2b6cb0,#fff 20%);outline-color:color-mix(in srgb,var(--accent),#fff 20%)}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid color-mix(in srgb,#2b6cb0,#fff 20%);outline:2px solid color-mix(in srgb,var(--accent),#fff 20%);outline-offset:2px}html[data-theme-mode=dark] .code,html[data-theme-mode=dark] .practice-card,html[data-theme-mode=dark] code,html[data-theme-mode=dark] pre{background:#1f2937!important;border-color:#2d3748!important;color:#ededed!important}.header-gradient{background:linear-gradient(135deg,#2b6cb0,#1e4e8c);background:linear-gradient(135deg,var(--header-start),var(--header-end))}.app-header-inner{justify-content:flex-end;max-width:1100px;padding:0 16px}.app-brand-link{font-size:18px}.app-auth-links{align-items:center;display:flex;gap:1em}.app-auth-link{font-weight:500}.app-auth-btn,.app-auth-link{color:#fff;text-decoration:none}.app-auth-btn{background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.3);border-radius:6px;font-weight:600;padding:.4em 1em;transition:background .2s ease,border-color .2s ease,transform .15s ease}.app-auth-btn:focus-visible,.app-auth-btn:hover{background:hsla(0,0%,100%,.25);border-color:hsla(0,0%,100%,.45);outline:none;transform:translateY(-1px)}html[data-theme-mode=dark] .app-header{box-shadow:0 6px 18px rgba(0,0,0,.35)}html[data-theme-mode=dark]{color-scheme:dark}html[data-theme-mode=dark] input,html[data-theme-mode=dark] select,html[data-theme-mode=dark] textarea{background:#111827!important;border:1px solid #374151!important;color:#e5e7eb!important}html[data-theme-mode=dark] input::placeholder,html[data-theme-mode=dark] textarea::placeholder{color:#9ca3af!important}html[data-theme-mode=dark] .dropdown,html[data-theme-mode=dark] .menu,html[data-theme-mode=dark] [role=dialog]>div,html[data-theme-mode=dark] [role=menu]{background:#fff!important;background:var(--container-bg)!important;border-color:#1f2937!important;color:#222!important;color:var(--text)!important}html[data-theme-mode=dark] .btn.secondary{background:#374151!important;color:#e5e7eb!important}#accountMenu a{text-decoration:none!important}#accountMenu a,#accountMenu a:focus,#accountMenu a:hover,#accountMenu a:visited{color:inherit!important}.app-header{background:transparent;border-bottom:1px solid rgba(0,0,0,.06);box-shadow:none;color:#222;color:var(--text);margin-bottom:1.25em;padding:12px 0}.app-header-inner{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;width:90%}.app-brand-link{color:#fff;font-size:1.4em;font-weight:700;letter-spacing:.5px;text-decoration:none}.app-user-links{align-items:center;display:flex;gap:1em}.app-header .header-auth-link{background:transparent;border:1px solid rgba(0,0,0,.12);border-radius:8px;color:#222!important;color:var(--text)!important;font-weight:600;padding:.45em 1em;text-decoration:none;transition:background .2s ease,transform .15s ease,box-shadow .2s ease,border-color .2s ease}.app-header .header-auth-link:focus-visible,.app-header .header-auth-link:hover{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.18);outline:none;transform:translateY(-1px)}html[data-theme-mode=dark] .app-header .header-auth-link{border-color:hsla(0,0%,100%,.15)}html[data-theme-mode=dark] .app-header .header-auth-link:focus-visible,html[data-theme-mode=dark] .app-header .header-auth-link:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.25)}.app-header .header-auth-link.active,.app-header .header-auth-link[aria-current=page]{background:#34d399;border-color:#34d399;box-shadow:0 4px 10px rgba(255,204,0,.35);color:#1a1a1a!important}.app-header .app-brand-link{color:#222!important;color:var(--text)!important;font-weight:700;text-decoration:none}.app-header .app-brand-link:focus-visible,.app-header .app-brand-link:hover{color:#2b6cb0!important;color:var(--link)!important;outline:none}html[data-theme-mode=dark] .card,html[data-theme-mode=dark] .card-panel,html[data-theme-mode=dark] .panel,html[data-theme-mode=dark] .panel-card{background:#fff!important;background:var(--container-bg)!important;border-color:#2d3748!important;color:#222!important;color:var(--text)!important}html[data-theme-mode=dark] [style*="color: #000000"],html[data-theme-mode=dark] [style*="color: black"],html[data-theme-mode=dark] [style*="color:#000000"],html[data-theme-mode=dark] [style*="color:black"]{color:#222!important;color:var(--text)!important}:root{--modal-bg:#fff;--text-secondary:#4a5568}html[data-theme-mode=dark] [role=dialog]>div{background:#fff!important;background:var(--modal-bg)!important;box-shadow:0 16px 40px rgba(0,0,0,.6)!important;color:#222!important;color:var(--text)!important}html[data-theme-mode=dark] ::selection{background:rgba(59,130,246,.35);color:#fff}.view-btn:active,.view-btn:focus,.view-btn:visited{color:#fff!important}#root,body,html{background-color:#f6f8fb!important;background-color:var(--bg,#f6f8fb)!important;color:#222!important;color:var(--text,#222)!important}#root,.App{background-color:inherit!important;min-height:100vh}.app-header .header-auth-icon{align-items:center;border-radius:999px;display:inline-flex;height:36px;justify-content:center;padding:0;width:36px}.sr-only{clip:rect(0,0,0,0)!important;border:0!important;height:1px!important;margin:-1px!important;overflow:hidden!important;padding:0!important;position:absolute!important;white-space:nowrap!important;width:1px!important}.MuiButton-containedPrimary,.MuiButton-containedPrimary:active,.MuiButton-containedPrimary:focus,.MuiButton-containedPrimary:hover,a.btn,a.btn:active,a.btn:focus,a.btn:hover,a.btn:link,a.btn:visited,a[style*=background],a[style*=background]:active,a[style*=background]:focus,a[style*=background]:hover,a[style*=background]:link,a[style*=background]:visited{color:#fff!important}a.btn.secondary,a.btn.secondary:active,a.btn.secondary:focus,a.btn.secondary:hover,a.btn.secondary:link,a.btn.secondary:visited{color:#2d3748!important;color:var(--secondary-text,#2d3748)!important;text-decoration:none}.groups-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.groups-search{grid-gap:8px;align-items:center;display:grid;gap:8px;grid-template-columns:1fr 180px 180px auto;margin-top:12px}@media (max-width:900px){.groups-search{grid-template-columns:1fr 1fr}.groups-search>button{grid-column:1/-1;justify-self:start}}@media (max-width:600px){.groups-search{grid-template-columns:1fr}}.groups-error,.groups-loading{margin-top:16px}.groups-error{color:#c53030}.groups-list{grid-gap:12px;display:grid;gap:12px;margin-top:16px}.group-card{grid-gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:grid;gap:8px;padding:12px}.group-card-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.group-card-title .group-name{font-size:18px;font-weight:700}.group-related{color:#555;font-size:12px}.group-desc{color:#333}.group-card-actions{align-items:center;display:inline-flex;flex-wrap:wrap;gap:8px}.groups-search input,.groups-search select{min-height:36px}.question-meta{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:.75em}.difficulty-badge{align-items:center;background:#eef2ff;border:1px solid #e0e7ff;border-radius:9999px;color:#3730a3;display:inline-flex;font-size:12px;font-weight:600;gap:6px;letter-spacing:.2px;padding:4px 10px}.difficulty-badge.difficulty-easy{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.difficulty-badge.difficulty-medium{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.difficulty-badge.difficulty-hard{background:#fef2f2;border-color:#fecaca;color:#991b1b}.option-letter{align-items:center;background:#fff;border:2px solid #cbd5e0;border-radius:50%;color:#475569;display:inline-flex;font-weight:700;height:28px;justify-content:center;margin-right:12px;min-width:28px;width:28px}.option-item.selected .option-letter{background:#ebf8ff;border-color:#4299e1;color:#1e3a8a}.result-actions .goal-status-message,.result-actions .task-status-message{align-items:center;background:transparent;box-shadow:none;display:inline-flex;flex-direction:row;justify-content:center;margin:0;max-width:none;padding:0;width:auto}.result-actions .goal-status-message .btn,.result-actions .task-status-message .btn{margin:0}.result-actions .btn,.result-actions a.btn{align-items:center;display:inline-flex;justify-content:center}@media (min-width:900px){body.has-sidebar .app-header{margin-left:240px;margin-left:var(--sidebar-width,240px);width:calc(100% - 240px);width:calc(100% - var(--sidebar-width, 240px))}body.has-sidebar .app-header-inner{margin-left:0;margin-right:0;max-width:none;padding-left:16px;padding-right:16px;width:100%}}.app-user,.app-user-row{align-items:center;display:flex;gap:1rem}.app-user-row{margin-left:auto}.app-user .MuiAvatar-root,.app-user .MuiButtonBase-root,.app-user .MuiChip-root{align-items:center;display:inline-flex}.app-badge-wrapper{position:relative}.app-badge-btn{align-items:center;background:color-mix(in srgb,#fff 85%,#222 15%);background:color-mix(in srgb,var(--container-bg,#fff) 85%,var(--text,#111827) 15%);border:1px solid color-mix(in srgb,#222 12%,transparent);border:1px solid color-mix(in srgb,var(--text,#111827) 12%,transparent);border-radius:999px;color:inherit;cursor:pointer;display:inline-flex;gap:8px;justify-content:center;padding:6px 10px}.app-badge-btn:hover{background:rgba(0,0,0,.08);border-color:rgba(0,0,0,.18)}html[data-theme-mode=dark] .app-badge-btn{background:hsla(0,0%,100%,.06);border-color:hsla(0,0%,100%,.12)}html[data-theme-mode=dark] .app-badge-btn:hover{background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.2)}.app-badge-count{background:#e53e3e;border-radius:12px;color:#fff;font-size:.85em;font-weight:700;padding:2px 8px}.header-auth-link.header-auth-icon .app-badge-count{border-radius:999px;font-size:.72em;line-height:1.1;padding:1px 6px;vertical-align:middle}.app-badge-menu{background:#fff;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.15);color:#333;min-width:280px;overflow:hidden;position:absolute;right:0;top:44px;z-index:1000}html[data-theme-mode=dark] .app-badge-menu{background:#111827;box-shadow:0 12px 28px rgba(0,0,0,.5);color:#e5e7eb}.app-badge-menu-header{border-bottom:1px solid #eee;font-weight:600;padding:10px 12px}html[data-theme-mode=dark] .app-badge-menu-header{border-bottom-color:#1f2937}.app-badge-menu-body{max-height:320px;overflow-y:auto}.app-badge-item{border-bottom:1px solid #f3f3f3;position:relative}html[data-theme-mode=dark] .app-badge-item{border-bottom-color:#1f2937}.app-badge-item-link{color:#333;display:block;padding:10px 36px 10px 12px;text-decoration:none}.app-badge-item-link:hover{background:#fafafa}html[data-theme-mode=dark] .app-badge-item-link{color:#e5e7eb}html[data-theme-mode=dark] .app-badge-item-link:hover{background:#0b1220}.app-badge-item-close{background:transparent;border:none;border-radius:4px;color:#999;cursor:pointer;padding:6px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.app-badge-item-close:hover{background:rgba(0,0,0,.04)}html[data-theme-mode=dark] .app-badge-item-close:hover{background:hsla(0,0%,100%,.06)}.app-badge-menu-footer{background:#fafafa;padding:8px 12px;text-align:right}.app-badge-menu-footer-link{color:#2b6cb0;color:var(--link)}html[data-theme-mode=dark] .app-badge-menu-footer{background:#0b1220}.app-header-inner{gap:1rem}.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-body1,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-body2,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-subtitle1,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-subtitle2,.css-1h14y14-MuiContainer-root .MuiTypography-body1,.css-1h14y14-MuiContainer-root .MuiTypography-body2,.css-1h14y14-MuiContainer-root .MuiTypography-subtitle1,.css-1h14y14-MuiContainer-root .MuiTypography-subtitle2{font-size:.98em}.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-h1,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-h2,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-h3,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-h4,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-h5,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiTypography-h6,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters h1,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters h2,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters h3,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters h4,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters h5,.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters h6,.css-1h14y14-MuiContainer-root .MuiTypography-h1,.css-1h14y14-MuiContainer-root .MuiTypography-h2,.css-1h14y14-MuiContainer-root .MuiTypography-h3,.css-1h14y14-MuiContainer-root .MuiTypography-h4,.css-1h14y14-MuiContainer-root .MuiTypography-h5,.css-1h14y14-MuiContainer-root .MuiTypography-h6,.css-1h14y14-MuiContainer-root h1,.css-1h14y14-MuiContainer-root h2,.css-1h14y14-MuiContainer-root h3,.css-1h14y14-MuiContainer-root h4,.css-1h14y14-MuiContainer-root h5,.css-1h14y14-MuiContainer-root h6{font-size:1.6em}.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiButton-root,.css-1h14y14-MuiContainer-root .MuiButton-root{font-size:.98em}.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiChip-label,.css-1h14y14-MuiContainer-root .MuiChip-label{font-size:.96em}.MuiContainer-root.MuiContainer-maxWidthLg.MuiContainer-disableGutters .MuiInputBase-input,.css-1h14y14-MuiContainer-root .MuiInputBase-input{font-size:.98em}html[data-theme-mode=dark] .app-header{border-bottom-color:#1f2937;box-shadow:none}.app-header .app-user .MuiIconButton-root{color:inherit}.app-user .MuiAvatar-root{border:2px solid rgba(0,0,0,.18);border-radius:50%;box-shadow:0 1px 2px rgba(0,0,0,.08);height:32px;width:32px}html[data-theme-mode=dark] .app-user .MuiAvatar-root{border-color:hsla(0,0%,100%,.35);box-shadow:0 1px 2px rgba(0,0,0,.4)}.app-header+*>.MuiBox-root,.app-header+*>.MuiBox-root.css-1flsh13,.app-header+*>.MuiBox-root.css-i9gxme,.app-header+*>.MuiBox-root.css-k008qs,.app-header+.MuiBox-root,.app-header+.MuiBox-root.css-1flsh13,.app-header+.MuiBox-root.css-i9gxme,.app-header+.MuiBox-root.css-k008qs{margin-top:0!important;padding-top:0!important}.css-1qm1lh{font-weight:700!important;margin-bottom:24px!important;margin-left:14px!important}.css-9rblcb-MuiTypography-root{font-family:Inter,Roboto,Helvetica Neue,Arial,system-ui,-apple-system,Segoe UI,Apple Color Emoji,Segoe UI Emoji,sans-serif;font-size:1.5rem;font-weight:400;font-weight:700!important;line-height:1.334;margin:0;margin-top:0!important}header.app-header{background:#fff;border-bottom:1px solid #eee;justify-content:space-between;padding:6px 16px}header.app-header>div{align-items:center;display:flex}header.app-header .app-header-inner{-webkit-overflow-scrolling:touch;align-items:center;display:flex;gap:1rem;justify-content:flex-end;margin:0;max-width:none;overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain;padding:0;scrollbar-width:none;white-space:nowrap}header.app-header .app-header-inner::-webkit-scrollbar{display:none}html[data-theme-mode=dark] header.app-header{background:#0b0f17;border-bottom-color:#1f2937}header.app-header .app-header-search{flex:0 0 500px;max-width:100%}header.app-header .app-header-search .MuiFormControl-root,header.app-header .app-header-search .MuiTextField-root{max-width:none!important;width:100%!important}header.app-header .app-header-search .MuiInputBase-root{width:100%!important}.hashtag,.mention{color:#2b6cb0;color:var(--link);cursor:pointer;font-weight:600}@media (max-width:640px){header.app-header{padding:6px 10px}header.app-header .app-header-inner{gap:.5rem}header.app-header .app-header-search{flex:1 1 auto;min-width:0}.app-header .header-auth-link{padding:6px 8px}}@media (max-width:430px){header.app-header{flex-wrap:wrap}header.app-header .app-header-search{flex-basis:100%;margin:8px 0 0;order:2}.app-badge-menu{min-width:auto;right:8px;width:calc(100vw - 16px)}}@media (max-width:440px){header.app-header{flex-wrap:wrap}header.app-header .app-header-search{flex-basis:100%;margin:8px 0 0;order:2}.app-badge-menu{min-width:auto;right:8px;width:calc(100vw - 16px)}header.app-header .app-header-inner{gap:8px}header.app-header .app-header-inner .MuiIconButton-root,header.app-header .app-header-inner button.MuiIconButton-root{height:36px;width:36px}header.app-header .app-header-inner .MuiChip-root{display:none!important}}.app-header{background:#fff;background:var(--container-bg,#fff);padding-top:max(env(safe-area-inset-top,0px),12px);position:-webkit-sticky;position:sticky;top:0;z-index:1100}.sticky-header-offset{padding-top:64px}#number_ques .txt{background-color:#348dc1;border-radius:0 15px 0 0;color:#fff;font-size:16px;line-height:225%;margin-bottom:10px;padding-top:5px;text-align:center}#number_ques{font-size:24px;padding-bottom:10px;text-align:center}.question-index.active,.question-index.active.MuiButton-root{background-color:#ee7600!important;color:#fff!important}.point_ques{line-height:225%;position:relative}.point_ques,.point_ques span._top{color:#fff;font-size:16px;text-align:center}.point_ques span._top{background-color:#d55;border-radius:0 15px 0 0;display:block;height:37px;line-height:37px;margin-bottom:10px;padding-top:5px}.bg_btclass_report{align-items:center;background:#fff;border:1px dashed #d1d5db;border-radius:8px;color:#111827;cursor:pointer;display:flex;font-size:14px;gap:6px;line-height:1.3;margin-top:8px;padding:6px 8px;width:100%}.bg_btclass_report .icon-bt{align-items:center;display:inline-flex;justify-content:center}.bg_btclass_report:hover{background:#f9fafb;border-color:#cbd5e1}.box_switch_audio{border-top:2px solid #ffb400;display:table;padding-bottom:10px;text-align:center;width:100%}#v2-difficulty-label,.bg_btclass_right #number_ques .txt,.bg_btclass_right .point_ques ._top,.results-section .result-title{min-height:1.2em}.practice-v2 .result-card{background:#fff;border-radius:20px;box-shadow:0 8px 24px rgba(0,0,0,.08);font-family:Inter,sans-serif;margin:40px auto;max-width:1000px;overflow:visible;padding:48px 28px 28px;position:relative;text-align:center;width:100%}.practice-v2 .result-card:before{background:linear-gradient(135deg,#34d399,#facc15);border-top-left-radius:20px;border-top-right-radius:20px;content:"";height:96px;left:0;position:absolute;right:0;top:0;z-index:0}.practice-v2 .result-card .result-icon{align-items:center;background:linear-gradient(135deg,#34d399,#facc15);border-radius:50%;box-shadow:0 4px 12px rgba(0,0,0,.15);color:#fff;display:flex;font-size:42px;height:90px;justify-content:center;margin:-60px auto 16px;position:relative;width:90px;z-index:1}.practice-v2 .result-card h2{color:#111827;font-size:1.6rem;font-weight:700;line-height:1.25;margin:12px 0 6px}.practice-v2 .result-card .status{color:#059669;font-size:1rem;font-weight:500;line-height:1.3;margin-bottom:16px;margin-top:2px}.practice-v2 .result-card .score-circle{align-items:center;display:inline-flex;height:120px;justify-content:center;margin:12px 0 20px;position:relative;width:120px}.practice-v2 .result-card .score-circle .MuiCircularProgress-root{height:120px!important;width:120px!important}.practice-v2 .result-card .score-circle svg{height:120px;transform:rotate(-90deg);width:120px}.practice-v2 .result-card .score-circle.pass .MuiCircularProgress-circle{stroke:#16a34a!important}.practice-v2 .result-card .score-circle.fail .MuiCircularProgress-circle{stroke:#dc2626!important}.practice-v2 .result-card .score-value{align-items:center;color:#111827;display:flex;font-size:1.1rem;font-weight:800;inset:0;justify-content:center;letter-spacing:.3px;position:absolute}.practice-v2 .result-card .score-circle.pass .score-value,.practice-v2 .result-card .score-circle.pass+.score-value{color:#065f46}.practice-v2 .result-card .score-circle.fail .score-value,.practice-v2 .result-card .score-circle.fail+.score-value{color:#7f1d1d}.practice-v2 .result-card .actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:16px}.practice-v2 .result-card .actions a,.practice-v2 .result-card .actions button{align-items:center;border:1px solid transparent;border-radius:10px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:6px;padding:8px 16px;text-decoration:none;transition:all .2s ease}.practice-v2 .result-card .btn-primary{background-color:#2563eb;border:1px solid #2563eb;color:#fff}.practice-v2 .result-card .btn-primary:hover{background-color:#1d4ed8}.practice-v2 .result-card .btn-outlined{background:#fff;border:1px solid #059669;color:#059669}.practice-v2 .result-card .btn-outlined:hover{background:#f0fdf4}.practice-v2 .result-card .btn-text{background:transparent;color:#374151}.practice-v2 .result-card .btn-text:hover{background:#f3f4f6}.practice-v2-question-header{min-height:24px}.ques_index{background:#ee7600;border-radius:4px;color:#fff;font-family:Arial;font-size:18px;height:35px;line-height:35px;padding:0 10px;position:relative;width:88px}.div-image-option{margin-left:0!important}.image-option{align-items:center;border-radius:12px;display:inline-flex;justify-content:center;max-width:100%;overflow:hidden;text-align:center;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background-color .2s ease}.image-option img{display:block;height:auto;margin:0 auto;max-width:100%;object-fit:contain;width:auto}.image-option.selected{background-color:#fee2e2;box-shadow:0 6px 18px rgba(0,0,0,.12);outline:3px solid #fecaca;outline-offset:2px}.image-option:focus-visible{outline:3px solid #93c5fd;outline-offset:2px}.image-option:not([disabled]):hover{box-shadow:0 8px 20px rgba(0,0,0,.14);transform:translateY(-2px)}.image-option[data-correct=true]{border:3px solid #10b981}.image-option.selected[data-correct=false]{border:3px solid #ef4444}@supports (-webkit-touch-callout:none){.MuiButton-root.MuiButton-sizeSmall{-webkit-tap-highlight-color:rgba(0,0,0,0)}@media (max-width:480px){.MuiButton-root.MuiButton-sizeSmall{min-height:44px}.MuiButton-root.MuiButton-sizeSmall .MuiButton-startIcon{margin-right:6px}}}.blog-content{word-break:break-word}.blog-content canvas,.blog-content img,.blog-content svg,.blog-content video{height:auto;max-width:100%}.blog-content iframe{max-width:100%;width:100%}.blog-content code,.blog-content kbd,.blog-content pre,.blog-content samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.blog-content pre{background:hsla(0,0%,50%,.08);border-radius:8px;overflow:auto;padding:.75rem}.blog-content table{border-collapse:collapse;display:block;overflow-x:auto;width:100%}.blog-content table td,.blog-content table th{border-bottom:1px solid rgba(0,0,0,.08);padding:.5rem}header.app-header{align-items:center;display:flex;flex-wrap:wrap;overflow:visible}header.app-header .app-header-inner{flex:1 1 auto;min-width:0;width:auto}header.app-header .app-header-search{flex:1 1 420px}header.app-header .app-user-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px}@media (max-width:1024px){header.app-header .app-header-inner{justify-content:space-between;order:1;padding:0 16px;width:100%}header.app-header .app-header-search{flex-basis:100%;margin:8px 16px 0!important;max-width:calc(100% - 32px)!important;order:2}header.app-header .app-user-row{gap:8px}}@media (max-width:600px){header.app-header .app-header-inner{padding:0 12px}header.app-header .app-user-row{gap:6px}}.lesson-content{font-size:1rem;line-height:1.7}.lesson-content h1,.lesson-content h2,.lesson-content h3,.lesson-content h4,.lesson-content h5,.lesson-content h6{color:#1a365d;color:var(--heading);margin-bottom:.6em;margin-top:1.2em}.lesson-content p{margin:.6em 0}.lesson-content ol,.lesson-content ul{margin:.6em 0;padding-left:1.6em}.lesson-content li{margin:.25em 0}.lesson-content blockquote{background:#f7fafc;border-left:4px solid #cbd5e0;color:#2d3748;margin:1em 0;padding:.6em 1em}.lesson-content code,.lesson-content pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.lesson-content pre{background:#f7fafc;border-radius:8px;overflow:auto;padding:.75em 1em}.lesson-content .ql-indent-1{margin-left:3em}.lesson-content .ql-indent-2{margin-left:6em}.lesson-content .ql-indent-3{margin-left:9em}.lesson-content .ql-indent-4{margin-left:12em}.lesson-content .ql-indent-5{margin-left:15em}.lesson-content .ql-indent-6{margin-left:18em}.lesson-content .ql-indent-7{margin-left:21em}.lesson-content .ql-indent-8{margin-left:24em}.lesson-content .ql-indent-9{margin-left:27em}.lesson-content ul{list-style:disc inside}.lesson-content ol{list-style:decimal inside}.lesson-content .ql-align-center{text-align:center}.lesson-content .ql-align-right{text-align:right}.lesson-content .ql-align-justify{text-align:justify}.back-button{align-items:center;background-color:rgba(43,108,176,.1);border:1px solid #2b6cb0;border-radius:4px;box-shadow:0 1px 3px rgba(0,0,0,.1);color:#2b6cb0;cursor:pointer;display:inline-flex;font-size:.9em;font-weight:500;justify-content:center;margin-bottom:1em;padding:.5em 1em;transition:all .2s}.back-button:hover{background-color:rgba(43,108,176,.2);box-shadow:0 2px 4px rgba(0,0,0,.15)}@media (max-width:768px){.back-button{font-size:.85em;padding:.4em .8em}}@media (max-width:480px){.back-button{font-size:.8em;padding:.3em .7em}}.modal{align-items:center;display:flex;justify-content:center;outline:0;overflow:auto;z-index:2000}.modal,.modal-backdrop{height:100%;left:0;position:fixed;top:0;width:100%}.modal-backdrop{background-color:rgba(0,0,0,.5);z-index:1999}.modal-dialog-popup{display:flex;flex-direction:column;margin:1.75rem auto;max-height:95vh;max-width:1000px;transform:translate(0)!important}.modal-content{border:none!important;border-radius:12px!important;box-shadow:0 .5rem 1.5rem rgba(0,0,0,.5)!important;display:flex;flex:1 1;flex-direction:column;overflow:hidden;padding:0;width:100%}.modal-body{background-color:#f8f9fc;flex:1 1;max-height:80vh;overflow-y:auto;padding:1.5rem!important}.modal-body,.modal-body form{display:flex;flex-direction:column}.modal-body form{flex:1 1}.modal-body .form-control{border:1px solid #d1d3e2!important;border-radius:8px!important;box-shadow:0 2px 4px rgba(0,0,0,.05)!important;display:block;font-size:1rem!important;padding:.75rem 1rem!important;position:relative;transition:all .2s ease!important;width:100%;z-index:1}.modal-body .form-control:focus{border-color:#4e73df!important;box-shadow:0 0 0 .2rem rgba(78,115,223,.25)!important;outline:0!important}.modal-body textarea.form-control{box-sizing:border-box!important;display:block!important;margin-bottom:15px!important;min-height:100px;overflow:auto;position:relative!important;resize:vertical;width:100%!important;z-index:5!important}.modal-open{overflow:hidden}.modal-header .btn-close{color:#000!important;filter:none!important;font-size:1.2rem!important;font-weight:700!important;margin:0!important;opacity:.8!important;padding:.5rem!important;position:absolute!important;right:15px!important;top:15px!important;z-index:10!important}.modal-header .btn-close:hover{color:#000!important;opacity:1!important}.modal.fade .modal-dialog{transform:translateY(-50px);transition:transform .3s ease-out}.modal.show .modal-dialog{transform:none!important}.text-truncate img{display:block;height:auto;margin:5px 0;max-height:150px;max-width:100%;object-fit:contain}.high-quality-image-container{align-items:center;display:flex;flex-direction:column;justify-content:center;width:100%}.high-quality-image{-webkit-backface-visibility:hidden;backface-visibility:hidden;height:auto;max-width:100%;transform:translateZ(0);transition:transform .3s ease}.modal-dialog-popup.modal-fullscreen-lg-down{margin:1rem auto;max-width:90vw}@media (max-width:992px){.modal-dialog-popup.modal-fullscreen-lg-down{height:100%;margin:0;max-width:100%}}.image-viewer-modal .modal-content{background-color:#f8f9fc}.image-viewer-modal .modal-body{align-items:center;display:flex;justify-content:center;min-height:50vh;padding:1rem}.mantine-Modal-header{align-items:center;border-bottom:none;display:flex;justify-content:space-between;padding:1rem}.mantine-Modal-title{color:#fff;font-size:1.2rem;font-weight:600;margin:0}.mantine-Modal-close{align-items:center;background:transparent;border:none;cursor:pointer;display:flex;justify-content:center;padding:0}.mantine-CloseButton-root{border-radius:4px;height:25px;padding:0;transition:background-color .2s ease;width:25px}.mantine-CloseButton-root:hover{background-color:rgba(0,0,0,.1)}.ML__keyboard,.ML__popover,.ML__virtual-keyboard{z-index:5000!important}.modal-dialog-popup.keyboard-shift,.modal.show .modal-dialog.modal-dialog-popup.keyboard-shift{transform:translateY(calc(min(0px, 60vh)*-1))!important;transform:translateY(calc(min(var(--keyboard-height, 0px), 60vh)*-1))!important}.modal-custom .modal-body.keyboard-padding{padding-bottom:16px!important;padding-bottom:calc(var(--keyboard-height, 0px) + 16px)!important}.virtual-keyboard-host{background:#fff;border-radius:8px;border-top:1px solid #e5e7eb;bottom:0;display:none;margin-top:12px;overflow:hidden;position:-webkit-sticky;position:sticky;z-index:2}.modal-custom .ML__virtual-keyboard.inline-inside-modal{bottom:auto!important;box-shadow:none!important;left:auto!important;max-width:100%!important;position:static!important;right:auto!important;width:100%!important;z-index:auto!important}.modal-custom .modal-body h6{color:#1f3b73;font-weight:700;margin-bottom:.5rem;position:relative}.modal-custom .modal-body h6:after{background:linear-gradient(90deg,#3498db,#8e44ad);border-radius:2px;content:"";display:block;height:3px;margin-top:6px;width:40px}.modal-custom .modal-body>.mb-3:not(.alert){background:#fff;border:1px solid #e9eef7;border-radius:12px;box-shadow:0 4px 10px rgba(31,59,115,.06);padding:14px 16px}.modal-custom .modal-body>.mb-3:not(.alert)+.mb-3:not(.alert){margin-top:1rem}.modal-custom .modal-body p{color:#2d3748;margin:.25rem 0 .75rem}.modal-custom .modal-body img{border:1px solid #e6ebf4;border-radius:10px;box-shadow:0 6px 16px rgba(31,59,115,.08);transition:transform .2s ease,box-shadow .2s ease}.modal-custom .modal-body a img:hover{box-shadow:0 10px 22px rgba(31,59,115,.15);transform:translateY(-2px) scale(1.02)}.modal-custom .list-group{background:transparent;border:none}.modal-custom .list-group-item{background:#fbfdff!important;border:1px solid #e9eef7!important;border-left:4px solid #cbd5e1!important;border-radius:10px!important;color:#1f2937!important;margin-bottom:10px!important;padding:10px 12px!important}.modal-custom .list-group-item-success{background:#f0fdf4!important;border-left-color:#22c55e!important}.modal-custom .list-group-item-warning{background:#fffbeb!important;border-left-color:#f59e0b!important}.modal-custom .list-group-item-info{background:#eff6ff!important;border-left-color:#3b82f6!important}.modal-custom .list-group-item-info:before,.modal-custom .list-group-item-success:before,.modal-custom .list-group-item-warning:before{display:inline-block;font-weight:600;margin-right:8px}.modal-custom .list-group-item-success:before{color:#16a34a;content:"✓"}.modal-custom .list-group-item-warning:before{color:#d97706;content:"⚠"}.modal-custom .list-group-item-info:before{color:#2563eb;content:"ℹ"}.modal-custom .display-4{color:#0f172a;font-size:2.75rem;font-weight:800;letter-spacing:-.02em}.modal-custom .progress{background-color:#e6ebf4;border-radius:999px;height:8px;overflow:hidden}.modal-custom .progress-bar{background:linear-gradient(90deg,#22c55e,#16a34a)}.modal-custom .modal-body::-webkit-scrollbar{width:10px}.modal-custom .modal-body::-webkit-scrollbar-track{background:#eef2f7;border-radius:8px}.modal-custom .modal-body::-webkit-scrollbar-thumb{background:#c7d2fe;border-radius:8px}.modal-custom .modal-body::-webkit-scrollbar-thumb:hover{background:#a5b4fc}.modal-custom .styled-dash-list{list-style:none;margin:6px 0 0;padding-left:0}.modal-custom .styled-dash-list li{grid-column-gap:8px;align-items:start;column-gap:8px;display:grid;grid-template-columns:14px 1fr}.modal-custom .styled-dash-list li+li{margin-top:6px}.modal-custom .styled-dash-list li:before{color:#374151;content:"–";display:inline-block;line-height:1.3;text-align:center;width:14px}

/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{height:1px;left:-100000px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{word-wrap:break-word;box-sizing:border-box;height:100%;line-height:1.42;outline:none;overflow-y:auto;padding:12px 15px;-o-tab-size:4;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap}.ql-editor>*{cursor:text}.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor ol,.ql-editor p,.ql-editor pre,.ql-editor ul{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;margin:0;padding:0}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"\2022"}.ql-editor ul[data-checked=false],.ql-editor ul[data-checked=true]{pointer-events:none}.ql-editor ul[data-checked=false]>li *,.ql-editor ul[data-checked=true]>li *{pointer-events:all}.ql-editor ul[data-checked=false]>li:before,.ql-editor ul[data-checked=true]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"\2611"}.ql-editor ul[data-checked=false]>li:before{content:"\2610"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-increment:list-0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:rgba(0,0,0,.6);content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow .ql-toolbar:after,.ql-snow.ql-toolbar:after{clear:both;content:"";display:table}.ql-snow .ql-toolbar button,.ql-snow.ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow .ql-toolbar button svg,.ql-snow.ql-toolbar button svg{float:left;height:100%}.ql-snow .ql-toolbar button:active:hover,.ql-snow.ql-toolbar button:active:hover{outline:none}.ql-snow .ql-toolbar input.ql-image[type=file],.ql-snow.ql-toolbar input.ql-image[type=file]{display:none}.ql-snow .ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar button.ql-active,.ql-snow .ql-toolbar button:focus,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar button.ql-active,.ql-snow.ql-toolbar button:focus,.ql-snow.ql-toolbar button:hover{color:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill{fill:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow .ql-toolbar button:hover:not(.ql-active),.ql-snow.ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-stroke.ql-thin,.ql-snow .ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{margin-bottom:5px;margin-top:5px;padding:5px 10px;white-space:pre-wrap}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;padding:2px 4px;width:24px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{margin-top:-9px;position:absolute;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-item:before,.ql-snow .ql-picker.ql-header .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-item:before,.ql-snow .ql-picker.ql-font .ql-picker-label:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-item:before,.ql-snow .ql-picker.ql-size .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:0 2px 8px rgba(0,0,0,.2)}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;display:none;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.register-page{background:linear-gradient(180deg,#f0f7ff,#f8fffb);display:grid;min-height:100vh;padding:24px;place-items:center}.register-card{grid-gap:0;background:#fff;border-radius:20px;box-shadow:0 20px 60px rgba(31,94,180,.15);display:grid;gap:0;grid-template-columns:1fr 1fr;max-width:1100px;overflow:hidden;width:100%}.register-left{background:linear-gradient(135deg,#e0f2fe,#dcfce7);display:flex;flex-direction:column;justify-content:flex-end;position:relative}.register-illustration{display:block;filter:saturate(1.05);height:100%;object-fit:cover;width:100%}.register-tagline{background:linear-gradient(180deg,transparent,rgba(0,0,0,.35));bottom:0;color:#fff;left:0;padding:24px 28px;position:absolute;right:0}.register-tagline h2{font-size:1.6rem;margin:0 0 6px}.register-tagline p{margin:0;opacity:.95}.register-right{display:flex;flex-direction:column;justify-content:center;padding:28px}.header-section h1{margin:0 0 4px}.subtitle{color:#4a5568;margin:0 0 14px}.register-form .form-group{margin-bottom:14px}.form-group.with-icon .input-icon-wrap{position:relative}.input-icon-wrap.legacy svg{color:#6b7280;height:18px;left:12px;position:absolute;top:50%;transform:translateY(-50%);width:18px}.input-icon-wrap.legacy input{padding-left:40px}.input-icon-wrap.legacy.password input{padding-right:44px}.toggle-visibility{align-items:center;background:transparent;border:none;border-radius:6px;color:#718096;cursor:pointer;display:inline-flex;height:34px;justify-content:center;margin-top:-6px;position:absolute;right:10px;top:50%;transform:translateY(-50%);width:34px}.toggle-visibility:hover{background:#edf2f7;color:#2d3748}.toggle-visibility:focus-visible{outline:3px solid rgba(66,153,225,.35);outline-offset:2px}.pwd-strength{align-items:center;display:flex;gap:8px;margin-top:8px}.pwd-strength .bar{background:#e5e7eb;border-radius:9999px;box-shadow:inset 0 1px 2px rgba(0,0,0,.06);height:8px;width:120px}.label-inline{align-items:center;display:flex;gap:8px}.tooltip-btn{align-items:center;background:#e2f0ff;border:none;border-radius:9999px;color:#1d4ed8;cursor:pointer;display:inline-flex;font-weight:700;height:22px;justify-content:center;width:22px}.tooltip{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;font-size:.95rem;margin:6px 0 8px;padding:8px 10px}.field-error{color:#c53030;font-size:.9rem;margin-top:6px}.has-error input,.has-error select,.has-error textarea{border-color:#feb2b2;box-shadow:0 0 0 4px hsla(0,97%,85%,.2)}.form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.form-actions.stack{display:flex;flex-direction:column;gap:12px;margin-top:12px}.btn.register-btn{background:linear-gradient(135deg,#22c55e,#3b82f6);border:none;border-radius:14px;box-shadow:0 10px 20px rgba(56,189,248,.25);color:#fff;font-size:16px;font-weight:700;padding:14px 22px}.btn.register-btn:hover{box-shadow:0 14px 28px rgba(56,189,248,.35);transform:translateY(-1px)}.btn.register-btn:disabled{background:linear-gradient(135deg,#86efac,#93c5fd);box-shadow:none}.or-divider{align-items:center;color:#64748b;display:flex;gap:8px;justify-content:center}.or-divider:after,.or-divider:before{background:#e5e7eb;content:"";flex:1 1;height:1px}.social-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr}.social-btn{align-items:center;border:1px solid transparent;border-radius:12px;cursor:pointer;display:inline-flex;font-weight:600;gap:10px;justify-content:center;padding:12px 16px;width:100%}.social-btn.google{background:#fff;border-color:#e5e7eb}.social-btn.facebook{background:#1877f2;color:#fff}.social-btn:hover{filter:brightness(1.02)}.info-message.friendly{background:#ecfeff;border:1px solid #a5f3fc;border-radius:10px;color:#0e7490;margin-bottom:12px;padding:12px 14px}.login-link{margin-top:8px;text-align:center}.login-link a{font-weight:600}@media (max-width:900px){.register-card{grid-template-columns:1fr}.register-left{height:220px}}.adminCreate.container{margin:24px auto;max-width:1440px;padding:0 16px}.adminCreate .card .card{background:#fafafa;border:1px solid #e5e7eb;border-radius:10px;box-shadow:none;padding:16px}.adminCreate .card .card .formGroup+.formGroup{margin-top:10px}.adminCreate .card .card>.btn.danger{float:right;margin-top:8px}.adminCreate .card .card:after{clear:both;content:"";display:block}.adminCreate .card .card .hintRow{margin-top:8px}.adminCreate .card .card .formGrid{gap:12px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.adminCreate .card>h3+.hint,.adminCreate .card>p.hint{margin-bottom:8px;margin-top:4px}.adminCreate .card>.btn{margin-top:4px}.adminCreate .examples-editor{margin-top:0}.adminCreate .examples-editor .card+.card{margin-top:8px}.pageHeader h1{font-size:24px;margin:0}.pageHeader .subtitle{color:#6b7280;margin:6px 0 16px}.card{background:#fff;border:1px solid #eef2f7;border-radius:12px;box-shadow:0 10px 20px rgba(0,0,0,.06);padding:20px}.card:hover{box-shadow:0 12px 24px rgba(0,0,0,.08)}.formGrid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.formGroup{display:flex;flex-direction:column}.formGroup.full{grid-column:1/-1}label{color:#111827;font-weight:600;margin-bottom:6px}.req{color:#ef4444}.input{background:#fff;border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;height:38px;max-width:100%;outline:none;padding:8px 10px;transition:border-color .15s,box-shadow .15s,background .15s;width:100%}.input:hover{border-color:#9ca3af}.input:focus{border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.15)}.input.error{background:#fff7f7;border-color:#ef4444}.input.textarea{box-sizing:border-box;height:auto;max-width:100%;resize:vertical;width:100%}.input.file{height:auto;padding:6px 8px}.adminCreate select.input{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:16px;color:#111827;font-size:16px;height:auto;line-height:1.45;min-height:38px;padding:8px 36px 8px 10px}.adminCreate select.input option{color:#111827}.adminCreate select.input option[disabled],.adminCreate select.input option[value=""]{color:#9ca3af}.adminCreate select.input:disabled{background-color:#f9fafb;color:#6b7280}.hintRow{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-top:6px}.fieldError{color:#b91c1c;font-size:12px}.counter,.hint{color:#6b7280;font-size:12px}.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.adminCreate .btn{border:1px solid transparent;border-radius:8px;cursor:pointer;font-weight:600;padding:10px 14px;transition:transform .05s ease,box-shadow .2s ease,background .2s ease,color .2s ease}.adminCreate .btn:disabled{cursor:not-allowed;opacity:.6}.adminCreate .btn.primary{background:#4f46e5;box-shadow:0 6px 14px rgba(79,70,229,.25);color:#fff}.adminCreate .btn.primary:hover:not(:disabled){background:#4338ca}.adminCreate .btn.secondary{background:#10b981;box-shadow:0 6px 14px rgba(16,185,129,.25);color:#fff}.adminCreate .btn.secondary:hover:not(:disabled){background:#059669}.adminCreate .btn.danger{background:#ef4444;box-shadow:0 6px 14px rgba(239,68,68,.25);color:#fff}.adminCreate .btn.danger:hover:not(:disabled){background:#dc2626}.adminCreate .btn.ghost{background:transparent;border-color:#d1d5db;color:#111827}.adminCreate .btn.ghost:hover{background:#f3f4f6}.alert{border:1px solid;border-radius:10px;font-size:14px;margin-bottom:12px;padding:10px 12px}.alert.success{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.alert.danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.alert.info{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.note{color:#6b7280;font-size:12px;margin-top:8px}.adminCreate .table thead th{background:#f9fafb;position:-webkit-sticky;position:sticky;top:0;z-index:1}.adminCreate .table tbody tr:hover{background:#fafafa}.adminCreate .table tbody tr td{vertical-align:top}.adminCreate .listToolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:12px}.adminCreate .actionsGroup,.adminCreate .filtersGroup{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.adminCreate .actionsGroup>div{align-items:center;display:flex;gap:8px}.adminCreate .actionsGroup>div:not(.searchBox){white-space:nowrap}.adminCreate .actionsGroup .btn,.adminCreate .actionsGroup .input,.adminCreate .actionsGroup select,.adminCreate .filtersGroup .btn,.adminCreate .filtersGroup .input,.adminCreate .filtersGroup select{min-height:38px}.adminCreate .searchBox{position:relative}.adminCreate .searchBox .input{box-sizing:border-box;min-width:160px;padding-right:44px;width:100%}.adminCreate .searchBox .clearBtn{align-items:center;background:transparent;border:none;border-radius:6px;bottom:6px;color:#6b7280;display:inline-flex;font-size:18px;justify-content:center;line-height:1;min-width:28px;padding:0;pointer-events:auto;position:absolute;right:6px;top:6px;width:28px;z-index:2}.adminCreate .searchBox .clearBtn:hover{background:#f3f4f6}.adminCreate .listToolbar>.searchBox{flex:1 1 100%}.adminCreate .listToolbar>.searchBox .input{min-width:160px;width:100%}.adminCreate .listToolbar>.searchBox .searchInputWrap{width:100%}.adminCreate .btn{line-height:1}@media (max-width:768px){.formGrid{grid-template-columns:1fr}.adminCreate .listToolbar{gap:10px}.adminCreate .searchBox{flex:1 1 100%}.adminCreate .searchBox .input{min-width:0;width:100%}.adminCreate .listToolbar>.searchBox .searchInputWrap{max-width:none}}.adminCreate .searchInputWrap{position:relative}.adminCreate .option-input-row{align-items:center;display:flex;gap:8px;margin-bottom:8px}.adminCreate .option-add-btn{align-items:center;display:inline-flex;height:38px;justify-content:center;line-height:1;margin-top:0;min-width:38px;padding:0;width:38px}.adminCreate .option-add-btn svg{height:16px;width:16px}.adminCreate .option-add-btn:disabled{cursor:not-allowed;opacity:.6}.adminCreate .inline-control-btn{align-items:center;display:inline-flex;justify-content:center;line-height:1;padding:0 12px}.adminCreate .inline-control-btn,.adminCreate .inline-control-select{height:38px;margin-top:0;min-height:38px}.adminCreate .searchBox>label{font-weight:400}.adminCreate .card .formGrid>.formGroup,.adminCreate .formGrid>.formGroup{min-width:0}.adminCreate .input.textarea{word-break:break-word}.adminCreate .inline-control-right{align-items:center;display:inline-flex;flex-wrap:wrap;gap:12px;margin-left:auto;margin-top:0}.adminCreate .quill{display:block;margin-bottom:12px;position:relative}.adminCreate .quill .ql-toolbar{min-height:42px}.adminCreate .quill[style] .ql-container{height:calc(100% - 42px)!important;overflow:auto}.adminCreate .quill:not([style]) .ql-container{height:auto!important;overflow:visible}.adminCreate .quill .ql-editor{overflow-wrap:anywhere;white-space:normal;word-break:break-word}.adminCreate .formGroup{overflow:visible}.adminCreate .examples-editor .card{display:block}.adminCreate .examples-editor .card+.card{margin-top:12px}.admin-controls{align-items:center}.admin-controls .admin-create-btn{align-self:center;height:40px;line-height:1;margin-top:0;padding:0 14px}.tableWrap{overflow-x:auto}.usersTable{background:#fff;border-collapse:separate;border-spacing:0;width:100%}.usersTable thead th{background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#334155;font-size:13px;font-weight:600;padding:10px 12px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:1}.usersTable tbody td{border-bottom:1px solid #f1f5f9;color:#0f172a;font-size:14px;padding:10px 12px}.usersTable tbody tr:hover{background:#f9fafb}.usersTable .mono{color:#334155;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px}.actionsCell{white-space:nowrap}.actionsCell .actions{align-items:center;display:inline-flex;flex-wrap:wrap;gap:8px}.actionsCell .btn{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#0f172a;cursor:pointer;font-size:13px;height:30px;line-height:1;padding:0 10px;transition:background .12s ease,box-shadow .12s ease,transform 80ms ease}.actionsCell .btn:hover{background:#eef2ff}.actionsCell .btn:active{transform:translateY(1px)}.actionsCell .btn--primary{background:#2563eb;border-color:#2563eb;color:#fff}.actionsCell .btn--primary:hover{filter:brightness(1.05)}.actionsCell .btn--success{background:#16a34a;border-color:#16a34a;color:#fff}.actionsCell .btn--warning{background:#d97706;border-color:#d97706;color:#fff}.actionsCell .btn--danger{background:#ef4444;border-color:#ef4444;color:#fff}.actionsCell .btn--ghost{background:#fff;border-color:#e5e7eb;color:#0f172a}@media (max-width:768px){.usersTable tbody td,.usersTable thead th{font-size:13px;padding:8px 10px}.admin-controls{gap:10px}.admin-controls .searchWrap{flex:1 1 100%;min-width:0}.admin-controls select{flex:1 1 160px;min-width:0;width:100%}.admin-controls .admin-create-btn{justify-content:center;margin-left:0!important;width:100%}.admin-bottom-controls{flex-wrap:wrap!important;gap:10px!important}.admin-bottom-controls>div:first-child{display:flex;flex-wrap:wrap;gap:8px;width:100%}.admin-bottom-controls .mantine-Pagination-root{flex-wrap:wrap;margin-left:0!important}.admin-bottom-controls>.m_4081bf90{justify-content:center!important;width:100%}.twoCol{grid-template-columns:1fr!important}}.searchWrap{flex:1 1;min-width:220px;position:relative}.searchWrap .searchInput{background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;outline:none;padding:10px 36px 10px 12px;width:100%}.searchWrap .searchInput:focus{border-color:#94a3b8;box-shadow:0 0 0 3px rgba(59,130,246,.15)}.searchWrap .clearBtn{align-items:center;background:transparent;border:none;border-radius:999px;color:#6b7280;cursor:pointer;display:inline-flex;height:24px;justify-content:center;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px}.searchWrap .clearBtn:hover{background:#f3f4f6}.feedbackCell{max-width:420px}.feedbackMessage{max-height:120px;overflow:auto;padding-right:4px;white-space:pre-wrap;word-break:break-word}@media (max-width:768px){.feedbackCell{max-width:240px}.feedbackMessage{max-height:100px}}.tsm-overlay{align-items:center;animation:fadeIn .18s ease;background:rgba(0,0,0,.55);display:flex;inset:0;justify-content:center;padding:12px;position:fixed;z-index:2000}.tsm-modal{background:#fff;background:var(--modal-bg,#fff);border-radius:12px;box-shadow:0 20px 50px rgba(0,0,0,.45);color:#111;color:var(--text,#111);font-size:14px;max-height:90vh;overflow-y:auto;padding:20px;position:relative;width:min(980px,100%)}.tsm-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.tsm-title{font-size:18px;font-weight:700;margin:0}.tsm-icon-btn{background:transparent;border:none;color:inherit;cursor:pointer;font-size:24px;line-height:1}.tsm-first-time{background:hsla(0,0%,100%,.1);border-radius:8px;margin-bottom:12px;padding:12px}.tsm-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.tsm-section{margin-bottom:14px}.tsm-section-title{font-weight:700;margin:10px 0 8px}.tsm-fun-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.tsm-preset-card{background:hsla(0,0%,100%,.85);border:1px solid #e2e8f0;border-radius:10px;color:#111;color:var(--text,#111);cursor:pointer;display:flex;flex-direction:column;padding:10px;text-align:left}.tsm-preset-card.active{outline:2px solid #3b82f6;outline:2px solid var(--accent,#3b82f6)}.tsm-preset-name{font-weight:600;margin-bottom:6px}.tsm-preset-preview{align-items:center;border-radius:8px;display:flex;gap:8px;height:40px;justify-content:center;overflow:hidden;position:relative}.tsm-star{font-size:16px}.tsm-ball{border-radius:50%;height:14px;width:14px}.tsm-segmented{background:rgba(148,163,184,.25);border-radius:10px;display:flex;gap:4px;margin-bottom:10px;padding:4px}.tsm-segment-btn{background:transparent;border:none;border-radius:8px;color:#111;color:var(--text,#111);cursor:pointer;flex:1 1;font:inherit;padding:8px 10px}.tsm-segment-btn.active{background:hsla(0,0%,100%,.8);box-shadow:0 2px 6px rgba(0,0,0,.12)}.tsm-segment-btn.active,.tsm-segment-btn.active-dark{border:2px solid #3b82f6;border:2px solid var(--accent,#3b82f6);font-weight:600}.tsm-segment-btn.active-dark{background:#374151;box-shadow:0 2px 6px rgba(0,0,0,.2);color:#e5e7eb}.tsm-swatches{display:flex;flex-wrap:wrap;gap:10px}.tsm-swatch-btn{align-items:center;background:hsla(0,0%,100%,.85);border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;height:34px;justify-content:center;width:34px}.tsm-swatch-btn.active{background:hsla(0,0%,100%,.95);border-color:#3b82f6;border-color:var(--accent,#3b82f6);outline:2px solid #3b82f6;outline:2px solid var(--accent,#3b82f6)}.tsm-background-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.tsm-bg-thumb{background:rgba(148,163,184,.15);border:1px solid #e2e8f0;border-radius:8px;color:#111;color:var(--text,#111);cursor:pointer;font:inherit;padding:10px;text-align:center}.tsm-bg-thumb.active{outline:2px solid #3b82f6;outline:2px solid var(--accent,#3b82f6)}.tsm-upload-col,.tsm-upload-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.tsm-small-link{font-size:12px;margin-top:6px}.tsm-uploading{color:#555;font-size:12px}.tsm-error{color:#dc2626;font-size:12px;margin-top:6px}.tsm-preview{background:rgba(148,163,184,.12);border:1px solid #e2e8f0;transition:all .2s ease}.tsm-preview,.tsm-preview-header{border-radius:10px;padding:12px;position:relative}.tsm-preview-header{align-items:center;color:#fff;display:flex;justify-content:space-between;margin-bottom:12px;overflow:hidden}.tsm-banner-img{height:100%;inset:0;object-fit:cover;opacity:.2;position:absolute;width:100%}.tsm-header-title{font-weight:700;position:relative}.tsm-header-btn{background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.4);border-radius:6px;color:#fff;cursor:pointer;font:inherit;padding:6px 10px;position:relative}.tsm-preview-text{margin:0}.tsm-mascots{align-items:center;display:flex;gap:8px;margin-top:12px}.tsm-mascot{font-size:20px}.tsm-preview-actions{display:flex;gap:8px;margin-top:12px}.tsm-btn-primary{background:#3b82f6;background:var(--accent,#3b82f6);color:#fff}.tsm-btn-primary,.tsm-btn-secondary{border:none;border-radius:6px;cursor:pointer;font:inherit;padding:8px 12px}.tsm-btn-secondary{background:#e2e8f0;color:#2d3748}.tsm-btn-secondary.dark{background:#374151;color:#e5e7eb}.tsm-message.success{color:#16a34a;font-weight:600;margin-top:10px}.tsm-footer{align-items:center;justify-content:space-between;margin-top:16px}.tsm-footer,.tsm-footer-actions{display:flex;flex-wrap:wrap;gap:8px}.tsm-footer-actions{justify-content:flex-end}.tsm-confirm-overlay{align-items:center;background:rgba(0,0,0,.35);display:flex;inset:0;justify-content:center;padding:12px;position:absolute;z-index:2100}.tsm-confirm-card{background:#111827;background:var(--container-bg,#111827);border:1px solid #1f2937;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.35);color:#f9fafb;color:var(--text,#f9fafb);padding:16px;width:min(420px,100%)}.tsm-confirm-title{font-weight:700;margin-bottom:8px}.tsm-confirm-desc{color:#d1d5db;font-size:14px;margin-bottom:12px}.tsm-confirm-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}@media (max-width:800px){.tsm-grid{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
/*# sourceMappingURL=main.8ee45ac1.css.map*/