:root{--color-primary:#39a8ff;--color-primary-deep:#0099e7;--color-primary-soft:#ebf7fe;--color-success:#5cb85c;--color-warning:#f0ad4e;--color-danger:#d9534f;--color-accent:#ffe010;--color-accent-text:#c36323;--color-text:#333;--color-text-secondary:#666;--color-text-muted:#999;--color-border:#e6e6e6;--color-border-light:#eee;--color-bg-page:#f7fafc;--color-bg-card:#fff;--color-bg-soft:#fafafa;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-pill:999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:32px;--space-8:40px;--shadow-soft:0 4px 16px #39a8ff14;--shadow-popup:0 12px 32px #3333331f;--font-family:"Microsoft YaHei", "PingFang SC", "Hiragino Sans GB", "Noto Sans SC", sans-serif;--font-size-display:32px;--font-size-h1:28px;--font-size-h2:22px;--font-size-h3:18px;--font-size-h4:16px;--font-size-body:14px;--font-size-small:12px;--line-height-tight:1.4;--line-height-normal:1.6;--line-height-loose:1.8;--sidebar-width:220px;--header-height:56px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{background-color:var(--color-bg-page);color:var(--color-text);font-family:var(--font-family);font-size:var(--font-size-body);line-height:var(--line-height-normal);min-height:100vh}body{min-width:320px}a{color:var(--color-primary);text-decoration:none;transition:color .2s}a:hover{color:var(--color-primary-deep)}button,input,select,textarea{font:inherit}button{background:0 0;border:none}ul,ol{list-style:none}.page-container{width:100%;min-width:0;min-height:100vh;display:flex}.sidebar{background:var(--color-bg-card);border-right:1px solid var(--color-border-light);width:var(--sidebar-width);z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--color-border-light);height:var(--header-height);padding:0 var(--space-5);align-items:center;display:flex}.sidebar-logo h1{color:var(--color-primary);font-size:var(--font-size-h4);font-weight:600}.sidebar-nav{padding:var(--space-4) 0;flex:1;overflow-y:auto}.nav-group{margin-bottom:var(--space-4)}.nav-group-title{color:var(--color-text-muted);font-size:var(--font-size-small);padding:var(--space-2) var(--space-5);font-weight:500}.nav-item,.nav-button{color:var(--color-text-secondary);cursor:pointer;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);width:100%;transition:all .2s;display:flex}.nav-button{text-align:left}.nav-item:hover,.nav-button:hover{background:var(--color-bg-soft);color:var(--color-text)}.nav-item.active{background:var(--color-primary-soft);color:var(--color-primary);font-weight:500}.nav-item-icon{justify-content:center;align-items:center;width:20px;height:20px;display:flex}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-width:0;display:flex}.header{background:var(--color-bg-card);border-bottom:1px solid var(--color-border-light);height:var(--header-height);padding:0 var(--space-6);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.mobile-menu-button{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;display:none}.mobile-menu-button span{background:currentColor;border-radius:999px;width:18px;height:2px;display:block}.mobile-nav-layer{display:none}.mobile-nav-backdrop{z-index:900;background:#0f172a73;position:fixed;inset:0}.mobile-nav-drawer{background:var(--color-bg-card);max-width:calc(100vw - 48px);width:var(--sidebar-width);z-index:901;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:18px 0 36px #0f172a2e}.mobile-nav-header{border-bottom:1px solid var(--color-border-light);height:var(--header-height);justify-content:space-between;align-items:center;display:flex}.mobile-nav-logo{border-bottom:0;flex:1}.mobile-nav-close{color:var(--color-text-muted);cursor:pointer;height:var(--header-height);width:var(--header-height);justify-content:center;align-items:center;font-size:28px;display:flex}.header-title{font-size:var(--font-size-h4);font-weight:600}.header-right,.header-left,.user-info{align-items:center;gap:var(--space-3);display:flex}.user-info{border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3)}.user-avatar,.avatar{background:var(--color-primary-soft);color:var(--color-primary);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-weight:500;display:flex}.avatar-lg{font-size:var(--font-size-h3);width:56px;height:56px}.content-area{min-width:0;padding:var(--space-6);flex:1}.page-header{margin-bottom:var(--space-6)}.page-title{font-size:var(--font-size-h1);margin-bottom:var(--space-2);font-weight:600}.page-desc{color:var(--color-text-secondary)}.grid{gap:var(--space-5);min-width:0;display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mt-4{margin-top:var(--space-4)}.p-4{padding:var(--space-4)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.font-bold{font-weight:600}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.sidebar{display:none}.mobile-menu-button{flex:none;display:inline-flex}.mobile-nav-layer{display:block}.main-content{width:100%;margin-left:0}.header{gap:var(--space-3);padding:0 var(--space-4)}.header-left{min-width:0}.header-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.user-name{display:none}.content-area{padding:var(--space-4)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.btn{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);white-space:nowrap;border:1px solid #0000;justify-content:center;transition:all .2s;display:inline-flex}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-deep);color:#fff}.btn-default{background:var(--color-bg-card);border-color:var(--color-border);color:var(--color-text)}.btn-default:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-text{color:var(--color-primary);padding:var(--space-1) var(--space-2)}.btn-sm{font-size:var(--font-size-small);padding:var(--space-1) var(--space-3)}.btn-lg{font-size:var(--font-size-h4);padding:var(--space-3) var(--space-6)}.btn-block{width:100%}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.checkbox-inline{color:var(--color-text-secondary);font-size:var(--font-size-small);align-items:center;gap:var(--space-2);display:inline-flex}.checkbox-inline input{margin:0}.input-label{font-weight:500}.input-label.required:after{color:var(--color-danger);content:"*";margin-left:var(--space-1)}.input,.textarea{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);min-height:36px;padding:0 var(--space-3);width:100%;transition:all .2s}.textarea{min-height:100px;padding:var(--space-3);resize:vertical}.input:focus,.textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-soft);outline:none}.input-lg{min-height:44px}.password-input-wrap{width:100%;position:relative}.password-input-wrap .password-input{padding-right:44px}.password-toggle-button{border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;height:28px;right:var(--space-2);background:0 0;border:0;justify-content:center;align-items:center;width:28px;padding:0;transition:background-color .2s,color .2s,box-shadow .2s;display:inline-flex;position:absolute;top:50%;transform:translateY(-50%)}.password-toggle-button:hover:not(:disabled){background:var(--color-bg-soft);color:var(--color-primary)}.password-toggle-button:focus-visible{box-shadow:0 0 0 2px var(--color-primary-soft);color:var(--color-primary);outline:none}.password-toggle-button:disabled{cursor:not-allowed;opacity:.5}.input-with-action{align-items:center;gap:var(--space-2);display:flex}.input-with-action .input{flex:1}.input-action{flex-shrink:0;min-height:36px}.input-hint{color:var(--color-text-muted);font-size:var(--font-size-small);line-height:1.6}.segmented-control{background:var(--color-bg-soft);border:1px solid var(--color-border);border-radius:var(--radius-pill);gap:var(--space-1);padding:4px;display:inline-flex}.segmented-option{border-radius:var(--radius-pill);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-small);min-width:88px;padding:var(--space-2) var(--space-4);background:0 0;border:none;font-weight:600;transition:background-color .2s,color .2s,box-shadow .2s}.segmented-option.active{background:#fff;box-shadow:0 1px 2px #0f172a14}.segmented-option.active.add{color:var(--color-success)}.segmented-option.active.subtract{color:var(--color-danger)}.card,.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.card{min-width:0;padding:var(--space-5)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;min-width:0;display:flex}.card-title{font-size:var(--font-size-h3);font-weight:600}.card-body{margin-top:var(--space-4);min-width:0}.card-body-tight{max-width:100%;margin-top:0;padding:0;overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th,.table td{border-bottom:1px solid var(--color-border-light);padding:var(--space-3) var(--space-4);text-align:left;vertical-align:top}.table th{background:var(--color-bg-soft);color:var(--color-text-secondary);font-size:var(--font-size-small);font-weight:500}.table tr:hover td{background:var(--color-bg-soft)}.tag{border-radius:var(--radius-sm);font-size:var(--font-size-small);align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);display:inline-flex}.tag-default{background:var(--color-bg-soft);color:var(--color-text-secondary)}.tag-primary{background:var(--color-primary-soft);color:var(--color-primary)}.tag-success{color:var(--color-success);background:#e8f5e9}.tag-warning{color:var(--color-warning);background:#fff8e1}.tag-danger{color:var(--color-danger);background:#ffebee}.tabs{border-bottom:1px solid var(--color-border);gap:var(--space-5);display:flex}.tab-item{color:var(--color-text-secondary);cursor:pointer;padding:var(--space-3) 0;position:relative}.tab-item.active{color:var(--color-primary);font-weight:500}.tab-item.active:after{background:var(--color-primary);content:"";height:2px;position:absolute;bottom:-1px;left:0;right:0}.pagination{align-items:center;gap:var(--space-2);display:flex}.pagination-item{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;justify-content:center;align-items:center;min-width:32px;height:32px;display:flex}.pagination-item.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.stat-card{padding:var(--space-5)}.stat-card-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.stat-card-title{color:var(--color-text-secondary)}.stat-card-icon{border-radius:var(--radius-md);font-size:var(--font-size-small);justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-card-icon.primary{background:var(--color-primary-soft);color:var(--color-primary)}.stat-card-icon.success{color:var(--color-success);background:#e8f5e9}.stat-card-icon.warning{color:var(--color-warning);background:#fff8e1}.stat-card-icon.danger{color:var(--color-danger);background:#ffebee}.stat-card-value{font-size:var(--font-size-display);font-weight:600;line-height:1.2}.filter-bar{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-4);flex-wrap:wrap;display:flex}.filter-bar>*{max-width:100%}.modal-overlay{opacity:0;pointer-events:none;z-index:1000;background:#00000073;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:fixed;inset:0}.modal-overlay.show{opacity:1;pointer-events:auto}.modal{background:var(--color-bg-card);border-radius:var(--radius-lg);width:calc(100% - 32px);max-width:560px;max-height:90vh;overflow:hidden}.modal-header,.modal-footer{border-bottom:1px solid var(--color-border);padding:var(--space-5);justify-content:space-between;align-items:center;display:flex}.modal-footer{border-bottom:0;border-top:1px solid var(--color-border);gap:var(--space-3);justify-content:flex-end}.modal-body{max-height:calc(90vh - 148px);padding:var(--space-5);overflow-y:auto}@media (width<=768px){.card{padding:var(--space-4)}.card-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.card-header>*{max-width:100%}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .input,.filter-bar .btn,.filter-bar select{width:100%}.filter-bar .flex{flex-wrap:wrap;width:100%;margin-left:0!important}.filter-bar .flex .btn{flex:140px}.student-summary-grid{gap:var(--space-2);grid-template-columns:repeat(4,minmax(0,1fr))}.student-summary-grid .stat-card{min-width:0;padding:var(--space-2)}.student-summary-grid .stat-card-title{overflow-wrap:anywhere;font-size:12px;line-height:1.2}.student-summary-grid .stat-card-value{overflow-wrap:anywhere;margin-top:4px;font-size:22px;line-height:1.1}.tabs{gap:var(--space-4);padding-bottom:1px;overflow-x:auto}.tab-item{flex:none}.pagination{flex-wrap:wrap}.modal{width:calc(100% - 24px);max-height:calc(100vh - 24px)}.modal-header,.modal-footer{padding:var(--space-4)}.modal-footer{flex-wrap:wrap}.modal-footer .btn{flex:120px}.modal-body{max-height:calc(100vh - 132px);padding:var(--space-4)}}.modal-title{font-size:var(--font-size-h3);font-weight:600}.modal-close{color:var(--color-text-muted);cursor:pointer;font-size:24px}.confirm-dialog-summary{border:1px solid var(--color-primary);border-radius:var(--radius-md);align-items:flex-start;gap:var(--space-3);padding:var(--space-4);display:flex}.confirm-dialog-summary.info{background:var(--color-primary-soft);border-color:var(--color-primary)}.confirm-dialog-summary.warning{border-color:var(--color-warning);background:#fff8e1}.confirm-dialog-summary.danger{border-color:var(--color-danger);background:#ffebee}.confirm-dialog-icon{background:var(--color-primary);color:#fff;font-size:var(--font-size-small);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-weight:700;line-height:1;display:inline-flex}.confirm-dialog-summary.warning .confirm-dialog-icon{background:var(--color-warning)}.confirm-dialog-summary.danger .confirm-dialog-icon{background:var(--color-danger)}.confirm-dialog-description{color:var(--color-text);line-height:var(--line-height-normal)}.confirm-dialog-detail{margin-top:var(--space-4)}.alert{border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4)}.alert-info{background:var(--color-primary-soft);border:1px solid var(--color-primary)}.alert-warning{border:1px solid var(--color-warning);background:#fff8e1}.alert-danger{border:1px solid var(--color-danger);background:#ffebee}.student-card{border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:var(--space-3);padding:var(--space-4);display:flex}.student-card-info{flex:1}.student-card-name{font-weight:500}.student-card-meta{color:var(--color-text-secondary);font-size:var(--font-size-small)}.record-item{border-bottom:1px solid var(--color-border-light);gap:var(--space-3);padding:var(--space-4);display:flex}.record-item:last-child{border-bottom:none}.record-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.record-icon.add{color:var(--color-success);background:#e8f5e9}.record-icon.subtract{color:var(--color-danger);background:#ffebee}.record-content{flex:1}.record-title{font-weight:500}.record-desc,.record-meta{color:var(--color-text-secondary);font-size:var(--font-size-small)}.record-meta{gap:var(--space-3);margin-top:var(--space-2);display:flex}.record-score.add{color:var(--color-success)}.record-score.subtract{color:var(--color-danger)}.toast{background:var(--color-text);border-radius:var(--radius-md);box-shadow:var(--shadow-popup);color:#fff;padding:var(--space-3) var(--space-4)}.toast-success{background:var(--color-success)}.toast-danger{background:var(--color-danger)}.toast-warning{background:var(--color-warning)}.brand-mark{background:var(--color-primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;display:inline-flex}.brand-mark-large{width:36px;height:36px}.header-bar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--space-3) var(--space-5);z-index:100;background:#fffffff2;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 16px #3333330d}.header-logo{color:var(--color-primary);align-items:center;gap:var(--space-2);font-weight:600;display:flex}.login-btn{background:var(--color-primary);border-radius:var(--radius-md);color:#fff;padding:var(--space-2) var(--space-5);font-weight:500;display:inline-block}.login-btn:hover{color:#fff}.public-header{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-deep) 100%);color:#fff;padding:120px var(--space-6) var(--space-6);text-align:center}.public-header h1{font-size:var(--font-size-h1);margin-bottom:var(--space-2)}.public-content{max-width:960px;padding:var(--space-5);margin:0 auto}.class-info-card{background:var(--color-bg-card);border-radius:var(--radius-lg);margin-bottom:var(--space-5);padding:var(--space-5);box-shadow:0 10px 24px #39a8ff14}.class-info-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.class-info-title{font-size:var(--font-size-h3);font-weight:600}.class-info-stats{gap:var(--space-3);grid-template-columns:repeat(5,1fr);display:grid}.class-stat-item{background:var(--color-bg-soft);border-radius:var(--radius-md);padding:var(--space-3);text-align:center}.class-stat-value{color:var(--color-primary);font-size:var(--font-size-h3);font-weight:600}.class-stat-label{color:var(--color-text-secondary);font-size:var(--font-size-small);margin-top:var(--space-1)}.filter-tabs{gap:var(--space-2);flex-wrap:wrap;display:flex}.filter-tab{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;padding:var(--space-2) var(--space-4);transition:all .2s}.filter-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.ranking-table{border-collapse:collapse;width:100%}.ranking-table th,.ranking-table td{border-bottom:1px solid var(--color-border);padding:var(--space-3) var(--space-4);text-align:center}.ranking-table th{background:var(--color-bg-soft);color:var(--color-text-secondary);font-weight:600}.rank-badge{border-radius:999px;justify-content:center;align-items:center;width:32px;height:32px;font-weight:600;display:inline-flex}.rank-badge.gold{color:#fff;background:linear-gradient(135deg,gold,orange)}.rank-badge.silver{color:#fff;background:linear-gradient(135deg,silver,#a0a0a0)}.rank-badge.bronze{color:#fff;background:linear-gradient(135deg,#cd7f32,#b87333)}.rank-badge.normal{background:var(--color-bg-soft);color:var(--color-text-secondary)}.score-bar{background:var(--color-bg-soft);height:8px;margin-left:var(--space-2);border-radius:999px;width:100px;display:inline-block;overflow:hidden}.score-bar-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-primary-deep));height:100%;display:block}.login-prompt{background:var(--color-bg-soft);border-radius:var(--radius-lg);margin-top:var(--space-5);padding:var(--space-5);text-align:center}.login-page{background:linear-gradient(135deg, var(--color-primary-soft) 0%, var(--color-bg-page) 100%);min-height:100vh;padding:var(--space-6);justify-content:center;align-items:center;display:flex}.login-container{width:100%;max-width:400px}.login-container-wide{max-width:600px}.login-card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-popup);padding:var(--space-7)}.login-actions{margin-bottom:var(--space-4);justify-content:flex-start;display:flex}.login-back-link{color:var(--color-primary);font-size:var(--font-size-small);text-decoration:none}.login-back-link:hover{text-decoration:underline}.login-header{margin-bottom:var(--space-6);text-align:center}.login-logo{background:var(--color-primary);border-radius:var(--radius-md);color:#fff;height:60px;margin:0 auto var(--space-4);justify-content:center;align-items:center;width:60px;display:flex}.login-title{font-size:var(--font-size-h2);margin-bottom:var(--space-2);font-weight:600}.login-subtitle{color:var(--color-text-secondary)}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.login-note{background:var(--color-bg-soft);border-radius:var(--radius-md);margin-top:var(--space-4);padding:var(--space-4)}.password-page{min-height:100vh;padding:var(--space-6);justify-content:center;align-items:center;display:flex}.password-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);max-width:520px;padding:var(--space-6);width:100%}.toolbar-row{align-items:end;gap:var(--space-4);flex-wrap:wrap;min-width:0;display:flex}.toolbar-field{min-width:180px}.teacher-statistics-toolbar{align-items:end;gap:var(--space-4);flex-wrap:wrap;min-width:0;display:flex}.teacher-statistics-summary-row{gap:var(--space-3);display:flex}.teacher-statistics-summary-item{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:0;padding:var(--space-4);text-align:center;flex:1}.teacher-statistics-summary-value{color:var(--color-primary);font-size:var(--font-size-h2);overflow-wrap:anywhere;font-weight:600;line-height:1.2}.teacher-statistics-summary-label{color:var(--color-text-secondary);font-size:var(--font-size-small);margin-top:var(--space-1)}.teacher-distribution-list{gap:var(--space-3);flex-direction:column;display:flex}.teacher-distribution-meta{align-items:center;gap:var(--space-3);margin-bottom:var(--space-1);justify-content:space-between;display:flex}.teacher-distribution-bar{background:var(--color-bg-soft);border-radius:var(--radius-sm);height:24px;display:flex;overflow:hidden}.teacher-distribution-segment{color:#fff;font-size:var(--font-size-small);justify-content:center;align-items:center;min-width:0;height:100%;font-weight:600;transition:width .2s;display:flex}.teacher-distribution-segment.primary,.teacher-trend-bar.positive{background:var(--color-primary)}.teacher-distribution-segment.success{background:var(--color-success)}.teacher-distribution-segment.warning{background:var(--color-warning)}.teacher-distribution-segment.danger,.teacher-trend-bar.negative{background:var(--color-danger)}.teacher-trend-chart{align-items:flex-end;gap:var(--space-3);min-width:0;height:220px;display:flex}.teacher-trend-item{align-items:center;gap:var(--space-1);flex-direction:column;flex:1;justify-content:flex-end;min-width:0;height:100%;display:flex}.teacher-trend-value,.teacher-trend-label{font-size:var(--font-size-small);overflow-wrap:anywhere;max-width:100%;font-weight:600;line-height:1.2}.teacher-trend-label{color:var(--color-text-secondary);font-weight:400}.teacher-trend-bar{border-radius:var(--radius-sm) var(--radius-sm) 0 0;width:100%;min-height:8px;max-height:160px}.empty-state{color:var(--color-text-secondary);align-items:center;min-height:220px;display:flex}.toolbar-actions{flex:1;min-width:300px}.toolbar-button-wrap{flex-wrap:wrap}.task-list{gap:var(--space-3);flex-direction:column;display:flex}.task-item{align-items:center;gap:var(--space-3);display:flex}.task-dot{background:var(--color-primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.rules-span-2{grid-column:span 2}.rules-content-row{gap:var(--space-4);margin-bottom:var(--space-5);display:flex}.rules-content-panel{flex:1;min-width:0}.panel-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.panel-title{font-size:var(--font-size-h4);font-weight:600}.rule-category{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-3)}.rule-category-header{border-bottom:1px solid var(--color-border);padding:var(--space-3) var(--space-4);justify-content:space-between;align-items:center;display:flex}.rule-category-title{align-items:center;gap:var(--space-2);font-weight:600;display:flex}.rule-category-badge{background:var(--color-primary-soft);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--font-size-small);padding:var(--space-1) var(--space-2)}.rule-item{border-bottom:1px solid var(--color-border);padding:var(--space-3) var(--space-4);justify-content:space-between;align-items:center;display:flex}.rule-item:last-child{border-bottom:none}.rule-item-name{font-size:var(--font-size-small);font-weight:500}.rule-item-score{font-size:var(--font-size-small);font-weight:600}.rule-item-score.add{color:var(--color-success)}.rule-item-score.subtract{color:var(--color-danger)}.committee-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-2);padding:var(--space-3)}.committee-card-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.committee-name{align-items:center;gap:var(--space-2);font-weight:600;display:flex}.committee-icon{background:var(--color-primary-soft);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.committee-rules{gap:var(--space-1);flex-wrap:wrap;display:flex}.committee-rule-tag{background:var(--color-bg-soft);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-small);padding:var(--space-1) var(--space-2)}.committee-rule-tag.primary{background:var(--color-primary-soft);color:var(--color-primary)}.teacher-record-tabs-row{border-bottom:1px solid var(--color-border);gap:var(--space-5);display:flex}.teacher-record-tabs-row .tab-item{color:var(--color-text-secondary);cursor:pointer;padding:var(--space-3) 0;position:relative}.teacher-record-tabs-row .tab-item.active{color:var(--color-primary);font-weight:500}.teacher-record-tabs-row .tab-item.active:after{background:var(--color-primary);content:"";height:2px;position:absolute;bottom:-1px;left:0;right:0}.teacher-record-tabs-row .tab-item:disabled{color:var(--color-text-muted);cursor:not-allowed}.teacher-direct-score-panel{display:block}.teacher-direct-score-records{margin-top:var(--space-5)}.committee-submit-card{min-height:100%}.committee-top-layout{gap:var(--space-4);grid-template-columns:minmax(0,1fr);display:grid}.committee-permission-card{align-self:start}.committee-permission-bottom-card{margin-top:var(--space-5)}.committee-permission-summary{gap:var(--space-3);display:grid}.committee-permission-summary-compact .profile-field{padding:var(--space-3);background:#fafbfd}.committee-permission-stats{gap:var(--space-2);flex-wrap:wrap;display:flex}.committee-permission-pill{border-radius:var(--radius-pill);font-size:var(--font-size-small);padding:6px var(--space-3);font-weight:600}.committee-permission-pill.add{color:#f97316;background:#fff4d6}.committee-permission-pill.subtract{color:#2563eb;background:#e8f2ff}.committee-permission-rule-columns{gap:var(--space-4);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.committee-permission-rule-column{padding:var(--space-3);background:#f8fbff;border:1px solid #94a3b838;border-radius:12px}.committee-permission-rule-column.add{background:#fffbeb}.committee-permission-rule-column.subtract{background:#eff6ff}.committee-permission-rule-column-title{font-size:var(--font-size-small);margin-bottom:var(--space-2);font-weight:700}.committee-score-type-tabs{width:fit-content}.committee-submit-toolbar{align-items:center;gap:var(--space-3);justify-content:space-between;display:flex}.committee-selected-panel,.committee-common-panel{padding:var(--space-3);background:#f8fbff;border:1px solid #94a3b833;border-radius:16px}.committee-selected-panel-header{align-items:center;gap:var(--space-3);justify-content:space-between;display:flex}.committee-selected-title-line{align-items:baseline;gap:var(--space-2);flex-wrap:wrap;display:flex}.committee-panel-label{color:var(--color-text-secondary);font-size:var(--font-size-small)}.committee-panel-value{color:var(--color-text);font-size:var(--font-size-body);font-weight:700;line-height:1.2}.committee-selected-chips,.committee-common-rules{gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.committee-selected-chip,.committee-common-rule{border-radius:var(--radius-pill);color:var(--color-text);cursor:pointer;font-size:var(--font-size-small);padding:6px var(--space-3);white-space:nowrap;background:#fff;border:1px solid #94a3b83d;font-weight:600}.committee-common-rule.active{background:var(--color-primary-soft);color:var(--color-primary);border-color:#2563eb47}.committee-rule-dropdown{position:relative}.committee-rule-dropdown.empty{border-radius:var(--radius-md);color:var(--color-text-muted);padding:var(--space-3);background:#fff;border:1px solid #94a3b847}.committee-rule-select{border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;align-items:center;gap:var(--space-2);min-height:44px;padding:var(--space-2) var(--space-3);text-align:left;background:#fff;border:1px solid #94a3b847;justify-content:space-between;width:100%;display:flex}.committee-rule-select:hover{border-color:#2563eb57}.committee-rule-menu{border-radius:var(--radius-md);z-index:30;background:#fff;border:1px solid #94a3b847;gap:2px;max-height:240px;margin-top:4px;padding:4px;display:grid;position:absolute;left:0;right:0;overflow-y:auto;box-shadow:0 16px 32px #0f172a24}.committee-rule-option{border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;align-items:center;gap:var(--space-2);min-height:44px;padding:var(--space-2) var(--space-3);text-align:left;background:#fff;border:1px solid #0000;justify-content:space-between;width:100%;display:flex}.committee-rule-option:hover{border-color:#2563eb57}.committee-rule-option.active{background:var(--color-primary-soft);border-color:#2563eb75;box-shadow:0 0 0 1px #2563eb14}.committee-rule-name{font-size:var(--font-size-small);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:700;overflow:hidden}.committee-rule-score{border-radius:var(--radius-pill);font-size:var(--font-size-small);flex-shrink:0;padding:5px 8px;font-weight:800;line-height:1}.committee-rule-caret{color:var(--color-text-muted);font-size:var(--font-size-small);flex-shrink:0;font-weight:700}.committee-rule-select.add .committee-rule-score,.committee-rule-option.add .committee-rule-score{color:#15803d;background:#16a34a1f}.committee-rule-select.subtract .committee-rule-score,.committee-rule-option.subtract .committee-rule-score{color:#b91c1c;background:#dc26261a}.committee-inline-link{align-self:flex-start;padding-left:0;padding-right:0}.committee-remark-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.committee-remark-textarea{resize:vertical;min-height:44px}.committee-remark-grid{align-items:stretch;gap:var(--space-3);grid-template-columns:minmax(0,1fr) minmax(180px,.45fr);display:grid}.committee-time-field{gap:var(--space-2);flex-direction:column;display:flex}.committee-submit-inline{display:flex}.committee-submit-sticky{align-items:center;gap:var(--space-3);bottom:0;left:var(--sidebar-width);padding:var(--space-3) var(--space-6);z-index:20;background:#fffffff0;border-top:1px solid #94a3b833;justify-content:space-between;display:none;position:sticky;box-shadow:0 -8px 20px #0f172a14}.committee-submit-sticky-meta{flex-direction:column;gap:2px;display:flex}.committee-student-section{margin-bottom:var(--space-5)}.committee-student-header-main{min-width:0}.committee-student-pagination{align-items:center;gap:var(--space-2);flex-shrink:0;margin-left:auto;display:flex}.committee-student-pagination span{color:var(--color-text-secondary);font-size:var(--font-size-small);text-align:center;min-width:44px;font-weight:700}.committee-student-grid{gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(88px,1fr));display:grid}.committee-student-card{text-align:center;background:linear-gradient(#f9fbff 0%,#fff 100%);border:1px solid #94a3b847;border-radius:12px;flex-direction:column;padding:0;transition:background .2s,transform .2s,box-shadow .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.committee-student-card:hover{border-color:#3b82f65c;transform:translateY(-1px);box-shadow:0 8px 16px #0f172a12}.committee-student-card.selected{background:linear-gradient(#f0fdf4 0%,#fff 100%);border-color:#16a34ac2;box-shadow:0 0 0 2px #16a34a2e,0 8px 16px #15803d1a}.committee-student-selected-marker{color:#fff;pointer-events:none;z-index:1;background:#16a34a;border-bottom-left-radius:8px;align-items:center;gap:4px;padding:4px 6px;font-size:10px;font-weight:700;line-height:1;display:inline-flex;position:absolute;top:0;right:0}.committee-student-main{color:inherit;cursor:pointer;padding:18px var(--space-2) 0;flex-direction:column;align-items:center;width:100%;display:flex}.committee-student-avatar-wrap{height:42px;margin-bottom:var(--space-2);border:2px solid #bfe1ff;border-radius:50%;justify-content:center;align-items:center;width:42px;display:flex}.committee-student-avatar{color:#2563eb;background:linear-gradient(#eff6ff 0%,#dbeafe 100%);border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;font-weight:700;display:flex}.committee-student-avatar-lg{width:72px;height:72px;font-size:32px}.committee-student-name{min-height:18px;font-size:14px;font-weight:600;line-height:1.25}.committee-student-meta{color:var(--color-text-secondary);margin-top:1px;font-size:11px;line-height:1.25}.committee-student-badge{border-radius:var(--radius-pill);color:#2563eb;margin-top:var(--space-2);max-width:100%;padding:2px var(--space-2);text-overflow:ellipsis;white-space:nowrap;background:#eef6ff;font-size:10px;font-weight:600;overflow:hidden}.committee-student-badge.muted{color:var(--color-text-muted);background:#f8fafc}.committee-student-actions{margin-top:var(--space-2);grid-template-columns:repeat(2,minmax(0,1fr));gap:0;width:100%;display:grid}.committee-action-chip{cursor:pointer;text-align:center;border-top:1px solid #94a3b829;min-height:32px;font-size:14px;font-weight:700}.committee-action-chip.add{color:#f97316;background:#fff4d6;border-bottom-left-radius:12px}.committee-action-chip.subtract{color:#2563eb;background:#e8f2ff;border-bottom-right-radius:12px}.committee-action-chip:disabled{color:#94a3b8;cursor:not-allowed;background:#f8fafc}.committee-quick-panel{min-width:min(100%,420px)}.committee-quick-student{align-items:center;gap:var(--space-3);padding:var(--space-4);background:#f8fbff;border:1px solid #94a3b838;border-radius:20px;display:flex}.committee-quick-action{min-width:min(100%,360px)}.committee-quick-action-student{align-items:center;gap:var(--space-3);padding:var(--space-3);background:#f8fbff;border:1px solid #94a3b838;border-left:4px solid #f97316;border-radius:14px;display:flex}.committee-quick-action-student.subtract{border-left-color:#2563eb}.committee-quick-action-avatar{color:#2563eb;background:linear-gradient(#eff6ff 0%,#dbeafe 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:18px;font-weight:700;display:flex}.committee-quick-action-name{font-size:16px;font-weight:700}.committee-quick-action-meta{color:var(--color-text-secondary);font-size:var(--font-size-small);margin-top:2px}@media (width<=960px){.committee-top-layout{grid-template-columns:1fr}}@media (width<=768px){.teacher-record-tabs-row{gap:var(--space-4);overflow-x:auto}.committee-permission-card .card-header,.committee-submit-card .card-header,.committee-student-section .card-header{align-items:flex-start;gap:var(--space-2);flex-direction:column}.committee-permission-card .card-body,.committee-submit-card .card-body,.committee-student-section .card-body{margin-top:var(--space-3)}.committee-permission-summary-compact{gap:var(--space-2)}.committee-permission-summary-compact .profile-field{padding:var(--space-2) var(--space-3)}.committee-permission-rule-columns{gap:var(--space-3);grid-template-columns:1fr}.committee-submit-toolbar{flex-direction:column;align-items:stretch}.committee-score-type-tabs{width:100%}.committee-score-type-tabs .segmented-option{flex:1}.committee-selected-panel,.committee-common-panel{padding:var(--space-3);border-radius:14px}.committee-selected-panel-header{align-items:flex-start;gap:var(--space-2);flex-direction:column}.committee-remark-grid{grid-template-columns:1fr}.committee-common-rules{flex-wrap:nowrap;padding-bottom:2px;overflow-x:auto}.committee-common-rule,.committee-selected-chip{flex-shrink:0}.committee-student-section .card-header .text-secondary{font-size:var(--font-size-small)}.committee-student-section .card-header{flex-flow:wrap;align-items:flex-start}.committee-student-header-main{flex:180px}.committee-student-pagination{margin-left:auto}.committee-student-grid{grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:6px}.committee-student-main{padding:16px 6px 0}.committee-student-avatar-wrap{width:38px;height:38px}.committee-student-avatar{width:30px;height:30px;font-size:15px}.committee-student-name{font-size:13px}.committee-student-badge,.committee-submit-inline{display:none}.committee-submit-sticky{padding:var(--space-3) var(--space-4);display:flex;left:0}}.assignment-rule-groups{gap:var(--space-3);margin-top:var(--space-3);flex-direction:column;display:flex}.assignment-rule-group{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3)}.assignment-rule-priority{margin-top:var(--space-3);background:linear-gradient(#f8fbff,#fff);border-color:#2563eb47}.assignment-rule-group-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.assignment-rule-group-title{font-size:var(--font-size-small);font-weight:600}.assignment-rule-group-meta{color:var(--color-text-muted);font-size:var(--font-size-small);margin-top:2px}.assignment-rule-grid{gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.rule-checkbox-item{background:var(--color-bg-soft);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);display:flex}.rule-checkbox-item input{flex-shrink:0}.rule-checkbox-item .rule-name{font-size:var(--font-size-small);flex:1}.rule-score-tag{border-radius:var(--radius-pill);font-size:var(--font-size-small);padding:2px var(--space-2);font-weight:600}.rule-score-tag.add{color:var(--color-success);background:#e8f5e9}.rule-score-tag.subtract{color:var(--color-danger);background:#ffebee}.committee-current,.committee-current-empty{background:var(--color-bg-soft);border-left:3px solid var(--color-success);border-radius:var(--radius-sm);align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);padding:var(--space-2) var(--space-3);display:flex}.committee-current-empty{border-left-color:var(--color-border);color:var(--color-text-muted);font-size:var(--font-size-small);justify-content:space-between}.committee-current-avatar{background:var(--color-success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:500;display:flex}.committee-current-info{flex:1}.committee-current-name{font-size:var(--font-size-small);font-weight:500}.committee-current-meta{color:var(--color-text-muted);font-size:var(--font-size-small)}.profile-hero{align-items:center;gap:var(--space-4);display:flex}.profile-name{margin-bottom:0}.profile-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.profile-field{background:var(--color-bg-soft);border-radius:var(--radius-md);gap:var(--space-1);padding:var(--space-4);flex-direction:column;display:flex}.score-summary{background:linear-gradient(135deg, var(--color-primary-soft), #fff);border-radius:var(--radius-lg);padding:var(--space-5)}.score-summary-value{color:var(--color-primary-deep);font-size:52px;font-weight:700;line-height:1}.score-summary-meta{color:var(--color-text-secondary);margin-top:var(--space-2)}.toast-stack{gap:var(--space-2);right:var(--space-5);top:var(--space-5);z-index:2000;flex-direction:column;display:flex;position:fixed}@media (width<=1200px){.teacher-statistics-summary-row{flex-wrap:wrap}.teacher-statistics-summary-item{flex:1 1 calc(33.33% - var(--space-3))}}@media (width<=768px){.page-header,.page-title,.page-desc{min-width:0;max-width:100%}.toolbar-row,.teacher-statistics-toolbar{flex-direction:column;align-items:stretch}.toolbar-field,.toolbar-actions{width:100%;min-width:0}.teacher-statistics-summary-item{flex:1 1 calc(50% - var(--space-3))}.teacher-distribution-meta{flex-direction:column;align-items:flex-start;gap:2px}.toolbar-button-wrap,.toolbar-actions{flex-wrap:wrap;display:flex}.toolbar-button-wrap .btn,.toolbar-actions .btn{flex:140px}.public-header{padding-top:96px}.class-info-stats,.profile-grid{grid-template-columns:1fr}.rules-span-2{grid-column:span 1}.rules-content-row{flex-direction:column}.ranking-table{font-size:var(--font-size-small)}.class-info-card,.login-card,.password-card{padding:var(--space-4)}}
