:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#fff;--border-color:#e2e8f0;--border-hover:#cbd5e1;--color-primary:#6366f1;--color-primary-glow:#6366f126;--gradient-primary:linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);--color-success:#10b981;--color-success-glow:#10b9811a;--gradient-success:linear-gradient(135deg, #10b981 0%, #059669 100%);--color-warning:#d97706;--color-warning-glow:#d977061a;--color-error:#ef4444;--color-error-glow:#ef44441a;--gradient-error:linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--color-info:#3b82f6;--color-info-glow:#3b82f61a;--text-main:#0f172a;--text-muted:#64748b;--text-inverse:#fff;--font-family:"Outfit", "Plus Jakarta Sans", system-ui, sans-serif;--radius-lg:16px;--radius-md:10px;--radius-sm:6px;--shadow-main:0 4px 20px 0 #0f172a0d;--transition-fast:all .2s cubic-bezier(.4, 0, .2, 1);--transition-normal:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-main);font-family:var(--font-family);background-image:radial-gradient(at 0 0,#6366f10a 0,#0000 50%),radial-gradient(at 50% 0,#8b5cf608 0,#0000 50%),radial-gradient(at 100% 0,#3b82f60a 0,#0000 50%);background-attachment:fixed;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#00000005}::-webkit-scrollbar-thumb{background:#0f172a1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.app-container{min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10;flex-direction:column;width:260px;height:100vh;padding:2rem 1.5rem;display:flex;position:fixed;top:0;left:0}.brand{align-items:center;gap:.75rem;margin-bottom:3rem;display:flex}.brand-icon{border-radius:var(--radius-md);background:var(--gradient-primary);color:#fff;width:38px;height:38px;box-shadow:0 0 15px var(--color-primary-glow);justify-content:center;align-items:center;font-size:1.25rem;font-weight:800;display:flex}.brand-info h2{letter-spacing:.5px;font-size:1.1rem;font-weight:700}.brand-info p{color:var(--text-muted);font-size:.75rem}.nav-links{flex-direction:column;gap:.5rem;list-style:none;display:flex}.nav-item{color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);align-items:center;gap:1rem;padding:.75rem 1rem;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:var(--text-main);background:#0f172a0a;transform:translate(4px)}.nav-item.active{background:var(--gradient-primary);color:var(--text-inverse);transform:none;box-shadow:0 10px 20px -3px #6366f140}.nav-item.active:hover{background:var(--gradient-primary);color:var(--text-inverse);transform:none}.nav-icon{font-size:1.2rem}.sync-status-indicator{border-radius:var(--radius-md);border:1px solid var(--border-color);background:#0f172a04;margin-top:auto;padding:1rem}.indicator-header{align-items:center;gap:.5rem;margin-bottom:.25rem;font-size:.8rem;font-weight:600;display:flex}.pulse-dot{background-color:var(--color-success);width:8px;height:8px;box-shadow:0 0 8px var(--color-success);border-radius:50%;animation:2s infinite pulse}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 8px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.indicator-text{color:var(--text-muted);font-size:.75rem}.main-content{flex:1;min-height:100vh;margin-left:260px;padding:2.5rem}.page-header{justify-content:space-between;align-items:center;margin-bottom:2.5rem;display:flex}.header-title h1{margin-bottom:.25rem;font-size:1.8rem;font-weight:700}.header-title p{color:var(--text-muted);font-size:.9rem}.header-actions{gap:1rem;display:flex}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);border:none;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--gradient-primary);color:var(--text-inverse);box-shadow:0 4px 12px var(--color-primary-glow)}.btn-primary:hover{box-shadow:0 6px 18px var(--color-primary-glow);filter:brightness(1.1);transform:translateY(-1px)}.btn-secondary{color:var(--text-main);border:1px solid var(--border-color);background:#ffffff0d}.btn-secondary:hover{border-color:var(--border-hover);background:#ffffff14}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem;margin-bottom:2.5rem;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:var(--transition-normal);flex-direction:column;padding:1.75rem 1.5rem;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0f172a05,0 2px 4px -1px #0f172a03}.stat-card.success{background:linear-gradient(135deg,#fff 75%,#f0fdf4 100%)}.stat-card.primary{background:linear-gradient(135deg,#fff 75%,#eff6ff 100%)}.stat-card.warning{background:linear-gradient(135deg,#fff 75%,#fffbeb 100%)}.stat-card.info{background:linear-gradient(135deg,#fff 75%,#faf5ff 100%)}.stat-card:hover{transform:translateY(-5px);box-shadow:0 20px 25px -5px #0f172a0f,0 10px 10px -5px #0f172a05}.stat-card.primary:hover{border-color:var(--color-info)}.stat-card.success:hover{border-color:var(--color-success)}.stat-card.warning:hover{border-color:var(--color-warning)}.stat-card.info:hover{border-color:var(--color-primary)}.stat-card:before{content:"";height:4px;position:absolute;top:0;left:0;right:0}.stat-card.primary:before{background:var(--color-info)}.stat-card.success:before{background:var(--color-success)}.stat-card.warning:before{background:var(--color-warning)}.stat-card.info:before{background:var(--color-primary)}.stat-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.75px;justify-content:space-between;align-items:center;margin-bottom:.85rem;font-size:.8rem;font-weight:700;display:flex}.stat-icon{border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.15rem;display:flex;box-shadow:inset 0 1px 2px #0000000d}.stat-card.success .stat-icon{color:#047857;background:#d1fae5}.stat-card.primary .stat-icon{color:#1d4ed8;background:#dbeafe}.stat-card.warning .stat-icon{color:#b45309;background:#fef3c7}.stat-card.info .stat-icon{color:#6b21a8;background:#f3e8ff}.stat-value{font-size:2.6rem;font-weight:800;line-height:1.1;font-family:var(--font-family);margin-bottom:.5rem}.stat-card.success .stat-value{color:#10b981}.stat-card.primary .stat-value{color:#2563eb}.stat-card.warning .stat-value{color:#d97706}.stat-card.info .stat-value{color:#6366f1}.stat-desc{color:var(--text-muted);font-size:.8rem;font-weight:500}.glass-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-main);padding:2rem}.panel-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.panel-header h3{font-size:1.2rem;font-weight:700}.table-container{width:100%;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%;font-size:.92rem}.custom-table th{border-bottom:2px solid var(--border-color);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background-color:#f8fafc;padding:1rem;font-size:.75rem;font-weight:600}.custom-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:1rem}.custom-table tr:last-child td{border-bottom:none}.custom-table tbody tr{transition:var(--transition-fast)}.custom-table tbody tr:hover{background:#6366f104}.custom-table tbody tr:hover td:first-child{position:relative}.custom-table tbody tr:hover td:first-child:before{content:"";background:var(--color-primary);border-top-left-radius:4px;border-bottom-left-radius:4px;width:4px;position:absolute;top:0;bottom:0;left:0}.badge{text-transform:capitalize;border:1px solid #0000;border-radius:30px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex;box-shadow:0 1px 2px #00000005}.badge-in{color:#047857;background:#ecfdf5;border-color:#d1fae5}.badge-out{color:#1d4ed8;background:#eff6ff;border-color:#dbeafe}.badge-late{color:#b45309;background:#fffbeb;border-color:#fef3c7}.badge-sync-success{color:#15803d;background:#f0fdf4;border-color:#dcfce7}.badge-sync-fail{color:#b91c1c;background:#fef2f2;border-color:#fee2e2}.search-wrapper{width:300px;position:relative}.search-input{border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-main);font-family:var(--font-family);transition:var(--transition-fast);background:#fff;outline:none;padding:.6rem 1rem .6rem 2.5rem;font-size:.9rem}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 10px var(--color-primary-glow);background:#fff}.search-icon{color:var(--text-muted);font-size:1rem;position:absolute;top:50%;left:.9rem;transform:translateY(-50%)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#0f172a66;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.25s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{border:1px solid var(--border-color);border-radius:var(--radius-lg);background:#fff;width:500px;max-width:90%;animation:.3s cubic-bezier(.34,1.56,.64,1) slideUp;overflow:hidden;box-shadow:0 20px 25px -5px #0f172a1a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h3{font-size:1.25rem;font-weight:700}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.5rem}.close-btn:hover{color:var(--text-main)}.modal-body{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-muted);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.form-control{border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-main);font-family:var(--font-family);transition:var(--transition-fast);background:#fff;outline:none;padding:.75rem 1rem;font-size:.95rem}.form-control:focus{border-color:var(--color-primary);background:#fff}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.log-row-info{border-left:3px solid var(--color-info)}.log-row-success{border-left:3px solid var(--color-success)}.log-row-warning{border-left:3px solid var(--color-warning)}.log-row-error{border-left:3px solid var(--color-error)}.log-level{border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:700}.log-level.info{background:var(--color-info-glow);color:var(--color-info)}.log-level.success{background:var(--color-success-glow);color:var(--color-success)}.log-level.warning{background:var(--color-warning-glow);color:var(--color-warning)}.log-level.error{background:var(--color-error-glow);color:var(--color-error)}.log-message{font-weight:500}.log-time{color:var(--text-muted);font-family:monospace;font-size:.85rem}@media (width<=768px){.app-container{flex-direction:column}.sidebar{width:100%;height:auto;padding:1.5rem;position:relative}.brand{margin-bottom:1.5rem}.main-content{margin-left:0;padding:1.5rem}}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{border-radius:var(--radius-lg);border:1px solid var(--border-color);width:420px;max-width:100%;padding:2.5rem;animation:.4s ease-out fadeIn;box-shadow:0 20px 40px #0f172a14}.alert-message{border-radius:var(--radius-md);padding:.75rem 1rem;font-size:.85rem;font-weight:500}.alert-message.error-message{background:var(--color-error-glow);color:var(--color-error);border:1px solid #ef44444d}.logout-item{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.logout-btn{justify-content:center;width:100%;color:var(--color-error)!important;background:#ef44440d!important;border:1px solid #ef444433!important}.logout-btn:hover{background:var(--color-error)!important;color:#fff!important}.stat-card.danger{background:linear-gradient(135deg,#fff 75%,#fef2f2 100%)}.stat-card.danger:hover{border-color:var(--color-error)}.stat-card.danger:before{background:var(--color-error)}.stat-card.danger .stat-icon{color:#b91c1c;background:#fee2e2}.stat-card.danger .stat-value{color:#ef4444}.stat-card{-webkit-user-select:none;user-select:none;cursor:pointer!important}.stat-card.active{transform:translateY(-5px)scale(1.02)}.stat-card.success.active{box-shadow:0 0 15px #10b98133,0 20px 25px -5px #0f172a0f;border-color:var(--color-success)!important}.stat-card.primary.active{box-shadow:0 0 15px #3b82f633,0 20px 25px -5px #0f172a0f;border-color:var(--color-info)!important}.stat-card.warning.active{box-shadow:0 0 15px #d9770633,0 20px 25px -5px #0f172a0f;border-color:var(--color-warning)!important}.stat-card.danger.active{box-shadow:0 0 15px #ef444433,0 20px 25px -5px #0f172a0f;border-color:var(--color-error)!important}.stat-card.info.active{box-shadow:0 0 15px #6366f133,0 20px 25px -5px #0f172a0f;border-color:var(--color-primary)!important}.stat-card.proper{background:linear-gradient(135deg,#fff 75%,#f0fdfa 100%)}.stat-card.proper:hover{border-color:#0d9488}.stat-card.proper:before{background:#0d9488}.stat-card.proper .stat-icon{color:#0f766e;background:#ccfbf1}.stat-card.proper .stat-value{color:#0d9488}.stat-card.proper.active{box-shadow:0 0 15px #0d948833,0 20px 25px -5px #0f172a0f;border-color:#0d9488!important}
