.skeleton{background:linear-gradient(90deg,var(--slate-200) 25%,var(--slate-100) 50%,var(--slate-200) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:6px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text-container{display:flex;flex-direction:column;gap:.5rem}.skeleton-text{height:16px}.skeleton-card{padding:1.5rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius)}.skeleton-list-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--slate-50);border-radius:10px}.skeleton-kpi-card{padding:1.5rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);position:relative;overflow:hidden}.skeleton-dashboard-stats{display:flex;flex-direction:column;gap:.75rem}.skeleton-stat-item{display:flex;flex-direction:column;padding:.75rem;background:var(--slate-50);border-radius:10px}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:1000}.loading-overlay-content{text-align:center;color:var(--muted)}.loading-overlay-content .loading-spinner{margin:0 auto 1rem}.skeleton-pulse{animation:skeleton-pulse 2s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.6}}.loading-dots{display:inline-flex;gap:4px}.loading-dots span{width:8px;height:8px;background:var(--muted);border-radius:50%;animation:dots-bounce 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes dots-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.loading-bar{width:100%;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.loading-bar-progress{height:100%;background:var(--primary);border-radius:2px;animation:bar-progress 1.5s ease-in-out infinite}@keyframes bar-progress{0%{width:0%;margin-left:0%}50%{width:60%;margin-left:20%}to{width:0%;margin-left:100%}}:root{--primary: #3b82f6;--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--green-50: #f0fdf4;--green-100: #dcfce7;--green-200: #bbf7d0;--green-500: #22c55e;--green-600: #16a34a;--green-700: #15803d;--green-800: #166534;--green-900: #14532d;--red-50: #fef2f2;--red-100: #fee2e2;--red-500: #ef4444;--red-600: #dc2626;--amber-50: #fffbeb;--amber-100: #fef3c7;--amber-500: #f59e0b;--amber-600: #d97706;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--border: var(--slate-200);--bg-muted: var(--slate-50);--muted: var(--slate-500);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--radius: 12px}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;background:var(--slate-50);color:var(--slate-800);line-height:1.5}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2}p{margin:0}a{color:inherit;text-decoration:none}ul,ol{list-style:none;margin:0;padding:0}img{max-width:100%;display:block}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{width:260px;background:linear-gradient(180deg,#1e3a8a,#1e40af);color:#fff;display:flex;flex-direction:column;padding:1.2rem;position:fixed;top:0;left:0;bottom:0;z-index:50}.sidebar .logo{display:flex;align-items:center;gap:.75rem;padding:0 .5rem;margin-bottom:1.5rem}.sidebar .dot{width:10px;height:10px;border-radius:50%;background:var(--green-500);box-shadow:0 0 0 3px #22c55e4d}.sidebar .logo span{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.sidebar .logo small{display:block;font-size:.7rem;opacity:.7;font-weight:400}.sidebar .nav-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:10px;color:#ffffffbf;transition:all .2s;font-size:.9rem}.sidebar .nav-link:hover{background:#ffffff1a;color:#fff}.sidebar .nav-link.active{background:#ffffff26;color:#fff;font-weight:500}.sidebar .muted{color:#ffffff80}.sidebar .nav-group{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar .nav-group>div:not(.nav-link){padding:.5rem 1rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#fff6}.sidebar-bottom{margin-top:auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar-bottom .nav-link{color:#fff9}.sidebar-bottom .nav-link:hover{color:#fff}.main-layout{flex:1;margin-left:260px;display:flex;flex-direction:column}.header{background:#fff;border-bottom:1px solid var(--border);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:40}.header .breadcrumbs{font-size:.875rem;color:var(--muted)}.header h1{font-size:1.5rem;font-weight:600}.header .search{position:relative}.header .search input{width:320px;padding:.6rem 1rem .6rem 2.5rem;border:1px solid var(--border);border-radius:10px;background:var(--slate-50);font-size:.875rem}.header .search:before{content:"";position:absolute;left:.85rem;top:50%;transform:translateY(-50%);width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;opacity:.5}.content{flex:1;padding:2rem}.page{max-width:1400px}.page-title{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.page-title .breadcrumbs{font-size:.8rem;color:var(--muted);margin-bottom:.25rem}.page-title h1{font-size:1.75rem;font-weight:600}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.card-header h3{font-size:1.1rem;font-weight:600}button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:10px;font-size:.875rem;font-weight:500;border:none;transition:all .2s}button.primary{background:var(--primary);color:#fff}button.primary:hover{background:var(--primary-600)}button.secondary{background:var(--slate-100);color:var(--slate-700)}button.secondary:hover{background:var(--slate-200)}button.ghost{background:transparent;color:var(--slate-600);border:1px solid var(--border)}button.ghost:hover{background:var(--slate-50);border-color:var(--slate-300)}button.danger{background:var(--red-500);color:#fff}button.danger:hover{background:var(--red-600)}button.sm{padding:.4rem .85rem;font-size:.8rem}button.lg{padding:.85rem 1.75rem;font-size:1rem}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{width:100%;padding:.7rem 1rem;border:1px solid var(--border);border-radius:10px;font-size:.9rem;transition:all .2s;background:#fff}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--slate-700)}.form-group{margin-bottom:1.25rem}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.9rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.table th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--slate-50)}.table tbody tr:hover{background:var(--slate-50)}.table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge.success{background:var(--green-100);color:var(--green-700)}.badge.warning{background:var(--amber-100);color:var(--amber-600)}.badge.danger{background:var(--red-50);color:var(--red-600)}.badge.badge-processing{background:#fef9c3;color:#854d0e}.badge.info{background:var(--primary-100);color:var(--primary-700)}.badge.neutral{background:var(--slate-100);color:var(--slate-600)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.stat-icon.blue{background:var(--primary-50);color:var(--primary-600)}.stat-icon.green{background:var(--green-50);color:var(--green-600)}.stat-icon.amber{background:var(--amber-50);color:var(--amber-600)}.stat-icon.red{background:var(--red-50);color:var(--red-600)}.stat-icon.purple{background:#f3e8ff;color:#7c3aed}.stat-content h4{font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:.25rem}.stat-content p{font-size:.875rem;color:var(--muted)}.tabs{display:flex;gap:.5rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.tab{padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all .2s;background:none;border-left:none;border-right:none;border-top:none}.tab:hover{color:var(--slate-700)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.muted{color:var(--muted)}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.w-full{width:100%}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.login-wrapper{min-height:100vh;display:flex}.login-side{flex:1;background:linear-gradient(135deg,#1e3a8a,#3a86ff);color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:3rem}.login-side h1{font-size:2.5rem;margin-bottom:.5rem}.login-side p{font-size:1.1rem;opacity:.9;max-width:320px;text-align:center}.login-form-panel{flex:1;display:flex;justify-content:center;align-items:center;background:var(--slate-50);padding:2rem}.login-box{background:#fff;padding:2.5rem;border-radius:16px;box-shadow:0 10px 40px #00000014;width:100%;max-width:420px}.login-box h2{font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.login-logo{text-align:center;margin-bottom:1.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal-content{background:#fff;border-radius:16px;padding:1.5rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.modal-header h3{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--muted);cursor:pointer;padding:0}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}@media (max-width: 1024px){.sidebar{width:220px}.main-layout{margin-left:220px}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.main-layout{margin-left:0}.login-side{display:none}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.header .search{display:none}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--muted)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem 2rem;color:var(--muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.action-buttons{display:flex;gap:.5rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.detail-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.detail-card h4{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.75rem}.detail-item{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border)}.detail-item:last-child{border-bottom:none}.detail-item .label{color:var(--muted);font-size:.875rem}.detail-item .value{font-weight:500}.timeline{position:relative;padding-left:1.5rem}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--border)}.timeline-item{position:relative;padding-bottom:1.5rem}.timeline-item:before{content:"";position:absolute;left:-1.5rem;top:.25rem;width:10px;height:10px;border-radius:50%;background:var(--primary);border:2px solid #fff;box-shadow:0 0 0 2px var(--primary)}.timeline-item.completed:before{background:var(--green-500);box-shadow:0 0 0 2px var(--green-500)}.timeline-item.cancelled:before{background:var(--red-500);box-shadow:0 0 0 2px var(--red-500)}.user-info-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--slate-50);border-radius:12px;margin-bottom:1rem}.user-avatar{width:48px;height:48px;border-radius:12px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem}.user-details h4{font-size:1rem;font-weight:600}.user-details p{font-size:.8rem;color:var(--muted)}.status-indicator{display:inline-flex;align-items:center;gap:.5rem}.status-indicator:before{content:"";width:8px;height:8px;border-radius:50%}.status-indicator.online:before{background:var(--green-500)}.status-indicator.offline:before{background:var(--slate-400)}.status-indicator.busy:before{background:var(--red-500)}.filter-bar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-bar select{width:auto;min-width:150px}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.pagination button{min-width:40px}.pagination-info{font-size:.875rem;color:var(--muted);margin:0 1rem}.stats-row{display:flex;gap:1rem;margin-bottom:1rem}.stats-row .stat-mini{flex:1;text-align:center;padding:1rem;background:var(--slate-50);border-radius:10px}.stats-row .stat-mini .value{font-size:1.5rem;font-weight:700;color:var(--slate-800)}.stats-row .stat-mini .label{font-size:.75rem;color:var(--muted);text-transform:uppercase}.skeleton{background:linear-gradient(90deg,var(--slate-100) 25%,var(--slate-50) 50%,var(--slate-100) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:6px}.skeleton-text{height:16px;margin-bottom:.5rem}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.skeleton-text.long{width:100%}.skeleton-circle{width:40px;height:40px;border-radius:50%}.skeleton-rect{width:100%;height:40px;border-radius:8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-table-row{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border)}.skeleton-table-row>div{flex:1}.alert-ticker{background:#fef08a;padding:.75rem 1.5rem;overflow:hidden;display:flex;align-items:center;border-bottom:3px solid #eab308}.alert-ticker-content{display:flex;align-items:center;gap:.75rem;animation:ticker-scroll 30s linear infinite;white-space:nowrap}.alert-ticker-text{color:#dc2626;font-weight:700;font-size:.95rem}.alert-ticker-icon{color:#dc2626;flex-shrink:0}@keyframes ticker-scroll{0%{transform:translate(100%)}to{transform:translate(-100%)}}.alert-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem}.alert-popup{background:#fff;border-radius:16px;max-width:480px;width:100%;overflow:hidden;box-shadow:0 20px 40px #00000026}.alert-popup-header{background:#fef08a;padding:1.5rem 2rem;display:flex;align-items:center;gap:1rem}.alert-popup-icon{color:#b45309}.alert-popup-header h2{color:#b45309;font-size:1.35rem;font-weight:700;margin:0}.alert-popup-body{padding:2rem}.alert-popup-message{background:#fef9c3;color:#b45309;padding:1rem 1.25rem;border-radius:10px;font-size:1rem;font-weight:500;margin-bottom:1.5rem;line-height:1.5}.alert-summary{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.alert-summary-row{display:flex;justify-content:space-between;align-items:center;background:#fef9c3;padding:1rem 1.25rem;border-radius:10px}.alert-summary-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#a16207;font-weight:600}.alert-summary-label svg{color:#b45309}.alert-summary-value{font-weight:700;font-size:1rem;color:#b45309}.alert-urgency{color:#dc2626;font-weight:800}.alert-records h4,.alert-lockout-records h4{font-size:.8rem;color:#a16207;margin-bottom:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.alert-table{width:100%;border-collapse:collapse;font-size:.9rem;background:#fff;border-radius:10px;overflow:hidden;border:1px solid #e5e7eb}.alert-table th,.alert-table td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid #e5e7eb}.alert-table th{font-weight:600;color:#78716c;font-size:.75rem;text-transform:uppercase;background:#fafaf9}.alert-table tr:last-child td{border-bottom:none}.alert-table tr:hover{background:#fef9c3}.alert-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.alert-badge-warning{background:#fef08a;color:#b45309}.alert-popup-footer{padding:1.5rem 2rem;border-top:1px solid #e5e7eb;display:flex;justify-content:center;gap:1rem;background:#fafaf9}.alert-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;font-size:.9rem;font-weight:600;border:none;cursor:pointer;transition:all .2s}.alert-btn svg{flex-shrink:0}.alert-btn-ghost{background:transparent;color:#78716c;border:2px solid #d6d3d1}.alert-btn-ghost:hover{background:#f5f5f4;border-color:#a8a29e}.alert-btn-primary{background:#b45309;color:#fff}.alert-btn-primary:hover{background:#a16207}.alert-btn-large{padding:1rem 2.5rem;font-size:1.1rem;width:100%;max-width:320px}.alert-lockout-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1.5rem}.alert-lockout-container{background:#fff;border-radius:20px;max-width:500px;width:100%;padding:2.5rem;text-align:center;box-shadow:0 25px 50px #00000040}.alert-lockout-icon{color:#dc2626;margin-bottom:1rem;display:flex;justify-content:center}.alert-lockout-container h1{font-size:1.5rem;color:#dc2626;margin:0 0 1rem;font-weight:700}.alert-lockout-message{color:#78716c;margin-bottom:2rem;line-height:1.5;font-size:1rem}.alert-lockout-details{background:#fef9c3;border-radius:14px;padding:1.5rem;margin-bottom:2rem}.alert-lockout-summary{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem}.alert-lockout-row{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1rem 1.25rem;border-radius:10px}.alert-lockout-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#a16207;font-weight:600}.alert-lockout-label svg{color:#b45309}.alert-lockout-amount{font-size:1.5rem;font-weight:700;color:#dc2626}.alert-lockout-value{font-size:1rem;font-weight:700;color:#b45309}.alert-lockout-records{margin-top:1rem}.alert-lockout-actions{display:flex;flex-direction:column;gap:.75rem;align-items:center}.alert-lockout-note{font-size:.875rem;color:#a8a29e;margin:0}
