:root{--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-primary-light: #eef2ff;--color-primary-50: #eef2ff;--color-primary-100: #e0e7ff;--color-primary-600: #4f46e5;--color-primary-700: #4338ca;--color-success: #059669;--color-success-light: #ecfdf5;--color-success-50: #ecfdf5;--color-warning: #d97706;--color-warning-light: #fffbeb;--color-danger: #dc2626;--color-danger-light: #fef2f2;--color-bg: #f8fafc;--color-surface: #ffffff;--color-surface-hover: #f1f5f9;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--color-text: #0f172a;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-text-inverse: #ffffff;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--sidebar-width: 260px;--header-height: 64px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;line-height:1.5}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-success{background:var(--color-success);color:var(--color-text-inverse)}.btn-success:hover:not(:disabled){background:#047857;transform:translateY(-1px)}.btn-danger{background:var(--color-danger);color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-outline{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-outline:hover:not(:disabled){background:var(--color-surface-hover)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-size-md);border-radius:var(--radius-lg)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:var(--space-6)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text)}.form-group{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-4)}.form-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.form-input,.form-select{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-input:focus,.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input::placeholder{color:var(--color-text-muted)}.form-error{font-size:var(--font-size-xs);color:var(--color-danger)}.badge{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500}.badge-entry{background:var(--color-success-light);color:var(--color-success)}.badge-exit{background:var(--color-danger-light);color:var(--color-danger)}.badge-admin{background:var(--color-primary-light);color:var(--color-primary)}.badge-active{background:var(--color-success-light);color:var(--color-success)}.badge-inactive{background:var(--color-danger-light);color:var(--color-danger)}.table-container{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg)}table{width:100%;border-collapse:collapse}th,td{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-size-sm);border-bottom:1px solid var(--color-border-light)}th{background:var(--color-bg);font-weight:600;color:var(--color-text-secondary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em}tr:hover td{background:var(--color-surface-hover)}.admin-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,#1e1b4b,#312e81);color:var(--color-text-inverse);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:50;overflow-y:auto}.sidebar-header{padding:var(--space-6);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{font-size:var(--font-size-xl);font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#818cf8,#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.sidebar-subtitle{font-size:var(--font-size-xs);color:#ffffff80;margin-top:var(--space-1)}.sidebar-nav{padding:var(--space-4);flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#ffffffb3;text-decoration:none;font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast)}.sidebar-link:hover{background:#ffffff1a;color:#fff;text-decoration:none}.sidebar-link.active{background:#ffffff26;color:#fff}.sidebar-link .icon{font-size:var(--font-size-lg);width:24px;text-align:center}.sidebar-footer{padding:var(--space-4);border-top:1px solid rgba(255,255,255,.1)}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.page-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--space-4) var(--space-8);display:flex;align-items:center;justify-content:space-between;height:var(--header-height);position:sticky;top:0;z-index:40}.page-title{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text)}.page-body{padding:var(--space-8)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-4);margin-bottom:var(--space-8)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;align-items:flex-start;gap:var(--space-4);transition:all var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);flex-shrink:0}.stat-icon.entry{background:var(--color-success-light)}.stat-icon.exit{background:var(--color-danger-light)}.stat-icon.inside{background:var(--color-primary-light)}.stat-icon.warning{background:var(--color-warning-light)}.stat-info{flex:1}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.stat-value{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-text);line-height:1.2}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e1b4b,#312e81,#4f46e5);padding:var(--space-4)}.login-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-10);width:100%;max-width:420px;animation:fadeInUp .4s ease-out}.login-logo{text-align:center;margin-bottom:var(--space-8)}.login-logo h1{font-size:var(--font-size-2xl);font-weight:800;background:linear-gradient(135deg,var(--color-primary),#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-logo p{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--space-1)}.login-error{background:var(--color-danger-light);color:var(--color-danger);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-4);animation:shake .3s ease}.gate-screen{min-height:100vh;background:#0a0a0f;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8)}.gate-qr-container{background:#fff;padding:var(--space-6);border-radius:var(--radius-xl);box-shadow:0 0 60px #6366f14d;margin:var(--space-8) 0;animation:pulse-glow 3s ease-in-out infinite}.gate-qr-container img{display:block;width:300px;height:300px}.gate-info{text-align:center}.gate-facility-name{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-2)}.gate-name{font-size:var(--font-size-lg);color:#fff9;margin-bottom:var(--space-6)}.gate-timer{font-size:var(--font-size-3xl);font-weight:800;font-variant-numeric:tabular-nums}.gate-timer.warning{color:#f59e0b}.gate-status{margin-top:var(--space-6);font-size:var(--font-size-sm);color:#fff6}.scan-page{min-height:100vh;background:var(--color-bg);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.scan-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-8);width:100%;max-width:420px;text-align:center}.scan-icon{width:80px;height:80px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto var(--space-6)}.scan-icon.success{background:var(--color-success-light)}.scan-icon.error{background:var(--color-danger-light)}.scan-facility{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-1)}.scan-gate{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-6)}.scan-actions{display:flex;flex-direction:column;gap:var(--space-3)}.scan-result{padding:var(--space-6);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.scan-result.success{background:var(--color-success-light)}.scan-result .result-icon{font-size:48px;margin-bottom:var(--space-3)}.scan-result .result-text{font-size:var(--font-size-lg);font-weight:600;color:var(--color-success)}.scan-result .result-time{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-2)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-6);width:90%;max-width:500px;max-height:80vh;overflow-y:auto;animation:fadeInUp .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.modal-title{font-size:var(--font-size-lg);font-weight:600}.modal-close{background:none;border:none;font-size:var(--font-size-xl);cursor:pointer;color:var(--color-text-muted);padding:var(--space-1)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6)}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:200;display:flex;flex-direction:column;gap:var(--space-2)}.toast{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;box-shadow:var(--shadow-lg);animation:slideInRight .3s ease-out;display:flex;align-items:center;gap:var(--space-2)}.toast-success{background:var(--color-success);color:#fff}.toast-error{background:var(--color-danger);color:#fff}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.loading-page{min-height:100vh;display:flex;align-items:center;justify-content:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 40px #6366f133}50%{box-shadow:0 0 80px #6366f166}}.audit-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4)}.audit-row{transition:background var(--transition-fast)}.audit-row:hover td{background:var(--color-primary-50)!important}.audit-detail-expand{background:var(--color-bg)!important;padding:var(--space-4) var(--space-6)!important}.audit-detail-content{display:flex;flex-direction:column;gap:var(--space-2)}.audit-detail-row{display:flex;gap:var(--space-3);font-size:var(--font-size-sm);align-items:flex-start}.audit-detail-row strong{min-width:120px;color:var(--color-text-secondary);flex-shrink:0}.audit-detail-json{background:#1e1b4b;color:#c4b5fd;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-xs);overflow-x:auto;margin-top:var(--space-1);max-height:200px;overflow-y:auto;font-family:SF Mono,Fira Code,Consolas,monospace;line-height:1.5}.badge-auth{background:#dbeafe;color:#1d4ed8}.badge-admin-action{background:#fed7aa;color:#c2410c}.badge-facility{background:#e0e7ff;color:#4338ca}.badge-gate{background:#fef3c7;color:#b45309}.badge-qr{background:#d1fae5;color:#047857}.badge-device{background:#ede9fe;color:#6d28d9}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-4);border-top:1px solid var(--color-border-light)}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-muted);font-variant-numeric:tabular-nums}.devices-page-container{max-width:900px;margin:0 auto;padding:var(--space-8)}.devices-page-header{margin-bottom:var(--space-8)}.devices-page-title{font-size:var(--font-size-2xl);font-weight:800;color:var(--color-text);margin-bottom:var(--space-2)}.devices-page-subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm)}.devices-grid{display:grid;gap:var(--space-4)}.device-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.device-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.device-current{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary-light)}.device-card-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);border-bottom:1px solid var(--color-border-light)}.device-icon{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border-radius:var(--radius-lg);flex-shrink:0}.device-info{flex:1;min-width:0}.device-name{font-weight:600;font-size:var(--font-size-sm);color:var(--color-text);display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-1)}.device-platform{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.device-card-body{padding:var(--space-4) var(--space-5)}.device-detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-1) 0;font-size:var(--font-size-xs)}.device-detail-label{color:var(--color-text-muted)}.device-detail-value{color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.device-card-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);background:var(--color-bg)}.device-delete-confirm{display:flex;align-items:center;gap:var(--space-2)}.unknown-device-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:300;animation:fadeIn .3s ease}.unknown-device-modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-8);max-width:400px;width:90%;text-align:center;animation:fadeInUp .4s ease-out}.unknown-device-icon{font-size:48px;margin-bottom:var(--space-4)}.unknown-device-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);margin-bottom:var(--space-2)}.unknown-device-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6);line-height:1.6}.unknown-device-actions{display:flex;flex-direction:column;gap:var(--space-3)}.idle-warning-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:350;animation:fadeIn .3s ease}.idle-warning-modal{background:var(--color-surface);border:2px solid var(--color-warning);border-radius:var(--radius-xl);box-shadow:0 0 40px #d9770633;padding:var(--space-8);max-width:400px;width:90%;text-align:center;animation:fadeInUp .4s ease-out}.idle-warning-icon{font-size:48px;margin-bottom:var(--space-4)}.idle-warning-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-warning);margin-bottom:var(--space-2)}.idle-warning-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6);line-height:1.6}.idle-warning-actions{display:flex;gap:var(--space-3);justify-content:center}@media(max-width:768px){.sidebar{display:none}.main-content{margin-left:0}.page-body{padding:var(--space-4)}.stats-grid{grid-template-columns:1fr 1fr}.gate-qr-container img{width:250px;height:250px}.audit-filter-grid{grid-template-columns:1fr}.devices-page-container{padding:var(--space-4)}.chart-grid{grid-template-columns:1fr}.report-tabs,.report-toolbar{flex-wrap:wrap}}.report-tabs{display:flex;gap:var(--space-1);background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--space-1)}.report-tab{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.report-tab:hover{background:var(--color-surface);color:var(--color-text)}.report-tab.active{background:var(--color-primary);color:var(--color-text-inverse);box-shadow:var(--shadow-sm)}.report-toolbar{display:flex;align-items:flex-end;gap:var(--space-4);flex-wrap:wrap}.export-bar{display:flex;gap:var(--space-2);align-items:flex-end}.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-6)}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-xs)}.chart-card-header{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-4)}.alert-card{padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:600}.alert-card.warning{background:var(--color-warning-light);color:var(--color-warning);border:1px solid rgba(217,119,6,.2)}.late-badge{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;background:var(--color-danger-light);color:var(--color-danger)}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);padding:var(--space-2) 0}.info-item{display:flex;flex-direction:column;gap:var(--space-1)}.info-label{font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:var(--font-size-sm);color:var(--color-text);font-weight:500}.action-buttons{display:flex;gap:var(--space-1);align-items:center}.form-error-box{background:var(--color-danger-light);color:var(--color-danger);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-4);animation:shake .3s ease}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.modal-lg{max-width:600px}.badge-custom-role{background:#ede9fe;color:#6d28d9}.profile-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-4)}.profile-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-8);width:100%;max-width:500px;animation:fadeInUp .4s ease-out}.profile-header{text-align:center;margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border-light)}.profile-avatar{width:80px;height:80px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),#7c3aed);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);font-weight:800;margin:0 auto var(--space-4);letter-spacing:1px}.profile-name{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text);margin-bottom:var(--space-1)}.profile-email{font-size:var(--font-size-sm);color:var(--color-text-muted)}.profile-info{margin-bottom:var(--space-6)}.profile-note{background:var(--color-primary-light);border:1px solid var(--color-primary-100);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-6)}.profile-note p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.profile-actions{display:flex;gap:var(--space-3);justify-content:center}@media(max-width:768px){.info-grid{grid-template-columns:1fr}}.scroll-reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.scroll-reveal.revealed{opacity:1;transform:translateY(0)}.section-anchor{position:absolute;top:-80px}.landing-page{overflow-x:hidden;background:#050510;color:#e2e8f0}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:#050510d9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.06)}.landing-nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;height:70px;display:flex;align-items:center;justify-content:space-between}.landing-nav-logo{font-size:1.25rem;font-weight:800;color:#fff!important;text-decoration:none!important;display:flex;align-items:center;gap:.5rem}.nav-logo-icon{font-size:1.5rem;color:#a78bfa}.landing-nav-links{display:flex;align-items:center;gap:1.5rem}.landing-nav-links a{color:#fff9;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s}.landing-nav-links a:hover{color:#fff;text-decoration:none}.landing-hero{min-height:100vh;display:flex;align-items:center;justify-content:center;gap:4rem;padding:6rem 2rem 4rem;max-width:1200px;margin:0 auto;position:relative}.hero-bg-shapes{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0}.hero-shape{position:absolute;border-radius:50%;filter:blur(120px);opacity:.35}.hero-shape-1{width:500px;height:500px;background:#4f46e5;top:-100px;right:-100px;animation:float1 12s ease-in-out infinite}.hero-shape-2{width:400px;height:400px;background:#7c3aed;bottom:-50px;left:-100px;animation:float2 15s ease-in-out infinite}.hero-shape-3{width:300px;height:300px;background:#06b6d4;top:40%;left:50%;animation:float3 10s ease-in-out infinite}@keyframes float1{0%,to{transform:translate(0)}50%{transform:translate(-40px,30px)}}@keyframes float2{0%,to{transform:translate(0)}50%{transform:translate(30px,-40px)}}@keyframes float3{0%,to{transform:translate(0)}50%{transform:translate(-20px,-30px)}}.hero-content{flex:1;position:relative;z-index:1;animation:fadeInUp .8s ease-out}.hero-badge{display:inline-block;padding:.4rem 1rem;border-radius:9999px;background:#4f46e526;border:1px solid rgba(79,70,229,.3);color:#a5b4fc;font-size:.85rem;font-weight:500;margin-bottom:1.5rem}.hero-title{font-size:3.2rem;font-weight:800;line-height:1.15;color:#fff;margin-bottom:1.5rem;letter-spacing:-.02em}.hero-gradient-text{background:linear-gradient(135deg,#818cf8,#c084fc,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.15rem;color:#fff9;line-height:1.7;max-width:500px;margin-bottom:2rem}.hero-actions{display:flex;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.hero-cta{background:linear-gradient(135deg,#4f46e5,#7c3aed)!important;box-shadow:0 4px 20px #4f46e566;font-size:1rem!important;padding:.85rem 2rem!important;border-radius:12px!important}.hero-cta:hover{box-shadow:0 6px 30px #4f46e599!important;transform:translateY(-2px)!important}.hero-cta-secondary{color:#ffffffb3!important;border-color:#ffffff26!important}.hero-cta-secondary:hover{background:#ffffff0d!important;color:#fff!important;text-decoration:none!important}.hero-stats{display:flex;align-items:center;gap:1.5rem}.hero-stat-num{display:block;font-size:1.5rem;font-weight:800;color:#fff}.hero-stat-label{font-size:.8rem;color:#ffffff73;text-transform:uppercase;letter-spacing:.05em}.hero-stat-divider{width:1px;height:40px;background:#ffffff1a}.hero-image-wrapper{flex:1;position:relative;z-index:1;animation:fadeInUp 1s ease-out .2s both}.hero-image{width:100%;max-width:540px;border-radius:20px;box-shadow:0 20px 60px #00000080}.hero-image-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:30px;background:radial-gradient(ellipse at center,rgba(79,70,229,.2),transparent 70%);z-index:-1}.landing-section{max-width:1200px;margin:0 auto;padding:6rem 2rem;position:relative}.section-tag{display:inline-block;padding:.3rem .8rem;border-radius:6px;background:#4f46e51a;color:#a5b4fc;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}.section-title{font-size:2.2rem;font-weight:800;color:#fff;margin-bottom:1rem;letter-spacing:-.01em}.section-desc{font-size:1.05rem;color:#ffffff8c;line-height:1.7;max-width:600px;margin-bottom:2.5rem}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.feature-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:2rem;transition:all .3s ease}.feature-card:hover{background:#ffffff0f;border-color:#4f46e54d;transform:translateY(-4px);box-shadow:0 8px 30px #0000004d}.feature-icon{width:50px;height:50px;border-radius:12px;background:#4f46e51f;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.25rem}.feature-title{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.5rem}.feature-desc{font-size:.9rem;color:#ffffff80;line-height:1.6}.landing-preview,.landing-security,.landing-mobile,.landing-reporting{display:flex;align-items:center;gap:4rem}.preview-content,.security-content,.mobile-content,.reporting-content,.preview-image-wrapper,.security-image-wrapper,.mobile-image-wrapper,.reporting-image-wrapper{flex:1}.preview-image,.security-image,.mobile-image,.reporting-image{width:100%;border-radius:16px;box-shadow:0 15px 50px #0006}.preview-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.preview-list li{font-size:.95rem;color:#ffffffa6;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.security-features{display:flex;flex-direction:column;gap:1rem}.security-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-radius:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);transition:all .2s}.security-item:hover{background:#ffffff0d;border-color:#4f46e533}.security-item-icon{font-size:1.5rem;flex-shrink:0;margin-top:2px}.security-item strong{color:#fff;font-size:.95rem}.security-item span{color:#ffffff80;font-size:.85rem}.landing-vision{text-align:center}.vision-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:3rem;text-align:left}.vision-card{background:linear-gradient(145deg,#ffffff0a,#ffffff03);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:1.75rem;transition:all .3s}.vision-card:hover{border-color:#7c3aed4d;transform:translateY(-4px);box-shadow:0 8px 30px #7c3aed26}.vision-icon{font-size:2rem;margin-bottom:1rem}.vision-title{font-size:1rem;font-weight:700;color:#fff;margin-bottom:.5rem}.vision-desc{font-size:.85rem;color:#ffffff80;line-height:1.6}.vision-full-image{width:100%;max-width:800px;border-radius:16px;box-shadow:0 15px 50px #0006;margin:0 auto;display:block}.landing-login-section{position:relative;padding:6rem 2rem;overflow:hidden}.login-section-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#1e1b4b,#312e81,#4338ca);opacity:.5}.login-section-inner{position:relative;z-index:1;max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:4rem}.login-section-text{flex:1}.login-section-features{display:flex;flex-direction:column;gap:.75rem;margin-top:2rem}.lsf-item{display:flex;align-items:center;gap:.75rem;color:#ffffffa6;font-size:.95rem}.lsf-item span{font-size:1.2rem}.login-section-form-wrapper{flex:0 0 400px}.login-section-card{background:#fffffff2;border-radius:20px;padding:2.5rem;box-shadow:0 20px 60px #0006}.login-section-logo{text-align:center;font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,#4f46e5,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:2rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-section-logo span{-webkit-text-fill-color:#7c3aed;font-size:1.6rem}.login-section-card .form-input{background:#f8fafc}.landing-footer{background:#0006;border-top:1px solid rgba(255,255,255,.06);padding:4rem 2rem 0}.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem}.footer-logo{font-size:1.3rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.footer-logo span{color:#a78bfa;font-size:1.5rem}.footer-tagline{color:#ffffff73;font-size:.9rem}.footer-links-group h4{color:#fff;font-size:.9rem;font-weight:600;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.footer-links-group a{display:block;color:#ffffff80;text-decoration:none;font-size:.9rem;padding:.3rem 0;transition:color .2s}.footer-links-group a:hover{color:#a5b4fc;text-decoration:none}.footer-social{display:flex;gap:.75rem;flex-wrap:wrap}.social-link{width:40px;height:40px;border-radius:10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#ffffff8c;transition:all .2s}.social-link:hover{background:#4f46e533;border-color:#4f46e566;color:#a5b4fc;transform:translateY(-2px)}.footer-bottom{border-top:1px solid rgba(255,255,255,.06);max-width:1200px;margin:0 auto;padding:1.5rem 0;display:flex;align-items:center;justify-content:space-between}.footer-bottom p{color:#ffffff59;font-size:.85rem}.footer-dua{font-family:Times New Roman,serif;font-size:1rem!important;color:#a78bfa80!important;direction:rtl}@media(max-width:1024px){.landing-hero{flex-direction:column;text-align:center;gap:2rem}.hero-subtitle{margin-left:auto;margin-right:auto}.hero-actions,.hero-stats{justify-content:center}.hero-image{max-width:420px;margin:0 auto}.features-grid,.vision-grid{grid-template-columns:repeat(2,1fr)}.landing-preview,.landing-security,.landing-mobile,.landing-reporting{flex-direction:column;gap:2rem}.login-section-inner{flex-direction:column;text-align:center}.login-section-form-wrapper{flex:none;width:100%;max-width:420px}.footer-inner{grid-template-columns:1fr 1fr}}@media(max-width:640px){.hero-title{font-size:2.2rem}.section-title{font-size:1.7rem}.features-grid,.vision-grid{grid-template-columns:1fr}.hero-stats{flex-direction:column;gap:1rem}.hero-stat-divider{display:none}.landing-nav-links a:not(.btn){display:none}.footer-inner{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:.5rem;text-align:center}}
