@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-color:#0b0f19;--bg-surface:#111827;--bg-glass:#111827b3;--bg-glass-light:#ffffff0d;--border-glass:#ffffff14;--border-glass-hover:#ffffff26;--primary:#3b82f6;--primary-hover:#2563eb;--primary-glow:#3b82f659;--secondary:#8b5cf6;--secondary-hover:#7c3aed;--danger:#ef4444;--danger-hover:#dc2626;--warning:#f59e0b;--success:#10b981;--success-glow:#10b98140;--text-main:#f3f4f6;--text-muted:#9ca3af;--text-dim:#6b7280;--gradient-primary:linear-gradient(135deg, #3b82f6, #8b5cf6);--gradient-success:linear-gradient(135deg, #10b981, #06b6d4);--gradient-danger:linear-gradient(135deg, #ef4444, #f97316);--shadow-lg:0 8px 32px #0000004d;--shadow-glow-primary:0 0 20px #3b82f64d;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition:all .3s cubic-bezier(.4, 0, .2, 1);--navbar-height:64px}:root[data-theme=light]{--bg-color:#f8fafc;--bg-surface:#fff;--bg-glass:#ffffffbf;--bg-glass-light:#0000000a;--border-glass:#0000001a;--border-glass-hover:#00000026;--text-main:#0f172a;--text-muted:#475569;--text-dim:#64748b}[data-theme=light] body{background-image:radial-gradient(at 0 0,#3b82f626 0,#0000 50%),radial-gradient(at 100% 100%,#8b5cf626 0,#0000 50%),radial-gradient(#10b9811a 0,#0000 70%)}[data-theme=light] .navbar{background:#ffffffd9}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,system-ui,-apple-system,sans-serif}body{background-color:var(--bg-color);color:var(--text-main);background-image:radial-gradient(at 0 0,#3b82f61f 0,#0000 50%),radial-gradient(at 100% 100%,#8b5cf61a 0,#0000 50%),radial-gradient(#10b9810d 0,#0000 70%);background-attachment:fixed;min-height:100vh}#root{flex-direction:column;min-height:100vh;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.animate-fade-in{animation:.5s ease-out fadeIn}.animate-fade-in-up{animation:.5s ease-out fadeInUp}.animate-fade-in-down{animation:.4s ease-out fadeInDown}.animate-slide-in-right{animation:.4s ease-out slideInRight}.animate-scale-in{animation:.3s ease-out scaleIn}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-spin{animation:1s linear infinite spin}.stagger-children>*{animation:.4s ease-out backwards fadeInUp}.stagger-children>:first-child{animation-delay:50ms}.stagger-children>:nth-child(2){animation-delay:.1s}.stagger-children>:nth-child(3){animation-delay:.15s}.stagger-children>:nth-child(4){animation-delay:.2s}.stagger-children>:nth-child(5){animation-delay:.25s}.stagger-children>:nth-child(6){animation-delay:.3s}.glass-panel{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transition:var(--transition)}.glass-panel:hover{border-color:var(--border-glass-hover)}.glass-panel-static{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.glass-input{background:var(--bg-glass-light);border:1px solid var(--border-glass);width:100%;color:var(--text-main);border-radius:var(--radius-sm);transition:var(--transition);outline:none;padding:14px 16px;font-size:.95rem}.glass-input:focus{border-color:var(--primary);background:var(--border-glass);box-shadow:0 0 0 3px #3b82f626}.glass-input::placeholder{color:var(--text-dim)}select.glass-input option{background-color:var(--bg-surface);color:var(--text-main)}[data-theme=light] select.glass-input option{color:#0f172a;background-color:#fff}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--gradient-primary);color:#fff;background-size:200% 200%}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-glow-primary);transform:translateY(-2px)}.btn-danger{background:var(--gradient-danger);color:#fff;background-size:200% 200%}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #ef444459}.btn-ghost{background:var(--bg-glass-light);color:var(--text-main);border:1px solid var(--border-glass)}.btn-ghost:hover:not(:disabled){background:var(--bg-glass-light);border-color:var(--border-glass-hover);transform:translateY(-1px)}.btn-success{background:var(--gradient-success);color:#fff}.btn-success:hover:not(:disabled){box-shadow:0 4px 16px var(--success-glow);transform:translateY(-2px)}.btn-sm{padding:8px 16px;font-size:.85rem}.btn-lg{padding:16px 32px;font-size:1.05rem}.btn-icon{border-radius:var(--radius-sm);padding:10px}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-content{padding:24px;padding-top:calc(var(--navbar-height) + 24px);flex:1;width:100%;max-width:960px;margin:0 auto;animation:.4s ease-out fadeInUp}.container{width:100%;max-width:600px;margin:0 auto;padding:24px}.flex-center{justify-content:center;align-items:center;min-height:100vh;display:flex}.page-title{align-items:center;gap:12px;margin-bottom:24px;font-size:1.6rem;font-weight:700;display:flex}.page-title svg{color:var(--primary)}.form-group{margin-bottom:20px;position:relative}.form-group label{color:var(--text-muted);margin-bottom:8px;font-size:.875rem;font-weight:500;display:block}.input-wrapper{position:relative}.input-wrapper .toggle-password{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:4px;transition:color .2s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.input-wrapper .toggle-password:hover{color:var(--text-main)}.navbar{height:var(--navbar-height);background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-glass);z-index:1000;justify-content:space-between;align-items:center;padding:0 24px;animation:.4s ease-out fadeInDown;display:flex;position:fixed;top:0;left:0;right:0}.navbar-brand{color:var(--text-main);align-items:center;gap:12px;text-decoration:none;display:flex}.navbar-brand .logo-icon{background:var(--gradient-primary);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.navbar-brand h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.15rem;font-weight:700}.navbar-nav{align-items:center;gap:4px;list-style:none;display:flex}.navbar-nav .nav-link{border-radius:var(--radius-sm);color:var(--text-muted);transition:var(--transition);align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;font-weight:500;text-decoration:none;display:flex;position:relative}.navbar-nav .nav-link:hover{color:var(--text-main);background:var(--bg-glass-light)}.navbar-nav .nav-link.active{color:var(--primary);background:#3b82f61a}.navbar-actions{align-items:center;gap:12px;display:flex}.navbar-user{align-items:center;gap:10px;display:flex}.navbar-avatar{background:var(--gradient-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:.85rem;font-weight:700;display:flex}.navbar-user-name{color:var(--text-main);font-size:.9rem;font-weight:500}.hamburger{color:var(--text-main);cursor:pointer;background:0 0;border:none;padding:8px;display:none}.mobile-nav-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;background:#0009;display:none;position:fixed;inset:0}.mobile-nav-overlay.show{animation:.3s ease-out fadeIn;display:block}.mobile-nav{background:var(--bg-surface);border-left:1px solid var(--border-glass);z-index:2001;width:300px;height:100dvh;padding:24px;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 24px);padding-top:calc(env(safe-area-inset-top,0px) + 60px);flex-direction:column;gap:8px;transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0;transform:translate(100%);box-shadow:-10px 0 30px #00000080}.mobile-nav.show{transform:translate(0)}.mobile-nav-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.mobile-nav-user{align-items:center;gap:16px;display:flex}.mobile-nav-avatar{width:48px;height:48px;color:var(--primary);background:#3b82f633;border:1px solid #3b82f64d;border-radius:12px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;display:flex;box-shadow:0 4px 12px #3b82f61a}.mobile-nav-user-info{flex-direction:column;display:flex}.mobile-nav-role{color:#fff6;letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px;font-size:10px;font-weight:800}.mobile-nav-name{color:#fff;font-size:.95rem;font-weight:700}.mobile-nav-nik{color:var(--primary);margin-top:2px;font-size:11px;font-weight:500}.mobile-nav-close{color:#fff6;cursor:pointer;width:40px;height:40px;transition:var(--transition);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;display:flex}.mobile-nav-close:hover{color:#fff;background:#ffffff1a}.mobile-nav-links{flex:1;margin:0 -8px;padding:0 8px;overflow-y:auto}.mobile-nav .nav-link{color:#fff6;transition:var(--transition);border:1px solid #0000;border-radius:16px;align-items:center;gap:16px;margin-bottom:8px;padding:16px;font-size:.95rem;font-weight:700;text-decoration:none;display:flex}.mobile-nav .nav-link .icon-box{width:40px;height:40px;transition:var(--transition);background:#ffffff0d;border-radius:10px;justify-content:center;align-items:center;display:flex}.mobile-nav .nav-link:hover{color:#fff;background:#ffffff08}.mobile-nav .nav-link.active{background:var(--primary);color:#fff;transform:scale(1.02);box-shadow:0 8px 20px #3b82f64d}.mobile-nav .nav-link.active .icon-box{background:#fff3}.mobile-nav-footer{border-top:1px solid #ffffff1a;padding-top:24px}.btn-logout-mobile{color:#f87171;cursor:pointer;width:100%;transition:var(--transition);background:0 0;border:1px solid #0000;border-radius:16px;align-items:center;gap:16px;padding:16px;font-weight:700;display:flex}.btn-logout-mobile:hover{background:#ef44441a;border-color:#ef444433}.btn-logout-mobile .icon-box{background:#ef44441a;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}@media (width<=768px){.navbar-nav,.navbar-user-name{display:none}.hamburger{display:flex}}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);transition:var(--transition);padding:20px;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.primary:before{background:var(--gradient-primary)}.stat-card.success:before{background:var(--gradient-success)}.stat-card.warning:before{background:linear-gradient(135deg,#f59e0b,#f97316)}.stat-card.danger:before{background:var(--gradient-danger)}.stat-card:hover{border-color:var(--border-glass-hover);transform:translateY(-2px)}.stat-card-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:12px;display:flex}.stat-card.primary .stat-card-icon{color:var(--primary);background:#3b82f626}.stat-card.success .stat-card-icon{color:var(--success);background:#10b98126}.stat-card.warning .stat-card-icon{color:var(--warning);background:#f59e0b26}.stat-card.danger .stat-card-icon{color:var(--danger);background:#ef444426}.stat-card-value{margin-bottom:4px;font-size:1.8rem;font-weight:800;line-height:1}.stat-card-label{color:var(--text-muted);font-size:.85rem;font-weight:500}.toast-container{top:calc(var(--navbar-height) + 16px);z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;right:16px}.toast{border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-glass);box-shadow:var(--shadow-lg);align-items:center;gap:12px;min-width:300px;max-width:420px;padding:14px 20px;animation:.3s ease-out slideInRight;display:flex}.toast.removing{animation:.3s ease-in forwards slideOutRight}@keyframes slideOutRight{to{opacity:0;transform:translate(100%)}}.toast-icon{flex-shrink:0;width:20px;height:20px}.toast.success{border-left:3px solid var(--success)}.toast.success .toast-icon{color:var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.error .toast-icon{color:var(--danger)}.toast.info{border-left:3px solid var(--primary)}.toast.info .toast-icon{color:var(--primary)}.toast.warning{border-left:3px solid var(--warning)}.toast.warning .toast-icon{color:var(--warning)}.toast-message{color:var(--text-main);flex:1;font-size:.9rem}.toast-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:2px;transition:color .2s;display:flex}.toast-close:hover{color:var(--text-main)}.toast-progress{border-radius:0 0 var(--radius-md) var(--radius-md);background:var(--primary);height:2px;animation:linear forwards shrink;position:absolute;bottom:0;left:0}@keyframes shrink{0%{width:100%}to{width:0}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;background:#0009;justify-content:center;align-items:center;padding:24px;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-surface);border:1px solid var(--border-glass);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;animation:.3s ease-out scaleIn;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-glass);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{font-size:1.15rem;font-weight:600}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border-glass);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.spinner{border:3px solid var(--border-glass);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-page{min-height:60vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.skeleton{background:linear-gradient(90deg, var(--bg-glass-light) 25%, #ffffff1a 50%, var(--bg-glass-light) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:100px;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{color:var(--success);background:#10b98126}.badge-danger{color:var(--danger);background:#ef444426}.badge-warning{color:var(--warning);background:#f59e0b26}.badge-primary{color:var(--primary);background:#3b82f626}.badge-muted{color:var(--text-muted);background:#9ca3af26}.history-card{background:var(--bg-glass-light);border:1px solid var(--border-glass);border-radius:var(--radius-md);transition:var(--transition);padding:16px 20px}.history-card:hover{border-color:var(--border-glass-hover);background:#ffffff12}.alert{border-radius:var(--radius-sm);align-items:center;gap:10px;margin-bottom:20px;padding:14px 18px;font-size:.9rem;animation:.3s ease-out fadeInUp;display:flex}.alert-error{color:#fca5a5;background:#ef44441f;border:1px solid #ef44444d}.alert-success{color:#6ee7b7;background:#10b9811f;border:1px solid #10b9814d}.alert-info{color:#93c5fd;background:#3b82f61f;border:1px solid #3b82f64d}.avatar{color:#fff;background:var(--gradient-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.avatar-sm{width:32px;height:32px;font-size:.8rem}.avatar-md{width:48px;height:48px;font-size:1.1rem}.avatar-lg{width:72px;height:72px;font-size:1.6rem}.avatar-xl{width:96px;height:96px;font-size:2rem}.live-clock{font-variant-numeric:tabular-nums;background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:800;line-height:1}.live-clock-separator{animation:1s step-end infinite blink}.live-clock-date{color:var(--text-muted);margin-top:4px;font-size:.95rem}.camera-preview{border-radius:var(--radius-lg);border:2px solid var(--border-glass);width:100%;max-width:400px;transition:var(--transition);background:#000;margin:0 auto;position:relative;overflow:hidden}.camera-preview:hover{border-color:var(--primary)}.camera-preview video{width:100%;height:auto;display:block}.camera-overlay{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.camera-overlay-ring{border:2px dashed #ffffff40;border-radius:50%;width:160px;height:160px}.camera-placeholder{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:60px 0;display:flex}@media (width<=768px){.app-content{padding:16px;padding-top:calc(var(--navbar-height) + 16px)}.stat-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card-value{font-size:1.4rem}.live-clock{font-size:2.2rem}.page-title{font-size:1.3rem}.container{padding:16px}.toast{min-width:auto;max-width:calc(100vw - 32px)}}@media (width<=480px){.stat-grid{grid-template-columns:1fr 1fr}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-glass);border-radius:100px}::-webkit-scrollbar-thumb:hover{background:#fff3}.text-muted{color:var(--text-muted)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-center{text-align:center}.font-mono{font-variant-numeric:tabular-nums}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0,0,0,0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}[data-theme=light] .mobile-nav{background:#fff;border-left:1px solid #0000000d}[data-theme=light] .mobile-nav-name{color:#1e293b}[data-theme=light] .mobile-nav-role{color:#0006}[data-theme=light] .mobile-nav-close{color:#64748b;background:#0000000d;border-color:#0000001a}[data-theme=light] .mobile-nav .nav-link{color:#64748b}[data-theme=light] .mobile-nav .nav-link:hover{color:#1e293b;background:#00000008}[data-theme=light] .mobile-nav .nav-link.active{color:#fff}[data-theme=light] .mobile-nav .nav-link .icon-box{color:var(--primary);background:#3b82f61a}[data-theme=light] .mobile-nav .nav-link.active .icon-box{color:#fff;background:#fff3}[data-theme=light] .mobile-nav-footer{border-top:1px solid #00000014}
