:root{--bg-primary: #f5f7fa;--bg-secondary: #ffffff;--bg-tertiary: #eef1f6;--bg-card: rgba(255, 255, 255, .85);--bg-card-hover: rgba(240, 243, 250, .95);--bg-glass: rgba(0, 0, 0, .02);--bg-glass-hover: rgba(0, 0, 0, .05);--accent-primary: #5b54e0;--accent-primary-hover: #6c63ff;--accent-primary-glow: rgba(91, 84, 224, .18);--accent-secondary: #00b894;--accent-secondary-glow: rgba(0, 184, 148, .15);--accent-warning: #f0932b;--accent-danger: #e74c3c;--accent-danger-hover: #c0392b;--accent-info: #0abde3;--text-primary: #1e2235;--text-secondary: #5a6078;--text-tertiary: #9298ad;--text-accent: #5b54e0;--border-color: rgba(0, 0, 0, .08);--border-color-hover: rgba(0, 0, 0, .15);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-glow: 0 0 16px var(--accent-primary-glow);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--sidebar-width: 260px;--sidebar-collapsed: 70px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary: #0f1023;--bg-secondary: #161832;--bg-tertiary: #1e2046;--bg-card: rgba(30, 32, 70, .6);--bg-card-hover: rgba(40, 44, 90, .7);--bg-glass: rgba(255, 255, 255, .04);--bg-glass-hover: rgba(255, 255, 255, .08);--accent-primary: #6c63ff;--accent-primary-hover: #7b73ff;--accent-primary-glow: rgba(108, 99, 255, .3);--accent-secondary: #00d4aa;--accent-secondary-glow: rgba(0, 212, 170, .2);--accent-warning: #ffb347;--accent-danger: #ff6b6b;--accent-danger-hover: #ff5252;--accent-info: #4ecdc4;--text-primary: #e8e8f0;--text-secondary: #9396b0;--text-tertiary: #5d6082;--text-accent: #a5a0ff;--border-color: rgba(255, 255, 255, .06);--border-color-hover: rgba(255, 255, 255, .12);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--accent-primary-glow)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow:hidden;height:100vh;transition:background-color .35s ease,color .35s ease}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-color)}.theme-toggle-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:0}.theme-toggle-btn:hover{background:var(--bg-glass-hover);color:var(--accent-primary);border-color:var(--accent-primary-glow);transform:rotate(15deg);box-shadow:var(--shadow-glow)}.theme-toggle-btn svg{flex-shrink:0}.theme-toggle-btn .theme-icon-sun{display:none}.theme-toggle-btn .theme-icon-moon,[data-theme=dark] .theme-toggle-btn .theme-icon-sun{display:block}[data-theme=dark] .theme-toggle-btn .theme-icon-moon{display:none}#app{display:flex;height:100vh;width:100vw;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:all var(--transition-slow);position:relative;z-index:100}.sidebar-header{padding:20px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.sidebar-logo{display:flex;align-items:center;gap:12px}.logo-icon{font-size:28px;filter:drop-shadow(0 0 8px rgba(108,99,255,.4))}.logo-text h1{font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.school-name-display{font-size:.7rem;color:var(--text-tertiary);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.sidebar-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:none}.sidebar-toggle:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.semester-switcher{padding:12px 16px;border-bottom:1px solid var(--border-color)}.semester-switcher label{display:block;font-size:.7rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.semester-switcher select{width:100%;padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-family:inherit;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast);outline:none}.semester-switcher select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-glow)}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;transition:all var(--transition-fast);position:relative}.nav-item:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.nav-item.active{background:linear-gradient(135deg,#6c63ff26,#6c63ff0d);color:var(--accent-primary)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--accent-primary);border-radius:0 4px 4px 0}.nav-item svg{flex-shrink:0;opacity:.7}.nav-item.active svg{opacity:1}.nav-group{margin-top:2px}.nav-group-toggle{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:left;position:relative}.nav-group-toggle:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.nav-group.open>.nav-group-toggle{color:var(--text-primary)}.nav-group.has-active>.nav-group-toggle{color:var(--accent-primary)}.nav-group-toggle .nav-group-icon{flex-shrink:0;opacity:.7}.nav-group.open>.nav-group-toggle .nav-group-icon,.nav-group.has-active>.nav-group-toggle .nav-group-icon{opacity:1}.nav-group-toggle span{flex:1}.nav-group-chevron{flex-shrink:0;opacity:.5;transition:transform var(--transition-normal);margin-left:auto}.nav-group.open>.nav-group-toggle .nav-group-chevron{transform:rotate(180deg)}.nav-group-items{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--transition-normal)}.nav-group.open>.nav-group-items{grid-template-rows:1fr}.nav-group-items-inner{min-height:0;overflow:hidden;display:flex;flex-direction:column;gap:2px}.nav-group.open>.nav-group-items>.nav-group-items-inner{padding-top:2px}.nav-item.nav-item-child{padding-left:44px;font-size:.85rem;padding-top:8px;padding-bottom:8px;opacity:0;transform:translate(-8px);transition:all var(--transition-fast),opacity var(--transition-normal),transform var(--transition-normal)}.nav-group.open .nav-item.nav-item-child{opacity:1;transform:translate(0)}.nav-group.open .nav-item.nav-item-child:nth-child(1){transition-delay:.02s}.nav-group.open .nav-item.nav-item-child:nth-child(2){transition-delay:.04s}.nav-group.open .nav-item.nav-item-child:nth-child(3){transition-delay:.06s}.nav-group.open .nav-item.nav-item-child:nth-child(4){transition-delay:.08s}.nav-group.open .nav-item.nav-item-child:nth-child(5){transition-delay:.1s}.nav-item.nav-item-child.active:before{left:32px}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:28px 32px;background:var(--bg-primary);background-image:radial-gradient(ellipse at 20% 50%,rgba(108,99,255,.03) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(0,212,170,.02) 0%,transparent 50%)}.page-header{margin-bottom:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.page-header h2{font-size:1.6rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px}.page-header h2 .header-icon{font-size:1.4rem}.page-subtitle{font-size:.85rem;color:var(--text-secondary);margin-top:4px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-normal)}.card:hover{border-color:var(--border-color-hover)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-normal);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));opacity:0;transition:opacity var(--transition-normal)}.stat-card:hover:before{opacity:1}.stat-card:hover{transform:translateY(-2px);border-color:var(--border-color-hover);box-shadow:var(--shadow-md)}.stat-icon{font-size:1.8rem;margin-bottom:10px}.stat-value{font-size:1.8rem;font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:4px}.stat-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--radius-sm);border:none;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent-primary);color:#fff;box-shadow:0 2px 8px var(--accent-primary-glow)}.btn-primary:hover{background:var(--accent-primary-hover);box-shadow:0 4px 16px var(--accent-primary-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-color-hover)}.btn-danger{background:#ff6b6b1a;color:var(--accent-danger);border:1px solid rgba(255,107,107,.2)}.btn-danger:hover{background:#ff6b6b33;border-color:#ff6b6b4d}.btn-success{background:#00d4aa1a;color:var(--accent-secondary);border:1px solid rgba(0,212,170,.2)}.btn-success:hover{background:#00d4aa33}.btn-sm{padding:6px 12px;font-size:.78rem}.btn-icon{padding:8px;border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-color);color:var(--text-secondary)}.btn-icon:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.data-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-color)}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table thead{background:var(--bg-tertiary)}.data-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-glass-hover)}.data-table tbody tr:last-child td{border-bottom:none}.table-actions{display:flex;gap:6px}.badge{display:inline-block;padding:3px 10px;border-radius:50px;font-size:.7rem;font-weight:600}.badge-active{background:#00d4aa26;color:var(--accent-secondary);border:1px solid rgba(0,212,170,.3)}.badge-inactive{background:var(--bg-glass);color:var(--text-tertiary);border:1px solid var(--border-color)}.badge-subject{background:#6c63ff1f;color:var(--text-accent);border:1px solid rgba(108,99,255,.2);margin:2px}.badge-type-subject{background:#6c63ff1f;color:var(--text-accent);border:1px solid rgba(108,99,255,.2)}.badge-type-ekskul{background:#00b8941f;color:var(--accent-secondary);border:1px solid rgba(0,184,148,.25)}.badge-type-keagamaan{background:#0abde31f;color:var(--accent-info);border:1px solid rgba(10,189,227,.25)}.badge-type-upacara{background:#f0932b1f;color:var(--accent-warning);border:1px solid rgba(240,147,43,.25)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-tertiary)}.empty-state .empty-icon{font-size:3rem;margin-bottom:12px;opacity:.5}.empty-state p{font-size:.9rem}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-control{width:100%;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-family:inherit;font-size:.9rem;transition:all var(--transition-fast);outline:none}.form-control:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.form-control::placeholder{color:var(--text-tertiary)}textarea.form-control{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.checkbox-group{display:flex;flex-wrap:wrap;gap:8px;max-height:180px;overflow-y:auto;padding:8px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.checkbox-item{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;font-size:.8rem;transition:all var(--transition-fast)}.checkbox-item:hover{background:var(--bg-card-hover)}.checkbox-item input[type=checkbox]{accent-color:var(--accent-primary)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity var(--transition-normal)}.modal-overlay.hidden{opacity:0;pointer-events:none}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:90%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:1.4rem;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.modal-body{padding:20px 24px 24px}.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-md);animation:toastIn .4s cubic-bezier(.34,1.56,.64,1);min-width:280px;max-width:420px}.toast-success{background:linear-gradient(135deg,#00d4aa33,#00d4aa1a);border:1px solid rgba(0,212,170,.3);color:var(--accent-secondary)}.toast-error{background:linear-gradient(135deg,#ff6b6b33,#ff6b6b1a);border:1px solid rgba(255,107,107,.3);color:var(--accent-danger)}.toast-warning{background:linear-gradient(135deg,#ffb34733,#ffb3471a);border:1px solid rgba(255,179,71,.3);color:var(--accent-warning)}.toast-info{background:linear-gradient(135deg,#4ecdc433,#4ecdc41a);border:1px solid rgba(78,205,196,.3);color:var(--accent-info)}@keyframes toastIn{0%{opacity:0;transform:translate(40px) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}.toast-exit{animation:toastOut .3s ease forwards}@keyframes toastOut{to{opacity:0;transform:translate(40px) scale(.9)}}.schedule-builder{display:flex;gap:20px;min-height:60vh}.teacher-panel{width:240px;min-width:240px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px;overflow-y:auto;max-height:70vh;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.teacher-panel-title{font-size:.85rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.teacher-search{width:100%;padding:8px 10px;margin-bottom:12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-family:inherit;font-size:.8rem;outline:none;transition:all var(--transition-fast)}.teacher-search:focus{border-color:var(--accent-primary)}.teacher-card{padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:6px;cursor:grab;transition:all var(--transition-fast);font-size:.82rem}.teacher-card:hover{border-color:var(--accent-primary);background:var(--bg-card-hover);transform:translate(2px)}.teacher-card:active{cursor:grabbing}.teacher-card .teacher-name{font-weight:600;color:var(--text-primary);margin-bottom:2px}.teacher-card .teacher-subject{font-size:.72rem;color:var(--text-tertiary)}.teacher-card.dragging{opacity:.5;border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.schedule-grid-wrap{flex:1;overflow:auto}.schedule-controls{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.class-tabs{display:flex;gap:4px;flex-wrap:wrap}.class-tab{padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:inherit}.class-tab:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.class-tab.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.schedule-grid{display:grid;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-card)}.schedule-grid .grid-header{background:var(--bg-tertiary);padding:10px 12px;font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;text-align:center;border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color)}.schedule-grid .grid-header:last-child{border-right:none}.schedule-grid .grid-time{background:var(--bg-tertiary);padding:8px 10px;font-size:.72rem;color:var(--text-secondary);text-align:center;border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center}.grid-time .slot-label{font-weight:700;color:var(--text-primary);font-size:.78rem}.grid-time .slot-time{font-size:.65rem;color:var(--text-tertiary)}.grid-time.is-break{background:#ffb3470d}.grid-time.is-break .slot-label{color:var(--accent-warning)}.schedule-cell{padding:4px;border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);min-height:54px;transition:all var(--transition-fast);position:relative}.schedule-cell:last-child{border-right:none}.schedule-cell.is-break{background:repeating-linear-gradient(45deg,transparent,transparent 5px,rgba(255,179,71,.03) 5px,rgba(255,179,71,.03) 10px);pointer-events:none}.schedule-cell.drag-over{background:#6c63ff1a;border-color:var(--accent-primary);box-shadow:inset 0 0 0 2px var(--accent-primary-glow)}.schedule-cell.conflict{background:#ff6b6b14;box-shadow:inset 0 0 0 2px #ff6b6b33}.schedule-entry{padding:6px 8px;background:linear-gradient(135deg,#6c63ff26,#6c63ff14);border:1px solid rgba(108,99,255,.25);border-radius:6px;font-size:.72rem;cursor:pointer;height:100%;display:flex;flex-direction:column;justify-content:center;transition:all var(--transition-fast);position:relative}.schedule-entry:hover{border-color:var(--accent-primary);background:linear-gradient(135deg,#6c63ff33,#6c63ff1f)}.schedule-entry.type-ekskul{background:linear-gradient(135deg,#00b89426,#00b8940f);border-color:#00b8944d}.schedule-entry.type-ekskul:hover{background:linear-gradient(135deg,#00b89438,#00b8941a);border-color:var(--accent-secondary)}.schedule-entry.type-ekskul .entry-subject{color:var(--accent-secondary)}.schedule-entry.type-keagamaan{background:linear-gradient(135deg,#0abde326,#0abde30f);border-color:#0abde34d}.schedule-entry.type-keagamaan:hover{background:linear-gradient(135deg,#0abde338,#0abde31a);border-color:var(--accent-info)}.schedule-entry.type-keagamaan .entry-subject{color:var(--accent-info)}.schedule-entry.type-upacara{background:linear-gradient(135deg,#f0932b26,#f0932b0f);border-color:#f0932b4d}.schedule-entry.type-upacara:hover{background:linear-gradient(135deg,#f0932b38,#f0932b1a);border-color:var(--accent-warning)}.schedule-entry.type-upacara .entry-subject{color:var(--accent-warning)}.schedule-entry .entry-teacher{font-weight:600;color:var(--text-primary);font-size:.75rem;line-height:1.2}.schedule-entry .entry-subject{color:var(--text-accent);font-size:.68rem}.schedule-entry .entry-remove{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:var(--accent-danger);color:#fff;border:none;font-size:10px;cursor:pointer;display:none;align-items:center;justify-content:center;line-height:1}.schedule-entry:hover .entry-remove{display:flex}.school-form{max-width:700px}.logo-upload{display:flex;align-items:center;gap:20px;margin-bottom:20px}.logo-preview{width:80px;height:80px;border-radius:var(--radius-md);border:2px dashed var(--border-color);display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg-tertiary);cursor:pointer;transition:all var(--transition-fast)}.logo-preview:hover{border-color:var(--accent-primary)}.logo-preview img{width:100%;height:100%;object-fit:contain}.logo-preview .logo-placeholder{font-size:2rem;opacity:.3}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-family:inherit;font-size:.82rem;font-weight:500;cursor:pointer;transition:all var(--transition-normal);text-decoration:none}.quick-action-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary);border-color:var(--border-color-hover);transform:translateY(-2px)}.quick-action-btn .qa-icon{font-size:1.4rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@media(max-width:768px){.sidebar{position:fixed;left:-100%;transition:left var(--transition-slow)}.sidebar.open{left:0}.sidebar-toggle{display:block}.main-content{padding:16px}.schedule-builder{flex-direction:column}.teacher-panel{width:100%;min-width:100%;max-height:200px}.form-row{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:fadeIn .3s ease}.kbm-profiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.kbm-profile-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 16px;cursor:pointer;transition:all var(--transition-fast)}.kbm-profile-card:hover{border-color:var(--border-color-hover);background:var(--bg-card-hover)}.kbm-profile-card.active{border-color:var(--accent-primary);background:linear-gradient(135deg,#6c63ff1f,#6c63ff0a);box-shadow:0 0 0 1px var(--accent-primary-glow)}.profile-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:.9rem}.profile-card-days{font-size:.75rem;color:var(--text-tertiary)}.kbm-profile-card.active .profile-card-days{color:var(--text-accent)}::selection{background:var(--accent-primary);color:#fff}.backup-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:20px}.backup-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 28px}.backup-card-icon{font-size:2.8rem;margin-bottom:12px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.1))}.backup-card-title{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.backup-card-desc{font-size:.85rem;color:var(--text-secondary);margin-bottom:20px;max-width:340px;line-height:1.5}.backup-stats{width:100%;max-width:300px;margin-bottom:24px}.backup-stat-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border-color);font-size:.82rem}.backup-stat-row span{color:var(--text-secondary)}.backup-stat-row strong{color:var(--text-primary);font-weight:600}.backup-btn{padding:12px 28px;font-size:.9rem}.restore-drop-zone{width:100%;max-width:360px;padding:36px 24px;border:2px dashed var(--border-color);border-radius:var(--radius-lg);background:var(--bg-glass);cursor:pointer;transition:all var(--transition-normal);margin-bottom:16px}.restore-drop-zone:hover{border-color:var(--accent-primary);background:var(--accent-primary-glow)}.restore-drop-zone.drag-active{border-color:var(--accent-primary);background:var(--accent-primary-glow);transform:scale(1.02);box-shadow:var(--shadow-glow)}.drop-zone-icon{font-size:2rem;margin-bottom:8px;opacity:.6}.restore-drop-zone p{font-size:.82rem;color:var(--text-tertiary);line-height:1.6}.restore-preview{width:100%;max-width:360px}.restore-info-grid{text-align:left;margin-bottom:16px}.restore-warning{background:#f0932b1a;border:1px solid rgba(240,147,43,.25);border-radius:var(--radius-sm);padding:10px 14px;font-size:.8rem;color:var(--accent-warning);margin-bottom:16px;text-align:left}.restore-actions{display:flex;gap:10px;justify-content:center}.day-picker{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.subject-card{padding:8px 10px;margin-bottom:6px;border-radius:var(--radius-sm);cursor:grab;transition:all var(--transition-fast);border:1px solid transparent}.subject-card:hover{transform:translate(2px);box-shadow:var(--shadow-sm)}.subject-card.dragging{opacity:.5}.subject-card-name{font-weight:600;font-size:.82rem;color:var(--text-primary)}.subject-card-type{font-size:.68rem;text-transform:capitalize;opacity:.7}.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.report-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 24px}.report-card-icon{font-size:2.5rem;margin-bottom:10px}.report-card-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}.report-card-desc{font-size:.8rem;color:var(--text-secondary);margin-bottom:18px;line-height:1.5;max-width:320px}.report-form{width:100%;max-width:320px}.report-form .form-group{text-align:left}.report-btn{width:100%;margin-top:12px}.report-semester-info{display:flex;flex-direction:column;gap:2px;padding:10px 18px;background:var(--bg-glass);border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary);margin-bottom:16px}.week-nav{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.week-label{font-size:.88rem;font-weight:600;color:var(--text-primary);padding:0 8px}.att-s-belum{background:#94a3b81a;color:#94a3b8;border:1px solid rgba(148,163,184,.25)}.att-slot-row.att-unmarked{border-left:3px dashed rgba(148,163,184,.4)}.day-tabs{display:flex;gap:4px}.day-tab{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-glass);color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:inherit}.day-tab:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.day-tab.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.day-date{font-size:.85rem;color:var(--text-secondary);font-weight:500}.dashboard-bottom-row{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:start}.dashboard-two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.dashboard-right-col{display:flex;flex-direction:column;gap:20px}.mini-schedule-table th,.mini-schedule-table td{text-align:center;padding:6px 8px;font-size:.75rem}.mini-schedule-table .slot-no{font-weight:700;color:var(--text-primary);font-size:.78rem}.mini-schedule-table .slot-time{font-size:.68rem;color:var(--text-tertiary);white-space:nowrap}.mini-schedule-table .empty-slot{color:var(--text-tertiary)}.mini-schedule-table .break-row{background:#ffb3470a}.mini-schedule-table .break-cell{background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(255,179,71,.03) 4px,rgba(255,179,71,.03) 8px)}.mini-entry{padding:4px 6px;border-radius:4px;font-size:.72rem;font-weight:600;line-height:1.3}.mini-entry small{font-weight:400;font-size:.65rem;opacity:.8}.att-summary{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.att-summary-item{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600}.att-s-count{font-size:1.2rem;font-weight:800}.att-s-label{font-size:.75rem;font-weight:500}.att-s-hadir{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2)}.att-s-terlambat{background:#eab3081a;color:#ca8a04;border:1px solid rgba(234,179,8,.2)}.att-s-sakit{background:#f973161a;color:#f97316;border:1px solid rgba(249,115,22,.2)}.att-s-izin{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.att-s-alfa{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.att-list{max-height:60vh;overflow-y:auto}.att-teacher-card{border-bottom:1px solid var(--border-color);padding:12px;transition:background var(--transition-fast)}.att-teacher-card:last-child{border-bottom:none}.att-teacher-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.att-teacher-info{flex:1}.att-name{font-weight:700;font-size:.88rem;color:var(--text-primary)}.att-subjects{font-size:.72rem;color:var(--text-tertiary)}.mark-all-wrap{position:relative}.mark-all-toggle{font-size:.72rem!important;padding:4px 10px!important}.mark-all-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:50;overflow:hidden;min-width:140px}.mark-all-option{display:block;width:100%;padding:8px 14px;border:none;background:none;color:var(--text-primary);font-size:.8rem;font-family:inherit;text-align:left;cursor:pointer;transition:background var(--transition-fast)}.mark-all-option:hover{background:var(--bg-glass-hover)}.att-slots{display:flex;flex-direction:column;gap:4px}.att-slot-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);background:var(--bg-glass);transition:background var(--transition-fast)}.att-slot-row:hover{background:var(--bg-glass-hover)}.att-slot-info{flex:1;display:flex;align-items:center;gap:8px;min-width:0;font-size:.78rem}.att-slot-label{font-weight:600;color:var(--text-primary);white-space:nowrap}.att-slot-time{color:var(--text-tertiary);font-size:.7rem;white-space:nowrap}.att-slot-detail{color:var(--text-secondary);font-size:.72rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.att-status{display:flex;gap:3px}.att-btn{width:30px;height:30px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-glass);cursor:pointer;font-size:.8rem;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;padding:0}.att-btn:hover{transform:scale(1.1)}.att-btn.att-hadir.active{background:#22c55e26;border-color:#22c55e66;box-shadow:0 0 6px #22c55e33}.att-btn.att-terlambat.active{background:#eab30826;border-color:#eab30866;box-shadow:0 0 6px #eab30833}.att-btn.att-sakit.active{background:#f9731626;border-color:#f9731666;box-shadow:0 0 6px #f9731633}.att-btn.att-izin.active{background:#3b82f626;border-color:#3b82f666;box-shadow:0 0 6px #3b82f633}.att-btn.att-alfa.active{background:#ef444426;border-color:#ef444466;box-shadow:0 0 6px #ef444433}.att-sub-options{width:100%;padding:4px 0 2px 8px;display:flex;gap:14px;flex-wrap:wrap;animation:fadeIn .2s ease}.att-checkbox{display:flex;align-items:center;gap:5px;font-size:.75rem;color:var(--text-secondary);cursor:pointer}.att-checkbox input[type=checkbox]{accent-color:var(--accent-primary)}.att-notes{min-height:80px;resize:vertical}@media(max-width:900px){.dashboard-two-col,.dashboard-bottom-row{grid-template-columns:1fr}}.rpt-filter-bar{margin-bottom:20px;padding:16px 20px}.rpt-filter-row{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap}.rpt-filter-item{display:flex;flex-direction:column;gap:4px}.rpt-filter-item label{font-size:.75rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.rpt-filter-item input{width:170px}.rpt-period-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:16px;font-weight:500}.rpt-stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:20px}.rpt-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:18px;text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:relative;overflow:hidden;transition:all var(--transition-normal)}.rpt-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;opacity:0;transition:opacity var(--transition-normal)}.rpt-stat-card:hover:before{opacity:1}.rpt-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.rpt-stat-primary:before{background:var(--accent-primary)}.rpt-stat-success:before{background:#22c55e}.rpt-stat-info:before{background:var(--accent-info)}.rpt-stat-warning:before{background:#ca8a04}.rpt-stat-danger:before{background:#ef4444}.rpt-stat-icon{font-size:1.6rem;margin-bottom:6px}.rpt-stat-value{font-size:1.8rem;font-weight:800;color:var(--text-primary);line-height:1;margin-bottom:4px}.rpt-stat-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.rpt-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.rpt-section{padding:20px;margin-bottom:16px}.rpt-insights{display:flex;flex-direction:column;gap:12px}.rpt-dist-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:14px}.rpt-dist-bar{display:flex;height:28px;border-radius:50px;overflow:hidden;background:var(--bg-tertiary);margin-bottom:12px}.rpt-dist-seg{transition:width .6s cubic-bezier(.4,0,.2,1);min-width:2px}.rpt-seg-H{background:#22c55e}.rpt-seg-T{background:#eab308}.rpt-seg-S{background:#f97316}.rpt-seg-I{background:#3b82f6}.rpt-seg-A{background:#ef4444}.rpt-dist-legend{display:flex;flex-wrap:wrap;gap:12px}.rpt-leg{display:flex;align-items:center;gap:5px;font-size:.75rem;color:var(--text-secondary)}.rpt-leg-dot{width:10px;height:10px;border-radius:3px;display:inline-block}.rpt-dist-empty{text-align:center;padding:32px 16px;color:var(--text-tertiary);font-size:.9rem}.rpt-chart-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:14px}.rpt-bar-chart{display:flex;flex-direction:column;gap:6px}.rpt-bar-row{display:flex;align-items:center;gap:10px}.rpt-bar-name{width:130px;min-width:130px;font-size:.78rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right}.rpt-bar-track{flex:1;height:20px;background:var(--bg-tertiary);border-radius:50px;overflow:hidden}.rpt-bar-fill{height:100%;border-radius:50px;transition:width .8s cubic-bezier(.4,0,.2,1)}.rpt-bar-good{background:linear-gradient(90deg,#22c55e,#4ade80)}.rpt-bar-warn{background:linear-gradient(90deg,#eab308,#facc15)}.rpt-bar-bad{background:linear-gradient(90deg,#ef4444,#f87171)}.rpt-bar-pct{width:40px;font-size:.78rem;font-weight:700;color:var(--text-primary)}.rpt-ranking-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:14px}.rpt-tbl-center{text-align:center}.rpt-c-H{color:#22c55e}.rpt-c-T{color:#ca8a04}.rpt-c-S{color:#f97316}.rpt-c-I{color:#3b82f6}.rpt-c-A{color:#ef4444}.rpt-badge{display:inline-block;padding:2px 10px;border-radius:50px;font-size:.7rem;font-weight:600;white-space:nowrap}.rpt-badge-good{background:#22c55e1f;color:#22c55e;border:1px solid rgba(34,197,94,.25)}.rpt-badge-warn{background:#eab3081f;color:#ca8a04;border:1px solid rgba(234,179,8,.25)}.rpt-badge-bad{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.rpt-late-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.rpt-late-title{font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:10px}.rpt-late-list{display:flex;flex-direction:column;gap:6px}.rpt-late-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--radius-sm);background:var(--bg-glass)}.rpt-late-item:hover{background:var(--bg-glass-hover)}.rpt-late-rank{width:22px;height:22px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--text-secondary)}.rpt-late-name{flex:1;font-size:.82rem;color:var(--text-primary)}.rpt-late-count{font-size:.75rem;font-weight:600;color:var(--accent-warning)}.rpt-absent-card .rpt-late-count{color:var(--accent-danger)}.rpt-no-issues{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;text-align:center;font-size:1rem;color:var(--text-secondary)}.rpt-export-panel{margin-top:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden}.rpt-export-header{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-primary);transition:background var(--transition-fast)}.rpt-export-header:hover{background:var(--bg-glass-hover)}.rpt-export-chevron{transition:transform var(--transition-normal);opacity:.5}.rpt-export-header.open .rpt-export-chevron{transform:rotate(180deg)}.rpt-export-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--transition-normal)}.rpt-export-body.open{grid-template-rows:1fr}.rpt-export-grid{min-height:0;overflow:hidden;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;padding:0 20px 20px}.rpt-export-body:not(.open) .rpt-export-grid{padding:0}.rpt-export-card{padding:16px;border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}.rpt-export-card h4{font-size:.88rem;font-weight:700;color:var(--text-primary);margin:0}.rpt-export-card p{font-size:.78rem;color:var(--text-secondary);margin:0;line-height:1.4}.rpt-export-icon{font-size:1.4rem}.rpt-export-new{border-color:var(--accent-primary-glow);background:linear-gradient(135deg,#6c63ff0d,#6c63ff05)}.rpt-new-tag{font-size:.6rem;padding:2px 6px;border-radius:4px;background:var(--accent-primary);color:#fff;vertical-align:middle;letter-spacing:.5px}.rpt-semester-badge{font-size:.8rem;color:var(--text-secondary);padding:6px 10px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.rpt-loading{text-align:center;padding:40px;color:var(--text-tertiary);font-size:.9rem}@media(max-width:900px){.rpt-two-col{grid-template-columns:1fr}.rpt-filter-row{flex-direction:column;align-items:stretch}.rpt-filter-item input{width:100%}.rpt-bar-name{width:80px;min-width:80px}}.hidden{display:none!important}
