*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;background:#F9FAFB;color:#111827}button,input,select,textarea{font-family:inherit}a{color:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#D1D5DB;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9CA3AF}.shell{background:#F9FAFB}.shell,.sidebar{display:flex;min-height:100vh}.sidebar{width:232px;background:#ffffff;border-right:1px solid #e5e7eb;flex-direction:column;position:fixed;top:0;left:0;z-index:50}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px 20px 16px;border-bottom:1px solid #f3f4f6}.sidebar-logo-icon{width:32px;height:32px;border-radius:8px;background:#4F46E5;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:15px;flex-shrink:0}.sidebar-logo-text{font-weight:700;font-size:15px;color:#111827;letter-spacing:-.3px}.sidebar-logo-sub{font-size:11px;color:#9CA3AF;margin-top:1px}.sidebar-section-label{font-size:10px;font-weight:700;color:#9CA3AF;letter-spacing:.08em;text-transform:uppercase;padding:16px 20px 6px}.sidebar-nav{padding:8px 12px;display:flex;flex-direction:column;gap:2px;flex:1 1}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;text-decoration:none;font-size:14px;font-weight:500;color:#6B7280;transition:background .12s,color .12s;cursor:pointer;border:none;background:none;font-family:inherit;width:100%;text-align:left}.sidebar-link:hover{background:#F9FAFB;color:#111827}.sidebar-link.active{background:#EEF2FF;color:#4F46E5;font-weight:600}.sidebar-link-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.sidebar-footer{padding:16px 20px;border-top:1px solid #f3f4f6}.sidebar-user{gap:10px}.sidebar-avatar,.sidebar-user{display:flex;align-items:center}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:#4F46E5;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.sidebar-user-name{font-size:13px;font-weight:600;color:#111827}.sidebar-user-role{font-size:11px;color:#9CA3AF}.main-content{margin-left:232px;flex:1 1;display:flex;flex-direction:column;min-height:100vh}.topbar{height:60px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:-webkit-sticky;position:sticky;top:0;z-index:40}.topbar-title{font-size:17px;font-weight:700;color:#111827;letter-spacing:-.3px}.topbar-sub{font-size:12px;color:#9CA3AF;margin-top:1px}.topbar-right{gap:12px}.topbar-badge,.topbar-right{display:flex;align-items:center}.topbar-badge{gap:6px;padding:5px 12px;background:#F0FDF4;border:1px solid #bbf7d0;border-radius:20px;font-size:12px;font-weight:600;color:#15803D}.topbar-badge-dot{width:6px;height:6px;border-radius:50%;background:#22C55E}.page-content{padding:28px;flex:1 1}.card{border:1px solid #e5e7eb;border-radius:16px;padding:24px;box-shadow:0 1px 3px rgba(0,0,0,.04)}.card,.card-sm{background:#fff}.card-sm{border:1px solid #e5e7eb;border-radius:12px;padding:16px 18px;box-shadow:0 1px 2px rgba(0,0,0,.03)}.kpi-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:20px 22px;transition:box-shadow .15s}.kpi-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.06)}.kpi-value{font-size:36px;font-weight:800;line-height:1;margin-bottom:6px}.kpi-label{font-size:12px;font-weight:600;color:#6B7280;letter-spacing:.03em;text-transform:uppercase;margin-bottom:4px}.kpi-sub{font-size:12px;color:#9CA3AF}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:38px;padding:0 16px;border-radius:9px;border:none;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .12s,transform .1s,box-shadow .12s;text-decoration:none;white-space:nowrap}.btn:hover{opacity:.88}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#4F46E5;color:#fff;box-shadow:0 1px 4px rgba(79,70,229,.25)}.btn-primary:hover{box-shadow:0 3px 10px rgba(79,70,229,.3);opacity:1}.btn-success{background:#22C55E;color:#fff}.btn-danger{background:#EF4444;color:#fff}.btn-ghost{background:#F9FAFB;border:1px solid #e5e7eb;color:#374151}.btn-ghost:hover{background:#F3F4F6;opacity:1}.btn-lg{height:48px;padding:0 24px;font-size:15px;border-radius:12px}.btn-sm{height:32px;padding:0 12px;font-size:13px;border-radius:7px}.input{width:100%;height:42px;border-radius:9px;border:1px solid #d1d5db;background:#F9FAFB;font-size:14px;padding:0 14px;outline:none;font-family:inherit;color:#111827;transition:border-color .12s,box-shadow .12s}.input:focus{border-color:#4F46E5;box-shadow:0 0 0 3px rgba(79,70,229,.1);background:#fff}.input::placeholder{color:#9CA3AF}.label{display:block;font-size:12px;font-weight:600;color:#374151;margin-bottom:6px}.badge,.label{letter-spacing:.03em}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}.badge-high{background:#DCFCE7;color:#15803D}.badge-medium{background:#FEF9C3;color:#A16207}.badge-low{background:#FEE2E2;color:#B91C1C}.badge-indigo{background:#EEF2FF;color:#4338CA}.badge-gray{background:#F3F4F6;color:#6B7280}.badge-done{background:#DCFCE7;color:#15803D}.badge-pending{background:#FEF9C3;color:#A16207}.badge-failed{background:#FEE2E2;color:#B91C1C}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-size:15px;font-weight:700;color:#111827}.section-sub{font-size:13px;color:#9CA3AF;margin-top:2px}.table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid #e5e7eb}.table{width:100%;border-collapse:collapse;font-size:13px}.table thead th{background:#F9FAFB;padding:10px 14px;font-weight:600;color:#6B7280;text-align:left;border-bottom:1px solid #e5e7eb;white-space:nowrap;font-size:11px;letter-spacing:.04em;text-transform:uppercase}.table tbody td{padding:12px 14px;border-bottom:1px solid #f3f4f6;color:#374151;vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:#FAFAFA}.score-circle{border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}.upload-zone{border:2px dashed #d1d5db;border-radius:12px;padding:32px 20px;text-align:center;cursor:pointer;background:#F9FAFB;transition:border-color .15s,background .15s}.upload-zone:hover{border-color:#4F46E5;background:#F5F3FF}.upload-zone.active{border-color:#4F46E5;background:#EEF2FF}@keyframes os_spin{to{transform:rotate(1turn)}}.spinner{border-radius:50%;animation:os_spin .7s linear infinite;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:#9CA3AF}.empty-state-icon{font-size:36px;margin-bottom:12px}.empty-state-title{font-size:15px;font-weight:600;color:#6B7280;margin-bottom:6px}.empty-state-sub{font-size:13px}.alert{border-radius:10px;padding:13px 16px;font-size:14px}.alert-error{background:#FEF2F2;border:1px solid #fecaca;color:#991B1B}.alert-success{background:#F0FDF4;border:1px solid #bbf7d0;color:#14532D}.alert-info{background:#EEF2FF;border:1px solid #c7d2fe;color:#3730A3}.tabs{display:flex;border-bottom:1px solid #e5e7eb;margin-bottom:20px;gap:0}.tab-btn{padding:10px 18px;background:none;font-family:inherit;font-size:14px;font-weight:500;color:#6B7280;cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s}.tab-btn.active{color:#4F46E5;border-bottom-color:#4F46E5;font-weight:600}.tab-btn:hover{color:#374151}.feedback-block{border-radius:10px;padding:14px 16px;margin-bottom:10px}.feedback-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;gap:6px}.feedback-text{font-size:14px;line-height:1.7}.progress-bar{height:5px;border-radius:3px;background:#E5E7EB;overflow:hidden;margin-top:4px}.progress-fill{height:100%;border-radius:3px;transition:width .3s}@media (max-width:768px){.sidebar{display:none}.main-content{margin-left:0}}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .12s ease}.modal-box{border-radius:16px;max-width:520px}.modal-box,.modal-box-sm{background:#fff;padding:28px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.25);animation:slideUp .15s ease}.modal-box-sm{border-radius:14px;max-width:380px;text-align:center}.toast{position:fixed;top:20px;right:20px;z-index:999;padding:12px 18px;border-radius:10px;font-size:14px;font-weight:600;color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.18);display:flex;align-items:center;gap:8px;animation:slideIn .2s ease;max-width:340px}.toast-success{background:#15803D}.toast-error{background:#B91C1C}.toast-info{background:#4F46E5}.toast-warning{background:#A16207}.confirm-icon{font-size:40px;margin-bottom:12px}.confirm-title{font-size:17px;font-weight:700;color:#111827;margin-bottom:8px}.confirm-body{font-size:14px;color:#6B7280;margin-bottom:24px;line-height:1.6}.alert-warning{background:#FFFBEB;border:1px solid #fde68a;color:#92400E}.form-row{display:grid;grid-gap:14px;gap:14px;margin-bottom:14px}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}.form-full{grid-column:1/-1}.form-label{display:block;color:#374151;letter-spacing:.03em;margin-bottom:5px;text-transform:uppercase}.chip,.form-label{font-size:12px;font-weight:600}.chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px}.chip-blue{background:#EEF2FF;color:#4F46E5}.chip-yellow{background:#FEF9C3;color:#A16207}.chip-green{background:#DCFCE7;color:#15803D}.chip-gray{background:#F3F4F6;color:#6B7280}.chip-remove{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;font-size:14px;padding:0;line-height:1}.chip-remove:hover{opacity:1}.role-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.role-owner{background:#EEF2FF;color:#4338CA}.role-admin{background:#DCFCE7;color:#15803D}.role-teacher{background:#FEF9C3;color:#A16207}.role-viewer{background:#F3F4F6;color:#6B7280}.danger-zone{border:1px solid #fecaca;border-radius:12px;padding:20px;background:#FFF5F5}.danger-zone-title{font-size:14px;font-weight:700;color:#991B1B;margin-bottom:6px}.danger-zone-desc{font-size:13px;color:#B91C1C;margin-bottom:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideIn{0%{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}