@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-primary:#1a1a2e;--color-primary-light:#16213e;--color-primary-dark:#0f0f1a;--color-accent:#4a6fa5;--color-accent-hover:#3d5d8a;--color-accent-light:#6b8fc4;--color-surface:#f8fafc;--color-surface-elevated:#fff;--color-surface-hover:#f1f5f9;--color-surface-dark:#e2e8f0;--color-text-primary:#1e293b;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-text-inverse:#f8fafc;--color-border:#e2e8f0;--color-border-focus:#4a6fa5;--color-error:#dc2626;--color-error-bg:#fef2f2;--color-error-border:#fecaca;--color-success:#16a34a;--color-success-bg:#f0fdf4;--color-warning:#f59e0b;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000000d;--shadow-glow:0 0 20px #4a6fa526;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s cubic-bezier(.16, 1, .3, 1);--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--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;--space-16:4rem}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-surface);min-height:100vh;line-height:1.6}#root{min-height:100vh}.input-field{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-surface-elevated);border:1.5px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);outline:none}.input-field::placeholder{color:var(--color-text-muted)}.input-field:hover{border-color:var(--color-text-muted)}.input-field:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #4a6fa51f}.input-field.input-error{border-color:var(--color-error);box-shadow:0 0 0 3px #dc26261a}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-family);font-size:var(--font-size-base);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;font-weight:600;line-height:1.5;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{color:var(--color-text-inverse);background:linear-gradient(135deg, var(--color-accent), var(--color-accent-hover));box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--color-accent-hover), var(--color-primary-light));box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active:not(:disabled){box-shadow:var(--shadow-sm);transform:translateY(0)}.btn-secondary{color:var(--color-text-primary);background-color:var(--color-surface);border:1.5px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-surface-hover);border-color:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .5s var(--transition-slow) forwards}.animate-slide-up{animation:slideUp .6s var(--transition-slow) forwards}.animate-shake{animation:.5s ease-in-out shake}.login-page{min-height:100vh;padding:var(--space-4);background:linear-gradient(145deg, var(--color-primary-dark) 0%, var(--color-primary) 40%, var(--color-primary-light) 100%);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background-image:radial-gradient(circle at 20% 80%,#4a6fa514 0%,#0000 50%),radial-gradient(circle at 80% 20%,#4a6fa50f 0%,#0000 50%),radial-gradient(circle,#ffffff05 0%,#0000 70%);position:absolute;inset:0}.login-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#4a6fa51a 0%,#0000 70%);border-radius:50%;width:300px;height:300px;position:absolute;top:-100px;right:-100px}.login-card{background-color:var(--color-surface-elevated);border-radius:var(--radius-lg);width:100%;max-width:420px;padding:var(--space-10);box-shadow:var(--shadow-xl);z-index:1;animation:.7s cubic-bezier(.16,1,.3,1) forwards slideUp;position:relative}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{width:56px;height:56px;margin:0 auto var(--space-5);background:linear-gradient(135deg, var(--color-accent), var(--color-primary-light));border-radius:var(--radius-md);box-shadow:var(--shadow-md);justify-content:center;align-items:center;display:flex}.login-logo svg{color:var(--color-text-inverse)}.login-title{font-size:var(--font-size-2xl);color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:-.025em;font-weight:700}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:400}.login-form{gap:var(--space-5);flex-direction:column;display:flex}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:500}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{left:var(--space-3);color:var(--color-text-muted);pointer-events:none;transition:color var(--transition-fast);position:absolute}.input-wrapper .input-field{padding-left:calc(var(--space-3) + 24px + var(--space-2))}.input-wrapper:focus-within .input-icon{color:var(--color-accent)}.password-toggle{right:var(--space-3);color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);transition:color var(--transition-fast);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute}.password-toggle:hover{color:var(--color-text-secondary)}.form-error{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-sm);font-weight:500;animation:.3s forwards fadeIn;display:flex}.login-btn{width:100%;padding:var(--space-3) var(--space-6);margin-top:var(--space-2);font-size:var(--font-size-base);height:48px}.login-btn .spinner{border:2.5px solid #ffffff4d;border-top-color:var(--color-text-inverse);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}.login-footer{text-align:center;margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border)}.login-footer p{font-size:var(--font-size-xs);color:var(--color-text-muted)}.app-layout{background-color:var(--color-surface);min-height:100vh;display:flex}.sidebar{background-color:var(--color-primary);z-index:200;width:260px;min-height:100vh;transition:transform var(--transition-normal);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5);border-bottom:1px solid #ffffff14;display:flex}.sidebar-brand-icon{background:linear-gradient(135deg, var(--color-accent), var(--color-accent-hover));border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar-brand-icon svg{color:var(--color-text-inverse)}.sidebar-brand-text{font-size:var(--font-size-lg);color:var(--color-text-inverse);letter-spacing:-.025em;font-weight:700}.sidebar-close{color:#ffffff80;cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);background:0 0;border:none;margin-left:auto;display:none}.sidebar-close:hover{color:var(--color-text-inverse)}.sidebar-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.sidebar-nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:#fff9;border-radius:var(--radius-sm);font-size:var(--font-size-sm);transition:all var(--transition-fast);font-weight:500;text-decoration:none;display:flex}.sidebar-nav-item:hover{color:var(--color-text-inverse);background-color:#ffffff12}.sidebar-nav-item.active{color:var(--color-text-inverse);background-color:#4a6fa54d;font-weight:600}.sidebar-footer{padding:var(--space-4) var(--space-4);border-top:1px solid #ffffff14}.sidebar-user{align-items:center;gap:var(--space-3);display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-accent), var(--color-accent-hover));width:34px;height:34px;color:var(--color-text-inverse);font-size:var(--font-size-sm);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.sidebar-user-info{flex-direction:column;display:flex;overflow:hidden}.sidebar-user-name{font-size:var(--font-size-sm);color:var(--color-text-inverse);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-role{font-size:var(--font-size-xs);color:#ffffff73}.sidebar-overlay{z-index:190;background-color:#00000080;display:none;position:fixed;inset:0}.main-wrapper{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;display:flex}.top-header{padding:var(--space-4) var(--space-8);background-color:var(--color-surface-elevated);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);z-index:100;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.hamburger-btn{color:var(--color-text-primary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:background-color var(--transition-fast);background:0 0;border:none;display:none}.hamburger-btn:hover{background-color:var(--color-surface-hover)}.top-header-title{font-size:var(--font-size-lg);color:var(--color-text-primary);letter-spacing:-.015em;font-weight:600}.top-header-actions{align-items:center;gap:var(--space-4);display:flex}.top-header-user{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.main-content{padding:var(--space-8);flex:1;width:100%;max-width:1280px;margin:0 auto}.dashboard-welcome{margin-bottom:var(--space-6)}.dashboard-welcome h2{font-size:var(--font-size-3xl);color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:-.025em;font-weight:700}.dashboard-welcome p{font-size:var(--font-size-lg);color:var(--color-text-secondary)}.stats-grid{gap:var(--space-6);margin-top:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));display:grid}.stat-card{background-color:var(--color-surface-elevated);border-radius:var(--radius-md);padding:var(--space-6);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);animation:.5s forwards fadeIn}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-clickable{cursor:pointer}.stat-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.stat-card-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-card-icon.blue{color:var(--color-accent);background-color:#4a6fa51a}.stat-card-icon.green{color:var(--color-success);background-color:#16a34a1a}.stat-card-icon.amber{color:var(--color-warning);background-color:#f59e0b1a}.stat-card-icon.slate{color:var(--color-text-secondary);background-color:#1e293b14}.stat-card-title{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:600}.stat-card-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.module-page{animation:.4s forwards fadeIn}.module-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.module-header-left{align-items:center;gap:var(--space-4);display:flex}.module-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--color-accent), var(--color-accent-hover));width:48px;height:48px;color:var(--color-text-inverse);flex-shrink:0;justify-content:center;align-items:center;display:flex}.module-title{font-size:var(--font-size-2xl);color:var(--color-text-primary);letter-spacing:-.025em;font-weight:700}.module-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.module-filters{align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.search-box{flex:1;min-width:200px;max-width:360px;position:relative}.search-box .search-icon{left:var(--space-3);color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{padding-left:calc(var(--space-3) + 18px + var(--space-2))!important}.filter-tabs{gap:var(--space-1);background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:3px;display:flex}.filter-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;font-weight:500;display:flex}.filter-tab:hover{color:var(--color-text-primary);background-color:var(--color-surface-hover)}.filter-tab.active{color:var(--color-text-primary);background-color:var(--color-surface);box-shadow:var(--shadow-sm);font-weight:600}.filter-badge{font-size:var(--font-size-xs);border-radius:var(--radius-full);background-color:var(--color-surface-dark);color:var(--color-text-secondary);padding:1px 7px;font-weight:600}.filter-badge.green{background-color:var(--color-success-bg);color:var(--color-success)}.filter-badge.red{background-color:var(--color-error-bg);color:var(--color-error)}.module-loading{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-16) 0;color:var(--color-text-secondary);font-size:var(--font-size-base);display:flex}.spinner-icon{animation:.8s linear infinite spin}.module-error{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);font-weight:500;display:flex}.module-empty{padding:var(--space-16) var(--space-8);text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.module-empty h3{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-top:var(--space-4);margin-bottom:var(--space-2);font-weight:600}.module-empty p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-6)}.table-container{background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead{background-color:var(--color-surface);border-bottom:1px solid var(--color-border)}.data-table th{padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);text-align:left;white-space:nowrap;font-weight:600}.data-table td{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-primary);border-bottom:1px solid var(--color-border);vertical-align:middle}.data-table tbody tr{transition:background-color var(--transition-fast)}.data-table tbody tr:hover{background-color:var(--color-surface-hover)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tr.row-inactive{opacity:.55}.data-table tr.row-inactive:hover{opacity:.75}.th-id{width:70px}.th-status{width:120px}.th-actions{width:120px;text-align:center!important}.td-id{color:var(--color-text-muted);font-weight:600;font-size:var(--font-size-xs)}.td-name{font-weight:500}.cell-with-icon{align-items:center;gap:var(--space-2);display:flex}.cell-icon{color:var(--color-text-muted);flex-shrink:0}.status-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);letter-spacing:.01em;align-items:center;padding:2px 10px;font-weight:600;display:inline-flex}.status-badge.active{background-color:var(--color-success-bg);color:var(--color-success)}.status-badge.inactive{background-color:var(--color-error-bg);color:var(--color-error)}.action-buttons{justify-content:center;align-items:center;gap:var(--space-2);display:flex}.action-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-elevated);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.edit{color:var(--color-accent)}.action-btn.edit:hover:not(:disabled){border-color:var(--color-accent);background-color:#4a6fa51a}.action-btn.toggle.deactivate{color:var(--color-error)}.action-btn.toggle.deactivate:hover:not(:disabled){background-color:var(--color-error-bg);border-color:var(--color-error)}.action-btn.toggle.activate{color:var(--color-success)}.action-btn.toggle.activate:hover:not(:disabled){background-color:var(--color-success-bg);border-color:var(--color-success)}.table-footer{padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:right;margin-top:var(--space-3)}.modal-overlay{z-index:500;padding:var(--space-4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background-color:var(--color-surface-elevated);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-xl);overflow:hidden}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-lg);color:var(--color-text-primary);letter-spacing:-.015em;font-weight:700}.modal-close{width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background-color:var(--color-surface-hover);color:var(--color-text-primary)}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);background-color:var(--color-surface);display:flex}.form-field-error{align-items:center;gap:var(--space-2);margin-top:var(--space-2);color:var(--color-error);font-size:var(--font-size-xs);font-weight:500;display:flex}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm)}.toast-success{bottom:var(--space-6);right:var(--space-6);align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:var(--color-success);color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);box-shadow:var(--shadow-lg);z-index:600;font-weight:500;animation:.3s forwards slideUp;display:flex;position:fixed}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-close{display:flex}.sidebar-overlay{display:block}.main-wrapper{margin-left:0}.hamburger-btn{display:flex}.main-content{padding:var(--space-4)}.top-header{padding:var(--space-3) var(--space-4)}.top-header-user{display:none}.module-header{flex-direction:column;align-items:flex-start}.module-filters{flex-direction:column;align-items:stretch}.search-box{max-width:100%}.filter-tabs{justify-content:center;width:100%}.stats-grid{grid-template-columns:1fr}.dashboard-welcome h2{font-size:var(--font-size-2xl)}.table-container{overflow-x:auto}.data-table{min-width:500px}.toast-success{left:var(--space-4);right:var(--space-4);bottom:var(--space-4)}}@media (width<=480px){.login-page{padding:var(--space-3)}.login-card{padding:var(--space-5) var(--space-4);border-radius:var(--radius-md);max-width:100%}.login-title{font-size:var(--font-size-xl)}.modal-card{margin:var(--space-4)}}
