*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--surface: #1a1d27;--border: #2c2f3e;--text: #e2e8f0;--muted: #8892a4;--accent: #4e9af1;--accent2: #f1a94e;--danger: #e05c5c;--success: #4ecb71;font-size:15px}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;line-height:1.6}.app{width:100%;padding:1.5rem 2rem 3rem}.app-header{text-align:center;margin-bottom:1.75rem}.app-header h1{font-size:2rem;letter-spacing:-.02em;color:var(--accent)}.app-header p{color:var(--muted);margin-top:.4rem}.tab-nav{display:flex;gap:1.5rem;border-bottom:1px solid var(--border);margin-bottom:1.75rem;flex-wrap:wrap}.tab-group{display:flex;align-items:center;gap:.25rem}.tab-group-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:0 .5rem 0 .25rem;border-right:1px solid var(--border);margin-right:.25rem}.tab-btn{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:.9rem;font-weight:500;padding:.55rem .9rem;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px;border-radius:4px 4px 0 0;white-space:nowrap}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:#4e9af112}.tab-content{display:flex;flex-direction:column;gap:1.5rem}footer{text-align:center;margin-top:2rem;color:var(--muted);font-size:.8rem}.panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.75rem}.panel h2{font-size:1.2rem;color:var(--text);margin-bottom:.35rem}.panel-desc{color:var(--muted);font-size:.875rem;margin-bottom:1.25rem}.controls{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.slider-row{display:flex;flex-direction:column;gap:.2rem}.slider-label{display:flex;justify-content:space-between;font-size:.85rem;color:var(--muted)}.slider-label strong{color:var(--text);min-width:4rem;text-align:right}input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer}.toggle-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted);cursor:pointer}.toggle-row input{accent-color:var(--accent);cursor:pointer}.run-btn{align-self:flex-start;background:var(--accent);color:#fff;border:none;border-radius:6px;padding:.5rem 1.4rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.run-btn:hover:not(:disabled){opacity:.85}.run-btn:disabled{opacity:.45;cursor:not-allowed}.chart-wrap{position:relative;min-height:360px;height:400px}.chart-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.9rem;border:1px dashed var(--border);border-radius:8px}.info-msg{font-size:.8rem;color:var(--muted);margin-bottom:.75rem;font-family:monospace}.table-scroll{width:100%;overflow-x:auto;margin-top:1.25rem;border-radius:6px}.summary-table{width:100%;min-width:420px;margin-top:0;border-collapse:collapse;font-size:.85rem}.summary-table th,.summary-table td{padding:.5rem .75rem;border:1px solid var(--border);text-align:right}.summary-table th{background:#22263a;color:var(--muted);font-weight:500}.summary-table th:first-child,.summary-table td:first-child{position:sticky;left:0;z-index:1}.summary-table th:first-child{background:#22263a}.summary-table td:first-child{background:var(--surface);text-align:center;font-weight:600;color:var(--accent)}.field-row{display:flex;flex-direction:column;gap:.2rem;font-size:.85rem;color:var(--muted)}.date-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.text-input,.select-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:5px;padding:.35rem .6rem;font-size:.85rem;width:100%}.select-input{cursor:pointer}.text-input:focus,.select-input:focus{outline:none;border-color:var(--accent)}.json-editor{border:1px solid var(--border);border-radius:6px;padding:.6rem .9rem}.json-editor summary{cursor:pointer;font-size:.85rem;color:var(--muted);-webkit-user-select:none;user-select:none}.json-textarea{width:100%;margin-top:.6rem;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:5px;padding:.5rem;font-family:monospace;font-size:.78rem;resize:vertical}.error-msg{color:var(--danger);font-size:.85rem;margin-bottom:.75rem}.error-inline{color:var(--danger);font-size:.8rem;margin-left:.5rem}.heatmap-wrap{margin-top:1.5rem}.heatmap-wrap h4{font-size:.9rem;color:var(--muted);margin-bottom:.6rem}.heatmap-table{border-collapse:collapse;font-size:.75rem}.heatmap-table th,.heatmap-table td{padding:.3rem .5rem;border:1px solid var(--border);text-align:center;white-space:nowrap}.heatmap-table th{background:#22263a;color:var(--muted)}.heatmap-table th:first-child,.heatmap-table td:first-child{position:sticky;left:0;z-index:1;background:#22263a}.port-summary{margin-top:1.25rem}.port-summary h4{font-size:.9rem;color:var(--muted);margin-bottom:.6rem}.results-wrap{display:flex;flex-direction:column;gap:.25rem}@media(max-width:600px){.date-row{grid-template-columns:1fr}}
