*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #F3F5F8;--bg-secondary: #FFFFFF;--bg-tertiary: #E8EEF5;--bg-surface: #FFFFFF;--app-rail: #102033;--app-rail-hover: #172F4B;--app-rail-active:#1F6FBD;--border-subtle: #D6DEE8;--text-primary: #17202A;--text-secondary: #4B5563;--text-dim: #6B7280;--text-dark: #1A1D27;--text-on-rail: #E6EEF8;--text-rail-dim: #9BAEC4;--accent: #1F6FBD;--accent-hover: #185FA5;--accent-pressed: #124B84;--status-success: #4ADE80;--status-warning: #FBBF24;--status-error: #F87171;--status-info: #60A5FA;--preview-bg: #202020;--preview-card: #2D2D2D;--preview-text: #FFFFFF;--preview-sub: #C0C0C0;--shadow-1: 0 1px 2px rgba(15,23,42,.06);--shadow-2: 0 8px 24px rgba(15,23,42,.1);--shadow-3: 0 16px 40px rgba(15,23,42,.18);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--font-sans: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Consolas", monospace}html,body,#root{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}body{color-scheme:light}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#b9c5d3;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#8ca0b8}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,textarea,select,button{font-family:inherit;font-size:inherit}.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}.app-shell{display:flex;height:100vh;overflow:hidden;background:var(--bg-primary)}.app-workspace{display:flex;flex:1;min-width:0;flex-direction:column}.app-topbar{height:64px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:0 28px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle)}.app-kicker{font-size:11px;font-weight:700;line-height:1;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em}.app-title{margin-top:4px;font-size:18px;font-weight:700;line-height:1.2;color:var(--text-primary)}.app-main{flex:1;min-width:0;overflow-y:auto;padding:28px}.identity-chip{display:inline-flex;align-items:center;gap:10px;min-width:0;padding:6px 10px 6px 6px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:#f8fafc}.identity-avatar{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);background:#dce8f7;color:var(--accent-pressed);font-size:13px;font-weight:700}.identity-copy{min-width:0;display:flex;flex-direction:column;line-height:1.2}.identity-copy strong{max-width:220px;overflow:hidden;color:var(--text-primary);font-size:12px;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.identity-copy small{margin-top:2px;color:var(--text-dim);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.app-sidebar{width:248px;flex-shrink:0;display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--app-rail);border-right:1px solid rgba(255,255,255,.08);color:var(--text-on-rail)}.sidebar-brand{padding:22px 18px 18px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-brand-row{display:flex;align-items:center;gap:10px}.sidebar-brand-mark{display:flex;width:34px;height:34px;flex-shrink:0;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--app-rail-active)}.sidebar-product{color:var(--text-on-rail);font-size:13px;font-weight:700;line-height:1.2}.sidebar-console{margin-top:2px;color:var(--text-rail-dim);font-size:11px;font-weight:500}.sidebar-role{margin-top:14px;width:fit-content;padding:3px 8px;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-sm);color:#d8e8fa;background:#ffffff0f;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px}.sidebar-section-label{padding:14px 10px 6px;color:var(--text-rail-dim);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.sidebar-link{position:relative;display:flex;align-items:center;gap:10px;min-height:38px;margin-bottom:2px;padding:9px 10px 9px 12px;border-radius:var(--radius-sm);color:var(--text-rail-dim);font-size:13px;font-weight:600;line-height:1;text-decoration:none;transition:background .12s,color .12s}.sidebar-link svg{flex-shrink:0}.sidebar-link:hover{background:var(--app-rail-hover);color:var(--text-on-rail)}.sidebar-link.active{background:#1f6fbd38;color:#fff}.sidebar-link.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 2px 2px 0;background:#5aa7f2}.sidebar-footer{padding:12px 10px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-signout{display:flex;width:100%;min-height:38px;align-items:center;gap:10px;padding:9px 10px 9px 12px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-rail-dim);cursor:pointer;font-size:13px;font-weight:600;text-align:left}.sidebar-signout:hover{background:var(--app-rail-hover);color:var(--text-on-rail)}.btn{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:9px 14px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;font-size:13px;font-weight:700;line-height:1;transition:background .15s,border-color .15s,color .15s,opacity .15s;white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:active:not(:disabled){background:var(--accent-pressed)}.btn-secondary{background:#eef3f8;border-color:var(--border-subtle);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:#e2eaf3}.btn-danger{background:var(--status-error);border-color:var(--status-error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-subtle)}.card{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);box-shadow:var(--shadow-1);padding:24px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.field input,.field textarea,.field select{background:#fff;border:1px solid #C8D3DF;border-radius:var(--radius-sm);color:var(--text-primary);padding:10px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1f6fbd1f;outline:none}.field input::placeholder,.field textarea::placeholder{color:var(--text-dim)}.field textarea{resize:vertical;min-height:80px}.field select option{background:#fff}.char-counter{font-size:11px;color:var(--text-dim);text-align:right}.char-counter.warning{color:var(--status-warning)}.char-counter.error{color:var(--status-error)}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px}.page-header h1{font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:0}.page-header .subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.data-table{width:100%;border-collapse:collapse}.data-table th{font-size:11px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;padding:10px 16px;text-align:left;border-bottom:1px solid var(--border-subtle);background:#f7f9fc}.data-table td{padding:12px 16px;border-bottom:1px solid #E5EAF0;color:var(--text-secondary);font-size:13px}.data-table td:first-child{color:var(--text-primary)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f8fbfe}.metric-card{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:20px 24px;box-shadow:var(--shadow-1)}.metric-card .metric-label{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.metric-card .metric-value{font-size:30px;font-weight:700;color:var(--text-primary);line-height:1.2}.metric-card .metric-sub{font-size:12px;color:var(--text-dim);margin-top:4px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px;color:var(--text-dim);text-align:center}.empty-state svg{opacity:.4}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a7a;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-3);padding:32px;max-width:480px;width:100%;margin:16px}.modal h2{font-size:20px;font-weight:700;margin-bottom:8px}.modal p{color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(31,111,189,.18);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:#fef2f2;border:1px solid #FCA5A5;border-radius:var(--radius-sm);padding:12px 16px;color:var(--status-error);font-size:13px;margin-bottom:16px}.success-banner{background:#ecfdf5;border:1px solid #86EFAC;border-radius:var(--radius-sm);padding:12px 16px;color:var(--status-success);font-size:13px;margin-bottom:16px}@media(max-width:920px){.app-sidebar{width:72px}.sidebar-product,.sidebar-console,.sidebar-role,.sidebar-section-label,.sidebar-link span,.sidebar-signout{font-size:0}.sidebar-brand{padding:18px}.sidebar-link,.sidebar-signout{justify-content:center;padding:10px}.app-main{padding:20px}.identity-copy strong{max-width:140px}}@media(max-width:640px){.app-topbar{height:auto;min-height:64px;align-items:flex-start;flex-direction:column;padding:14px 16px}.page-header{align-items:flex-start;flex-direction:column}}
