@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(15px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes flash{0%,to{opacity:1}50%{opacity:.3}}@keyframes shine{to{background-position:200% center}}@keyframes slideAndFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}:root{--primary-color: #4F46E5;--primary-color-dark: #3730A3;--secondary-color: #EEF2FF;--background-color: #F8FAFC;--surface-color: #FFFFFF;--text-color: #1E293B;--text-color-secondary: #475569;--text-muted: #64748B;--border-color: #E2E8F0;--error-color: #DC2626;--success-color: #16A34A;--warning-color: #D97706;--info-color: #6366F1;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";--table-row-alt-bg: #F8FAFC;--table-hover-bg: #F1F5F9;--result-banner-pass-bg: #ECFDF5;--result-banner-pass-text: #065F46;--result-banner-fail-bg: #FFFBEB;--result-banner-fail-text: #92400E;--explanation-bg: #F5F3FF;--explanation-border: #8B5CF6;--q-nav-answered-bg: #D1FAE5;--q-nav-unanswered-bg: #F3F4F6;--q-nav-answered-border: #6EE7B7;--answer-correct-bg: #DCFCE7;--answer-incorrect-bg: #FEE2E2;--selected-answer-bg: #E0E7FF;--tab-color-students: #4F46E5;--tab-color-classes: #F97316;--tab-color-questions: #0EA5E9;--tab-color-results: #E11D48;--tab-color-settings: #16A34A;--tab-color-students-bg: #EEF2FF;--tab-color-classes-bg: #FFF7ED;--tab-color-questions-bg: #F0F9FF;--tab-color-results-bg: #FFF1F2;--tab-color-settings-bg: #F0FDF4}body[data-theme=dark]{--primary-color: #6366F1;--primary-color-dark: #818CF8;--secondary-color: #334155;--background-color: #0F172A;--surface-color: #1E293B;--text-color: #F1F5F9;--text-color-secondary: #CBD5E1;--text-muted: #94A3B8;--border-color: #334155;--error-color: #F87171;--success-color: #4ADE80;--warning-color: #FBBF24;--table-row-alt-bg: #1A253C;--table-hover-bg: #2C384D;--result-banner-pass-bg: rgba(6, 95, 70, .5);--result-banner-pass-text: #6EE7B7;--result-banner-fail-bg: rgba(146, 64, 14, .5);--result-banner-fail-text: #FCD34D;--explanation-bg: rgba(139, 92, 246, .1);--explanation-border: #A78BFA;--q-nav-answered-bg: rgba(16, 185, 129, .2);--q-nav-unanswered-bg: #334155;--q-nav-answered-border: #34D399;--answer-correct-bg: rgba(74, 222, 128, .15);--answer-incorrect-bg: rgba(248, 113, 113, .15);--selected-answer-bg: rgba(99, 102, 241, .2);--tab-color-students-bg: rgba(79, 70, 229, .2);--tab-color-classes-bg: rgba(249, 115, 22, .2);--tab-color-questions-bg: rgba(14, 165, 233, .2);--tab-color-results-bg: rgba(225, 29, 72, .2);--tab-color-settings-bg: rgba(22, 163, 74, .2)}body[data-color-theme=orange]{--primary-color: #F97316;--primary-color-dark: #C2410C}body[data-color-theme=orange][data-theme=dark]{--primary-color: #FB923C;--primary-color-dark: #FDBA74}body[data-color-theme=sky]{--primary-color: #0EA5E9;--primary-color-dark: #0369A1}body[data-color-theme=sky][data-theme=dark]{--primary-color: #38BDF8;--primary-color-dark: #7DD3FC}body[data-color-theme=rose]{--primary-color: #E11D48;--primary-color-dark: #9F1239}body[data-color-theme=rose][data-theme=dark]{--primary-color: #F43F5E;--primary-color-dark: #FDA4AF}body[data-color-theme=green]{--primary-color: #16A34A;--primary-color-dark: #14532D}body[data-color-theme=green][data-theme=dark]{--primary-color: #4ADE80;--primary-color-dark: #86EFAC}body{margin:0;font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-color);transition:background-color .3s,color .3s}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8fafc;padding:20px;position:relative}.theme-toggle-fixed{position:absolute;top:20px;right:30px;z-index:100}.loading-container,.error-container{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--background-color)}.section-container{background:var(--surface-color);border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.section-container h4{margin-top:0;margin-bottom:20px;color:var(--text-color)}.welcome-title{font-size:2.6rem;font-weight:900;color:#1e293b;line-height:1.1;margin-bottom:2rem;display:flex;flex-direction:column;letter-spacing:-.02em}.welcome-subtitle{font-size:1.15rem;font-weight:500;color:#334155;margin-bottom:.8rem;letter-spacing:normal;text-transform:none}.gradient-text{background:linear-gradient(-45deg,#3b82f6,#4f46e5,#1e293b,#4f46e5,#3b82f6);background-size:400% 400%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradient-shimmer 8s ease infinite}@keyframes gradient-shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.login-card{width:100%;max-width:1100px;display:flex;align-items:center;border-radius:0;overflow:visible;box-shadow:none;background:transparent}.login-info-panel{flex:1.2;padding:60px;background:transparent;display:flex;flex-direction:column;justify-content:center}.login-form-panel{flex:1;padding:40px 60px;background:#fff;border-radius:24px;box-shadow:0 40px 80px -12px #00000026;display:flex;flex-direction:column;justify-content:center;border:1px solid #F1F5F9;align-self:center}@media(max-width:900px){.login-card{flex-direction:column}.login-info-panel,.login-form-panel{padding:40px}.login-form-panel{border-left:none;border-top:1px solid #F1F5F9}}.info-pills-row{cursor:pointer}.info-pill-item{display:flex;align-items:center;background:#fff;padding:10px 15px;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;transition:transform .2s;border:1px solid #E2E8F0;flex:1}.info-pill-item:hover{transform:translateY(-3px);box-shadow:0 10px 15px -3px #0000001a}.pill-icon-box{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2em;margin-right:12px;flex-shrink:0}.pill-text-box{display:flex;flex-direction:column}.pill-text-box strong{font-size:.9em;color:#1e293b}.pill-text-box span{font-size:.8em;color:#64748b}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px}.auth-modal-content{background:#fff;width:100%;max-width:500px;border-radius:16px;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a;animation:slideUp .2s ease-out}.auth-modal-header{padding:20px;border-bottom:1px solid #F1F5F9;display:flex;align-items:center;justify-content:space-between}.auth-modal-header h3{margin:0;font-size:1.2em;color:#1e293b}.auth-modal-close{background:none;border:none;font-size:1.5em;cursor:pointer;color:#94a3b8;line-height:1}.auth-modal-body{padding:20px}.auth-modal-footer{padding:15px 20px;background:#f8fafc;border-top:1px solid #F1F5F9}.help-step{display:flex;align-items:flex-start;gap:15px;margin-bottom:20px}.help-icon{background:#f0fdfa;color:#0d9488;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2em;flex-shrink:0}.help-desc strong{display:block;color:#0d9488;margin-bottom:4px}.help-desc p{margin:0;font-size:.9em;color:#475569;line-height:1.5}.contact-avatar-wrapper img{width:100px;height:100px;border-radius:50%;border:4px solid white;box-shadow:0 4px 6px #0000001a;object-fit:cover}.contact-name{margin:10px 0 5px;font-size:1.4em;color:#064e3b;font-weight:800}.contact-slogan{color:#065f46;font-size:.95em;opacity:.8}.contact-link-pill{background:#fff;padding:10px 15px;border-radius:25px;display:flex;align-items:center;gap:10px;box-shadow:0 2px 4px #0000000d}.pill-icon{width:20px;text-align:center}.pill-label{background:#3b82f6;color:#fff;padding:2px 6px;border-radius:4px;font-size:.65em;font-weight:900}.pill-value{font-size:.9em;color:#1e293b;font-weight:600}body[data-theme=dark] .login-page{background:#0f172a}body[data-theme=dark] .login-card{background:transparent;border:none}body[data-theme=dark] .login-info-panel{background:transparent}body[data-theme=dark] .login-form-panel{background:#1e293b;border-color:#334155}body[data-theme=dark] .login-form-panel .btn-outline{color:#cbd5e1!important;border-color:#475569!important}body[data-theme=dark] .info-pills-row{display:flex;gap:15px}body[data-theme=dark] .info-pill-item{background:#1e293b80;border-color:#334155;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}body[data-theme=dark] .info-pill-item[style*="#10B981"]{border-color:#10b981!important;background:#10b9810d!important}body[data-theme=dark] .info-pill-item[style*="#F59E0B"]{border-color:#f59e0b!important;background:#f59e0b0d!important}body[data-theme=dark] .pill-text-box strong{color:#f1f5f9}body[data-theme=dark] .pill-text-box span{color:#94a3b8}body[data-theme=dark] .contact-modal-content{background:#1e293b!important}body[data-theme=dark] .contact-left{background:#111827!important;border-right:1px solid #334155!important;border-bottom:none}body[data-theme=dark] .contact-right{background:#1e293b!important;border-top:none}body[data-theme=dark] .contact-right h3{color:#f1f5f9!important;border-bottom-color:#334155!important}body[data-theme=dark] .contact-name,body[data-theme=dark] .contact-slogan,body[data-theme=dark] .intro-text{color:#f1f5f9!important}body[data-theme=dark] .contact-link-pill{background:#334155}body[data-theme=dark] .pill-value{color:#f1f5f9}body[data-theme=dark] .help-desc strong,body[data-theme=dark] .help-desc p{color:#f1f5f9!important}body[data-theme=dark] .welcome-title{color:#f1f5f9}body[data-theme=dark] .welcome-subtitle{color:#cbd5e1}body[data-theme=dark] .gradient-text{background:linear-gradient(to right,#60a5fa,#818cf8,#f1f5f9);-webkit-background-clip:text;background-clip:text}.theme-toggle-btn{background:var(--surface-color);border:1px solid var(--border-color);border-radius:50%;width:40px;height:40px;display:flex;justify-content:center;align-items:center;font-size:1.2rem;cursor:pointer;transition:background-color .2s,transform .2s;color:var(--text-color)}.theme-toggle-btn:hover{transform:scale(1.1);background-color:var(--secondary-color)}.btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:1em;font-weight:500;transition:background-color .2s,box-shadow .2s,transform .2s;background-color:var(--secondary-color);color:var(--primary-color-dark)}body[data-theme=dark] .btn{color:var(--text-color);background-color:var(--secondary-color)}.btn:hover{box-shadow:0 2px 5px #00000026;filter:brightness(.95);transform:translateY(-1px)}.btn.btn-primary{background-color:var(--primary-color);color:#fff}.btn.btn-primary:hover{background-color:var(--primary-color-dark)}.btn.btn-large{padding:12px 24px;font-size:1.2em}.btn.btn-danger{background-color:#fee2e2;color:#dc2626}body[data-theme=dark] .btn.btn-danger{background-color:#dc262633;color:var(--error-color)}.btn.btn-danger:hover{background-color:#fecaca}body[data-theme=dark] .btn.btn-danger:hover{background-color:#dc26264d}.btn:disabled{background-color:var(--border-color);cursor:not-allowed;color:var(--text-muted);box-shadow:none;transform:none}.btn-sm{padding:4px 8px;font-size:.8em;margin-left:5px}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:14px;border:1px solid var(--border-color);text-align:left;vertical-align:middle}.data-table th{background-color:var(--secondary-color);color:var(--primary-color-dark);font-weight:600;transition:background-color .3s,color .3s}body[data-theme=dark] .data-table th{color:var(--text-color)}.data-table tbody tr{transition:background-color .2s ease-in-out;background-color:var(--surface-color);color:var(--text-color)}.data-table tbody tr:nth-child(2n){background-color:var(--table-row-alt-bg)}.data-table tbody tr:hover{background-color:var(--table-hover-bg)}.data-table tbody tr.selected{background-color:var(--secondary-color)!important}body[data-theme=dark] .data-table tbody tr.selected{background-color:var(--primary-color)!important;color:#fff}.table-wrapper{overflow-x:auto}.loading-container,.error-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh}.error-message{color:var(--error-color);text-align:center;margin-bottom:15px}.success-message{color:var(--success-color);background-color:var(--result-banner-pass-bg);padding:10px;border-radius:4px;text-align:center;margin-bottom:15px;border:1px solid var(--success-color);white-space:pre-wrap;word-break:break-word}.error-container p{max-width:600px;text-align:center;line-height:1.5;margin:10px 20px}.error-container button{margin-top:20px}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0f172ab3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out forwards}.modal-content{background:var(--surface-color);color:var(--text-color);padding:20px;border-radius:8px;width:90%;max-width:600px;box-shadow:0 5px 15px #0000004d;animation:slideUp .4s cubic-bezier(.25,.46,.45,.94) forwards;border:1px solid var(--border-color)}.modal-content.large{max-width:950px}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:10px;margin-bottom:20px}.modal-header h3{margin:0;font-size:1.4em;color:var(--primary-color-dark)}body[data-theme=dark] .modal-header h3{color:var(--primary-color)}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-color)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-actions .btn-confirm-danger{background-color:var(--error-color);color:#fff}.modal-form fieldset{border:1px solid var(--border-color);border-radius:6px;padding:10px 20px 15px;margin-bottom:20px}.modal-form legend{font-weight:600;font-size:1.1em;color:var(--primary-color-dark);padding:0 10px;margin-left:-10px}body[data-theme=dark] .modal-form legend{color:var(--primary-color)}.modal-form-layout-2col{display:grid;grid-template-columns:1fr 1fr;gap:0 30px}.modal-form input,.modal-form select,.form-group input,.form-group select{width:100%;padding:8px;margin-top:5px;margin-bottom:15px;border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;background-color:var(--surface-color);color:var(--text-color);transition:border-color .2s,box-shadow .2s}.modal-form input:focus,.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e533}.form-group label{display:block;font-weight:500;margin-bottom:5px}.pagination-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;margin-top:20px}.pagination-info,.pagination-nav{display:flex;align-items:center;gap:8px}.pagination-nav{gap:15px}@media(max-width:768px){.modal-form-layout-2col{grid-template-columns:1fr}.pagination-controls{flex-direction:column;align-items:stretch;gap:10px}.pagination-nav{justify-content:space-between}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--background-color);padding:2rem;box-sizing:border-box;position:relative}.login-container .theme-toggle-btn{position:absolute;top:20px;right:20px;z-index:10}.login-card{display:grid;grid-template-columns:1fr 400px;width:100%;max-width:1280px;align-items:center;gap:40px;animation:fadeIn .6s ease-out forwards}.login-info-panel{display:flex;flex-direction:column;justify-content:center;background-color:transparent;color:var(--text-color);padding:2rem 3rem;min-width:0}.welcome-title{font-weight:800;line-height:1.2;margin:0;font-size:2.4rem;color:transparent;background:linear-gradient(90deg,var(--text-color) 35%,var(--primary-color) 50%,var(--text-color) 65%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;animation:slideUp .8s ease-out forwards,shine 3s linear infinite 1.5s}.welcome-subtitle{display:block;font-size:1.8rem;font-weight:400;line-height:1.4;opacity:.9;color:var(--text-color);-webkit-background-clip:initial;background-clip:initial;background:none;animation:slideUp .6s ease-out forwards}.login-form-container{display:flex;justify-content:center;align-items:center;background-color:var(--surface-color);border-radius:8px;box-shadow:0 2px 4px #0000001a,0 8px 16px #0000001a;padding:2rem}.login-form{background:transparent;padding:0;box-shadow:none;border-radius:0;width:100%;max-width:450px}.login-form.registration-form{max-width:500px;background:var(--surface-color);padding:40px;border-radius:8px;box-shadow:0 4px 10px #0000001a}.login-form h2{text-align:center;margin-bottom:25px;color:var(--primary-color-dark);font-weight:700;font-size:1.8em}.input-group{margin-bottom:25px}.input-group label{display:block;margin-bottom:5px;font-weight:500}.input-group input{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box;background-color:var(--surface-color);color:var(--text-color);transition:border-color .2s,box-shadow .2s}.input-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e533}.remember-me-wrapper{margin-bottom:20px;display:flex;align-items:center}.remember-me-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.95rem;color:var(--text-color);-webkit-user-select:none;user-select:none}.remember-me-label input{width:18px;height:18px;margin:0;cursor:pointer;accent-color:var(--primary-color)}.login-form button[type=submit]{width:100%;padding:12px;font-size:1.1rem;margin-top:10px}.login-form>h2,.login-form .input-group,.login-form button[type=submit]{opacity:0;animation:slideUp .5s ease-out forwards}.login-form>h2{animation-delay:.1s}.login-form .input-group:nth-of-type(1){animation-delay:.2s}.login-form .input-group:nth-of-type(2){animation-delay:.3s}.login-form button[type=submit]{animation-delay:.4s}@media(max-width:1024px){.login-card{grid-template-columns:1fr;max-width:500px;gap:30px}.login-info-panel{text-align:center;padding:2rem 1rem}.welcome-title{font-size:2rem}.welcome-subtitle{font-size:1.5rem}}@media(max-width:600px){.login-container{padding:1rem}.login-form-container{padding:1.5rem}.welcome-title{font-size:1.6rem}.welcome-subtitle{font-size:1.2rem}}.student-view-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--background-color);font-family:Inter,sans-serif;font-size:1.2rem;transition:background-color .3s}.student-view-header{background-color:var(--surface-color);color:var(--text-color);padding:15px 25px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 4px #0000001a;z-index:20;position:sticky;top:0;border-bottom:1px solid var(--border-color)}.student-view-header h1{margin:0;font-size:1.15em;font-weight:700;color:var(--primary-color);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.student-header-actions{display:flex;align-items:center;gap:15px}.header-user-name{font-weight:600;color:var(--text-color-secondary);font-size:.9em}.btn-logout{background-color:#f59e0b;color:#fff;border:none;padding:8px 18px;border-radius:8px;font-weight:600;cursor:pointer;font-size:.85em;transition:all .2s;flex-shrink:0}.btn-logout:hover{background-color:#d97706;transform:translateY(-1px)}.student-welcome-banner{background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#312e81;padding:50px 20px 80px;text-align:center;border-bottom-left-radius:35px;border-bottom-right-radius:35px;position:relative;overflow:hidden}body[data-theme=dark] .student-welcome-banner{background:linear-gradient(135deg,#1e1b4b,#312e81);color:#eef2ff}.welcome-content h2{font-size:2.4em;font-weight:800;margin:0 0 12px;letter-spacing:-.5px}.welcome-content p{font-size:1.15em;opacity:.9;margin:0 0 30px}.btn-hero{background:#4f46e5;color:#fff;border:none;padding:16px 48px;border-radius:50px;font-weight:700;font-size:1.15em;cursor:pointer;box-shadow:0 10px 15px -3px #4f46e54d;text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-hero:hover{background:#4338ca;transform:translateY(-3px) scale(1.02);box-shadow:0 20px 25px -5px #4f46e566}.dashboard-content-container{max-width:1400px;margin:-45px auto 40px;padding:0 10px;width:100%;box-sizing:border-box;position:relative;z-index:2}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:15px;margin-bottom:30px}.stat-card{background:var(--surface-color);border-radius:14px;padding:18px 24px;box-shadow:0 4px 6px -1px #00000012;display:flex;justify-content:space-between;align-items:center;min-height:100px;border:1px solid var(--border-color);border-left-width:6px;transition:transform .2s,box-shadow .2s}.stat-label{font-size:.8em;font-weight:700;color:var(--text-muted);text-transform:uppercase;margin-bottom:5px}.stat-value{font-size:2.2em;font-weight:800;color:var(--text-color);line-height:1.1}.stat-sub{font-size:.9em;color:var(--text-color-secondary)}.circle-progress-container{position:relative;width:68px;height:68px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.circle-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.85em;font-weight:800}.dashboard-card{background:var(--surface-color);border-radius:14px;padding:24px;box-shadow:0 2px 5px #0000000d;border:1px solid var(--border-color);margin-bottom:25px;color:var(--text-color)}.card-accent-blue{border-top:6px solid #3B82F6}.card-accent-cyan{border-top:6px solid #06B6D4}.card-accent-rose{border-top:6px solid #F43F5E}.card-accent-green{border-top:6px solid #10B981}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.card-title{font-size:1.2em;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.wrong-questions-table{width:100%;border-collapse:collapse;margin-top:10px}.wrong-questions-table th,.wrong-questions-table td{padding:12px 10px;text-align:left;border-bottom:1px solid var(--border-color)}.wrong-questions-table th{font-size:.8em;text-transform:uppercase;color:var(--text-muted)}.wrong-questions-table .col-attempts{width:100px;font-weight:700;color:var(--error-color)}.wrong-questions-table .col-content{font-size:.95em;line-height:1.4}.btn-link{background:#e0f2fe;color:#0369a1;border:none;padding:6px 16px;border-radius:8px;font-size:.9em;font-weight:600;cursor:pointer;transition:all .2s}body[data-theme=dark] .btn-link{background:#0369a133;color:#7dd3fc}.btn-link:hover{background:#bae6fd;color:#0284c7}body[data-theme=dark] .btn-link:hover{background:#0369a14d}.history-table{width:100%;font-size:1.05em;border-collapse:collapse}.history-table th{padding:12px 10px;color:var(--text-muted);font-weight:700;text-transform:uppercase;font-size:.85em;border-bottom:2px solid var(--border-color)}.history-table th:first-child,.history-table td:first-child{text-align:left;padding-left:0}.history-table th:nth-child(2),.history-table td:nth-child(2){text-align:center}.history-table th:nth-child(3),.history-table td:nth-child(3){text-align:center}.history-table th:last-child,.history-table td:last-child{text-align:right;padding-right:0}.history-table td{padding:16px 10px;border-bottom:1px solid var(--border-color);color:var(--text-color)}body[data-theme=dark] .history-table td,body[data-theme=dark] .wrong-questions-table td{color:#f1f5f9}.btn-sm{background-color:#f0f9ff;color:#0284c7;border:1px solid #E0F2FE;padding:8px 16px;border-radius:8px;font-weight:600;cursor:pointer;font-size:.9em;transition:all .2s}.btn-sm:hover{background-color:#e0f2fe}.card-accent-rose .card-header{flex-direction:column;align-items:center;text-align:center;gap:8px}.card-accent-rose .card-header .card-title{margin:0}.card-accent-rose .card-header div{font-size:.95em;opacity:.8}.profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.profile-row{display:flex;flex-direction:column}.profile-label{font-size:.8em;color:var(--text-muted);font-weight:600;text-transform:uppercase}.profile-value{font-size:1.1em;font-weight:600;color:var(--text-color)}.practice-item{display:flex;justify-content:space-between;align-items:center;padding:18px 0;border-bottom:1px solid var(--border-color)}.practice-item:last-child{border-bottom:none}.btn-practice-sm{background:var(--primary-color);color:#fff;border:none;padding:10px 24px;border-radius:10px;font-weight:600;font-size:.95em;cursor:pointer;flex-shrink:0;box-shadow:0 4px 6px -1px #4f46e533}.main-dashboard-grid{display:grid;grid-template-columns:1fr 400px;gap:25px}@media(max-width:1024px){.main-dashboard-grid{grid-template-columns:1fr}.student-view-container{font-size:1.1rem}}@media(max-width:768px){.student-view-header{flex-direction:column;padding:20px 15px;gap:15px;text-align:center}.student-header-actions{width:100%;justify-content:center;flex-wrap:wrap;gap:10px}.header-user-name{width:100%;order:-1;margin-bottom:5px;font-size:1em;display:block}.student-view-header h1{font-size:1.1em;width:100%}.welcome-content h2{font-size:1.8em}.profile-grid{grid-template-columns:1fr}.dashboard-content-container{padding:0 10px}.wrong-questions-table .col-attempts{width:80px}}@media(max-width:480px){.history-table th:nth-child(3),.history-table td:nth-child(3){display:none}.history-table th:first-child,.history-table td:first-child{width:60%}.practice-item{flex-direction:column;align-items:stretch;gap:12px}.btn-practice-sm{width:100%;text-align:center}}.col-content .q-text-main{font-weight:500;margin-bottom:5px}.q-correct-ans-preview{font-size:.9em;padding:8px 12px;background-color:var(--answer-correct-bg);border-radius:6px;border-left:4px solid var(--success-color);margin-top:5px}.badge-correct{font-weight:700;color:var(--success-color);margin-right:5px}.quiz-container{width:100%;height:100vh;box-sizing:border-box;background-color:var(--background-color);display:flex;flex-direction:column}.quiz-layout{display:grid;grid-template-columns:320px 1fr;gap:25px;height:100%;padding:25px;box-sizing:border-box;flex-grow:1;overflow:hidden}.quiz-main-panel{background:transparent;border-radius:8px;overflow-y:auto;height:100%;scroll-behavior:smooth;padding-bottom:60px}.all-questions-list{padding:0 20px 20px}.quiz-side-panel{background-color:#f0f5ff;padding:20px;border-radius:8px;border:1px solid var(--border-color);height:calc(100vh - 50px);display:flex;flex-direction:column}body[data-theme=dark] .quiz-side-panel{background-color:#1e293b}.quiz-header{margin:0 20px;padding-top:20px;color:var(--primary-color-dark)}.quiz-header h3{margin:0;padding-bottom:15px;border-bottom:1px solid var(--border-color);font-size:1.8em;text-align:center}.side-panel-header{margin-bottom:20px}.side-panel-header h4{margin-top:0;color:var(--primary-color-dark);text-align:center}body[data-theme=dark] .side-panel-header h4{color:var(--primary-color)}.timer-block{margin-bottom:15px;text-align:center}.timer-label{font-size:.9em;color:#555;margin-bottom:4px}body[data-theme=dark] .timer-label{color:#94a3b8}.timer-display{font-size:2.5em;font-weight:700;font-family:monospace;color:var(--primary-color-dark)}body[data-theme=dark] .timer-display{color:#818cf8}.timer-display.low-time{color:var(--error-color)}.timer-display.flashing-warning{animation:flash 1s infinite}.answered-count{font-size:1em;text-align:center;margin-bottom:15px}.progress-bar-container{height:20px;width:100%;background-color:var(--secondary-color);border-radius:10px;overflow:hidden;margin-top:5px}.progress-bar-fill{height:100%;background-color:var(--primary-color);text-align:center;line-height:20px;color:#fff;font-size:.8em;transition:width .3s ease-in-out}.student-info-panel{background-color:#fffbeb;border:1px solid #FEF3C7;border-radius:8px;padding:15px;margin-bottom:15px;color:#92400e}body[data-theme=dark] .student-info-panel{background-color:#1a253c;border-color:#334155;color:#f1f5f9}.info-grid{display:grid;grid-template-columns:auto 1fr;gap:5px 10px;align-items:center;font-size:.9em}.info-label{font-weight:700}.quiz-question-nav{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:20px;flex-grow:1;overflow-y:auto;padding:5px}.q-nav-btn{border:1px solid var(--border-color);border-radius:6px;padding:12px 0;cursor:pointer;transition:all .2s ease-in-out;font-weight:600;font-size:.9em;color:var(--text-color)}.q-nav-btn.unanswered{background-color:var(--q-nav-unanswered-bg)}.q-nav-btn.answered{background-color:var(--q-nav-answered-bg);border-color:var(--q-nav-answered-border)}.q-nav-btn.active{border-color:var(--primary-color);background-color:var(--primary-color);color:#fff!important;transform:scale(1.05)}body[data-theme=dark] .q-nav-btn.unanswered{background-color:#334155;color:#cbd5e1}.btn-submit-side{margin-top:auto;width:100%}.question-box{margin-bottom:30px;padding:24px;background-color:var(--surface-color);border-radius:12px;border:1px solid var(--border-color);scroll-margin-top:80px}.question-text{font-size:1.15em;line-height:1.5;margin-top:0}.options-list{display:flex;flex-direction:column;gap:12px}.option-label{display:block;padding:14px;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease-in-out;min-height:44px;display:flex;align-items:center}.option-label:hover{background-color:var(--secondary-color);border-color:var(--primary-color)}.option-label.selected{background-color:var(--selected-answer-bg);border-color:var(--primary-color);font-weight:600}.option-label.official-selected{background-color:#eef2ff!important;border-color:#818cf8!important;box-shadow:0 0 0 1px #6366f11a;color:#3730a3!important}body[data-theme=dark] .option-label.official-selected{background-color:#6366f126!important;border-color:#818cf8!important;color:#e0e7ff!important;box-shadow:0 0 10px #6366f133}body[data-theme=dark] .option-label.selected:not(.official-selected){background-color:#6366f126;color:#f1f5f9}.option-label input{margin-right:15px;transform:scale(1.3);accent-color:var(--primary-color)}.option-label.feedback-correct{background-color:var(--answer-correct-bg);border-color:var(--success-color)}.option-label.feedback-incorrect{background-color:#f43f5e1a;border-color:var(--error-color)}.mobile-quiz-header,.mobile-quiz-controls,.mobile-map-overlay{display:none}@media(max-width:1024px){.quiz-container{overflow-y:auto;-webkit-overflow-scrolling:touch;height:100dvh;display:block}.quiz-side-panel{display:none}.quiz-layout{display:block;padding:0;margin:0;height:auto;overflow:visible;flex-grow:0}.quiz-main-panel{height:auto;border-radius:0;background-color:var(--background-color);padding-top:60px;padding-bottom:80px;overflow:visible}.question-box{margin:10px 12px 25px;padding:20px;box-shadow:0 1px 3px #0000000d}.quiz-header{display:none}.mobile-quiz-header{display:flex;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;width:100%;height:56px;background-color:var(--surface-color);border-bottom:1px solid var(--border-color);z-index:1000;padding:0 15px;box-sizing:border-box;box-shadow:0 2px 4px #0000000d}.mobile-timer-badge{display:flex;align-items:center;background:var(--secondary-color);padding:4px 10px;border-radius:20px;font-weight:600;color:var(--primary-color-dark)}.timer-icon{margin-right:5px;font-size:1.1em}.timer-text.low-time{color:var(--error-color);animation:flash 1s infinite}.mobile-progress-wrapper{flex-grow:1;margin:0 15px;display:flex;flex-direction:column;align-items:center}.mobile-progress-wrapper .progress-bar-container{height:6px;margin-top:0;margin-bottom:2px}.progress-text-sm{font-size:.75em;color:#64748b}.btn-mobile-submit{background:var(--primary-color);color:#fff;border:none;padding:6px 14px;border-radius:4px;font-weight:600;font-size:.9em}.mobile-quiz-controls{display:flex;align-items:center;justify-content:space-between;position:fixed;bottom:0;left:0;width:100%;height:64px;background-color:var(--surface-color);border-top:1px solid var(--border-color);z-index:1000;padding:0 10px;box-sizing:border-box;box-shadow:0 -2px 10px #0000000d}.mobile-nav-btn{background:transparent;border:1px solid var(--border-color);padding:8px 16px;border-radius:6px;font-weight:600;color:var(--text-color);min-width:80px}.mobile-nav-btn:active{background-color:var(--secondary-color)}.mobile-nav-btn:disabled{opacity:.4}.mobile-map-trigger{background:transparent;border:none;font-weight:700;color:var(--primary-color);font-size:1em;display:flex;align-items:center;gap:5px}.map-icon{font-size:1.4em}.mobile-map-overlay{display:block;position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:2000;animation:fadeIn .2s;display:flex;align-items:flex-end}.mobile-map-content{width:100%;background:var(--surface-color);border-top-left-radius:20px;border-top-right-radius:20px;padding:20px;max-height:75vh;overflow-y:auto;animation:slideUp .3s ease-out}.mobile-map-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid var(--border-color);padding-bottom:12px}.mobile-map-header h4{margin:0;font-size:1.25em}.mobile-map-header button{background:none;border:none;font-size:2em;line-height:1;padding:5px;color:#64748b}.mobile-map-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;padding:5px}.mobile-map-grid .q-nav-btn{padding:14px 0;font-size:1.05em}}.review-page-container{max-width:900px;margin:40px auto;padding:0 20px;animation:fadeIn .5s ease-out}.result-summary-card{background:var(--surface-color);border-radius:30px;padding:40px;box-shadow:0 10px 25px #0000000d;border:1px solid var(--border-color);text-align:center;display:flex;flex-direction:column;align-items:center;margin-bottom:30px}.result-user-info{display:flex;align-items:center;gap:15px;margin-bottom:30px;width:100%;justify-content:flex-start}.user-avatar-circle{width:60px;height:60px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5em;font-weight:800}.user-name-title{text-align:left}.user-name-title h3{margin:0;font-size:1.3em;color:var(--primary-color-dark)}.user-name-title p{margin:2px 0 0;font-size:.9em;color:var(--text-muted)}.result-chart-section{margin:20px 0;display:flex;flex-direction:column;align-items:center}.result-score-text{margin-top:15px;font-size:1.1em;font-weight:600;color:var(--text-color-secondary)}.result-feedback-banner{width:100%;max-width:500px;margin:30px 0;padding:20px;border-radius:20px;background-color:#fffbeb;border:1px solid #FEF3C7}body[data-theme=dark] .result-feedback-banner{background-color:#fbbf241a;border-color:#fbbf2433}.feedback-title{font-size:1.4em;font-weight:800;margin-bottom:10px;color:#92400e}body[data-theme=dark] .feedback-title{color:#fcd34d}.feedback-subtitle{font-size:1em;color:#b45309}body[data-theme=dark] .feedback-subtitle{color:#fbbf24;opacity:.8}.result-stats-row{display:flex;width:100%;max-width:600px;border-top:1px dashed var(--border-color);padding-top:25px;margin-bottom:30px}.stat-item{flex:1;display:flex;flex-direction:column}.stat-item:first-child{border-right:1px solid var(--border-color)}.stat-label{font-size:.8em;text-transform:uppercase;color:var(--text-muted);font-weight:700;letter-spacing:1px;margin-bottom:5px}.stat-val{font-size:1.3em;font-weight:800;color:var(--text-color)}.result-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:500px}.btn-result{padding:14px;border-radius:12px;font-weight:700;font-size:1em;cursor:pointer;transition:all .2s;border:none}.btn-result-detail{background-color:#e0f2fe;color:#0369a1}.btn-result-detail:hover{background-color:#bae6fd}.btn-result-home{background-color:#0ea5e9;color:#fff;box-shadow:0 4px 12px #0ea5e94d}.btn-result-home:hover{background-color:#0284c7;transform:translateY(-2px)}.review-questions-list{display:flex;flex-direction:column;gap:20px;margin-top:30px;padding-bottom:50px;animation:slideAndFadeIn .4s ease-out}.review-question-box{border:1px solid var(--border-color);padding:25px;border-radius:16px;background:var(--surface-color);color:var(--text-color);position:relative}.review-question-box.correct{border-left:8px solid var(--success-color)}.review-question-box.incorrect{border-left:8px solid var(--error-color)}.review-options{display:flex;flex-direction:column;gap:10px;margin-top:20px}.option-item{padding:12px 16px;border-radius:8px;border:1px solid var(--border-color);font-size:.95em}.option-item.correct-answer{background-color:var(--answer-correct-bg);border-color:var(--success-color);color:var(--text-color);font-weight:600}.option-item.incorrect-answer{background-color:var(--answer-incorrect-bg);border-color:var(--error-color);color:var(--text-color)}.option-item.student-choice{position:relative;padding-left:35px}.option-item.student-choice:before{content:"➔";position:absolute;left:12px;color:var(--primary-color);font-weight:700}.explanation-container{margin-top:20px}.btn-explanation-toggle{background:#f1f5f9;border:1px solid #E2E8F0;color:#475569;padding:8px 16px;border-radius:8px;font-size:.9em;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .2s}body[data-theme=dark] .btn-explanation-toggle{background:#334155;border-color:#475569;color:#cbd5e1}.btn-explanation-toggle:hover{background:#e2e8f0}.explanation-section{margin-top:12px;padding:20px;background-color:#f8fafc;border-left:4px solid var(--primary-color);border-radius:8px;font-size:1.05em;line-height:1.7;animation:fadeIn .3s ease-out}body[data-theme=dark] .explanation-section{background-color:#ffffff0d}.explanation-section strong{display:block;margin-bottom:10px;color:var(--primary-color);text-transform:uppercase;font-size:.9em;letter-spacing:.8px}@media(max-width:600px){.review-page-container{margin:15px auto;padding:0 10px}.result-summary-card{padding:20px 15px;border-radius:20px;margin-bottom:15px}.result-user-info{margin-bottom:15px;gap:10px}.user-avatar-circle{width:45px;height:45px;font-size:1.2em}.user-name-title h3{font-size:1.1em}.result-chart-section{margin:10px 0}.result-feedback-banner{margin:15px 0;padding:12px;border-radius:15px}.feedback-title{font-size:1.1em;margin-bottom:4px}.feedback-subtitle{font-size:.85em}.result-stats-row{padding-top:15px;margin-bottom:20px;flex-direction:row;gap:0}.stat-item:first-child{border-bottom:none;padding-bottom:0}.stat-label{font-size:.7em}.stat-val{font-size:1.05em}.result-actions{gap:10px}.btn-result{padding:10px;font-size:.95em;border-radius:10px}}.admin-layout-wrapper{display:flex!important;flex-direction:row!important;height:100vh;width:100vw;overflow:hidden;background-color:var(--background-color);transition:background-color .3s}.admin-sidebar{width:260px;background:#0f172a;color:#f1f5f9;display:flex;flex-direction:column;transition:width .3s ease;flex-shrink:0;box-shadow:2px 0 10px #0003;z-index:100}.admin-layout-wrapper.collapsed .admin-sidebar{width:70px}.admin-main-container{flex-grow:1;display:flex;flex-direction:column;overflow:hidden;position:relative;width:0}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:10px 25px;background-color:var(--surface-color);border-bottom:1px solid var(--border-color);flex-shrink:0}.admin-header h1{margin:0;font-size:1.5em;color:var(--primary-color-dark)}.header-actions{display:flex;align-items:center;gap:15px}.admin-nav{display:flex;padding:0 20px;border-bottom:2px solid var(--border-color);background-color:var(--surface-color);flex-shrink:0}.nav-btn{padding:12px 20px;border:2px solid transparent;border-bottom:none;background-color:transparent;cursor:pointer;margin-right:5px;transition:all .2s ease-in-out;font-size:1em;font-weight:500;color:#475569;border-top-left-radius:6px;border-top-right-radius:6px;position:relative;margin-bottom:-2px}body[data-theme=dark] .nav-btn{color:#94a3b8}.nav-btn:hover{background-color:var(--secondary-color);color:var(--primary-color-dark)}.nav-btn.active{font-weight:700;color:var(--primary-color);border-color:var(--border-color);border-bottom-color:var(--background-color);background-color:var(--background-color)}body[data-theme=dark] .nav-btn.active{border-bottom-color:var(--background-color)}.admin-dashboard[data-active-tab=students] .nav-btn.active{background-color:var(--tab-color-students);border-color:var(--tab-color-students) var(--tab-color-students) var(--background-color);color:#fff}.admin-dashboard[data-active-tab=classes] .nav-btn.active{background-color:var(--tab-color-classes);border-color:var(--tab-color-classes) var(--tab-color-classes) var(--background-color);color:#fff}.admin-dashboard[data-active-tab=questions] .nav-btn.active{background-color:var(--tab-color-questions);border-color:var(--tab-color-questions) var(--tab-color-questions) var(--background-color);color:#fff}.admin-dashboard[data-active-tab=results] .nav-btn.active{background-color:var(--tab-color-results);border-color:var(--tab-color-results) var(--tab-color-results) var(--background-color);color:#fff}.admin-dashboard[data-active-tab=settings] .nav-btn.active{background-color:var(--tab-color-settings);border-color:var(--tab-color-settings) var(--tab-color-settings) var(--background-color);color:#fff}.admin-dashboard .section-container h4,.admin-dashboard .details-panel h4{transition:color .3s}.admin-dashboard[data-active-tab=students] .section-container h4,.admin-dashboard[data-active-tab=students] .details-panel h4{color:var(--tab-color-students)}.admin-dashboard[data-active-tab=classes] .section-container h4,.admin-dashboard[data-active-tab=classes] .details-panel h4{color:var(--tab-color-classes)}.admin-dashboard[data-active-tab=questions] .section-container h4,.admin-dashboard[data-active-tab=questions] .details-panel h4,.admin-dashboard[data-active-tab=questions] .assignment-layout h4,.admin-dashboard[data-active-tab=questions] .template-management-layout h4{color:var(--tab-color-questions)}.admin-dashboard[data-active-tab=results] .section-container h4,.admin-dashboard[data-active-tab=results] .details-panel h4{color:var(--tab-color-results)}.admin-dashboard[data-active-tab=settings] .section-container h4,.admin-dashboard[data-active-tab=settings] .details-panel h4{color:var(--tab-color-settings)}.admin-dashboard[data-active-tab=students] .data-table th{background-color:var(--tab-color-students-bg);color:var(--tab-color-students)}.admin-dashboard[data-active-tab=classes] .data-table th{background-color:var(--tab-color-classes-bg);color:var(--tab-color-classes)}.admin-dashboard[data-active-tab=questions] .data-table th{background-color:var(--tab-color-questions-bg);color:var(--tab-color-questions)}.admin-dashboard[data-active-tab=results] .data-table th{background-color:var(--tab-color-results-bg);color:var(--tab-color-results)}.admin-dashboard[data-active-tab=settings] .data-table th{background-color:var(--tab-color-settings-bg);color:var(--tab-color-settings)}.admin-content{flex-grow:1;padding:25px;overflow-y:auto;overflow-x:hidden}.section-container{background:var(--surface-color);padding:20px;border-radius:8px;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000a}.action-buttons{margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.filter-controls{display:flex;justify-content:space-between;align-items:center}.filter-group-inline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.filter-group-inline input,.filter-group-inline select{padding:8px;border-radius:4px;border:1px solid var(--border-color);background-color:var(--surface-color);color:var(--text-color)}.class-management-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:25px;align-items:flex-start}.class-list-panel h4{margin-top:0;margin-bottom:15px;color:var(--primary-color-dark)}.details-panel{border:1px solid var(--border-color);border-radius:8px;padding:20px;min-height:400px;background:var(--background-color)}.placeholder-text-container{display:flex;justify-content:center;align-items:center;height:100%;min-height:350px}.placeholder-text{color:#64748b;font-size:1.1em;text-align:center}.details-section{margin-top:25px}.details-section h5{font-size:1.1em;margin-bottom:15px;color:var(--primary-color-dark)}.template-tags-container{display:flex;flex-wrap:wrap;gap:10px;padding:10px;border:1px solid var(--border-color);border-radius:6px;min-height:100px;background-color:var(--background-color)}.template-tag{padding:8px 16px;border-radius:20px;border:2px solid var(--secondary-color);background-color:var(--surface-color);color:var(--text-color);cursor:pointer;font-weight:500;transition:all .2s ease-in-out}.template-tag:hover{border-color:var(--primary-color)}.template-tag.assigned{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color-dark)}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.setting-toggle-card{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease-in-out}.setting-toggle-card:hover{border-color:var(--primary-color);box-shadow:0 2px 5px #0000000d}.setting-toggle-card.active{border-color:var(--primary-color);background-color:var(--secondary-color)}.setting-toggle-card.disabled{cursor:not-allowed;opacity:.6}.setting-card-label{font-weight:500;font-size:.9em;padding-right:10px}.setting-card-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.setting-card-toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%}.setting-card-toggle input:checked+.toggle-slider{background-color:var(--primary-color)}.setting-card-toggle input:checked+.toggle-slider:before{transform:translate(20px)}.sub-tabs{display:flex;margin-bottom:15px;gap:5px}.sub-tabs button{padding:8px 12px;border:1px solid var(--border-color);background-color:var(--surface-color);cursor:pointer;border-radius:4px;transition:all .2s ease-in-out}.sub-tabs button:hover{border-color:var(--primary-color);background-color:var(--secondary-color)}.sub-tabs button.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color);font-weight:500}.template-assignment-container{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:flex-start}.assignment-layout{display:grid;grid-template-columns:350px 1fr;gap:25px;height:calc(100vh - 200px)}.target-selector-panel,.template-selector-panel{display:flex;flex-direction:column;background-color:var(--surface-color);border-radius:8px;border:1px solid var(--border-color);height:100%}.target-selector-header{padding:15px;border-bottom:1px solid var(--border-color);flex-shrink:0}.target-selector-header h4{margin:0 0 15px;text-align:center}.target-tabs{display:flex;border:1px solid var(--border-color);border-radius:6px;overflow:hidden;margin-bottom:15px}.target-tabs button{flex:1;padding:10px;border:none;background-color:transparent;cursor:pointer;transition:background-color .2s;font-weight:500}.target-tabs button:first-child{border-right:1px solid var(--border-color)}.target-tabs button.active{background-color:var(--secondary-color);color:var(--primary-color)}.target-search-input{width:100%;padding:8px;border:1px solid var(--border-color);border-radius:4px;box-sizing:border-box}.target-list-container{flex-grow:1;overflow-y:auto;padding:10px}.target-list-item{padding:10px 15px;border-radius:4px;cursor:pointer;transition:background-color .2s,color .2s;margin-bottom:5px;border:1px solid transparent}.target-list-item:hover{background-color:var(--secondary-color)}.target-list-item.selected{background-color:var(--primary-color);color:#fff;font-weight:500;border-color:var(--primary-color-dark)}.target-item-name{font-weight:500}.target-item-meta{font-size:.9em;opacity:.7;margin-left:8px}.target-list-item-empty{text-align:center;padding:20px;color:#64748b}.template-selector-panel{padding:20px}.template-selector-placeholder{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;height:100%;color:#64748b}.template-selector-placeholder span{font-size:3rem;margin-bottom:15px;color:var(--border-color)}.template-selector-header{margin-bottom:15px;flex-shrink:0}.template-selector-header h4{margin:0}.template-selector-header p{margin:5px 0 0;color:#64748b}.template-list-container{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.template-list-item{display:flex;justify-content:space-between;align-items:center;padding:15px;border-radius:6px;border:1px solid var(--border-color);background-color:var(--background-color);cursor:pointer;transition:all .2s ease-in-out}.template-list-item:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 2px 5px #0000000d}.template-list-item.assigned{background-color:var(--secondary-color);border-color:var(--primary-color)}.template-item-info{display:flex;flex-direction:column}.template-item-name{font-weight:600}.template-item-qcount{font-size:.85em;color:#64748b;margin-top:2px}.template-item-checkbox{transform:scale(1.3);accent-color:var(--primary-color)}.template-management-layout{display:grid;grid-template-columns:380px 1fr;gap:25px;height:calc(100vh - 200px)}.template-list-panel{display:flex;flex-direction:column;background-color:var(--surface-color);border-radius:8px;border:1px solid var(--border-color);height:100%;padding:15px}.template-list-panel h4{margin:0 0 15px;text-align:center}.template-management-list-container{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:5px}.template-management-list-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;border-radius:6px;border:1px solid var(--border-color);background-color:var(--background-color);cursor:pointer;transition:all .2s ease-in-out}.template-management-list-item:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 2px 5px #0000000d}.template-management-list-item.active{background-color:var(--secondary-color);border-color:var(--primary-color)}.template-management-list-item .template-item-info{flex-grow:1;margin-right:10px}.template-editor-panel-wrapper{display:flex;flex-direction:column;height:100%;overflow:hidden}.template-editor-panel-wrapper .template-editor-view,.template-editor-panel-wrapper .template-editor-form{height:100%;display:flex;flex-direction:column}.template-editor-panel-wrapper .template-editor-layout{flex-grow:1;min-height:0}.template-editor-panel-wrapper .template-panel{min-height:0}.template-editor-view.section-container{background-color:var(--background-color)}.template-editor-form{padding:0}.template-editor-header{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:20px;background-color:var(--surface-color);padding:15px;border-radius:8px;border:1px solid var(--border-color)}.template-editor-header .form-group{flex-grow:1;margin:0}.template-editor-header .form-group label{font-size:.85em}.template-editor-header .form-group input{margin:0}.editor-main-actions{display:flex;gap:10px;flex-shrink:0}.template-editor-layout{display:grid;grid-template-columns:1fr auto 1fr;gap:20px;align-items:stretch}.template-panel{border:1px solid var(--border-color);border-radius:6px;padding:15px;display:flex;flex-direction:column;background-color:var(--surface-color)}.template-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-shrink:0}.template-panel-header h5{margin:0}.template-panel .assignment-table.table-wrapper{flex-grow:1;max-height:none}.assignment-actions.vertical{display:flex;flex-direction:column;justify-content:center;gap:10px}.advanced-question-select{padding:10px;margin-bottom:10px;background-color:var(--secondary-color);border-radius:4px;border:1px solid var(--border-color);flex-shrink:0}.advanced-question-select h6{margin-top:0;margin-bottom:10px;font-size:.9em;font-weight:600;color:var(--primary-color-dark)}.advanced-select-group{display:flex;align-items:center;gap:8px;margin-bottom:8px}.advanced-select-group label{font-weight:500;font-size:.9em;white-space:nowrap;width:100px}.advanced-select-group input[type=number],.advanced-select-group input[type=text]{flex-grow:1;padding:6px;border:1px solid var(--border-color);border-radius:4px;font-size:.9em}.assignment-table{max-height:400px;overflow-y:auto}.filter-grid{display:flex;flex-wrap:wrap;gap:15px;align-items:flex-end;padding:15px;background-color:var(--secondary-color);border-radius:6px;margin-bottom:20px}.filter-group{display:flex;flex-direction:column}.filter-group label{font-size:.85em;font-weight:500;margin-bottom:4px}.filter-group input,.filter-group select{padding:8px;border-radius:4px;border:1px solid var(--border-color)}#min-score{width:120px}.filter-grid .pagination-controls{flex-grow:1;justify-content:flex-end;margin-top:0}.template-selection-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px;max-height:300px;overflow-y:auto;padding:15px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--background-color)}.template-selection-card{display:flex;flex-direction:column;padding:15px;border-radius:6px;border:2px solid var(--border-color);background-color:var(--surface-color);cursor:pointer;text-align:left;transition:all .2s ease-in-out}.template-selection-card.status-all{background-color:var(--secondary-color);border-color:var(--primary-color)}.template-selection-card.status-some{background-color:#fef3c7;border-color:var(--warning-color);border-style:dashed}.template-card-name{font-weight:600}.template-card-count{font-size:.9em;color:#64748b;margin-top:4px}.assignment-mode{display:flex;gap:20px;margin-bottom:10px;padding:10px;background-color:var(--secondary-color);border-radius:6px}.theme-picker{display:flex;flex-wrap:wrap;gap:15px;margin-top:10px}.theme-swatch{display:flex;align-items:center;gap:10px;padding:8px 16px;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;background-color:var(--surface-color);transition:all .2s ease-in-out}.theme-swatch:hover{transform:translateY(-2px);box-shadow:0 2px 5px #00000014}.theme-swatch.active{border-color:var(--primary-color);background-color:var(--secondary-color);font-weight:600}.theme-swatch-color{width:24px;height:24px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.theme-swatch-label{font-size:1em}.settings-section{padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--border-color)}.settings-actions{margin-top:20px}@media(max-width:1024px){.class-management-layout,.template-management-layout,.assignment-layout{grid-template-columns:1fr}.admin-nav{overflow-x:auto;padding-bottom:2px}.admin-nav::-webkit-scrollbar{height:4px}.admin-nav::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.template-editor-layout{grid-template-columns:1fr;grid-template-rows:auto auto auto}.assignment-actions.vertical{flex-direction:row;margin:15px 0;justify-content:center}.assignment-actions.vertical button{transform:rotate(90deg)}.details-panel{min-height:200px}}@media(max-width:768px){.admin-header{flex-direction:column;gap:10px;padding:10px 15px}.filter-grid{flex-direction:column;align-items:stretch}.filter-controls,.filter-group-inline{flex-direction:column;align-items:stretch;gap:15px}.action-buttons{flex-direction:column;align-items:stretch}.action-buttons>div{display:flex;flex-direction:column;gap:10px}}.sidebar-header{height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{font-weight:800;font-size:1.2em;color:#6366f1;white-space:nowrap}.sidebar-collapse-btn{background:#ffffff1a;border:none;color:#fff;width:30px;height:30px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.sidebar-collapse-btn:hover{background:#fff3}.sidebar-nav{flex-grow:1;padding:20px 10px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;overflow-x:hidden}.sidebar-nav-btn{display:flex;align-items:center;padding:12px 15px;border-radius:8px;border:none;background:transparent;color:#94a3b8;cursor:pointer;transition:all .2s ease;text-align:left;width:100%;white-space:nowrap}.sidebar-nav-btn:hover{background:#ffffff0d;color:#fff}.sidebar-nav-btn.active{background:#6366f1;color:#fff;font-weight:600}.nav-icon{font-size:1.4em;min-width:30px;display:flex;justify-content:center}.nav-label{margin-left:10px;font-size:.95em;opacity:1;transition:opacity .2s}.admin-layout-wrapper.collapsed .nav-label{display:none}.sidebar-footer{padding:15px 10px;border-top:1px solid rgba(255,255,255,.1)}.btn-logout-sidebar{display:flex;align-items:center;padding:12px 15px;border-radius:8px;border:none;background:transparent;color:#f87171;cursor:pointer;width:100%;transition:background .2s}.btn-logout-sidebar:hover{background:#f871711a}.admin-top-bar{height:60px;background:var(--surface-color);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 25px;flex-shrink:0}.top-bar-title h2{margin:0;font-size:1.25em;color:var(--text-color)}.top-bar-actions{display:flex;align-items:center;gap:20px}.admin-profile-mini{font-size:.9em;font-weight:600;color:var(--text-color-secondary)}.general-stats{padding:25px;overflow-y:auto;height:100%}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--surface-color);padding:25px;border-radius:12px;border:1px solid var(--border-color);border-bottom:4px solid #E2E8F0;display:flex;align-items:center;gap:20px;box-shadow:0 4px 6px -1px #0000000d;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-3px);box-shadow:0 10px 15px -3px #0000001a}.stat-card.blue{border-bottom-color:#3b82f6}.stat-card.green{border-bottom-color:#10b981}.stat-card.orange{border-bottom-color:#f59e0b}.stat-card.red{border-bottom-color:#ef4444}.stat-card.purple{border-bottom-color:#8b5cf6}.stat-icon-wrapper{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.8em}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:2.1em;font-weight:900;color:var(--text-color);line-height:1}.stat-label{font-size:.9em;color:var(--text-muted);margin-top:8px;font-weight:500}.contact-settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}.chart-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:20px;margin-bottom:30px;min-height:280px}.chart-card{background:var(--surface-color);padding:20px;border-radius:12px;border:1px solid var(--border-color);height:320px;display:flex;flex-direction:column;box-shadow:0 4px 6px -1px #0000000d}.chart-card h4{margin-top:0;margin-bottom:15px;font-size:1.05em;color:var(--primary-color)}.result-stats-charts{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:25px}@media(max-width:1024px){.result-stats-charts{grid-template-columns:1fr}}.debug-log-container{position:fixed;width:500px;height:300px;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 5px 15px #0003;z-index:1001;display:flex;flex-direction:column;transition:width .2s,height .2s;font-size:14px}.debug-log-header{padding:8px 12px;background-color:var(--secondary-color);cursor:move;border-bottom:1px solid var(--border-color);border-top-left-radius:8px;border-top-right-radius:8px;display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none}.debug-log-header span{font-weight:600}.debug-log-toggle-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-color);padding:0 5px}.debug-log-content{flex-grow:1;overflow-y:auto;padding:10px;word-break:break-all;font-family:monospace}.debug-log-content>div{padding:2px 0;border-bottom:1px solid var(--border-color)}.debug-log-content>div:last-child{border-bottom:none}.debug-log-container.minimized{width:250px;height:40px;overflow:hidden;cursor:pointer!important}.debug-log-container.minimized .debug-log-content{display:none}
