:root{--primary:#f59e0b;--primary-hover:#fbbf24;--primary-dark:#d97706;--primary-glow:#f59e0b33;--primary-ghost:#f59e0b14;--bg:#0c1222;--sidebar:#0f1629;--surface:#141c30;--surface-hover:#1a2540;--surface-active:#1f2d4d;--border:#1e2a45;--border-light:#263354;--text:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-on-primary:#0c1222;--success:#22c55e;--success-bg:#22c55e1f;--warning:#f59e0b;--warning-bg:#f59e0b1f;--danger:#ef4444;--danger-bg:#ef44441f;--info:#3b82f6;--info-bg:#3b82f61f;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000040;--shadow-lg:0 8px 25px #00000059;--shadow-glow:0 0 20px #f59e0b26;--sidebar-width:280px;--sidebar-collapsed:72px;--topnav-height:72px;--content-max-width:1600px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--topnav-bg:#0c1222cc;--sidebar-end:#0a1020;--dashboard-orb-opacity:.12}:root[data-theme=light]{--bg:#f8fafc;--sidebar:#e2e8f0;--sidebar-end:#cbd5e1;--surface:#fff;--surface-hover:#cbd5e1;--surface-active:#94a3b8;--border:#cbd5e1;--border-light:#e2e8f0;--text:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--text-on-primary:#fff;--success-bg:#f0fdf4;--warning-bg:#fdfbeb;--danger-bg:#fef2f2;--info-bg:#eff6ff;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 8px 25px #00000014;--shadow-glow:0 0 20px #f59e0b0d;--topnav-bg:#e2e8f0d9;--dashboard-orb-opacity:.06}body{transition:background-color .3s,color .3s}.sidebar,.topnav,.dashboard-card,.stat-card-inner,.table,th,td,input,select,textarea,button{transition:background-color .3s,border-color .3s,color .3s,box-shadow .3s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);background-color:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:var(--primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-hover)}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{color:var(--text);font-weight:700;line-height:1.2}h1{letter-spacing:-.02em;font-size:2.5rem}h2{letter-spacing:-.01em;font-size:2rem}h3{font-size:1.5rem;font-weight:600}h4{font-size:1.25rem;font-weight:600}h5{font-size:1rem;font-weight:600}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-info{color:var(--info)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);font-family:var(--font-family);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;padding:10px 20px;font-size:.875rem;font-weight:600;line-height:1.4;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--text-on-primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{color:var(--text);border:1px solid var(--border);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-light)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);background:0 0;padding:8px 12px}.btn-ghost:hover:not(:disabled){color:var(--text);background:var(--surface-hover)}.btn-sm{padding:6px 14px;font-size:.8125rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{border-radius:var(--radius-sm);width:40px;height:40px;padding:0}.btn-icon.btn-sm{width:32px;height:32px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.card:hover{border-color:var(--border-light)}.card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--text);font-size:1rem;font-weight:600}.card-subtitle{color:var(--text-muted);margin-top:2px;font-size:.8125rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal);position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--primary);opacity:0;height:3px;transition:opacity var(--transition-normal);position:absolute;top:0;left:0;right:0}.stat-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-sm);font-size:.8125rem}.stat-value{color:var(--text);font-size:2rem;font-weight:700;line-height:1}.stat-change{margin-top:var(--space-sm);border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-size:.8125rem;font-weight:600;display:inline-flex}.stat-change.positive{color:var(--success);background:var(--success-bg)}.stat-change.negative{color:var(--danger);background:var(--danger-bg)}.stat-icon{border-radius:var(--radius-md);width:48px;height:48px;margin-bottom:var(--space-md);justify-content:center;align-items:center;font-size:1.25rem;display:flex}.form-group{margin-bottom:var(--space-lg)}.form-label{color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:.875rem;font-weight:500;display:block}.form-input,.form-select,.form-textarea{width:100%;font-family:var(--font-family);color:var(--text);background:var(--sidebar);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast);outline:none;padding:10px 14px;font-size:.875rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23737373' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-select option{background:var(--surface);color:var(--text)}.form-textarea{resize:vertical;min-height:100px}.form-hint{color:var(--text-muted);margin-top:4px;font-size:.75rem}.form-error{color:var(--danger);margin-top:4px;font-size:.75rem}.form-row{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.table-container{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);width:100%;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table thead{background:var(--sidebar);z-index:1;position:sticky;top:0}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 16px;font-size:.75rem;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;padding:12px 16px}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--surface-hover)}.data-table tbody tr:last-child td{border-bottom:none}.badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-neutral{color:var(--text-secondary);background:#a3a3a31f}.badge-primary{background:var(--primary-ghost);color:var(--primary)}.badge-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.badge-dot.success{background:var(--success)}.badge-dot.warning{background:var(--warning)}.badge-dot.danger{background:var(--danger)}.badge-dot.info{background:var(--info)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--space-md);animation:fadeIn var(--transition-fast) ease;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:90vh;animation:slideUp var(--transition-normal) ease;overflow-y:auto}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:1.125rem;font-weight:700}.modal-body{padding:var(--space-lg)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);display:flex}.search-bar{align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.search-input-wrapper{flex:1;min-width:240px;position:relative}.search-input-wrapper .search-icon{color:var(--text-muted);pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;top:0;bottom:0;left:14px}.search-input-wrapper .form-input{padding-left:40px}.empty-state{padding:var(--space-3xl) var(--space-lg);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-md);opacity:.3;font-size:3rem}.empty-state-title{color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:1.125rem;font-weight:600}.empty-state-desc{color:var(--text-muted);max-width:360px;font-size:.875rem}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.spinner-lg{border-width:4px;width:40px;height:40px}.loading-overlay{justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;min-height:200px;display:flex}.loading-text{color:var(--text-muted);font-size:.875rem}.toast-container{top:var(--space-lg);right:var(--space-lg);z-index:9999;gap:var(--space-sm);flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-md);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);min-width:300px;max-width:440px;animation:slideInRight var(--transition-normal) ease;padding:14px 20px;display:flex}.toast.toast-success{border-left:3px solid var(--success)}.toast.toast-warning{border-left:3px solid var(--warning)}.toast.toast-danger{border-left:3px solid var(--danger)}.toast.toast-info{border-left:3px solid var(--info)}.toast-message{color:var(--text);flex:1;font-size:.875rem}.toast-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1rem}.pagination{justify-content:center;align-items:center;gap:var(--space-xs);margin-top:var(--space-lg);display:flex}.pagination-btn{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;font-size:.875rem;display:flex}.pagination-btn:hover{background:var(--surface-hover);color:var(--text)}.pagination-btn.active{background:var(--primary);color:var(--text-on-primary);font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{to{transform:translate(100%)}}.animate-fade-in{animation:fadeIn var(--transition-normal) ease}.animate-slide-up{animation:slideUp var(--transition-normal) ease}.skeleton{background:linear-gradient(90deg, var(--surface-hover) 25%, var(--border) 37%, var(--surface-hover) 63%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{width:80%;height:14px;margin-bottom:8px}.skeleton-text:last-child{width:60%}.skeleton-circle{border-radius:50%;width:48px;height:48px}.skeleton-card{height:120px}.page-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.page-title{letter-spacing:-.01em;font-size:1.75rem;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:2px;font-size:.875rem}.page-actions{align-items:center;gap:var(--space-sm);display:flex}.grid-stats{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));display:grid}.grid-2{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.tabs{border-bottom:1px solid var(--border);margin-bottom:var(--space-lg);gap:2px;display:flex;overflow-x:auto}.tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 18px;font-size:.875rem;font-weight:500}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.confirm-dialog{text-align:center}.confirm-dialog-icon{width:64px;height:64px;margin:0 auto var(--space-md);background:var(--danger-bg);border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;display:flex}.confirm-dialog-title{margin-bottom:var(--space-sm);font-size:1.25rem;font-weight:700}.confirm-dialog-message{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:.875rem}@media (width<=1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){:root{--sidebar-width:100%}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.grid-2,.grid-3{grid-template-columns:1fr}.grid-stats{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;align-items:flex-start}.modal{max-width:100%;margin:var(--space-md)}.search-bar{flex-direction:column;align-items:stretch}.toast-container{left:var(--space-md);right:var(--space-md)}.toast{min-width:auto}}@media (width<=480px){.grid-stats{grid-template-columns:1fr}}.skeleton-loader-wrapper{gap:var(--space-sm);padding:var(--space-md) 0;flex-direction:column;width:100%;display:flex}.skeleton-row{align-items:center;gap:var(--space-md);padding:12px var(--space-md);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);box-sizing:border-box;height:52px;display:flex;position:relative;overflow:hidden}.skeleton-item{border-radius:var(--radius-xs);background:#ffffff0f;height:14px;position:relative;overflow:hidden}.skeleton-row:after,.skeleton-item:after{content:"";background-image:linear-gradient(90deg,#fff0 0%,#ffffff0a 20%,#ffffff14 60%,#fff0 100%);animation:1.5s infinite shimmer;position:absolute;inset:0;transform:translate(-100%)}.d-flex{display:flex!important}.flex-column{flex-direction:column!important}.justify-content-between{justify-content:space-between!important}.justify-content-end{justify-content:flex-end!important}.align-items-center{align-items:center!important}.align-items-start{align-items:flex-start!important}.flex-wrap{flex-wrap:wrap!important}.gap-1{gap:var(--space-xs)!important}.gap-2{gap:var(--space-sm)!important}.gap-3{gap:var(--space-md)!important}.row{flex-wrap:wrap;margin-left:-12px;margin-right:-12px;display:flex}.row>*{box-sizing:border-box;flex-shrink:0;width:100%;max-width:100%;padding-left:12px;padding-right:12px}.g-3{margin-top:-8px;margin-bottom:-8px}.g-3>*{padding-top:8px;padding-bottom:8px}@media (width>=768px){.col-md-3{flex:none;width:25%}.col-md-4{flex:none;width:33.3333%}.col-md-5{flex:none;width:41.6667%}.col-md-6{flex:none;width:50%}.col-md-7{flex:none;width:58.3333%}.col-md-8{flex:none;width:66.6667%}.col-md-9{flex:none;width:75%}.col-md-10{flex:none;width:83.3333%}.col-md-12{flex:none;width:100%}}.mb-1{margin-bottom:4px!important}.mb-2{margin-bottom:8px!important}.mb-3{margin-bottom:16px!important}.mb-4{margin-bottom:24px!important}.mt-1{margin-top:4px!important}.mt-2{margin-top:8px!important}.mt-3{margin-top:16px!important}.mt-4{margin-top:24px!important}.me-1{margin-right:4px!important}.me-2{margin-right:8px!important}.w-100{width:100%!important}.text-end{text-align:right!important}.text-center{text-align:center!important}.animate-fade-in>.d-flex.justify-content-between.align-items-center.mb-4{width:100%;gap:var(--space-xl)!important}.animate-fade-in>.d-flex.justify-content-between.align-items-center.mb-4>div:first-child{flex:auto;max-width:72%!important}.animate-fade-in>.d-flex.justify-content-between.align-items-center.mb-4>button,.animate-fade-in>.d-flex.justify-content-between.align-items-center.mb-4>a{flex-shrink:0!important}@media (width<=768px){.animate-fade-in>.d-flex.justify-content-between.align-items-center.mb-4{align-items:flex-start!important;gap:var(--space-md)!important;flex-direction:column!important}.animate-fade-in>.d-flex.justify-content-between.align-items-center.mb-4>div:first-child{max-width:100%!important}.animate-fade-in>.d-flex.justify-content-between.align-items-center.mb-4>button,.animate-fade-in>.d-flex.justify-content-between.align-items-center.mb-4>a{width:100%!important}}.sidebar-img-icon{object-fit:contain;vertical-align:middle;filter:invert(.9)brightness(1.2);width:18px;height:18px;transition:transform var(--transition-fast), filter var(--transition-fast)}.nav-item:hover .sidebar-img-icon,.nav-item.active .sidebar-img-icon{transform:scale(1.1);filter:invert()brightness(1.5)!important}:root[data-theme=light] .sidebar-img-icon{filter:brightness(.2)contrast(1.5)!important}:root[data-theme=light] .nav-item.active .sidebar-img-icon,:root[data-theme=light] .nav-item:hover .sidebar-img-icon{filter:brightness(0)contrast(2)!important}.dashboard-img-icon{object-fit:contain;vertical-align:middle;filter:invert(.9)brightness(1.2);width:22px;height:22px;transition:transform var(--transition-fast), filter var(--transition-fast)}.stat-card:hover .dashboard-img-icon{transform:scale(1.1);filter:invert()brightness(1.5)!important}:root[data-theme=light] .dashboard-img-icon{filter:brightness(.2)contrast(1.5)!important}:root[data-theme=light] .stat-card:hover .dashboard-img-icon{filter:brightness(0)contrast(2)!important}.currency-img-icon{object-fit:contain;vertical-align:middle;filter:invert(.9)brightness(1.2);width:20px;height:20px;transition:transform var(--transition-fast), filter var(--transition-fast)}.currency-img-icon.text-muted-icon{filter:invert(.6)brightness()}.feature-icon .currency-img-icon{width:16px;height:16px}:root[data-theme=light] .currency-img-icon{filter:brightness(.2)contrast(1.5)!important}:root[data-theme=light] .currency-img-icon.text-muted-icon{filter:brightness(.6)contrast()!important}.view-switcher-container{background:var(--sidebar);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-md);padding:4px;display:inline-flex}.view-btn{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:6px 14px;font-size:.8125rem;font-weight:600;display:inline-flex}.view-btn:hover{color:var(--text)}.view-btn.active{background:var(--surface-hover);color:var(--primary);box-shadow:var(--shadow-sm)}.stats-row{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.mini-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);align-items:center;gap:var(--space-md);transition:all var(--transition-normal);display:flex}.mini-stat-card:hover{border-color:var(--border-light);transform:translateY(-1px)}.mini-stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.15rem;display:flex}.mini-stat-icon.blue-bg{color:#3b82f6;background:#3b82f61a}.mini-stat-icon.green-bg{color:#22c55e;background:#22c55e1a}.mini-stat-icon.amber-bg{color:#f59e0b;background:#f59e0b1a}.mini-stat-icon.purple-bg{color:#a855f7;background:#a855f71a}.mini-stat-info{flex-direction:column;display:flex}.mini-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.mini-stat-value{color:var(--text);font-size:1.15rem;font-weight:700}.calendar-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);overflow-x:auto}.calendar-nav-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.calendar-week-label{color:var(--text);font-size:1.15rem;font-weight:700}.calendar-nav-buttons{align-items:center;gap:var(--space-xs);display:flex}.calendar-grid{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--sidebar);grid-template-columns:80px repeat(7,1fr);min-width:800px;display:grid;overflow:hidden}.calendar-header-cell{background:var(--surface);border-bottom:2px solid var(--border);border-right:1px solid var(--border);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:12px 6px;display:flex}.calendar-header-cell:last-child{border-right:none}.calendar-day-name{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:.75rem;font-weight:700}.calendar-day-date{color:var(--text);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;margin-top:2px;font-size:1.1rem;font-weight:700;display:flex}.calendar-header-cell.is-today .calendar-day-date{background:var(--primary);color:var(--text-on-primary);box-shadow:var(--shadow-glow)}.calendar-time-col{background:var(--surface);border-right:2px solid var(--border);border-bottom:1px solid var(--border);color:var(--text-secondary);padding:16px var(--space-xs);justify-content:center;align-items:center;font-size:.8125rem;font-weight:700;display:flex}.calendar-slot-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);min-height:72px;padding:var(--space-xs);transition:all var(--transition-fast);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;display:flex;position:relative}.calendar-slot-cell:nth-child(8n){border-right:none}.slot-level-empty{background:#ffffff04}.slot-level-empty:hover{background:var(--surface-hover)}.slot-level-low{background:#22c55e14;border-left:3px solid #22c55e!important}.slot-level-low:hover{background:#22c55e26}.slot-level-low .slot-indicator{color:#22c55e}.slot-level-medium{background:#f59e0b14;border-left:3px solid #f59e0b!important}.slot-level-medium:hover{background:#f59e0b26}.slot-level-medium .slot-indicator{color:#f59e0b}.slot-level-high{background:#ef444414;border-left:3px solid #ef4444!important}.slot-level-high:hover{background:#ef444426}.slot-level-high .slot-indicator{color:#ef4444}.slot-cell-content{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.slot-indicator{align-items:center;gap:6px;font-size:.8125rem;font-weight:700;display:flex}.slot-dot{background:currentColor;border-radius:50%;width:8px;height:8px;box-shadow:0 0 6px}.slot-sub-text{color:var(--text-muted);margin-top:4px;font-size:.6875rem}.slot-add-btn{opacity:0;transition:all var(--transition-fast);border-radius:var(--radius-xs);align-items:center;gap:2px;padding:4px 8px;font-size:.75rem;display:inline-flex;transform:scale(.9)}.calendar-slot-cell:hover .slot-add-btn{opacity:1;transform:scale(1)}.calendar-slot-cell[title]:hover:after{content:attr(title);z-index:120;border:1px solid var(--border-light);color:var(--text);border-radius:var(--radius-sm);white-space:pre-line;width:180px;box-shadow:var(--shadow-lg);pointer-events:none;text-align:left;background:#090d16;padding:8px 12px;font-size:.75rem;line-height:1.4;position:absolute;bottom:105%;left:50%;transform:translate(-50%)}.slot-detail-item{background:var(--sidebar);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm);transition:all var(--transition-fast)}.slot-detail-item:last-child{margin-bottom:0}.slot-detail-item:hover{border-color:var(--border-light)}.slot-detail-header{margin-bottom:var(--space-xs);justify-content:space-between;align-items:flex-start;display:flex}.slot-detail-student{color:var(--text);font-size:.9375rem;font-weight:700}.slot-detail-meta{color:var(--text-secondary);flex-direction:column;gap:4px;font-size:.8125rem;display:flex}.meta-row{align-items:center;gap:var(--space-sm);display:flex}.meta-icon{color:var(--text-muted);text-align:center;width:14px}.slot-detail-actions{justify-content:flex-end;gap:var(--space-xs);margin-top:var(--space-sm);border-top:1px solid var(--border);padding-top:var(--space-sm);display:flex}@media (width<=1024px) and (width>=769px){:root{--sidebar-width:72px}.sidebar:not(.collapsed) .brand-text,.sidebar:not(.collapsed) .nav-label,.sidebar:not(.collapsed) .user-info,.sidebar:not(.collapsed) .brand-tagline{display:none!important}.sidebar:not(.collapsed) .footer-user{padding:var(--space-sm) 0!important;justify-content:center!important}.sidebar:not(.collapsed) .logout-btn{justify-content:center!important;padding:10px 0!important}.sidebar:not(.collapsed) .nav-item{margin-left:4px;margin-right:4px;justify-content:center!important;padding:10px 0!important}.sidebar:not(.collapsed) .nav-active-indicator{width:3px!important;top:8px!important;bottom:8px!important;left:0!important}.sidebar:not(.collapsed) .collapse-btn{margin:0 auto!important;transform:rotate(180deg)!important}}@media (width<=992px) and (width>=577px){.col-md-3,.col-md-4{flex:0 0 50%!important;width:50%!important;max-width:50%!important}.stats-grid,.scheduler-stats-grid,.grid-stats{grid-template-columns:repeat(2,1fr)!important}}@media (height<=520px){:root{--topnav-height:52px;--space-xl:12px;--space-lg:10px;--space-md:8px;--space-sm:6px}.welcome-banner{margin-bottom:12px!important;padding:12px 16px!important}.dashboard-tabs{margin-bottom:12px!important}.card,.dashboard-card,.stat-card{padding:var(--space-md)!important}.modal{max-height:96vh!important}.modal-header{padding:var(--space-sm) var(--space-md)!important}.modal-body{padding:var(--space-md)!important}.modal-footer{padding:var(--space-sm) var(--space-md)!important}.form-group{margin-bottom:var(--space-md)!important}}@media (width<=768px){.page-header{align-items:stretch!important;gap:var(--space-md)!important;text-align:left!important;flex-direction:column!important}.page-actions{gap:var(--space-sm)!important;flex-direction:column!important;width:100%!important}.page-actions>.btn,.page-actions>a{justify-content:center!important;width:100%!important;padding:12px!important}.search-bar{align-items:stretch!important;gap:var(--space-sm)!important;flex-direction:column!important}.search-input-wrapper{width:100%!important;min-width:100%!important}.search-bar>.btn{width:100%!important}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto;border-radius:var(--radius-md)!important;box-shadow:inset 8px 0 8px -8px #0006,inset -8px 0 8px -8px #0006!important}.data-table th,.data-table td{padding:10px 12px!important;font-size:.8125rem!important}}@media (width<=576px){.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-10,.col-md-12{flex:0 0 100%!important;width:100%!important;max-width:100%!important}.stats-grid,.scheduler-stats-grid,.grid-stats{grid-template-columns:1fr!important}.modal{border-radius:var(--radius-lg)!important;max-height:calc(100vh - 16px)!important;margin:8px!important}.modal-body,.calendar-wrapper{padding:var(--space-md)!important}.calendar-wrapper:after{content:"↔ Geser horizontal untuk melihat jadwal lengkap";text-align:center;color:var(--text-muted);margin-top:var(--space-sm);letter-spacing:.02em;font-size:.6875rem;font-weight:600;display:block}}
