*{box-sizing:border-box}body{background:#f3f7fd;margin:0;font-family:Inter,Segoe UI,sans-serif}#root{min-height:100vh}:root{--sidebar-bg:#0f172a;--sidebar-text:#dbeafe;--sidebar-muted:#93c5fd;--surface:#fff;--surface-subtle:#f8fafc;--border:#dbe3f0;--text:#0f172a;--muted:#475569;--accent:#3b82f6;--danger:#ef4444;--success:#16a34a;--mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Courier New", monospace}.app-shell{grid-template-columns:220px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:var(--sidebar-bg);color:var(--sidebar-text);flex-direction:column;gap:1rem;height:100vh;padding:1.25rem .85rem;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-top h1{letter-spacing:-.02em;margin:0;font-size:1rem;font-weight:700}.sidebar-top p{color:var(--sidebar-muted);margin:.3rem 0 0;font-size:.8rem}.sidebar-nav{flex-direction:column;gap:.2rem;display:flex}.nav-link{color:#cbd5e1;border-radius:6px;padding:.5rem .65rem;font-size:.875rem;text-decoration:none;transition:background .1s,color .1s}.nav-link:hover{color:#fff;background:#ffffff14}.nav-link.active{background:var(--accent);color:#fff;font-weight:500}.sidebar-footer{flex-direction:column;gap:.5rem;margin-top:auto;display:flex}.user-email{color:#94a3b8;overflow-wrap:anywhere;margin:0;font-size:.78rem}.main-content{background:#f1f5f9;flex-direction:column;min-height:100vh;padding:1.25rem;display:flex}.center-screen{min-height:100vh;color:var(--text);place-items:center;display:grid}@media (width<=980px){.app-shell{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #334155;height:auto;position:static}}.tab-page{flex-direction:column;height:100%;display:flex}.tab-header{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.tab-header h2{color:var(--text);flex:auto;margin:0;font-size:1.1rem}.master-detail{flex:1;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:1rem;min-height:0;display:grid}.list-pane{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.list-pane-header{border-bottom:1px solid var(--border);background:var(--surface-subtle);padding:.75rem 1rem}.list-pane-body{flex:1;overflow-y:auto}.detail-pane{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;display:flex;overflow-y:auto}.detail-pane-header{border-bottom:1px solid var(--border);background:var(--surface-subtle);flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.detail-pane-header h3{color:var(--text);margin:0;font-size:.95rem}.detail-pane-body{flex-direction:column;flex:1;gap:.85rem;padding:1rem;display:flex}.detail-pane-actions{border-top:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;gap:.5rem;padding:.75rem 1rem;display:flex}.detail-empty{color:var(--muted);text-align:center;flex:1;justify-content:center;align-items:center;padding:2rem;font-size:.9rem;display:flex}@media (width<=980px){.master-detail{grid-template-columns:1fr}.list-pane,.detail-pane{max-height:50vh}}.table-wrap{width:100%;overflow:auto}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--border);background:var(--surface-subtle);white-space:nowrap;padding:.55rem .75rem;font-size:.78rem;font-weight:600}td{text-align:left;border-bottom:1px solid var(--border);color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:240px;padding:.6rem .75rem;font-size:.875rem;overflow:hidden}tbody tr{cursor:pointer;transition:background .1s}tbody tr:hover{background:var(--surface-subtle)}tbody tr.row-selected{border-left:3px solid var(--accent);background:#eff6ff}tbody tr.row-selected td:first-child{padding-left:calc(.75rem - 3px)}.empty-state{text-align:center;padding:2.5rem 1rem}.empty-state-message{color:var(--text);margin:0 0 .35rem;font-size:.95rem;font-weight:500}.empty-state-description{color:var(--muted);margin:0;font-size:.85rem}label{color:var(--text);flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:500;display:flex}input:not([type=checkbox]),select,textarea{border:1px solid var(--border);color:var(--text);box-sizing:border-box;background:#fff;border-radius:6px;width:100%;padding:.5rem .65rem;font-size:.875rem;transition:border-color .15s,box-shadow .15s}input:not([type=checkbox]):focus,select:focus,textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #3b82f626}input[readonly]{background:var(--surface-subtle);color:var(--muted);cursor:default}textarea{resize:vertical;min-height:100px;font-family:var(--mono);font-size:.82rem}button{cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);white-space:nowrap;border-radius:6px;padding:.5rem .9rem;font-size:.875rem;font-weight:500;transition:background .1s,border-color .1s}button:hover{background:var(--surface-subtle)}button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}button.primary:hover{background:#2563eb;border-color:#2563eb}button.danger{background:var(--danger);border-color:var(--danger);color:#fff}button.danger:hover{background:#dc2626}button.secondary{border-color:var(--border);color:var(--muted);background:0 0}button:disabled{opacity:.5;cursor:not-allowed}.danger-outline{color:#dbeafe;background:0 0;border-color:#334155}.actions{flex-wrap:wrap;gap:.5rem;display:flex}.grid{gap:.75rem;display:grid}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}@media (width<=600px){.grid.two{grid-template-columns:1fr}}.field-group{flex-direction:column;gap:.4rem;display:flex}.field-label{color:var(--text);font-size:.85rem;font-weight:500}.field-label-row{align-items:center;gap:.5rem;display:flex}.tag-pills{flex-wrap:wrap;gap:.35rem;display:flex}.tag-pill{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;padding:.15rem .5rem;font-size:.75rem}.checkbox-row{flex-wrap:wrap;gap:1rem;display:flex}.checkbox-label{cursor:pointer;flex-direction:row;align-items:center;gap:.35rem;font-weight:400;display:flex}.json-field{font-family:var(--mono)}.json-field-invalid{border-color:var(--danger)!important}.json-error-badge{color:var(--danger);background:#fef2f2;border:1px solid #fecaca;border-radius:4px;padding:.1rem .4rem;font-size:.72rem;font-weight:600}.readonly-field{flex-direction:column;gap:.2rem;display:flex}.readonly-label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:.78rem;font-weight:600}.readonly-value{color:var(--text);word-break:break-all;font-size:.875rem}.search-wrap{width:100%}.search-input{box-sizing:border-box;border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:6px;padding:.45rem .7rem;font-size:.875rem}.search-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #3b82f626}.toast-container{z-index:1000;pointer-events:none;flex-direction:column;gap:.5rem;max-width:360px;display:flex;position:fixed;top:1rem;right:1rem}.toast{pointer-events:all;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.7rem .9rem;font-size:.875rem;font-weight:500;animation:.2s toast-in;display:flex;box-shadow:0 4px 12px #00000026}.toast-success{color:#166534;background:#ecfdf5;border:1px solid #bbf7d0}.toast-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.toast-info{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.toast-dismiss{cursor:pointer;color:inherit;opacity:.6;background:0 0;border:none;flex-shrink:0;padding:0;font-size:1.1rem;line-height:1}.toast-dismiss:hover{opacity:1;background:0 0}@keyframes toast-in{0%{opacity:0;transform:translate(1rem)}to{opacity:1;transform:translate(0)}}.dialog-overlay{z-index:500;background:#0f172a73;place-items:center;animation:.15s overlay-in;display:grid;position:fixed;inset:0}.dialog{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:calc(100vw - 2rem);max-width:400px;padding:1.5rem;animation:.15s dialog-in;box-shadow:0 20px 50px #0003}.dialog-title{color:var(--text);margin:0 0 .5rem;font-size:1rem}.dialog-message{color:var(--muted);margin:0 0 1.25rem;font-size:.9rem;line-height:1.5}.dialog-actions{justify-content:flex-end;gap:.5rem;display:flex}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes dialog-in{0%{opacity:0;transform:scale(.95)translateY(-.5rem)}to{opacity:1;transform:scale(1)translateY(0)}}.status-badge{border:1px solid #0000;border-radius:999px;padding:.2rem .55rem;font-size:.73rem;font-weight:600;display:inline-block}.status-open{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.status-in_progress{color:#c2410c;background:#fff7ed;border-color:#fed7aa}.status-done,.status-active,.status-complete{color:#166534;background:#ecfdf5;border-color:#bbf7d0}.status-retracted,.status-revoked,.status-failed,.status-paused{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.status-pending{color:var(--muted);border-color:var(--border);background:#f8fafc}.key-banner{color:#92400e;background:#fffbeb;border:1px solid #facc15;border-radius:8px;padding:.85rem 1rem}.key-banner-title{margin:0 0 .4rem;font-size:.85rem;font-weight:600}.key-banner-code{font-family:var(--mono);word-break:break-all;margin-bottom:.6rem;font-size:.8rem;display:block}.error{color:var(--danger);margin:0;font-size:.85rem}.loading-text{color:var(--muted);font-size:.85rem}
