.erp-shell{display:flex;flex-direction:column;min-height:100vh;background:var(--color-neutral-50)}[data-theme=dark] .erp-shell{background:var(--color-neutral-950)}.sidebar{position:fixed;top:56px;left:0;bottom:0;width:240px;background:var(--color-neutral-0, #ffffff);border-right:1px solid var(--color-neutral-200);padding:1rem 0;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem;z-index:40;transition:transform .2s ease}[data-theme=dark] .sidebar{background:var(--color-neutral-900);border-right-color:var(--color-neutral-800)}.sidebar-section{padding:.5rem 1rem .25rem}.sidebar-section-label{font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-neutral-400);margin-bottom:.25rem}.nav-item{display:flex;align-items:center;gap:.625rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--color-neutral-600);text-decoration:none;border-radius:.375rem;margin:0 .5rem;cursor:pointer;transition:background .15s,color .15s}.nav-item:hover{background:var(--color-neutral-100);color:var(--color-neutral-900)}.nav-item.active{background:var(--color-primary-subtle, #EEF4FF);color:var(--color-primary);font-weight:600}[data-theme=dark] .nav-item{color:var(--color-neutral-400)}[data-theme=dark] .nav-item:hover{background:var(--color-neutral-800);color:var(--color-neutral-100)}[data-theme=dark] .nav-item.active{background:#1a46cc26;color:var(--color-primary-light, #D6E4FF)}.erp-content{margin-left:240px;margin-top:56px;padding:1.5rem;flex:1}.page-header{margin-bottom:1.5rem}.page-title{font-size:1.5rem;font-weight:700;color:var(--color-neutral-900);margin:0 0 .25rem}.page-subtitle{font-size:.875rem;color:var(--color-neutral-500);margin:0}[data-theme=dark] .page-title{color:var(--color-neutral-50)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.timetable-container{background:var(--color-neutral-0, #ffffff);border:1px solid var(--color-neutral-200);border-radius:.75rem;overflow:hidden}[data-theme=dark] .timetable-container{background:var(--color-neutral-900);border-color:var(--color-neutral-800)}.timetable-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-neutral-200)}[data-theme=dark] .timetable-header{border-bottom-color:var(--color-neutral-800)}.timetable-title{font-weight:600;font-size:1rem;color:var(--color-neutral-900)}[data-theme=dark] .timetable-title{color:var(--color-neutral-50)}.timetable-grid{overflow-x:auto}.timetable-table{width:100%;border-collapse:collapse;font-size:.8125rem}.timetable-table th{padding:.625rem .75rem;text-align:center;font-weight:600;color:var(--color-neutral-600);background:var(--color-neutral-50);border-bottom:1px solid var(--color-neutral-200)}[data-theme=dark] .timetable-table th{background:var(--color-neutral-800);color:var(--color-neutral-300);border-bottom-color:var(--color-neutral-700)}.timetable-table td{padding:.5rem .75rem;border:1px solid var(--color-neutral-100);min-width:120px;vertical-align:top}[data-theme=dark] .timetable-table td{border-color:var(--color-neutral-800)}.time-slot-label{font-weight:600;color:var(--color-neutral-500);font-size:.75rem;white-space:nowrap}.session-cell{background:var(--color-primary-subtle, #EEF4FF);border-radius:.375rem;padding:.375rem .5rem}.session-cell .subject{font-weight:600;color:var(--color-primary);font-size:.8125rem}.session-cell .room{font-size:.6875rem;color:var(--color-neutral-500);margin-top:.125rem}.empty-cell{color:var(--color-neutral-300);text-align:center;font-size:.6875rem}.week-selector{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.week-label{font-size:.875rem;font-weight:600;color:var(--color-neutral-700)}[data-theme=dark] .week-label{color:var(--color-neutral-300)}.week-select{padding:.375rem .75rem;border:1px solid var(--color-neutral-300);border-radius:.5rem;font-size:.875rem;background:var(--color-neutral-0, #fff);color:var(--color-neutral-900);cursor:pointer}[data-theme=dark] .week-select{background:var(--color-neutral-800);border-color:var(--color-neutral-700);color:var(--color-neutral-100)}.empty-state{text-align:center;padding:3rem 1.5rem}.empty-state-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.4}.empty-state-text{font-size:.9375rem;color:var(--color-neutral-500)}.auth-guard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;background:var(--color-neutral-50)}[data-theme=dark] .auth-guard-loading{background:var(--color-neutral-950)}.auth-guard-spinner{width:40px;height:40px;border:3px solid var(--color-neutral-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.topbar{position:fixed;top:0;left:0;right:0;height:56px;z-index:50;display:flex;align-items:center;padding:0 1.25rem;gap:.75rem;background:var(--color-neutral-0, #ffffff);border-bottom:1px solid var(--color-neutral-200);background-clip:padding-box}[data-theme=dark] .topbar{background:var(--color-neutral-900);border-bottom-color:var(--color-neutral-800)}.topbar-brand{display:flex;align-items:center;gap:.5rem;text-decoration:none}.topbar-logo{width:30px;height:30px;border-radius:8px;background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.8125rem}.topbar-app-name{font-weight:700;font-size:1rem;color:var(--color-neutral-900)}[data-theme=dark] .topbar-app-name{color:var(--color-neutral-50)}.topbar-spacer{flex:1}.topbar-actions{display:flex;align-items:center;gap:.5rem}.topbar-action-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:.5rem;border:none;background:transparent;color:var(--color-neutral-500);cursor:pointer;transition:background .15s,color .15s}.topbar-action-btn:hover{background:var(--color-neutral-100);color:var(--color-neutral-800)}[data-theme=dark] .topbar-action-btn:hover{background:var(--color-neutral-800);color:var(--color-neutral-200)}.topbar-user{position:relative;display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.25rem .5rem;border-radius:.5rem;transition:background .15s}.topbar-user:hover{background:var(--color-neutral-100)}[data-theme=dark] .topbar-user:hover{background:var(--color-neutral-800)}.topbar-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary);color:#fff;font-weight:700;font-size:.8125rem;display:flex;align-items:center;justify-content:center}.topbar-user-name{font-size:.875rem;font-weight:600;color:var(--color-neutral-700)}[data-theme=dark] .topbar-user-name{color:var(--color-neutral-300)}.topbar-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--color-neutral-0, #ffffff);border:1px solid var(--color-neutral-200);border-radius:.75rem;box-shadow:0 8px 24px #0000001f;overflow:hidden;z-index:100}[data-theme=dark] .topbar-dropdown{background:var(--color-neutral-800);border-color:var(--color-neutral-700)}.topbar-dropdown-header{padding:.75rem 1rem;border-bottom:1px solid var(--color-neutral-100)}[data-theme=dark] .topbar-dropdown-header{border-bottom-color:var(--color-neutral-700)}.topbar-dropdown-item{display:flex;align-items:center;gap:.625rem;padding:.625rem 1rem;font-size:.875rem;color:var(--color-neutral-700);text-decoration:none;cursor:pointer;border:none;background:transparent;width:100%;transition:background .12s}.topbar-dropdown-item:hover{background:var(--color-neutral-50);color:var(--color-neutral-900)}[data-theme=dark] .topbar-dropdown-item{color:var(--color-neutral-300)}[data-theme=dark] .topbar-dropdown-item:hover{background:var(--color-neutral-700);color:var(--color-neutral-100)}.topbar-dropdown-item.danger{color:var(--color-error, #dc2626)}.topbar-dropdown-divider{border:none;border-top:1px solid var(--color-neutral-100);margin:0}[data-theme=dark] .topbar-dropdown-divider{border-top-color:var(--color-neutral-700)}@media(max-width:768px){.sidebar{transform:translate(-100%)}.erp-content{margin-left:0}}
