:root{--color-brand:#6366f1;--color-brand-light:#818cf8;--color-brand-dark:#4f46e5;--color-brand-glow:#6366f11f;--color-brand-subtle:#6366f10f;--color-accent:#06b6a4;--color-accent-light:#2dd4bf;--color-accent-dark:#0d9488;--color-success:#10b981;--color-warning:#f0a030;--color-danger:#f04438;--color-info:#6366f1;--color-bg-primary:#09090f;--color-bg-secondary:#111118;--color-bg-tertiary:#19191f;--color-bg-elevated:#1a1a24;--color-bg-glass:#111118bf;--color-bg-hover:#6366f10f;--color-bg-subtle:#ffffff05;--color-border:#ffffff0f;--color-border-hover:#ffffff1f;--color-border-active:#6366f159;--color-border-subtle:#ffffff08;--color-text-primary:#ececf1;--color-text-secondary:#8e8ea0;--color-text-muted:#5a5a72;--color-text-inverse:#111118;--shadow-xs:0 1px 2px #0000003d;--shadow-sm:0 1px 3px #0000004d, 0 1px 2px -1px #0000004d;--shadow-md:0 4px 6px -1px #00000059, 0 2px 4px -2px #00000059;--shadow-lg:0 10px 15px -3px #00000059, 0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #00000073, 0 8px 10px -6px #0000004d;--shadow-2xl:0 25px 50px -12px #0000008c;--shadow-glow:0 0 24px #6366f11f, 0 0 48px #6366f10f;--shadow-card:0 0 0 1px var(--color-border), 0 1px 3px #0003;--shadow-card-hover:0 0 0 1px var(--color-border-hover), 0 8px 24px #00000040;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-2xs:.6875rem;--font-size-xs:.75rem;--font-size-sm:.8125rem;--font-size-base:.875rem;--font-size-md:.9375rem;--font-size-lg:1.0625rem;--font-size-xl:1.25rem;--font-size-2xl:1.625rem;--font-size-3xl:2rem;--font-size-4xl:2.5rem;--font-size-5xl:3.25rem;--font-size-display:4rem;--line-height-tight:1.15;--line-height-snug:1.3;--line-height-normal:1.5;--line-height-relaxed:1.65;--line-height-loose:1.8;--letter-spacing-tight:-.025em;--letter-spacing-normal:-.011em;--letter-spacing-wide:.025em;--letter-spacing-wider:.06em;--space-0:0;--space-px:1px;--space-0-5:.125rem;--space-1:.25rem;--space-1-5:.375rem;--space-2:.5rem;--space-2-5:.625rem;--space-3:.75rem;--space-3-5:.875rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-7:1.75rem;--space-8:2rem;--space-9:2.25rem;--space-10:2.5rem;--space-12:3rem;--space-14:3.5rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;--radius-xs:4px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-3xl:24px;--radius-full:9999px;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--sidebar-width:272px;--sidebar-collapsed:76px;--header-height:68px;--max-content-width:1360px;--page-padding-x:var(--space-8);--page-padding-y:var(--space-8)}[data-theme=light]{--color-bg-primary:#fafafa;--color-bg-secondary:#fff;--color-bg-tertiary:#f5f5f7;--color-bg-elevated:#fff;--color-bg-glass:#fafafad9;--color-bg-hover:#6366f10a;--color-bg-subtle:#00000004;--color-border:#0000000f;--color-border-hover:#0000001f;--color-border-active:#6366f159;--color-border-subtle:#00000008;--color-text-primary:#1d1d1f;--color-text-secondary:#6e6e73;--color-text-muted:#aeaeb2;--color-text-inverse:#fff;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px -1px #0000000f;--shadow-md:0 4px 8px -2px #0000000f, 0 2px 4px -2px #0000000a;--shadow-lg:0 12px 24px -4px #00000014, 0 4px 8px -4px #0000000a;--shadow-xl:0 24px 48px -12px #0000001f;--shadow-2xl:0 32px 64px -16px #00000024;--shadow-glow:0 0 24px #6366f10f;--shadow-card:0 0 0 1px var(--color-border), 0 1px 3px #0000000a;--shadow-card-hover:0 0 0 1px var(--color-border-hover), 0 8px 24px #00000014}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);letter-spacing:var(--letter-spacing-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100vh;transition:background-color var(--transition-slow), color var(--transition-slow);font-feature-settings:"cv02", "cv03", "cv04", "cv11"}a{color:var(--color-brand);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-brand-light)}img{max-width:100%;display:block}input,textarea,select,button{font-family:inherit;font-size:inherit;letter-spacing:inherit}::selection{background:var(--color-brand);color:#fff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #f0443859}50%{box-shadow:0 0 0 10px #f0443800}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes gradient-shift{0%,to{background-position:0%}50%{background-position:100%}}@keyframes subtle-pulse{0%,to{opacity:1}50%{opacity:.7}}.fade-in{animation:fadeIn var(--transition-base) var(--ease-out-expo) forwards}.fade-in-up{animation:fadeInUp .45s var(--ease-out-expo) forwards}.fade-in-down{animation:fadeInDown .45s var(--ease-out-expo) forwards}.slide-in-left{animation:slideInLeft .4s var(--ease-out-expo) forwards}.slide-in-right{animation:slideInRight .4s var(--ease-out-expo) forwards}.scale-in{animation:scaleIn .3s var(--ease-out-expo) forwards}.stagger-children>*{opacity:0;animation:fadeInUp .45s var(--ease-out-expo) forwards}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}.stagger-children>:nth-child(7){animation-delay:.3s}.stagger-children>:nth-child(8){animation-delay:.35s}.text-2xs{font-size:var(--font-size-2xs)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-4xl{font-size:var(--font-size-4xl)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-brand{color:var(--color-brand)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.font-light{font-weight:300}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.grid{display:grid}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.px-8{padding-left:var(--space-8);padding-right:var(--space-8)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.ml-auto{margin-left:auto}
.btn{justify-content:center;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);letter-spacing:var(--letter-spacing-normal);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;padding:11px 22px;font-weight:550;line-height:1;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn:active:not(:disabled){transition-duration:80ms;transform:scale(.975)}.btn-primary{background:var(--color-brand);color:#fff;border-color:var(--color-brand);box-shadow:0 1px 2px #0003,inset 0 1px #ffffff1f}.btn-primary:hover:not(:disabled){background:var(--color-brand-dark);box-shadow:var(--shadow-glow), 0 2px 4px #0003;transform:translateY(-1px)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-border);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-elevated);border-color:var(--color-border-hover);transform:translateY(-1px)}.btn-success{background:var(--color-success);color:#fff;box-shadow:0 1px 2px #0003,inset 0 1px #ffffff1f}.btn-success:hover:not(:disabled){background:var(--color-accent-dark);transform:translateY(-1px)}.btn-danger{background:var(--color-danger);color:#fff;box-shadow:0 1px 2px #0003,inset 0 1px #ffffff1a}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary)}.btn-outline{color:var(--color-brand);border-color:var(--color-border);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-brand-subtle);border-color:var(--color-brand)}.btn-sm{font-size:var(--font-size-xs);border-radius:var(--radius-md);padding:7px 14px}.btn-lg{font-size:var(--font-size-md);border-radius:var(--radius-xl);padding:15px 32px}.btn-xl{font-size:var(--font-size-md);border-radius:var(--radius-xl);padding:18px 40px;font-weight:600}.btn-icon{min-width:40px;min-height:40px;padding:10px}.btn-icon.btn-sm{min-width:32px;min-height:32px;padding:7px}.card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-7);transition:all var(--transition-base);box-shadow:var(--shadow-card)}.card-hover:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.card-glass{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(16px)saturate(1.5);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-7)}.card-stat{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-7);gap:var(--space-4);transition:all .25s var(--ease-out-expo);box-shadow:var(--shadow-card);flex-direction:column;display:flex;position:relative;overflow:hidden}.card-stat:before{content:"";background:linear-gradient(90deg, var(--stat-color,var(--color-brand)), transparent);opacity:0;height:2px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.card-stat:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-card-hover);transform:translateY(-3px)}.card-stat:hover:before{opacity:1}.card-stat .stat-icon{border-radius:var(--radius-lg);background:var(--stat-color-bg,var(--color-brand-glow));width:44px;height:44px;color:var(--stat-color,var(--color-brand));justify-content:center;align-items:center;display:flex}.card-stat .stat-value{font-size:var(--font-size-3xl);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary);font-weight:700;line-height:1}.card-stat .stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-normal);font-weight:450}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-normal);font-weight:500}.form-label .required{color:var(--color-danger);margin-left:3px}.form-input,.form-select,.form-textarea{width:100%;font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);box-shadow:var(--shadow-xs);outline:none;padding:12px 16px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-brand);box-shadow:0 0 0 3px var(--color-brand-glow), var(--shadow-xs)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input.error,.form-select.error{border-color:var(--color-danger);box-shadow:0 0 0 3px #f0443814}.form-error{font-size:var(--font-size-xs);color:var(--color-danger)}.form-textarea{resize:vertical;min-height:110px;line-height:var(--line-height-normal)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235A5A72' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}.badge{font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-wide);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:5px;padding:4px 12px;font-weight:600;line-height:1.4;display:inline-flex}.badge-success{color:var(--color-success);background:#0fcc921a}.badge-warning{color:var(--color-warning);background:#f0a0301a}.badge-danger{color:var(--color-danger);background:#f044381a}.badge-info{color:var(--color-info);background:#6366f11a}.badge-muted{color:var(--color-text-muted);background:#5a5a721a}.badge-dot:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.table-container{border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-card);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-text-muted);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:14px 20px;font-weight:600}.table td{font-size:var(--font-size-sm);color:var(--color-text-primary);border-bottom:1px solid var(--color-border-subtle);vertical-align:middle;padding:16px 20px}.table tr:last-child td{border-bottom:none}.table tr{transition:background-color var(--transition-fast)}.table tr:hover td{background:var(--color-bg-hover)}.table .visitor-info{align-items:center;gap:var(--space-3);display:flex}.table .visitor-avatar{border-radius:var(--radius-full);object-fit:cover;background:linear-gradient(135deg, var(--color-bg-tertiary), var(--color-bg-elevated));width:38px;height:38px;font-weight:600;font-size:var(--font-size-xs);color:var(--color-text-secondary);border:1px solid var(--color-border);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.table .visitor-avatar img{object-fit:cover;width:100%;height:100%}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;padding:var(--space-6);animation:fadeIn .2s var(--ease-out-expo);background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-2xl);width:100%;max-width:580px;max-height:90vh;animation:scaleIn .28s var(--ease-out-expo);box-shadow:var(--shadow-2xl);overflow-y:auto}.modal-lg{max-width:740px}.modal-header{padding:var(--space-6) var(--space-7);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-header h2{font-size:var(--font-size-lg);letter-spacing:var(--letter-spacing-tight);font-weight:600}.modal-body{padding:var(--space-7)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-7);border-top:1px solid var(--color-border);display:flex}.toast{top:var(--space-5);right:var(--space-5);z-index:2000;gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast-item{align-items:center;gap:var(--space-3);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);animation:slideInRight .3s var(--ease-out-expo);min-width:340px;max-width:440px;padding:16px 20px;display:flex}.toast-item.toast-success{border-left:3px solid var(--color-success)}.toast-item.toast-error{border-left:3px solid var(--color-danger)}.toast-item.toast-warning{border-left:3px solid var(--color-warning)}.toast-item.toast-info{border-left:3px solid var(--color-info)}.avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-brand), var(--color-brand-dark));width:40px;height:40px;font-weight:600;font-size:var(--font-size-sm);color:#fff;box-shadow:0 0 0 2px var(--color-bg-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.avatar-sm{width:34px;height:34px;font-size:var(--font-size-xs)}.avatar-lg{width:56px;height:56px;font-size:var(--font-size-lg)}.avatar-xl{width:80px;height:80px;font-size:var(--font-size-2xl)}.avatar img{object-fit:cover;width:100%;height:100%}.search-bar{width:100%;max-width:420px;position:relative}.search-bar .search-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-bar .form-input{padding-left:42px}.pagination{align-items:center;gap:var(--space-1);display:flex}.pagination button{border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:38px;height:38px;color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;font-weight:500;display:flex}.pagination button:hover{background:var(--color-bg-hover);border-color:var(--color-border-hover)}.pagination button.active{background:var(--color-brand);border-color:var(--color-brand);color:#fff;box-shadow:0 1px 3px #6366f14d}.pagination button:disabled{opacity:.35;cursor:not-allowed}.empty-state{padding:var(--space-20) var(--space-10);text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{width:56px;height:56px;margin-bottom:var(--space-5);opacity:.3}.empty-state h3{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--space-2);letter-spacing:var(--letter-spacing-tight);font-weight:600}.empty-state p{font-size:var(--font-size-sm);max-width:380px;line-height:var(--line-height-relaxed)}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-brand);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-lg{border-width:3px;width:40px;height:40px}.loading-screen{justify-content:center;align-items:center;gap:var(--space-5);flex-direction:column;min-height:100vh;display:flex}.tabs{gap:var(--space-1);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-8);display:flex}.tab{padding:var(--space-3) var(--space-5);font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-weight:500}.tab:hover{color:var(--color-text-primary)}.tab.active{color:var(--color-brand);border-bottom-color:var(--color-brand)}.dropdown{position:relative}.dropdown-menu{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);min-width:220px;padding:var(--space-2);box-shadow:var(--shadow-xl);z-index:100;animation:scaleIn .15s var(--ease-out-expo);position:absolute;top:calc(100% + 6px);right:0}.dropdown-item{align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;text-align:left;width:100%;transition:all var(--transition-fast);background:0 0;border:none;padding:10px 14px;display:flex}.dropdown-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.dropdown-divider{background:var(--color-border);height:1px;margin:var(--space-2) 0}.toggle{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;width:48px;height:26px;transition:all var(--transition-fast);position:relative}.toggle.active{background:var(--color-brand);border-color:var(--color-brand)}.toggle:after{content:"";width:20px;height:20px;transition:transform .2s var(--ease-out-expo);box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px}.toggle.active:after{transform:translate(22px)}.camera-container{aspect-ratio:4/3;background:var(--color-bg-primary);border:2px dashed var(--color-border-hover);border-radius:var(--radius-xl);justify-content:center;align-items:center;width:100%;max-width:400px;display:flex;position:relative;overflow:hidden}.camera-container video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.camera-container .camera-placeholder{align-items:center;gap:var(--space-3);color:var(--color-text-muted);flex-direction:column;display:flex}.camera-controls{justify-content:center;align-items:center;gap:var(--space-4);margin-top:var(--space-5);display:flex}.capture-btn{background:var(--color-brand);cursor:pointer;width:60px;height:60px;transition:all var(--transition-fast);box-shadow:var(--shadow-md);border:4px solid #fff;border-radius:50%}.capture-btn:hover{background:var(--color-brand-dark);transform:scale(1.08)}.capture-btn:active{transform:scale(.95)}.signature-pad{border:2px solid var(--color-border);border-radius:var(--radius-xl);cursor:crosshair;touch-action:none;background:#fff;width:100%;max-width:500px;height:200px}.photo-preview{border-radius:var(--radius-xl);border:2px solid var(--color-border);width:120px;height:120px;position:relative;overflow:hidden}.photo-preview img{object-fit:cover;width:100%;height:100%}.photo-preview .remove-btn{color:#fff;cursor:pointer;width:26px;height:26px;transition:background var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:6px;right:6px}.photo-preview .remove-btn:hover{background:var(--color-danger)}.section-divider{background:var(--color-border);height:1px;margin:var(--space-8) 0}@media (max-width:1024px){.hide-tablet{display:none!important}}@media (max-width:768px){.hide-mobile{display:none!important}.modal{max-width:100%;margin:var(--space-4);max-height:calc(100vh - 32px)}.table-container{font-size:var(--font-size-xs)}.table th,.table td{padding:10px 14px}}@media (max-width:480px){.card{padding:var(--space-5)}.btn{padding:10px 18px}}
.auth-page{min-height:100vh;display:flex}.auth-left{padding:var(--space-12);flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.auth-right{padding:var(--space-8);background:linear-gradient(135deg,#0b0f1a 0%,#1a2744 50%,#0d1b2a 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-right:before{content:"";background:radial-gradient(circle,#3b82f614 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.auth-right .brand-text{z-index:1;text-align:center;position:relative}.auth-right .brand-text h1{font-size:var(--font-size-4xl);background:linear-gradient(135deg,#60a5fa,#3b82f6,#10b981);-webkit-text-fill-color:transparent;margin-bottom:var(--space-4);-webkit-background-clip:text;background-clip:text;font-weight:800}.auth-right .brand-text p{font-size:var(--font-size-lg);color:#fff9;max-width:400px;line-height:1.7}.auth-form{width:100%;max-width:440px}.auth-form .logo{font-size:var(--font-size-2xl);background:linear-gradient(135deg, var(--color-brand), var(--color-accent));-webkit-text-fill-color:transparent;margin-bottom:var(--space-2);-webkit-background-clip:text;background-clip:text;font-weight:800}.auth-form h2{font-size:var(--font-size-2xl);margin-bottom:var(--space-2);letter-spacing:-.025em;font-weight:700}.auth-form .subtitle{color:var(--color-text-secondary);margin-bottom:var(--space-8)}.auth-form .form-group+.form-group{margin-top:var(--space-5)}.auth-form .submit-btn{margin-top:var(--space-8);width:100%}.auth-form .auth-footer{margin-top:var(--space-6);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auth-form .auth-footer a{color:var(--color-brand);font-weight:500}.auth-error{border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-sm);margin-bottom:var(--space-4);align-items:center;gap:var(--space-2);background:#ef44441a;border:1px solid #ef444433;padding:12px 16px;display:flex}@media (max-width:768px){.auth-right{display:none}.auth-left{padding:var(--space-6)}}.dashboard-layout{background:var(--color-bg-primary);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);z-index:50;transition:width var(--transition-base), transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{padding:var(--space-6) var(--space-6);border-bottom:1px solid var(--color-border);align-items:center;gap:var(--space-3);height:var(--header-height);display:flex}.sidebar-brand .brand-name{font-size:var(--font-size-xl);background:linear-gradient(135deg, var(--color-brand), var(--color-accent));-webkit-text-fill-color:transparent;white-space:nowrap;-webkit-background-clip:text;background-clip:text;font-weight:800}.sidebar.collapsed .brand-name{display:none}.sidebar-nav{padding:var(--space-5) var(--space-4);gap:var(--space-1-5,6px);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);padding:var(--space-3) var(--space-3) var(--space-1);font-size:10px;font-weight:600}.sidebar.collapsed .sidebar-section-label{display:none}.nav-item{align-items:center;gap:var(--space-3);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left;white-space:nowrap;background:0 0;border:none;width:100%;padding:11px 14px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item.active{background:var(--color-brand-glow);color:var(--color-brand)}.nav-item .nav-icon{flex-shrink:0;width:20px;height:20px}.nav-item .nav-label{flex:1}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-badge{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.nav-badge{background:var(--color-danger);color:#fff;border-radius:var(--radius-full);padding:2px 6px;font-size:10px;font-weight:700;line-height:1}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--color-border)}.dashboard-main{margin-left:var(--sidebar-width);transition:margin-left var(--transition-base);flex-direction:column;flex:1;min-height:100vh;display:flex}.sidebar.collapsed~.dashboard-main{margin-left:var(--sidebar-collapsed)}.dashboard-header{height:var(--header-height);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);padding:0 var(--space-6);z-index:40;-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:var(--space-4);display:flex}.header-left .page-title{font-size:var(--font-size-lg);font-weight:600}.header-right{align-items:center;gap:var(--space-3);display:flex}.notification-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex;position:relative}.notification-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.notification-btn .notif-dot{background:var(--color-danger);border:2px solid var(--color-bg-secondary);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.theme-toggle{border-radius:var(--radius-md);border:1px solid var(--color-border);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--color-bg-hover);color:var(--color-text-primary);transform:scale(1.05)}.user-menu{align-items:center;gap:var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);padding:6px 12px;display:flex}.user-menu:hover{background:var(--color-bg-hover)}.user-menu .user-info{text-align:right}.user-menu .user-name{font-size:var(--font-size-sm);font-weight:600}.user-menu .user-role{font-size:var(--font-size-xs);color:var(--color-text-muted)}.dashboard-content{padding:var(--space-8) var(--space-10);max-width:var(--max-content-width);flex:1;width:100%}.page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-header h1{font-size:var(--font-size-2xl);letter-spacing:-.025em;font-weight:700}.page-header .subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-2)}.page-header-actions{align-items:center;gap:var(--space-3);display:flex}.stats-grid{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));display:grid}.filter-bar{align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.filter-bar .form-select{min-width:150px;font-size:var(--font-size-sm);padding:8px 32px 8px 12px}.checkin-page{max-width:800px;margin:0 auto}.checkin-steps{margin-bottom:var(--space-8);padding:0 var(--space-4);align-items:center;display:flex}.checkin-step{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted);display:flex}.checkin-step.active{color:var(--color-brand)}.checkin-step.completed{color:var(--color-success)}.checkin-step .step-number{width:28px;height:28px;font-weight:600;font-size:var(--font-size-xs);border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.checkin-step.active .step-number{background:var(--color-brand);border-color:var(--color-brand);color:#fff}.checkin-step.completed .step-number{background:var(--color-success);border-color:var(--color-success);color:#fff}.checkin-step-divider{background:var(--color-border);height:2px;margin:0 var(--space-3);flex:1}.checkin-form-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}@media (max-width:600px){.checkin-form-grid{grid-template-columns:1fr}}.analytics-grid{gap:var(--space-5);grid-template-columns:repeat(2,1fr);display:grid}.analytics-grid .chart-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-7);box-shadow:var(--shadow-card,var(--shadow-sm))}.analytics-grid .chart-card.full-width{grid-column:1/-1}.chart-card .chart-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.chart-card .chart-title{font-size:var(--font-size-md);font-weight:600}@media (max-width:768px){.analytics-grid{grid-template-columns:1fr}}.kiosk-page{min-height:100vh;padding:var(--space-8);text-align:center;background:var(--color-bg-primary);flex-direction:column;justify-content:center;align-items:center;display:flex}.kiosk-page .kiosk-logo{font-size:var(--font-size-4xl);background:linear-gradient(135deg, var(--color-brand), var(--color-accent));-webkit-text-fill-color:transparent;margin-bottom:var(--space-4);-webkit-background-clip:text;background-clip:text;font-weight:800}.kiosk-page .kiosk-welcome{font-size:var(--font-size-2xl);color:var(--color-text-secondary);margin-bottom:var(--space-10);max-width:500px}.kiosk-actions{gap:var(--space-6);display:flex}.kiosk-action-card{width:280px;padding:var(--space-10) var(--space-6);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base);text-align:center;color:inherit;text-decoration:none}.kiosk-action-card:hover{border-color:var(--color-brand);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.kiosk-action-card .kiosk-icon{border-radius:var(--radius-lg);width:64px;height:64px;margin:0 auto var(--space-4);background:var(--color-brand-glow);color:var(--color-brand);justify-content:center;align-items:center;display:flex}.kiosk-action-card h3{font-size:var(--font-size-xl);margin-bottom:var(--space-2);font-weight:600}.kiosk-action-card p{font-size:var(--font-size-sm);color:var(--color-text-secondary)}@media (max-width:768px){.kiosk-actions{flex-direction:column;width:100%;max-width:320px}.kiosk-action-card{width:100%}}.emergency-banner{color:#fff;padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);margin-bottom:var(--space-6);background:linear-gradient(135deg,#dc2626,#ef4444);justify-content:space-between;align-items:center;animation:2s infinite pulse-glow;display:flex}.emergency-banner h2{font-size:var(--font-size-xl);align-items:center;gap:var(--space-3);font-weight:700;display:flex}.emergency-count{font-size:var(--font-size-4xl);text-align:center;padding:var(--space-8);font-weight:800}.landing-page{min-height:100vh}.landing-nav{padding:var(--space-4) var(--space-8);z-index:100;-webkit-backdrop-filter:none;background:0 0;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;transition:background .3s,border-color .3s,-webkit-backdrop-filter .3s,backdrop-filter .3s;display:flex;position:fixed;top:0;left:0;right:0}.landing-nav.scrolled{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border)}.landing-nav .nav-brand{font-size:var(--font-size-xl);background:linear-gradient(135deg, var(--color-brand), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.landing-nav .nav-links{align-items:center;gap:var(--space-6);display:flex}.landing-nav .nav-links a{font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color var(--transition-fast);font-weight:500}.landing-nav .nav-links a:hover{color:var(--color-text-primary)}.landing-hero{align-items:center;gap:var(--space-12);padding:calc(var(--header-height) + var(--space-16)) var(--space-10) var(--space-12);grid-template-columns:1.2fr 1fr;max-width:1200px;margin:0 auto;display:grid;position:relative;overflow:hidden}.landing-hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f10f 0%,#0000 70%);border-radius:50%;width:800px;height:800px;position:absolute;top:50%;left:30%;transform:translate(-50%,-50%)}.hero-content{z-index:1;position:relative}.hero-badge{align-items:center;gap:var(--space-2);background:var(--color-brand-glow);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-brand);margin-bottom:var(--space-6);border:1px solid #6366f133;padding:6px 16px;font-weight:500;display:inline-flex}.landing-hero h1{margin-bottom:var(--space-6);letter-spacing:-.035em;font-size:clamp(2.25rem,4vw,3.5rem);font-weight:800;line-height:1.1}.landing-hero h1 .gradient-text{background:linear-gradient(135deg,#818cf8,#6366f1,#06b6a4);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-hero .hero-subtitle{font-size:var(--font-size-md);color:var(--color-text-secondary);max-width:480px;margin-bottom:var(--space-8);line-height:1.75}.hero-cta{gap:var(--space-4);margin-bottom:var(--space-6);display:flex}.hero-preview{z-index:1;position:relative}.hero-preview img{border-radius:var(--radius-xl);width:100%;transition:transform .4s,box-shadow .4s;transform:perspective(1200px)rotateY(-3deg)rotateX(1deg);box-shadow:0 20px 60px #00000026,0 8px 20px #00000014,0 0 0 1px #ffffff0d}.hero-preview img:hover{transform:perspective(1200px)rotateY(0)rotateX(0);box-shadow:0 25px 80px #6366f126,0 10px 30px #0000001a,0 0 0 1px #ffffff14}.landing-features{padding:var(--space-24,6rem) var(--space-10)}.landing-features h2{text-align:center;font-size:var(--font-size-3xl);margin-bottom:var(--space-12);font-weight:700}.features-grid{gap:var(--space-6);max-width:var(--max-content-width);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;display:grid}.feature-card{padding:var(--space-8);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all .3s var(--ease-out-expo,ease)}.feature-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.feature-card .feature-icon{border-radius:var(--radius-lg);width:52px;height:52px;margin-bottom:var(--space-5);background:var(--color-brand-glow);color:var(--color-brand);justify-content:center;align-items:center;display:flex}.feature-card h3{font-size:var(--font-size-md);margin-bottom:var(--space-2);letter-spacing:-.01em;font-weight:600}.feature-card p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.7}.settings-section{margin-bottom:var(--space-8)}.settings-section h3{font-size:var(--font-size-md);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border);font-weight:600}.settings-grid{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}@media (max-width:600px){.settings-grid{grid-template-columns:1fr}}.color-picker-group{align-items:center;gap:var(--space-3);display:flex}.color-picker-group input[type=color]{border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:0 0;width:40px;height:40px;padding:2px}@media (max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-xl);transform:translate(0)}.dashboard-main{margin-left:0!important}.mobile-overlay{z-index:45;background:#00000080;animation:.2s fadeIn;position:fixed;inset:0}.mobile-menu-btn{display:flex!important}.landing-nav .nav-links a:not(.btn){display:none}}.mobile-menu-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:none}.mobile-menu-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}@media (max-width:768px){.dashboard-content{padding:var(--space-4)}.stats-grid{gap:var(--space-3);grid-template-columns:1fr 1fr}.page-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.page-header h1{font-size:var(--font-size-xl)}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{min-width:600px}.filter-bar{gap:var(--space-3);flex-direction:column}.filter-bar .search-bar{max-width:100%!important}.notification-dropdown{width:calc(100vw - 32px);max-width:360px;right:-40px}.landing-nav{padding:var(--space-3) var(--space-4)}.landing-nav .nav-links{gap:var(--space-3)}.landing-nav .nav-links a:not(.btn){display:none}.landing-hero{padding:calc(var(--header-height) + var(--space-8)) var(--space-4) var(--space-8);gap:var(--space-8);text-align:center;grid-template-columns:1fr}.landing-hero h1{margin-bottom:var(--space-4);font-size:clamp(1.75rem,7vw,2.75rem)}.landing-hero .hero-subtitle{font-size:var(--font-size-sm);margin-bottom:var(--space-6);max-width:100%}.hero-cta{width:100%;max-width:300px;margin:0 auto var(--space-4);flex-direction:column}.hero-trust{flex-wrap:wrap;justify-content:center}.hero-preview img{transform:none}.hero-cta .btn{justify-content:center;width:100%}.hero-trust{flex-wrap:wrap;justify-content:center;gap:var(--space-4)!important}.landing-features{padding:var(--space-12) var(--space-4)}.landing-features h2{font-size:var(--font-size-2xl);margin-bottom:var(--space-8)}.features-grid{gap:var(--space-4);grid-template-columns:1fr}.feature-card{padding:var(--space-5)}#pricing{padding:var(--space-10) var(--space-4)!important}#pricing h2{font-size:var(--font-size-2xl)!important}footer>div>div:first-child{gap:var(--space-6)!important;grid-template-columns:1fr 1fr!important}.checkin-steps{gap:var(--space-1)}.checkin-step span{font-size:var(--font-size-2xs)}.camera-container{max-width:100%;height:280px}.overview-grid{grid-template-columns:1fr!important}.modal{max-height:calc(100dvh - 24px);max-width:calc(100vw - 24px)!important;margin:12px!important}.emergency-banner{text-align:center;gap:var(--space-3);flex-direction:column}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.dashboard-header{padding:0 var(--space-4)}.dashboard-content{padding:var(--space-3)}.card{padding:var(--space-4)}.btn{font-size:var(--font-size-xs);padding:10px 16px}.stat-card{padding:var(--space-4)}.stat-card .stat-value{font-size:var(--font-size-xl)}.btn .hide-mobile{display:none}.landing-hero h1{font-size:1.5rem}.hero-badge{font-size:var(--font-size-xs);padding:4px 12px}.landing-nav .btn-sm{font-size:var(--font-size-xs);padding:6px 12px}footer>div>div:first-child{grid-template-columns:1fr!important}.checkin-step-divider{margin:0 var(--space-1)}.step-number{width:28px;height:28px;font-size:11px}.kiosk-page{padding:var(--space-4)}.kiosk-page .kiosk-logo{font-size:var(--font-size-2xl)}.kiosk-page .kiosk-welcome{font-size:var(--font-size-lg)}}@media print{.sidebar,.dashboard-header,.page-header-actions,.filter-bar,.pagination,.btn,.theme-toggle,.notification-btn{display:none!important}.dashboard-main{margin-left:0!important}.dashboard-content{padding:0}body{color:#000;background:#fff}.card,.table-container{box-shadow:none;border:1px solid #ddd}}.badge-print{color:#111;width:86mm;height:54mm;font-family:var(--font-family);background:#fff;border:1px solid #ddd;border-radius:4px;flex-direction:column;justify-content:space-between;padding:8mm;display:flex}.badge-print .badge-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding-bottom:4mm;display:flex}.badge-print .badge-visitor-name{font-size:16px;font-weight:700}.badge-print .badge-company{color:#666;font-size:11px}.badge-print .badge-details{color:#444;flex-direction:column;gap:2px;font-size:10px;display:flex}.badge-print .badge-qr{width:60px;height:60px}
