@charset "UTF-8";:root{--bg: #f7f8fa;--bg-secondary: #f1f5f9;--surface: #ffffff;--surface-hover: #f8fafc;--text: #0f172a;--text-secondary: #334155;--muted: #64748b;--muted-light: #94a3b8;--primary: #2563eb;--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-600: #1d4ed8;--primary-700: #1e40af;--success: #16a34a;--success-bg: #ecfdf5;--success-border: #a7f3d0;--success-text: #065f46;--error: #dc2626;--error-bg: #fef2f2;--error-border: #fecaca;--error-text: #991b1b;--warning: #d97706;--warning-bg: #fff7ed;--warning-border: #fed7aa;--warning-text: #9a3412;--info: #1d4ed8;--info-bg: #eff6ff;--info-border: #bfdbfe;--info-text: #1e3a8a;--border: #e5e7eb;--border-light: #f1f5f9;--border-dark: #cbd5e1;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .05);--shadow: 0 4px 24px rgba(15, 23, 42, .06);--shadow-md: 0 6px 20px rgba(15, 23, 42, .12);--shadow-lg: 0 8px 30px rgba(15, 23, 42, .1);--shadow-xl: 0 12px 40px rgba(15, 23, 42, .15);--shadow-2xl: 0 25px 100px rgba(15, 23, 42, .25);--radius-sm: 8px;--radius: 10px;--radius-md: 12px;--radius-lg: 14px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing: 12px;--spacing-md: 16px;--spacing-lg: 20px;--spacing-xl: 24px;--spacing-2xl: 32px;--transition-fast: .15s ease;--transition: .2s ease;--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}.theme-dark,:root.dark{--bg: #0b1220;--bg-secondary: #1e293b;--surface: #0f172a;--surface-hover: #1e293b;--text: #e5e7eb;--text-secondary: #cbd5e1;--muted: #8ea0b8;--muted-light: #64748b;--border: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .05);--border-dark: rgba(255, 255, 255, .15);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow: 0 4px 24px rgba(0, 0, 0, .4);--shadow-md: 0 6px 20px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .35);--shadow-xl: 0 12px 40px rgba(0, 0, 0, .45);--shadow-2xl: 0 25px 100px rgba(0, 0, 0, .6)}.btn{padding:10px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm);font-weight:500;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;position:relative;overflow:hidden;white-space:nowrap;text-decoration:none}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.btn:hover:before{left:100%}.btn:hover{background:var(--surface-hover);transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-dark)}.btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn.primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-600) 100%);border-color:var(--primary-700);color:#fff;box-shadow:0 4px 12px #2563eb4d}.btn.primary:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);box-shadow:0 6px 20px #2563eb66}.btn.outline{background:transparent;border-width:2px}.btn.outline:hover{background:var(--surface-hover)}.btn.ghost{background:transparent;border:none;box-shadow:none}.btn.ghost:hover{background:var(--surface-hover);box-shadow:none}.btn.danger{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.btn.danger:hover{background:#fee2e2;border-color:#fca5a5}.btn.small{padding:6px 12px;font-size:12px}.btn.large{padding:14px 24px;font-size:16px;font-weight:600}.btn .btn-icon{font-size:16px;display:inline-flex;align-items:center;transition:transform var(--transition-fast)}.btn:hover .btn-icon{transform:scale(1.1)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:all var(--transition);overflow:hidden}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-dark)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:500;border:1px solid transparent;white-space:nowrap;box-shadow:var(--shadow-sm)}.badge.ok,.badge.success,.badge.active{background:var(--success-bg);color:var(--success-text);border-color:var(--success-border)}.badge.off,.badge.error,.badge.danger,.badge.inactive{background:var(--error-bg);color:var(--error-text);border-color:var(--error-border)}.badge.warn,.badge.warning{background:var(--warning-bg);color:var(--warning-text);border-color:var(--warning-border)}.badge.info{background:var(--info-bg);color:var(--info-text);border-color:var(--info-border)}.badge.gray{background:#f3f4f6;color:#374151;border-color:#e5e7eb}.chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--radius-full);font-size:12px;background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:all var(--transition-fast)}.chip:hover{background:var(--surface-hover);border-color:var(--border-dark)}.chip.active{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700);box-shadow:0 0 0 3px #2563eb26}input[type=text],input[type=email],input[type=password],input[type=number],input[type=url],input[type=tel],select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:14px;transition:all var(--transition-fast);font-family:inherit}input[type=text]:hover:not(:disabled),input[type=email]:hover:not(:disabled),input[type=password]:hover:not(:disabled),input[type=number]:hover:not(:disabled),input[type=url]:hover:not(:disabled),input[type=tel]:hover:not(:disabled),select:hover:not(:disabled),textarea:hover:not(:disabled){border-color:var(--border-dark)}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=url]:focus,input[type=tel]:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #2563eb26}input[type=text]:disabled,input[type=email]:disabled,input[type=password]:disabled,input[type=number]:disabled,input[type=url]:disabled,input[type=tel]:disabled,select:disabled,textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-secondary)}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,input[type=number]::placeholder,input[type=url]::placeholder,input[type=tel]::placeholder,select::placeholder,textarea::placeholder{color:var(--muted);opacity:.6}textarea{resize:vertical;min-height:80px}label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:500;color:var(--text)}label.checkbox-label,label.radio-label{flex-direction:row;align-items:center;gap:8px;font-weight:400}.alert{padding:12px 16px;border-radius:var(--radius);border:1px solid;font-size:14px}.alert.error{background:var(--error-bg);color:var(--error-text);border-color:var(--error-border)}.alert.success{background:var(--success-bg);color:var(--success-text);border-color:var(--success-border)}.alert.warning{background:var(--warning-bg);color:var(--warning-text);border-color:var(--warning-border)}.alert.info{background:var(--info-bg);color:var(--info-text);border-color:var(--info-border)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-state{display:flex;align-items:center;justify-content:center;gap:12px;padding:40px 20px;color:var(--muted);font-size:14px}.empty{text-align:center;color:var(--muted);padding:48px 20px;border:2px dashed var(--border);border-radius:var(--radius-md);background:var(--bg-secondary)}.empty .empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.empty p{margin:8px 0;font-size:14px}.empty p.empty-hint{font-size:13px;margin-top:4px}.empty p.empty-hint strong{color:var(--text);font-weight:600}dialog{border:none;border-radius:var(--radius-2xl);padding:0;background:var(--surface);color:var(--text);box-shadow:var(--shadow-2xl);margin:auto;max-width:90vw;max-height:90vh;overflow:hidden}dialog::backdrop{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#02061799;animation:backdropFadeIn .3s ease-out forwards}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.dialog{padding:24px;display:flex;flex-direction:column;gap:16px;max-height:90vh;overflow-y:auto}.dialog::-webkit-scrollbar{width:8px}.dialog::-webkit-scrollbar-track{background:transparent}.dialog::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.dialog::-webkit-scrollbar-thumb:hover{background:var(--muted)}.dialog-title{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.dialog-title h3{margin:0;font-size:20px;font-weight:700;color:var(--text)}.dialog-title .dialog-subtitle{font-size:13px;color:var(--muted);margin:4px 0 0;font-weight:400}.dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px;padding-top:16px;border-top:1px solid var(--border)}.icon{padding:8px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;font-size:16px}.icon:hover{background:var(--surface-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.icon.danger{border-color:var(--error-border);color:var(--error-text)}.icon.danger:hover{background:var(--error-bg);border-color:#fca5a5}.icon.close{background:transparent;border:none}.icon.close:hover{background:var(--error-bg);transform:rotate(90deg)}.icon.small{padding:4px 8px;font-size:14px}.muted{color:var(--muted);font-size:13px}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap{gap:var(--spacing)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}*{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg);color:var(--text)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--muted)}::selection{background:var(--primary-200);color:var(--primary-700)}
