:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-card: #1e2a45;--bg-hover: #253555;--text-primary: #e0e0e0;--text-secondary: #a0a0b0;--text-formula: #88ccff;--accent: #4ecdc4;--accent-dim: #2a9d8f;--rate-positive: #6ecf6e;--rate-negative: #e06060;--border: #2a3a5a;--btn-bg: #2a9d8f;--btn-hover: #4ecdc4;--btn-disabled: #3a3a4e;--btn-text: #1a1a2e}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Courier New,Courier,monospace;background-color:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.5}#app{max-width:1100px;margin:0 auto;padding:10px}#content-wrapper{display:flex;gap:10px}#main-area{flex:1;min-width:0}#resource-sidebar{width:220px;flex-shrink:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;padding:8px;font-size:12px;align-self:flex-start;position:sticky;top:10px;max-height:calc(100vh - 100px);overflow-y:auto}#sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.sidebar-title{color:var(--accent);font-weight:700;font-size:12px}.btn-sidebar-edit{padding:1px 6px;font-family:inherit;font-size:10px;cursor:pointer;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:3px}.btn-sidebar-edit:hover{color:var(--text-primary);border-color:var(--accent-dim)}.btn-sidebar-edit.active{background:var(--accent-dim);color:var(--btn-text);border-color:var(--accent)}.sidebar-row{display:flex;justify-content:space-between;align-items:center;padding:1px 2px;gap:4px}.sidebar-row .sidebar-formula{color:var(--text-formula);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}.sidebar-row .sidebar-qty{color:var(--text-primary);text-align:right;font-weight:700;flex-shrink:0}.sidebar-row .sidebar-rate{color:var(--text-secondary);font-size:10px;text-align:right;flex-shrink:0}.sidebar-row .sidebar-qty.cap-warning{color:#e6c84c}.sidebar-row .sidebar-qty.cap-critical{color:#e06060}.sidebar-row-edit{display:flex;align-items:center;padding:1px 2px;gap:4px}.sidebar-row-edit label{display:flex;align-items:center;gap:4px;color:var(--text-formula);cursor:pointer;font-size:11px}.sidebar-row-edit input[type=checkbox]{accent-color:var(--accent)}#header{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;padding:10px 0;border-bottom:1px solid var(--border);margin-bottom:10px}#header h1{font-size:20px;color:var(--accent);margin-right:10px}.subtitle{color:var(--text-secondary);font-size:12px;flex:1}#header-controls button{margin-left:5px;padding:3px 10px;font-size:12px;font-family:inherit;cursor:pointer;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:3px}#header-controls button:hover{background:var(--bg-hover)}#tabs{display:flex;gap:2px;margin-bottom:10px}.tab{padding:6px 16px;font-family:inherit;font-size:13px;cursor:pointer;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);border-bottom:none;border-radius:4px 4px 0 0}.tab.active{background:var(--bg-card);color:var(--accent);border-color:var(--accent-dim)}.tab:hover{color:var(--text-primary)}.tab-content{display:none;background:var(--bg-card);border:1px solid var(--border);border-radius:0 4px 4px;padding:12px;min-height:400px}.tab-content.active{display:block}.tab-content h2{font-size:16px;color:var(--accent);margin-bottom:10px;border-bottom:1px solid var(--border);padding-bottom:5px}.resource-controls{display:flex;justify-content:flex-end;margin-bottom:6px}.btn-notation{padding:2px 8px;font-family:inherit;font-size:11px;cursor:pointer;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);border-radius:3px}.btn-notation:hover{color:var(--text-primary);border-color:var(--accent-dim)}.resource-table{width:100%;border-collapse:collapse}.resource-table th{text-align:left;color:var(--text-secondary);font-size:12px;padding:4px 8px;border-bottom:1px solid var(--border)}.resource-table td{padding:4px 8px;border-bottom:1px solid rgba(255,255,255,.03)}.resource-name{color:var(--text-primary)}.formula{color:var(--text-formula);font-size:12px}.resource-quantity{font-weight:700;text-align:right}.resource-rate{text-align:right;font-size:12px}.rate-positive{color:var(--rate-positive)}.rate-negative{color:var(--rate-negative)}.resource-cap{text-align:right;color:var(--text-secondary);font-size:12px}.reaction-card,.catalyst-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;padding:10px;margin-bottom:8px}.reaction-card.disabled,.catalyst-card.disabled{opacity:.6}.reaction-header,.catalyst-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:5px;flex-wrap:wrap}.reaction-desc,.catalyst-desc{color:var(--text-secondary);font-size:12px;margin-bottom:5px}.reaction-cost,.reaction-products,.catalyst-cost{font-size:12px;margin:3px 0}.label{color:var(--text-secondary)}.has{color:var(--rate-positive)}.missing{color:var(--rate-negative)}.reaction-tooltip{font-size:11px;color:var(--text-secondary);font-style:italic;margin-top:5px;padding-top:5px;border-top:1px solid rgba(255,255,255,.05)}.catalyst-tier{font-size:11px;color:var(--accent-dim);background:#4ecdc41a;padding:1px 6px;border-radius:3px}.catalyst-reaction{font-size:12px;margin:3px 0}.btn-show-reaction{padding:0 4px;font-family:inherit;font-size:12px;cursor:pointer;background:transparent;color:var(--accent);border:none;border-bottom:1px dotted var(--accent-dim)}.btn-show-reaction:hover{color:var(--btn-hover);border-bottom-color:var(--btn-hover)}.catalyst-stats{font-size:12px;display:flex;gap:15px;margin:5px 0;color:var(--text-secondary)}.btn-react,.btn-craft{padding:4px 12px;font-family:inherit;font-size:12px;cursor:pointer;background:var(--btn-bg);color:var(--btn-text);border:none;border-radius:3px;font-weight:700}.btn-react:hover,.btn-craft:hover{background:var(--btn-hover)}.btn-react:disabled,.btn-craft:disabled{background:var(--btn-disabled);color:var(--text-secondary);cursor:not-allowed}.log-entry{font-size:12px;color:var(--text-secondary);padding:2px 0;border-bottom:1px solid rgba(255,255,255,.03)}.log-entry:first-child{color:var(--accent)}#footer{display:flex;justify-content:space-between;padding:8px 0;margin-top:10px;font-size:12px;color:var(--text-secondary);border-top:1px solid var(--border)}.milestone-section h3{margin:12px 0 6px;color:var(--text-secondary);font-size:13px;text-transform:uppercase;letter-spacing:.05em}.milestone-card{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;padding:8px 12px;margin-bottom:6px}.milestone-card.achieved{border-left:3px solid var(--accent)}.milestone-card.locked{opacity:.4;border-left:3px solid var(--border)}.milestone-header{display:flex;justify-content:space-between;align-items:center}.milestone-tick{font-size:11px;color:var(--text-secondary)}.milestone-desc{font-size:12px;color:var(--text-secondary);margin-top:2px}.milestone-card.achieved .milestone-desc{color:var(--text-primary)}.tag-filters{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.tag-filters:empty{display:none}.tag-filter-label{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--text-secondary);cursor:pointer;padding:1px 6px;border:1px solid var(--border);border-radius:3px;background:var(--bg-secondary);-webkit-user-select:none;user-select:none}.tag-filter-label:hover{border-color:var(--accent-dim);color:var(--text-primary)}.tag-filter-label input[type=checkbox]{accent-color:var(--accent)}.reaction-rate{font-size:12px;margin:4px 0}.rate-value{font-weight:700;color:var(--rate-positive)}.rate-limiter{font-size:11px;font-style:italic;color:var(--text-secondary)}.rate-limiter-substrate{color:var(--rate-negative)}.rate-limiter-catalyst{color:var(--accent)}.time-estimate{font-size:11px;color:var(--text-secondary);font-style:italic;display:none}.reaction-card.disabled:hover .time-estimate,.catalyst-card.disabled:hover .time-estimate{display:block}.btn-res-nav{display:inline-block;padding:0 3px;margin-left:2px;font-family:inherit;font-size:10px;line-height:1.4;cursor:pointer;background:transparent;color:var(--text-secondary);border:1px solid transparent;border-radius:2px;vertical-align:baseline;opacity:.5;transition:opacity .1s,color .1s,border-color .1s}.btn-res-nav:hover{opacity:1;color:var(--accent);border-color:var(--accent-dim)}.resource-nav{white-space:nowrap}.resource-nav .btn-res-nav{font-size:11px;padding:1px 4px;opacity:.6}.reaction-filter-banner{display:flex;align-items:center;gap:10px;padding:6px 10px;margin-bottom:8px;background:var(--bg-secondary);border:1px solid var(--accent-dim);border-radius:4px;font-size:12px;color:var(--text-secondary)}.reaction-filter-banner strong{color:var(--accent)}.btn-show-all-reactions{margin-left:auto;padding:2px 8px;font-family:inherit;font-size:11px;cursor:pointer;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:3px}.btn-show-all-reactions:hover{color:var(--accent);border-color:var(--accent-dim)}.reaction-footer{margin-top:6px;padding-top:5px;border-top:1px solid rgba(255,255,255,.05)}.btn-show-catalysts{padding:2px 8px;font-family:inherit;font-size:11px;cursor:pointer;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:3px}.btn-show-catalysts:hover{color:var(--accent);border-color:var(--accent-dim)}.catalyst-filter-banner{display:flex;align-items:center;gap:10px;padding:6px 10px;margin-bottom:8px;background:var(--bg-secondary);border:1px solid var(--accent-dim);border-radius:4px;font-size:12px;color:var(--text-secondary)}.catalyst-filter-banner strong{color:var(--accent)}.btn-show-all-catalysts{margin-left:auto;padding:2px 8px;font-family:inherit;font-size:11px;cursor:pointer;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);border-radius:3px}.btn-show-all-catalysts:hover{color:var(--accent);border-color:var(--accent-dim)}.new-item{outline:1px solid #e6c84c;outline-offset:-1px}.sidebar-row.new-item{outline:none;border-left:2px solid #e6c84c;padding-left:0}tr.new-item>td{border-bottom-color:#e6c84c33}.empty-message{color:var(--text-secondary);font-style:italic;padding:20px;text-align:center}
