:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;font-size:14px;--font-page-title: 1.5rem;--font-section-title: 1.25rem;--font-card-title: 1.125rem;--font-body: 1rem;--font-label: .9375rem;--font-small: .8125rem;--font-xs: .75rem;--font-xxs: .6875rem;--fw-normal: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;color:#0f172a;background-color:#f5f7fb;--surface: #ffffff;--surface-muted: #f1f5f9;--surface-elevated: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--border-muted: #f1f5f9;--text: #0f172a;--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--text-placeholder: #94a3b8;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-active: #1e40af;--primary-light: #dbeafe;--primary-lighter: #eff6ff;--primary-text: #ffffff;--secondary: #475569;--secondary-hover: #334155;--secondary-active: #1e293b;--secondary-light: #f1f5f9;--secondary-text: #ffffff;--success: #16a34a;--success-hover: #15803d;--success-light: #dcfce7;--success-lighter: #f0fdf4;--success-text: #ffffff;--success-text-dark: #166534;--warning: #d97706;--warning-hover: #b45309;--warning-light: #fef3c7;--warning-lighter: #fffbeb;--warning-text: #ffffff;--warning-text-dark: #92400e;--error: #dc2626;--danger: #dc2626;--error-hover: #b91c1c;--error-light: #fee2e2;--error-lighter: #fef2f2;--error-text: #ffffff;--error-text-dark: #991b1b;--info: #0284c7;--info-hover: #0369a1;--info-light: #e0f2fe;--info-lighter: #f0f9ff;--info-text: #ffffff;--info-text-dark: #075985;--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;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 4px 6px -1px rgba(15, 23, 42, .08), 0 2px 4px -1px rgba(15, 23, 42, .04);--shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, .08), 0 4px 6px -2px rgba(15, 23, 42, .04);--shadow-xl: 0 20px 25px -5px rgba(15, 23, 42, .1), 0 10px 10px -5px rgba(15, 23, 42, .04);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem}[data-theme=dark]{color:#e2e8f0;background-color:#0b1120;--surface: #0f172a;--surface-muted: #1e293b;--surface-elevated: #1e293b;--surface-2: #1e293b;--border: #334155;--border-muted: #1e293b;--text: #f1f5f9;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-placeholder: #64748b;--primary: #3b82f6;--primary-hover: #2563eb;--primary-active: #1d4ed8;--primary-light: rgba(59, 130, 246, .15);--primary-lighter: rgba(59, 130, 246, .08);--secondary: #94a3b8;--secondary-hover: #cbd5e1;--secondary-light: rgba(148, 163, 184, .1);--success: #22c55e;--success-hover: #16a34a;--success-light: rgba(34, 197, 94, .15);--success-lighter: rgba(34, 197, 94, .08);--success-text-dark: #86efac;--warning: #f59e0b;--warning-hover: #d97706;--warning-light: rgba(245, 158, 11, .15);--warning-lighter: rgba(245, 158, 11, .08);--warning-text-dark: #fcd34d;--error: #ef4444;--danger: #ef4444;--error-hover: #dc2626;--error-light: rgba(239, 68, 68, .15);--error-lighter: rgba(239, 68, 68, .08);--error-text-dark: #fca5a5;--info: #0ea5e9;--info-hover: #0284c7;--info-light: rgba(14, 165, 233, .15);--info-lighter: rgba(14, 165, 233, .08);--info-text-dark: #7dd3fc;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 10px 10px -5px rgba(0, 0, 0, .2)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:inherit;text-decoration:none}.login-page{min-height:100vh;display:grid;place-items:center;padding:clamp(1.5rem,5vw,3rem);background:radial-gradient(circle at 20% 20%,#e8edff,#f5f7fb 55%)}[data-theme=dark] .login-page{background:radial-gradient(circle at 20% 20%,#0f172a,#0b1224 55%)}.login-card{width:min(440px,100%);border-radius:20px;padding:2.5rem 2.25rem 2.25rem;display:flex;flex-direction:column;gap:.25rem;background:var(--surface);border:1px solid var(--border);box-shadow:0 25px 60px #0f172a14,0 8px 24px #2563eb0f;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-logo{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;margin-bottom:.75rem;box-shadow:0 8px 24px #2563eb4d}.login-card .eyebrow{font-weight:var(--fw-bold);color:var(--primary);font-size:var(--font-xxs);letter-spacing:.1em;margin:0}.login-card h1{margin:.15rem 0 0;font-size:var(--font-section-title);font-weight:800;letter-spacing:-.02em;line-height:1.2}.login-card>.muted{margin:.35rem 0 0;font-size:var(--font-label);line-height:1.55}[data-theme=dark] .login-card{box-shadow:0 20px 50px #0006}.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:#94a3b8;margin:0 0 .35rem}h1{margin:0 0 .35rem;font-size:clamp(1.75rem,3vw,2.4rem)}h2{margin:0;font-size:var(--font-page-title);font-weight:var(--fw-bold)}h3{margin:0;font-size:var(--font-section-title);font-weight:var(--fw-bold)}.muted{color:#475569;font-size:var(--font-label)}[data-theme=dark] .muted{color:#94a3b8}.form-label{display:grid;gap:.4rem;color:#374151;font-weight:var(--fw-semibold);font-size:var(--font-label)}[data-theme=dark] .form-label{color:#d1d5db}.form-input{padding:.7rem .875rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:var(--font-label);transition:border-color .2s ease,box-shadow .2s ease}.form-input:hover:not(:disabled){border-color:#94a3b8}[data-theme=dark] .form-input:hover:not(:disabled){border-color:#475569}.form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}[data-theme=dark] .form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.form-input:disabled{opacity:.6;cursor:not-allowed;background:var(--surface-muted)}.form-input::placeholder{color:#94a3b8}[data-theme=dark] .form-input::placeholder{color:#64748b}select.form-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}textarea.form-input{resize:vertical;min-height:80px}.form-section{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:16px;padding:0;background:#fff;box-shadow:0 4px 16px #0f172a0f,0 1px 3px #0f172a0a;width:100%;max-width:100%;overflow:hidden;box-sizing:border-box;position:relative}[data-theme=dark] .form-section{border:1px solid #1e293b;background:#0f172a;box-shadow:0 4px 16px #00000040,0 1px 3px #00000026}.form-section h3{margin:0;font-size:var(--font-small);font-weight:var(--fw-bold);color:#1e40af;letter-spacing:.04em;text-transform:uppercase;padding:.85rem 1.25rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-bottom:1px solid #bfdbfe;display:flex;align-items:center;gap:.5rem}.form-section h3:before{content:"";display:inline-block;width:3.5px;height:16px;background:linear-gradient(180deg,#2563eb,#1d4ed8);border-radius:2px;flex-shrink:0}[data-theme=dark] .form-section h3{color:#93c5fd;background:linear-gradient(135deg,#2563eb26,#1e40af1a);border-bottom-color:#3b82f633}[data-theme=dark] .form-section h3:before{background:linear-gradient(180deg,#3b82f6,#2563eb)}.form-section-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-bottom:1px solid #bfdbfe;gap:.75rem}.form-section-header h3{padding:0;background:none;border:none;flex:1}[data-theme=dark] .form-section-header{background:linear-gradient(135deg,#2563eb26,#1e40af1a);border-bottom-color:#3b82f633}.form-section>div:not(.form-section-header){padding:1.25rem;width:100%;box-sizing:border-box}.form-section>.table-wrapper{padding:0 1.25rem 1.25rem;width:100%;box-sizing:border-box}.form-section .form-label{display:flex;flex-direction:column;gap:.35rem}.form-section textarea.form-input{resize:vertical;width:100%;box-sizing:border-box}.form-section p{padding:10px;margin:0}.form-section .form-label{font-weight:var(--fw-semibold);color:#374151;font-size:var(--font-label);letter-spacing:.01em}[data-theme=dark] .form-section .form-label{color:#d1d5db}.form-section .form-input{border-radius:10px;border:1.5px solid #e2e8f0;background:#f8fafc;transition:all .2s ease}.form-section .form-input:hover:not(:disabled){border-color:#cbd5e1;background:#fff}.form-section .form-input:focus{border-color:#2563eb;background:#fff;box-shadow:0 0 0 4px #2563eb1a}[data-theme=dark] .form-section .form-input{border-color:#334155;background:#1e293b}[data-theme=dark] .form-section .form-input:hover:not(:disabled){border-color:#475569;background:#0f172a}[data-theme=dark] .form-section .form-input:focus{border-color:#3b82f6;background:#0f172a;box-shadow:0 0 0 4px #3b82f626}.section-refresh-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;border-radius:8px;border:1.5px solid var(--primary);background:#2563eb0f;color:var(--primary);cursor:pointer;font-weight:600;font-size:.75rem;line-height:1.25;white-space:nowrap;transition:all .15s ease}.section-refresh-btn:hover{background:#2563eb24;border-color:var(--primary-hover);color:var(--primary-hover)}.section-refresh-btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .section-refresh-btn{border-color:#3b82f6;color:#93c5fd;background:#3b82f61a}[data-theme=dark] .section-refresh-btn:hover{background:#3b82f633}.form-section-header .ghost-button{padding:.4rem .85rem;font-size:var(--font-small);font-weight:var(--fw-bold);border-radius:8px;border:1.5px solid #2563eb;color:#2563eb;background:#2563eb0f;letter-spacing:.01em}.form-section-header .ghost-button:hover{background:#2563eb24;border-color:#1d4ed8;color:#1d4ed8}[data-theme=dark] .form-section-header .ghost-button{border-color:#3b82f6;color:#93c5fd;background:#3b82f61a}[data-theme=dark] .form-section-header .ghost-button:hover{background:#3b82f633}.form-action-bar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:1rem 1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px solid #cbd5e1;border-radius:14px;box-shadow:0 -2px 12px #0f172a14,0 4px 16px #0f172a0f;position:sticky;bottom:1rem;z-index:20;margin-top:.25rem}[data-theme=dark] .form-action-bar{background:linear-gradient(135deg,#1e293b,#0f172a);border-color:#334155;box-shadow:0 -2px 12px #0003,0 4px 16px #00000040}.form-section input[type=file]{font-size:.8rem;color:var(--text-muted, #64748b);cursor:pointer}.form-section input[type=file]::file-selector-button{padding:.35rem .75rem;border-radius:8px;border:1.5px solid #e2e8f0;background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#374151;font-weight:600;font-size:.78rem;cursor:pointer;margin-right:.6rem;transition:all .15s ease}.form-section input[type=file]::file-selector-button:hover{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#93c5fd;color:#1e40af}[data-theme=dark] .form-section input[type=file]::file-selector-button{border-color:#334155;background:linear-gradient(135deg,#1e293b,#0f172a);color:#d1d5db}[data-theme=dark] .form-section input[type=file]::file-selector-button:hover{background:linear-gradient(135deg,#2563eb26,#1e40af1a);border-color:#3b82f6;color:#93c5fd}.data-table{width:100%;border-collapse:collapse;color:#0f172a;font-size:var(--font-body)}[data-theme=dark] .data-table{color:#e2e8f0}.data-table th,.data-table td{padding:.75rem .875rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}.data-table th{font-weight:var(--fw-bold);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.04em;color:#475569;white-space:nowrap}[data-theme=dark] .data-table th{color:#94a3b8}.data-table thead{background:#f1f5f9;position:sticky;top:0;z-index:10}[data-theme=dark] .data-table thead{background:#0b1224}.data-table tbody tr{transition:background-color .15s ease}.data-table tbody tr:nth-child(2n){background:#f1f5f980}[data-theme=dark] .data-table tbody tr:nth-child(2n){background:#0f172a66}.data-table tbody tr:hover{background:#2563eb0f}[data-theme=dark] .data-table tbody tr:hover{background:#2563eb1f}.login-form{display:flex;flex-direction:column;gap:1.1rem;margin-top:1.5rem}.login-form label{display:flex;flex-direction:column;font-weight:var(--fw-semibold);gap:.4rem;color:#374151;font-size:var(--font-label)}[data-theme=dark] .login-form label{color:#d1d5db}.login-form input{padding:.8rem 1rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:var(--font-body);transition:border-color .2s ease,box-shadow .2s ease}.login-form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}[data-theme=dark] .login-form input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.login-form input::placeholder{color:#94a3b8}.login-form button{padding:.9rem 1.25rem;border-radius:10px;border:none;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-weight:var(--fw-bold);font-size:var(--font-body);cursor:pointer;box-shadow:0 4px 14px #2563eb4d;transition:all .2s ease;margin-top:.5rem}.login-form button:hover:not(:disabled){box-shadow:0 6px 20px #2563eb66;transform:translateY(-1px)}.login-form button:active:not(:disabled){transform:scale(.98)}[data-theme=dark] .login-form button{box-shadow:0 4px 14px #2563eb66}[data-theme=dark] .login-form button:hover:not(:disabled){box-shadow:0 6px 20px #2563eb80}.login-form button:disabled{opacity:.55;cursor:not-allowed;transform:none}.error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;color:#b91c1c;font-size:var(--font-label);font-weight:var(--fw-medium);display:flex;align-items:center;gap:.5rem}.error:before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#dc2626;color:#fff;font-weight:700;font-size:.75rem;flex-shrink:0}[data-theme=dark] .error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#fca5a5}[data-theme=dark] .error:before{background:#ef4444}.notice{border-radius:8px;padding:.75rem 1rem;border:1px solid var(--border);background:var(--surface-muted);color:var(--text);font-weight:var(--fw-medium);font-size:var(--font-label);display:flex;align-items:center;gap:.5rem}.notice.success{background:#ecfdf5;border-color:#a7f3d0;color:#047857}.notice.success:before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#10b981;color:#fff;font-weight:700;font-size:.7rem;flex-shrink:0}.notice.error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.notice.error:before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#dc2626;color:#fff;font-weight:700;font-size:.75rem;flex-shrink:0}.notice.info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.notice.info:before{content:"i";display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#2563eb;color:#fff;font-weight:700;font-size:.75rem;flex-shrink:0;font-style:italic}[data-theme=dark] .notice{background:#64748b1a;border:1px solid rgba(100,116,139,.2);color:#e2e8f0}[data-theme=dark] .notice.success{background:#10b9811f;border-color:#10b98140;color:#6ee7b7}[data-theme=dark] .notice.success:before{background:#10b981}[data-theme=dark] .notice.error{background:#ef44441f;border-color:#ef444440;color:#fca5a5}[data-theme=dark] .notice.error:before{background:#ef4444}[data-theme=dark] .notice.info{background:#3b82f61f;border-color:#3b82f640;color:#93c5fd}[data-theme=dark] .notice.info:before{background:#3b82f6}.shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr;background:#f5f7fb;color:#0f172a;position:relative}[data-theme=dark] .shell{background:#0b1120;color:#e2e8f0}.sidebar{border-right:1px solid var(--border);padding:1.25rem 1rem;background:var(--surface);display:flex;flex-direction:column;gap:.5rem;box-shadow:none;position:sticky;top:0;height:100vh;overflow-y:auto}[data-theme=dark] .sidebar{box-shadow:none}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:70}[data-theme=dark] .sidebar-backdrop{background:#0000008c}.logo{font-weight:800;letter-spacing:.01em;font-size:1.2rem}.nav-sections{display:grid;gap:.8rem}.nav-section{background:#f1f5f9;border:1px solid #d8e1ec;border-radius:14px;padding:.5rem;box-shadow:inset 0 1px #fff9}[data-theme=dark] .nav-section{background:#0b1224;border:1px solid #1f2a44;box-shadow:inset 0 1px #ffffff0d}.nav-section-title{padding:.35rem .65rem;font-weight:var(--fw-bold);color:#0f172a;font-size:var(--font-label);border-bottom:1px solid #d8e1ec;margin-bottom:.35rem}[data-theme=dark] .nav-section-title{color:#e2e8f0;border-bottom:1px solid #1f2937}.nav-section-items{display:grid;gap:.4rem}.nav-link{display:block;padding:.65rem .75rem;border-radius:10px;color:#475569;transition:background .2s,color .2s;font-weight:var(--fw-semibold);background:#fff;border:1px solid #e2e8f0;font-size:var(--font-label)}.nav-link:hover{background:#eef2f7}.nav-link.active{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 25px #2563eb3d;border-color:transparent}[data-theme=dark] .nav-link{color:#cbd5e1;background:#0f172a;border:1px solid #1f2937}[data-theme=dark] .nav-link:hover{background:#0b1224}[data-theme=dark] .nav-link.active{box-shadow:0 10px 25px #2563eb59;box-shadow:0 4px 12px #2563eb66}.content{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem;min-height:100vh;font-size:var(--font-body);min-width:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#334155}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#475569}.table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}.table-wrapper .data-table{border:none}.table-wrapper .data-table th:first-child,.table-wrapper .data-table td:first-child{padding-left:1rem}.table-wrapper .data-table th:last-child,.table-wrapper .data-table td:last-child{padding-right:1rem}.topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.75rem 1rem;box-shadow:0 1px 3px #0f172a0a}[data-theme=dark] .topbar{box-shadow:0 1px 3px #0003}.topbar-left{display:flex;align-items:center;gap:.75rem;min-width:0}.user-meta{display:flex;flex-direction:column;gap:.15rem}.user-name{font-weight:700;color:#0f172a}[data-theme=dark] .user-name{color:#e2e8f0}.user-role{color:#475569;font-size:var(--font-label)}[data-theme=dark] .user-role{color:#cbd5e1}.topbar-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;justify-content:flex-end}.ghost-button{padding:.55rem .9rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-weight:var(--fw-semibold);font-size:var(--font-label);transition:all .2s ease}.ghost-button:hover{border-color:#2563eb;color:#2563eb;background:#2563eb0f}.ghost-button:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.ghost-button:active{transform:scale(.98)}.ghost-button:disabled{opacity:.5;cursor:not-allowed;transform:none}[data-theme=dark] .ghost-button:hover{border-color:#3b82f6;color:#93c5fd;background:#3b82f61f}.menu-toggle{display:none;gap:.45rem;align-items:center;font-weight:800}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0f172a0a}[data-theme=dark] .card{box-shadow:0 1px 3px #0003}.card h2{font-size:var(--font-card-title);font-weight:var(--fw-bold);margin:0;color:var(--text)}.card p.muted{margin:.25rem 0 0;font-size:var(--font-label);line-height:1.5}.card-grid{display:grid;gap:var(--space-4)}.card-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap}.card-header-actions{display:flex;gap:var(--space-2);flex-wrap:wrap;flex-shrink:0}.form-row{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start}.form-row-2{display:grid;gap:var(--space-3);grid-template-columns:1fr 1fr}.form-row-3{display:grid;gap:var(--space-3);grid-template-columns:1fr 1fr 1fr}.form-actions{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center}.card-section{border-top:1px solid var(--border);padding-top:var(--space-3);display:grid;gap:var(--space-2)}.flash{padding:.75rem 1rem;border-radius:8px;font-size:var(--font-label);font-weight:var(--fw-medium)}.flash-success{background:var(--success-lighter);border:1px solid var(--success-light);color:var(--success-text-dark)}.flash-error{background:var(--error-lighter);border:1px solid var(--error-light);color:var(--error-text-dark)}@media (max-width: 640px){.form-row-2,.form-row-3{grid-template-columns:1fr}}.dashboard{display:flex;flex-direction:column;gap:1rem}.dashboard>form{display:flex;flex-direction:column;gap:1rem}.welcome-card{background:linear-gradient(135deg,#2563eb0f,#2563eb1a);border:1px solid rgba(37,99,235,.15);border-radius:12px;padding:1.25rem 1.5rem;box-shadow:0 2px 8px #2563eb0f;display:flex;justify-content:space-between;gap:1rem;align-items:center}.welcome-card h2{margin:0;font-size:var(--font-page-title);font-weight:var(--fw-bold);color:var(--text)}.welcome-card p{margin:.35rem 0 0;line-height:1.5}[data-theme=dark] .welcome-card{background:linear-gradient(135deg,#2563eb1a,#2563eb29);border:1px solid rgba(59,130,246,.2);box-shadow:0 2px 8px #2563eb1a}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:999px;font-size:.7rem;font-weight:var(--fw-semibold);letter-spacing:.02em;line-height:1.3;background:#f1f5f9;border:1px solid #e2e8f0;color:#475569;white-space:nowrap}[data-theme=dark] .badge{background:#94a3b81a;border:1px solid rgba(148,163,184,.2);color:#94a3b8}.badge.success{background:var(--success-lighter);border-color:var(--success-light);color:var(--success-text-dark)}[data-theme=dark] .badge.success{background:var(--success-light);border-color:var(--success);color:var(--success-text-dark)}.badge.warning{background:var(--warning-lighter);border-color:var(--warning-light);color:var(--warning-text-dark)}[data-theme=dark] .badge.warning{background:var(--warning-light);border-color:var(--warning);color:var(--warning-text-dark)}.badge.error,.badge.danger{background:var(--error-lighter);border-color:var(--error-light);color:var(--error-text-dark)}[data-theme=dark] .badge.error,[data-theme=dark] .badge.danger{background:var(--error-light);border-color:var(--error);color:var(--error-text-dark)}.badge.muted{background:var(--gray-100);border-color:var(--gray-200);color:var(--gray-500)}[data-theme=dark] .badge.muted{background:var(--secondary-light);border-color:var(--border);color:var(--text-muted)}.badge.info,.badge.primary{background:var(--primary-lighter);border-color:var(--primary-light);color:var(--primary-active)}[data-theme=dark] .badge.info,[data-theme=dark] .badge.primary{background:var(--primary-light);border-color:var(--primary);color:var(--info-text-dark)}.stats-grid{display:grid;gap:.875rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem 1.125rem;box-shadow:0 2px 8px #0f172a0a;transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#2563eb,#3b82f6);opacity:.7}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0f172a14}a.stat-card-link{text-decoration:none;color:inherit;cursor:pointer;display:block}a.stat-card-link:hover{border-color:var(--primary, #2563eb)}a.stat-card-link:hover:before{opacity:1}[data-theme=dark] .stat-card{box-shadow:0 2px 8px #0003}[data-theme=dark] .stat-card:hover{box-shadow:0 8px 24px #00000059}.stat-label{color:#64748b;font-size:var(--font-small);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.04em}[data-theme=dark] .stat-label{color:#94a3b8}.stat-value{font-size:1.75rem;font-weight:800;margin-top:.35rem;color:var(--text);line-height:1.2}.stat-hint{margin-top:.4rem;color:#94a3b8;font-size:var(--font-small)}[data-theme=dark] .stat-hint{color:#64748b}.quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.875rem}.quick-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.125rem 1.25rem;box-shadow:0 2px 8px #0f172a0a;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;display:flex;flex-direction:column;gap:.5rem}.quick-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0f172a14;border-color:#2563eb40}[data-theme=dark] .quick-card{box-shadow:0 2px 8px #0003}[data-theme=dark] .quick-card:hover{box-shadow:0 8px 24px #00000059;border-color:#3b82f640}.quick-card h3{margin:0;font-size:var(--font-card-title);font-weight:var(--fw-bold);color:var(--text)}.quick-card p{margin:0;color:#64748b;font-size:var(--font-label);line-height:1.5;flex:1}[data-theme=dark] .quick-card p{color:#94a3b8}.quick-card .link-button{align-self:flex-start;margin-top:.5rem}.link-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.55rem 1rem;border-radius:10px;border:1px solid transparent;text-decoration:none;font-weight:var(--fw-bold);font-size:var(--font-label);cursor:pointer;transition:all .2s ease}.link-button:focus-visible,.secondary-button:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.link-button:active,.secondary-button:active{transform:scale(.98)}.link-button:disabled,.secondary-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.link-button{margin-top:0;border-color:#2563eb;color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 14px #2563eb40}.link-button:hover{box-shadow:0 6px 20px #2563eb59;transform:translateY(-1px)}[data-theme=dark] .link-button{box-shadow:0 4px 14px #2563eb66}[data-theme=dark] .link-button:hover{box-shadow:0 6px 20px #2563eb80}.positive-button{background:linear-gradient(135deg,#16a34a,#15803d);border-color:#16a34a;box-shadow:0 4px 14px #16a34a40}.positive-button:hover{box-shadow:0 6px 20px #16a34a59;transform:translateY(-1px)}[data-theme=dark] .positive-button{box-shadow:0 4px 14px #16a34a59}.danger-button{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626;color:#fff!important;box-shadow:0 4px 14px #dc262640}.danger-button:hover{box-shadow:0 6px 20px #dc262659;transform:translateY(-1px)}[data-theme=dark] .danger-button{box-shadow:0 4px 14px #dc262659}.secondary-button{background:linear-gradient(135deg,#64748b,#475569);border-color:#64748b;color:#fff;box-shadow:0 4px 14px #47556933}.secondary-button:hover{box-shadow:0 6px 20px #4755694d;transform:translateY(-1px)}[data-theme=dark] .secondary-button{box-shadow:0 4px 14px #4755694d}.table-actions{display:flex;align-items:center;gap:.375rem;flex-wrap:nowrap}.table-button{margin-top:0;padding:.35rem .75rem;border-radius:var(--radius-sm);font-weight:var(--fw-semibold);font-size:var(--font-xs);line-height:1.25;white-space:nowrap;letter-spacing:.01em}.table-actions .link-button{margin-top:0}.table-actions .ghost-button:not(.danger-button){background:var(--surface)}[data-theme=dark] .table-actions .ghost-button:not(.danger-button){background:var(--surface)}.section-divider{border-top:1px solid var(--border);padding-top:1rem;margin-top:.5rem}.centered{min-height:60vh;display:grid;place-items:center;gap:.5rem;color:#0f172a}[data-theme=dark] .centered{color:#e2e8f0}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#f1f5f9cc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;animation:fadeIn .15s ease}[data-theme=dark] .loading-overlay{background:#0b1120d9}.loading-overlay__panel{display:grid;gap:.75rem;padding:1.5rem 2rem;border-radius:12px;background:var(--surface);border:1px solid var(--border);box-shadow:0 10px 40px #0f172a1f;align-items:center;justify-items:center;min-width:200px;animation:slideUp .2s ease}[data-theme=dark] .loading-overlay__panel{box-shadow:0 10px 40px #0006}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading-overlay__message{font-weight:700;font-size:.95rem;color:var(--text)}.loading-overlay__hint{color:var(--text-muted);font-size:.875rem}.spinner{width:32px;height:32px;border-radius:50%;border:3px solid rgba(37,99,235,.15);border-top-color:#2563eb;animation:spin .75s linear infinite}[data-theme=dark] .spinner{border:3px solid rgba(59,130,246,.2);border-top-color:#3b82f6}@keyframes spin{to{transform:rotate(360deg)}}.spinner-sm{width:16px;height:16px;border-width:2px}@media (max-width: 1080px){.shell{grid-template-columns:1fr;overflow-x:hidden}.sidebar{position:fixed;inset:0 auto 0 0;width:min(280px,85vw);height:100vh;overflow-y:auto;transform:translate(-105%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:80;box-shadow:4px 0 20px #0f172a26;border-right:1px solid var(--border)}[data-theme=dark] .sidebar{box-shadow:4px 0 20px #0006}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block}.nav-sections{max-height:calc(100vh - 100px);overflow-y:auto}.menu-toggle{display:inline-flex}.content{padding:1rem}.topbar{align-items:center}.card{padding:1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}@media (max-width: 720px){.topbar{flex-direction:column;gap:.75rem}.topbar-left{width:100%;justify-content:space-between}.topbar-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.card,.topbar{padding:.875rem;border-radius:10px}.quick-links{grid-template-columns:1fr}.welcome-card{flex-direction:column;align-items:flex-start;text-align:left}h1,.stat-value{font-size:1.5rem}}@media (max-width: 540px){.ghost-button{width:100%;justify-content:center}.topbar-actions{flex-direction:column}.link-button,.secondary-button{width:100%;justify-content:center}.table-actions{flex-wrap:wrap;gap:.4rem}.table-button{padding:.35rem .6rem;font-size:.75rem}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:.5rem .6rem}.stats-grid{grid-template-columns:1fr 1fr;gap:.5rem}.stat-card{padding:.75rem}.stat-label{font-size:.7rem}.stat-value{font-size:1.25rem}}.toast-container{position:fixed;top:16px;right:16px;display:flex;flex-direction:column;gap:10px;z-index:1000;max-width:min(380px,calc(100vw - 32px))}.toast{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:.875rem 1rem;border-radius:10px;background:#1e293b;color:#f1f5f9;box-shadow:0 8px 30px #00000040;font-size:.875rem;font-weight:500;animation:toastSlideIn .25s ease;border-left:4px solid transparent}@keyframes toastSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-error{border-left-color:#ef4444;background:linear-gradient(135deg,#1e293b,#291818)}.toast-success{border-left-color:#10b981;background:linear-gradient(135deg,#1e293b,#172520)}.toast-info{border-left-color:#3b82f6;background:linear-gradient(135deg,#1e293b,#1a2234)}.toast-close{border:none;background:transparent;color:#94a3b8;font-size:1.125rem;cursor:pointer;line-height:1;padding:0;transition:color .15s ease;flex-shrink:0}.toast-close:hover{color:#fff}.page-banner{background:linear-gradient(135deg,#4f46e5,#2563eb,#0ea5e9);border-radius:16px;padding:1.5rem 1.75rem;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;position:relative;overflow:hidden}.page-banner:before,.page-banner:after{content:"";position:absolute;border-radius:50%;pointer-events:none}.page-banner:before{top:-40px;right:-20px;width:180px;height:180px;background:#ffffff0f}.page-banner:after{bottom:-30px;right:80px;width:120px;height:120px;background:#ffffff0a}.page-banner-content{position:relative;z-index:1}.page-banner-eyebrow{margin:0;font-size:var(--font-xxs);font-weight:var(--fw-semibold);opacity:.8;text-transform:uppercase;letter-spacing:.08em}.page-banner h2{margin:.25rem 0 .2rem;font-size:var(--font-page-title);font-weight:800;letter-spacing:-.01em;color:#fff}.page-banner-desc{margin:0;opacity:.85;font-size:var(--font-label);line-height:1.5}.page-banner-actions{display:flex;gap:.5rem;position:relative;z-index:1;flex-wrap:wrap}.page-banner-btn{padding:.6rem 1.15rem;border-radius:10px;background:#fffffff2;color:#2563eb;font-weight:var(--fw-bold);font-size:var(--font-label);border:none;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap;transition:background .15s ease;text-decoration:none}.page-banner-btn:hover{background:#fff}.page-banner-btn-ghost{padding:.6rem 1.15rem;border-radius:10px;background:#ffffff2e;color:#fff;font-weight:var(--fw-bold);font-size:var(--font-label);border:1px solid rgba(255,255,255,.25);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap;transition:background .15s ease;text-decoration:none}.page-banner-btn-ghost:hover{background:#ffffff47}.page-banner-btn:disabled,.page-banner-btn-ghost:disabled{opacity:.6;cursor:not-allowed}[data-theme=dark] .page-banner{background:linear-gradient(135deg,#312e81,#1e40af,#0369a1)}@media (max-width: 640px){.page-banner{flex-direction:column;align-items:flex-start;padding:1.25rem}.page-banner-actions{width:100%}.page-banner-btn,.page-banner-btn-ghost{flex:1;justify-content:center}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.page-header h2{margin:0;font-size:var(--font-page-title);font-weight:var(--fw-bold);color:var(--text)}.page-header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.filter-bar{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.filter-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.15rem 1.35rem 1.35rem;display:grid;gap:.875rem;box-shadow:0 1px 3px #0000000a}.filter-panel-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding-bottom:.65rem;border-bottom:1px solid var(--border-muted)}.filter-panel-title{display:inline-flex;align-items:center;gap:.45rem;font-weight:var(--fw-bold);font-size:var(--font-small);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.filter-panel-title svg{width:15px;height:15px;opacity:.6}.filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--primary);color:var(--primary-text);font-size:.7rem;font-weight:700;line-height:1}.filter-clear-btn{border:none;background:none;color:var(--primary);font-weight:var(--fw-semibold);font-size:var(--font-small);cursor:pointer;padding:.3rem .6rem;border-radius:var(--radius-sm);transition:background .15s ease,color .15s ease}.filter-clear-btn:hover{background:var(--primary-lighter);color:var(--primary-hover)}[data-theme=dark] .filter-clear-btn:hover{background:var(--primary-light)}.filter-panel-grid{display:grid;gap:.75rem 1rem;grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}.filter-panel-grid .form-label{margin:0;min-width:0;font-size:var(--font-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);display:flex;flex-direction:column;gap:.4rem}.filter-panel-grid .form-input{padding:.55rem .75rem;font-size:var(--font-label);font-weight:var(--fw-normal);text-transform:none;letter-spacing:normal;color:var(--text);border:1.5px solid var(--border);border-radius:var(--radius-md, 8px);background:var(--surface);width:100%;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.filter-panel-grid .form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}[data-theme=dark] .filter-panel-grid .form-input:focus{box-shadow:0 0 0 3px #2563eb33}.filter-panel-grid select.form-input{padding-right:2.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;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='%2394a3b8' stroke-width='2.5' 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 .7rem center}.filter-panel-grid select.form-input::-ms-expand{display:none}[data-theme=dark] .filter-panel{background:var(--surface);border-color:var(--border);box-shadow:0 1px 3px #00000026}.filter-panel-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}.filter-panel-row .form-label{margin:0;min-width:140px;font-size:var(--font-small)}.filter-panel-row .form-input{padding:.55rem .75rem;font-size:var(--font-label);border-radius:var(--radius-sm);background:var(--surface)}.filter-checkbox-label{display:inline-flex;align-items:center;gap:.5rem;font-size:var(--font-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);cursor:pointer;padding:.15rem 0;-webkit-user-select:none;user-select:none}.filter-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.filter-divider{border-top:1px solid var(--border);margin:0}[data-theme=dark] .filter-panel{background:var(--surface-muted);border-color:var(--border)}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.4}.empty-state h3{margin:0 0 .5rem;color:var(--text);font-weight:600}.empty-state p{margin:0;font-size:var(--font-label)}.detail-section{border-top:1px solid var(--border);padding-top:1rem;margin-top:.5rem}.detail-section h3{margin:0 0 .75rem;font-size:var(--font-label);font-weight:var(--fw-bold);color:var(--text);text-transform:uppercase;letter-spacing:.04em}.grid-2{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid-3{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.grid-4{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.text-sm{font-size:var(--font-label)}.text-xs{font-size:var(--font-xs)}.font-medium{font-weight:var(--fw-medium)}.font-semibold{font-weight:var(--fw-semibold)}.font-bold{font-weight:var(--fw-bold)}.text-center{text-align:center}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}*:focus-visible{outline:2px solid #2563eb;outline-offset:2px}[data-theme=dark] *:focus-visible{outline-color:#3b82f6}:root{--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.content-area{animation:pageEnter .3s var(--ease-out-expo)}.card,.stat-card,.quick-card,.welcome-card{transition:transform var(--duration-normal) var(--ease-out-quart),box-shadow var(--duration-normal) var(--ease-out-quart)}.stat-card:hover,.quick-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0f172a1a}[data-theme=dark] .stat-card:hover,[data-theme=dark] .quick-card:hover{box-shadow:0 8px 25px #0000004d}.data-table tbody tr{transition:background-color var(--duration-fast) ease,transform var(--duration-fast) ease}.data-table tbody tr:hover{transform:scale(1.002)}.link-button,.ghost-button,.secondary-button,.positive-button,.danger-button{transition:all var(--duration-fast) var(--ease-out-quart);transform-origin:center}.link-button:active,.ghost-button:active,.secondary-button:active,.positive-button:active{transform:scale(.97)}.nav-link{transition:all var(--duration-fast) var(--ease-out-quart)}.nav-link:hover{transform:translate(2px)}.nav-link.active{transform:translate(0)}.form-input{transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease,background-color var(--duration-fast) ease}.badge{transition:transform var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.badge:hover{transform:scale(1.02)}.form-section{animation:sectionEnter .35s var(--ease-out-expo);animation-fill-mode:both}@keyframes sectionEnter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.form-section:nth-child(1){animation-delay:0ms}.form-section:nth-child(2){animation-delay:50ms}.form-section:nth-child(3){animation-delay:.1s}.form-section:nth-child(4){animation-delay:.15s}.form-section:nth-child(5){animation-delay:.2s}.form-section:nth-child(6){animation-delay:.25s}.form-section:nth-child(7){animation-delay:.3s}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--surface-muted) 25%,var(--surface) 50%,var(--surface-muted) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:6px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s var(--ease-in-out) infinite}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-content,.dropdown-menu{animation:scaleIn .15s var(--ease-out-expo)}@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)}}.topbar{animation:slideUp .25s var(--ease-out-expo)}.sidebar{animation:slideInLeft .3s var(--ease-out-expo)}.stats-grid .stat-card{animation:sectionEnter .35s var(--ease-out-expo);animation-fill-mode:both}.stats-grid .stat-card:nth-child(1){animation-delay:0ms}.stats-grid .stat-card:nth-child(2){animation-delay:50ms}.stats-grid .stat-card:nth-child(3){animation-delay:.1s}.stats-grid .stat-card:nth-child(4){animation-delay:.15s}.stats-grid .stat-card:nth-child(5){animation-delay:.2s}.stats-grid .stat-card:nth-child(6){animation-delay:.25s}.login-card{animation:scaleIn .4s var(--ease-out-expo)}.empty-state{animation:fadeIn .3s var(--ease-out-quart)}.notice,.error-message{animation:slideUp .25s var(--ease-out-expo)}.ghost-button svg,.link-button svg{transition:transform var(--duration-fast) ease}.ghost-button:hover svg,.link-button:hover svg{transform:scale(1.1)}.table-actions{transition:opacity var(--duration-fast) ease}input[type=checkbox]{transition:background-color var(--duration-fast) ease,border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 60%);opacity:0;transform:scale(0);transition:transform .4s ease,opacity .4s ease}.ripple:active:after{transform:scale(2.5);opacity:1;transition:transform 0s,opacity 0s}.admin-data-table-wrapper{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden;box-shadow:var(--shadow-sm)}.adt-toolbar{display:flex;flex-direction:column;gap:.75rem;padding:.875rem 1.125rem;background:var(--surface);border:1px solid var(--border);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.adt-toolbar-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap}.adt-subheader{width:100%}.adt-search-group{display:flex;align-items:center;gap:.625rem;flex:1;min-width:0}.adt-search{display:flex;align-items:center;position:relative;min-width:0;width:100%;max-width:320px;color:var(--text-muted)}.adt-search svg{position:absolute;left:.75rem;pointer-events:none;flex-shrink:0;opacity:.55;transition:opacity .15s ease}.adt-search:focus-within svg{opacity:1;color:var(--primary)}.adt-search .form-input{padding-left:2.25rem;padding-right:2.25rem;width:100%;height:38px;font-size:.8125rem;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);transition:border-color .2s ease,box-shadow .2s ease}.adt-search .form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}[data-theme=dark] .adt-search .form-input:focus{box-shadow:0 0 0 3px #2563eb33}.adt-search-clear{position:absolute;right:.5rem;display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--gray-100);border:none;border-radius:50%;color:var(--text-muted);cursor:pointer;transition:background .15s ease,color .15s ease}.adt-search-clear:hover{background:var(--gray-200);color:var(--text)}[data-theme=dark] .adt-search-clear{background:var(--gray-700)}[data-theme=dark] .adt-search-clear:hover{background:var(--gray-600);color:var(--gray-100)}.adt-result-count{font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap;flex-shrink:0}.adt-results-bar{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-bottom:none}.adt-results-left{display:flex;align-items:center;gap:.5rem}.adt-results-left h3{margin:0;font-size:.95rem;font-weight:700;color:var(--text)}.adt-count-badge{font-size:.75rem;font-weight:600;color:var(--primary);background:#2563eb14;padding:.2rem .6rem;border-radius:999px}[data-theme=dark] .adt-count-badge{background:#2563eb2e}.adt-results-bar:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.admin-data-table-wrapper{border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);overflow-x:auto;overflow-y:hidden}.admin-data-table-wrapper .rdt_Table{min-width:700px}.adt-actions{display:flex;gap:.5rem;flex-shrink:0;flex-wrap:wrap;align-items:center}.admin-data-table-wrapper .rdt_TableHead .rdt_TableHeadRow{background:var(--gray-50);border-bottom:2px solid var(--border)}[data-theme=dark] .admin-data-table-wrapper .rdt_TableHead .rdt_TableHeadRow{background:#0b122480}.admin-data-table-wrapper .rdt_TableCol_Sortable{transition:color .15s ease}.admin-data-table-wrapper .rdt_TableCol_Sortable:hover{color:var(--primary)}.admin-data-table-wrapper .rdt_TableRow{border-bottom-color:var(--border-muted)!important}.adt-results-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding:.75rem 1.125rem;background:var(--surface);border:1px solid var(--border);border-bottom:none;border-radius:12px 12px 0 0}.adt-results-toolbar-left{display:flex;align-items:center;gap:.6rem}.adt-count-badge{font-size:var(--font-xs);font-weight:var(--fw-semibold);background:var(--primary-lighter, rgba(37,99,235,.08));color:var(--primary, #2563eb);padding:.15rem .6rem;border-radius:999px}.adt-sort-label{display:flex;align-items:center;gap:.4rem;font-size:var(--font-small);font-weight:var(--fw-semibold);color:var(--text-secondary);white-space:nowrap}.adt-sort-label select.form-input{padding:.35rem 2rem .35rem .6rem;font-size:var(--font-small);min-width:140px;border-radius:8px}.adt-sort-label select.form-input::-ms-expand{display:none}.adt-results-toolbar+.admin-data-table-wrapper,.adt-results-toolbar+div>.admin-data-table-wrapper{border-top:none;border-radius:0 0 12px 12px}@media (max-width: 640px){.adt-results-toolbar{flex-direction:column;align-items:flex-start;gap:.5rem}}.pd-view-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .7rem;border-radius:6px;background:var(--primary, #4f46e5);color:#fff;font-weight:600;font-size:.75rem;border:none;cursor:pointer;transition:opacity .15s,transform .1s;white-space:nowrap}.pd-view-btn:hover{opacity:.88;transform:translateY(-1px)}.pd-view-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.admin-data-table-wrapper .rdt_Pagination{background:var(--surface);border-top:1px solid var(--border);padding:.5rem 1rem;min-height:52px;font-size:.8rem;display:flex;align-items:center;gap:.25rem}.admin-data-table-wrapper .rdt_Pagination select{-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;background:var(--surface) 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='%2394a3b8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat right .5rem center!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:var(--radius-sm, 6px)!important;padding:.35rem 1.8rem .35rem .6rem!important;font-size:.8rem!important;font-weight:500;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.admin-data-table-wrapper .rdt_Pagination select::-ms-expand{display:none!important}.admin-data-table-wrapper .rdt_Pagination select+svg{display:none!important}.admin-data-table-wrapper .rdt_Pagination select:hover{border-color:var(--primary)!important}.admin-data-table-wrapper .rdt_Pagination select:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px #2563eb1a!important;outline:none!important}[data-theme=dark] .admin-data-table-wrapper .rdt_Pagination select{background:var(--surface) 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.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat right .5rem center!important}[data-theme=dark] .admin-data-table-wrapper .rdt_Pagination select:focus{box-shadow:0 0 0 3px #2563eb33!important}.admin-data-table-wrapper .rdt_Pagination button{color:var(--text-muted);fill:var(--text-muted);border-radius:var(--radius-md, 8px);width:32px;height:32px;transition:background .15s ease,color .15s ease}.admin-data-table-wrapper .rdt_Pagination button:not(:disabled):hover{background:var(--primary-lighter);color:var(--primary);fill:var(--primary)}.admin-data-table-wrapper .rdt_Pagination button:disabled{opacity:.3}.adt-loader{display:flex;flex-direction:column;align-items:center;gap:.875rem;padding:3rem 2rem}.adt-loader span{color:var(--text-muted);font-size:.8125rem;font-weight:500}.adt-loader-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:adt-spin .7s linear infinite}@keyframes adt-spin{to{transform:rotate(360deg)}}.adt-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:3rem 2rem;text-align:center}.adt-empty svg{color:var(--gray-300);margin-bottom:.25rem}[data-theme=dark] .adt-empty svg{color:var(--gray-600)}.adt-empty h3{font-size:var(--font-body);font-weight:var(--fw-semibold);color:var(--text);margin:0}.adt-empty p{font-size:var(--font-small);color:var(--text-muted);margin:0}@media (max-width: 720px){.adt-toolbar-row,.adt-search-group{flex-direction:column;align-items:stretch}.adt-search{max-width:none}.adt-result-count{text-align:right}.adt-actions{justify-content:flex-start}}.draft-restored-banner{display:flex;align-items:center;gap:.5rem;padding:.65rem 1rem;border-radius:var(--radius);background:var(--amber-50, #fffbeb);border:1px solid var(--amber-200, #fde68a);color:var(--amber-800, #92400e);font-size:.84rem;font-weight:500}.draft-restored-banner svg{flex-shrink:0;color:var(--amber-500, #f59e0b)}.preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;z-index:35;overflow-y:auto}.preview-modal{background:var(--surface, #fff);border-radius:var(--radius-lg, 12px);max-width:860px;width:100%;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;max-height:calc(100vh - 4rem);overflow:hidden}.preview-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.preview-body{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.preview-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid var(--border);flex-shrink:0}.preview-breadcrumb{display:flex;flex-wrap:wrap;gap:.25rem;font-size:.8125rem;color:var(--text-secondary)}.preview-breadcrumb-sep{margin:0 .15rem;opacity:.5}.preview-top{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:start}@media (max-width: 680px){.preview-top{grid-template-columns:1fr}}.preview-image-area{display:flex;flex-direction:column;gap:.5rem}.preview-main-image{width:100%;aspect-ratio:1;object-fit:contain;border-radius:var(--radius);border:1px solid var(--border);background:var(--gray-50, #f9fafb)}.preview-no-image{width:100%;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border-radius:var(--radius);border:1px dashed var(--border);background:var(--gray-50, #f9fafb);color:var(--text-secondary);font-size:.8125rem}.preview-thumbnails{display:flex;gap:.35rem}.preview-thumb{width:52px;height:52px;object-fit:cover;border-radius:6px;border:1px solid var(--border);cursor:pointer}.preview-thumb-more{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--border);background:var(--gray-100, #f3f4f6);font-size:.75rem;font-weight:600;color:var(--text-secondary)}.preview-info{display:flex;flex-direction:column;gap:.75rem}.preview-info-row{display:flex;gap:.5rem;align-items:center}.preview-product-name{font-size:1.25rem;font-weight:700;color:var(--text);margin:0;line-height:1.3}.preview-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}.preview-meta-item{display:flex;flex-direction:column;gap:.15rem}.preview-meta-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.preview-meta-value{font-size:.875rem;font-weight:500;color:var(--text)}.preview-short-desc{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.preview-section{border-top:1px solid var(--border);padding-top:1rem}.preview-section h4{margin:0 0 .75rem;font-size:.9375rem;font-weight:600;color:var(--text)}.preview-table{width:100%;border-collapse:collapse;font-size:.8125rem}.preview-table th,.preview-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border);text-align:left}.preview-table th{font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;background:var(--gray-50, #f9fafb)}.preview-specs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}.preview-spec-item{display:flex;flex-direction:column;gap:.15rem;padding:.5rem .75rem;border-radius:8px;background:var(--gray-50, #f9fafb);border:1px solid var(--border)}.preview-spec-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.preview-spec-value{font-size:.875rem;font-weight:500;color:var(--text)}.preview-datasheet-link{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--primary);font-size:.8125rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}.preview-datasheet-link:hover{background:var(--gray-50, #f9fafb);border-color:var(--primary)}.badge.warning{background:var(--amber-100, #fef3c7);color:var(--amber-800, #92400e);border:1px solid var(--amber-200, #fde68a)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .15s ease}[data-theme=dark] .modal-backdrop{background:#000000a6}.modal-dialog{background:var(--card-bg, #fff);border:1px solid var(--border);border-radius:var(--radius, .5rem);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026;animation:scaleIn .15s var(--ease-out-expo, ease)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-header h3{font-size:var(--font-card-title);font-weight:var(--fw-bold)}.modal-body{padding:1.25rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid var(--border)}.pd-summary-strip{display:flex;flex-wrap:wrap;gap:0;background:var(--surface, #fff);border:1px solid var(--border);border-radius:12px;overflow:hidden}.pd-summary-item{flex:1 1 auto;min-width:120px;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.85rem 1rem;border-right:1px solid var(--border)}.pd-summary-item:last-child{border-right:none}.pd-summary-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start}@media (max-width: 900px){.pd-grid{grid-template-columns:1fr}}.pd-left,.pd-right{display:flex;flex-direction:column;gap:1.25rem}.pd-section-card{background:var(--surface, #fff);border:1px solid var(--border);border-radius:12px;overflow:hidden}.pd-section-header{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface-2, #f8fafc)}.pd-section-header svg{color:var(--primary, #4f46e5);opacity:.8;flex-shrink:0}.pd-section-title{margin:0;font-size:var(--font-label);font-weight:var(--fw-bold);color:var(--text-primary)}.pd-section-body{padding:1rem 1.25rem}.pd-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.pd-table{width:100%;border-collapse:collapse;font-size:.83rem}.pd-table th{text-align:left;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:.5rem .6rem;border-bottom:2px solid var(--border);white-space:nowrap}.pd-table td{padding:.55rem .6rem;border-bottom:1px solid var(--border);color:var(--text-primary)}.pd-table tbody tr:last-child td{border-bottom:1px solid var(--border)}.pd-table tfoot td{border-top:2px solid var(--border);border-bottom:none;padding-top:.65rem}.pd-back-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border-radius:10px;background:var(--primary, #4f46e5);color:#fff;font-weight:700;font-size:.85rem;border:none;cursor:pointer;transition:opacity .15s}.pd-back-btn:hover{opacity:.9}.pd-loader{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary, #4f46e5);border-radius:50%;animation:pd-spin .7s linear infinite}@keyframes pd-spin{to{transform:rotate(360deg)}}.pd-comment-box{padding:.85rem 1rem;background:var(--surface-2, #f8fafc);border:1px solid var(--border);border-radius:10px}.pd-comment-box+.pd-comment-box{margin-top:.6rem}.pd-comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.pd-comment-author{font-size:.8rem;font-weight:700;color:var(--text-primary)}.pd-comment-time{font-size:.7rem;color:var(--text-muted)}.pd-comment-body{font-size:.82rem;line-height:1.55;color:var(--text-primary);white-space:pre-wrap}.od-summary-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem}.od-summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.85rem 1rem;display:flex;align-items:flex-start;gap:.7rem;transition:transform .18s ease,box-shadow .18s ease}.od-summary-card:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0f172a12}.od-summary-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.od-summary-icon.blue{background:#eff6ff;color:#2563eb}.od-summary-icon.green{background:#ecfdf5;color:#16a34a}.od-summary-icon.amber{background:#fffbeb;color:#d97706}.od-summary-icon.purple{background:#f5f3ff;color:#7c3aed}.od-summary-icon.rose{background:#fff1f2;color:#e11d48}.od-summary-icon.slate{background:#f1f5f9;color:#475569}.od-summary-body{flex:1;min-width:0}.od-summary-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.15rem}.od-summary-value{font-size:1.05rem;font-weight:700;color:var(--text);line-height:1.25}.od-summary-hint{font-size:.72rem;color:var(--text-muted);margin-top:.15rem}.od-totals-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:.65rem}.od-total-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.7rem .9rem;text-align:center;transition:transform .18s ease,box-shadow .18s ease}.od-total-card:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0f172a12}.od-total-card.grand{border-color:var(--primary);border-width:2px;background:linear-gradient(135deg,#eff6ff,#f0f4ff)}.od-total-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.2rem}.od-total-value{font-size:1.05rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.od-total-card.grand .od-total-value{font-size:1.25rem;color:var(--primary)}[data-theme=dark] .od-summary-icon.blue{background:#1e3a5f}[data-theme=dark] .od-summary-icon.green{background:#14352a}[data-theme=dark] .od-summary-icon.amber{background:#3b2f1a}[data-theme=dark] .od-summary-icon.purple{background:#2e1f5e}[data-theme=dark] .od-summary-icon.rose{background:#3b1a20}[data-theme=dark] .od-summary-icon.slate{background:#1e293b}[data-theme=dark] .od-total-card.grand{background:linear-gradient(135deg,#1e293b,#1e3a5f)}@media (max-width: 900px){.od-summary-strip{grid-template-columns:1fr}.od-totals-strip{grid-template-columns:repeat(2,1fr)}}@media (max-width: 700px){.perm-grid-2col{grid-template-columns:1fr!important}}.od-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.od-tabs::-webkit-scrollbar{display:none}.od-tab{position:relative;display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.15rem;font-size:.82rem;font-weight:600;color:var(--text-muted);background:none;border:none;border-bottom:2.5px solid transparent;margin-bottom:-2px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.od-tab:hover{color:var(--primary)}.od-tab-active{color:var(--primary);border-bottom-color:var(--primary)}.od-tab .badge{font-size:.62rem;padding:.1rem .42rem;vertical-align:middle}html.dark .od-tab{color:var(--text-muted)}html.dark .od-tab:hover,html.dark .od-tab-active{color:var(--primary-light);border-bottom-color:var(--primary-light)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
