.global-nav{position:fixed;left:0;top:0;width:var(--nav-width);height:100vh;background:var(--nav-bg);display:flex;flex-direction:column;align-items:center;padding:4px 0;z-index:1000;overflow-y:auto;overflow-x:hidden}.global-nav::-webkit-scrollbar{width:0}.nav-item-wrapper{position:relative;width:100%;display:flex;flex-direction:column;align-items:center}.nav-item{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px 4px;color:#ffffffbf;cursor:pointer;border:none;background:none;position:relative;transition:background .15s;min-height:52px}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{color:#fff}.nav-item.active:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:var(--nav-active-border);border-radius:0 2px 2px 0}.nav-logo{padding:10px 4px;min-height:56px}.canvas-logo svg{display:block}.nav-avatar{width:32px;height:32px;border-radius:50%;background:#6b7780;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;border:2px solid rgba(255,255,255,.3)}.nav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:28px;height:28px}.nav-badge{position:absolute;top:-6px;right:-8px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--danger);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.nav-label{font-size:var(--font-size-nav);font-weight:700;text-transform:uppercase;margin-top:3px;letter-spacing:.5px;line-height:1.2}.nav-spacer{flex:1}.nav-flyout{position:absolute;left:var(--nav-width);top:0;background:#fff;border-radius:0 var(--radius-md) var(--radius-md) 0;box-shadow:var(--shadow-lg);min-width:240px;z-index:1001;padding:8px 0}.flyout-header{display:flex;align-items:center;gap:12px;padding:12px 16px}.flyout-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}.flyout-name{font-weight:700;color:var(--text-primary);font-size:14px}.flyout-email{font-size:12px;color:var(--text-secondary)}.flyout-divider{height:1px;background:var(--border-light);margin:4px 0}.flyout-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;cursor:pointer;font-size:14px;color:var(--text-primary);text-align:left}.flyout-item:hover{background:var(--bg-page)}.flyout-title{font-weight:700;font-size:14px;padding:8px 16px;color:var(--text-primary)}.flyout-course-item{padding:8px 16px}.course-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.course-name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flyout-all-courses{color:var(--text-link);font-weight:600}.course-layout{min-height:100vh}.course-breadcrumbs{display:flex;align-items:center;gap:8px;padding:12px 24px;font-size:var(--font-size-small);border-bottom:1px solid var(--border-light);background:var(--bg-content)}.breadcrumb-link{color:var(--text-link);text-decoration:none;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.breadcrumb-link:hover{text-decoration:underline}.breadcrumb-sep{color:var(--text-secondary);font-size:11px}.course-body{display:flex;min-height:calc(100vh - 41px)}.course-nav-sidebar{width:var(--course-nav-width);flex-shrink:0;background:var(--bg-content);border-right:1px solid var(--border-color);padding:8px 0;position:sticky;top:0;height:calc(100vh - 41px);overflow-y:auto}.course-nav-item{display:flex;align-items:center;height:36px;padding:0 16px;font-size:var(--font-size-body);color:var(--text-link);text-decoration:none;position:relative;border-left:3px solid transparent;transition:background .12s,border-color .12s}.course-nav-item:hover{background:var(--primary-light);text-decoration:none}.course-nav-item.active{border-left-color:var(--primary);background:var(--primary-light);font-weight:var(--font-weight-bold);color:var(--primary)}.course-nav-item.hidden-item{color:var(--text-secondary)}.course-nav-item.hidden-item:after{content:"";width:4px;height:4px;border-radius:50%;background:var(--text-secondary);position:absolute;right:16px;top:50%;transform:translateY(-50%)}.course-nav-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-content-area{flex:1;min-width:0;max-width:1100px;padding:24px}.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}.color-modal{background:var(--bg-content);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:380px;max-width:90vw}.color-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.color-modal-header h3{font-size:16px;font-weight:700}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:var(--text-secondary)}.modal-close-btn:hover{background:var(--bg-page);color:var(--text-primary)}.color-modal-body{padding:20px}.color-modal-field{margin-bottom:16px}.color-modal-field:last-child{margin-bottom:0}.color-modal-field label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.color-modal-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none;transition:border-color .15s}.color-modal-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.color-swatches{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:12px}.color-swatch{width:100%;aspect-ratio:1;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .1s,border-color .15s;max-width:36px}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-content)}.hex-input-row{display:flex;align-items:center;gap:8px}.hex-input{width:120px;flex:none}.hex-preview{width:32px;height:32px;border-radius:50%;border:1px solid var(--border-color);flex-shrink:0}.color-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border-light)}.dashboard-page{padding:16px 24px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.dashboard-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.dashboard-body{display:flex;gap:24px}.dashboard-main{flex:1;min-width:0}.dashboard-sidebar{width:var(--sidebar-width);flex-shrink:0}.course-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.course-card{background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:box-shadow .15s}.course-card:hover{box-shadow:var(--shadow-md)}.course-card-header{height:50px;position:relative}.card-settings-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;color:#fff}.course-card:hover .card-settings-btn{opacity:1}.card-settings-btn:hover{background:#ffffff80}.course-card-body{padding:12px 16px 8px}.course-card-name{font-size:15px;font-weight:700;color:var(--text-link);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.course-card-code{font-size:var(--font-size-small);color:var(--text-secondary);margin-top:2px}.course-card-term{font-size:var(--font-size-small);color:var(--text-secondary)}.course-card-footer{display:flex;align-items:center;gap:4px;padding:8px 12px 12px}.card-footer-icon{position:relative;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-secondary);transition:background .15s,color .15s}.card-footer-icon:hover{background:var(--bg-page);color:var(--text-primary)}.icon-badge{position:absolute;top:-2px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--primary);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.sidebar-section{margin-bottom:24px}.sidebar-section-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.view-calendar-link{display:flex;align-items:center;gap:4px;font-size:var(--font-size-small);color:var(--text-link);cursor:pointer}.view-calendar-link:hover{text-decoration:underline}.todo-list{display:flex;flex-direction:column}.todo-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light)}.todo-item:first-child{padding-top:0}.todo-icon{flex-shrink:0;padding-top:2px}.todo-content{flex:1;min-width:0}.todo-title{font-size:13px;font-weight:600;color:var(--text-link);cursor:pointer;display:block;line-height:1.3}.todo-title:hover{text-decoration:underline}.todo-meta{font-size:var(--font-size-small);color:var(--text-secondary);margin-top:2px}.todo-dismiss{flex-shrink:0;color:var(--text-secondary);padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center}.todo-dismiss:hover{background:var(--bg-page);color:var(--text-primary)}.todo-more{font-size:13px;color:var(--text-link);padding:8px 0;cursor:pointer}.todo-empty{font-size:13px;color:var(--text-secondary);font-style:italic;padding:8px 0}.coming-up-list{display:flex;flex-direction:column}.coming-up-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-light)}.coming-up-indicator{width:4px;min-height:32px;border-radius:2px;flex-shrink:0;margin-top:2px}.coming-up-content{flex:1;min-width:0}.coming-up-title{font-size:13px;color:var(--text-link);cursor:pointer;line-height:1.3}.coming-up-title:hover{text-decoration:underline}.coming-up-meta{font-size:var(--font-size-small);color:var(--text-secondary);margin-top:2px}.dashboard-list-view{background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.list-view-group{border-bottom:1px solid var(--border-color)}.list-view-group:last-child{border-bottom:none}.list-view-group-header{padding:10px 16px;font-size:13px;font-weight:700;color:var(--text-primary);background:var(--bg-module-header);border-bottom:1px solid var(--border-light)}.list-view-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border-light);position:relative}.list-view-item:last-child{border-bottom:none}.list-view-item:hover{background:#0374b508}.list-view-color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.list-view-icon{color:var(--text-secondary);flex-shrink:0;display:flex}.list-view-content{flex:1;min-width:0}.list-view-title{font-size:13px;font-weight:600;color:var(--text-link);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-view-meta{font-size:11px;color:var(--text-secondary);margin-top:1px}.list-view-time{font-size:11px;color:var(--text-secondary);flex-shrink:0}.list-view-unread{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0}.list-view-empty{padding:40px 20px;text-align:center;color:var(--text-secondary);font-size:14px}.courses-page{padding:20px 24px}.courses-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light);margin-bottom:16px}.courses-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.courses-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color)}.courses-tab{padding:8px 16px;font-size:14px;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px}.courses-tab:hover{color:var(--text-primary)}.courses-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.courses-search{position:relative}.courses-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.courses-search-input{padding:8px 12px 8px 30px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;width:250px;outline:none;color:var(--text-primary)}.courses-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.courses-table-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-content)}.courses-table{width:100%;border-collapse:collapse}.courses-table thead{background:var(--bg-module-header)}.courses-table th{text-align:left;padding:10px 14px;font-weight:700;font-size:12px;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap}.courses-table td{padding:12px 14px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.courses-table tbody tr:last-child td{border-bottom:none}.courses-table tbody tr:hover{background:#0374b508}.courses-name-link{display:flex;align-items:center;gap:8px;color:var(--text-link);font-weight:600}.courses-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.courses-code{font-size:11px;color:var(--text-secondary);margin-top:2px;margin-left:20px}.courses-nickname,.courses-term{font-size:13px;color:var(--text-secondary)}.courses-role{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;background:#e8f5fd;color:#0374b5}.courses-published.yes{color:var(--success);font-weight:600}.courses-published.no{color:var(--text-secondary)}.courses-empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.inbox-page{height:calc(100vh + -0px);display:flex;flex-direction:column}.inbox-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-content);flex-shrink:0}.inbox-toolbar-left{display:flex;align-items:center;gap:4px}.inbox-toolbar-right{display:flex;align-items:center;gap:8px}.inbox-filter{padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;color:var(--text-primary);background:var(--bg-content);outline:none}.inbox-filter:focus{border-color:var(--primary)}.btn-sm{padding:5px 10px;font-size:13px}.inbox-layout{display:flex;flex:1;overflow:hidden}.inbox-list-panel{width:380px;flex-shrink:0;border-right:1px solid var(--border-color);display:flex;flex-direction:column;background:var(--bg-content)}.inbox-search{position:relative;padding:10px 12px;border-bottom:1px solid var(--border-light)}.inbox-search-icon{position:absolute;left:22px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.inbox-search-input{width:100%;padding:7px 10px 7px 30px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;color:var(--text-primary);outline:none}.inbox-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.inbox-conversations{flex:1;overflow-y:auto}.inbox-conv-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-light);cursor:pointer;position:relative;transition:background .1s}.inbox-conv-item:hover{background:#0374b508}.inbox-conv-item.selected{background:#0374b514}.inbox-conv-item.unread{border-left:3px solid var(--primary)}.inbox-conv-item.unread .inbox-conv-subject{font-weight:700}.inbox-conv-avatar{flex-shrink:0}.inbox-conv-content{flex:1;min-width:0}.inbox-conv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.inbox-conv-name{font-size:13px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inbox-conv-time{font-size:11px;color:var(--text-secondary);flex-shrink:0;margin-left:8px}.inbox-conv-subject{font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}.inbox-conv-preview{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inbox-conv-course{font-size:11px;color:var(--text-secondary);margin-top:3px}.inbox-star-btn{flex-shrink:0;display:flex;align-items:center;padding:4px;border-radius:50%;cursor:pointer;margin-top:2px}.inbox-star-btn:hover{background:#0000000f}.inbox-empty-list{padding:40px 20px;text-align:center;color:var(--text-secondary);font-size:14px}.inbox-detail-panel{flex:1;display:flex;flex-direction:column;background:var(--bg-content);overflow:hidden}.inbox-detail-header{padding:16px 20px;border-bottom:1px solid var(--border-light)}.inbox-detail-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.inbox-detail-course{font-size:12px;color:var(--text-secondary)}.inbox-messages{flex:1;overflow-y:auto;padding:16px 20px}.inbox-message{display:flex;gap:12px;margin-bottom:20px}.inbox-message-avatar{flex-shrink:0}.inbox-message-content{flex:1}.inbox-message-meta{display:flex;align-items:center;gap:10px;margin-bottom:4px}.inbox-message-author{font-size:14px;font-weight:600;color:var(--text-primary)}.inbox-message-date{font-size:12px;color:var(--text-secondary)}.inbox-message-body{font-size:14px;color:var(--text-primary);line-height:1.5}.inbox-reply-area{border-top:1px solid var(--border-color);padding:12px 20px;flex-shrink:0}.inbox-reply-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary);resize:vertical;outline:none;min-height:60px;font-family:var(--font-family)}.inbox-reply-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.inbox-reply-actions{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.inbox-no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-size:16px}.inbox-no-selection-sub{font-size:13px;margin-top:4px}.inbox-compose-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:60px}.inbox-compose-modal{background:var(--bg-content);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:600px;max-height:calc(100vh - 120px);overflow-y:auto;display:flex;flex-direction:column}.inbox-compose-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.inbox-compose-header h2{font-size:18px;font-weight:700}.inbox-compose-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;color:var(--text-secondary)}.inbox-compose-close:hover{background:var(--bg-page);color:var(--text-primary)}.inbox-compose-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px}.inbox-compose-field label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.inbox-compose-field input,.inbox-compose-field select,.inbox-compose-field textarea{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary);background:var(--bg-content);outline:none;font-family:var(--font-family)}.inbox-compose-field input:focus,.inbox-compose-field select:focus,.inbox-compose-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.inbox-compose-field textarea{resize:vertical;min-height:120px}.inbox-compose-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border-light)}.inbox-compose-footer-right{display:flex;gap:8px}.calendar-page{display:flex;height:calc(100vh + -0px);overflow:hidden}.calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-content);flex-shrink:0}.calendar-header-left h1{font-size:22px;font-weight:var(--font-weight-light)}.calendar-header-center{display:flex;align-items:center;gap:8px}.calendar-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;color:var(--text-primary)}.calendar-nav-btn:hover{background:var(--bg-page)}.calendar-today-btn{padding:5px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;color:var(--text-primary);background:var(--bg-content)}.calendar-today-btn:hover{background:var(--bg-page)}.calendar-month-label{font-size:18px;font-weight:600;color:var(--text-primary);margin-left:8px}.calendar-view-tabs{display:flex;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.calendar-view-tab{padding:5px 14px;font-size:13px;color:var(--text-secondary);background:var(--bg-content);border-right:1px solid var(--border-color)}.calendar-view-tab:last-child{border-right:none}.calendar-view-tab.active{background:var(--primary);color:#fff}.calendar-view-tab:hover:not(.active){background:var(--bg-page)}.calendar-grid{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-content)}.calendar-grid-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border-color)}.calendar-grid-day-name{text-align:center;padding:8px 4px;font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase}.calendar-grid-body{flex:1;overflow-y:auto}.calendar-grid-week{display:grid;grid-template-columns:repeat(7,1fr);min-height:100px}.calendar-grid-cell{border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);padding:4px 6px;cursor:pointer;min-height:100px;transition:background .1s}.calendar-grid-cell:nth-child(7){border-right:none}.calendar-grid-cell:hover{background:#0374b508}.calendar-grid-cell.other-month{background:var(--bg-page)}.calendar-grid-cell.other-month .calendar-day-number{color:var(--text-secondary);opacity:.5}.calendar-day-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:13px;color:var(--text-primary);border-radius:50%;margin-bottom:2px}.calendar-day-number.today{background:var(--primary);color:#fff;font-weight:700}.calendar-cell-events{display:flex;flex-direction:column;gap:2px}.calendar-event-pill{display:flex;align-items:center;gap:3px;padding:1px 4px;border-radius:3px;color:#fff;font-size:11px;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.calendar-event-pill:hover{opacity:.85}.calendar-event-icon{font-size:10px;flex-shrink:0}.calendar-event-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-more-events{font-size:11px;color:var(--text-secondary);padding:1px 4px;cursor:pointer}.calendar-more-events:hover{color:var(--primary)}.calendar-sidebar{width:260px;flex-shrink:0;border-left:1px solid var(--border-color);background:var(--bg-content);overflow-y:auto;padding:16px}.calendar-mini{margin-bottom:20px}.calendar-mini-header{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px;text-align:center}.calendar-mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.calendar-mini-day-name{text-align:center;font-size:10px;font-weight:700;color:var(--text-secondary);padding:2px}.calendar-mini-day{text-align:center;font-size:11px;padding:3px;border-radius:50%;cursor:pointer;color:var(--text-primary)}.calendar-mini-day.other{color:var(--text-secondary);opacity:.4}.calendar-mini-day:hover{background:var(--bg-page)}.calendar-filters{margin-bottom:20px}.calendar-filters h3{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.calendar-filter-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px;color:var(--text-primary);cursor:pointer}.calendar-filter-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.calendar-filter-swatch{width:14px;height:14px;border-radius:3px;flex-shrink:0}.calendar-undated h3{font-size:14px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.calendar-undated-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;color:var(--text-primary)}.calendar-undated-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.calendar-undated-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-popover-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:1000;display:flex;align-items:center;justify-content:center}.calendar-popover{background:var(--bg-content);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:400px;overflow:hidden}.calendar-popover-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-left:4px solid var(--primary);border-bottom:1px solid var(--border-light)}.calendar-popover-header h3{font-size:16px;font-weight:600}.calendar-popover-close{display:flex;align-items:center;color:var(--text-secondary)}.calendar-popover-close:hover{color:var(--text-primary)}.calendar-popover-body{padding:14px 16px}.calendar-popover-field{font-size:13px;color:var(--text-primary);margin-bottom:8px;line-height:1.4}.calendar-popover-field strong{color:var(--text-primary)}.calendar-add-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:60px}.calendar-add-panel{background:var(--bg-content);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:480px;max-height:calc(100vh - 120px);overflow-y:auto}.calendar-add-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.calendar-add-header h3{font-size:18px;font-weight:700}.calendar-add-close{display:flex;align-items:center;color:var(--text-secondary)}.calendar-add-close:hover{color:var(--text-primary)}.calendar-add-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px}.calendar-add-field label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.calendar-add-field input,.calendar-add-field select,.calendar-add-field textarea{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary);background:var(--bg-content);outline:none;font-family:var(--font-family)}.calendar-add-field input:focus,.calendar-add-field select:focus,.calendar-add-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.calendar-add-checkbox{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-primary);cursor:pointer}.calendar-add-checkbox input{width:16px;height:16px;accent-color:var(--primary)}.calendar-add-times{display:flex;gap:12px}.calendar-add-times .calendar-add-field{flex:1}.calendar-add-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-light)}.modules-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modules-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.modules-empty{text-align:center;padding:48px 24px;color:var(--text-secondary);font-size:14px}.modules-empty p{margin-bottom:8px}.module-section{border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:16px;background:var(--bg-content);overflow:hidden}.module-header-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-module-header);border-bottom:1px solid var(--border-color);cursor:pointer;-webkit-user-select:none;user-select:none}.module-header-bar:hover{background:#ededee}.module-header-left{display:flex;align-items:center;gap:6px;min-width:0}.module-drag-handle{color:var(--text-secondary);cursor:grab;display:flex;align-items:center}.module-caret{display:flex;align-items:center;color:var(--text-secondary)}.module-name{font-size:15px;font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.module-header-right{display:flex;align-items:center;gap:4px}.module-publish-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%}.module-publish-btn:hover{background:#0000000f}.module-kebab-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:var(--text-secondary)}.module-kebab-btn:hover{background:#0000000f;color:var(--text-primary)}.module-menu-wrapper{position:relative}.module-dropdown-menu{position:absolute;top:100%;right:0;background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:120px;z-index:100;padding:4px 0}.module-dropdown-item{display:block;width:100%;padding:8px 14px;font-size:13px;color:var(--text-primary);text-align:left}.module-dropdown-item:hover{background:var(--bg-page)}.module-dropdown-danger{color:var(--danger)}.module-dropdown-danger:hover{background:var(--danger-light)}.module-items-list{border-top:none}.module-empty-items{padding:16px 20px;color:var(--text-secondary);font-size:13px;font-style:italic}.module-item{display:flex;align-items:center;gap:8px;padding:10px 12px 10px 16px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .1s}.module-item:hover{background:#0374b50a}.module-item.sub-header{cursor:default;background:none}.module-item.sub-header .item-title{font-weight:700;color:var(--text-primary)}.item-drag-handle{color:var(--text-secondary);opacity:.4;cursor:grab;display:flex;align-items:center;flex-shrink:0}.module-item:hover .item-drag-handle{opacity:.8}.item-type-icon{display:flex;align-items:center;color:var(--text-secondary);flex-shrink:0}.item-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}.item-link{color:var(--text-link)}.item-link:hover{text-decoration:underline}.item-right{display:flex;align-items:center;gap:12px;flex-shrink:0;margin-left:auto}.item-due-date,.item-points{font-size:var(--font-size-small);color:var(--text-secondary);white-space:nowrap}.item-publish-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%}.item-publish-btn:hover{background:#0000000f}.module-add-item-row{padding:6px 16px;border-top:1px solid var(--border-light);background:var(--bg-module-header)}.module-add-item-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-secondary);padding:4px 8px;border-radius:var(--radius-sm)}.module-add-item-btn:hover{background:#0000000f;color:var(--text-primary)}.modules-modal{background:var(--bg-content);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:420px;max-width:90vw}.modules-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.modules-modal-header h3{font-size:16px;font-weight:700}.modules-modal-body{padding:20px}.modal-field{margin-bottom:14px}.modal-field:last-child{margin-bottom:0}.modal-field label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.modal-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none;background:var(--bg-content);transition:border-color .15s}.modal-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.modules-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border-light)}.assignments-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.assignments-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.assignments-header-actions{display:flex;gap:8px}.assignments-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.assignments-search{position:relative;flex:1;max-width:300px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.assignments-search-input{width:100%;padding:8px 12px 8px 32px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none}.assignments-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.assignment-weights-info{font-size:var(--font-size-small);color:var(--text-secondary)}.assignment-groups{display:flex;flex-direction:column;gap:12px}.assignment-group{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-content);overflow:hidden}.assignment-group-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-module-header);cursor:pointer;-webkit-user-select:none;user-select:none}.assignment-group-header:hover{background:#ededee}.assignment-group-left{display:flex;align-items:center;gap:6px}.group-drag-handle{color:var(--text-secondary);display:flex;align-items:center;cursor:grab}.group-caret{display:flex;align-items:center;color:var(--text-secondary)}.group-name{font-size:15px;font-weight:700;color:var(--text-primary)}.group-weight{font-size:var(--font-size-small);color:var(--text-secondary);margin-left:8px}.assignment-group-right{display:flex;align-items:center;gap:4px}.btn-sm{padding:4px 8px;font-size:12px}.assignment-group-items{border-top:1px solid var(--border-light)}.assignment-group-empty{padding:16px 20px;color:var(--text-secondary);font-size:13px;font-style:italic}.assignment-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .1s}.assignment-row:last-child{border-bottom:none}.assignment-row:hover{background:#0374b50a}.assignment-row-left{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.assignment-drag-handle{color:var(--text-secondary);opacity:.4;display:flex;align-items:center;flex-shrink:0}.assignment-row:hover .assignment-drag-handle{opacity:.8}.assignment-publish-toggle{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:24px;height:24px;border-radius:50%}.assignment-publish-toggle:hover{background:#0000000f}.assignment-info{min-width:0;display:flex;flex-direction:column;gap:2px}.assignment-name{color:var(--text-link);font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.assignment-name:hover{text-decoration:underline}.assignment-needs-grading{font-size:11px;color:var(--warning);font-weight:600}.assignment-row-right{display:flex;align-items:center;gap:16px;flex-shrink:0;margin-left:16px}.assignment-due{font-size:var(--font-size-small);color:var(--text-secondary);white-space:nowrap}.assignment-points{font-size:var(--font-size-small);color:var(--text-secondary);white-space:nowrap;min-width:50px;text-align:right}.assignment-menu-wrapper{position:relative}.assignment-kebab{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:var(--text-secondary)}.assignment-kebab:hover{background:#0000000f;color:var(--text-primary)}.assignment-dropdown-menu{position:absolute;top:100%;right:0;background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:120px;z-index:100;padding:4px 0}.assignment-dropdown-item{display:block;width:100%;padding:8px 14px;font-size:13px;color:var(--text-primary);text-align:left}.assignment-dropdown-item:hover{background:var(--bg-page)}.assignment-dropdown-danger{color:var(--danger)}.assignment-dropdown-danger:hover{background:var(--danger-light)}.assignments-empty{text-align:center;padding:48px 24px;color:var(--text-secondary)}.assignment-detail-header{margin-bottom:20px}.assignment-detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.assignment-detail-title-row h1{font-size:24px;font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:1.3}.assignment-detail-actions{display:flex;gap:8px;flex-shrink:0}.assignment-detail-body{display:flex;gap:24px}.assignment-detail-main{flex:1;min-width:0}.assignment-detail-sidebar{width:240px;flex-shrink:0}.assignment-detail-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}.detail-meta-row{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.detail-meta-row svg{color:var(--text-secondary);flex-shrink:0}.detail-meta-label{font-weight:600;color:var(--text-primary);min-width:80px}.detail-meta-value{color:var(--text-primary)}.assignment-detail-divider{height:1px;background:var(--border-light);margin:20px 0}.assignment-detail-description{font-size:14px;line-height:1.6;color:var(--text-primary)}.assignment-detail-description p{margin-bottom:12px}.assignment-detail-description ul,.assignment-detail-description ol{margin-bottom:12px;padding-left:24px}.assignment-detail-description li{margin-bottom:4px}.assignment-detail-description code{background:var(--bg-page);padding:2px 6px;border-radius:3px;font-size:13px}.no-description{color:var(--text-secondary);font-style:italic}.assignment-submit-section{background:var(--bg-page);padding:16px;border-radius:var(--radius-sm);border:1px solid var(--border-light)}.assignment-submit-section h3{font-size:16px;font-weight:700;margin-bottom:8px}.submit-note{font-size:13px;color:var(--text-secondary);margin-bottom:12px}.detail-sidebar-section{padding:12px 0;border-bottom:1px solid var(--border-light)}.detail-sidebar-section:first-child{padding-top:0}.detail-sidebar-section h4{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-secondary);margin-bottom:4px;letter-spacing:.5px}.detail-sidebar-section p{font-size:14px;color:var(--text-primary)}.detail-sidebar-meta{font-size:12px;color:var(--text-secondary);margin-top:2px}.needs-grading-count{color:var(--warning)!important;font-weight:600}.status-published{color:var(--success)!important;font-weight:600}.status-unpublished{color:var(--text-secondary)!important}.assignment-form-page h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light);margin-bottom:20px}.assignment-form{background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:24px;max-width:800px}.form-field{margin-bottom:16px}.form-field label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.form-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none;background:var(--bg-content);transition:border-color .15s}.form-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none;resize:vertical;min-height:100px;font-family:var(--font-family);line-height:1.5;background:var(--bg-content)}.form-field-half{flex:1}.form-checkboxes{padding:12px 16px;background:var(--bg-page);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.section-label{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:8px;display:block}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-primary);cursor:pointer;margin-bottom:6px;font-weight:400}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.sub-field{margin-left:24px;margin-top:8px}.form-divider{height:1px;background:var(--border-light);margin:20px 0}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-light)}.announcements-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.announcements-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.announcements-empty{text-align:center;padding:48px 24px;color:var(--text-secondary)}.announcements-empty svg{margin-bottom:12px;opacity:.4}.announcements-list{display:flex;flex-direction:column;gap:1px;background:var(--border-light);border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.announcement-card{display:flex;align-items:flex-start;gap:12px;padding:16px 16px 16px 20px;background:var(--bg-content);position:relative;transition:background .1s}.announcement-card:hover{background:#0374b508}.announcement-card.unread{background:var(--primary-light)}.unread-indicator{position:absolute;left:6px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--primary)}.announcement-avatar{flex-shrink:0;padding-top:2px}.announcement-content{flex:1;min-width:0}.announcement-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}.announcement-author{font-weight:700;font-size:var(--font-size-body);color:var(--text-primary)}.announcement-date{font-size:var(--font-size-small);color:var(--text-secondary)}.announcement-title{display:block;font-size:16px;font-weight:700;color:var(--text-link);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.announcement-title:hover{text-decoration:underline}.announcement-preview{font-size:13px;color:var(--text-secondary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.announcement-detail-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.back-link{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-body);color:var(--text-link)}.back-link:hover{text-decoration:underline}.announcement-detail-card{background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:24px;margin-bottom:24px}.announcement-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.announcement-detail-author{font-weight:700;font-size:15px;color:var(--text-primary)}.announcement-detail-date{font-size:var(--font-size-small);color:var(--text-secondary)}.announcement-detail-title{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.3}.announcement-detail-body{font-size:var(--font-size-body);color:var(--text-primary);line-height:1.6}.announcement-detail-body p{margin-bottom:12px}.announcement-detail-body p:last-child{margin-bottom:0}.announcement-replies-section{margin-top:8px}.announcement-replies-section h3{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--text-primary)}.announcement-reply{display:flex;gap:12px;padding:12px 0;border-top:1px solid var(--border-light)}.announcement-reply-content{flex:1;min-width:0}.announcement-reply-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}.announcement-reply-author{font-weight:700;font-size:13px;color:var(--text-primary)}.announcement-reply-date{font-size:var(--font-size-small);color:var(--text-secondary)}.announcement-reply-message{font-size:var(--font-size-body);color:var(--text-primary);line-height:1.5}.announcement-reply-form{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-light)}.announcement-reply-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);resize:vertical;outline:none;min-height:80px;color:var(--text-primary)}.announcement-reply-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.announcement-reply-actions{display:flex;justify-content:flex-end;margin-top:8px}.announcement-reply-actions .btn:disabled{opacity:.5;cursor:not-allowed}.announcement-form-topbar{margin-bottom:16px}.announcement-form-page h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light);margin-bottom:20px}.announcement-form{background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:24px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:var(--font-size-body);font-weight:700;color:var(--text-primary);margin-bottom:6px}.form-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.form-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);resize:vertical;outline:none;line-height:1.5}.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.form-select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none;background:var(--bg-content)}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.form-checkbox-group{display:flex;flex-direction:column;gap:10px}.form-checkbox-label{display:flex;align-items:center;gap:8px;font-size:var(--font-size-body);color:var(--text-primary);cursor:pointer}.form-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.delay-posting-date{margin-left:24px;max-width:300px}.form-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;border-top:1px solid var(--border-light)}.form-actions .btn:disabled{opacity:.5;cursor:not-allowed}.discussions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.discussions-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.discussions-section{margin-bottom:24px}.discussions-section-header{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 4px}.discussions-empty{text-align:center;padding:48px 24px;color:var(--text-secondary)}.discussions-empty svg{margin-bottom:12px;opacity:.4}.discussions-list{border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;background:var(--border-light);display:flex;flex-direction:column;gap:1px}.discussion-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-content);transition:background .1s}.discussion-row:hover{background:#0374b508}.discussion-row.unread{border-left:3px solid var(--primary)}.discussion-row-left{display:flex;align-items:flex-start;gap:8px;flex:1;min-width:0}.pin-icon{color:var(--text-secondary);margin-top:4px;flex-shrink:0}.discussion-info{min-width:0;flex:1}.discussion-title{display:block;font-size:15px;font-weight:700;color:var(--text-link);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.discussion-title:hover{text-decoration:underline}.discussion-meta{font-size:var(--font-size-small);color:var(--text-secondary);display:flex;align-items:center;gap:4px;flex-wrap:wrap}.meta-sep{color:var(--border-color)}.discussion-row-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:16px}.discussion-publish-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%}.discussion-publish-toggle:hover{background:#0000000f}.discussion-menu-wrapper{position:relative}.discussion-kebab{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:var(--text-secondary)}.discussion-kebab:hover{background:#0000000f;color:var(--text-primary)}.discussion-dropdown-menu{position:absolute;top:100%;right:0;background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:160px;z-index:100;padding:4px 0}.discussion-dropdown-item{display:block;width:100%;padding:8px 14px;font-size:13px;color:var(--text-primary);text-align:left}.discussion-dropdown-item:hover{background:var(--bg-page)}.discussion-dropdown-danger{color:var(--danger)}.discussion-dropdown-danger:hover{background:var(--danger-light)}.discussion-detail-topbar{margin-bottom:16px}.discussion-detail-card{background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:24px;margin-bottom:24px}.discussion-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.discussion-detail-author{font-weight:700;font-size:15px;color:var(--text-primary)}.discussion-detail-date{font-size:var(--font-size-small);color:var(--text-secondary)}.discussion-detail-title{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.3}.discussion-detail-body{font-size:var(--font-size-body);color:var(--text-primary);line-height:1.6}.discussion-detail-body p{margin-bottom:12px}.discussion-locked-banner{margin-top:16px;padding:10px 14px;background:#fff3cd;border:1px solid #FFECB5;border-radius:var(--radius-sm);color:#856404;font-size:13px}.discussion-entries-section{margin-top:8px}.discussion-entries-section h3{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--text-primary)}.discussion-entry{padding:12px 0;border-top:1px solid var(--border-light)}.entry-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.entry-author{font-weight:700;font-size:13px;color:var(--text-primary);margin-right:8px}.entry-date{font-size:var(--font-size-small);color:var(--text-secondary)}.entry-body{font-size:var(--font-size-body);color:var(--text-primary);line-height:1.5;margin-bottom:6px;padding-left:42px}.entry-body p{margin-bottom:8px}.entry-body p:last-child{margin-bottom:0}.entry-body code{background:#f0f0f0;padding:1px 4px;border-radius:3px;font-size:13px;font-family:Courier New,monospace}.entry-actions{display:flex;align-items:center;gap:12px;padding-left:42px}.entry-action-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-secondary);padding:4px 8px;border-radius:var(--radius-sm);transition:background .1s,color .1s}.entry-action-btn:hover{background:var(--bg-page);color:var(--text-link)}.inline-reply-form{margin-top:8px;margin-left:42px}.inline-reply-textarea{width:100%;padding:8px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;resize:vertical;outline:none;min-height:60px;color:var(--text-primary)}.inline-reply-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.inline-reply-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:6px}.inline-reply-actions .btn-sm{padding:4px 10px;font-size:12px}.inline-reply-actions .btn:disabled{opacity:.5;cursor:not-allowed}.top-level-reply-form{margin-top:24px;padding-top:16px;border-top:2px solid var(--border-color)}.top-level-reply-form h4{font-size:15px;font-weight:700;margin-bottom:10px;color:var(--text-primary)}.top-level-reply-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);resize:vertical;outline:none;min-height:80px;color:var(--text-primary)}.top-level-reply-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.top-level-reply-actions{display:flex;justify-content:flex-end;margin-top:8px}.top-level-reply-actions .btn:disabled{opacity:.5;cursor:not-allowed}.discussion-form-topbar{margin-bottom:16px}.discussion-form-page h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light);margin-bottom:20px}.discussion-form{background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:24px}.graded-options{margin-left:24px;padding:12px 16px;background:var(--bg-page);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.gb-settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:60px}.gb-settings-modal{background:var(--bg-content);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:560px;max-height:calc(100vh - 120px);overflow-y:auto}.gb-settings-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.gb-settings-header h2{font-size:20px;font-weight:700;color:var(--text-primary)}.gb-settings-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;color:var(--text-secondary)}.gb-settings-close:hover{background:var(--bg-page);color:var(--text-primary)}.gb-settings-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color);padding:0 24px;margin-top:16px}.gb-settings-tab{padding:10px 16px;font-size:14px;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .1s,border-color .1s}.gb-settings-tab:hover{color:var(--text-primary)}.gb-settings-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.gb-settings-body{padding:20px 24px}.gb-late-policies{display:flex;flex-direction:column;gap:16px}.gb-checkbox-label{display:flex;align-items:center;gap:10px;font-size:var(--font-size-body);color:var(--text-primary);cursor:pointer}.gb-checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.gb-settings-field{margin-left:28px}.gb-field-label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.gb-input-row{display:flex;align-items:center;gap:6px}.gb-settings-input{width:80px;padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none}.gb-settings-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.gb-input-suffix{font-size:var(--font-size-body);color:var(--text-secondary)}.gb-settings-select{padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);background:var(--bg-content);outline:none}.gb-settings-select:focus{border-color:var(--primary)}.gb-settings-divider{height:1px;background:var(--border-light);margin:4px 0}.gb-deduction-fields{margin-left:28px}.gb-deduction-row{display:flex;gap:20px}.gb-settings-placeholder{color:var(--text-secondary);font-size:var(--font-size-body);padding:24px 0;text-align:center}.gb-settings-info{font-size:var(--font-size-body);color:var(--text-secondary);margin-bottom:16px}.gb-radio-group{display:flex;flex-direction:column;gap:12px}.gb-radio-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;padding:12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color .1s}.gb-radio-label:hover{border-color:var(--primary)}.gb-radio-label input[type=radio]{width:18px;height:18px;accent-color:var(--primary);margin-top:2px;flex-shrink:0}.gb-radio-label strong{font-size:14px;color:var(--text-primary)}.gb-radio-desc{font-size:12px;color:var(--text-secondary);margin-top:2px}.gb-advanced{display:flex;flex-direction:column;gap:16px}.gb-settings-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--border-light)}.gradebook-page{max-width:none}.gradebook-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}.gradebook-header-left{display:flex;align-items:center;gap:16px}.gradebook-header-left h1{font-size:22px;font-weight:var(--font-weight-light);white-space:nowrap}.gradebook-dropdowns{display:flex;gap:4px}.gb-dropdown-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;font-size:13px;color:var(--text-link);border-radius:var(--radius-sm)}.gb-dropdown-btn:hover{background:var(--bg-page);text-decoration:underline}.gradebook-header-right{display:flex;align-items:center;gap:8px}.gb-search{position:relative}.gb-search-icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.gb-search-input{padding:6px 10px 6px 28px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;width:180px;outline:none;color:var(--text-primary)}.gb-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.gradebook-table-wrapper{overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-content)}.gradebook-table{width:100%;border-collapse:collapse;font-size:13px;min-width:800px}.gradebook-table thead{background:var(--bg-module-header);position:sticky;top:0;z-index:10}.gradebook-table th{text-align:left;padding:8px 10px;font-weight:700;font-size:12px;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap}.gb-th-student{min-width:160px;max-width:200px;position:sticky;left:0;background:var(--bg-module-header);z-index:11;border-right:2px solid var(--border-color)}.gb-th-total{min-width:100px;border-right:1px solid var(--border-color)}.gb-th-assignment{min-width:100px;max-width:140px}.gb-th-assignment-name{overflow:hidden;text-overflow:ellipsis;max-width:120px;font-size:11px}.gb-th-assignment-pts{font-weight:400;font-size:10px;color:var(--text-secondary)}.gradebook-table tbody tr{border-bottom:1px solid var(--border-light)}.gradebook-table tbody tr:hover{background:#0374b505}.gb-td-student{padding:6px 10px;position:sticky;left:0;background:var(--bg-content);z-index:5;border-right:2px solid var(--border-color)}.gradebook-table tbody tr:hover .gb-td-student{background:#0374b505}.gb-student-name{font-size:12px;color:var(--text-link);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.gb-td-total{padding:6px 10px;border-right:1px solid var(--border-color)}.gb-total-pct{font-size:12px;font-weight:600;color:var(--text-primary);margin-right:4px}.gb-total-letter{font-size:11px;color:var(--text-secondary)}.gb-total-na{color:var(--text-secondary)}.gb-cell{padding:4px 8px;text-align:center;cursor:pointer;border-right:1px solid var(--border-light);min-width:60px;transition:background .1s}.gb-cell:hover{background:#0374b50f}.gb-cell-late{background:#fde8e8}.gb-cell-late:hover{background:#fadada}.gb-cell-excused{background:#e8f8ef}.gb-cell-excused:hover{background:#d0f0e0}.gb-cell-value{font-size:13px;color:var(--text-primary)}.gb-cell-excused .gb-cell-value{color:var(--success);font-weight:600;font-style:italic}.gb-cell-input{width:60px;padding:2px 4px;border:2px solid var(--primary);border-radius:2px;text-align:center;font-size:13px;outline:none;color:var(--text-primary)}.people-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.people-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.people-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:12px}.people-search{position:relative;flex:1;max-width:300px}.people-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.people-search-input{width:100%;padding:8px 12px 8px 30px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none}.people-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.people-role-filter{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);background:var(--bg-content);outline:none}.people-role-filter:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.people-count{font-size:var(--font-size-small);color:var(--text-secondary);margin-bottom:8px}.people-table-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-content)}.people-table{width:100%;border-collapse:collapse}.people-table thead{background:var(--bg-module-header)}.people-table th{text-align:left;padding:10px 14px;font-weight:700;font-size:12px;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap}.people-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.people-th-sortable:hover{color:var(--primary)}.people-table td{padding:10px 14px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.people-table tbody tr:last-child td{border-bottom:none}.people-table tbody tr:hover{background:#0374b508}.people-name-cell{display:flex;align-items:center;gap:10px}.people-name{color:var(--text-link);font-weight:600}.people-login{color:var(--text-secondary);font-size:12px}.people-section,.people-activity{font-size:12px;color:var(--text-secondary)}.role-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.role-teacher{background:#e8f5fd;color:#0374b5}.role-ta{background:#e8f8ef;color:#0b874b}.role-student{background:#f5f5f5;color:var(--text-secondary)}.role-observer{background:#fff3e0;color:#e65100}.people-empty{text-align:center;padding:48px 24px;color:var(--text-secondary)}.pages-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.pages-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.pages-table-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-content)}.pages-table{width:100%;border-collapse:collapse}.pages-table thead{background:var(--bg-module-header)}.pages-table th{text-align:left;padding:10px 14px;font-weight:700;font-size:12px;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap}.pages-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:4px}.pages-th-sortable:hover{color:var(--primary)}.pages-table td{padding:10px 14px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.pages-table tbody tr:last-child td{border-bottom:none}.pages-table tbody tr:hover{background:#0374b508}.pages-front-page-cell{width:30px;text-align:center}.pages-front-page-btn{display:flex;align-items:center;justify-content:center;padding:2px;cursor:pointer}.pages-front-page-btn:hover{opacity:.7}.pages-title-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-link);font-weight:600}.pages-title-link:hover{text-decoration:underline}.pages-front-label{display:inline-block;margin-left:8px;padding:1px 6px;background:#fff3e0;color:#e65100;border-radius:8px;font-size:10px;font-weight:600}.pages-date{font-size:12px;color:var(--text-secondary);white-space:nowrap}.pages-empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.page-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.page-detail-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.page-detail-meta{font-size:12px;color:var(--text-secondary);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.page-detail-body{font-size:14px;line-height:1.7;color:var(--text-primary)}.page-detail-body h2{font-size:20px;font-weight:700;margin:20px 0 10px}.page-detail-body h3{font-size:16px;font-weight:700;margin:16px 0 8px}.page-detail-body p{margin:8px 0}.page-detail-body ul,.page-detail-body ol{margin:8px 0;padding-left:24px}.page-detail-body li{margin:4px 0}.page-detail-body code{background:#f5f5f5;padding:1px 4px;border-radius:3px;font-family:Courier New,monospace;font-size:13px}.page-detail-body pre{background:#2d3b45;color:#e0e0e0;padding:14px 16px;border-radius:4px;overflow-x:auto;margin:12px 0}.page-detail-body pre code{background:none;color:inherit;padding:0}.page-detail-body a{color:var(--text-link)}.page-detail-body em{font-style:italic}.page-detail-body strong{font-weight:700}.page-editor-topbar{margin-bottom:12px}.page-editor-page h1{margin-bottom:16px}.page-editor-form{max-width:800px}.page-editor-body{font-family:Courier New,monospace;font-size:13px;min-height:300px}.files-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.files-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.files-actions{display:flex;gap:8px}.files-layout{display:flex;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-content);min-height:400px}.files-tree-panel{width:220px;flex-shrink:0;border-right:1px solid var(--border-color);padding:8px 0;overflow-y:auto}.files-tree-item{display:flex;align-items:center;gap:4px;padding:6px 10px;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background .1s}.files-tree-item:hover{background:#0374b50d}.files-tree-item.selected{background:#0374b51a;color:var(--primary);font-weight:600}.files-tree-toggle{display:flex;align-items:center;padding:0;color:var(--text-secondary);flex-shrink:0}.files-tree-spacer{width:14px;flex-shrink:0}.files-tree-icon{color:var(--primary);flex-shrink:0}.files-tree-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.files-list-panel{flex:1;overflow-x:auto}.files-breadcrumb{padding:10px 14px;font-size:14px;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.files-new-folder{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border-light);background:#0374b508}.files-new-folder input{flex:1;padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;outline:none}.files-new-folder input:focus{border-color:var(--primary)}.files-table{width:100%;border-collapse:collapse}.files-table thead{background:var(--bg-module-header)}.files-table th{text-align:left;padding:8px 14px;font-weight:700;font-size:12px;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap}.files-table td{padding:8px 14px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.files-table tbody tr:last-child td{border-bottom:none}.files-table tbody tr:hover{background:#0374b508}.files-row-folder{cursor:pointer}.files-row-folder:hover{background:#0374b50f}.files-name-cell{display:flex;align-items:center;gap:8px;font-weight:500}.files-icon-folder{color:var(--primary)}.files-date,.files-size{font-size:12px;color:var(--text-secondary);white-space:nowrap}.files-empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.syllabus-page h1{margin-bottom:16px}.syllabus-body{background:var(--bg-content);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:20px 24px;margin-bottom:24px;font-size:14px;line-height:1.7;color:var(--text-primary)}.syllabus-body h2{font-size:20px;font-weight:700;margin:16px 0 8px}.syllabus-body h3{font-size:16px;font-weight:700;margin:12px 0 6px}.syllabus-body p{margin:8px 0}.syllabus-body ul,.syllabus-body ol{margin:8px 0;padding-left:24px}.syllabus-body li{margin:4px 0}.syllabus-schedule h2{font-size:18px;font-weight:600;margin-bottom:12px}.syllabus-table{width:100%;border-collapse:collapse;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-content)}.syllabus-table thead{background:var(--bg-module-header)}.syllabus-table th{text-align:left;padding:10px 14px;font-weight:700;font-size:12px;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.syllabus-table td{padding:10px 14px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.syllabus-table tbody tr:last-child td{border-bottom:none}.syllabus-table tbody tr:hover{background:#0374b508}.syllabus-date{white-space:nowrap;color:var(--text-secondary);font-size:12px;width:120px}.syllabus-link{color:var(--text-link);font-weight:600}.syllabus-link:hover{text-decoration:underline}.syllabus-time{white-space:nowrap;color:var(--text-secondary);font-size:12px;width:100px}.syllabus-empty{text-align:center;padding:30px 20px;color:var(--text-secondary)}.settings-page h1{margin-bottom:16px}.settings-tabs{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:20px}.settings-tab{padding:10px 18px;font-size:14px;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .1s,border-color .1s}.settings-tab:hover{color:var(--text-primary)}.settings-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.settings-section{max-width:700px}.settings-form{display:flex;flex-direction:column;gap:16px}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.settings-nav-desc{font-size:13px;color:var(--text-secondary);margin-bottom:16px}.settings-nav-columns{display:flex;gap:24px}.settings-nav-col{flex:1}.settings-nav-col h3{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.settings-nav-list{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-content);min-height:200px}.settings-nav-hidden{background:var(--bg-page)}.settings-nav-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border-light);font-size:13px;color:var(--text-primary)}.settings-nav-item:last-child{border-bottom:none}.settings-nav-grip{color:var(--text-secondary);cursor:grab}.settings-nav-item span{flex:1}.settings-nav-hide,.settings-nav-show{display:flex;align-items:center;color:var(--text-secondary);padding:2px}.settings-nav-hide:hover{color:var(--danger)}.settings-nav-show:hover{color:var(--success)}.settings-features{display:flex;flex-direction:column;gap:0}.settings-feature-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border-light)}.settings-feature-item:last-child{border-bottom:none}.settings-feature-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.settings-feature-desc{font-size:12px;color:var(--text-secondary)}.settings-toggle{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0}.settings-toggle input{opacity:0;width:0;height:0}.settings-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--border-color);border-radius:24px;transition:.2s}.settings-toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.settings-toggle input:checked+.settings-toggle-slider{background:var(--success)}.settings-toggle input:checked+.settings-toggle-slider:before{transform:translate(18px)}.quizzes-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.quizzes-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.quizzes-toolbar{margin-bottom:16px}.quizzes-search{position:relative;max-width:300px}.quizzes-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.quizzes-search-input{width:100%;padding:8px 12px 8px 30px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);color:var(--text-primary);outline:none}.quizzes-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.quizzes-list{display:flex;flex-direction:column;gap:1px;border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;background:var(--border-color)}.quiz-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-content);transition:background .1s}.quiz-item:hover{background:#0374b508}.quiz-publish-btn{display:flex;align-items:center;justify-content:center;padding:4px}.unpublished-icon,.quiz-icon{color:var(--text-secondary)}.quiz-info{flex:1;min-width:0}.quiz-name{font-weight:600;color:var(--text-link);cursor:pointer;margin-bottom:4px}.quiz-name:hover{text-decoration:underline}.quiz-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-secondary)}.quiz-meta span{display:flex;align-items:center;gap:4px}.quiz-status{flex-shrink:0}.status-pill{display:inline-block;padding:3px 10px;border-radius:10px;font-size:11px;font-weight:600}.status-published{background:#e8f8ef;color:#0b874b}.status-unpublished{background:#f5f5f5;color:var(--text-secondary)}.quizzes-empty{text-align:center;padding:48px 24px;color:var(--text-secondary);background:var(--bg-content)}.quiz-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:40px;overflow-y:auto}.quiz-preview-modal{background:var(--bg-content);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:720px;max-height:calc(100vh - 80px);display:flex;flex-direction:column;margin-bottom:40px}.quiz-preview-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid var(--border-light)}.quiz-preview-header h2{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.quiz-preview-info{font-size:13px;color:var(--text-secondary)}.quiz-preview-close{font-size:24px;color:var(--text-secondary);padding:4px 8px;line-height:1}.quiz-preview-close:hover{color:var(--text-primary)}.quiz-score-banner{padding:12px 24px;background:#e8f5fd;color:#0374b5;font-weight:700;font-size:16px;border-bottom:1px solid var(--border-light)}.quiz-preview-body{padding:24px;overflow-y:auto;flex:1}.quiz-question{margin-bottom:24px;padding:16px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-content)}.quiz-question.correct{border-color:#0b874b;background:#f0fff5}.quiz-question.incorrect{border-color:#ee0612;background:#fff5f5}.quiz-question-header{display:flex;justify-content:space-between;margin-bottom:8px}.quiz-question-num{font-weight:700;font-size:13px;color:var(--text-primary)}.quiz-question-pts{font-size:12px;color:var(--text-secondary)}.quiz-question-text{font-size:14px;color:var(--text-primary);margin-bottom:12px;line-height:1.5}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:border-color .1s,background .1s}.quiz-option:hover{border-color:var(--primary)}.quiz-option input[type=radio]{width:16px;height:16px;accent-color:var(--primary);flex-shrink:0}.quiz-option.correct-answer{border-color:#0b874b;background:#e8f8ef}.quiz-option.wrong-answer{border-color:#ee0612;background:#fee}.quiz-short-answer{display:flex;flex-direction:column;gap:8px}.quiz-text-input{padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary);outline:none}.quiz-text-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.quiz-correct-text{font-size:13px;color:#0b874b;font-weight:600}.quiz-preview-footer{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border-light)}.groups-header{margin-bottom:24px}.groups-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light)}.groups-section h2{font-size:var(--font-size-section);font-weight:600;margin-bottom:16px;color:var(--text-primary)}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.group-card{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-content);overflow:hidden;transition:box-shadow .15s}.group-card:hover{box-shadow:var(--shadow-md)}.group-card-banner{height:40px}.group-card-body{padding:16px}.group-card-name{font-size:16px;font-weight:700;color:var(--text-link);margin-bottom:4px}.group-card-course{font-size:12px;color:var(--text-secondary);margin-bottom:8px}.group-card-desc{font-size:13px;color:var(--text-primary);margin-bottom:12px;line-height:1.4}.group-card-members{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.group-card-footer{display:flex;gap:0;border-top:1px solid var(--border-light)}.group-action{flex:1;display:flex;align-items:center;justify-content:center;padding:10px;color:var(--text-secondary);transition:background .1s,color .1s}.group-action:hover{background:#0374b50f;color:var(--primary)}.groups-empty{text-align:center;padding:64px 24px;color:var(--text-secondary)}.groups-empty svg{margin-bottom:16px;opacity:.4}.groups-empty p{font-size:16px}.notif-prefs-page{max-width:800px}.notif-prefs-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}.notif-prefs-header svg{color:var(--text-secondary);margin-top:4px;flex-shrink:0}.notif-prefs-header h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light);margin-bottom:4px}.notif-prefs-desc{font-size:var(--font-size-body);color:var(--text-secondary)}.notif-prefs-table-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-content)}.notif-prefs-table{width:100%;border-collapse:collapse}.notif-prefs-table thead{background:var(--bg-module-header)}.notif-prefs-table th{text-align:left;padding:12px 16px;font-weight:700;font-size:12px;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap}.notif-type-col{width:50%}.notif-channel-col{width:25%;text-align:center!important}.channel-header{display:flex;align-items:center;justify-content:center;gap:6px}.notif-prefs-table td{padding:12px 16px;border-bottom:1px solid var(--border-light);vertical-align:middle;text-align:center}.notif-prefs-table tbody tr:last-child td{border-bottom:none}.notif-prefs-table tbody tr:hover{background:#0374b508}.notif-type-cell{text-align:left!important}.notif-type-label{font-weight:600;font-size:14px;color:var(--text-primary);margin-bottom:2px}.notif-type-desc{font-size:12px;color:var(--text-secondary)}.notif-freq-select{padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:13px;color:var(--text-primary);background:var(--bg-content);outline:none;min-width:130px}.notif-freq-select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #0374b526}.notif-prefs-footer{margin-top:20px;display:flex;justify-content:flex-end}:root{--nav-bg: #394B58;--nav-bg-hover: #4a5e6d;--nav-active-border: #0374B5;--primary: #0374B5;--primary-hover: #0B6CA3;--primary-light: #E8F5FD;--bg-page: #F5F5F5;--bg-content: #FFFFFF;--bg-module-header: #F5F5F5;--text-primary: #2D3B45;--text-secondary: #6B7780;--text-link: #0374B5;--text-white: #FFFFFF;--border-color: #C7CDD1;--border-light: #E5E5E5;--success: #0B874B;--success-light: #E8F8EF;--warning: #FC5E13;--danger: #EE0612;--danger-light: #FDE8E8;--course-blue: #0374B5;--course-red: #EE0612;--course-green: #0B874B;--course-orange: #FC5E13;--course-purple: #6B3FA0;--font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-size-title: 28px;--font-size-section: 20px;--font-size-body: 14px;--font-size-small: 12px;--font-size-nav: 10px;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-bold: 700;--nav-width: 80px;--course-nav-width: 200px;--sidebar-width: 280px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 2px 8px rgba(0, 0, 0, .15);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .2);--radius-sm: 4px;--radius-md: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:var(--font-family);font-size:var(--font-size-body);color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font-family);cursor:pointer;border:none;background:none;font-size:inherit}input,textarea,select{font-family:var(--font-family);font-size:var(--font-size-body)}h1{font-size:var(--font-size-title);font-weight:var(--font-weight-light);color:var(--text-primary)}h2{font-size:var(--font-size-section);font-weight:var(--font-weight-normal);color:var(--text-primary)}h3{font-size:16px;font-weight:var(--font-weight-bold);color:var(--text-primary)}.app-layout{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;margin-left:var(--nav-width);overflow-y:auto;background:var(--bg-page)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;font-size:11px;font-weight:var(--font-weight-bold);color:#fff}.badge-danger{background:var(--danger)}.badge-primary{background:var(--primary)}.badge-success{background:var(--success)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:var(--font-size-body);font-weight:var(--font-weight-normal);transition:background .15s,border-color .15s}.btn-primary{background:var(--primary);color:#fff;border:1px solid var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-success{background:var(--success);color:#fff;border:1px solid var(--success)}.btn-success:hover{background:#097a42}.btn-secondary{background:var(--bg-content);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-page)}.btn-danger{background:var(--danger);color:#fff;border:1px solid var(--danger)}.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--font-weight-bold);color:#fff;background:var(--primary);flex-shrink:0}.published-icon{color:var(--success)}.unpublished-icon{color:var(--text-secondary)}.pill-toggle{display:inline-flex;border:1px solid var(--border-color);border-radius:20px;overflow:hidden}.pill-toggle button{padding:6px 12px;background:var(--bg-content);color:var(--text-secondary);border:none;display:flex;align-items:center;gap:4px;font-size:13px;transition:background .15s,color .15s}.pill-toggle button.active{background:var(--text-primary);color:#fff}.pill-toggle button:hover:not(.active){background:var(--bg-page)}
