.student-history{max-width:1200px;margin:0 auto;padding:0 1rem}.student-history-loading{display:flex;align-items:center;justify-content:center;height:100vh}.error-message{background-color:#f8717126;color:#f87171;padding:1rem;border-radius:8px;margin-bottom:1.5rem;border-left:3px solid #f87171}.calendar-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.stats-bar{display:flex;gap:1rem;margin-bottom:2rem;justify-content:flex-start}.stat-pill{display:flex;align-items:center;gap:.75rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:.75rem 1.25rem}.stat-pill svg{color:var(--color-success);flex-shrink:0}.stat-number{font-weight:700;font-size:1.25rem;color:var(--text-primary)}.stat-label{color:var(--text-muted);font-size:.9rem;white-space:nowrap}.calendar-section{background-color:var(--bg-secondary)}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.nav-button{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .2s ease}.nav-button:hover{background-color:var(--bg-tertiary)}.nav-button svg{width:24px;height:24px}.month-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:.05em;flex:1;text-align:center;min-width:200px}.day-headers{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1rem}.day-header{text-align:center;font-weight:600;color:var(--text-muted);font-size:.9rem;padding:.5rem 0;letter-spacing:.05em}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1.5rem}.calendar-day{aspect-ratio:1;border-radius:8px;cursor:pointer;border:1px solid transparent;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative;font-weight:500;color:var(--text-primary)}.calendar-day.other-month{opacity:.4;cursor:default}.calendar-day.other-month:hover{border-color:transparent}.calendar-day.selected{border:2px solid var(--text-primary)}.calendar-day.today{border:1px solid var(--text-muted)}.calendar-day:not(.other-month):hover{border-color:var(--text-primary)}.day-number{font-size:1rem;font-weight:600}.legend{display:flex;align-items:center;justify-content:center;gap:.75rem}.legend-label{color:var(--text-muted);font-size:.85rem;font-weight:500}.legend-colors{display:flex;gap:.4rem}.legend-color{width:24px;height:24px;border-radius:4px;border:1px solid var(--border-color)}.daily-detail-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.selected-date-title{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.selected-date-stats{margin-top:.5rem;color:var(--text-muted);font-size:.9rem}.add-session-btn{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:.75rem 1.25rem;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s ease;white-space:nowrap}.add-session-btn:hover{background-color:var(--bg-tertiary);border-color:var(--text-primary)}.add-session-form{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-group:last-of-type{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary);font-size:.95rem}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:var(--color-primary)}.form-group input::placeholder{color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.btn-cancel,.btn-save{padding:.75rem 1.5rem;border-radius:8px;border:none;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s ease}.btn-cancel{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-cancel:hover{background-color:var(--bg-tertiary)}.btn-save{background-color:var(--color-primary);color:var(--bg-primary);border:none}.btn-save:hover{opacity:.9}.sessions-list{display:grid;gap:1rem}.empty-state{text-align:center;padding:2.5rem;color:var(--text-muted);background-color:var(--bg-tertiary);border-radius:8px;border:1px dashed var(--border-color)}.empty-state p{margin:0;font-size:.95rem}.session-item{background-color:var(--bg-tertiary);border-left:3px solid var(--color-success);border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.session-left{display:flex;flex-direction:column;gap:.25rem}.session-right{display:flex;gap:1rem;align-items:center}.session-lesson{font-weight:700;color:var(--text-primary);font-size:1rem}.session-topic{color:var(--text-muted);font-size:.9rem}.session-time{color:var(--color-success);font-weight:600;font-size:.95rem}.session-type{color:var(--text-muted);background-color:var(--bg-secondary);padding:.25rem .75rem;border-radius:4px;font-size:.8rem;font-weight:500;text-transform:lowercase}.session-note{color:var(--text-muted);font-size:.85rem;padding-top:.75rem;border-top:1px solid var(--border-color);margin-top:.5rem}@media (max-width: 768px){.student-history{padding:0 .5rem}.calendar-container{padding:1rem}.stats-bar{flex-direction:column;margin-bottom:1.5rem}.stat-pill{width:100%}.calendar-header{gap:.5rem}.month-title{font-size:1.25rem;min-width:auto}.nav-button svg{width:20px;height:20px}.calendar-grid{gap:.4rem}.calendar-day{border-radius:6px}.day-number{font-size:.9rem}.legend{font-size:.85rem;gap:.5rem}.legend-color{width:20px;height:20px}.daily-detail-section{padding:1rem}.section-header{flex-direction:column;gap:1rem}.add-session-btn{width:100%}.form-row{grid-template-columns:1fr;margin-bottom:1rem}.form-actions{flex-direction:column;gap:.75rem}.btn-cancel,.btn-save{width:100%}.session-item{gap:.5rem}.session-right{flex-wrap:wrap;gap:.5rem}}.teacher-history-view .session-right{flex-wrap:wrap}.teacher-history-view .source-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;font-size:.78rem;font-weight:600;border-radius:999px;white-space:nowrap;letter-spacing:.02em;line-height:1.4}.teacher-history-view .source-badge.source-pomodoro{background-color:#6d28d91f;color:#6d28d9;border:1px solid rgba(109,40,217,.3)}.teacher-history-view .source-badge.source-manual{background-color:#6b72801f;color:#4b5563;border:1px solid rgba(107,114,128,.3)}.teacher-history-view .source-badge.source-program{background-color:#0596691f;color:#059669;border:1px solid rgba(5,150,105,.3)}.teacher-history-view .source-badge.source-generic{background-color:#6b728014;color:#6b7280;border:1px solid rgba(107,114,128,.25)}.teacher-history-view{max-width:none;padding:0}.teacher-history-view .calendar-container{padding:1rem;margin-bottom:1.25rem}.teacher-history-view .calendar-header{margin-bottom:.75rem}.teacher-history-view .day-headers{margin-bottom:.5rem;gap:.35rem}.teacher-history-view .day-header{padding:.25rem 0;font-size:.8rem}.teacher-history-view .calendar-grid{gap:.35rem;margin-bottom:.75rem}.teacher-history-view .calendar-day{aspect-ratio:auto;height:calc((40vh - 8rem) / 6);min-height:32px}.teacher-history-view .day-number{font-size:.85rem}.teacher-history-view .legend-color{width:18px;height:18px}.student-dashboard{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-greeting{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.dashboard-date{color:var(--text-muted);font-size:.95rem}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}.stat-card{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;text-align:center}.stat-value{font-size:1.75rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem}.stat-label{color:var(--text-muted);font-size:.95rem}.upcoming-section{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.upcoming-section h2{font-size:1.25rem;margin-bottom:1rem}.upcoming-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.upcoming-item{background-color:var(--bg-secondary);border-left:3px solid var(--color-primary);border-radius:8px;padding:1rem;display:flex;justify-content:space-between;align-items:center}.upcoming-time{font-size:.9rem;color:var(--text-muted);font-weight:500}.upcoming-lesson{font-size:1rem;color:var(--text-primary);font-weight:600}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.dashboard-card{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:2rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center}.dashboard-card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card-icon{color:var(--color-primary);margin-bottom:1rem;display:flex;justify-content:center}.card-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.card-desc{color:var(--text-muted);font-size:.9rem}@media (max-width: 768px){.stats-row,.dashboard-grid{grid-template-columns:1fr}.dashboard-greeting{font-size:1.5rem}.upcoming-list{grid-template-columns:1fr}}.light-content .sd-greeting{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.light-content .sd-greeting h1{font-size:1.6rem;font-weight:700;color:var(--text-on-light, #1F2937)}.light-content .muted{color:var(--text-muted-on-light, #6B7280)}.light-content .sd-track-badge{display:inline-flex;align-items:center;padding:6px 14px;border-radius:999px;background:#6d28d91f;color:#6d28d9;font-size:.82rem;font-weight:600;letter-spacing:.3px}.light-content .sd-schedule-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#f9fafb;border:1px solid #EEF0F3;border-radius:10px;color:var(--text-on-light, #1F2937)}.light-content .sd-ghost-btn{background:transparent;border:none;color:#6d28d9;font-size:.82rem;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s ease}.light-content .sd-ghost-btn:hover{background:#6d28d914}.light-content .sd-quicklink{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:18px 10px;background:#fff;border:1px solid #E5E7EB;border-radius:12px;color:var(--text-on-light, #1F2937);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s ease}.light-content .sd-quicklink:hover{transform:translateY(-2px);box-shadow:0 6px 16px #11182714;border-color:#d1d5db}.light-content .sd-quicklink-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center}.light-content .error-message{background:#dc262614;color:#b91c1c;padding:10px 14px;border-radius:8px;border-left:3px solid #DC2626;font-size:.9rem}.student-study-plan{max-width:1000px;margin:0 auto}.student-study-plan h1{margin-bottom:1.5rem}.day-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:1px solid var(--border-color);overflow-x:auto;padding-bottom:0}.day-tab{padding:.75rem 1rem;background:none;border:none;color:var(--text-muted);cursor:pointer;font-weight:500;border-bottom:2px solid transparent;transition:all .2s ease;white-space:nowrap;margin-bottom:-1px}.day-tab:hover{color:var(--text-primary)}.day-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.plan-content{margin-bottom:3rem}.slots-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.slot-card{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-left:3px solid;border-radius:12px;padding:1.5rem;position:relative;transition:all .2s ease}.slot-card:hover{box-shadow:var(--shadow-md)}.slot-card.completed{opacity:.7}.slot-card.completed .slot-lesson:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:var(--text-muted)}.slot-header{display:flex;justify-content:flex-end;margin-bottom:.75rem}.slot-badge{display:inline-block;background-color:#60a5fa26;color:var(--color-primary);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.slot-lesson{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.slot-time{color:var(--text-muted);font-size:.9rem;margin-bottom:.5rem}.slot-topic{color:var(--text-muted);font-size:.85rem;font-style:italic;margin-bottom:1rem;padding-left:.5rem;border-left:2px solid var(--border-color)}.slot-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-primary);font-weight:500;flex:1}.checkbox-label input[type=checkbox]{cursor:pointer;width:auto}.floating-btn{position:fixed;bottom:30px;right:30px;width:56px;height:56px;border-radius:50%;background-color:var(--color-primary);color:#000;border:none;font-size:1.5rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-lg);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.floating-btn:hover{transform:scale(1.1);box-shadow:0 15px 20px #60a5fa4d}@media (max-width: 768px){.slots-list{grid-template-columns:1fr}.floating-btn{bottom:20px;right:20px;width:48px;height:48px;font-size:1.25rem}.day-tabs{margin-bottom:1.5rem}}.student-pomodoro{max-width:900px;margin:0 auto}.student-pomodoro h1{margin-bottom:1.5rem}.mode-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color);margin-bottom:2rem}.mode-tab{padding:1rem 1.5rem;background:none;border:none;color:var(--text-muted);cursor:pointer;font-weight:500;border-bottom:2px solid transparent;transition:all .2s ease;margin-bottom:-1px}.mode-tab:hover{color:var(--text-primary)}.mode-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.mode-content{min-height:500px}.pomodoro-container,.timer-container,.stopwatch-container{display:flex;flex-direction:column;align-items:center;gap:2rem}.preset-selector{width:100%;display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.preset-selector label{margin:0;white-space:nowrap;font-weight:500}.preset-selector select{flex:1;max-width:400px}.timer-circle-container{position:relative;width:240px;height:240px;margin:2rem 0}.timer-circle{width:100%;height:100%}.circle-bg{fill:none;stroke:var(--border-color);stroke-width:2}.circle-progress{fill:none;stroke:var(--color-primary);stroke-width:4;stroke-linecap:round;stroke-dasharray:565.48;stroke-dashoffset:0;transform:rotate(-90deg);transform-origin:50% 50%;transition:stroke-dashoffset 1s linear}.timer-display{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.timer-time{font-size:3rem;font-weight:700;color:var(--text-primary);font-family:Courier New,monospace}.timer-phase{font-size:1rem;color:var(--text-muted);font-weight:500}.session-counter{font-size:.85rem;color:var(--text-muted)}.timer-display-large{font-size:4rem;font-weight:700;color:var(--color-primary);font-family:Courier New,monospace;margin:2rem 0}.timer-inputs{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%;max-width:300px}.input-group{display:flex;flex-direction:column}.input-group label{margin-bottom:.5rem;font-weight:500}.input-group input{font-size:1.25rem;text-align:center;padding:.75rem}.timer-controls{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin:1rem 0}.today-stats{text-align:center;color:var(--text-muted);font-size:1rem;padding:1rem 1.5rem;background-color:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color);width:100%;max-width:400px}@media (max-width: 768px){.timer-circle-container{width:180px;height:180px}.timer-time{font-size:2rem}.timer-display-large{font-size:2.5rem}.timer-controls{width:100%}.timer-controls .btn{flex:1;min-width:80px}}.fs-toggle-btn{display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap}.fs-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000;color:#e5e7eb;display:flex;align-items:center;justify-content:center;overflow:hidden;user-select:none;-webkit-user-select:none;cursor:default}.fs-clock{position:absolute;top:1.5rem;right:1.75rem;font-size:1rem;font-weight:500;color:#6b7280;font-variant-numeric:tabular-nums;letter-spacing:.05em}.fs-exit-btn{position:absolute;top:1rem;left:1rem;width:36px;height:36px;border-radius:50%;background:transparent;border:1px solid #2a2a2a;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:color .2s ease,border-color .2s ease}.fs-exit-btn:hover{color:#e5e7eb;border-color:#4b5563}.fs-center{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:2rem;text-align:center}.fs-lesson-label{font-size:1rem;color:#9ca3af;font-weight:500;letter-spacing:.02em;max-width:80vw;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.fs-lesson-range{color:#6b7280}.fs-time{font-size:clamp(5rem,20vw,18rem);line-height:1;font-weight:200;letter-spacing:.02em;font-variant-numeric:tabular-nums;color:#e5e7eb;margin:.5rem 0}.fs-sub{font-size:1.1rem;color:#9ca3af;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.fs-sub-dim{color:#4b5563;text-transform:none;letter-spacing:0}.fs-done{font-size:clamp(1.5rem,3vw,2.5rem);color:#34d399;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-top:.5rem}.fs-controls{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;margin-top:1.5rem}.fs-btn{background:transparent;border:1px solid #374151;color:#9ca3af;padding:.6rem 1.25rem;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease;min-width:110px}.fs-btn:hover:not(:disabled){color:#e5e7eb;border-color:#6b7280}.fs-btn:disabled{opacity:.35;cursor:not-allowed}.fs-btn-primary{border-color:#7c3aed;color:#c4b5fd}.fs-btn-primary:hover:not(:disabled){background:#7c3aed26;color:#ddd6fe}.fs-btn-danger{border-color:#7f1d1d;color:#fca5a5}.fs-btn-danger:hover:not(:disabled){background:#dc262626}.fs-btn-exit{border-color:#2a2a2a}.student-exams{max-width:1000px;margin:0 auto}.exams-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.exams-header h1{margin:0}.exam-type-tabs{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.exam-type-tab{padding:.75rem 1rem;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-muted);cursor:pointer;font-weight:500;transition:all .2s ease}.exam-type-tab:hover{border-color:var(--color-primary);color:var(--text-primary)}.exam-type-tab.active{background-color:var(--color-primary);color:#000;border-color:var(--color-primary)}.exam-form{margin-bottom:2rem}.exam-form h3{margin-bottom:1.5rem}.subjects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin:1.5rem 0}.subject-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.subject-section h4{margin:0 0 1rem;color:var(--text-primary);font-size:.95rem}.subject-fields{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.field{display:flex;flex-direction:column}.field label{font-size:.8rem;margin-bottom:.25rem}.field input{padding:.5rem;font-size:.9rem}.field.net{grid-column:1 / -1}.net-value{padding:.5rem;background-color:var(--bg-tertiary);border-radius:4px;text-align:center;color:var(--color-primary);font-weight:600}.total-net{text-align:right;padding:1rem;background-color:var(--bg-secondary);border-radius:8px;font-size:1.1rem;margin:1rem 0}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.exams-list{display:grid;gap:1rem}.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-muted);background-color:var(--bg-tertiary);border-radius:12px;border:1px dashed var(--border-color)}.exam-card{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.exam-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;cursor:pointer;transition:background-color .2s ease}.exam-header:hover{background-color:var(--bg-secondary)}.exam-date{color:var(--text-muted);font-size:.9rem;font-weight:500}.exam-net{font-size:1.75rem;font-weight:700;color:var(--color-primary)}.expand-icon{color:var(--text-muted);font-size:1.5rem;font-weight:700}.exam-details{padding:0 1.5rem 1.5rem;border-top:1px solid var(--border-color);background-color:var(--bg-secondary)}.subject-result{margin-bottom:1rem;padding:1rem;background-color:var(--bg-tertiary);border-radius:8px}.subject-name{font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.subject-stats{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;font-size:.9rem}.subject-stats span{color:var(--text-muted)}.subject-stats .net{grid-column:1 / -1;color:var(--color-primary);font-weight:600}.exam-badge{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.exam-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);justify-content:flex-end}.error-message{background-color:#f8717126;color:var(--color-error);padding:1rem;border-radius:8px;margin-bottom:1.5rem;border-left:3px solid var(--color-error)}@media (max-width: 768px){.exams-header{flex-direction:column;align-items:flex-start;gap:1rem}.exam-type-tabs{width:100%}.exam-header{flex-direction:column;align-items:flex-start;gap:.5rem}.exam-net{align-self:flex-end}.subjects-grid{grid-template-columns:1fr}}:root{--bg-primary: #0A0E27;--bg-secondary: #141937;--bg-tertiary: #1F2547;--bg-sidebar: #05071A;--text-primary: #F5F0E8;--text-muted: rgba(245, 240, 232, .55);--border-color: rgba(76, 29, 149, .25);--color-primary: #4C1D95;--color-primary-hover: #6D28D9;--color-primary-glow: rgba(76, 29, 149, .4);--color-success: #4ADE80;--color-error: #F87171;--color-warning: #FBBF24;--color-info: #6D28D9;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 25px rgba(10, 14, 39, .7)}.light-content{--bg-content: #F5F6FA;--bg-card: #FFFFFF;--border-content: #E5E7EB;--text-on-light: #1F2937;--text-muted-on-light: #6B7280;--shadow-card: 0 1px 3px rgba(17, 24, 39, .06), 0 1px 2px rgba(17, 24, 39, .04);--bg-primary: #F5F6FA;--bg-secondary: #F9FAFB;--bg-tertiary: #FFFFFF;--text-primary: #1F2937;--text-muted: #6B7280;--border-color: #E5E7EB;--color-primary: #6D28D9;--color-primary-hover: #7C3AED;--color-success: #059669;--color-error: #DC2626;--color-warning: #D97706;--color-info: #6D28D9;--shadow-sm: 0 1px 2px rgba(17, 24, 39, .05);--shadow-md: 0 4px 6px rgba(17, 24, 39, .08);--shadow-lg: 0 10px 25px rgba(17, 24, 39, .12);background:var(--bg-content);color:var(--text-on-light);min-height:100vh}.light-content .card{background-color:#fff;border:1px solid #E5E7EB;box-shadow:0 1px 3px #1118270f}.light-content .card:hover{border-color:#d1d5db;box-shadow:0 4px 10px #11182714}.light-content input,.light-content select,.light-content textarea{background-color:#fff;border:1px solid #E5E7EB;color:#1f2937}.light-content input::placeholder,.light-content textarea::placeholder{color:#9ca3af}.light-content .text-muted,.light-content .muted{color:#6b7280}.light-content .badge{border:1px solid transparent}.light-content .btn-primary{color:#fff}.light-content .btn-icon{color:#1f2937}.light-content .btn-icon:hover:not(:disabled){background-color:#f3f4f6}.light-content .modal{background-color:#fff;border:1px solid #E5E7EB}.light-content .modal-header,.light-content label{color:#1f2937}.light-content h1,.light-content h2,.light-content h3,.light-content h4,.light-content h5,.light-content h6{color:var(--text-on-light)}.light-content .text-muted,.light-content .muted{color:var(--text-muted-on-light)}.lc-card{background:var(--bg-card);border:1px solid var(--border-content);border-radius:14px;padding:20px;box-shadow:var(--shadow-card)}.lc-stat-tile{background:var(--bg-card);border:1px solid var(--border-content);border-radius:14px;padding:18px 20px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;box-shadow:var(--shadow-card)}.lc-stat-tile .tile-value{font-size:1.85rem;font-weight:700;color:var(--text-on-light);line-height:1.15}.lc-stat-tile .tile-label{font-size:.85rem;color:var(--text-muted-on-light);margin-top:4px}.lc-stat-tile .tile-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lc-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.lc-grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:16px}.lc-grid-1-1{display:grid;grid-template-columns:1fr 1fr;gap:16px}.lc-grid-2x2{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 1100px){.lc-grid-4{grid-template-columns:repeat(2,1fr)}.lc-grid-2-1,.lc-grid-1-1{grid-template-columns:1fr}}.lc-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.lc-card-title{font-size:1rem;font-weight:600;color:var(--text-on-light)}.light-content table{width:100%;border-collapse:collapse;background:transparent}.light-content table thead,.light-content table tbody,.light-content table tr{background:transparent}.light-content table thead{background:#f9fafb;border-bottom:1px solid var(--border-content)}.light-content table th,.light-content table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-content);color:var(--text-on-light);background:transparent}.light-content table th{color:var(--text-muted-on-light);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}.light-content table tbody tr:hover{background:#6d28d90d}.light-content table tbody tr:last-child td{border-bottom:none}.sidebar-avatar-block{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px 22px;border-bottom:1px solid var(--border-color);margin-bottom:12px}.sidebar-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#6d28d9,#4c1d95);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:.02em;box-shadow:0 4px 14px #4c1d958c;border:2px solid rgba(245,240,232,.12)}.sidebar-avatar-name{color:var(--text-primary);font-size:.95rem;font-weight:600;text-align:center;line-height:1.2}.sidebar-avatar-role{color:var(--text-muted);font-size:.75rem;text-align:center}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0a0e27,#1a1040 60%,#2a1260);background-attachment:fixed;color:var(--text-primary);line-height:1.6;min-height:100vh}#root{width:100%;height:100%}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;margin-bottom:.5rem}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem}p{margin-bottom:1rem}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}.btn{padding:.75rem 1.5rem;border:none;border-radius:12px;font-size:1rem;cursor:pointer;transition:all .2s ease;font-weight:500;display:inline-flex;align-items:center;gap:.5rem;border:1px solid transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--text-primary)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:0 4px 12px var(--color-primary-glow)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-secondary);border-color:var(--color-primary)}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#ef4444;box-shadow:var(--shadow-md)}.btn-success{background-color:var(--color-success);color:#000}.btn-success:hover:not(:disabled){background-color:#22c55e;box-shadow:var(--shadow-md)}.btn-small{padding:.5rem 1rem;font-size:.9rem}.btn-icon{padding:.5rem;border-radius:8px;background-color:transparent;color:var(--text-primary)}.btn-icon:hover:not(:disabled){background-color:var(--bg-tertiary)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],textarea,select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:#fff;font-family:inherit;font-size:1rem;transition:border-color .2s ease}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=date]:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4c1d9540}input[type=checkbox],input[type=radio]{cursor:pointer;accent-color:var(--color-primary)}.light-content input[type=text],.light-content input[type=email],.light-content input[type=password],.light-content input[type=number],.light-content input[type=date],.light-content textarea,.light-content select{background-color:#fff;border:1px solid #E5E7EB;color:#1f2937}.light-content input[type=text]::placeholder,.light-content input[type=email]::placeholder,.light-content input[type=password]::placeholder,.light-content input[type=number]::placeholder,.light-content textarea::placeholder{color:#9ca3af}label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-group{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-row-3{grid-template-columns:1fr 1fr 1fr}.card{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm)}.card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transition:all .2s ease}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.card-title{font-size:1.25rem;font-weight:600}.card-subtitle{font-size:.9rem;color:var(--text-muted);font-weight:400}.card-body{margin-bottom:1rem}.card-footer{border-top:1px solid var(--border-color);padding-top:1rem;display:flex;justify-content:flex-end;gap:.5rem}table{width:100%;border-collapse:collapse;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}thead{background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary)}td{padding:1rem;border-bottom:1px solid var(--border-color)}tbody tr:hover{background-color:var(--bg-tertiary)}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500;white-space:nowrap}.badge-success{background-color:#4ade8026;color:var(--color-success)}.badge-error{background-color:#f8717126;color:var(--color-error)}.badge-warning{background-color:#fbbf2426;color:var(--color-warning)}.badge-info{background-color:#6d28d92e;color:var(--color-info)}.badge-neutral{background-color:#8a857826;color:var(--text-muted)}.sidebar{width:240px;background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:2rem 0;position:fixed;height:100vh;overflow-y:auto}.sidebar-header{padding:0 1.5rem;margin-bottom:2rem;font-size:1.25rem;font-weight:600}.sidebar-nav{flex:1;display:flex;flex-direction:column}.sidebar-nav a{padding:.75rem 1.5rem;color:var(--text-muted);font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:.75rem}.sidebar-nav a:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.sidebar-nav a.active{background-color:var(--color-primary);color:var(--text-primary);border-left:3px solid var(--color-primary-hover);padding-left:calc(1.5rem - 3px);box-shadow:inset 0 0 20px #6d28d940}.sidebar-footer{padding:1.5rem 1.5rem 0;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem}.app-container{display:flex;min-height:100vh}.app-main{flex:1;display:flex;flex-direction:column;margin-left:240px;min-height:100vh}.app-header{position:sticky;top:0;z-index:100;background-color:#0a0e27d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.app-header-title{font-size:1.5rem;font-weight:600}.app-header-actions{display:flex;align-items:center;gap:1rem}.app-content{flex:1;padding:2rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;color:var(--text-primary)}.modal-body{margin-bottom:2rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem}.wheel-picker{position:relative;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.25rem;user-select:none;-webkit-user-select:none;touch-action:pan-y}.wheel-column{display:flex;flex-direction:column;align-items:center;gap:.2rem}.wheel-btn{background:transparent;border:none;border-radius:6px;width:44px;height:22px;color:var(--text-muted);opacity:.45;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:opacity .15s ease,color .15s ease,background .15s ease}.wheel-btn:hover:not(:disabled){opacity:1;color:var(--color-primary);background:#6d28d914}.wheel-btn:active:not(:disabled){transform:scale(.92)}.wheel-btn:disabled{opacity:.15;cursor:not-allowed}.wheel{width:88px;height:220px;overflow-y:scroll;overflow-x:hidden;scroll-snap-type:y mandatory;scrollbar-width:none;-ms-overflow-style:none;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 25%,black 75%,transparent 100%);mask-image:linear-gradient(to bottom,transparent 0%,black 25%,black 75%,transparent 100%);position:relative;z-index:1;border-radius:8px}.wheel:focus{outline:2px solid var(--color-primary);outline-offset:3px}.wheel:focus:not(:focus-visible){outline:none}.wheel::-webkit-scrollbar{display:none;width:0;height:0}.wheel-padding{height:88px;flex-shrink:0}.wheel-item{height:44px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:500;font-variant-numeric:tabular-nums;color:var(--text-muted);scroll-snap-align:center;scroll-snap-stop:always;cursor:pointer;transition:color .15s ease,transform .15s ease}.wheel-item.selected{color:var(--color-primary);font-weight:700;transform:scale(1.05)}.wheel-highlight{position:absolute;left:.25rem;right:.25rem;top:139px;transform:translateY(-50%);height:44px;background:#6d28d914;border-top:1px solid rgba(109,40,217,.25);border-bottom:1px solid rgba(109,40,217,.25);border-radius:8px;pointer-events:none;z-index:0}.wheel-separator{font-size:1.75rem;font-weight:700;color:var(--text-primary);padding:0 .1rem;position:relative;z-index:2;pointer-events:none}.wheel-step-header{text-align:center;margin-bottom:.5rem}.wheel-step-header .wheel-step-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.15rem}.wheel-step-header .wheel-step-value{font-size:1.75rem;font-weight:700;color:var(--color-primary);font-variant-numeric:tabular-nums;letter-spacing:.02em}.exam-subjects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin:.75rem 0 1rem}.exam-subject-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;padding:.75rem}.exam-subject-card h4{margin:0 0 .5rem;color:var(--text-primary);font-size:.95rem;font-weight:600}.exam-subject-fields{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.exam-subject-fields .field{display:flex;flex-direction:column}.exam-subject-fields .field label{font-size:.75rem;color:var(--text-muted);margin-bottom:.15rem}.exam-subject-fields .field input{padding:.4rem .5rem;font-size:.9rem}.exam-subject-fields .field.net{grid-column:1 / -1}.exam-subject-fields .net-value{padding:.4rem .5rem;background-color:var(--bg-tertiary);border-radius:6px;text-align:center;color:var(--color-primary);font-weight:700;font-variant-numeric:tabular-nums}.exam-total-net{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;font-size:1rem;margin-top:.5rem}.exam-total-net strong{color:var(--color-primary);font-size:1.25rem;font-variant-numeric:tabular-nums}.slot-time-warning{margin-top:.75rem;padding:.5rem .75rem;background:#ef444414;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#dc2626;font-size:.85rem;text-align:center}.notification-bell-container{position:relative}.notification-bell-button{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;position:relative;font-size:1.25rem}.notification-badge{position:absolute;top:-8px;right:-8px;background-color:var(--color-error);color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.notification-dropdown{position:absolute;top:100%;right:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;margin-top:.5rem;width:320px;max-height:400px;overflow-y:auto;z-index:100;box-shadow:var(--shadow-lg)}.notification-list{display:flex;flex-direction:column}.notification-item{padding:1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;transition:background-color .2s ease}.notification-item:hover{background-color:var(--bg-secondary)}.notification-item:last-child{border-bottom:none}.notification-dot{width:8px;height:8px;border-radius:50%;margin-top:.5rem;flex-shrink:0}.notification-dot.unread{background-color:var(--color-primary)}.notification-dot.read{background-color:transparent}.notification-content{flex:1}.notification-title{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.notification-message{font-size:.9rem;color:var(--text-muted);margin-bottom:.25rem}.notification-time{font-size:.8rem;color:var(--text-muted)}.notification-dropdown-footer{padding:1rem;border-top:1px solid var(--border-color);text-align:center}.notification-dropdown-footer button{width:100%}.tabs{display:flex;border-bottom:1px solid var(--border-color);margin-bottom:1.5rem;gap:0}.tab-button{padding:1rem 1.5rem;background:none;border:none;color:var(--text-muted);cursor:pointer;font-weight:500;font-size:1rem;transition:all .2s ease;border-bottom:2px solid transparent;margin-bottom:-1px}.tab-button:hover{color:var(--text-primary)}.tab-button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-content{display:none}.tab-content.active{display:block}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-center{display:flex;justify-content:center;align-items:center}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr);gap:1.5rem}.grid-3{grid-template-columns:repeat(3,1fr);gap:1.5rem}.grid-4{grid-template-columns:repeat(4,1fr);gap:1.5rem}.students-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.students-grid .card{padding:2rem;display:flex;flex-direction:column}.students-grid .card h3{font-size:1.15rem;margin-bottom:.5rem}@media (max-width: 768px){.students-grid{grid-template-columns:1fr}.students-grid .card{padding:1.5rem}}.hamburger-btn{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem}.sidebar-backdrop{display:none}@media (max-width: 1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.hamburger-btn{display:flex;align-items:center;justify-content:center}.sidebar{transform:translate(-100%);z-index:1001;transition:transform .3s ease}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000}.app-main{margin-left:0}.app-content,.app-header{padding:1rem}.grid-2,.grid-3,.grid-4,.form-row,.form-row-3{grid-template-columns:1fr}.modal{width:95%;padding:1.5rem}.notification-dropdown{width:280px;right:-1rem}h1{font-size:1.5rem}h2{font-size:1.25rem}.flex-between{flex-direction:column;align-items:flex-start;gap:1rem}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab-button{padding:.75rem 1rem;font-size:.9rem;white-space:nowrap}table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}th,td{padding:.75rem;font-size:.9rem;white-space:nowrap}.sidebar-header{font-size:1.1rem}.card{padding:1rem}.card-footer{flex-wrap:wrap}}@media (max-width: 480px){.app-content{padding:.75rem}.grid-2{grid-template-columns:1fr}.btn{padding:.6rem 1rem;font-size:.9rem}.btn-small{padding:.4rem .75rem;font-size:.85rem}.modal{width:98%;padding:1rem}.modal-header{font-size:1.25rem}}@media print{body{background-color:#fff;color:#000}.sidebar,.app-header,.btn,.notification-bell-container{display:none!important}.app-main{margin-left:0}.app-content{padding:0}.card{page-break-inside:avoid;border:1px solid #ccc}.credentials-card{background-color:#fff;color:#000;border:2px solid black;padding:2rem;max-width:600px;margin:0 auto}.credentials-field{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #ccc}.credentials-label{font-weight:700;min-width:150px}.credentials-value{font-family:monospace;font-size:1.1rem}.print-button,.copy-button{display:none!important}}.lesson-color{width:12px;height:12px;border-radius:50%;flex-shrink:0;display:inline-block}.lesson-blue{background-color:#60a5fa}.lesson-red{background-color:#f87171}.lesson-green{background-color:#4ade80}.lesson-purple{background-color:#a78bfa}.lesson-orange{background-color:#fb923c}.lesson-teal{background-color:#2dd4bf}.lesson-pink{background-color:#f472b6}.lesson-yellow{background-color:#fbbf24}.week-calendar{display:flex;flex-direction:column;gap:14px}.week-calendar-header{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap}.week-calendar-label{font-weight:600;font-size:.95rem;color:var(--text-primary, #1f2937);min-width:140px;text-align:center}.week-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.week-day{background:var(--bg-secondary, #1a1a1a);border:1px solid var(--border-color, #2a2a2a);border-radius:12px;padding:10px;min-height:150px;text-align:left;cursor:pointer;color:inherit;display:flex;flex-direction:column;gap:8px;transition:border-color .12s,transform .08s,background .12s;font:inherit}.week-day:hover{border-color:var(--color-primary, #8b5cf6)}.week-day:active{transform:translateY(1px)}.week-day.today{border-color:var(--color-primary, #8b5cf6);box-shadow:0 0 0 2px #8b5cf640}.week-day.past{opacity:.78}.week-day.selected{background:#8b5cf62e;border-color:var(--color-primary, #8b5cf6)}.week-day.copy-mode{cursor:copy}.week-day-header{display:flex;justify-content:space-between;align-items:baseline;font-size:.8rem}.week-day-name{color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.week-day-date{font-weight:700;font-size:.9rem}.week-day-body{flex:1;font-size:.78rem}.week-day-count{color:var(--color-primary, #8b5cf6);font-weight:600;display:inline-block;margin-bottom:4px}.week-day-slots{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.week-day-slots li{color:var(--text-secondary, #bbb);font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.week-day-slots li.done{opacity:.6;text-decoration:line-through}.week-day-slots li.more{color:var(--text-muted, #888);font-style:italic}.week-day-slots .wd-time{color:var(--text-muted, #888);font-variant-numeric:tabular-nums}.week-day-empty{color:var(--text-muted, #888)}@media (max-width: 820px){.week-calendar-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.week-calendar-grid{grid-template-columns:1fr}}.copy-banner{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:10px 14px;margin:12px 0;background:#8b5cf61f;border:1px solid var(--color-primary, #8b5cf6);border-radius:10px;color:var(--text-primary, #1f2937);font-size:.9rem}.copy-banner-actions{display:flex;gap:8px}.day-slot-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.day-slot-list li{padding:8px 10px;border:1px solid var(--border-color, #2a2a2a);border-radius:8px;display:flex;align-items:center;justify-content:space-between;gap:8px}.day-slot-list li.done{opacity:.65}.day-slot-list .dsl-main{flex:1;display:flex;flex-direction:column;gap:2px}.day-slot-list .dsl-time{color:var(--text-muted, #888);font-size:.8rem;font-variant-numeric:tabular-nums}.day-slot-list .dsl-topic{color:var(--text-muted, #888);font-size:.8rem;font-style:italic}.slot-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:10px;background:transparent;transition:background-color .2s ease,border-color .2s ease}.slot-row-body{flex:1;min-width:0}.slot-row-title{font-weight:600;color:var(--text-primary)}.slot-row-meta{font-size:.85rem;color:var(--text-muted);margin-top:.15rem}.slot-row-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.slot-row.slot-completed{background:#4ade8014;border-color:#4ade8059}.slot-row.slot-completed .slot-row-title{text-decoration:line-through;color:var(--text-muted)}.slot-row.slot-current{background:#f59e0b24;border-color:#f59e0b8c}.slot-row.slot-active{box-shadow:0 0 0 2px var(--color-primary) inset}.slot-pill{font-size:.78rem;font-weight:600;padding:.25rem .6rem;border-radius:999px;background:var(--bg-tertiary);color:var(--text-muted)}.slot-pill-success{background:#22c55e26;color:#059669}.author-badge{display:inline-flex;align-items:center;margin-left:.5rem;font-size:.72rem;font-weight:600;padding:.15rem .55rem;border-radius:999px;line-height:1.4;letter-spacing:.02em;vertical-align:middle;white-space:nowrap}.author-badge-teacher{background:#6b728026;color:#4b5563;border:1px solid rgba(107,114,128,.3)}.author-badge-student{background:#6d28d91f;color:#6d28d9;border:1px solid rgba(109,40,217,.3)}.author-badge-dual{background:#6b72801f;color:#4b5563;border:1px solid rgba(107,114,128,.3)}.author-badge-dual:before{content:"";width:6px;height:6px;border-radius:999px;background:#6d28d9;margin-right:.4rem}.slot-row-title{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem}.active-lesson-badge{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin-bottom:1rem;border:1px solid var(--color-primary, #7C3AED);border-radius:12px;background:#7c3aed14}.active-lesson-badge-icon{font-size:1.5rem;flex-shrink:0}.active-lesson-badge-body{flex:1;min-width:0}.active-lesson-badge-title{font-weight:600;color:var(--text-primary)}.active-lesson-badge-meta{font-size:.85rem;color:var(--text-muted);margin-top:.15rem}.active-lesson-badge-close{background:transparent;border:1px solid var(--border-color);color:var(--text-muted);width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;transition:all .2s ease}.active-lesson-badge-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}
