.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-button);font-weight:600;transition:all .2s ease;cursor:pointer;border:1px solid transparent;outline:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-accent-blue);color:#fff;box-shadow:0 4px 12px #3b82f64d}.btn-primary:hover:not(:disabled){background-color:#2563eb;transform:translateY(-1px)}.btn-secondary{background-color:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border-light)}.btn-secondary:hover:not(:disabled){background-color:var(--color-surface-muted)}.btn-outline{background-color:transparent;border:1px solid var(--color-accent-blue);color:var(--color-accent-blue)}.btn-outline:hover:not(:disabled){background-color:#3b82f60d}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:#0000000d;color:var(--color-text-primary)}.btn-sm{padding:6px 12px;font-size:var(--font-size-small)}.btn-md{padding:10px 20px;font-size:var(--font-size-body)}.btn-lg{padding:14px 28px;font-size:var(--font-size-h3)}.btn-full{width:100%}.input-wrapper{display:flex;flex-direction:column;gap:6px}.input-full{width:100%}.input-label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-secondary)}.input-field{padding:10px 14px;border-radius:var(--radius-button);border:1px solid var(--color-border-light);background-color:var(--color-surface);font-family:inherit;font-size:var(--font-size-body);transition:all .2s ease;outline:none}.input-field:focus{border-color:var(--color-accent-blue);box-shadow:0 0 0 3px #3b82f61a}.input-field.input-error{border-color:var(--color-accent-red)}.input-error-message{font-size:var(--font-size-small);color:var(--color-accent-red)}.card{background-color:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);border:1px solid rgba(255,255,255,.5)}.card-hoverable{transition:transform .2s ease,box-shadow .2s ease}.card-hoverable:hover{transform:translateY(-2px);box-shadow:0 12px 32px #0f172a14}.card-padding-none{padding:0}.card-padding-sm{padding:var(--spacing-4)}.card-padding-md{padding:var(--spacing-6)}.card-padding-lg{padding:var(--spacing-8)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:var(--spacing-4)}.auth-content{width:100%;max-width:450px}.auth-header{text-align:center;margin-bottom:var(--spacing-8)}.auth-logo{font-size:48px;font-weight:900;color:#fff;margin:0 0 var(--spacing-2) 0;text-shadow:0 2px 10px rgba(0,0,0,.2)}.auth-logo-img{width:80px;height:80px;object-fit:contain;margin-bottom:var(--spacing-4)}.auth-tagline{color:#ffffffe6;font-size:var(--font-size-body);margin:0}.auth-card{background:#fff;box-shadow:0 20px 60px #0000004d}.auth-title{font-size:var(--font-size-h2);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-2) 0}.auth-subtitle{color:var(--color-text-secondary);margin:0 0 var(--spacing-6) 0}.auth-error{padding:var(--spacing-3);background:#fee;border:1px solid #fcc;border-radius:var(--radius-md);color:#c33;margin-bottom:var(--spacing-4);font-size:var(--font-size-small)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.form-group label{font-size:var(--font-size-small);font-weight:600;color:var(--color-text-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4)}.auth-select{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-body);font-family:inherit;background:#fff;color:var(--color-text-primary);cursor:pointer;transition:border-color .2s}.auth-select:hover{border-color:var(--color-accent)}.auth-select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f11a}.auth-footer{margin-top:var(--spacing-6);text-align:center;padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.auth-footer p{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-small)}.auth-link{color:var(--color-accent);text-decoration:none;font-weight:600;transition:color .2s}.auth-link:hover{color:var(--color-accent-dark);text-decoration:underline}.auth-help{text-align:center;margin-top:var(--spacing-4);color:#ffffffe6;font-size:var(--font-size-small)}.auth-help a{color:#fff;font-weight:600}@media(max-width:768px){.form-row{grid-template-columns:1fr}.auth-logo{font-size:36px}}.sidebar{width:260px;background-color:var(--color-surface);height:100vh;display:flex;flex-direction:column;padding:var(--spacing-8) var(--spacing-4);border-right:1px solid var(--color-border-light);position:fixed;left:0;top:0}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:0 12px;margin-bottom:40px}.logo-icon{width:32px;height:32px;border-radius:8px;object-fit:contain}.logo-text{font-size:20px;font-weight:700;color:var(--color-text-primary)}.sidebar-nav{display:flex;flex-direction:column;gap:8px;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-pill);color:var(--color-text-secondary);text-decoration:none;transition:all .2s ease;border:none;background:none;width:100%;cursor:pointer;font-family:inherit;font-size:var(--font-size-body)}.nav-item:hover{background-color:var(--color-surface-muted);color:var(--color-text-primary)}.nav-item-active{background-color:var(--color-surface-muted);background-color:#3b82f614;color:var(--color-accent-blue);font-weight:600}.nav-icon{color:var(--color-text-light)}.nav-icon-active{color:var(--color-accent-blue)}.sidebar-footer{display:flex;flex-direction:column;gap:8px;margin-top:auto;padding-top:20px;border-top:1px solid var(--color-border-light)}.logout-btn,.logout-btn .nav-icon{color:var(--color-accent-red)}.logout-btn:hover{background-color:#ef44440d}.app-layout{display:flex;min-height:100vh;background-color:var(--color-background)}.main-content{flex:1;margin-left:260px;padding:var(--spacing-8);display:flex;flex-direction:column}.content-container{width:100%;margin:0 auto;display:block!important}.right-panel{width:320px;background-color:var(--color-background);padding:var(--spacing-8) var(--spacing-6) var(--spacing-8) 0;flex-shrink:0;display:flex;flex-direction:column;gap:var(--spacing-6)}@media(max-width:1024px){.right-panel{display:none}.main-content{margin-right:0}}.header-card{margin-bottom:32px;padding-top:16px;width:100%;max-width:none;grid-column:1 / -1;box-sizing:border-box}.header-card-content{display:flex;justify-content:space-between;align-items:center;width:100%}.header-text{display:flex;flex-direction:column;gap:8px;flex:1}.header-title{font-size:32px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.5px}.header-subtitle{font-size:16px;color:var(--color-text-secondary);font-weight:400;line-height:1.5}.header-date{display:flex;align-items:center;gap:12px;background-color:#f8f9fe;padding:8px 8px 8px 16px;border-radius:999px}.date-text{font-weight:500;color:var(--color-text-primary);font-size:14px}.calendar-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--color-text-primary)}@media(max-width:768px){.header-card-content{flex-direction:column;align-items:flex-start;gap:16px}.header-text{max-width:100%}.header-date{width:100%;justify-content:space-between}}.header-actions{margin-top:16px;display:flex;gap:12px}.action-btn{display:flex;align-items:center;font-weight:500}.header-actions .action-btn{background-color:#fff;color:#4f46e5;border:none}.header-actions .action-btn:hover{background-color:#f3f4f6}.join-link{text-decoration:underline;color:#000!important;justify-content:flex-start}.icon-black{color:#000}.stats-strip{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid #E5E7EB;border-bottom:1px solid #E5E7EB;margin-bottom:32px}.stat-card{display:flex;align-items:center;gap:14px;padding:16px 24px;background:transparent;border:none;position:relative;transition:background .2s}.stat-card:not(:last-child):after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);height:60%;width:1px;background-color:#e5e7eb}.stat-card:hover{background:#f9fafb}.stat-icon-wrapper{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background-color:#f3f4f6;color:#1f2937}.stat-info{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:13px;color:var(--color-text-primary);font-weight:500}.stat-content{display:flex;align-items:baseline;gap:8px}.stat-value{font-size:20px;font-weight:700;color:var(--color-text-primary);line-height:1}.stat-trend{font-size:11px;font-weight:500;display:flex;align-items:center;gap:2px}.stat-trend.green{color:#10b981}.stat-trend.red{color:#ef4444}@media(max-width:768px){.stats-strip{grid-template-columns:1fr;margin-bottom:24px}.stat-card{padding:16px 0;border-bottom:1px solid #E5E7EB}.stat-card:not(:last-child):after{display:none}.stat-card:last-child{border-bottom:none}}.lesson-list-container{margin-bottom:32px}.section-title{font-size:20px;font-weight:700;color:var(--color-text-primary)}.header-subtitle{font-size:16px;color:var(--color-text-primary);font-weight:500}.week-filter-btn{border:1px solid #E5E7EB;border-radius:20px;padding:6px 16px;font-weight:500;color:var(--color-text-primary);display:flex;align-items:center;gap:8px}.lesson-list{display:flex;flex-direction:column;gap:24px}.lesson-item{display:grid;grid-template-columns:auto 1fr 140px auto auto;align-items:center;gap:24px;cursor:pointer;transition:opacity .2s}.lesson-item:hover{opacity:.8}.lesson-item.lesson-locked{opacity:.5;cursor:not-allowed}.lesson-icon-container{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;color:var(--color-text-primary)}.lesson-item:nth-child(1) .lesson-icon-container{background-color:#e0e7ff;color:#4338ca}.lesson-item:nth-child(2) .lesson-icon-container{background-color:#fef3c7;color:#d97706}.lesson-item:nth-child(3) .lesson-icon-container{background-color:#f3f4f6;color:#374151}.lesson-main-info{min-width:0}.lesson-title{font-size:16px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lesson-status{display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.orange{background-color:#f59e0b}.status-dot.green{background-color:#10b981}.status-dot.blue{background-color:#3b82f6}.status-dot.gray{background-color:#9ca3af}.status-text{font-size:14px;font-weight:500;color:var(--color-text-primary)}.lesson-duration{display:flex;align-items:center;gap:8px;color:var(--color-text-primary);font-weight:600;font-size:14px}.duration-icon-wrapper{width:20px;height:20px;border-radius:50%;background-color:#e5e7eb;display:flex;align-items:center;justify-content:center;color:#fff}.clock-icon{color:#fff}.lesson-actions{display:flex;justify-content:flex-end}.more-btn{background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.more-btn:hover{background-color:#f3f4f6;color:var(--color-text-primary)}@media(max-width:768px){.lesson-item{grid-template-columns:auto 1fr auto;gap:12px}.lesson-status,.lesson-duration{display:none}}.mr-2{margin-right:8px}.join-link-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;font-size:14px;font-weight:600;color:#000;text-decoration:underline;white-space:nowrap}.join-link-btn:hover{opacity:.8}.action-btn{white-space:nowrap}.join-link{text-decoration:underline;color:#000!important;padding:0}.join-link:hover{background-color:transparent!important;opacity:.8}.icon-black{color:#000;min-width:16px}.profile-card{display:flex;flex-direction:column;align-items:center;text-align:center;background-color:#f3f4f6;border-radius:24px;padding:40px 24px;width:100%}.profile-header{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.avatar-container{position:relative;margin-bottom:16px}.avatar-container img,.default-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:4px solid #FFFFFF}.default-avatar{background-color:#e5e7eb;display:flex;align-items:center;justify-content:center;color:#9ca3af}.status-dot{position:absolute;bottom:4px;right:4px;width:16px;height:16px;background-color:#ef4444;border:2px solid #FFFFFF;border-radius:50%}.profile-name{font-size:18px;font-weight:700;color:var(--color-text-primary);margin-bottom:4px}.profile-username{font-size:14px;color:var(--color-text-secondary)}.profile-actions{display:flex;gap:16px;justify-content:center;width:100%}.action-btn{width:48px;height:48px;border-radius:50%;border:none;background-color:#fff;color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000000d}.action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.feed-title{font-size:var(--font-size-h3);font-weight:700;color:var(--color-text-primary);margin-bottom:16px}.feed-list{display:flex;flex-direction:column;gap:16px}.feed-item{display:flex;align-items:flex-start;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--color-border-light)}.feed-item:last-child{border-bottom:none;padding-bottom:0}.feed-content{display:flex;flex-direction:column;gap:4px}.feed-text{font-size:var(--font-size-body);color:var(--color-text-primary);line-height:1.4}.feed-points{color:var(--color-accent-green);font-weight:600}.feed-time{font-size:var(--font-size-small);color:var(--color-text-light)}.leaderboard-section{margin-bottom:32px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header-left{display:flex;align-items:center;gap:16px}.section-title{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0}.header-divider{width:1px;height:24px;background-color:#e5e7eb}.header-subtitle{font-size:16px;color:var(--color-text-primary);font-weight:500;margin:0}.leaderboard-list{display:flex;flex-direction:column;gap:24px}.leaderboard-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;padding:0;background:transparent;transition:opacity .2s}.leaderboard-item:hover{opacity:.8;background:transparent}.rank-container{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;color:var(--color-text-secondary);font-weight:700;font-size:16px}.leaderboard-item:nth-child(1) .rank-container{background-color:#fef3c7;color:#d97706}.leaderboard-item:nth-child(2) .rank-container{background-color:#f3f4f6;color:#9ca3af}.leaderboard-item:nth-child(3) .rank-container{background-color:#ffedd5;color:#c2410c}.rank-icon{display:block}.rank-icon.gold{color:#d97706}.rank-icon.silver{color:#9ca3af}.rank-icon.bronze{color:#c2410c}.student-info{min-width:0;display:flex;flex-direction:column;gap:2px}.student-name{font-size:16px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-cohort{font-size:13px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-points{display:flex;align-items:baseline;gap:4px;flex-shrink:0}.points-value{font-size:16px;font-weight:700;color:var(--color-text-primary)}.points-label{font-size:12px;color:var(--color-text-secondary);font-weight:500}.expand-btn{margin-top:24px;display:flex;align-items:center;justify-content:center;gap:6px;color:var(--color-text-secondary)}@media(max-width:640px){.leaderboard-item{gap:16px}.rank-container{width:40px;height:40px;font-size:14px}.student-name{font-size:14px}.student-cohort{font-size:12px}.points-value{font-size:15px}}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-pill);font-size:var(--font-size-small);font-weight:600;line-height:1}.badge-primary{background-color:#3b82f61a;color:var(--color-accent-blue)}.badge-success{background-color:#22c55e1a;color:var(--color-accent-green)}.badge-warning{background-color:#f59e0b1a;color:var(--color-accent-orange)}.badge-danger{background-color:#ef44441a;color:var(--color-accent-red)}.badge-neutral{background-color:var(--color-surface-muted);color:var(--color-text-secondary);border:1px solid var(--color-border-light)}.sticky-board-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1100;padding:20px}.sticky-board-modal{background:#2a2a2a;border-radius:var(--radius-lg);width:100%;height:100%;max-width:100%;max-height:100%;display:flex;flex-direction:column;overflow:hidden}.sticky-board-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);background:#333}.sticky-board-header h2{margin:0;font-size:20px;font-weight:600;color:#fff}.sticky-board-close{background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--radius-md);color:#fff9;transition:all .2s ease}.sticky-board-close:hover{background:#ffffff1a;color:#fff}.sticky-board-content{flex:1;overflow:auto;padding:40px;background:#f5f5f5}.sticky-board-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-size:16px}.sticky-board-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;padding:20px}.sticky-card{width:100%;min-height:180px;padding:0;display:flex;flex-direction:column;position:relative;transition:transform .3s ease,box-shadow .3s ease;cursor:default;box-shadow:2px 3px 8px #00000026,0 0 1px #0000001a;border-radius:2px}.sticky-card:nth-child(6n+1){transform:rotate(-2deg)}.sticky-card:nth-child(6n+2){transform:rotate(1.5deg)}.sticky-card:nth-child(6n+3){transform:rotate(-1deg)}.sticky-card:nth-child(6n+4){transform:rotate(2.5deg)}.sticky-card:nth-child(6n+5){transform:rotate(-1.5deg)}.sticky-card:nth-child(6n+6){transform:rotate(.5deg)}.sticky-card:hover{transform:rotate(0) scale(1.05) translateY(-5px);box-shadow:4px 6px 20px #0006,0 0 2px #0000004d;z-index:10}.sticky-card:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:50px;height:20px;background:linear-gradient(180deg,#fff6,#fff3);border-radius:2px;box-shadow:0 1px 3px #0000001a}.sticky-card:after{content:"";position:absolute;bottom:0;right:0;width:0;height:0;border-style:solid;border-width:0 0 20px 20px;border-color:transparent transparent rgba(0,0,0,.1) transparent;border-radius:0 0 2px}.sticky-card-inner{padding:20px 16px 16px;display:flex;flex-direction:column;flex:1;position:relative;z-index:1}.sticky-card-content{flex:1;padding:16px;display:flex;flex-direction:column}.sticky-card-image{width:100%;height:70px;overflow:hidden;background:#ffffff4d;border-radius:4px;margin-top:10px;border:1px solid rgba(0,0,0,.08)}.sticky-card-image img{width:100%;height:100%;object-fit:cover;border-radius:4px}.sticky-card-title{font-size:15px;font-weight:700;margin:0 0 8px;color:#000000d9;word-wrap:break-word;line-height:1.3;letter-spacing:-.3px}.sticky-card-description{font-size:13px;color:#000000a6;margin:0;line-height:1.5;word-wrap:break-word}.sticky-card-author{margin-top:auto;padding:12px 16px;font-size:11px;color:#00000073;font-style:italic;border-top:1px dashed rgba(0,0,0,.15)}.sticky-card-content:before{content:"";position:absolute;left:16px;right:16px;top:50px;height:1px;background:repeating-linear-gradient(90deg,#0000000f 0px 100%)}.sticky-card[style*="#FFF9C4"]{background:linear-gradient(145deg,#fff9c4,#fff59d)}.sticky-card[style*="#FFCDD2"]{background:linear-gradient(145deg,#ffcdd2,#ffab91)}.sticky-card[style*="#BBDEFB"]{background:linear-gradient(145deg,#bbdefb,#90caf9)}.sticky-card[style*="#C8E6C9"]{background:linear-gradient(145deg,#c8e6c9,#a5d6a7)}.sticky-card[style*="#FFE0B2"]{background:linear-gradient(145deg,#ffe0b2,#ffcc80)}.sticky-card[style*="#E1BEE7"]{background:linear-gradient(145deg,#e1bee7,#ce93d8)}.sticky-card.with-pin:before{content:"";position:absolute;top:-5px;left:50%;transform:translate(-50%);width:16px;height:16px;background:radial-gradient(circle at 30% 30%,#ff6b6b,#c92a2a);border-radius:50%;box-shadow:0 2px 4px #0000004d,inset 0 -2px 4px #0003}@media(max-width:1200px){.sticky-board-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:992px){.sticky-board-grid{grid-template-columns:repeat(3,1fr)}.sticky-board-content{padding:24px}}@media(max-width:768px){.sticky-board-grid{grid-template-columns:repeat(2,1fr);gap:16px}.sticky-card-title{font-size:13px}.sticky-card-description{font-size:11px}}@media(max-width:480px){.sticky-board-grid{grid-template-columns:1fr;gap:16px}}.lesson-player-page{min-height:100vh;background:var(--color-background);padding-bottom:60px}.lesson-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:16px 0;position:sticky;top:0;z-index:100}.header-content{max-width:1000px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px}.header-left{justify-self:start}.header-center{text-align:center}.header-right{justify-self:end}.lesson-page-title{font-size:24px;font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.lesson-meta{display:flex;align-items:center;justify-content:center;gap:12px;font-size:14px;color:var(--color-text-secondary)}.point-badge{padding:4px 12px;background:var(--color-background);border-radius:var(--radius-md);font-weight:500}.lesson-content{max-width:900px;margin:32px auto;padding:0 24px}.meeting-card-full{margin-bottom:32px;border:2px solid var(--color-accent);background:var(--color-surface)}.meeting-header{margin-bottom:16px}.meeting-label{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--color-text-primary);margin-bottom:6px}.meeting-label svg{color:var(--color-accent)}.meeting-description{font-size:14px;color:var(--color-text-secondary);margin:0}.meeting-url-container{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding:10px 12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md)}.meeting-url-text{flex:1;font-size:14px;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copy-icon-btn{flex-shrink:0;background:transparent;border:none;padding:4px;cursor:pointer;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s}.copy-icon-btn:hover{background:var(--color-background);color:var(--color-accent)}.meeting-join-btn{display:inline-flex;align-items:center;gap:6px}.activities-section{margin-bottom:48px}.section-heading{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.section-description{font-size:14px;color:var(--color-text-secondary);margin:0 0 24px}.activities-list-full{display:flex;flex-direction:column;gap:24px}.activity-card-full{border:1px solid var(--color-border);transition:box-shadow .2s}.activity-card-full:hover{box-shadow:0 4px 12px #00000014}.activity-header-full{margin-bottom:20px}.activity-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.activity-section-number{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0}.activity-content-full{display:flex;flex-direction:column;gap:20px}.activity-prompt-full{font-size:16px;font-weight:500;color:var(--color-text-primary);margin:0;line-height:1.5}.text-content-section{font-size:15px;line-height:1.7;color:var(--color-text-primary)}.text-content-section h1,.text-content-section h2,.text-content-section h3{margin-top:24px;margin-bottom:12px;font-weight:600}.text-content-section h2{font-size:20px}.text-content-section h3{font-size:18px}.text-content-section p{margin:12px 0}.text-content-section ul,.text-content-section ol{margin:12px 0;padding-left:24px}.text-content-section li{margin:6px 0}.options-grid{display:grid;gap:12px}.option-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;text-align:left;font-size:15px}.option-card:hover:not(.disabled){border-color:var(--color-accent);background:var(--color-surface)}.option-card.selected{border-color:var(--color-accent);background:var(--color-accent-light)}.option-card.disabled{opacity:.6;cursor:not-allowed}.option-marker{width:24px;height:24px;border-radius:50%;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-accent)}.option-card.selected .option-marker{border-color:var(--color-accent)}.answer-textarea{width:100%;padding:12px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;font-family:inherit;resize:vertical;min-height:120px;transition:border-color .2s}.answer-textarea:focus{outline:none;border-color:var(--color-accent)}.answer-textarea:disabled{opacity:.6;background:var(--color-background)}.submit-btn{align-self:flex-start}.feedback-box{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--color-accent-green-light);border:1px solid var(--color-accent-green);border-radius:var(--radius-md);color:var(--color-accent-green);font-weight:500}.resources-section{margin-top:48px}.resources-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:20px}.resource-card{height:auto;padding:16px;display:flex;flex-direction:column;align-items:center;gap:8px;text-decoration:none}.resource-card:hover{background:var(--color-accent-light);border-color:var(--color-accent)}.bingo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}.bingo-term{position:relative;min-height:80px;padding:12px;background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px}.bingo-term:hover:not(.disabled){border-color:var(--color-accent);background:var(--color-surface);transform:translateY(-2px)}.bingo-term.selected{border-color:var(--color-accent);background:var(--color-accent-light)}.bingo-term.disabled{opacity:.6;cursor:not-allowed}.bingo-term .check-icon{color:var(--color-accent)}.activity-description{margin:0 0 12px;font-size:14px;color:var(--color-text-secondary)}.stickies-form,.stickies-instructor-view{display:flex;flex-direction:column;gap:16px}.view-responses-btn{align-self:flex-start}.sticky-form-field{display:flex;flex-direction:column;gap:6px}.sticky-form-label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.sticky-title-input{padding:12px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;font-family:inherit;transition:border-color .2s}.sticky-title-input:focus{outline:none;border-color:var(--color-accent)}.sticky-description-input{padding:12px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s}.sticky-description-input:focus{outline:none;border-color:var(--color-accent)}.sticky-image-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px;border:2px dashed var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;color:var(--color-text-secondary)}.sticky-image-dropzone:hover{border-color:var(--color-accent);background:var(--color-background-subtle)}.sticky-image-preview{position:relative;width:100%;max-width:300px;border-radius:var(--radius-md);overflow:hidden}.sticky-image-preview img{width:100%;height:auto;display:block}.sticky-image-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#0009;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s}.sticky-image-remove:hover{background:#000c}@media(max-width:768px){.header-content{grid-template-columns:1fr;gap:12px}.header-left,.header-center,.header-right{justify-self:stretch}.header-center{text-align:left}.lesson-page-title{font-size:20px}.lesson-meta{justify-content:flex-start}.meeting-content{flex-direction:column;align-items:stretch}.meeting-btn{width:100%;text-align:center}.resources-grid{grid-template-columns:1fr}}.settings-page{max-width:800px;margin:0 auto}.settings-header{margin-bottom:32px}.settings-title{font-size:28px;font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.settings-subtitle{font-size:15px;color:var(--color-text-secondary);margin:0}.settings-content{display:flex;flex-direction:column;gap:24px}.settings-section{border:1px solid var(--color-border)}.section-header-settings{display:flex;align-items:flex-start;gap:12px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--color-border)}.section-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-accent-light);display:flex;align-items:center;justify-content:center;color:var(--color-accent);flex-shrink:0}.section-title-settings{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.settings-form{display:flex;flex-direction:column;gap:20px}.form-row{width:100%}.form-row-split{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-field{display:flex;flex-direction:column;gap:8px}.input-label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.readonly-field{padding:10px 12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md)}.readonly-text{font-size:14px;color:var(--color-text-secondary)}.input-with-message{display:flex;flex-direction:column;gap:8px}.email-notice{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:var(--color-accent-orange-light);border:1px solid var(--color-accent-orange);border-radius:var(--radius-md);font-size:13px;color:var(--color-accent-orange);line-height:1.5}.email-notice svg{flex-shrink:0;margin-top:2px}.settings-actions{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding-top:20px;border-top:1px solid var(--color-border)}.save-message{font-size:14px;font-weight:500;color:var(--color-accent-green);display:flex;align-items:center;gap:6px}@media(max-width:640px){.settings-page{padding:0 16px}.settings-title{font-size:24px}.form-row-split{grid-template-columns:1fr}.settings-actions{flex-direction:column-reverse;align-items:stretch;gap:12px}}.admin-sidebar{width:260px;background-color:var(--color-surface);height:100vh;display:flex;flex-direction:column;padding:var(--spacing-8) var(--spacing-4);border-right:1px solid var(--color-border-light);position:fixed;left:0;top:0}.admin-sidebar-logo{display:flex;align-items:center;gap:12px;padding:0 12px;margin-bottom:40px}.admin-sidebar-nav{display:flex;flex-direction:column;gap:8px;flex:1}.admin-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-pill);color:var(--color-text-secondary);text-decoration:none;transition:all .2s ease}.admin-nav-item:hover{background-color:var(--color-surface-muted);color:var(--color-text-primary)}.admin-nav-item-active{background-color:#3b82f614;color:var(--color-accent-blue);font-weight:600}.admin-nav-icon{color:var(--color-text-light)}.admin-nav-icon-active{color:var(--color-accent-blue)}.admin-logout-btn{margin-top:auto;width:100%;border:none;background:none;cursor:pointer;font-size:inherit;font-family:inherit}.admin-logout-btn:hover,.admin-logout-btn:hover .admin-nav-icon{color:var(--color-error, #ef4444)}.admin-layout{display:flex;min-height:100vh;background-color:var(--color-background)}.admin-main{flex:1;margin-left:260px;padding:var(--spacing-8);display:flex;flex-direction:column}.admin-content{max-width:1400px;width:100%;margin:0 auto}.admin-page-header{margin-bottom:var(--spacing-8)}.admin-page-title{font-size:var(--font-size-h1);font-weight:700;color:var(--color-text-primary);margin-bottom:8px}.admin-page-subtitle{font-size:var(--font-size-body);color:var(--color-text-secondary)}.admin-page-actions{display:flex;gap:12px;align-items:center}.admin-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.admin-stat-card{display:flex;gap:16px}.admin-stat-icon-wrapper{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-stat-info{display:flex;flex-direction:column;gap:4px;flex:1}.admin-stat-label{font-size:var(--font-size-small);color:var(--color-text-secondary);font-weight:500}.admin-stat-value{font-size:32px;font-weight:700;color:var(--color-text-primary);line-height:1}.admin-stat-change{font-size:var(--font-size-small);color:var(--color-accent-green);font-weight:500}.admin-dashboard-sections{display:grid;gap:var(--spacing-8)}.section-title{font-size:var(--font-size-h3);font-weight:700;color:var(--color-text-primary);margin-bottom:20px}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--color-border-light)}.activity-item:last-child{border-bottom:none;padding-bottom:0}.activity-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--color-surface-muted);border-radius:8px}.activity-content{flex:1;display:flex;flex-direction:column;gap:4px}.activity-text{font-size:var(--font-size-body);color:var(--color-text-primary);line-height:1.4}.activity-time{font-size:var(--font-size-small);color:var(--color-text-light)}@media(max-width:1200px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.admin-stats-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-title{font-size:1.25rem;font-weight:600;color:#111827;margin:0}.modal-close{background:none;border:none;cursor:pointer;color:#6b7280;padding:.5rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background-color:#f3f4f6;color:#111827}.modal-body{padding:1.5rem}.create-cohort-form{display:flex;flex-direction:column;gap:1.5rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:.875rem;transition:all .2s;resize:vertical}.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-textarea.input-error{border-color:#ef4444}.form-select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:.875rem;background-color:#fff;cursor:pointer;transition:all .2s}.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid #e5e7eb}.form-error{padding:.75rem;background-color:#fee2e2;color:#991b1b;border-radius:8px;font-size:.875rem}.cohort-list-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-border-light)}.search-bar{position:relative;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-light)}.search-input{width:100%;padding:10px 14px 10px 40px;border-radius:var(--radius-button);border:1px solid var(--color-border-light);background-color:var(--color-surface-muted);font-family:inherit;font-size:var(--font-size-body);outline:none}.search-input:focus{border-color:var(--color-accent-blue);background-color:var(--color-surface)}.cohort-table{overflow-x:auto}.cohort-table table{width:100%;border-collapse:collapse}.cohort-table thead{background-color:var(--color-surface-muted)}.cohort-table th{padding:12px 16px;text-align:left;font-size:var(--font-size-small);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.cohort-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .15s ease}.cohort-table tbody tr:hover{background-color:var(--color-surface-muted)}.cohort-table tbody tr:last-child{border-bottom:none}.cohort-table td{padding:16px;font-size:var(--font-size-body);color:var(--color-text-primary)}.cohort-name-cell{display:flex;flex-direction:column;gap:4px}.cohort-name{font-weight:600;color:var(--color-text-primary)}.cohort-description{font-size:var(--font-size-small);color:var(--color-text-secondary)}.csv-upload-content{display:flex;flex-direction:column;gap:1.5rem}.csv-upload-description{color:#4b5563;font-size:.9375rem;line-height:1.5;margin:0}.csv-format-info{background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;padding:1rem}.csv-format-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.csv-format-info h4{margin:0 0 .5rem;font-size:.875rem;color:#0369a1}.csv-format-info code{display:block;background-color:#e0f2fe;padding:.5rem;border-radius:4px;font-size:.875rem;color:#0c4a6e}.csv-download-sample{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background-color:#0369a1;color:#fff;border:none;border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.csv-download-sample:hover{background-color:#075985}.csv-format-note{margin:.75rem 0 0;font-size:.8125rem;color:#0369a1}.csv-dropzone{border:2px dashed #d1d5db;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;background-color:#f9fafb}.csv-dropzone:hover{border-color:#3b82f6;background-color:#eff6ff}.csv-dropzone.has-file{border-color:#10b981;background-color:#ecfdf5}.csv-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:#6b7280}.csv-dropzone-content svg{color:#9ca3af}.csv-file-input{display:none}.csv-file-selected{display:flex;align-items:center;gap:.75rem;color:#059669}.csv-file-selected svg:first-child{color:#10b981}.csv-filename{font-weight:500}.csv-remove-file{padding:.25rem;border:none;background:none;cursor:pointer;color:#6b7280;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.csv-remove-file:hover{background-color:#fee2e2;color:#dc2626}.csv-preview{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.csv-preview h4{margin:0;padding:.75rem 1rem;background-color:#f3f4f6;font-size:.875rem;color:#374151;border-bottom:1px solid #e5e7eb}.csv-preview-table{max-height:200px;overflow-y:auto}.csv-preview-table table{width:100%;border-collapse:collapse;font-size:.8125rem}.csv-preview-table th,.csv-preview-table td{padding:.5rem 1rem;text-align:left;border-bottom:1px solid #e5e7eb}.csv-preview-table th{background-color:#f9fafb;font-weight:600;color:#6b7280}.csv-preview-table td{color:#374151}.csv-preview-more{margin:0;padding:.5rem 1rem;font-size:.8125rem;color:#6b7280;font-style:italic}.csv-column-warnings{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:1rem}.csv-column-warnings h4{margin:0 0 .5rem;font-size:.875rem;color:#1e40af;display:flex;align-items:center;gap:.5rem}.csv-column-warnings ul{margin:0;padding-left:1.25rem;font-size:.8125rem;color:#1d4ed8}.csv-column-warnings li{margin-bottom:.25rem}.csv-parse-errors{background-color:#fef3c7;border:1px solid #fcd34d;border-radius:8px;padding:1rem}.csv-parse-errors h4{margin:0 0 .5rem;font-size:.875rem;color:#92400e;display:flex;align-items:center;gap:.5rem}.csv-parse-errors ul{margin:0;padding-left:1.25rem;font-size:.8125rem;color:#a16207}.csv-parse-errors li{margin-bottom:.25rem}.csv-parse-errors p{margin:.5rem 0 0;font-size:.8125rem;color:#92400e}.csv-error{background-color:#fee2e2;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;color:#991b1b;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.csv-result{display:flex;flex-direction:column;gap:1.5rem}.csv-result-header{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;border-radius:8px;text-align:center}.csv-result-header.success{background-color:#ecfdf5;color:#059669}.csv-result-header.partial{background-color:#fef3c7;color:#d97706}.csv-result-header h3{margin:0;font-size:1.125rem;color:inherit}.csv-result-stats{display:flex;justify-content:center;gap:2rem}.csv-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.csv-stat-value{font-size:2rem;font-weight:700}.csv-stat-label{font-size:.8125rem;color:#6b7280}.csv-stat.success .csv-stat-value{color:#059669}.csv-stat.error .csv-stat-value{color:#dc2626}.csv-stat.info .csv-stat-value{color:#2563eb}.csv-failed-list{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1rem}.csv-failed-list h4{margin:0 0 .5rem;font-size:.875rem;color:#991b1b}.csv-failed-list ul{margin:0;padding-left:1.25rem;font-size:.8125rem;color:#7f1d1d}.csv-failed-list li{margin-bottom:.25rem}.cohort-detail-header{margin-bottom:var(--spacing-6)}.cohort-detail-title-section{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-8)}.cohort-detail-actions{display:flex;gap:12px;align-items:center}.cohort-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.cohort-stat-card{display:flex;align-items:center;gap:16px}.stat-icon-wrapper{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center}.stat-content{display:flex;flex-direction:column;gap:2px}.stat-value{font-size:24px;font-weight:700;color:var(--color-text-primary);line-height:1}.stat-label{font-size:var(--font-size-small);color:var(--color-text-secondary)}.cohort-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border-light);margin-bottom:var(--spacing-8)}.cohort-tab{padding:12px 24px;background:none;border:none;font-family:inherit;font-size:var(--font-size-body);font-weight:600;color:var(--color-text-secondary);cursor:pointer;position:relative;transition:color .2s ease}.cohort-tab:hover{color:var(--color-text-primary)}.cohort-tab.active{color:var(--color-accent-blue)}.cohort-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background-color:var(--color-accent-blue)}.cohort-tab-content{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-6);margin-top:var(--spacing-6)}.info-item{display:flex;flex-direction:column;gap:4px}.info-label{font-size:var(--font-size-small);color:var(--color-text-secondary);font-weight:500}.info-value{font-size:var(--font-size-body);color:var(--color-text-primary);font-weight:600}.students-table-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-border-light);display:flex;justify-content:space-between;align-items:center}.students-table{width:100%;border-collapse:collapse}.students-table thead{background-color:var(--color-surface-muted)}.students-table th{padding:12px 16px;text-align:left;font-size:var(--font-size-small);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase}.students-table td{padding:16px;border-bottom:1px solid var(--color-border-light)}.students-table tbody tr:hover{background-color:var(--color-surface-muted)}.placeholder-text{color:var(--color-text-secondary);font-size:var(--font-size-body)}@media(max-width:768px){.cohort-stats-row,.info-grid{grid-template-columns:1fr}.cohort-detail-title-section{flex-direction:column;gap:16px}}.lesson-list-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-border-light)}.lesson-table{overflow-x:auto}.lesson-table table{width:100%;border-collapse:collapse}.lesson-table thead{background-color:var(--color-surface-muted)}.lesson-table th{padding:12px 16px;text-align:left;font-size:var(--font-size-small);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.lesson-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .15s ease}.lesson-table tbody tr:hover{background-color:var(--color-surface-muted)}.lesson-table tbody tr:last-child{border-bottom:none}.lesson-table td{padding:16px;font-size:var(--font-size-body);color:var(--color-text-primary)}.lesson-name-cell{display:flex;flex-direction:column;gap:4px}.lesson-name{font-weight:600;color:var(--color-text-primary);display:flex;align-items:center;gap:8px}.current-badge{font-size:11px;padding:2px 8px}.lesson-description{font-size:var(--font-size-small);color:var(--color-text-secondary)}.action-buttons{display:flex;gap:8px}.rich-text-editor{border:1px solid var(--color-border-light);border-radius:var(--radius-button);overflow:hidden}.rte-toolbar{display:flex;gap:4px;padding:8px;background-color:var(--color-surface-muted);border-bottom:1px solid var(--color-border-light);flex-wrap:wrap}.rte-btn{padding:6px 12px;background-color:#fff;border:1px solid var(--color-border-light);border-radius:6px;cursor:pointer;font-family:inherit;font-size:var(--font-size-small);color:var(--color-text-primary);transition:all .15s ease}.rte-btn:hover{background-color:var(--color-surface-muted);border-color:var(--color-accent-blue)}.rte-btn:active{background-color:var(--color-surface)}.rte-separator{width:1px;background-color:var(--color-border-light);margin:0 4px}.rte-content{padding:16px;min-height:200px;font-family:inherit;font-size:var(--font-size-body);line-height:1.6;color:var(--color-text-primary);outline:none}.rte-content:focus{background-color:var(--color-surface)}.rte-content h1{font-size:24px;font-weight:700;margin:16px 0 8px}.rte-content h2{font-size:20px;font-weight:700;margin:14px 0 6px}.rte-content h3{font-size:18px;font-weight:600;margin:12px 0 6px}.rte-content p{margin:8px 0}.rte-content ul,.rte-content ol{margin:8px 0;padding-left:24px}.rte-content li{margin:4px 0}.rte-content strong{font-weight:700}.rte-content em{font-style:italic}.rte-content u{text-decoration:underline}.lesson-builder-header{margin-bottom:var(--spacing-6)}.lesson-builder-title{margin-bottom:var(--spacing-8)}.lesson-builder-content{display:grid;grid-template-columns:1fr 320px;gap:var(--spacing-8)}.lesson-builder-main{display:flex;flex-direction:column;gap:var(--spacing-6)}.lesson-info-card{margin-bottom:0}.form-grid{display:grid;gap:var(--spacing-4);margin-top:var(--spacing-4)}.activities-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6)}.add-activity-buttons{display:flex;gap:8px}.empty-state{padding:var(--spacing-10);text-align:center;color:var(--color-text-secondary);background-color:var(--color-surface-muted);border-radius:var(--radius-button)}.activities-list{display:flex;flex-direction:column;gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.activity-item{display:flex;gap:12px;padding:var(--spacing-5);background-color:var(--color-surface-muted);border-radius:var(--radius-button);border:1px solid var(--color-border-light)}.activity-reorder-controls{display:flex;flex-direction:column;gap:4px;padding-top:4px}.reorder-btn{background:none;border:none;padding:4px;cursor:pointer;color:var(--color-text-light);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.reorder-btn:hover:not(:disabled){background-color:var(--color-surface);color:var(--color-text-primary)}.reorder-btn:disabled{opacity:.3;cursor:not-allowed}.activity-content{flex:1;display:flex;flex-direction:column;gap:12px}.activity-header{display:flex;justify-content:space-between;align-items:center}.activity-meta{display:flex;align-items:center;gap:12px}.activity-number{font-weight:600;color:var(--color-text-primary)}.activity-points{color:var(--color-accent-green);font-weight:600;font-size:var(--font-size-small)}.activity-actions{display:flex;gap:8px}.activity-prompt{font-size:var(--font-size-body);color:var(--color-text-primary);font-weight:500}.activity-text-preview{font-size:var(--font-size-body);color:var(--color-text-primary);line-height:1.6;padding:var(--spacing-4);background-color:#fff;border-radius:var(--radius-button);border:1px solid var(--color-border-light)}.activity-text-preview h1,.activity-text-preview h2,.activity-text-preview h3{margin-top:0;margin-bottom:8px}.activity-text-preview p{margin:0}.activity-text-preview ul,.activity-text-preview ol{margin:8px 0;padding-left:24px}.activity-options-preview{display:flex;flex-direction:column;gap:6px;margin-top:8px}.option-preview{padding:8px 12px;background-color:#fff;border-radius:var(--radius-button);font-size:var(--font-size-small);color:var(--color-text-secondary);display:flex;align-items:center;gap:8px}.correct-indicator{color:var(--color-accent-green);font-weight:700}.activity-form{border:2px solid var(--color-accent-blue);background-color:var(--color-surface)}.form-title{font-size:var(--font-size-h3);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-4)}.rich-text-section{margin-bottom:var(--spacing-4)}.rich-text-section .ql-toolbar{border-radius:var(--radius-button) var(--radius-button) 0 0;border-color:var(--color-border-light);background-color:var(--color-surface-muted)}.rich-text-section .ql-container{border-radius:0 0 var(--radius-button) var(--radius-button);border-color:var(--color-border-light);font-family:inherit;font-size:var(--font-size-body);min-height:200px}.rich-text-section .ql-editor{min-height:200px}.form-label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-secondary);margin-bottom:6px;display:block}.options-section{margin-top:var(--spacing-4)}.options-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.option-input-row{display:flex;gap:12px;align-items:center;margin-bottom:8px}.option-checkbox{width:20px;height:20px;cursor:pointer}.option-text-input{flex:1;padding:10px 14px;border-radius:var(--radius-button);border:1px solid var(--color-border-light);font-family:inherit;font-size:var(--font-size-body);outline:none}.option-text-input:focus{border-color:var(--color-accent-blue)}.checkbox-label{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:var(--font-size-small);color:var(--color-text-secondary);cursor:pointer}.checkbox-label input{cursor:pointer}.form-actions{display:flex;gap:12px;margin-top:var(--spacing-6);padding-top:var(--spacing-6);border-top:1px solid var(--color-border-light)}.lesson-builder-sidebar{display:flex;flex-direction:column;gap:var(--spacing-6)}.lesson-summary{position:sticky;top:var(--spacing-8)}.summary-title{font-size:var(--font-size-h3);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-4)}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--color-border-light)}.summary-item:last-child{border-bottom:none}.summary-label{font-size:var(--font-size-small);color:var(--color-text-secondary);font-weight:500}.summary-value{font-size:var(--font-size-h3);font-weight:700;color:var(--color-text-primary)}.save-actions{display:flex;flex-direction:column;gap:12px}.cohort-assignment-table{width:100%;border-collapse:collapse;margin-top:16px}.cohort-assignment-table thead{background:var(--color-background);border-bottom:2px solid var(--color-border)}.cohort-assignment-table th{text-align:left;padding:12px;font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.cohort-assignment-table td{padding:16px 12px;border-bottom:1px solid var(--color-border);font-size:14px;color:var(--color-text-primary)}.cohort-assignment-table tbody tr:hover{background:var(--color-background)}.cohort-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent)}.status-select{padding:6px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;transition:border-color .2s}.status-select:hover{border-color:var(--color-accent)}.status-select:focus{outline:none;border-color:var(--color-accent)}@media(max-width:1024px){.lesson-builder-content{grid-template-columns:1fr}.lesson-summary{position:static}.cohort-assignment-table{display:block;overflow-x:auto}}.cohort-register-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.cohort-register-card{max-width:500px;width:100%}.register-header{text-align:center;margin-bottom:2rem}.register-header h1{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.register-header p{color:#6b7280;font-size:1rem}.enrollment-closed{text-align:center;padding:2rem 0}.enrollment-closed h2{font-size:1.5rem;font-weight:600;color:#ef4444;margin-bottom:1rem}.enrollment-closed p{color:#6b7280;font-size:1rem;line-height:1.6}.enrollment-closed a{color:#667eea;text-decoration:none;font-weight:500}.enrollment-closed a:hover{text-decoration:underline}.register-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-error{padding:.75rem 1rem;background-color:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.875rem}.login-link{text-align:center;color:#6b7280;font-size:.875rem;margin-top:1rem}.login-link a{color:#667eea;text-decoration:none;font-weight:500}.login-link a:hover{text-decoration:underline}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.forum-container{padding:0}.forum-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.forum-title{font-size:24px;font-weight:700;color:var(--color-text-primary);margin:0}.forum-list{display:flex;flex-direction:column;gap:16px}.forum-empty{text-align:center;padding:64px 24px;color:var(--color-text-secondary)}.forum-empty-icon{width:64px;height:64px;margin:0 auto 16px;background-color:var(--color-surface-muted);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-light)}.forum-empty-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.forum-empty-text{font-size:14px;color:var(--color-text-secondary);margin-bottom:24px}.question-card{background:var(--color-surface);border-radius:var(--radius-card);padding:24px;box-shadow:var(--shadow-card);cursor:pointer;transition:transform .2s,box-shadow .2s}.question-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px #0f172a14}.question-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.question-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 16px 0 0;flex:1}.question-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:var(--radius-pill)}.question-status.resolved{background-color:#dcfce7;color:#166534}.question-status.open{background-color:#fef3c7;color:#92400e}.question-content{font-size:14px;color:var(--color-text-secondary);margin-bottom:16px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.question-footer{display:flex;justify-content:space-between;align-items:center}.question-author{display:flex;align-items:center;gap:12px}.author-avatar{width:32px;height:32px;border-radius:50%;background-color:var(--color-surface-muted);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--color-text-secondary)}.author-avatar.moderator{background-color:#eef2ff;color:var(--color-accent-purple)}.author-info{display:flex;flex-direction:column;gap:2px}.author-name{font-size:14px;font-weight:500;color:var(--color-text-primary)}.author-name.moderator{color:var(--color-accent-purple)}.author-date{font-size:12px;color:var(--color-text-light)}.question-meta{display:flex;align-items:center;gap:16px}.meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-secondary)}.question-detail{padding:24px}.question-detail-header{margin-bottom:24px}.question-detail-title{font-size:22px;font-weight:700;color:var(--color-text-primary);margin:0 0 16px}.question-detail-content{font-size:15px;color:var(--color-text-primary);line-height:1.7;margin-bottom:24px}.question-detail-meta{display:flex;align-items:center;gap:16px;padding-bottom:24px;border-bottom:1px solid var(--color-border-light)}.answers-section{margin-top:24px}.answers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.answers-title{font-size:16px;font-weight:600;color:var(--color-text-primary)}.answers-list{display:flex;flex-direction:column;gap:16px}.answer-card{background:var(--color-surface-muted);border-radius:16px;padding:20px}.answer-card.accepted{background:#f0fdf4;border:1px solid #86EFAC}.answer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.answer-content{font-size:14px;color:var(--color-text-primary);line-height:1.6}.accepted-badge{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:#166534}.new-answer-form{margin-top:24px;padding-top:24px;border-top:1px solid var(--color-border-light)}.new-answer-form textarea{width:100%;min-height:120px;padding:16px;border:1px solid var(--color-border-light);border-radius:12px;font-size:14px;font-family:inherit;resize:vertical;margin-bottom:16px}.new-answer-form textarea:focus{outline:none;border-color:var(--color-accent-blue)}.new-answer-actions{display:flex;justify-content:flex-end}.new-question-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-group input,.form-group textarea{padding:12px 16px;border:1px solid var(--color-border-light);border-radius:10px;font-size:14px;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent-blue)}.form-group textarea{min-height:150px;resize:vertical}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.moderator-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;color:var(--color-accent-purple);background:#eef2ff;padding:2px 8px;border-radius:var(--radius-pill);margin-left:8px}.back-button{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--color-text-secondary);background:none;border:none;cursor:pointer;padding:8px 0;margin-bottom:16px}.back-button:hover{color:var(--color-text-primary)}@media(max-width:640px){.forum-header{flex-direction:column;align-items:stretch;gap:16px}.question-footer{flex-direction:column;align-items:flex-start;gap:12px}.question-meta{width:100%;justify-content:flex-start}}.help-page{max-width:800px;margin:0 auto}.help-header{margin-bottom:32px}.help-title{font-size:28px;font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.help-subtitle{font-size:15px;color:var(--color-text-secondary);margin:0}.help-content{display:flex;flex-direction:column;gap:24px}.help-section{border:1px solid var(--color-border-light);border-radius:var(--radius-card)}.section-header-help{display:flex;align-items:flex-start;gap:12px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--color-border-light)}.section-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-surface-muted);display:flex;align-items:center;justify-content:center;color:var(--color-accent-blue);flex-shrink:0}.section-title-help{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.section-description{font-size:14px;color:var(--color-text-secondary);margin:0}.faq-list{display:flex;flex-direction:column;gap:16px}.faq-item{padding:16px;background:var(--color-background);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.faq-question{font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0 0 8px}.faq-answer{font-size:14px;color:var(--color-text-secondary);margin:0;line-height:1.5}.resources-list{display:flex;flex-direction:column;gap:12px}.resource-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-background);border-radius:var(--radius-md);border:1px solid var(--color-border-light);color:var(--color-text-primary);text-decoration:none;font-size:14px;transition:border-color .2s,background-color .2s}.resource-item:hover{border-color:var(--color-accent-blue);background:var(--color-surface-muted)}.resource-item svg{color:var(--color-accent-blue);flex-shrink:0}.chat-section{min-height:400px}.chat-start{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.chat-start-text{font-size:15px;color:var(--color-text-secondary);margin:0 0 20px}.chat-container{display:flex;flex-direction:column;height:350px}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:var(--color-background);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.chat-message{max-width:80%;padding:12px 16px;border-radius:var(--radius-lg);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-message-user{align-self:flex-end;background:var(--color-accent-blue);color:#fff}.chat-message-user .message-text{color:#fff}.chat-message-system{align-self:flex-start;background:var(--color-surface);border:1px solid var(--color-border-light);color:var(--color-text-primary)}.message-text{font-size:14px;line-height:1.5;margin:0 0 4px;word-wrap:break-word}.message-time{font-size:11px;opacity:.7}.chat-message-user .message-time{color:#fffc}.chat-message-system .message-time{color:var(--color-text-secondary)}.message-sender{display:block;font-size:12px;font-weight:600;color:var(--color-accent-blue);margin-bottom:4px}.chat-loading{display:flex;align-items:center;justify-content:center;padding:40px 20px;color:var(--color-text-secondary)}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;background:var(--color-text-secondary);border-radius:50%;animation:bounce 1.4s ease-in-out infinite both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-input-container{display:flex;gap:12px;margin-top:16px;align-items:flex-end}.chat-input{flex:1;padding:12px 16px;border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:14px;font-family:inherit;resize:none;min-height:44px;max-height:120px;background:var(--color-surface);color:var(--color-text-primary);transition:border-color .2s}.chat-input:focus{outline:none;border-color:var(--color-accent-blue)}.chat-input::placeholder{color:var(--color-text-secondary)}.chat-input:disabled{opacity:.6;cursor:not-allowed}@media(max-width:640px){.help-page{padding:0 16px}.help-title{font-size:24px}.chat-message{max-width:90%}.chat-container{height:300px}}:root{--color-background: #FFFFFF;--color-surface: #FFFFFF;--color-surface-muted: #FAFAFF;--color-text-primary: #1F2937;--color-text-secondary: #6B7280;--color-text-light: #9CA3AF;--color-border-light: #E5E7EB;--color-accent-blue: #3B82F6;--color-accent-green: #22C55E;--color-accent-orange: #F59E0B;--color-accent-red: #EF4444;--color-accent-purple: #8B5CF6;--color-avatar-border: #F3F4F6;--color-shadow-light: rgba(0, 0, 0, .04);--font-primary: "Poppins", sans-serif;--font-size-h1: 28px;--font-size-h2: 22px;--font-size-h3: 18px;--font-size-body: 15px;--font-size-small: 13px;--radius-card: 20px;--radius-button: 10px;--radius-pill: 999px;--shadow-card: 0 8px 24px rgba(15, 23, 42, .05);--shadow-none: none;--spacing-0: 0px;--spacing-1: 4px;--spacing-2: 8px;--spacing-3: 12px;--spacing-4: 16px;--spacing-5: 20px;--spacing-6: 24px;--spacing-8: 32px;--spacing-10: 40px}body{margin:0;font-family:var(--font-primary);background-color:var(--color-background);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}h1,h2,h3,h4,h5,h6,p{margin:0}button{font-family:inherit}
