:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#111827;background:#f5f7fb;line-height:1.5;font-weight:400}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:#f5f7fb;color:#111827}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh;display:grid;grid-template-columns:264px 1fr}.sidebar{background:#0f172a;color:#fff;padding:20px 16px;border-right:1px solid rgba(255,255,255,.08)}.sidebar-brand{display:flex;gap:12px;align-items:center;margin-bottom:28px}.brand-mark{width:42px;height:42px;border-radius:12px;background:#fff;color:#0f172a;display:grid;place-items:center;font-weight:700}.brand-title{font-weight:700}.brand-subtitle{color:#ffffffb8;font-size:12px}.sidebar-nav{display:flex;flex-direction:column;gap:6px}.nav-item{padding:11px 12px;border-radius:10px;color:#ffffffdb;font-size:14px}.nav-item:hover,.nav-item.active{background:#ffffff1f;color:#fff}.app-main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 28px;background:#fff;border-bottom:1px solid #e5e7eb}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#6b7280}.topbar-title{margin:4px 0 0;font-size:24px}.topbar-actions,.page-actions,.button-row,.pill-row{display:flex;gap:8px;flex-wrap:wrap}.app-content{padding:24px 28px 40px}.breadcrumbs{display:flex;align-items:center;gap:6px;color:#6b7280;margin-bottom:18px;font-size:14px;flex-wrap:wrap}.breadcrumb-divider{margin:0 2px}.breadcrumb-current{color:#111827;font-weight:600}.page-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:20px}.page-title{margin:0;font-size:28px}.page-description{margin:6px 0 0;color:#6b7280;max-width:860px}.button{border:1px solid #111827;background:#111827;color:#fff;padding:10px 14px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.button:disabled{cursor:not-allowed;opacity:.6}.button-secondary{background:#fff;color:#111827}.topbar-button{padding:8px 12px}.card,.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 1px 2px #1018280a}.card-header{padding:18px 20px 0;display:flex;justify-content:space-between;gap:16px}.card-title{margin:0;font-size:18px}.card-subtitle{margin:4px 0 0;color:#6b7280;font-size:14px}.card-body{padding:20px}.stat-card{padding:18px}.stat-label{color:#6b7280;font-size:14px}.stat-value{font-size:32px;font-weight:700;margin-top:8px}.stat-value-compact{font-size:18px;line-height:1.4;word-break:break-word}.stat-helper{color:#6b7280;font-size:13px;margin-top:4px}.stats-grid,.three-col,.two-col{display:grid;gap:16px;margin-bottom:16px}.stats-grid,.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.stack{display:flex;flex-direction:column;gap:16px}.stack-sm{display:flex;flex-direction:column;gap:10px}.editor-stack{display:flex;flex-direction:column;gap:14px}.editor-card{border:1px solid #e5e7eb;border-radius:14px;padding:14px;background:#fafafa}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.section-block{margin-bottom:16px}.section-header h3{margin:0 0 4px}.section-header p,.muted-text{margin:0;color:#6b7280}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{text-align:left;padding:12px 14px;border-bottom:1px solid #e5e7eb;vertical-align:top;font-size:14px}.data-table th{color:#6b7280;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.data-table tbody tr:last-child td{border-bottom:0}.text-link{color:#1d4ed8;font-weight:600}.text-link:hover{text-decoration:underline}.text-button{border:0;background:transparent;color:#1d4ed8;cursor:pointer;font:inherit;font-weight:600;padding:0;text-align:left}.text-button:hover,.text-button.active{text-decoration:underline}.empty-state{border:1px dashed #d1d5db;border-radius:14px;padding:18px;min-height:170px;display:flex;flex-direction:column;justify-content:center;background:#fafafa}.empty-state h4{margin:0 0 6px}.empty-state p{margin:0;color:#6b7280}.empty-icon{font-size:22px;margin-bottom:8px;color:#6b7280}.status-badge,.pill,.inline-badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;border:1px solid #d1d5db;background:#f9fafb}.pill.muted{color:#475569;background:#f8fafc}.inline-badge.on{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.inline-badge.off{background:#f3f4f6;color:#6b7280}.status-active{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.status-draft{background:#fffbeb;color:#92400e;border-color:#fde68a}.status-disabled,.status-archived{background:#f3f4f6;color:#374151}.status-placeholder{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.status-ready{background:#eef2ff;color:#4338ca;border-color:#c7d2fe}.status-pending{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.status-approved{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.status-declined{background:#fff7ed;color:#9a3412;border-color:#fdba74}.status-error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.tabs-root{display:flex;flex-direction:column;gap:16px}.tabs-list{display:flex;gap:8px;flex-wrap:wrap}.tab-button{border:1px solid #d1d5db;background:#fff;color:#374151;padding:10px 14px;border-radius:10px;cursor:pointer}.tab-button.active{border-color:#111827;background:#111827;color:#fff}.tabs-panel{min-width:0}.kv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.kv-item{border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px;background:#fafafa}.kv-label{color:#6b7280;font-size:12px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.kv-value{font-weight:600}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.compact-grid{grid-template-columns:1fr}.field-row{display:flex;flex-direction:column;gap:6px}.field-row label{color:#6b7280;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.field-row input{border:1px solid #d1d5db;border-radius:10px;background:#fafafa;padding:10px 12px;color:#111827;width:100%}.field-row select,.field-row textarea{border:1px solid #d1d5db;border-radius:10px;background:#fafafa;padding:10px 12px;color:#111827}.field-select{min-height:44px}.lookup-row{display:flex;gap:10px;align-items:center}.lookup-row .button{flex-shrink:0}.checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.checkbox-card{display:flex;align-items:center;gap:10px;border:1px solid #d1d5db;border-radius:12px;padding:12px 14px;background:#fafafa;cursor:pointer}.checkbox-card.compact{min-height:44px}.checkbox-card.checked{border-color:#93c5fd;background:#eff6ff}.checkbox-card input{margin:0}.field-textarea{width:100%;min-height:360px;resize:vertical}.code-area,.json-panel{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.55}.json-panel{margin:0;padding:14px;border:1px solid #e5e7eb;border-radius:12px;background:#fafafa;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.inline-alert{border-radius:12px;padding:12px 14px;border:1px solid #d1d5db}.inline-alert.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.template-banner,.candidate-detail-card,.policy-summary-card,.trace-stage-card{border:1px solid #e5e7eb;border-radius:14px;background:#fafafa}.template-banner,.candidate-detail-card,.trace-stage-card{padding:14px}.template-banner{display:flex;flex-direction:column;gap:12px}.template-banner-top,.candidate-detail-header,.trace-stage-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.policy-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.policy-summary-card{padding:14px;display:flex;flex-direction:column;gap:8px}.policy-summary-label{color:#6b7280;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.candidate-detail-header h4{margin:0 0 4px}.candidate-detail-header p{margin:0;color:#6b7280}.candidate-score{font-size:18px;font-weight:700}.trace-stage-list{display:flex;flex-direction:column;gap:12px}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top left,rgba(37,99,235,.14),transparent 32%),radial-gradient(circle at bottom right,rgba(15,23,42,.12),transparent 28%),#f5f7fb}.auth-card{width:min(100%,460px);background:#ffffffeb;border:1px solid rgba(148,163,184,.28);border-radius:22px;padding:28px;box-shadow:0 18px 60px #0f172a1f}.auth-title{margin:8px 0 10px;font-size:34px;line-height:1.05}.auth-form{display:flex;flex-direction:column;gap:14px;margin-top:22px}.auth-submit{margin-top:8px;width:100%;justify-content:center}.auth-note{margin-top:16px;color:#6b7280;font-size:13px}.tree-list{list-style:none;margin:0;padding-left:0}.tree-list.nested{padding-left:24px;margin-top:10px;border-left:1px solid #d1d5db}.tree-list>li+li,.tree-list.nested>li+li{margin-top:12px}.tree-node{border:1px solid #d1d5db;border-radius:12px;padding:12px 14px;background:#fff}.tree-node.portfolio{background:#eff6ff}.tree-node.merchant{background:#ecfeff}.tree-node.structural{background:#f8fafc}.tree-node.transacting{background:#fafafa}.tree-node-label{font-weight:700}.tree-node-meta{color:#6b7280;font-size:13px;margin-top:4px}.mini-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.mini-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.mini-grid>div{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border-radius:12px;background:#fafafa;border:1px solid #e5e7eb}.mini-grid strong{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#6b7280}.note-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:10px}.note-list.tight{gap:8px}.check-list{display:flex;flex-direction:column;gap:10px}.check-item{display:flex;align-items:center;gap:10px;justify-content:space-between;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;background:#fafafa}.check-item input{margin-right:10px}.metric-list{display:flex;flex-direction:column;gap:10px}.metric-row{display:flex;justify-content:space-between;gap:12px;border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px;background:#fafafa}.detail-line{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;border:1px solid #e5e7eb;border-radius:12px;padding:12px 14px;background:#fafafa}.detail-label{color:#6b7280;font-size:12px;text-transform:uppercase;letter-spacing:.04em;flex:0 0 140px}.detail-value{text-align:right;font-weight:600;word-break:break-word}.placeholder-chart{border:1px solid #e5e7eb;border-radius:14px;padding:16px;background:#fafafa}.placeholder-chart-title{font-weight:600;margin-bottom:16px}.placeholder-bars{height:160px;display:flex;align-items:flex-end;gap:10px}.placeholder-bars span{flex:1;border-radius:10px 10px 0 0;background:linear-gradient(180deg,#cbd5e1,#64748b)}@media(max-width:1080px){.app-shell{grid-template-columns:220px 1fr}.stats-grid,.three-col,.policy-summary-grid,.mini-grid,.field-grid,.kv-grid,.checkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:820px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}.topbar,.page-header{flex-direction:column;align-items:flex-start}.lookup-row{flex-direction:column;align-items:stretch}.detail-line{flex-direction:column}.detail-value{text-align:left}.stats-grid,.three-col,.two-col,.policy-summary-grid,.mini-grid,.field-grid,.kv-grid,.checkbox-grid{grid-template-columns:1fr}}
