:root{--bg-base: #080d18;--bg-surface: #0e1628;--bg-raised: #141e34;--bg-elevated: #1a2640;--bg-overlay: #1f2e4a;--border: #2a3a58;--border-bright: #3a5080;--gold: #c9a84c;--gold-bright: #e0c068;--gold-dim: #7a6330;--gold-bg: rgba(201, 168, 76, .08);--gold-bg-hover: rgba(201, 168, 76, .14);--text-primary: #e8e4d9;--text-secondary: #a0aec0;--text-muted: #5a6a80;--text-gold: #c9a84c;--red: #e05252;--red-bg: rgba(224, 82, 82, .1);--orange: #e8922a;--orange-bg: rgba(232, 146, 42, .1);--yellow: #d4b84a;--yellow-bg: rgba(212, 184, 74, .1);--green: #3dba7e;--green-bg: rgba(61, 186, 126, .1);--blue: #4a9ede;--blue-bg: rgba(74, 158, 222, .1);--font-display: "Playfair Display", Georgia, serif;--font-body: "IBM Plex Sans", system-ui, sans-serif;--font-mono: "IBM Plex Mono", "Courier New", monospace;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);font-size:14px;color:var(--text-primary);background:var(--bg-base);line-height:1.6;-webkit-font-smoothing:antialiased}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;min-width:240px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid var(--border)}.sidebar-logo-mark{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--gold);letter-spacing:.02em}.sidebar-logo-sub{font-size:10px;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}.sidebar-case-ctx{padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg-raised)}.sidebar-case-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}.sidebar-case-name{font-size:13px;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.sidebar-nav-section{padding:8px 20px 4px;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;font-size:13px;color:var(--text-secondary);text-decoration:none;border-left:2px solid transparent;transition:all var(--transition);cursor:pointer}.sidebar-nav-item:hover{background:var(--bg-raised);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--gold-bg);color:var(--gold);border-left-color:var(--gold)}.sidebar-nav-item .nav-icon{width:16px;text-align:center;flex-shrink:0;font-size:14px}.sidebar-alert-badge{margin-left:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;border-radius:10px;padding:1px 6px;font-family:var(--font-mono)}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border)}.sidebar-user{font-size:12px;color:var(--text-secondary);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user strong{color:var(--text-primary);display:block;font-size:13px}.sidebar-user-role{font-size:10px;color:var(--gold-dim);text-transform:uppercase;letter-spacing:.1em}.main-content{flex:1;overflow-y:auto;background:var(--bg-base)}.page-container{max-width:1100px;margin:0 auto;padding:32px 32px 64px}.page-header{margin-bottom:28px}.page-title{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--text-primary);line-height:1.2}.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:6px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px}.card-sm{padding:14px 18px}.card-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all var(--transition);text-decoration:none;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gold);color:#080d18;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--gold-bright)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg-raised);color:var(--text-primary);border-color:var(--border-bright)}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid rgba(224,82,82,.3)}.btn-danger:hover:not(:disabled){background:#e0525233}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:12px 24px;font-size:14px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:14px;padding:9px 12px;transition:border-color var(--transition);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold-dim)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-select option{background:var(--bg-raised)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.04em;font-family:var(--font-mono)}.badge-confirmed{background:var(--green-bg);color:var(--green)}.badge-inferred{background:var(--blue-bg);color:var(--blue)}.badge-disputed{background:var(--orange-bg);color:var(--orange)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-orange{background:var(--orange-bg);color:var(--orange)}.badge-yellow{background:var(--yellow-bg);color:var(--yellow)}.badge-green,.badge-complete{background:var(--green-bg);color:var(--green)}.badge-in-progress{background:var(--blue-bg);color:var(--blue)}.badge-pending{background:var(--bg-elevated);color:var(--text-muted)}.badge-tier2{background:var(--gold-bg);color:var(--gold)}.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:6px}.alert-banner{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-radius:var(--radius-md);border:1px solid;margin-bottom:12px;font-size:13px}.alert-banner-red{background:var(--red-bg);border-color:#e052524d;color:var(--red)}.alert-banner-orange{background:var(--orange-bg);border-color:#e8922a4d;color:var(--orange)}.alert-banner-yellow{background:var(--yellow-bg);border-color:#d4b84a4d;color:var(--yellow)}.alert-banner-green{background:var(--green-bg);border-color:#3dba7e4d;color:var(--green)}.alert-banner-icon{font-size:15px;flex-shrink:0;margin-top:1px}.alert-banner-msg{flex:1}.alert-banner-cat{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.table-wrap{overflow-x:auto}table.es-table{width:100%;border-collapse:collapse;font-size:13px}table.es-table th{text-align:left;padding:10px 14px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-raised)}table.es-table td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:top}table.es-table tr:last-child td{border-bottom:none}table.es-table tr:hover td{background:var(--bg-raised)}.progress-track{background:var(--bg-elevated);border-radius:100px;height:6px;overflow:hidden}.progress-fill{height:100%;background:var(--gold);border-radius:100px;transition:width .5s ease}.progress-fill-green{background:var(--green)}.modal-overlay{position:fixed;inset:0;background:#080d18cc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--bg-surface);border:1px solid var(--border-bright);border-radius:var(--radius-xl);padding:28px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto}.modal-title{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.drawer-overlay{position:fixed;inset:0;background:#080d1899;z-index:900}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;background:var(--bg-surface);border-left:1px solid var(--border-bright);z-index:901;display:flex;flex-direction:column;overflow:hidden}.drawer-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.drawer-title{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-primary)}.drawer-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.drawer-body{flex:1;overflow-y:auto;padding:20px 24px}.drawer-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-state{display:flex;align-items:center;gap:12px;color:var(--text-muted);padding:40px 0;justify-content:center;font-size:13px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:32px;margin-bottom:12px;opacity:.4}.empty-state-msg{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.empty-state-hint{font-size:12px;color:var(--text-muted)}.error-msg{background:var(--red-bg);border:1px solid rgba(224,82,82,.3);color:var(--red);padding:10px 14px;border-radius:var(--radius-md);font-size:13px;margin-top:8px}.stats-row{display:grid;gap:12px;margin-bottom:24px}.stats-row-4{grid-template-columns:repeat(4,1fr)}.stats-row-3{grid-template-columns:repeat(3,1fr)}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px}.stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px}.stat-value{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--text-primary);line-height:1}.stat-sub{font-size:11px;color:var(--text-muted);margin-top:4px}.stat-value.gold{color:var(--gold)}.stat-value.green{color:var(--green)}.stat-value.red{color:var(--red)}.auth-page{min-height:100vh;background:var(--bg-base);display:flex;align-items:center;justify-content:center;padding:24px;background-image:radial-gradient(ellipse at 20% 50%,rgba(201,168,76,.04) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(74,158,222,.04) 0%,transparent 60%)}.auth-box{width:100%;max-width:440px}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo-text{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--gold);letter-spacing:.02em}.auth-logo-sub{font-size:11px;color:var(--text-muted);letter-spacing:.14em;text-transform:uppercase;margin-top:4px}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px}.auth-tabs{display:flex;gap:0;margin-bottom:24px;background:var(--bg-base);border-radius:var(--radius-md);padding:3px}.auth-tab{flex:1;padding:8px;text-align:center;font-size:13px;font-weight:500;cursor:pointer;border-radius:6px;border:none;background:transparent;color:var(--text-muted);transition:all var(--transition)}.auth-tab.active{background:var(--bg-elevated);color:var(--text-primary)}.auth-disclaimer{margin-top:24px;padding:14px 16px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);font-size:11px;color:var(--text-muted);line-height:1.7}.auth-disclaimer strong{color:var(--gold);display:block;margin-bottom:4px;font-size:10px;text-transform:uppercase;letter-spacing:.1em}.case-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.case-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all var(--transition);text-decoration:none;display:block}.case-card:hover{border-color:var(--gold-dim);background:var(--bg-raised);transform:translateY(-1px)}.case-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.case-card-name{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text-primary);line-height:1.3}.case-card-charges{font-size:12px;color:var(--text-secondary);margin-top:4px;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.case-card-meta{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.case-card-progress{margin-top:12px}.case-card-progress-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted);margin-bottom:5px}.phase-section{margin-bottom:28px}.phase-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}.phase-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--gold);font-family:var(--font-mono)}.phase-name{font-size:12px;color:var(--text-muted)}.component-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition);margin-bottom:4px}.component-row:hover{background:var(--bg-raised);border-color:var(--border)}.component-code{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--gold);width:60px;flex-shrink:0}.component-name{flex:1;font-size:13px;color:var(--text-primary)}.component-phase-tag{font-size:10px;color:var(--text-muted);font-family:var(--font-mono)}.ai-output{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;font-size:13px;line-height:1.7;color:var(--text-primary);white-space:pre-wrap;font-family:var(--font-mono);max-height:400px;overflow-y:auto}.ai-generating{display:flex;align-items:center;gap:10px;color:var(--gold);font-size:13px;padding:20px 0}.audit-entry{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px}.audit-time{color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap;flex-shrink:0;font-size:11px}.audit-action{color:var(--text-primary);flex:1}.audit-hash{color:var(--text-muted);font-family:var(--font-mono);font-size:10px;white-space:nowrap;flex-shrink:0}.divider{height:1px;background:var(--border);margin:20px 0}.text-gold{color:var(--gold)}.text-muted{color:var(--text-muted)}.text-mono{font-family:var(--font-mono)}.text-sm{font-size:12px}.text-xs{font-size:11px}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.roid-callout{background:#e052520f;border:1px solid rgba(224,82,82,.25);border-left:3px solid var(--red);padding:10px 14px;border-radius:var(--radius-md);font-size:12px;color:var(--text-secondary);margin-bottom:16px}.roid-callout strong{color:var(--red);font-size:10px;text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:3px}[data-theme=light]{--es-bg: #f4f1eb;--es-surface: #ffffff;--es-text-primary: #0e1628;--es-text-secondary: #3a4a60;--es-text-muted: #6a7a90;--es-gold: #b8922a;--es-border: #dcd6cc;--es-card-border: #e0dbd0;--es-sidebar-bg: #e8e3d8;--es-sidebar-border: #d0c8b0;--es-input-bg: #ffffff;--es-input-border: #c8c0b0;--es-green: #1e8a5a;--es-red: #c0392b}[data-theme=light] body{background-color:#f4f1eb;color:#0e1628}[data-theme=light] .sidebar{background:#e8e3d8;border-right-color:#d0c8b0}
