*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary-50: #eef2ff;--primary-100: #e0e7ff;--primary-200: #c7d2fe;--primary-500: #6366f1;--primary-600: #4f46e5;--primary-700: #4338ca;--primary-color: var(--primary-500);--primary-hover: var(--primary-600);--accent-500: #8b5cf6;--accent-600: #7c3aed;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--secondary-color: var(--gray-500);--success-color: #16a34a;--success-soft: #dcfce7;--success-soft-2:#bbf7d0;--success-strong:#15803d;--warning-color: #d97706;--warning-soft: #fef3c7;--warning-soft-2:#fde68a;--warning-strong:#b45309;--danger-color: #dc2626;--danger-soft: #fef2f2;--danger-soft-2: #fee2e2;--danger-strong: #b91c1c;--info-color: #2563eb;--info-soft: #dbeafe;--info-soft-2: #bfdbfe;--info-strong: #1d4ed8;--text-primary: var(--gray-800);--text-secondary: var(--gray-500);--text-muted: var(--gray-400);--text-inverse: #ffffff;--bg-primary: #ffffff;--bg-secondary: var(--gray-50);--bg-tertiary: var(--gray-100);--bg-app: #f5f7fb;--border-color: var(--gray-200);--border-strong:var(--gray-300);--radius-sm: 6px;--radius: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl:20px;--radius-pill: 999px;--border-radius: var(--radius);--border-radius-lg: var(--radius-lg);--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .04);--shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 6px -1px rgba(15, 23, 42, .08), 0 2px 4px -2px rgba(15, 23, 42, .05);--shadow-lg: 0 10px 20px -6px rgba(15, 23, 42, .12), 0 4px 8px -4px rgba(15, 23, 42, .06);--shadow-xl: 0 24px 48px -12px rgba(15, 23, 42, .18);--shadow-primary: 0 6px 16px -4px rgba(99, 102, 241, .35);--shadow-focus: 0 0 0 4px rgba(99, 102, 241, .15);--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-primary-strong: linear-gradient(135deg, #4f46e5 0%, #7c3aed 100%);--gradient-auth: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-sidebar: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);--gradient-app-bg: linear-gradient(180deg, #f5f7fb 0%, #eef1f7 100%);--sidebar-width: 260px;--sidebar-collapsed-width: 76px;--header-height: 64px;--ease: cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s var(--ease);--transition: .2s var(--ease);--transition-slow: .3s var(--ease);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--font-mono: "JetBrains Mono", "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:14px;line-height:1.55;color:var(--text-primary);background:var(--gradient-app-bg);background-attachment:fixed;font-feature-settings:"cv11","ss01","ss03";letter-spacing:-.005em}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-hover);text-decoration:underline}::selection{background:var(--primary-100);color:var(--primary-700)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25;letter-spacing:-.02em;color:var(--text-primary)}h1{font-size:26px;font-weight:700;letter-spacing:-.025em}h2{font-size:20px;font-weight:650}h3{font-size:17px}h4{font-size:14px}h5{font-size:13px}h6{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border:1px solid transparent;border-radius:var(--radius);font-family:inherit;font-size:14px;font-weight:600;line-height:1;cursor:pointer;text-decoration:none;white-space:nowrap;-webkit-user-select:none;user-select:none;transition:transform var(--transition-fast),background var(--transition),box-shadow var(--transition),border-color var(--transition),color var(--transition)}.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn svg{flex-shrink:0}.btn.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn.btn-primary:hover:not(:disabled){background:var(--gradient-primary-strong);box-shadow:0 10px 22px -6px #6366f173;transform:translateY(-1px)}.btn.btn-secondary{background:var(--bg-primary);color:var(--gray-700);border-color:var(--border-color);box-shadow:var(--shadow-xs)}.btn.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--border-strong);color:var(--text-primary)}.btn.btn-ghost{background:transparent;color:var(--gray-600)}.btn.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--text-primary)}.btn.btn-outline{background:transparent;color:var(--primary-color);border-color:var(--primary-200)}.btn.btn-outline:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-color)}.btn.btn-success{background:var(--success-soft);color:var(--success-strong);border-color:var(--success-soft-2)}.btn.btn-success:hover:not(:disabled){background:var(--success-soft-2)}.btn.btn-danger{background:var(--danger-soft);color:var(--danger-color);border-color:var(--danger-soft-2)}.btn.btn-danger:hover:not(:disabled){background:var(--danger-soft-2)}.btn.btn-block{width:100%}.btn.btn-sm{padding:7px 12px;font-size:13px;border-radius:var(--radius-sm)}.btn.btn-lg{padding:13px 26px;font-size:15px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--gray-500);transition:all var(--transition-fast)}.btn-icon:hover{background:var(--gray-100);color:var(--text-primary)}.btn-icon.btn-danger:hover{background:var(--danger-soft);color:var(--danger-color)}.btn-icon.btn-warning:hover{background:var(--warning-soft);color:var(--warning-strong)}.btn-icon.btn-success:hover{background:var(--success-soft);color:var(--success-strong)}input,select,textarea,button{font-family:inherit;font-size:14px}input[type=text],input[type=email],input[type=password],input[type=tel],input[type=number],input[type=search],input[type=date],input[type=time],input[type=datetime-local],input[type=url],select,textarea,.form-control{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--bg-primary);color:var(--text-primary);transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}input[type=text]:hover:not(:disabled):not(:focus),input[type=email]:hover:not(:disabled):not(:focus),input[type=password]:hover:not(:disabled):not(:focus),input[type=tel]:hover:not(:disabled):not(:focus),input[type=number]:hover:not(:disabled):not(:focus),input[type=search]:hover:not(:disabled):not(:focus),input[type=date]:hover:not(:disabled):not(:focus),input[type=time]:hover:not(:disabled):not(:focus),input[type=datetime-local]:hover:not(:disabled):not(:focus),input[type=url]:hover:not(:disabled):not(:focus),select:hover:not(:disabled):not(:focus),textarea:hover:not(:disabled):not(:focus),.form-control:hover:not(:disabled):not(:focus){border-color:var(--border-strong)}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=tel]:focus,input[type=number]:focus,input[type=search]:focus,input[type=date]:focus,input[type=time]:focus,input[type=datetime-local]:focus,input[type=url]:focus,select:focus,textarea:focus,.form-control:focus{outline:none;border-color:var(--primary-color);box-shadow:var(--shadow-focus)}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,input[type=tel]::placeholder,input[type=number]::placeholder,input[type=search]::placeholder,input[type=date]::placeholder,input[type=time]::placeholder,input[type=datetime-local]::placeholder,input[type=url]::placeholder,select::placeholder,textarea::placeholder,.form-control::placeholder{color:var(--text-muted)}input[type=text]:disabled,input[type=email]:disabled,input[type=password]:disabled,input[type=tel]:disabled,input[type=number]:disabled,input[type=search]:disabled,input[type=date]:disabled,input[type=time]:disabled,input[type=datetime-local]:disabled,input[type=url]:disabled,select:disabled,textarea:disabled,.form-control:disabled{background:var(--gray-50);color:var(--gray-500);cursor:not-allowed}input[type=text].error,input[type=text].is-invalid,input[type=email].error,input[type=email].is-invalid,input[type=password].error,input[type=password].is-invalid,input[type=tel].error,input[type=tel].is-invalid,input[type=number].error,input[type=number].is-invalid,input[type=search].error,input[type=search].is-invalid,input[type=date].error,input[type=date].is-invalid,input[type=time].error,input[type=time].is-invalid,input[type=datetime-local].error,input[type=datetime-local].is-invalid,input[type=url].error,input[type=url].is-invalid,select.error,select.is-invalid,textarea.error,textarea.is-invalid,.form-control.error,.form-control.is-invalid{border-color:var(--danger-color)}input[type=text].error:focus,input[type=text].is-invalid:focus,input[type=email].error:focus,input[type=email].is-invalid:focus,input[type=password].error:focus,input[type=password].is-invalid:focus,input[type=tel].error:focus,input[type=tel].is-invalid:focus,input[type=number].error:focus,input[type=number].is-invalid:focus,input[type=search].error:focus,input[type=search].is-invalid:focus,input[type=date].error:focus,input[type=date].is-invalid:focus,input[type=time].error:focus,input[type=time].is-invalid:focus,input[type=datetime-local].error:focus,input[type=datetime-local].is-invalid:focus,input[type=url].error:focus,input[type=url].is-invalid:focus,select.error:focus,select.is-invalid:focus,textarea.error:focus,textarea.is-invalid:focus,.form-control.error:focus,.form-control.is-invalid:focus{box-shadow:0 0 0 4px #ef44441f}select{cursor:pointer;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='%2364748b' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;appearance:none}textarea{resize:vertical;min-height:100px;line-height:1.55}label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:6px}label .required{color:var(--danger-color);margin-left:2px}.form-group{margin-bottom:18px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-hint{font-size:12px;color:var(--text-muted);margin-top:6px}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;transition:box-shadow var(--transition),transform var(--transition)}.card-elevated{box-shadow:var(--shadow-md);border-color:transparent}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:-24px -24px 20px;padding:18px 24px;border-bottom:1px solid var(--border-color)}.card-header h2,.card-header h3{margin:0}.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:14px;border:1px solid transparent}.alert.alert-success{background:var(--success-soft);color:var(--success-strong);border-color:var(--success-soft-2)}.alert.alert-error,.alert.alert-danger{background:var(--danger-soft);color:var(--danger-color);border-color:var(--danger-soft-2)}.alert.alert-warning{background:var(--warning-soft);color:var(--warning-strong);border-color:var(--warning-soft-2)}.alert.alert-info{background:var(--info-soft);color:var(--info-strong);border-color:var(--info-soft-2)}.badge,.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;line-height:1.3;letter-spacing:.01em;background:var(--gray-100);color:var(--gray-700);border:1px solid transparent}.badge.badge-primary,.badge.status-primary,.status-badge.badge-primary,.status-badge.status-primary{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-100)}.badge.badge-success,.badge.status-success,.status-badge.badge-success,.status-badge.status-success{background:var(--success-soft);color:var(--success-strong);border-color:var(--success-soft-2)}.badge.badge-warning,.badge.status-warning,.status-badge.badge-warning,.status-badge.status-warning{background:var(--warning-soft);color:var(--warning-strong);border-color:var(--warning-soft-2)}.badge.badge-danger,.badge.status-danger,.badge.status-error,.status-badge.badge-danger,.status-badge.status-danger,.status-badge.status-error{background:var(--danger-soft);color:var(--danger-color);border-color:var(--danger-soft-2)}.badge.badge-info,.badge.status-info,.status-badge.badge-info,.status-badge.status-info{background:var(--info-soft);color:var(--info-strong);border-color:var(--info-soft-2)}.badge.badge-neutral,.badge.status-neutral,.status-badge.badge-neutral,.status-badge.status-neutral{background:var(--gray-100);color:var(--gray-700);border-color:var(--gray-200)}.badge:before,.status-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}.badge.no-dot:before,.status-badge.no-dot:before{display:none}.table-container,.data-table-wrapper{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th,.data-table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border-color)}.data-table thead th{background:var(--gray-50);font-weight:600;font-size:11px;text-transform:uppercase;color:var(--gray-500);letter-spacing:.06em;border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:1}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--gray-50)}.data-table tbody tr:last-child td{border-bottom:none}.data-table td{color:var(--gray-700)}.page-container{padding:0}.page-container.with-padding{padding:24px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-header h1{margin:0}.page-header .subtitle,.page-header .page-subtitle{color:var(--text-secondary);margin:6px 0 0;font-size:14px}.page-header .page-actions{display:flex;gap:10px;flex-wrap:wrap}.filters-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center;padding:14px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.search-input-wrapper{flex:1;position:relative;min-width:240px;max-width:360px}.search-input-wrapper>svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input-wrapper input{padding-left:38px;background:var(--gray-50);border-color:transparent}.search-input-wrapper input:focus{background:var(--bg-primary)}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:24px;flex-wrap:wrap}.page-btn{min-width:36px;height:36px;padding:0 12px;border:1px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--gray-600);cursor:pointer;transition:all var(--transition-fast)}.page-btn:hover:not(:disabled){border-color:var(--primary-300, var(--primary-200));color:var(--primary-color);background:var(--primary-50)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-btn.active{background:var(--gradient-primary);border-color:transparent;color:#fff;box-shadow:var(--shadow-primary)}.page-info{margin-left:12px;font-size:13px;color:var(--text-secondary)}.empty-state{text-align:center;padding:64px 20px}.empty-state svg{color:var(--gray-300)}.empty-state h3{margin:16px 0 6px;color:var(--gray-700)}.empty-state p{color:var(--text-secondary);margin:0}.empty-content{display:flex;flex-direction:column;align-items:center;gap:12px}.empty-content svg{color:var(--gray-300)}.empty-content p{color:var(--text-secondary);margin:0}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.spinner-small{width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.loading-overlay{position:absolute;inset:0;background:rgba(255,255,255,.75);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.skeleton{background:linear-gradient(90deg,var(--gray-100) 0%,var(--gray-200) 50%,var(--gray-100) 100%);background-size:1000px 100%;animation:shimmer 1.6s infinite linear;border-radius:var(--radius-sm)}router-outlet+*{animation:fadeInUp .25s var(--ease)}.error-message{color:var(--danger-color);font-size:12px;margin-top:4px;font-weight:500}.divider{height:1px;background:var(--border-color);margin:16px 0;border:none}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--success-color)}.text-warning{color:var(--warning-color)}.text-danger{color:var(--danger-color)}.text-primary{color:var(--primary-color)}.text-mono{font-family:var(--font-mono)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:16px}.mt-4{margin-top:24px}.mt-5{margin-top:32px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:16px}.mb-4{margin-bottom:24px}.mb-5{margin-bottom:32px}.p-1{padding:4px}.p-2{padding:8px}.p-3{padding:16px}.p-4{padding:24px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:999px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--gray-400);background-clip:padding-box;border:2px solid transparent}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-auth);padding:20px;position:relative;overflow:hidden}.auth-container:before,.auth-container:after{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;pointer-events:none}.auth-container:before{width:480px;height:480px;background:rgba(139,92,246,.55);top:-160px;left:-160px}.auth-container:after{width:520px;height:520px;background:rgba(99,102,241,.55);bottom:-180px;right:-180px}.auth-card{position:relative;z-index:1;background:rgba(255,255,255,.96);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-2xl);box-shadow:0 30px 60px -12px #0f172a59;padding:44px;width:100%;max-width:440px}.auth-header{text-align:center;margin-bottom:32px}.auth-header .logo{display:flex;justify-content:center;margin-bottom:18px}.auth-header .logo svg{color:var(--primary-color);filter:drop-shadow(0 4px 8px rgba(99,102,241,.3))}.auth-header h1{font-size:26px;margin-bottom:8px}.auth-header p{color:var(--text-secondary)}.auth-form .form-group{margin-bottom:18px}.auth-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.auth-footer{text-align:center;margin-top:28px;padding-top:24px;border-top:1px solid var(--border-color)}.auth-footer p{color:var(--text-secondary);font-size:14px}.auth-footer p a{color:var(--primary-color);font-weight:600}@media (max-width: 768px){.auth-card{padding:28px}.auth-form .form-row,.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:stretch}}
