@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-tertiary: #1a2234;--bg-card: #1e293b;--bg-card-hover: #263348;--accent-blue: #3b82f6;--accent-blue-hover: #2563eb;--accent-cyan: #06b6d4;--accent-green: #10b981;--accent-green-glow: rgba(16, 185, 129, .3);--accent-red: #ef4444;--accent-red-glow: rgba(239, 68, 68, .3);--accent-orange: #f59e0b;--accent-purple: #8b5cf6;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--status-pending: #f59e0b;--status-priced: #3b82f6;--status-accepted: #10b981;--status-rejected: #ef4444;--status-matched: #8b5cf6;--side-buy: #10b981;--side-sell: #ef4444;--border-color: #2d3a4f;--border-radius: 12px;--border-radius-sm: 8px;--shadow-glow: 0 4px 24px rgba(59, 130, 246, .15);--shadow-hover: 0 8px 32px rgba(59, 130, 246, .25);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border-bottom:1px solid var(--border-color)}.header-title{display:flex;align-items:center;gap:var(--spacing-md)}.header-title h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.role-toggle{display:flex;background:var(--bg-primary);border-radius:var(--border-radius);padding:4px;gap:4px}.role-btn{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius-sm);background:transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.role-btn.active{background:var(--accent-blue);color:#fff;box-shadow:0 2px 8px #3b82f666}.role-btn:hover:not(.active){background:var(--bg-tertiary);color:var(--text-primary)}.content-wrapper{display:flex;flex-direction:column;flex:1;overflow:hidden}.main-content{display:flex;flex-shrink:0;min-height:0;overflow:hidden}.resize-divider{height:6px;background:var(--bg-tertiary);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);cursor:row-resize;transition:background var(--transition-fast);position:relative}.resize-divider:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:40px;height:3px;background:var(--text-muted);border-radius:2px;opacity:.5}.resize-divider:hover{background:var(--accent-blue)}.resize-divider:hover:after{background:#fff;opacity:1}.resize-divider-horizontal{width:6px;background:var(--bg-tertiary);border-left:1px solid var(--border-color);border-right:1px solid var(--border-color);cursor:col-resize;transition:background var(--transition-fast);position:relative;flex-shrink:0}.resize-divider-horizontal:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:3px;height:40px;background:var(--text-muted);border-radius:2px;opacity:.5}.resize-divider-horizontal:hover{background:var(--accent-blue)}.resize-divider-horizontal:hover:after{background:#fff;opacity:1}.panel-wrapper{display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.panel{flex:1;display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--border-color)}.panel:last-child{border-right:none}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.panel-header h2{font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:var(--spacing-sm)}.panel-header .icon{opacity:.7}.panel-content{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-md);transition:all var(--transition-normal);cursor:pointer}.card:hover{background:var(--bg-card-hover);transform:translateY(-2px);box-shadow:var(--shadow-hover)}.card.highlighted{border-color:var(--accent-cyan);box-shadow:0 0 20px #06b6d44d}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm)}.card-title{font-weight:600;font-size:1rem;color:var(--text-primary)}.card-subtitle{font-size:.85rem;color:var(--text-secondary);margin-top:2px}.card-body{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm);margin-top:var(--spacing-md)}.card-field{display:flex;flex-direction:column;gap:2px}.card-field label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.card-field .value{font-size:.9rem;font-weight:500;color:var(--text-primary)}.card-field .value.mono{font-family:var(--font-mono)}.card-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.status-badge.pending{background:#f59e0b26;color:var(--status-pending)}.status-badge.priced{background:#3b82f626;color:var(--status-priced)}.status-badge.accepted{background:#10b98126;color:var(--status-accepted)}.status-badge.rejected{background:#ef444426;color:var(--status-rejected)}.status-badge.matched{background:#8b5cf626;color:var(--status-matched)}.status-badge.partially_matched{background:#06b6d426;color:var(--accent-cyan)}.side-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase}.side-badge.buy{background:#10b98126;color:var(--side-buy)}.side-badge.sell{background:#ef444426;color:var(--side-sell)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--border-radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-blue-hover);box-shadow:0 4px 12px #3b82f666}.btn-success{background:var(--accent-green);color:#fff}.btn-success:hover:not(:disabled){box-shadow:0 4px 12px var(--accent-green-glow)}.btn-danger{background:var(--accent-red);color:#fff}.btn-danger:hover:not(:disabled){box-shadow:0 4px 12px var(--accent-red-glow)}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-outline:hover:not(:disabled){border-color:var(--accent-blue);color:var(--accent-blue)}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-full{width:100%}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.form-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.form-control{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.9rem;transition:all var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f633}.form-control::placeholder{color:var(--text-muted)}select.form-control{cursor:pointer}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.quote-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.quote-form h3{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.price-input-group{display:flex;gap:var(--spacing-sm);align-items:flex-end}.price-input-group .form-group{flex:1;margin-bottom:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.3}.empty-state h3{font-size:1.1rem;font-weight:500;margin-bottom:var(--spacing-sm)}.empty-state p{font-size:.9rem}.connection-status{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.8rem;color:var(--text-muted)}.connection-status .dot{width:8px;height:8px;border-radius:50%;background:var(--accent-red)}.connection-status.connected .dot{background:var(--accent-green);box-shadow:0 0 8px var(--accent-green-glow)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card{animation:fadeIn .3s ease}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{animation:pulse 1.5s infinite}.user-selector{display:flex;align-items:center;gap:var(--spacing-md)}.user-selector label{font-size:.85rem;color:var(--text-secondary)}.user-selector select{padding:6px 12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.85rem}.table-header{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--border-radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);gap:var(--spacing-sm);position:sticky;top:0;z-index:10}.table-body{display:flex;flex-direction:column;gap:2px}.table-filter-row{display:flex;align-items:center;padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);gap:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.filter-input{width:100%;max-width:90%;padding:2px 4px;font-size:.7rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);cursor:pointer}.filter-input:focus{outline:none;border-color:var(--accent-blue)}.filter-input option{background:var(--bg-secondary);color:var(--text-primary)}.table-row{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border-radius:var(--border-radius-sm);gap:var(--spacing-sm);transition:all var(--transition-fast);cursor:pointer;font-size:.85rem}.table-row:hover{background:var(--bg-card-hover)}.table-row.highlighted{background:#06b6d426;box-shadow:inset 0 0 0 1px var(--accent-cyan)}.table-row.selected{background:#8b5cf633;box-shadow:inset 0 0 0 2px var(--status-matched);cursor:pointer}.table-row.selected:hover{background:#8b5cf64d}.empty-row{padding:var(--spacing-lg);text-align:center;color:var(--text-muted);font-size:.9rem}.col-instrument{flex:1;min-width:80px;font-weight:500}.col-asset{flex:.8;min-width:60px;color:var(--text-secondary)}.col-side{flex:.5;min-width:50px}.col-notional{flex:.8;min-width:70px;text-align:right}.col-price{flex:.6;min-width:60px;text-align:right}.col-status{flex:.7;min-width:70px}.col-actions{flex:1;min-width:100px;display:flex;gap:4px;justify-content:flex-end}.col-booking{flex:.6;min-width:60px;text-align:center}.col-match{flex:.4;min-width:40px;text-align:center}.side-tag{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:700}.side-tag.buy{background:#10b98133;color:var(--side-buy)}.side-tag.sell{background:#ef444433;color:var(--side-sell)}.status-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.status-tag.pending{background:#f59e0b33;color:var(--status-pending)}.status-tag.priced{background:#3b82f633;color:var(--status-priced)}.status-tag.accepted{background:#10b98133;color:var(--status-accepted)}.status-tag.rejected{background:#ef444433;color:var(--status-rejected)}.status-tag.matched{background:#8b5cf633;color:var(--status-matched)}.status-tag.booked{background:#3b82f633;color:var(--status-priced)}.match-indicator{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:.75rem}.match-indicator.matched,.match-indicator.full{background:#8b5cf64d;color:var(--status-matched)}.match-indicator.partial{background:#f59e0b4d;color:var(--status-pending)}.match-indicator.pending{background:var(--bg-tertiary);color:var(--text-muted)}.btn-xs{padding:3px 8px;font-size:.7rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all var(--transition-fast)}.btn-xs.btn-primary{background:var(--accent-blue);color:#fff}.btn-xs.btn-primary:hover{background:var(--accent-blue-hover)}.btn-xs.btn-success{background:var(--accent-green);color:#fff}.btn-xs.btn-danger{background:var(--accent-red);color:#fff}.btn-xs.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-xs:disabled{opacity:.5;cursor:not-allowed}.inline-price{display:flex;gap:4px;align-items:center}.form-control-xs{padding:3px 6px;width:70px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.75rem;font-family:var(--font-mono)}.form-control-xs:focus{outline:none;border-color:var(--accent-blue)}.inline-form{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-sm);flex-wrap:wrap}.form-control-sm{padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.8rem}.form-control-sm:focus{outline:none;border-color:var(--accent-blue)}.mono{font-family:var(--font-mono)}.text-muted{color:var(--text-muted)}.col-client{flex:.8;min-width:70px;font-weight:500;color:var(--accent-cyan)}.col-timer{flex:.5;min-width:45px;text-align:center}.timer{font-family:var(--font-mono);font-size:.75rem;font-weight:600;padding:2px 6px;border-radius:4px;background:#10b98133;color:var(--accent-green)}.timer.urgent{background:#ef444433;color:var(--accent-red);animation:timerPulse .5s ease infinite}.timer.expired{background:#64748b33;color:var(--text-muted)}@keyframes pulsate{0%,to{background:var(--bg-card)}50%{background:#f59e0b26}}@keyframes timerPulse{0%,to{opacity:1}50%{opacity:.6}}.table-row.pulsate{animation:pulsate 2s ease-in-out infinite}.price-loading{animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.price-source{font-size:.9rem;margin-right:4px}.price-source.yahoo{color:var(--accent-green)}.price-source.mock{color:var(--status-pending)}.risk-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.risk-panel .panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.risk-panel .panel-header h2{font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:var(--spacing-sm)}.total-pnl{margin-left:var(--spacing-md);padding:2px 8px;border-radius:var(--border-radius-sm);font-weight:700;font-size:.9rem}.total-pnl.positive{background:#10b98133;color:var(--accent-green)}.total-pnl.negative{background:#ef444433;color:var(--status-rejected)}.loading-indicator{font-size:.75rem;color:var(--text-muted)}.risk-panel .panel-content{flex:1;overflow-y:auto;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.col-position{flex:0 0 160px;display:flex;align-items:center;gap:4px;white-space:nowrap}.col-position.long{color:var(--accent-green)}.col-position.short{color:var(--status-rejected)}.position-label{font-size:.6rem;font-weight:600;opacity:.7}.col-pnl{flex:0 0 160px;font-weight:600;white-space:nowrap}.col-pnl.positive{color:var(--accent-green)}.col-pnl.negative{color:var(--status-rejected)}.table-row.has-preview{background:#3b82f61a;animation:pulse-preview 1.5s infinite}@keyframes pulse-preview{0%,to{background:#3b82f61a}50%{background:#3b82f633}}.table-row.new-position{background:#06b6d426;border:1px dashed var(--accent-cyan)}.preview-delta{margin-left:4px;font-size:.75rem;font-weight:700;padding:1px 4px;border-radius:3px}.preview-delta.positive{background:#10b98133;color:var(--accent-green)}.preview-delta.negative{background:#ef444433;color:var(--status-rejected)}.preview-only{opacity:.8}.app.v2{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary)}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.app-logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo-icon{font-size:1.5rem}.logo-text{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.version-badge{background:var(--accent-purple);color:#fff;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px}.user-controls{display:flex;align-items:center;gap:var(--spacing-md)}.toggle-group{display:flex;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);overflow:hidden}.toggle-btn{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.toggle-btn.active{background:var(--accent-blue);color:#fff}.toggle-btn:hover:not(.active){background:var(--bg-card)}.user-select{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.85rem;min-width:200px}.connection-status{font-size:.9rem}.asset-tabs{display:flex;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);padding:0 var(--spacing-lg)}.asset-tab{padding:12px 24px;border:none;background:transparent;color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;position:relative;display:flex;align-items:center;gap:6px}.asset-tab:hover{color:var(--text-secondary);background:var(--bg-card)}.asset-tab.active{color:var(--text-primary);background:var(--bg-secondary)}.asset-tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--accent-blue)}.live-badge{font-size:.6rem}.live-badge.live{color:var(--accent-green)}.live-badge.manual{color:var(--accent-orange, #f59e0b)}.blotters-container{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border-color);flex:1}.blotter{display:flex;flex-direction:column;background:var(--bg-secondary)}.blotter-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);position:relative}.blotter-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.blotter-count{background:var(--bg-card);color:var(--text-secondary);font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:10px}.blotter-columns{display:flex;gap:8px;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border-bottom:1px solid var(--border-color);font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.blotter-body{flex:1;overflow-y:auto}.blotter-row{display:flex;gap:8px;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid rgba(45,58,79,.5);font-size:.8rem;cursor:pointer;transition:background .15s}.blotter-row>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.blotter-row:hover{background:var(--bg-card-hover)}.blotter-row.pending{animation:pulse-pending 2s infinite}.blotter-row.priced{background:#3b82f61a}.blotter-row.expired{opacity:.5;background:#ef44440d}.blotter-row.matched{background:#8b5cf61a}.blotter-row.partial{background:#f59e0b1a}.blotter-empty{display:flex;align-items:center;justify-content:center;height:100px;color:var(--text-muted);font-size:.85rem}.direction-tag{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;font-size:.65rem;font-weight:700}.direction-tag.buy{background:#10b98133;color:var(--side-buy)}.direction-tag.sell{background:#ef444433;color:var(--side-sell)}.timer-badge{background:var(--status-pending);color:var(--bg-primary);font-size:.6rem;font-weight:700;padding:1px 4px;border-radius:3px;animation:blink-timer 1s infinite}@keyframes blink-timer{0%,to{opacity:1}50%{opacity:.6}}.match-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:.65rem}.match-icon.full{background:#8b5cf64d;color:var(--status-matched)}.match-icon.partial{background:#f59e0b4d;color:var(--status-pending)}.context-menu{position:fixed;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:0 8px 32px #0006;z-index:1000;min-width:150px}.context-menu-item{padding:10px 16px;font-size:.85rem;cursor:pointer;transition:background .15s}.context-menu-item:hover{background:var(--accent-blue);color:#fff}.context-menu-item:first-child{border-radius:var(--border-radius-sm) var(--border-radius-sm) 0 0}.context-menu-item:last-child{border-radius:0 0 var(--border-radius-sm) var(--border-radius-sm)}.app.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted);font-size:1.2rem}@keyframes pulse-pending{0%,to{background:transparent}50%{background:#f59e0b1a}}.action-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent-blue);color:#fff;border:none;border-radius:var(--border-radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{background:var(--accent-blue-hover);box-shadow:var(--shadow-glow)}.blotter-actions{display:flex;align-items:center;gap:var(--spacing-sm);position:relative}.btn-icon{background:transparent;border:none;cursor:pointer;font-size:.9rem;padding:4px;opacity:.7;transition:opacity .2s}.btn-icon:hover{opacity:1}.column-config{position:absolute;top:100%;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:var(--spacing-sm);z-index:100;min-width:150px;box-shadow:0 4px 16px #0000004d}.column-config-title{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:var(--spacing-sm)}.column-config-item{display:flex;align-items:center;gap:6px;padding:4px 0;font-size:.8rem;color:var(--text-secondary);cursor:pointer}.column-config-item:hover{color:var(--text-primary)}.column-config-item input{accent-color:var(--accent-blue)}.col-broker{flex:0 0 50px}.col-counterparty{flex:0 0 70px}.col-rateIndex{flex:0 0 50px}.col-direction{flex:0 0 30px;text-align:center}.col-notional{flex:0 0 60px;text-align:right}.col-price{flex:0 0 60px;text-align:right;display:flex;align-items:center;justify-content:flex-end;gap:4px}.col-trader,.col-sales{flex:0 0 55px}.col-startDate,.col-endDate{flex:0 0 50px}.col-fee{flex:0 0 45px;text-align:right}.col-pnl{flex:0 0 70px;text-align:right}.col-risk{flex:0 0 65px;text-align:right}.col-status{flex:0 0 70px}.status-badge{display:inline-block;padding:2px 6px;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:uppercase}.status-pending{background:#fbbf2433;color:#fbbf24}.status-priced{background:#3b82f633;color:#3b82f6}.status-accepted{background:#22c55e33;color:#22c55e}.status-rejected{background:#ef444433;color:#ef4444}.status-expired{background:#6b728033;color:#6b7280}.status-booked{background:#8b5cf633;color:#8b5cf6}.status-matched{background:#10b98133;color:#10b981}.col-match{flex:0 0 35px;text-align:center}.pnl-value{font-weight:600;font-family:var(--font-mono);font-size:.75rem}.pnl-value.positive{color:var(--accent-green)}.pnl-value.negative{color:var(--accent-red)}.blotter-header{position:relative}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.modal-close{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:var(--text-primary)}.rfq-form{padding:var(--spacing-lg)}.form-row{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.form-group{flex:1;display:flex;flex-direction:column;gap:6px}.form-group.flex-2{flex:2}.form-group label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.form-group input,.form-group select{padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:.9rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-blue)}.form-error{background:#ef44441a;border:1px solid var(--accent-red);color:var(--accent-red);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-md);font-size:.85rem}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.btn-secondary{padding:10px 20px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--bg-card);color:var(--text-primary)}.side-toggle{display:flex!important;flex-direction:row!important}.side-toggle .toggle-btn.active.buy{background:var(--side-buy);color:#fff}.side-toggle .toggle-btn.active.sell{background:var(--side-sell);color:#fff}.pricing-modal{max-width:450px;overflow:hidden}.quote-summary{background:var(--bg-tertiary);padding:var(--spacing-md);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-lg)}.quote-summary-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border-color)}.quote-summary-row:last-child{border-bottom:none}.quote-summary-row .label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.quote-summary-row .value{font-size:.9rem;color:var(--text-primary);font-weight:500}.pricing-form{padding:0 var(--spacing-lg) var(--spacing-lg)}.market-price-ref{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:#3b82f61a;border:1px solid var(--accent-blue);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-md)}.market-price-ref .label{font-size:.75rem;color:var(--accent-blue);text-transform:uppercase}.market-price-ref .value{font-size:1rem;color:var(--accent-blue);font-weight:600}.price-input{font-size:1.25rem!important;font-weight:600;text-align:center}.price-hint{font-size:.7rem;color:var(--text-muted);text-align:center;margin-top:4px}.pricing-metrics{display:flex;gap:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-lg)}.pricing-metrics .metric{flex:1;text-align:center}.pricing-metrics .metric-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}.pricing-metrics .metric-value{display:block;font-size:1rem;font-weight:600;font-family:var(--font-mono)}.pricing-metrics .metric-value.positive{color:var(--positive)}.pricing-metrics .metric-value.negative{color:var(--negative)}
