@import"https://fonts.googleapis.com/css2?family=Lato:wght@300;400;500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Lato,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;color:#333}h1,h2,h3,h4,h5,h6{font-family:Lato,system-ui,sans-serif;font-weight:500;letter-spacing:-.01em}.landing{min-height:100vh;background:#fff;color:#1a202c}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #f0f0f0}.landing-nav-inner{max-width:1100px;margin:0 auto;padding:0 32px;height:60px;display:flex;align-items:center;justify-content:space-between}.landing-logo{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:700;color:#1a202c;letter-spacing:-.02em}.landing-logo-icon{width:28px;height:28px;border-radius:7px;background:#e33c26;display:flex;align-items:center;justify-content:center;flex-shrink:0}.landing-logo-icon.small{width:22px;height:22px;border-radius:5px}.landing-nav-links{display:flex;align-items:center;gap:8px}.landing-nav-link{padding:7px 16px;font-size:14px;font-weight:500;color:#4a5568;text-decoration:none;border-radius:8px;transition:background .15s}.landing-nav-link:hover{background:#f7fafc}.landing-nav-btn{padding:7px 18px;font-size:14px;font-weight:600;color:#fff;background:#1a202c;border-radius:8px;text-decoration:none;transition:background .15s}.landing-nav-btn:hover{background:#2d3748}.landing-hero{padding:130px 32px 40px;text-align:center}.landing-hero-inner{max-width:680px;margin:0 auto}.landing-badge{display:inline-block;padding:5px 14px;font-size:12px;font-weight:600;color:#5a67d8;background:#ebf4ff;border-radius:20px;margin-bottom:24px;letter-spacing:.02em}.landing-title{font-size:52px;font-weight:800;line-height:1.1;letter-spacing:-.03em;color:#1a202c;margin-bottom:20px}.landing-title-accent{background:linear-gradient(135deg,#5a67d8,#38b2ac);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-subtitle{font-size:18px;line-height:1.65;color:#718096;margin-bottom:36px;max-width:520px;margin-left:auto;margin-right:auto}.landing-cta{display:flex;align-items:center;justify-content:center;gap:12px}.landing-cta-primary{display:inline-flex;align-items:center;gap:6px;padding:12px 28px;font-size:15px;font-weight:600;color:#fff;background:#1a202c;border-radius:10px;text-decoration:none;transition:background .15s,transform .1s}.landing-cta-primary:hover{background:#2d3748;transform:translateY(-1px)}.landing-cta-secondary{padding:12px 24px;font-size:15px;font-weight:500;color:#4a5568;text-decoration:none;border-radius:10px;border:1px solid #e2e8f0;transition:background .15s}.landing-cta-secondary:hover{background:#f7fafc}.landing-preview-wrapper{position:relative;max-width:1060px;margin:56px auto 0;padding:0 20px}.landing-preview-glow{position:absolute;top:30px;left:50%;transform:translate(-50%);width:90%;height:70%;background:radial-gradient(ellipse,rgba(90,103,216,.12) 0%,transparent 70%);pointer-events:none;z-index:0}.preview-container{position:relative;z-index:1;border-radius:12px;overflow:hidden;box-shadow:0 8px 40px #0000001f,0 0 0 1px #0000000f;background:#1a1a1a;animation:previewFloat 6s ease-in-out infinite,previewFadeIn .8s ease-out}@keyframes previewFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes previewFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.preview-browser{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#2d2d2d}.preview-dots{display:flex;gap:6px}.preview-dots .dot{width:10px;height:10px;border-radius:50%}.dot.red{background:#ff5f57}.dot.yellow{background:#febc2e}.dot.green{background:#28c840}.preview-url{flex:1;text-align:center}.preview-url span{display:inline-block;padding:4px 24px;background:#3a3a3a;border-radius:6px;font-size:12px;color:#aaa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,monospace}.preview-screen{position:relative;width:100%;aspect-ratio:2560 / 1347;overflow:hidden;background:#f5f5f5}.preview-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:top left;opacity:0;transition:opacity .6s ease-in-out}.preview-img.active{opacity:1}.preview-tabs{display:flex;justify-content:center;gap:4px;padding:10px 16px;background:#2d2d2d}.preview-tab{padding:4px 14px;font-size:11px;font-weight:500;color:#888;background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s;font-family:inherit}.preview-tab.active{color:#fff;background:#3a3a3a}.preview-tab:hover:not(.active){color:#bbb}.landing-features{padding:80px 32px;background:#fafbfc}.landing-features-inner{max-width:1000px;margin:0 auto}.landing-section-title{text-align:center;font-size:28px;font-weight:700;letter-spacing:-.02em;margin-bottom:48px;color:#1a202c}.landing-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.landing-feature-card{padding:28px 24px;background:#fff;border-radius:12px;border:1px solid #edf2f7;transition:box-shadow .2s,transform .15s}.landing-feature-card:hover{box-shadow:0 4px 20px #0000000f;transform:translateY(-2px)}.landing-feature-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ebf4ff;color:#5a67d8;border-radius:10px;margin-bottom:16px}.landing-feature-card h3{font-size:16px;font-weight:600;margin-bottom:8px;color:#1a202c}.landing-feature-card p{font-size:14px;line-height:1.6;color:#718096}.landing-steps{padding:80px 32px}.landing-steps-inner{max-width:900px;margin:0 auto}.landing-steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;text-align:center}.landing-step-num{width:40px;height:40px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;background:#1a202c;color:#fff;font-size:16px;font-weight:700;border-radius:50%}.landing-step h3{font-size:16px;font-weight:600;margin-bottom:8px;color:#1a202c}.landing-step p{font-size:14px;line-height:1.6;color:#718096}.landing-bottom-cta{padding:80px 32px;background:#fafbfc;text-align:center}.landing-bottom-cta-inner{max-width:600px;margin:0 auto}.landing-bottom-cta h2{font-size:28px;font-weight:700;letter-spacing:-.02em;margin-bottom:28px;color:#1a202c}.landing-footer{padding:28px 32px;border-top:1px solid #edf2f7}.landing-footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.landing-footer-brand{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#a0aec0}.landing-footer-copy{font-size:13px;color:#a0aec0}@media(max-width:768px){.landing-title{font-size:34px}.landing-subtitle{font-size:16px}.landing-features-grid{grid-template-columns:1fr}.landing-steps-grid{grid-template-columns:1fr;gap:32px}.landing-hero{padding:120px 20px 40px}.landing-cta{flex-direction:column}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fafbfc;padding:40px 20px}.auth-container{width:100%;max-width:400px;text-align:center}.auth-logo{display:inline-flex;align-items:center;gap:8px;font-size:17px;font-weight:700;color:#1a202c;text-decoration:none;margin-bottom:36px}.auth-logo .landing-logo-icon{width:28px;height:28px;border-radius:7px;background:#e33c26;display:flex;align-items:center;justify-content:center}.auth-title{font-size:26px;font-weight:700;color:#1a202c;letter-spacing:-.02em;margin-bottom:6px}.auth-subtitle{font-size:14px;color:#718096;margin-bottom:28px}.auth-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px;font-size:14px;font-weight:500;color:#2d3748;background:#fff;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:background .15s,box-shadow .15s;font-family:inherit}.auth-google-btn:hover{background:#f7fafc;box-shadow:0 1px 4px #0000000f}.auth-divider{display:flex;align-items:center;margin:20px 0;gap:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.auth-divider span{font-size:12px;color:#a0aec0;text-transform:uppercase;letter-spacing:.05em}.auth-form{display:flex;flex-direction:column;gap:12px;text-align:left}.auth-field{position:relative}.auth-field-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#a0aec0;pointer-events:none}.auth-field input{width:100%;padding:11px 14px 11px 40px;font-size:14px;font-family:inherit;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#1a202c;transition:border-color .15s,box-shadow .15s;outline:none}.auth-field input:focus{border-color:#5a67d8;box-shadow:0 0 0 3px #5a67d81a}.auth-field input::placeholder{color:#a0aec0}.auth-error{font-size:13px;color:#e53e3e;text-align:center;padding:8px;background:#fff5f5;border-radius:8px}.auth-submit{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:11px;font-size:15px;font-weight:600;font-family:inherit;color:#fff;background:#1a202c;border:none;border-radius:10px;cursor:pointer;transition:background .15s;margin-top:4px}.auth-submit:hover{background:#2d3748}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-footer-text{margin-top:24px;font-size:14px;color:#718096}.auth-footer-text a{color:#5a67d8;font-weight:500;text-decoration:none}.auth-footer-text a:hover{text-decoration:underline}.onboarding-page{min-height:100vh;background:#fafbfc;display:flex;flex-direction:column;align-items:center;padding:40px 20px}.onboarding-header{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:700;color:#1a202c;margin-bottom:40px}.onboarding-header .landing-logo-icon{width:28px;height:28px;border-radius:7px;background:#e33c26;display:flex;align-items:center;justify-content:center}.onboarding-progress{display:flex;align-items:center;gap:0;margin-bottom:40px;width:100%;max-width:520px}.onboarding-step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0;transition:all .2s;border:2px solid #e2e8f0;background:#fff;color:#a0aec0}.onboarding-step-dot.active{border-color:#1a202c;background:#1a202c;color:#fff}.onboarding-step-dot.completed{border-color:#48bb78;background:#48bb78;color:#fff}.onboarding-step-line{flex:1;height:2px;background:#e2e8f0;transition:background .2s}.onboarding-step-line.completed{background:#48bb78}.onboarding-card{width:100%;max-width:520px;background:#fff;border-radius:16px;border:1px solid #edf2f7;padding:36px 32px;box-shadow:0 1px 8px #0000000a}.onboarding-card h2{font-size:22px;font-weight:700;color:#1a202c;margin-bottom:6px;letter-spacing:-.02em}.onboarding-card .step-desc{font-size:14px;color:#718096;margin-bottom:28px;line-height:1.5}.ob-field{margin-bottom:18px}.ob-field label{display:block;font-size:13px;font-weight:600;color:#4a5568;margin-bottom:6px}.ob-field input,.ob-field select{width:100%;padding:10px 14px;font-size:14px;font-family:inherit;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#1a202c;outline:none;transition:border-color .15s,box-shadow .15s}.ob-field input:focus,.ob-field select:focus{border-color:#5a67d8;box-shadow:0 0 0 3px #5a67d81a}.ob-field input::placeholder{color:#a0aec0}.ob-field .ob-hint{font-size:12px;color:#a0aec0;margin-top:4px}.ob-field-row{display:flex;gap:12px}.ob-field-row .ob-field{flex:1}.ob-token-field{position:relative}.ob-token-field input{padding-right:40px}.ob-token-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;display:flex}.ob-token-toggle:hover{color:#718096}.ob-connection-status{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;margin-bottom:18px}.ob-connection-status.testing{background:#ebf8ff;color:#3182ce}.ob-connection-status.success{background:#f0fff4;color:#38a169}.ob-connection-status.error{background:#fff5f5;color:#e53e3e}.ob-connection-status .ob-spinner{animation:obSpin 1s linear infinite}@keyframes obSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ob-test-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:600;font-family:inherit;color:#5a67d8;background:#ebf4ff;border:none;border-radius:8px;cursor:pointer;transition:background .15s;margin-bottom:8px}.ob-test-btn:hover{background:#c3dafe}.ob-test-btn:disabled{opacity:.6;cursor:not-allowed}.ob-course-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;max-height:340px;overflow-y:auto}.ob-course-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid #edf2f7;border-radius:10px;transition:border-color .15s,background .15s;cursor:pointer}.ob-course-item:hover{background:#f7fafc}.ob-course-item.selected{border-color:#5a67d8;background:#f7f7ff}.ob-course-check{width:20px;height:20px;border-radius:6px;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ob-course-item.selected .ob-course-check{border-color:#5a67d8;background:#5a67d8;color:#fff}.ob-course-info{flex:1;min-width:0}.ob-course-name{font-size:14px;font-weight:600;color:#1a202c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ob-course-code{font-size:12px;color:#a0aec0}.ob-course-color{width:24px;height:24px;border-radius:6px;border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:transform .1s}.ob-course-color:hover{transform:scale(1.15)}.ob-color-picker{position:relative}.ob-color-popover{position:absolute;right:0;top:100%;margin-top:4px;padding:8px;background:#fff;border-radius:10px;border:1px solid #edf2f7;box-shadow:0 4px 16px #0000001a;display:flex;gap:6px;flex-wrap:wrap;width:160px;z-index:10}.ob-color-swatch{width:24px;height:24px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:transform .1s}.ob-color-swatch:hover{transform:scale(1.15)}.ob-color-swatch.active{border-color:#1a202c}.ob-pref-group{margin-bottom:22px}.ob-pref-group label{display:block;font-size:13px;font-weight:600;color:#4a5568;margin-bottom:8px}.ob-radio-group{display:flex;gap:8px}.ob-radio-option{flex:1;padding:14px 16px;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;text-align:center;transition:all .15s}.ob-radio-option:hover{background:#f7fafc}.ob-radio-option.selected{border-color:#5a67d8;background:#f7f7ff}.ob-radio-option .ob-radio-icon{display:flex;align-items:center;justify-content:center;margin-bottom:6px;color:#a0aec0}.ob-radio-option.selected .ob-radio-icon{color:#5a67d8}.ob-radio-option .ob-radio-title{font-size:14px;font-weight:600;color:#1a202c;margin-bottom:2px}.ob-radio-option .ob-radio-desc{font-size:12px;color:#a0aec0;line-height:1.4}.ob-slider-row{display:flex;align-items:center;gap:12px}.ob-slider-row input[type=range]{flex:1;accent-color:#5a67d8}.ob-slider-value{font-size:14px;font-weight:600;color:#1a202c;min-width:44px;text-align:center}.ob-tz-wrapper{position:relative}.ob-tz-dropdown{position:absolute;top:100%;left:0;right:0;max-height:180px;overflow-y:auto;background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-top:4px;box-shadow:0 4px 16px #00000014;z-index:10}.ob-tz-option{padding:8px 14px;font-size:13px;color:#4a5568;cursor:pointer}.ob-tz-option:hover{background:#f7fafc}.ob-tz-option.active{background:#ebf4ff;color:#5a67d8;font-weight:500}.ob-import-zone{border:2px dashed #e2e8f0;border-radius:12px;padding:32px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;margin-bottom:18px}.ob-import-zone:hover{border-color:#cbd5e0;background:#f7fafc}.ob-import-zone-icon{color:#a0aec0;margin-bottom:8px}.ob-import-zone p{font-size:14px;color:#718096;margin-bottom:4px}.ob-import-zone .ob-import-hint{font-size:12px;color:#a0aec0}.ob-import-file{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#f7fafc;border-radius:10px;margin-bottom:18px}.ob-import-file-name{flex:1;font-size:14px;color:#4a5568;font-weight:500}.ob-import-file-remove{background:none;border:none;color:#a0aec0;cursor:pointer;display:flex;padding:2px}.ob-import-file-remove:hover{color:#e53e3e}.ob-skip-text{text-align:center;font-size:13px;color:#a0aec0;margin-top:8px}.onboarding-nav{display:flex;align-items:center;justify-content:space-between;margin-top:28px;padding-top:20px;border-top:1px solid #edf2f7}.ob-back-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:500;font-family:inherit;color:#718096;background:transparent;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:background .15s}.ob-back-btn:hover{background:#f7fafc}.ob-next-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;font-size:14px;font-weight:600;font-family:inherit;color:#fff;background:#1a202c;border:none;border-radius:10px;cursor:pointer;transition:background .15s}.ob-next-btn:hover{background:#2d3748}.ob-next-btn:disabled{opacity:.5;cursor:not-allowed}.ob-next-btn.finish{background:#48bb78}.ob-next-btn.finish:hover{background:#38a169}.ob-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0;gap:12px;color:#a0aec0}.ob-loading .ob-spinner{animation:obSpin 1s linear infinite}.ob-empty{text-align:center;padding:24px 0;color:#a0aec0;font-size:14px}@media(max-width:560px){.onboarding-card{padding:28px 20px}.ob-radio-group{flex-direction:column}}.legal-page{min-height:100vh;background:#f7fafc;padding:0 20px 60px}.legal-header{padding:20px 0;max-width:720px;margin:0 auto}.legal-container{max-width:720px;margin:0 auto;background:#fff;border-radius:12px;padding:40px 48px;box-shadow:0 1px 3px #00000014}.legal-container h1{font-size:28px;font-weight:700;color:#1a202c;margin:0 0 4px}.legal-updated{color:#a0aec0;font-size:13px;margin:0 0 32px}.legal-container h2{font-size:16px;font-weight:600;color:#2d3748;margin:28px 0 8px}.legal-container p{font-size:14px;line-height:1.7;color:#4a5568;margin:0 0 12px}.legal-container ul{margin:0 0 12px;padding-left:20px}.legal-container li{font-size:14px;line-height:1.7;color:#4a5568;margin-bottom:4px}.legal-container a{color:#5a67d8}.sidebar{width:200px;background:#323e49;display:flex;flex-direction:column;padding:20px 0;flex-shrink:0;color:#f2f2f2;font-family:Lato,system-ui,sans-serif}.sidebar-header{display:flex;align-items:center;gap:10px;padding:0 20px;margin-bottom:32px}.sidebar-logo{width:32px;height:32px;border-radius:8px;background:#e33c26;display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;font-weight:700}.sidebar-title{font-weight:600;font-size:15px;font-family:Lato,system-ui,sans-serif}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 20px;cursor:pointer;font-size:14px;font-family:Lato,system-ui,sans-serif;font-weight:400;transition:background .12s}.sidebar-item:hover{background:#3e4e5b}.sidebar-item.active{background:#4a5568;font-weight:600}.sidebar-item-icon{font-size:16px;width:20px;text-align:center}.sidebar-spacer{flex:1}.sidebar-tip{margin:0 16px;padding:12px 14px;background:#374151;border-radius:8px;font-size:12px;color:#a0aec0;line-height:1.5}.sidebar-courses-toggle{position:relative}.sidebar-chevron{margin-left:auto;transition:transform .2s ease}.sidebar-chevron.expanded{transform:rotate(180deg)}.sidebar-courses-list{display:flex;flex-direction:column}.sidebar-course-item{display:flex;align-items:center;gap:10px;padding:8px 20px 8px 52px;cursor:pointer;font-size:13px;transition:background .12s}.sidebar-course-item:hover{background:#3e4e5b}.sidebar-course-item.active{background:#4a5568;font-weight:600}.sidebar-course-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sidebar-footer{padding:16px 20px;border-top:1px solid hsl(207,19%,30%);display:flex;flex-direction:column;gap:8px}.sidebar-email{font-size:12px;color:#a0aec0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{font-size:12px;color:#a0aec0;cursor:pointer;transition:color .12s}.sidebar-logout:hover{color:#fff}@media(max-width:768px){.sidebar{width:100%;height:auto;flex-direction:row;flex-wrap:wrap;padding:8px 0;overflow-x:auto}.sidebar-header{padding:0 12px;margin-bottom:0}.sidebar-item{padding:8px 12px;font-size:13px;gap:6px}.sidebar-courses-list,.sidebar-chevron,.sidebar-spacer,.sidebar-footer{display:none}}.time-block{position:absolute;left:4px;right:4px;border-radius:6px;border-left:1px solid;cursor:grab;display:flex;flex-direction:column;overflow:hidden;-webkit-user-select:none;user-select:none;transition:box-shadow .15s;z-index:10}.time-block.dragging{cursor:grabbing;z-index:100;transition:none}.time-block.selected{z-index:50}.time-block.fixed,.time-block.fixed .block-content{cursor:default}.resize-handle{height:7px;cursor:ns-resize;flex-shrink:0;display:flex;justify-content:center;align-items:center}.handle-bar{width:20px;height:2.5px;border-radius:2px;opacity:.6}.block-content{flex:1;padding:0 8px;display:flex;flex-direction:column;gap:1px;min-height:0;cursor:grab}.time-block.dragging .block-content{cursor:grabbing}.block-title-row{display:flex;align-items:flex-start;gap:4px}.block-title{font-size:12px;font-weight:600;line-height:14px;flex:1;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical}.block-time{font-size:10px;display:flex;align-items:center;gap:3px}.block-duration{margin-left:1px}.delete-btn{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:3px;background:#00000080;color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:200;line-height:1;transition:background .15s}.delete-btn:hover{background:#000000b3}.block-checkbox{cursor:pointer;width:13px;height:13px;margin:0;flex-shrink:0}.modal-overlay{position:fixed;inset:0;background:#00000040;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:24px;width:380px;box-shadow:0 20px 60px #00000026}.popover-overlay{position:fixed;inset:0;z-index:1000}.popover-content{position:fixed;background:#fff;border-radius:12px;padding:24px;width:380px;box-shadow:0 8px 30px #0000002e,0 2px 8px #00000014;z-index:1001}.popover-arrow{position:absolute;width:10px;height:10px;background:#fff;transform:translateY(-50%) rotate(45deg)}.popover-arrow-left{left:-5px;box-shadow:-2px 2px 4px #0000000f}.popover-arrow-right{right:-5px;box-shadow:2px -2px 4px #0000000f}.modal-title{font-size:16px;font-weight:700;margin-bottom:12px;color:#2d3748}.modal-input{width:100%;padding:10px 0;border-radius:0;border:none;border-bottom:1px solid #E2E8F0;font-size:14px;outline:none;box-sizing:border-box;margin-bottom:16px}.modal-input:focus{border-color:#3182ce}.modal-form{border-top:1px solid #EDF2F7;padding-top:8px;margin-bottom:16px}.modal-form-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #EDF2F7;min-height:20px}.modal-form-row:last-child{border-bottom:none}.modal-form-row-notes{align-items:flex-start}.modal-form-label{font-size:14px;color:#2d3748;flex-shrink:0;min-width:60px}.modal-form-value{display:flex;align-items:center;gap:8px;color:#4a5568;font-size:14px}.modal-form-date{font-size:14px;color:#718096;background:#f7fafc;padding:4px 8px;border-radius:6px;border:1px solid #E2E8F0}.color-dot-trigger{width:20px;height:20px;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #00000026;transition:transform .12s}.color-dot-trigger:hover{transform:scale(1.15)}.color-grid-overlay{position:fixed;inset:0;z-index:1100}.color-grid-popup{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border-radius:12px;padding:16px;box-shadow:0 12px 40px #0003,0 2px 8px #00000014;z-index:1101;width:280px}.color-grid-presets{display:flex;gap:8px;flex-wrap:wrap}.color-grid-dot{width:22px;height:22px;border-radius:50%;cursor:pointer;transition:transform .12s;box-sizing:border-box}.color-grid-dot:hover{transform:scale(1.2)}.color-grid-dot.selected{transform:scale(1.15)}.color-grid-rainbow{background:conic-gradient(#e06c6c,#e0a66c,#e0e06c,#59c059,#53c6c6,#6186d1,#a679d2,#c6a,#e06c6c)!important;border:2px solid rgba(255,255,255,.6)!important;box-shadow:0 1px 3px #0000001f;position:relative}.color-grid-rainbow.active{border-color:#0003!important;box-shadow:0 0 0 2px #00000026}.color-grid-matrix{display:flex;flex-direction:column;gap:2px;margin-top:12px;padding-top:12px;border-top:1px solid #EDF2F7}.color-grid-row{display:flex;gap:2px}.color-grid-cell{width:20px;height:20px;border-radius:3px;cursor:pointer;transition:transform .1s}.color-grid-cell:hover{transform:scale(1.3);z-index:1}.repeat-modal-overlay{position:fixed;inset:0;background:#0003;z-index:1100;display:flex;align-items:center;justify-content:center}.repeat-modal{background:#fff;border-radius:12px;padding:24px;width:320px;box-shadow:0 12px 40px #0000002e;position:relative}.repeat-close-btn{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:#a0aec0;padding:4px;display:flex;align-items:center;justify-content:center}.repeat-close-btn:hover{color:#4a5568}.repeat-title{font-size:16px;font-weight:700;color:#2d3748;margin-bottom:16px}.repeat-mode-select{width:100%;padding:8px 12px;border:1px solid #E2E8F0;border-radius:8px;font-size:14px;color:#2d3748;background:#f7fafc;outline:none;cursor:pointer;margin-bottom:12px}.repeat-mode-select:focus{border-color:#3182ce}.repeat-interval-row{display:flex;align-items:center;gap:8px;font-size:14px;color:#4a5568;margin-bottom:12px}.repeat-interval-input{width:48px;padding:6px 8px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;text-align:center;outline:none;color:#2d3748}.repeat-interval-input:focus{border-color:#3182ce}.repeat-day-chips{display:flex;gap:6px;margin-bottom:12px}.repeat-chip{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#4a5568;background:#f7fafc;border:1px solid #E2E8F0;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.repeat-chip:hover{background:#edf2f7}.repeat-chip.active{background:#e53e3e;color:#fff;border-color:#e53e3e}.repeat-tabs{display:flex;gap:0;margin-bottom:12px;border:1px solid #E2E8F0;border-radius:8px;overflow:hidden}.repeat-tab{flex:1;padding:8px 0;text-align:center;font-size:13px;font-weight:500;color:#4a5568;background:#f7fafc;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.repeat-tab:hover{background:#edf2f7}.repeat-tab.active{background:#e53e3e;color:#fff}.repeat-date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:12px}.repeat-date-cell{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;color:#4a5568;background:#f7fafc;border:1px solid #EDF2F7;border-radius:6px;cursor:pointer;transition:all .12s;-webkit-user-select:none;user-select:none}.repeat-date-cell:hover{background:#edf2f7}.repeat-date-cell.active{background:#e53e3e;color:#fff;border-color:#e53e3e}.repeat-month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:12px}.repeat-month-chip{padding:8px 0;text-align:center;font-size:13px;font-weight:500;color:#4a5568;background:#f7fafc;border:1px solid #EDF2F7;border-radius:8px;cursor:pointer;transition:all .12s;-webkit-user-select:none;user-select:none}.repeat-month-chip:hover{background:#edf2f7}.repeat-month-chip.active{background:#e53e3e;color:#fff;border-color:#e53e3e}.repeat-confirm-btn{width:100%;padding:10px;border:none;border-radius:8px;background:#e53e3e;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.repeat-confirm-btn:hover{background:#c53030}.modal-form-clickable{color:#4a5568;cursor:pointer;font-size:14px}.repeat-value-display{display:flex;align-items:center;gap:4px}.repeat-stepper-arrows{display:inline-flex;flex-direction:column;align-items:center;line-height:1;margin-left:2px;gap:0}.repeat-arrow-up,.repeat-arrow-down{font-size:10px;color:#a0aec0;line-height:7px;display:block}.repeat-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border-radius:10px;box-shadow:0 8px 30px #00000029,0 2px 8px #0000000f;min-width:200px;padding:6px 0;z-index:1050;overflow:hidden}.repeat-dropdown-item{display:flex;align-items:center;justify-content:space-between;padding:9px 16px;font-size:14px;color:#2d3748;cursor:pointer;transition:background .1s;gap:10px}.repeat-dropdown-item:hover{background:#f7fafc}.repeat-dropdown-item.active{font-weight:500}.repeat-dropdown-check{color:#e53e3e;font-size:15px;font-weight:600}.repeat-dropdown-divider{height:1px;background:#edf2f7;margin:4px 0}.repeat-dropdown-custom{color:#e53e3e;gap:8px;justify-content:flex-start}.repeat-dropdown-custom svg{color:#e53e3e}.toggle-switch{position:relative;display:inline-block;width:40px;height:22px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:#cbd5e0;border-radius:22px;transition:.2s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px #00000026}.toggle-switch input:checked+.toggle-slider{background:#48bb78}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.modal-time-input{padding:4px 8px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;outline:none;color:#2d3748;background:#f7fafc}.modal-time-input:focus{border-color:#3182ce}.modal-notes-input{width:100%;padding:8px 10px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;outline:none;resize:vertical;font-family:inherit;color:#2d3748;box-sizing:border-box;min-height:40px}.modal-notes-input:focus{border-color:#3182ce}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.modal-btn{padding:8px 18px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.modal-btn.delete{border:1px solid #E2E8F0;background:#f7fafc;color:#4a5568;margin-right:auto}.modal-btn.delete:hover{background:#edf2f7}.modal-btn.cancel{border:1px solid #E2E8F0;background:#f7fafc;color:#4a5568}.modal-btn.cancel:hover{background:#edf2f7}.modal-btn.confirm{padding:8px 22px;border:none;background:#e53e3e;color:#fff;font-weight:600}.modal-btn.confirm:hover:not(:disabled){background:#c53030}.modal-btn.confirm.disabled,.modal-btn.confirm:disabled{background:#e53e3e66;cursor:default}.calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.calendar-header{padding:24px 32px 0;flex-shrink:0}.calendar-header h1{margin:0;font-size:28px;font-weight:700;color:#1a202c}.calendar-header-top{display:flex;align-items:flex-start;justify-content:space-between}.calendar-header p{margin:4px 0 20px;font-size:14px;color:#a0aec0}.view-toggle{display:flex;background:#edf2f7;border-radius:8px;padding:3px;gap:2px}.view-toggle-btn{padding:6px 16px;border:none;border-radius:6px;background:transparent;color:#718096;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.view-toggle-btn:hover{color:#2d3748}.view-toggle-btn.active{background:#fff;color:#1a202c;box-shadow:0 1px 3px #0000001a;font-weight:600}.calendar-nav{display:flex;align-items:center;padding:0 32px 12px;gap:10px;flex-shrink:0}.delete-all-btn{margin-left:auto;padding:5px 12px;border-radius:6px;border:1px solid #FEB2B2;background:#fff5f5;color:#c53030;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.delete-all-btn:hover{background:#fed7d7}.today-btn{padding:4px 12px;border-radius:6px;border:1px solid #E2E8F0;background:#fff;font-size:13px;font-weight:500;color:#4a5568;cursor:pointer}.today-btn:hover{background:#f7fafc}.nav-btn{width:30px;height:30px;border-radius:6px;border:1px solid #E2E8F0;background:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:#718096}.nav-btn:hover{background:#f7fafc}.nav-date{font-weight:600;font-size:15px;color:#2d3748}.nav-label{font-size:13px;color:#a0aec0;margin-left:4px}.today-link{cursor:pointer;transition:color .15s}.today-link:not(.current):hover{color:#4a5568}.today-link.current{cursor:default}.nav-week-label{font-size:13px;font-weight:600;color:#2d3748;background:#edf2f7;padding:2px 10px;border-radius:10px;margin-left:4px}.header-section{flex-shrink:0;background:#ffffffd9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid #D1D9E3;overflow-y:auto;scrollbar-gutter:stable}.day-headers{display:grid;grid-template-columns:60px repeat(7,1fr);padding:0}.day-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px;border-left:1px solid #E2E8F0}.day-name{font-size:12px;font-weight:600;color:#a0aec0;letter-spacing:.8px}.day-date{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:18px;font-weight:600;font-size:16px;color:#2d3748}.day-date.today{background:#e53e3e;color:#fff}.calendar-grid{flex:1;overflow-y:scroll;overflow-x:hidden;position:relative;display:grid;grid-template-columns:60px repeat(7,1fr);scrollbar-gutter:stable}.time-labels{position:relative}.time-label{display:flex;align-items:flex-start;justify-content:flex-end;padding-right:10px;font-size:12px;color:#a0aec0;transform:translateY(-8px);-webkit-user-select:none;user-select:none;font-weight:500}.day-column{position:relative;border-left:1px solid #D1D9E3;background:#fff}.day-column.today-col{background:#fff}.hour-cell{border-bottom:1px solid #D8E0EA;box-sizing:border-box;position:relative}.hour-cell:after{content:"";position:absolute;left:0;right:0;top:50%;border-bottom:1px solid #D8E0EA}.drag-preview-block{position:absolute;left:4px;right:4px;border-radius:6px;background:#3182ce33;border:2px dashed rgba(49,130,206,.5);pointer-events:none;z-index:5;transition:top .08s ease,height .08s ease}.drag-preview-block.invalid{background:#e53e3e26;border-color:#e53e3e66}.current-time-line{position:absolute;left:0;right:0;height:2px;z-index:150;pointer-events:none;transform:translateY(-1px)}.current-time-line.today{background:#e53e3e}.current-time-line.non-today{background:#e53e3e26}.current-time-label{position:absolute;right:5px;transform:translateY(-50%);background:#e53e3e;color:#fff;font-size:12px;font-weight:500;padding:2px 6px;border-radius:10px;white-space:nowrap;z-index:160;pointer-events:none;line-height:1.3}.current-time-label:after{content:"";position:absolute;left:100%;top:50%;transform:translateY(-50%);width:14px;height:2px;background:#e53e3e}.all-day-row{display:grid;grid-template-columns:60px repeat(7,1fr);min-height:32px}.all-day-label{display:flex;align-items:center;justify-content:flex-end;padding-right:10px;font-size:11px;color:#a0aec0;font-weight:500}.all-day-cell{border-left:1px solid #D1D9E3;padding:4px 3px;display:flex;flex-direction:column;gap:2px;min-width:0;overflow:hidden}.all-day-cell.today-col{background:transparent}.all-day-pill{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:600;color:#3d3d3d;white-space:nowrap;overflow:hidden;position:relative;cursor:default;min-width:0;flex-shrink:0}.all-day-pill-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.all-day-pill-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.all-day-pill-delete{background:none;border:none;color:#0006;font-size:12px;cursor:pointer;padding:0 2px;margin-left:auto;line-height:1;display:none}.all-day-pill:hover .all-day-pill-delete{display:inline}@media(max-width:768px){.calendar-header{padding:16px 16px 0}.calendar-header h1{font-size:22px}.calendar-header-top{flex-direction:column;gap:12px}.calendar-nav{padding:0 16px 8px;gap:6px;flex-wrap:wrap}.view-toggle-btn{padding:5px 10px;font-size:12px}.day-headers,.calendar-grid,.all-day-row{grid-template-columns:40px repeat(7,1fr)}.time-label{font-size:10px;padding-right:4px}.day-name{font-size:10px}.day-date{width:28px;height:28px;font-size:13px}}.month-calendar-layout{flex:1;display:flex;overflow:hidden;background:#fafafa;font-family:Lato,system-ui,sans-serif}.month-calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden;border-right:1px solid hsl(210,14%,89%)}.month-calendar-header{padding:24px 32px;background:#fff;border-bottom:1px solid hsl(210,14%,92%)}.month-nav{display:flex;align-items:center;gap:12px}.month-nav-btn{width:36px;height:36px;border-radius:6px;border:1px solid hsl(210,14%,89%);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#595959;transition:all .15s ease}.month-nav-btn:hover{background:#f0f2f4}.month-today-btn{padding:6px 16px;border-radius:6px;border:1px solid hsl(210,14%,89%);background:#fff;cursor:pointer;font-size:14px;font-weight:500;font-family:Lato,system-ui,sans-serif;color:#2d3748;transition:all .15s ease;margin-right:4px}.month-today-btn:hover{background:#f0f2f4}.month-title{font-size:28px;font-weight:700;color:#1a202c;margin:0;min-width:220px;letter-spacing:-.02em}.month-grid-wrapper{overflow-y:auto;flex:1}.month-grid{display:grid;grid-template-columns:repeat(7,1fr)}.month-grid-spacer{grid-column:1 / -1;height:300px}.month-weekday-header{padding:6px 0;text-align:center;font-size:13px;font-weight:600;color:#a0aec0;text-transform:uppercase;letter-spacing:.05em;background:#fff;border-bottom:1px solid #D8E0EA;position:sticky;top:0;z-index:1}.month-day-cell{min-height:200px;min-width:0;overflow:hidden;border-right:1px solid #D1D9E3;border-bottom:1px solid #D8E0EA;padding:6px 8px;display:flex;flex-direction:column;background:#fff}.month-day-cell:nth-child(7n+7){border-right:none}.month-day-cell.other-month{background:#f8f9fa}.month-day-cell.other-month .month-day-number{color:#b8b8b8}.month-day-cell.today{background:#e53e3e1f!important}.month-day-number{font-size:15px;font-weight:500;color:#2d3748;padding:2px 6px;margin-bottom:4px;align-self:flex-end}.month-day-number.today-number{background:#e53e3e;color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:0;font-weight:700;font-size:14px}.month-day-events{display:flex;flex-direction:column;gap:3px;flex:1}.month-event-item{display:flex;align-items:center;gap:6px;padding:3px 8px;border-radius:4px;border:1px solid;background:#fff;font-size:14px;font-family:Lato,system-ui,sans-serif;cursor:pointer;transition:all .12s ease;min-height:26px;line-height:1.3;box-shadow:0 1px 2px #0000000a;overflow:hidden;min-width:0}.month-event-item:hover{background:#f6f7f9}.month-event-item.completed{opacity:.45}.month-event-item.completed .month-event-title{text-decoration:line-through}.month-event-icon{flex-shrink:0;display:flex;align-items:center}.month-event-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;font-size:14px;font-family:Lato,system-ui,sans-serif;line-height:1.4}.month-holiday-item{display:flex;align-items:center;padding:3px 8px;border-radius:4px;font-size:13px;font-family:Lato,system-ui,sans-serif;font-weight:600;min-height:24px;line-height:1.3;overflow:hidden;min-width:0}.month-holiday-holiday{background:#fee2e2;color:#b91c1c}.month-holiday-no_class{background:#fef3c7;color:#92400e}.month-holiday-event{background:#dbeafe;color:#1e40af}.month-holiday-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.month-calendar-sidebar{width:240px;flex-shrink:0;background:#fff;padding:30px 20px 24px;overflow-y:auto}.calendar-sidebar-section{margin-bottom:24px}.calendar-sidebar-title{font-size:14px;font-weight:700;color:#2d3748;text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px;padding:0 4px}.calendar-sidebar-list{display:flex;flex-direction:column;gap:2px}.calendar-sidebar-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:6px;cursor:pointer;transition:background .15s ease}.calendar-sidebar-item:hover{background:#f3f5f7}.calendar-sidebar-item.hidden-course{opacity:.45}.calendar-color-dot{width:14px;height:14px;border-radius:3px;flex-shrink:0;border:2px solid}.calendar-course-name{font-size:16px;font-weight:400;color:#2d3748;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}@media(max-width:768px){.month-calendar-layout{flex-direction:column}.month-calendar-main{border-right:none;border-bottom:1px solid hsl(210,14%,89%)}.month-header{padding:16px}.month-header-title{font-size:22px}.month-day-cell{min-height:60px}}.todo-panel{border-left:none;background:#fff;padding:24px 16px;overflow:auto;flex-shrink:0}.todo-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.todo-panel-title{font-size:16px;font-weight:700;color:#2d3748;font-style:italic}.todo-section{margin-bottom:8px}.todo-section-header{display:flex;align-items:center;gap:6px;padding:6px 0;border-bottom:1px solid #EDF2F7;margin-bottom:4px}.section-collapse-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#a0aec0;padding:0;flex-shrink:0}.section-collapse-btn:hover{color:#4a5568}.todo-section-title{font-size:14px;font-weight:700;color:#2d3748;cursor:pointer;-webkit-user-select:none;user-select:none;flex:1}.section-count{font-size:12px;color:#a0aec0;background:#edf2f7;border-radius:10px;padding:1px 7px;min-width:18px;text-align:center}.section-header-actions{display:flex;align-items:center;gap:1px}.section-action-btn{display:none;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;border-radius:4px;transition:color .12s ease}.todo-section-header:hover .section-action-btn{display:flex}.section-action-btn:hover{color:#3182ce}.section-action-btn.delete:hover{color:#e53e3e}.section-edit-input{flex:1;padding:1px 4px;border:none;border-bottom:2px solid #3182CE;border-radius:0;background:transparent;font-size:14px;font-weight:700;outline:none;color:#2d3748;background:#fff}.section-plan-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#a0aec0;padding:3px;border-radius:4px;flex-shrink:0;transition:all .15s ease}.section-plan-btn:hover:not(:disabled){color:#805ad5;background:#f0e6ff}.section-plan-btn:disabled{opacity:.5;cursor:not-allowed}.todo-section-header[draggable]{cursor:grab}.todo-section-header[draggable]:active{cursor:grabbing}.todo-section.section-dragging{opacity:.4}.todo-section.section-drag-over{border-top:2px solid #3182CE}.hidden-sections-restore{display:flex;gap:6px;padding:8px 0;flex-wrap:wrap}.restore-section-btn{background:#edf2f7;border:1px dashed #CBD5E0;border-radius:6px;padding:4px 10px;font-size:13px;color:#718096;cursor:pointer;transition:all .15s}.restore-section-btn:hover{background:#e2e8f0;color:#4a5568;border-color:#a0aec0}.new-section-area{padding:4px 0 8px}.new-section-btn{display:flex;align-items:center;gap:6px;background:none;border:1px dashed #CBD5E0;border-radius:6px;padding:6px 12px;font-size:14px;color:#718096;cursor:pointer;transition:all .15s;width:100%;justify-content:center}.new-section-btn:hover{background:#edf2f7;color:#4a5568;border-color:#a0aec0}.todo-section-content{padding-left:2px}.spin{animation:spin 1s linear infinite}.todo-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;cursor:pointer;font-size:15px;position:relative}.todo-drag-zone{display:flex;align-items:flex-start;gap:8px;flex:1;min-width:0}.todo-item.assignment-item{align-items:flex-start}.todo-indicator{width:3px;min-height:18px;align-self:stretch;border-radius:1.5px;flex-shrink:0;margin-top:2px}.todo-item input[type=checkbox]{accent-color:#3182CE;width:16px;height:16px;flex-shrink:0;margin-top:1px}.todo-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.todo-text{cursor:grab;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;line-height:1.4}.todo-text.done{text-decoration:line-through;color:#cbd5e0}.todo-deadline{font-size:12px;color:#a0aec0;line-height:1.2}.todo-deadline.deadline-red{color:#e53e3e;font-weight:600}.todo-deadline.deadline-orange{color:#f97316;font-weight:600}.todo-deadline.deadline-yellow{color:#e8a630;font-weight:600}.todo-deadline.done{color:#a0aec0;font-weight:400}.todo-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;margin-top:0;visibility:hidden;opacity:0;pointer-events:none}.todo-item.hovered .todo-actions,.todo-item.editing .todo-actions{visibility:visible;opacity:1;pointer-events:auto}.todo-action-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;border-radius:4px;transition:color .12s ease}.todo-action-btn:hover{color:#3182ce}.todo-action-btn.delete:hover{color:#e53e3e}.todo-edit-input{flex:1;padding:2px 4px;border:1px solid #3182CE;border-radius:4px;font-size:14px;outline:none;color:#2d3748;background:#fff}.todo-add-row{display:flex;align-items:center;gap:8px;margin-top:4px;padding:6px 0;position:relative}.todo-add-checkbox{width:16px;height:16px;flex-shrink:0;cursor:not-allowed;accent-color:#3182CE;pointer-events:none}.todo-add-input{flex:1;padding:0;border:none;font-size:14px;outline:none;color:#a0aec0;background:transparent}.todo-empty{padding:8px 0;font-size:13px;color:#cbd5e0;font-style:italic}.todo-assignment-group{margin-bottom:2px}.todo-group-label{font-size:12px;font-weight:600;color:#a0aec0;text-transform:uppercase;letter-spacing:.3px;padding:6px 0 2px 5px}@media(max-width:768px){.todo-panel{padding:16px 12px;width:100%!important;border-left:none;border-top:1px solid #E2E8F0}}.settings-container{flex:1;padding:48px 64px;overflow-y:auto;background:#fafafa;font-family:Lato,system-ui,sans-serif}.settings-header{margin-bottom:40px}.settings-header h1{font-size:32px;font-weight:700;color:#333;margin:0 0 8px;font-family:Lato,system-ui,sans-serif;letter-spacing:-.03em}.settings-header p{font-size:15px;color:#737373;margin:0;font-weight:400}.settings-content{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:32px}.settings-section{background:#fff;border-radius:12px;padding:24px;border:1px solid hsl(210,14%,89%);box-shadow:0 2px 8px -2px #0000000d,0 4px 16px -4px #00000014;transition:box-shadow .2s}.section-header{display:flex;gap:12px;margin-bottom:24px;align-items:center}.section-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.section-icon.blue-icon{background:#0a74ae1a;color:#0a74ae}.section-icon.red-icon{background:#e33c261a;color:#e33c26}.section-header h2{font-size:18px;font-weight:500;color:#333;margin:0 0 4px;font-family:Lato,system-ui,sans-serif;letter-spacing:-.01em}.section-subtitle{font-size:14px;color:#737373;margin:0;font-weight:400}.section-title-row{display:flex;justify-content:space-between;align-items:center;flex:1}.study-cap-input-wrapper{display:flex;align-items:center;gap:4px}.study-cap-value{font-size:20px;font-weight:500;color:#333;padding:6px 14px;background:#f0f2f4;border-radius:6px;border:1px solid hsl(210,14%,89%);font-family:Lato,system-ui,sans-serif;width:60px;text-align:center;outline:none;transition:all .2s ease}.study-cap-value:hover{border-color:#c5ccd3}.study-cap-value:focus{border-color:#0a74ae;background:#fff}.study-cap-value::-webkit-inner-spin-button,.study-cap-value::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.study-cap-value[type=number]{-moz-appearance:textfield}.study-cap-unit{font-size:20px;font-weight:500;color:#333;font-family:Lato,system-ui,sans-serif}.planning-options{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.planning-option{padding:16px;border:1px solid hsl(210,14%,89%);border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;gap:16px;background:#fff;align-items:flex-start}.planning-option:hover{border-color:#d3d9de;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.planning-option.selected{border-color:#0a74ae;background:#0a74ae0d}.planning-option.selected.finish-early-option{border-color:#e33c26;background:#e33c260d}.option-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.option-icon.balanced{background:#0a74ae;color:#fff}.planning-option:not(.selected) .option-icon.balanced{background:#f0f2f4;color:#737373}.option-icon.finish-early{background:#e33c26;color:#fff}.planning-option:not(.selected) .option-icon.finish-early{background:#f0f2f4;color:#737373}.option-content h3{font-size:17px;font-weight:500;color:#333;margin:0 0 8px;font-family:Lato,system-ui,sans-serif}.option-content p{font-size:14px;color:#737373;margin:0;line-height:1.5;font-weight:400}.slider-container{margin-top:20px}.study-cap-slider{width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,hsl(201,89%,36%) 0%,hsl(201,89%,36%) var(--slider-progress, 0%),hsl(210,17%,95%) var(--slider-progress, 0%),hsl(210,17%,95%) 100%);outline:none;-webkit-appearance:none;appearance:none;cursor:pointer;transition:background .15s ease}.study-cap-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#0a74ae;cursor:pointer;box-shadow:0 2px 6px #0d6efd4d;transition:all .2s ease}.study-cap-slider::-webkit-slider-thumb:hover{background:#09679a;transform:scale(1.15);box-shadow:0 3px 10px #0d6efd66}.study-cap-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#0a74ae;cursor:pointer;border:none;box-shadow:0 2px 6px #0d6efd4d;transition:all .2s ease}.study-cap-slider::-moz-range-thumb:hover{background:#09679a;transform:scale(1.15);box-shadow:0 3px 10px #0d6efd66}.study-cap-slider::-moz-range-track{background:transparent}.slider-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:#999;font-weight:400;position:relative}.slider-labels span{position:absolute;transform:translate(-50%)}.slider-labels span:nth-child(1){left:0%}.slider-labels span:nth-child(2){left:27.27%}.slider-labels span:nth-child(3){left:63.64%}.slider-labels span:nth-child(4){left:100%}.busy-blocks-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.busy-block-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f0f2f480;border-radius:10px;transition:all .2s ease;border:1px solid transparent}.busy-block-item:hover{background:#f0f2f4;border-color:#dfe3e7;box-shadow:0 2px 6px #0000000d}.busy-block-info{flex:1}.busy-block-title{font-size:14px;font-weight:500;color:#333;margin-bottom:4px;font-family:Lato,system-ui,sans-serif}.busy-block-details{font-size:13px;color:#737373;font-weight:400}.busy-block-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s}.busy-block-item:hover .busy-block-actions{opacity:1}.edit-block-btn,.delete-block-btn{padding:6px;background:transparent;border:none;color:#999;cursor:pointer;border-radius:6px;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.edit-block-btn:hover{background:#ebedf0;color:#595959}.delete-block-btn:hover{background:#d331311a;color:#d33131}.add-block-btn{padding:8px 16px;background:#fff;border:1px solid hsl(210,14%,89%);border-radius:8px;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px;margin-left:auto;font-family:Lato,system-ui,sans-serif}.add-block-btn:hover{border-color:#0a74ae;color:#0a74ae;background:#0a74ae08;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.section-header-content{display:flex;justify-content:space-between;align-items:flex-start;flex:1}.import-btn{padding:8px 16px;background:#fff;border:1px solid hsl(210,14%,89%);border-radius:8px;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px;font-family:Lato,system-ui,sans-serif}.import-btn:hover{border-color:#0a74ae;color:#0a74ae;background:#0a74ae08;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.canvas-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px;font-weight:500;color:#333;font-family:Lato,system-ui,sans-serif}.form-input{padding:10px 12px;border:1px solid hsl(210,14%,89%);border-radius:8px;font-size:14px;font-family:Lato,system-ui,sans-serif;outline:none;transition:all .2s ease;background:#fff;color:#333}.form-input:hover{border-color:#c5ccd3}.form-input:focus{border-color:#0a74ae;background:#fff}.form-input::placeholder{color:#999}.token-input-wrapper{position:relative;display:flex;align-items:center}.token-input-wrapper .form-input{flex:1;padding-right:44px}.toggle-token-btn{position:absolute;right:8px;padding:6px;background:transparent;border:none;color:#999;cursor:pointer;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.toggle-token-btn:hover{background:#f0f2f4;color:#333}.form-hint{font-size:13px;color:#999;margin:0;font-weight:400}.save-connection-btn{padding:10px 24px;background:#0a74ae;border:none;border-radius:8px;font-size:14px;font-weight:500;color:#fff;cursor:pointer;transition:all .2s ease;font-family:Lato,system-ui,sans-serif;align-self:flex-start}.save-connection-btn:hover:not(:disabled){background:#09679a;transform:translateY(-1px);box-shadow:0 2px 8px #0d6efd33}.save-connection-btn:disabled{opacity:.6;cursor:not-allowed}.connection-status{padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;font-family:Lato,system-ui,sans-serif}.connection-status.testing{background:#f0f2f4;color:#737373}.connection-status.success{background:#1eae531a;color:#1a9948}.connection-status.error{background:#d331311a;color:#bd2828}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.import-modal{background:#fff;border-radius:12px;padding:24px;width:400px;box-shadow:0 20px 60px #00000026;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.import-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;color:#333}.import-modal-header h3{font-size:18px;font-weight:600;margin:0;font-family:Lato,system-ui,sans-serif}.import-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border:2px dashed hsl(210,14%,89%);border-radius:12px;cursor:pointer;transition:all .2s ease;background:#f9fafb;margin-bottom:16px}.import-upload-area:hover{border-color:#0a74ae;background:#0a74ae08}.import-file-input{display:none}.import-upload-area svg{color:#0a74ae;margin-bottom:12px}.import-text{font-size:15px;font-weight:500;color:#333;margin:0 0 4px;font-family:Lato,system-ui,sans-serif}.import-hint{font-size:13px;color:#999;margin:0;font-weight:400}.import-cancel-btn{width:100%;padding:10px;background:#fff;border:1px solid hsl(210,14%,89%);border-radius:8px;font-size:14px;font-weight:500;color:#333;cursor:pointer;transition:all .2s ease;font-family:Lato,system-ui,sans-serif}.import-cancel-btn:hover{background:#f0f2f4}.add-block-form{display:flex;flex-direction:column;gap:20px}.time-row{display:flex;align-items:flex-end;gap:12px}.time-row .form-group{flex:1}.time-input{width:100%}.time-separator{font-size:18px;font-weight:500;color:#737373;padding-bottom:12px}.days-selector{display:flex;gap:8px;flex-wrap:wrap}.day-chip{padding:8px 14px;border:1px solid hsl(210,14%,89%);border-radius:20px;background:#fff;font-size:13px;font-weight:500;color:#737373;cursor:pointer;transition:all .2s ease;font-family:Lato,system-ui,sans-serif}.day-chip:hover{border-color:#0a74ae;color:#0a74ae}.day-chip.selected{background:#0a74ae;border-color:#0a74ae;color:#fff}.modal-actions{display:flex;gap:12px;margin-top:4px}.modal-actions .import-cancel-btn{width:auto;flex:1}.modal-actions .save-connection-btn{flex:1;align-self:auto;text-align:center}.semester-date-row{display:flex;gap:16px}.semester-date-row .form-group{flex:1}.school-events-list{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.no-events-text{font-size:14px;color:#a0aec0;padding:12px 0}.school-event-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;transition:background .1s}.school-event-item:hover{background:#f6f7f9}.school-event-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.school-event-type-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;white-space:nowrap;flex-shrink:0}.school-event-type-badge.holiday{color:#c53030;background:#fbdfdf}.school-event-type-badge.no_class{color:#b7791f;background:#fdecce}.school-event-type-badge.event{color:#2b6cb0;background:#deebf7}.school-event-title{font-size:14px;color:#2d3748;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.school-event-date{font-size:13px;color:#718096;white-space:nowrap;margin-left:auto;padding-left:12px}.school-event-actions{display:flex;gap:4px;margin-left:8px;opacity:0;transition:opacity .12s}.school-event-item:hover .school-event-actions{opacity:1}.school-event-edit-btn,.school-event-delete-btn{padding:4px;background:transparent;border:none;color:#a0aec0;cursor:pointer;border-radius:4px;display:flex;align-items:center}.school-event-edit-btn:hover{color:#4a5568;background:#ebedf0}.school-event-delete-btn:hover{color:#d33131;background:#d331311a}.schedule-import-modal{max-width:640px;width:90vw}.schedule-import-desc{font-size:14px;color:#718096;margin:0 0 16px}.schedule-import-files{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.schedule-file-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#f0f2f4;border-radius:6px;font-size:12px;color:#4a5568}.schedule-file-chip button{background:transparent;border:none;color:#a0aec0;cursor:pointer;padding:2px;display:flex;align-items:center}.schedule-file-chip button:hover{color:#e53e3e}.parsed-events-list{max-height:320px;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.parsed-event-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;background:#f6f7f9}.parsed-event-title{font-size:14px;color:#2d3748;flex:1}.parsed-event-date{font-size:13px;color:#718096;white-space:nowrap}.parsed-event-delete{background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;border-radius:4px;display:flex;align-items:center;flex-shrink:0;transition:all .15s}.parsed-event-delete:hover{color:#e53e3e;background:#fed7d7}.tz-dropdown{position:absolute;top:68px;left:0;right:0;background:#fff;border:1px solid hsl(201,89%,36%);border-radius:8px;box-shadow:0 8px 24px #0000001f;max-height:220px;overflow-y:auto;z-index:200;list-style:none;margin:0;padding:4px 0}.tz-option{padding:8px 14px;font-size:13px;font-family:Lato,system-ui,sans-serif;color:#333;cursor:pointer;transition:background .1s}.tz-option:hover{background:#0a74ae14}.tz-option.selected{background:#0a74ae1f;color:#086191;font-weight:600}.language-options{display:flex;gap:8px}.language-option{padding:8px 20px;border:1px solid hsl(210,14%,89%);border-radius:8px;background:#fff;color:#4a5568;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;font-family:Lato,system-ui,sans-serif}.language-option:hover{border-color:#3182ce;color:#2d3748}.language-option.active{background:#ebf8ff;border-color:#3182ce;color:#3182ce;font-weight:600}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;cursor:pointer}.toggle-label{font-size:14px;color:#4a5568}.toggle-checkbox{width:18px;height:18px;accent-color:#3182CE;cursor:pointer}@media(max-width:768px){.settings-container{padding:24px 16px}.settings-header h1{font-size:24px}.settings-content{gap:20px}.settings-section{padding:16px}.planning-options{grid-template-columns:1fr}.semester-date-row{flex-direction:column;gap:12px}.time-row{flex-direction:column;align-items:stretch;gap:8px}.time-separator{display:none}.days-selector{gap:6px}.day-chip{padding:6px 10px;font-size:12px}.section-header{flex-wrap:wrap}.section-header-content{flex-direction:column;gap:8px}.import-btn,.add-block-btn{align-self:flex-start}}.course-page{flex:1;overflow-y:auto;background:#e9e9ec;font-family:Lato,system-ui,sans-serif}.course-page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;font-size:14px;color:#a0aec0}.course-page-loading .loading-spinner{animation:course-spin 1s linear infinite}@keyframes course-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.course-page-header{padding:32px 40px 24px;background:#fff;border-bottom:1px solid hsl(210,14%,92%);display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.course-header-left{flex:1;min-width:0}.course-page-title{font-size:28px;font-weight:700;color:#1a202c;margin:0}.course-page-subtitle{font-size:15px;color:#718096;margin:6px 0 0}.course-header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.course-sync-time{font-size:13px;color:#a0aec0;white-space:nowrap}.course-sync-btn,.course-import-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s ease;white-space:nowrap}.course-sync-btn{background:#fff;border:1px solid hsl(210,14%,89%);color:#2d3748}.course-sync-btn:hover:not(:disabled){background:#f3f5f7}.course-sync-btn:disabled{opacity:.6;cursor:not-allowed}.course-import-btn{background:#3182ce;border:1px solid #3182CE;color:#fff}.course-import-btn:hover{background:#2b6cb0}.course-info-empty{font-size:14px;color:#a0aec0;font-style:italic}.course-info-edit-btn{padding:4px 6px;background:transparent;border:none;color:#a6a6a6;cursor:pointer;border-radius:4px;display:flex;align-items:center;transition:color .12s}.course-info-edit-btn:hover{color:#3380cc}.course-info-edit-actions{display:flex;gap:6px}.course-info-save-btn,.course-info-cancel-btn{display:flex;align-items:center;gap:3px;padding:3px 10px;border-radius:6px;border:none;font-size:12px;font-weight:500;cursor:pointer;transition:background .12s}.course-info-save-btn{background:#3380cc;color:#fff}.course-info-save-btn:hover{background:#2e73b8}.course-info-cancel-btn{background:#ededed;color:#4a5568}.course-info-cancel-btn:hover{background:#e0e0e0}.course-info-form{display:flex;flex-direction:column;gap:8px}.course-info-form-row{display:flex;align-items:center;gap:10px}.course-info-input{flex:1;padding:6px 10px;border:1px solid hsl(210,14%,85%);border-radius:6px;font-size:13px;color:#2d3748;outline:none;font-family:inherit}.course-info-input:focus{border-color:#478cd1;box-shadow:0 0 0 2px #478cd126}.course-info-input::placeholder{color:#a0aec0}.course-ta-form-item{padding:10px 0;border-top:1px solid hsl(210,14%,93%);display:flex;flex-direction:column;gap:6px;position:relative}.course-ta-remove-btn{position:absolute;top:10px;right:0;padding:4px;background:transparent;border:none;color:#a6a6a6;cursor:pointer;border-radius:4px;transition:color .12s}.course-ta-remove-btn:hover{color:#d33131}.course-ta-add-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px dashed hsl(210,14%,80%);border-radius:6px;background:transparent;font-size:13px;color:#718096;cursor:pointer;margin-top:6px;transition:border-color .12s,color .12s}.course-ta-add-btn:hover{border-color:#478cd1;color:#3380cc}.course-page-content{padding:28px 40px 60px;display:grid;grid-template-columns:1fr 1fr;gap:16px;overflow:hidden}@media(max-width:768px){.course-page-header{padding:20px 16px 16px;flex-direction:column;gap:12px}.course-page-title{font-size:22px}.course-header-right{flex-wrap:wrap}.course-page-content{grid-template-columns:1fr;padding:16px}.course-section-draggable{grid-column:span 1!important}.section-span-btn{display:none}.course-card{padding:16px}}.course-section-draggable{border-radius:14px;transition:opacity .15s,box-shadow .15s;min-width:0}.section-toolbar{display:flex;align-items:center;gap:2px;margin-bottom:4px;height:20px;opacity:0;transition:opacity .15s}.course-section-draggable:hover .section-toolbar{opacity:1}.section-drag-handle{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:5px;color:#a0aec0;cursor:grab;transition:color .12s,background .12s}.section-drag-handle:active{cursor:grabbing}.section-drag-handle:hover{color:#4a5568;background:#ebedf0}.section-span-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:5px;border:none;background:none;color:#a0aec0;cursor:pointer;transition:color .12s,background .12s}.section-span-btn:hover{color:#4a5568;background:#ebedf0}.course-section-draggable.section-dragging{opacity:.4}.course-section-draggable.section-drag-over{box-shadow:0 -3px #3182ce;border-radius:14px}.course-card{background:#fff;border-radius:12px;border:1px solid hsl(210,14%,91%);padding:24px 28px;min-width:0;overflow:hidden}.course-card-label{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}.course-grade-display{display:flex;align-items:center;gap:12px;margin-bottom:10px}.course-grade-number{font-size:42px;font-weight:700;color:#22c55e}.course-letter-badge{font-size:14px;font-weight:600;padding:4px 10px;border-radius:20px;border:1.5px solid}.course-grade-note{font-size:13px;color:#22c55e}.course-info-list{display:flex;flex-direction:column;gap:12px}.course-info-row{display:flex;align-items:center;gap:12px;font-size:14px;color:#2d3748}.course-info-icon{color:#718096;flex-shrink:0}.course-info-link{color:#3182ce;text-decoration:none}.course-info-link:hover{text-decoration:underline}.course-ta-section{margin-top:8px;padding-top:10px;border-top:1px solid #EDF2F7}.course-ta-label{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.course-ta-item{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.course-ta-item:last-child{margin-bottom:0}.course-section-header{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:#1a202c;margin-bottom:20px}.course-section-icon{color:#3182ce}.grade-overall-row{display:flex;gap:24px;margin-bottom:24px;padding:16px 20px;background:#f6f7f9;border-radius:10px}.grade-overall-item{display:flex;flex-direction:column;align-items:center;min-width:100px}.grade-overall-label{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.04em}.grade-overall-value{font-size:28px;font-weight:700;line-height:1.2;color:#1a202c}.grade-overall-sub{font-size:11px;color:#a0aec0;margin-top:2px}.grade-breakdown-list{display:flex;flex-direction:column;gap:16px}.grade-breakdown-item{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:6px 16px}.grade-breakdown-info{grid-column:1;grid-row:1;display:flex;align-items:center;gap:8px;font-size:14px;color:#2d3748}.grade-breakdown-icon{color:#718096;display:flex}.grade-breakdown-name{font-weight:600}.grade-breakdown-weight{color:#a0aec0;font-size:12px;background:#f3f5f7;padding:2px 7px;border-radius:4px}.grade-breakdown-right{grid-column:2;grid-row:1;display:flex;align-items:center;gap:10px;justify-self:end}.grade-breakdown-score{font-size:14px;font-weight:600;color:#2d3748}.grade-breakdown-percent{font-size:14px;font-weight:700;color:#1a202c;min-width:48px;text-align:right}.grade-breakdown-empty{color:#a0aec0;font-weight:400}.grade-breakdown-bar{grid-column:1 / -1;grid-row:2;height:6px;background:#dfdfe2;border-radius:3px;overflow:hidden}.grade-breakdown-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.grade-breakdown-whatif{display:flex;align-items:center;gap:4px}.grade-whatif-input{width:52px;padding:4px 8px;border:1.5px solid #CBD5E0;border-radius:6px;font-size:13px;font-weight:600;font-family:Lato,system-ui,sans-serif;color:#2d3748;text-align:center;outline:none;transition:border-color .15s ease}.grade-whatif-input:focus{border-color:#3182ce}.grade-whatif-input::placeholder{color:#cbd5e0;font-weight:400}.grade-whatif-label{font-size:13px;color:#a0aec0;font-weight:500}.grade-whatif-reset{margin-top:16px;padding:6px 14px;border:1px solid hsl(210,14%,89%);border-radius:6px;background:#fff;font-size:13px;font-weight:500;color:#718096;cursor:pointer;transition:all .12s ease}.grade-whatif-reset:hover{background:#f3f5f7;color:#2d3748}.grade-whatif-input::-webkit-outer-spin-button,.grade-whatif-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.grade-whatif-input[type=number]{-moz-appearance:textfield}.upcoming-list{display:flex;flex-direction:column;gap:4px}.upcoming-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:8px;border:1px solid #EDF2F7;background:#fff}.upcoming-item:hover{background:#f9fafb}.upcoming-left{display:flex;align-items:flex-start;gap:12px}.upcoming-checkbox{width:18px;height:18px;accent-color:#3182CE;margin-top:2px;flex-shrink:0}.upcoming-title{font-size:15px;font-weight:500;color:#1a202c}.upcoming-title.checked{text-decoration:line-through;color:#cbd5e0}.upcoming-title-link{cursor:pointer}.upcoming-title-link:hover{color:#2e73b8;text-decoration:underline}.upcoming-meta{display:flex;align-items:center;gap:10px;margin-top:4px}.upcoming-due{font-size:13px;color:#718096}.upcoming-due-badge{font-size:12px;font-weight:600;color:#fff;background:#e53e3e;padding:3px 10px;border-radius:12px}.upcoming-time{font-size:13px;color:#a0aec0}.upcoming-open-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid hsl(210,14%,89%);border-radius:8px;background:#fff;font-size:13px;font-weight:500;color:#2d3748;cursor:pointer;transition:background .12s ease;white-space:nowrap}.upcoming-open-btn:hover{background:#f3f5f7}.upcoming-right{display:flex;align-items:center;gap:6px}.upcoming-delete-btn{padding:6px;background:transparent;border:none;color:#a6a6a6;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.upcoming-delete-btn:hover{background:#d331311a;color:#d33131}.upcoming-edit-btn{padding:2px 4px;background:transparent;border:none;color:#b3b3b3;cursor:pointer;border-radius:4px;display:inline-flex;align-items:center;transition:color .12s}.upcoming-edit-btn:hover{color:#3380cc}.upcoming-date-input{font-size:13px;padding:2px 6px;border:1px solid hsl(210,14%,80%);border-radius:6px;outline:none;color:#2d3748}.upcoming-date-input:focus{border-color:#478cd1;box-shadow:0 0 0 2px #478cd126}.upcoming-remaining{font-size:12px;font-weight:500;padding:1px 8px;border-radius:10px;white-space:nowrap}.upcoming-remaining-normal{color:#4a5568;background:#ebedf0}.upcoming-remaining-yellow{color:#975a16;background:#fdecce}.upcoming-remaining-red{color:#c53030;background:#fbdfdf}.upcoming-due-yellow{color:#b7791f!important}.upcoming-due-red{color:#c53030!important;font-weight:600}.past-graded-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.past-graded-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:#1a202c;margin:0}.past-graded-icon{color:#3182ce}.past-graded-group{margin-bottom:6px}.past-graded-group:last-child{margin-bottom:0}.past-graded-group-label{font-size:13px;font-weight:600;color:#a0aec0;text-transform:uppercase;letter-spacing:.3px;padding:12px 0 6px;border-bottom:1px solid #CBD5E0}.past-graded-list{display:flex;flex-direction:column}.past-graded-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #EDF2F7}.past-graded-item:last-child{border-bottom:none}.past-graded-name{font-size:15px;font-weight:500;color:#2d3748}.past-graded-meta{font-size:13px;color:#718096;margin-top:3px}.past-graded-right{text-align:right}.past-graded-score{font-size:15px;font-weight:500;color:#2d3748;display:block}.past-graded-score-value{cursor:text;border-bottom:1px solid transparent;transition:border-color .15s}.past-graded-score-value:hover{border-bottom-color:#cbd5e0}.past-graded-score-input{width:50px;font-size:15px;font-weight:500;color:#2d3748;border:none;border-bottom:1.5px solid #3182CE;outline:none;background:transparent;text-align:right;padding:0;-moz-appearance:textfield}.past-graded-score-input::-webkit-outer-spin-button,.past-graded-score-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.past-graded-percent{font-size:13px;color:#718096}.past-graded-excused{color:#a0aec0;font-style:italic;font-weight:400}.past-graded-revert-btn{background:none;border:1px solid #CBD5E0;border-radius:6px;color:#718096;cursor:pointer;padding:4px 10px;display:inline-flex;align-items:center;gap:5px;font-size:12px;transition:all .15s}.past-graded-revert-btn:hover{color:#3182ce;border-color:#3182ce;background:#ebf8ff}.past-graded-item.past-graded-dropped{opacity:.45}.past-graded-dropped-tag{font-size:10px;color:#a0aec0;background:#edf2f7;border-radius:3px;padding:1px 5px;margin-left:6px}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.course-import-modal{background:#fff;border-radius:16px;padding:32px;width:420px;max-width:90vw;box-shadow:0 20px 60px #00000026}.course-import-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;color:#1a202c}.course-import-modal-header h3{font-size:18px;font-weight:700;margin:0}.course-import-desc{font-size:14px;color:#718096;line-height:1.5;margin:0 0 20px}.import-mode-tabs{display:flex;gap:0;margin-bottom:20px;border:1px solid #E2E8F0;border-radius:8px;overflow:hidden}.import-mode-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:500;color:#718096;background:#fff;border:none;cursor:pointer;transition:all .12s ease}.import-mode-tab:first-child{border-right:1px solid #E2E8F0}.import-mode-tab.active{background:#3182ce;color:#fff}.import-mode-tab:hover:not(.active){background:#f3f5f7}.import-file-section{margin-bottom:16px}.import-file-picker{display:flex;align-items:center;gap:10px;padding:14px 16px;border:1.5px solid #E2E8F0;border-radius:10px;cursor:pointer;color:#718096;transition:all .12s ease}.import-file-picker:hover{border-color:#3182ce;color:#3182ce}.import-file-picker span{font-size:14px;font-weight:500}.import-file-hint{margin-left:auto;font-size:12px!important;color:#a0aec0!important;font-weight:400!important}.import-tip{font-size:12px;color:#a0aec0;margin:8px 0 0;line-height:1.4}.import-file-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.course-import-file-input{display:none}.import-file-selected{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1.5px solid #3182CE;border-radius:10px;background:#f5faff}.import-file-icon{color:#3182ce;flex-shrink:0}.import-file-name{flex:1;font-size:14px;font-weight:500;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-file-remove{background:none;border:none;font-size:18px;color:#a0aec0;cursor:pointer;padding:0 4px;line-height:1}.import-file-remove:hover{color:#e53e3e}.import-url-section{margin-bottom:16px}.import-url-input{width:100%;padding:12px 14px;border:1.5px solid #E2E8F0;border-radius:10px;font-size:14px;font-family:Lato,system-ui,sans-serif;color:#2d3748;outline:none;transition:border-color .15s ease;box-sizing:border-box}.import-url-input:focus{border-color:#3182ce}.import-url-input::placeholder{color:#cbd5e0}.course-import-status{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:14px;margin-bottom:12px}.import-modal-actions{display:flex;gap:10px}.import-submit-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border:none;border-radius:8px;background:#3182ce;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s ease}.import-submit-btn:hover:not(:disabled){background:#2b6cb0}.import-submit-btn:disabled{opacity:.5;cursor:not-allowed}.course-import-status.success{background:#f0fff4;color:#22543d}.course-import-status.error{background:#fff5f5;color:#c53030}.course-import-cancel-btn{flex:1;padding:10px;border:1px solid hsl(210,14%,89%);border-radius:8px;background:#fff;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:background .12s ease}.course-import-cancel-btn:hover{background:#f3f5f7}.course-notes-card{margin-top:0}.notes-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.notes-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:#1a202c;margin:0;flex:1}.notes-icon{color:#3182ce}.notes-upload-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;border:1px solid #E2E8F0;background:#fff;font-size:13px;font-weight:500;color:#4a5568;cursor:pointer;transition:all .12s ease}.notes-upload-btn:hover{border-color:#3182ce;color:#3182ce}.notes-image-grid{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px;max-width:100%}.notes-image-card{width:280px;min-width:100px;max-width:100%;border:1px solid #E2E8F0;border-radius:10px;background:#fff;overflow:hidden;position:relative;transition:box-shadow .15s ease,border-color .15s ease;display:flex;flex-direction:column}.notes-resize-handle{position:absolute;bottom:0;right:0;width:18px;height:18px;cursor:nwse-resize;display:flex;align-items:center;justify-content:center;opacity:1;color:#718096;z-index:1}.notes-image-card:hover{box-shadow:0 2px 10px #00000014}.notes-image-card.dragging{opacity:.4}.notes-image-card.drag-over{border-color:#3182ce;box-shadow:0 0 0 2px #3182ce4d}.notes-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid #EDF2F7;background:#f7fafc;flex-shrink:0;cursor:grab}.notes-card-icon{color:#718096;flex-shrink:0}.notes-card-name{flex:1;font-size:13px;font-weight:500;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notes-card-delete{background:none;border:none;color:#cbd5e0;cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:all .12s}.notes-image-card:hover .notes-card-delete{opacity:1}.notes-card-delete:hover{color:#e53e3e}.notes-card-body{overflow:hidden;display:flex;align-items:center;justify-content:center;background:#fafbfc}.notes-card-body img{width:100%;display:block;cursor:zoom-in}.notes-file-list{display:flex;flex-direction:column;gap:4px}.notes-file-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;transition:background .12s ease;width:fit-content}.notes-file-item:hover{background:#f7fafc}.notes-file-icon{color:#718096;display:flex;flex-shrink:0}.notes-file-name{font-size:14px;color:#3182ce;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notes-file-download{color:#718096;display:flex;align-items:center;padding:4px;border-radius:4px;transition:color .12s}.notes-file-download:hover{color:#3182ce}.notes-file-delete{background:none;border:none;color:#a0aec0;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:all .12s}.notes-file-item:hover .notes-file-delete{opacity:1}.notes-file-delete:hover{color:#e53e3e}.notes-empty{text-align:center;padding:24px;color:#a0aec0;font-size:14px}.notes-lightbox{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:zoom-out}.course-notes-card.file-drag-over{border-color:#3182ce;background:#f5faff;box-shadow:inset 0 0 0 2px #3182ce}.course-notes-card.file-drag-over .notes-empty{color:#3182ce;font-weight:600}.notes-lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 4px 20px #0000004d}.notes-file-name.clickable{cursor:pointer}.notes-file-name.clickable:hover{text-decoration:underline;color:#2b6cb0}.notes-preview-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.notes-preview-modal{width:85vw;height:85vh;background:#fff;border-radius:12px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000040}.notes-preview-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid #E2E8F0;flex-shrink:0}.notes-preview-title{font-size:15px;font-weight:600;color:#1a202c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:16px}.notes-preview-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.notes-preview-download-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:6px;border:1px solid #E2E8F0;background:#fff;font-size:13px;font-weight:500;color:#4a5568;text-decoration:none;transition:all .12s}.notes-preview-download-btn:hover{border-color:#3182ce;color:#3182ce}.notes-preview-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:#718096;cursor:pointer;transition:all .12s}.notes-preview-close-btn:hover{background:#edf2f7;color:#2d3748}.notes-preview-body{flex:1;overflow:hidden}.notes-preview-iframe{width:100%;height:100%;border:none}.courses-list-page{flex:1;overflow-y:auto;background:#f7f7f7;font-family:Lato,system-ui,sans-serif}.courses-list-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;text-align:center}.courses-list-empty-icon{color:#cbd5e0;margin-bottom:16px}.courses-list-empty-title{font-size:22px;font-weight:700;color:#1a202c;margin:0 0 8px}.courses-list-empty-desc{font-size:15px;color:#718096;margin:0 0 24px;max-width:320px;line-height:1.5}.courses-list-connect-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#3182ce;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .12s ease}.courses-list-connect-btn:hover{background:#2b6cb0}.courses-list-header{padding:32px 40px 24px;background:#fff;border-bottom:1px solid hsl(210,14%,92%);display:flex;align-items:center;justify-content:space-between}.courses-list-header-left{display:flex;align-items:baseline;gap:12px}.courses-list-title{font-size:28px;font-weight:700;color:#1a202c;margin:0}.courses-list-count{font-size:14px;color:#a0aec0;font-weight:500}.courses-list-header-right{display:flex;align-items:center;gap:12px}.courses-list-sync-time{font-size:13px;color:#a0aec0;white-space:nowrap}.courses-list-sync-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s ease;white-space:nowrap;background:#fff;border:1px solid hsl(210,14%,89%);color:#2d3748}.courses-list-sync-btn:hover:not(:disabled){background:#f3f5f7}.courses-list-sync-btn:disabled{opacity:.6;cursor:not-allowed}.courses-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:28px 40px 60px}.courses-list-card{background:#fff;border-radius:12px;border:1px solid hsl(210,14%,91%);overflow:hidden;cursor:pointer;transition:box-shadow .15s ease,transform .15s ease}.courses-list-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.courses-list-card-accent{height:4px;width:100%}.courses-list-card-body{padding:18px 20px 16px}.courses-list-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.courses-list-card-code{font-size:16px;font-weight:700;color:#1a202c;margin:0;line-height:1.3}.courses-list-card-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .15s ease}.courses-list-card:hover .courses-list-card-actions{opacity:1}.courses-list-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:#718096;cursor:pointer;transition:all .12s ease}.courses-list-action-btn:hover{background:#f0f2f4;color:#2d3748}.courses-list-action-delete:hover{background:#fff5f5;color:#e53e3e}.courses-list-card-name{font-size:14px;color:#4a5568;margin:0 0 12px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.courses-list-card-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.courses-list-card-term{font-size:12px;color:#718096;background:#f3f5f7;padding:3px 8px;border-radius:4px}.courses-list-card-grade{font-size:13px;font-weight:600;color:#22c55e}.courses-list-color-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid #EDF2F7}.courses-list-color-dot{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .12s ease}.courses-list-color-dot:hover{transform:scale(1.15)}.courses-list-color-dot.selected{border-color:#1a202c;box-shadow:0 0 0 2px #fff,0 0 0 4px #1a202c}.courses-list-delete-modal{background:#fff;border-radius:14px;padding:28px;width:380px;max-width:90vw;box-shadow:0 20px 60px #00000026}.courses-list-delete-modal h3{font-size:18px;font-weight:700;color:#1a202c;margin:0 0 8px}.courses-list-delete-modal p{font-size:14px;color:#718096;line-height:1.5;margin:0 0 20px}.courses-list-delete-modal-actions{display:flex;gap:10px;justify-content:flex-end}.courses-list-modal-cancel{padding:8px 16px;border:1px solid hsl(210,14%,89%);border-radius:8px;background:#fff;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:background .12s ease}.courses-list-modal-cancel:hover{background:#f3f5f7}.courses-list-modal-delete{padding:8px 16px;border:none;border-radius:8px;background:#e53e3e;font-size:14px;font-weight:500;color:#fff;cursor:pointer;transition:background .12s ease}.courses-list-modal-delete:hover{background:#c53030}.assignment-page{flex:1;overflow-y:auto;background:#e9e9ec;font-family:Lato,system-ui,sans-serif}.assignment-page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:200px;color:#a0aec0;font-size:14px}.assignment-loading-spinner{animation:assignment-spin 1s linear infinite}@keyframes assignment-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.assignment-page-content{padding:28px 40px 60px;max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.assignment-back-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:none;color:#4a5568;font-size:14px;font-weight:500;cursor:pointer;border-radius:6px;transition:background .12s,color .12s;align-self:flex-start}.assignment-back-btn:hover{background:#dce0e5;color:#1a202c}.assignment-card{background:#fff;border-radius:12px;border:1px solid hsl(210,14%,91%);padding:24px 28px}.assignment-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.assignment-title{font-size:22px;font-weight:700;color:#1a202c;margin:0;line-height:1.3}.assignment-canvas-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid hsl(210,14%,89%);border-radius:8px;background:#364563;font-size:13px;font-weight:500;color:#fff;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .12s}.assignment-canvas-btn:hover{background:#2d3953}.assignment-meta{display:flex;align-items:center;gap:12px;margin-top:10px;flex-wrap:wrap}.assignment-due{display:flex;align-items:center;gap:5px;font-size:14px;font-weight:500;color:#4a5568}.assignment-due-red{color:#c53030;font-weight:600}.assignment-due-yellow{color:#b7791f}.assignment-remaining{font-size:12px;font-weight:500;padding:2px 10px;border-radius:10px;white-space:nowrap}.assignment-remaining-normal{color:#4a5568;background:#ebedf0}.assignment-remaining-yellow{color:#975a16;background:#fdecce}.assignment-remaining-red{color:#c53030;background:#fbdfdf}.assignment-points{font-size:14px;color:#718096}.assignment-section-title{font-size:18px;font-weight:700;color:#1a202c;margin:0 0 8px}.assignment-description{font-size:14px;color:#4a5568;line-height:1.6}.assignment-description p{margin:8px 0}.assignment-description a{color:#2e73b8}.assignment-description-section{margin-top:20px;padding-top:20px;border-top:1px solid hsl(210,14%,91%)}.assignment-description-section .assignment-section-title{font-size:15px;margin-bottom:12px}.assignment-description-empty{font-size:14px;color:#4a5568;margin:0}.assignment-steps-subtitle{font-size:13px;color:#a0aec0;margin:0 0 16px}.assignment-progress{margin-bottom:16px}.assignment-progress-header{display:flex;justify-content:space-between;font-size:13px;color:#4a5568;margin-bottom:6px}.assignment-progress-bar{height:8px;background:#dfdfe2;border-radius:4px;overflow:hidden}.assignment-progress-fill{height:100%;background:#3182ce;border-radius:4px;transition:width .3s ease}.assignment-steps-list{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.assignment-step{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;transition:background .1s}.assignment-step:hover{background:#f6f7f9}.assignment-step-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#3182CE;flex-shrink:0}.assignment-step-title{flex:1;font-size:14px;color:#2d3748}.assignment-step-title.checked{text-decoration:line-through;color:#a0aec0}.assignment-step-delete{padding:4px;background:transparent;border:none;color:transparent;cursor:pointer;border-radius:4px;display:flex;align-items:center;transition:color .12s,background .12s}.assignment-step:hover .assignment-step-delete{color:#b3b3b3}.assignment-step-delete:hover{color:#d33131!important;background:#d331311a}.assignment-add-step{display:flex;gap:8px}.assignment-add-step-input{flex:1;padding:8px 12px;border:1px solid hsl(210,14%,85%);border-radius:8px;font-size:14px;color:#2d3748;outline:none;font-family:inherit}.assignment-add-step-input:focus{border-color:#478cd1;box-shadow:0 0 0 2px #478cd126}.assignment-add-step-input::placeholder{color:#a0aec0}.assignment-add-step-btn{padding:8px 20px;background:#ebedf0;border:none;border-radius:8px;font-size:14px;font-weight:500;color:#4a5568;cursor:pointer;transition:background .12s}.assignment-add-step-btn:hover:not(:disabled){background:#dce0e5}.assignment-add-step-btn:disabled{opacity:.5;cursor:default}.assignment-section-title-row{display:flex;align-items:center;justify-content:space-between}.assignment-section-title-row .assignment-section-title{margin-bottom:0}.assignment-ai-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid hsl(210,14%,89%);border-radius:8px;background:transparent;color:#805ad5;cursor:pointer;transition:background .12s,color .12s}.assignment-ai-btn:hover:not(:disabled){background:#f5f0fa;color:#6b46c1}.assignment-ai-btn:disabled{opacity:.6;cursor:default}.ai-preview-section{background:#f7f4fa;border:1px solid hsl(270,30%,90%);border-radius:10px;padding:16px;margin-bottom:16px}.ai-preview-header{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#805ad5;margin-bottom:12px}.ai-preview-step{display:flex;align-items:center;gap:10px;padding:8px 0}.ai-preview-number{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#805ad5;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.ai-preview-title{font-size:14px;color:#2d3748}.ai-preview-actions{display:flex;gap:10px;margin-top:14px}.ai-preview-confirm{display:flex;align-items:center;gap:6px;padding:8px 18px;background:#805ad5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s}.ai-preview-confirm:hover{background:#6b46c1}.ai-preview-cancel{padding:8px 18px;background:transparent;border:1px solid hsl(210,14%,85%);border-radius:8px;font-size:14px;font-weight:500;color:#718096;cursor:pointer;transition:background .12s}.ai-preview-cancel:hover{background:#f0f2f4}.ai-chat-modal{background:#fff;border-radius:16px;padding:28px 32px;width:480px;max-width:90vw;box-shadow:0 20px 60px #00000026}.ai-chat-modal-header{display:flex;align-items:center;gap:10px;color:#805ad5;margin-bottom:8px}.ai-chat-modal-header h3{font-size:18px;font-weight:700;margin:0;flex:1;color:#1a202c}.ai-chat-close{background:transparent;border:none;color:#a0aec0;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center}.ai-chat-close:hover{color:#4a5568;background:#f0f2f4}.ai-chat-desc{font-size:14px;color:#718096;margin:0 0 16px}.ai-chat-textarea{width:100%;padding:12px;border:1px solid hsl(210,14%,85%);border-radius:8px;font-size:14px;font-family:inherit;color:#2d3748;resize:vertical;outline:none;box-sizing:border-box}.ai-chat-textarea:focus{border-color:#96c;box-shadow:0 0 0 2px #9966cc26}.ai-chat-textarea::placeholder{color:#a0aec0}.ai-chat-file-label{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px dashed hsl(210,14%,82%);border-radius:8px;font-size:13px;color:#718096;cursor:pointer;margin-top:12px;transition:background .12s}.ai-chat-file-label:hover{background:#f6f7f8}.ai-chat-file-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.ai-chat-file-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#f0f2f4;border-radius:6px;font-size:12px;color:#4a5568}.ai-chat-file-chip button{background:transparent;border:none;color:#a0aec0;cursor:pointer;padding:2px;display:flex;align-items:center}.ai-chat-file-chip button:hover{color:#e53e3e}.ai-chat-actions{margin-top:16px}.ai-chat-generate-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:#805ad5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s}.ai-chat-generate-btn:hover:not(:disabled){background:#6b46c1}.ai-chat-generate-btn:disabled{opacity:.5;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}.year-calendar-layout{flex:1;display:flex;overflow:hidden;background:#fafafa;font-family:Lato,system-ui,sans-serif}.year-calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.year-calendar-header{padding:24px 32px;background:#fff;border-bottom:1px solid hsl(210,14%,92%)}.year-nav{display:flex;align-items:center;gap:12px}.year-grid-wrapper{flex:1;overflow-y:auto;padding:28px 32px}.year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.year-mini-month{background:#fff;border-radius:10px;padding:16px;cursor:pointer;transition:box-shadow .15s ease,transform .15s ease;border:1px solid hsl(210,14%,92%)}.year-mini-month:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.year-mini-month.current{border-color:#e53e3e}.year-mini-month-title{font-size:15px;font-weight:700;color:#1a202c;margin-bottom:10px;letter-spacing:-.01em}.year-mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px 0}.year-mini-weekday{font-size:10px;font-weight:600;color:#a0aec0;text-align:center;padding:2px 0 4px;text-transform:uppercase}.year-mini-day{display:flex;flex-direction:column;align-items:center;padding:2px 0;min-height:22px;position:relative}.year-mini-day.empty{min-height:22px}.year-mini-day-num{font-size:11px;font-weight:400;color:#4a5568;line-height:1;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%}.year-mini-day.today .year-mini-day-num{background:#e53e3e;color:#fff;font-weight:700}.year-mini-day.holiday .year-mini-day-num{color:#e53e3e;font-weight:600}.year-mini-dots{display:flex;gap:2px;margin-top:1px}.year-mini-dot{width:4px;height:4px;border-radius:50%}@media(max-width:768px){.year-calendar-layout{flex-direction:column}.year-calendar-header{padding:16px}.year-calendar-header h1{font-size:22px}.year-calendar-grid{padding:16px;grid-template-columns:repeat(2,1fr);gap:16px}}@media(max-width:480px){.year-calendar-grid{grid-template-columns:1fr}}.analytics-page{flex:1;padding:48px 64px;overflow-y:auto;background:#fafafa;font-family:Lato,system-ui,sans-serif}.analytics-header{margin-bottom:40px}.analytics-content{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:32px}.analytics-loading,.analytics-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;min-height:400px;color:#718096;font-size:14px}.analytics-spinner{animation:spin 1s linear infinite;color:#a0aec0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.analytics-error{color:#e53e3e}.analytics-header h1{font-size:32px;font-weight:700;color:#333;margin:0 0 8px;letter-spacing:-.03em}.analytics-subtitle{font-size:15px;color:#737373;margin:0}.analytics-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-card{background:#fff;border:1px solid hsl(210,14%,89%);border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px -2px #0000000d,0 4px 16px -4px #00000014}.stat-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.busy{background:#fed7d7;color:#e53e3e}.stat-icon.avg{background:#c6f6d5;color:#38a169}.stat-icon.peak{background:#fefcbf;color:#d69e2e}.stat-icon.free{background:#bee3f8;color:#3182ce}.stat-value{font-size:16px;font-weight:700;color:#1a202c}.stat-label{font-size:11px;color:#a0aec0;margin-top:1px}.heatmap-section{background:#fff;border:1px solid hsl(210,14%,89%);border-radius:12px;padding:24px;box-shadow:0 2px 8px -2px #0000000d,0 4px 16px -4px #00000014}.heatmap-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.heatmap-section-header h2,.weekly-section h2,.type-section h2{font-size:16px;font-weight:700;color:#333;margin:0}.heatmap-legend{display:flex;align-items:center;gap:3px}.legend-label{font-size:11px;color:#a0aec0;margin:0 3px}.legend-cell{width:14px;height:14px;border-radius:3px;border:1px solid #e2e8f0}.heatmap-calendar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.heatmap-month{min-width:0}.heatmap-month-title{font-size:14px;font-weight:600;color:#2d3748;margin-bottom:8px}.heatmap-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.heatmap-weekday{font-size:10px;font-weight:600;color:#a0aec0;text-align:center;padding:2px 0 4px}.heatmap-day{aspect-ratio:1;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s,box-shadow .1s;position:relative;min-height:28px}.heatmap-day:hover:not(.empty):not(.outside){transform:scale(1.15);box-shadow:0 2px 8px #00000026;z-index:2}.heatmap-day.empty{cursor:default}.heatmap-day.outside{opacity:.3;cursor:default}.heatmap-day.today{outline:2px solid #e53e3e;outline-offset:-1px}.heatmap-day-num{font-size:11px;font-weight:500;line-height:1}.heatmap-day-dots{display:flex;gap:2px;margin-top:2px}.heatmap-day-dot{width:3px;height:3px;border-radius:50%}.day-detail-card{background:#fff;border:1px solid hsl(210,14%,89%);border-radius:12px;padding:24px;animation:fadeIn .15s ease;box-shadow:0 2px 8px -2px #0000000d,0 4px 16px -4px #00000014}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.day-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.day-detail-date{font-size:14px;font-weight:600;color:#2d3748}.day-detail-badges{display:flex;gap:8px}.day-detail-badge{font-size:12px;padding:2px 10px;border-radius:10px;font-weight:500}.day-detail-badge.study{background:#fed7d7;color:#c53030}.day-detail-badge.class{background:#bee3f8;color:#2b6cb0}.day-detail-badge.free{background:#c6f6d5;color:#276749}.day-detail-assignments{display:flex;flex-direction:column;gap:6px}.day-detail-assignment{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 8px;border-radius:6px;background:#f7fafc}.day-detail-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.day-detail-title{color:#2d3748;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-detail-type{font-size:11px;color:#718096;background:#edf2f7;padding:1px 6px;border-radius:4px;flex-shrink:0}.day-detail-course{font-size:11px;color:#a0aec0;flex-shrink:0}.day-detail-done{font-size:11px;color:#38a169;font-weight:600;flex-shrink:0}.weekly-section{background:#fff;border:1px solid hsl(210,14%,89%);border-radius:12px;padding:24px;box-shadow:0 2px 8px -2px #0000000d,0 4px 16px -4px #00000014}.weekly-section h2{margin-bottom:14px}.weekly-bars{display:flex;flex-direction:column;gap:5px}.weekly-bar-row{display:flex;align-items:center;gap:10px;height:22px}.weekly-bar-row.current .weekly-bar-label{color:#e53e3e;font-weight:600}.weekly-bar-label{width:52px;font-size:11px;color:#718096;flex-shrink:0;text-align:right}.weekly-bar-track{flex:1;height:14px;background:#f7fafc;border-radius:4px;overflow:hidden}.weekly-bar-fill{height:100%;background:linear-gradient(90deg,#fc8181,#e53e3e);border-radius:4px;transition:width .4s ease}.weekly-bar-row.current .weekly-bar-fill{background:linear-gradient(90deg,#e53e3e,#9b2c2c)}.weekly-bar-value{width:100px;font-size:11px;color:#4a5568;font-weight:500;flex-shrink:0}.weekly-bar-count{color:#a0aec0;font-weight:400}.type-section{background:#fff;border:1px solid hsl(210,14%,89%);border-radius:12px;padding:24px;box-shadow:0 2px 8px -2px #0000000d,0 4px 16px -4px #00000014}.type-section h2{margin-bottom:14px}.type-stacked-bar{display:flex;height:18px;border-radius:6px;overflow:hidden;margin-bottom:12px}.type-bar-segment{min-width:3px;transition:opacity .15s}.type-bar-segment:hover{opacity:.8}.type-legend{display:flex;flex-wrap:wrap;gap:10px 18px}.type-legend-item{display:flex;align-items:center;gap:6px;font-size:12px}.type-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.type-legend-label{color:#4a5568}.type-legend-count{color:#a0aec0;font-size:11px}@media(max-width:768px){.analytics-page{padding:24px 16px}.analytics-header{margin-bottom:24px}.analytics-header h1{font-size:24px}.analytics-content{gap:20px}.analytics-stats{grid-template-columns:repeat(2,1fr);gap:10px}.heatmap-section,.weekly-section,.type-section,.day-detail-card{padding:16px}.heatmap-section-header{flex-direction:column;align-items:flex-start;gap:10px}.heatmap-calendar-grid{grid-template-columns:1fr}.weekly-bar-value{width:80px;font-size:10px}.day-detail-header{flex-direction:column;align-items:flex-start;gap:6px}}@media(max-width:480px){.analytics-stats{grid-template-columns:1fr}.stat-card{padding:12px}.weekly-bar-label{width:40px;font-size:10px}}.daily-review-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.daily-review-modal{background:#fff;border-radius:12px;padding:24px 28px;width:420px;max-width:90vw;box-shadow:0 12px 40px #00000026}.daily-review-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.daily-review-header h3{margin:0;font-size:18px;color:#2d3748}.daily-review-icon{font-size:20px}.daily-review-desc{color:#718096;font-size:14px;margin:0 0 16px}.daily-review-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.daily-review-item{display:flex;align-items:center;justify-content:space-between;gap:12px}.daily-review-title{font-size:14px;color:#2d3748;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.daily-review-input-group{display:flex;align-items:center;gap:4px;flex-shrink:0}.daily-review-input{width:60px;padding:4px 8px;border:1px solid #E2E8F0;border-radius:6px;font-size:14px;text-align:right;outline:none}.daily-review-input:focus{border-color:#3182ce}.daily-review-unit{font-size:13px;color:#a0aec0}.daily-review-actions{display:flex;justify-content:flex-end;gap:10px}.daily-review-skip{padding:8px 16px;border:1px solid #E2E8F0;border-radius:8px;background:#fff;color:#718096;font-size:14px;cursor:pointer}.daily-review-skip:hover{background:#f7fafc}.daily-review-save{padding:8px 20px;border:none;border-radius:8px;background:#3182ce;color:#fff;font-size:14px;cursor:pointer}.daily-review-save:hover{background:#2b6cb0}.app-layout{display:flex;height:100vh;font-family:Lato,system-ui,sans-serif;background:#fff;color:#333;overflow:hidden;font-size:14px;font-weight:400}.panel-divider{width:4px;cursor:col-resize;background:#dfe3e7;flex-shrink:0;transition:background .15s;position:relative}.panel-divider:after{content:"";position:absolute;inset:0 -4px}.panel-divider:hover{background:#0a74ae}.right-panel-animated{display:flex;animation:panelFadeSlideIn .25s ease-out}@keyframes panelFadeSlideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.app-loading-spinner{animation:app-spin 1s linear infinite}@keyframes app-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.app-layout{flex-direction:column;height:100vh}.panel-divider{display:none}}
