:root{--color-primary: #000000;--color-primary-hover: #1a1a1a;--color-primary-active: #333333;--color-primary-subtle: #f5f5f5;--color-primary-muted: #e8e8e8;--color-bg: #ffffff;--color-surface: #fafafa;--color-surface-2: #f4f4f4;--color-surface-3: #eeeeee;--color-border: #e8e8e8;--color-border-strong: #cccccc;--color-text: #111111;--color-text-secondary: #555555;--color-text-muted: #999999;--color-text-inverse: #ffffff;--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-success-border: #bbf7d0;--color-warning: #d97706;--color-warning-bg: #fffbeb;--color-warning-border: #fde68a;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--font-sans: "DM Sans", system-ui, -apple-system, sans-serif;--font-mono: "DM Mono", "Fira Code", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 16px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--text-3xl: 36px;--leading-tight: 1.2;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--radius-xs: 3px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0,0,0,.06);--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.04);--shadow-xl: 0 20px 25px rgba(0,0,0,.1), 0 8px 10px rgba(0,0,0,.04);--nav-height: 56px;--max-width: 1100px;--content-padding: var(--space-6);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--weight-regular);line-height:var(--leading-normal);color:var(--color-text);background:var(--color-bg);min-height:100vh}img,video{max-width:100%}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}a{color:inherit;text-decoration:none}#root,.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;padding-top:var(--nav-height)}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--content-padding)}.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);background:var(--color-bg);border-bottom:1px solid var(--color-border);display:flex;align-items:center}.nav-inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--content-padding);display:flex;align-items:center;gap:var(--space-8);width:100%}.nav-logo{font-size:18px;font-weight:var(--weight-bold);letter-spacing:-.5px;color:var(--color-text);flex-shrink:0}.nav-links{display:flex;align-items:center;gap:var(--space-1);flex:1}.nav-link{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);transition:color var(--transition-fast),background var(--transition-fast);background:none;border:none;white-space:nowrap}.nav-link:hover{color:var(--color-text);background:var(--color-surface-2)}.nav-link.active{color:var(--color-text);background:var(--color-primary-muted);font-weight:var(--weight-semibold)}.page{padding:var(--space-8) 0 var(--space-16)}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--text-2xl);font-weight:var(--weight-bold);letter-spacing:-.5px;line-height:var(--leading-tight);color:var(--color-text)}.page-subtitle{margin-top:var(--space-2);font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.page-grid{display:grid;gap:var(--space-6)}.page-grid-2{grid-template-columns:1fr 1fr}.page-grid-3{grid-template-columns:repeat(3,1fr)}.page-grid-sidebar{grid-template-columns:1fr 340px}.card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.card-sm{padding:var(--space-4);border-radius:var(--radius-md)}.card-flat{border-radius:var(--radius-md);border:1px solid var(--color-border)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5);gap:var(--space-4)}.card-title{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--color-text);letter-spacing:-.2px}.card-desc{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:9px var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);line-height:1;border:1px solid transparent;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.45;pointer-events:none}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{background:var(--color-bg);color:var(--color-text);border-color:var(--color-border-strong)}.btn-secondary:hover{background:var(--color-surface-2);border-color:var(--color-border-strong)}.btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:transparent}.btn-ghost:hover{background:var(--color-surface-2);color:var(--color-text)}.btn-danger{background:var(--color-error-bg);color:var(--color-error);border-color:var(--color-error-border)}.btn-danger:hover{background:var(--color-error);color:#fff}.btn-sm{padding:6px var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-sm)}.btn-lg{padding:12px var(--space-6);font-size:var(--text-base)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text)}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted)}.form-input,.form-select,.form-textarea{width:100%;padding:9px var(--space-3);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #00000014}.form-textarea{resize:vertical;min-height:80px;line-height:var(--leading-relaxed)}.form-grid{display:grid;gap:var(--space-4)}.form-grid-2{grid-template-columns:1fr 1fr}.form-grid-3{grid-template-columns:repeat(3,1fr)}.form-grid-4{grid-template-columns:repeat(4,1fr)}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border)}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}thead tr{background:var(--color-surface);border-bottom:1px solid var(--color-border)}th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--color-surface)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-medium);line-height:1;white-space:nowrap}.badge-default{background:var(--color-surface-2);color:var(--color-text-secondary)}.badge-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}.badge-error{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error-border)}.badge-black{background:var(--color-primary);color:var(--color-text-inverse)}.progress-bar-wrap{height:6px;background:var(--color-surface-2);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow);background:var(--color-primary)}.progress-bar-fill.success{background:var(--color-success)}.progress-bar-fill.warning{background:var(--color-warning)}.progress-bar-fill.error{background:var(--color-error)}.divider{height:1px;background:var(--color-border);margin:var(--space-6) 0}.callout{padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:var(--leading-relaxed);border-left:3px solid}.callout-info{background:var(--color-surface-2);border-color:var(--color-border-strong);color:var(--color-text-secondary)}.callout-success{background:var(--color-success-bg);border-color:var(--color-success);color:#15803d}.callout-warning{background:var(--color-warning-bg);border-color:var(--color-warning);color:#92400e}.callout-error{background:var(--color-error-bg);border-color:var(--color-error);color:#991b1b}.callout-black{background:var(--color-primary);border-color:transparent;color:var(--color-text-inverse);border-radius:var(--radius-md)}.tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-6)}.tab-btn{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--transition-fast),border-color var(--transition-fast);cursor:pointer}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-text);border-bottom-color:var(--color-primary);font-weight:var(--weight-semibold)}.stat{display:flex;flex-direction:column;gap:var(--space-1)}.stat-label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:var(--text-xl);font-weight:var(--weight-bold);letter-spacing:-.5px;line-height:1;color:var(--color-text)}.stat-value-sm{font-size:var(--text-lg);font-weight:var(--weight-semibold)}.stat-sub{font-size:var(--text-xs);color:var(--color-text-muted)}.empty{text-align:center;padding:var(--space-16) var(--space-8);color:var(--color-text-muted)}.empty-title{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.empty-desc{font-size:var(--text-sm)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-4)}.modal{background:var(--color-bg);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:480px;box-shadow:var(--shadow-xl)}.modal-header{margin-bottom:var(--space-6)}.modal-title{font-size:var(--text-lg);font-weight:var(--weight-bold);letter-spacing:-.3px}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.spinner-lg{width:24px;height:24px;border-width:2.5px}@keyframes spin{to{transform:rotate(360deg)}}.loading-pulse{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-sm{font-size:var(--text-sm)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.font-medium{font-weight:var(--weight-medium)}.font-semibold{font-weight:var(--weight-semibold)}.font-mono{font-family:var(--font-mono)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media (max-width: 768px){:root{--content-padding: var(--space-4);--nav-height: 52px}.page-grid-2,.page-grid-3,.page-grid-sidebar{grid-template-columns:1fr}.form-grid-2,.form-grid-3,.form-grid-4{grid-template-columns:1fr 1fr}.nav-links{gap:0}.nav-logo{display:none}}@media (max-width: 480px){.form-grid-2,.form-grid-3,.form-grid-4{grid-template-columns:1fr}}
