.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-nav{position:sticky;top:0;z-index:10;background:#0a0e14d9;backdrop-filter:saturate(140%) blur(8px);-webkit-backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--border-subtle)}.app-nav-inner{max-width:var(--content-max);margin:0 auto;padding:0 var(--space-5);height:var(--nav-height);display:flex;align-items:center;gap:var(--space-5)}.app-brand{display:flex;align-items:center;gap:var(--space-2);color:var(--text-primary);font-weight:600;font-size:var(--text-md)}.app-brand:hover{color:var(--text-primary)}.app-brand-mark{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent) 0%,#7c3aed 100%);color:#fff;font-weight:700;font-size:13px;letter-spacing:-.02em}.app-nav-links{display:flex;align-items:center;gap:6px;margin-left:var(--space-5);padding:4px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-full)}.app-nav-link{position:relative;color:var(--text-secondary);padding:6px 14px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;border:1px solid transparent;transition:background .14s ease,color .14s ease,border-color .14s ease;line-height:1.2}.app-nav-link:hover{color:var(--text-primary);background:var(--bg-elevated)}.app-nav-link.active{color:var(--text-primary);background:var(--bg-elevated);border-color:var(--border-strong);box-shadow:inset 0 0 0 1px var(--accent-soft)}.app-nav-end{margin-left:auto;display:flex;align-items:center;gap:var(--space-3)}.app-user-chip{font-size:var(--text-xs);color:var(--text-secondary);background:var(--bg-elevated);padding:4px 10px;border-radius:var(--radius-full);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-signout{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-default);padding:6px 14px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;transition:background .12s ease,color .12s ease,border-color .12s ease}.app-signout:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-strong)}.app-content{flex:1;width:100%;max-width:var(--content-max);margin:0 auto;padding:var(--space-6) var(--space-5)}.app-content-narrow{max-width:var(--content-max-narrow)}@media (max-width: 720px){.app-nav-inner{gap:var(--space-2);padding:0 var(--space-3)}.app-nav-links{margin-left:0;padding:3px;gap:2px}.app-nav-link{padding:5px 10px;font-size:12px}.app-brand-name,.app-user-chip{display:none}.app-content{padding:var(--space-5) var(--space-3)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font:inherit;font-weight:500;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease,transform 80ms ease,box-shadow .12s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn:disabled{cursor:not-allowed;opacity:.55}.btn:not(:disabled):active{transform:translateY(1px)}.btn-sm{padding:6px 12px;font-size:var(--text-sm)}.btn-md{padding:9px 18px;font-size:var(--text-sm)}.btn-primary{background:var(--accent);color:var(--accent-text-on)}.btn-primary:not(:disabled):hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:not(:disabled):hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-danger{background:transparent;color:var(--danger-text);border-color:var(--border-default)}.btn-danger:not(:disabled):hover{background:var(--danger-bg);border-color:var(--danger)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:not(:disabled):hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-loading{pointer-events:none}.btn-spinner{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:btn-spin .7s linear infinite;opacity:.85}@keyframes btn-spin{to{transform:rotate(360deg)}}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5)}.card-compact{padding:var(--space-3)}.card-flat{border:none}.page-header{margin-bottom:var(--space-6)}.page-header-back{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);font-size:var(--text-sm);padding:4px 12px;border-radius:var(--radius-full);background:var(--bg-surface);border:1px solid var(--border-subtle);margin-bottom:var(--space-3);transition:background .12s ease,color .12s ease,border-color .12s ease}.page-header-back:hover{color:var(--text-primary);background:var(--bg-elevated);border-color:var(--border-strong)}.page-header-row{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.page-header-title{margin:0;font-size:var(--text-2xl);letter-spacing:-.01em}.page-header-subtitle{color:var(--text-secondary);font-size:var(--text-base);margin-top:var(--space-1);max-width:60ch}.page-header-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.empty-state{border:1px dashed var(--border-default);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-5);text-align:center;background:var(--bg-surface)}.empty-state-title{font-size:var(--text-md);font-weight:500;color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state-hint{color:var(--text-secondary);font-size:var(--text-sm);max-width:40ch;margin:0 auto}.empty-state-action{margin-top:var(--space-4)}.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;line-height:1;white-space:nowrap;border:1px solid transparent}.tag-neutral{background:var(--bg-elevated);color:var(--text-secondary);border-color:var(--border-subtle)}.tag-success{background:var(--success-bg);color:var(--success-text);border-color:#10b9814d}.tag-warning{background:var(--warning-bg);color:var(--warning-text);border-color:#f59e0b4d}.tag-danger{background:var(--danger-bg);color:var(--danger-text);border-color:#ef44444d}.tag-accent{background:var(--accent-soft);color:var(--accent-hover);border-color:#5b8def4d}.table-wrapper{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table th{text-align:left;font-weight:500;color:var(--text-secondary);padding:10px 14px;border-bottom:1px solid var(--border-default);background:var(--bg-surface);position:sticky;top:0}.table td{padding:10px 14px;border-bottom:1px solid var(--border-subtle);vertical-align:top;color:var(--text-primary)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background .1s ease}.table tbody tr:hover{background:var(--bg-elevated)}.td-ellipsis{max-width:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.td-muted{color:var(--text-muted)}.field{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.field-label{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.field-hint{font-size:var(--text-xs);color:var(--text-muted)}.error-banner{display:flex;align-items:flex-start;gap:var(--space-3);background:var(--danger-bg);border:1px solid rgba(239,68,68,.35);color:var(--danger-text);padding:12px 14px;border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-sm)}.error-banner-icon{font-size:16px;line-height:1;flex-shrink:0;margin-top:1px}.error-banner-body{flex:1}.error-banner-dismiss{background:transparent;color:inherit;border:none;padding:0 4px;opacity:.6;font-size:14px}.error-banner-dismiss:hover{opacity:1}:root{--bg-base: #0a0e14;--bg-surface: #11161f;--bg-elevated: #1a2030;--bg-hover: #232b3d;--border-subtle: #1f2937;--border-default: #2a3447;--border-strong: #3a4663;--text-primary: #e6edf3;--text-secondary: #9ca3af;--text-muted: #6b7280;--text-inverse: #0a0e14;--accent: #5b8def;--accent-hover: #7ba3ff;--accent-pressed: #4778d8;--accent-soft: rgba(91, 141, 239, .12);--accent-text-on: #ffffff;--success: #10b981;--success-bg: rgba(16, 185, 129, .14);--success-text: #6ee7b7;--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .14);--warning-text: #fcd34d;--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .14);--danger-text: #fca5a5;--focus-ring: 0 0 0 2px var(--bg-base), 0 0 0 4px var(--accent);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;--text-xs: 12px;--text-sm: 13px;--text-base: 14px;--text-md: 15px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--text-3xl: 36px;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.7;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--radius-full: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .45);--nav-height: 56px;--content-max: 960px;--content-max-narrow: 640px}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100vh}body{margin:0;background:var(--bg-base);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{margin:0;line-height:var(--leading-tight);color:var(--text-primary);font-weight:600}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}h4{font-size:var(--text-md)}p{margin:0;line-height:var(--leading-normal)}a{color:var(--accent);text-decoration:none;transition:color .12s ease}a:hover{color:var(--accent-hover)}code,pre,kbd,samp{font-family:var(--font-mono);font-size:.92em}code{background:var(--bg-elevated);color:var(--text-primary);padding:1px 6px;border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}hr{border:0;border-top:1px solid var(--border-default);margin:var(--space-5) 0}input,textarea,select{font:inherit;color:var(--text-primary);background:var(--bg-base);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:8px 10px;outline:none;transition:border-color .12s ease,box-shadow .12s ease;width:100%}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}input[disabled],textarea[disabled],select[disabled]{opacity:.55;cursor:not-allowed}input[type=file]{border:1px dashed var(--border-strong);padding:12px;background:var(--bg-surface);cursor:pointer}input[type=file]::file-selector-button{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default);padding:6px 12px;border-radius:var(--radius-sm);margin-right:var(--space-3);font:inherit;cursor:pointer}input[type=file]::file-selector-button:hover{background:var(--bg-hover)}input[type=checkbox]{width:auto;accent-color:var(--accent);cursor:pointer}textarea{resize:vertical;min-height:80px;font-family:var(--font-mono);font-size:var(--text-sm)}button{font:inherit;cursor:pointer}::selection{background:var(--accent);color:var(--accent-text-on)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full);border:2px solid var(--bg-base)}*::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.muted{color:var(--text-secondary)}.dim{color:var(--text-muted)}.error{color:var(--danger-text)}.success{color:var(--success-text)}.mono{font-family:var(--font-mono);font-size:var(--text-sm)}.stack{display:flex;flex-direction:column;gap:var(--space-3)}.row{display:flex;gap:var(--space-3);align-items:center}.row-end{display:flex;gap:var(--space-3);align-items:center;justify-content:flex-end}.spread{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.grow{flex:1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
