:root{--bg: #080b10;--surface: #0d1117;--surface2: #111820;--border: rgba(255, 255, 255, .06);--border-active: rgba(212, 175, 55, .35);--gold: #d4af37;--gold-glow: rgba(212, 175, 55, .08);--text: #e8e6e1;--text-muted: rgba(232, 230, 225, .5);--text-dim: rgba(232, 230, 225, .25);--green: #26a69a;--red: #ef5350;--blue: #4fc3f7;--purple: #a78bfa;--orange: #fb923c;--mono: "IBM Plex Mono", monospace;--serif: "DM Serif Display", serif;--thai: "Noto Sans Thai", sans-serif}.font-mono{font-family:var(--mono)}.font-thai{font-family:var(--thai)}.font-display{font-family:var(--serif)}*{margin:0;padding:0;box-sizing:border-box}html,body{background:var(--bg);color:var(--text);font-family:var(--thai);min-height:100vh}#root{min-height:100vh;display:flex}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.app-layout{display:flex;flex:1;min-height:100vh;width:100%}.sidebar{width:220px;min-width:220px;background:var(--surface);border-right:1px solid var(--border);padding:24px 0 0;flex-shrink:0;position:sticky;top:0;height:100vh;overflow:hidden;transition:width .22s cubic-bezier(.4,0,.2,1),min-width .22s cubic-bezier(.4,0,.2,1);will-change:width;display:flex;flex-direction:column}.sidebar.collapsed .nav-section{padding:0 6px;margin-bottom:16px}.sidebar.collapsed .nav-item{justify-content:center;padding:10px 0;gap:0}.sidebar.collapsed .nav-item.active{padding-left:0;border-left-width:2px}.sidebar.collapsed .nav-icon{font-size:18px}.brand-collapsed{padding:0 0 16px!important;justify-content:center!important}.sidebar-toggle{padding:4px 8px;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-dim);font-size:15px;cursor:pointer;transition:color .15s,border-color .15s;flex-shrink:0;line-height:1}.sidebar-toggle:hover{color:var(--gold);border-color:#d4af3766}.brand{display:flex;align-items:center;justify-content:space-between;padding:0 12px 20px;border-bottom:1px solid var(--border);margin-bottom:20px;gap:8px}.brand-name{font-family:var(--serif);font-size:20px;line-height:1.1}.brand-name span{color:var(--gold)}.brand-sub{font-size:10px;letter-spacing:.2em;color:var(--gold);margin-top:4px}.nav-section{padding:0 14px;margin-bottom:20px}.nav-label{font-size:10px;letter-spacing:.25em;color:var(--text-dim);text-transform:uppercase;padding:0 10px;margin-bottom:8px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;font-size:14px;color:var(--text-muted);cursor:pointer;border-radius:4px;transition:background-color .15s,color .15s;font-family:var(--thai);border:none;background:transparent;width:100%;text-align:left}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--gold-glow);color:var(--gold);border-left:2px solid var(--gold);padding-left:10px}.nav-icon{font-size:15px}.nav-badge{margin-left:auto;background:#d4af3733;color:var(--gold);font-size:10px;padding:2px 7px;border-radius:10px;letter-spacing:.1em}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}.sidebar-user{border-top:1px solid var(--border);padding:10px 14px 14px;display:flex;flex-direction:column;gap:8px;flex-shrink:0}.sidebar.collapsed .sidebar-user{padding:10px 6px 12px;align-items:center}.sidebar-user-info{font-family:var(--mono);font-size:11px;line-height:1.3;overflow:hidden}.sidebar-user-email{color:var(--text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-role{color:var(--gold);font-size:9px;letter-spacing:.2em;text-transform:uppercase;margin-top:2px}.sidebar-logout{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:6px 10px;font-size:11px;font-family:var(--mono);cursor:pointer;transition:all .15s;border-radius:3px}.sidebar-logout:hover{color:var(--red);border-color:var(--red)}.sidebar.collapsed .sidebar-logout{padding:6px 8px;font-size:14px}.login-shell{flex:1;min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top,rgba(212,175,55,.08),transparent 60%),var(--bg);padding:20px}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--gold);padding:36px 30px;display:flex;flex-direction:column;gap:16px}.login-brand{text-align:center;margin-bottom:12px;border-bottom:1px solid var(--border);padding-bottom:18px}.login-brand .brand-name{font-size:26px}.login-brand .brand-sub{margin-top:6px}.login-error{background:#ef53501a;border-left:2px solid var(--red);color:var(--red);padding:8px 12px;font-size:12px;font-family:var(--thai)}.login-hint{font-size:11px;color:var(--text-dim);text-align:center;margin-top:4px;font-family:var(--thai)}.login-loading{color:var(--text-muted);font-family:var(--mono);font-size:13px;letter-spacing:.05em}.splash-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:center;background:var(--bg);pointer-events:none;font-family:Georgia,Times New Roman,serif}.splash-card{width:280px;text-align:center}.splash-brand-name{font-size:30px;letter-spacing:.01em;line-height:1.15;color:var(--text);white-space:nowrap}.splash-brand-name span{color:var(--gold)}.splash-brand-sub{font-size:9.5px;letter-spacing:.32em;color:var(--gold);text-transform:uppercase;margin-top:10px;font-family:ui-monospace,SF Mono,Menlo,Consolas,Courier New,monospace;opacity:.75}.splash-bar{width:220px;height:2px;background:var(--surface2);border-radius:2px;position:relative;overflow:hidden;margin:24px auto 0}.splash-bar-fill{position:absolute;top:0;left:0;height:100%;width:40%;background:linear-gradient(90deg,transparent 0%,var(--gold) 50%,transparent 100%);animation:splashBarSlide 1.2s ease-in-out infinite;will-change:transform}@keyframes splashBarSlide{0%{transform:translate(-100%)}to{transform:translate(550%)}}.splash-msg{font-family:ui-monospace,SF Mono,Menlo,Consolas,Courier New,monospace;font-size:10px;letter-spacing:.18em;color:var(--text-dim);text-transform:uppercase;margin-top:16px}.login-success{background:#26a69a1a;border-left:2px solid var(--green);color:var(--green);padding:10px 14px;font-size:12px;font-family:var(--thai);line-height:1.5}.login-links{display:flex;justify-content:space-between;gap:12px;margin-top:10px;font-size:11px;font-family:var(--thai)}.login-links a{color:var(--text-dim);text-decoration:none;transition:color .15s}.login-links a:hover{color:var(--gold)}.sidebar-user-actions{display:flex;flex-direction:column;gap:6px}.sidebar.collapsed .sidebar-user-actions{align-items:center}.sidebar-account{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:6px 10px;font-size:11px;font-family:var(--mono);cursor:pointer;transition:all .15s;border-radius:3px;text-decoration:none;text-align:center;display:block}.sidebar-account:hover,.sidebar-account.active{color:var(--gold);border-color:#d4af3766}.sidebar.collapsed .sidebar-account{padding:6px 8px;font-size:14px}.account-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}.account-grid>div{min-width:0}.account-label{font-size:10px;letter-spacing:.18em;color:var(--text-dim);text-transform:uppercase;margin-bottom:4px}.account-value{font-size:14px;color:var(--text)}.account-value.mono{font-family:var(--mono)}.perf-filter-panel{padding:8px 12px;margin-bottom:10px}.perf-filter-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;row-gap:6px}.perf-filter-row+.perf-filter-row{margin-top:6px;padding-top:6px;border-top:1px dashed var(--border)}.perf-filter-row-period{gap:6px}.perf-field{display:flex;align-items:center;gap:5px;height:30px}.perf-field-label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;flex-shrink:0;white-space:nowrap;line-height:1}.perf-field-control{display:flex;align-items:center;height:30px}.perf-filter-actions{display:flex;gap:5px;align-items:center;margin-left:4px;height:30px}.perf-filter-meta{margin-left:auto;font-size:11px;color:var(--text-muted);font-family:var(--mono);white-space:nowrap}.perf-filter-row .form-input,.perf-filter-row .form-select,.perf-filter-row .combobox-input,.perf-filter-row .chip-group,.perf-filter-row .btn-tiny{height:30px!important;font-size:12px!important;padding-top:0!important;padding-bottom:0!important;line-height:28px!important}.perf-filter-row .form-input,.perf-filter-row .form-select{padding-left:10px;padding-right:10px}.perf-filter-row .combobox-input{padding-left:10px!important;padding-right:24px!important}.perf-filter-row .btn-tiny{line-height:1!important;padding:0 10px!important}.perf-filter-row .chip-group{padding:2px!important;line-height:1!important}.perf-filter-row .chip{height:24px!important;padding:0 8px!important;line-height:24px!important;font-size:11px!important}.confirm-dialog{background:var(--surface);border:1px solid var(--border-active);width:100%;max-width:420px;margin-top:18vh;position:relative;padding:24px 26px 20px;display:flex;flex-direction:column;gap:14px;animation:confirmIn .18s ease-out}.confirm-dialog:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold)}.confirm-danger:before{background:var(--red)}.confirm-title{font-family:var(--serif);font-size:20px;color:var(--text);letter-spacing:-.01em}.confirm-danger .confirm-title{color:var(--red)}.confirm-message{font-size:13px;color:var(--text-muted);line-height:1.55;font-family:var(--thai)}.confirm-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.confirm-actions .btn{min-width:92px}@keyframes confirmIn{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.main{flex:1;padding:28px 36px 60px;overflow-x:hidden;contain:layout paint;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--border);gap:16px}.page-title{font-family:var(--serif);font-size:28px}.page-title span{color:var(--gold);font-style:italic}.page-sub{font-family:var(--thai);font-size:13px;color:var(--text-muted);margin-top:4px;font-weight:300}.topbar-right{display:flex;gap:12px;align-items:center}.btn{font-family:var(--thai);font-size:13px;padding:9px 16px;background:transparent;color:var(--text);border:1px solid var(--border);cursor:pointer;transition:all .2s;box-sizing:border-box;min-height:36px;display:inline-flex;align-items:center;justify-content:center;line-height:1.15}.btn:hover{border-color:var(--gold);color:var(--gold)}.btn.primary{background:var(--gold);color:var(--bg);border-color:var(--gold);font-weight:500}.btn.primary:hover{background:transparent;color:var(--gold)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.danger{color:var(--red);border-color:#ef535059}.btn.danger:hover{background:#ef53501a;border-color:var(--red);color:var(--red)}.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--border);margin-bottom:24px}.kpi{background:var(--surface);padding:16px 18px;position:relative;overflow:hidden;transition:background .3s}.kpi:hover{background:var(--surface2)}.kpi:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s}.kpi:hover:before{transform:scaleX(1)}.kpi-label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--text-dim);text-transform:uppercase;margin-bottom:8px}.kpi-value{font-family:var(--mono);font-size:24px;font-weight:500;line-height:1}.kpi-value.green{color:var(--green)}.kpi-value.red{color:var(--red)}.kpi-value.gold{color:var(--gold)}.kpi-sub{font-family:var(--thai);font-size:12px;color:var(--text-muted);margin-top:5px;font-weight:300}.panel{background:var(--surface);border:1px solid var(--border);margin-bottom:18px}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border)}.panel-title{font-family:var(--thai);font-size:14px;font-weight:600;color:var(--gold);letter-spacing:.05em}.panel-body{padding:20px}.panel-empty{padding:40px 20px;text-align:center;font-family:var(--thai);font-size:14px;color:var(--text-muted);font-weight:300}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;font-family:var(--mono);font-size:10px;letter-spacing:.15em;color:var(--text-dim);padding:10px 12px;border-bottom:1px solid var(--border);text-transform:uppercase;font-weight:400;background:var(--surface2);position:sticky;top:0;z-index:3}td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.025);font-family:var(--thai);font-weight:300}tr:hover td{background:#ffffff05}tr.clickable{cursor:pointer}.pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;font-family:var(--mono)}.pill.long,.pill.win,.pill.active{background:#26a69a26;color:var(--green)}.pill.short,.pill.loss,.pill.closed{background:#ef535026;color:var(--red)}.pill.open,.pill.paused{background:#4fc3f726;color:var(--blue)}.pill.be{background:#e8e6e114;color:var(--text-muted)}.pill.quant{background:#d4af371f;color:var(--gold)}.pill.grid{background:#a78bfa26;color:var(--purple)}.pill.manual{background:#fb923c26;color:var(--orange)}.pill.archived{background:#e8e6e114;color:var(--text-dim)}.pnl-pos{color:var(--green);font-weight:500}.pnl-neg{color:var(--red);font-weight:500}.chart-container{position:relative;height:240px}.chart-skeleton{display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,transparent 0%,rgba(212,175,55,.02) 50%,transparent 100%);border:1px dashed rgba(255,255,255,.04);border-radius:2px}.chart-skeleton-msg{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.05em}.form-section{margin-bottom:20px}.form-section:last-child{margin-bottom:0}.form-section-title{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid var(--border);padding-bottom:6px;margin-bottom:14px;font-family:var(--mono)}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}.form-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field.full{grid-column:1 / -1}.form-label{font-family:var(--mono);font-size:10px;letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase}.form-input,.form-select,.form-textarea{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:9px 12px;font-family:var(--thai);font-size:13px;outline:none;transition:border-color .2s;width:100%}.form-textarea{font-weight:300;resize:vertical;min-height:72px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold)}.form-select{cursor:pointer}.ir-mode-toggle{display:inline-flex;background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:2px;gap:2px}.ir-mode-btn{background:transparent;border:none;color:var(--text-muted);font-family:var(--mono);font-size:12px;padding:5px 14px;border-radius:3px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.ir-mode-btn:hover{color:var(--text)}.ir-mode-btn.active{background:var(--gold);color:#000;font-weight:500;box-shadow:0 0 6px #d4af374d}.ir-period-select{background:var(--surface2);border:1px solid var(--gold);color:var(--text);font-family:var(--mono);font-size:13px;font-weight:500;height:32px;padding:0 10px;border-radius:4px;min-width:140px;cursor:pointer}.ir-period-select:focus{outline:none;box-shadow:0 0 0 2px #d4af374d}.ir-period-select option{background:var(--surface);color:var(--text)}.form-error{font-family:var(--thai);font-size:12px;color:var(--red);font-weight:300}.combobox{position:relative;width:100%}.combobox-input{padding-right:28px!important}.combobox-caret{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-dim);font-size:10px;cursor:pointer;-webkit-user-select:none;user-select:none;pointer-events:auto;transition:color .15s}.combobox:hover .combobox-caret{color:var(--text-muted)}.combobox-list{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:220px;overflow-y:auto;background:var(--surface);border:1px solid var(--border-active);box-shadow:0 8px 24px #00000080;z-index:200;padding:4px 0}.combobox-item{padding:8px 12px;font-family:var(--thai);font-size:13px;color:var(--text);cursor:pointer;transition:background .1s}.combobox-item.active,.combobox-item:hover{background:var(--surface2)}.combobox-item.active{color:var(--gold)}.combobox-item.selected:before{content:"✓";color:var(--gold);margin-right:6px;font-size:12px}.datetime-wrap{position:relative;display:flex;align-items:stretch}.datetime-text{flex:1;border-top-right-radius:0;border-bottom-right-radius:0}.datetime-pick-btn{background:var(--surface2);border:1px solid var(--border);border-left:none;color:var(--text-muted);padding:0 10px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}.datetime-pick-btn:hover{color:var(--gold);border-color:var(--border-active)}.datetime-hidden{position:absolute;right:0;top:0;width:36px;height:100%;opacity:0;pointer-events:none;border:none;background:transparent}.combobox-add{border-top:1px solid var(--border);color:var(--gold);font-family:var(--thai);font-weight:300;font-size:13px}.combobox-add.active{background:#d4af3714}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:60px 20px;overflow-y:auto;animation:fadeIn .2s}.modal{background:var(--surface);border:1px solid var(--border-active);width:100%;max-width:760px;position:relative}.modal:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold)}.modal-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-title{font-family:var(--serif);font-size:22px}.modal-close{background:none;border:none;color:var(--text-dim);font-size:24px;cursor:pointer;line-height:1;padding:0}.modal-close:hover{color:var(--gold)}.modal-body{padding:22px 24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.strat-section{margin-bottom:18px;border:1px solid var(--border);background:var(--surface)}.strat-section.status-active{border-left:3px solid var(--green)}.strat-section.status-paused{border-left:3px solid var(--blue)}.strat-section.status-archived{border-left:3px solid var(--text-dim);opacity:.78}.strat-section-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;gap:16px;flex-wrap:wrap}.strat-section-head:hover{background:var(--surface2)}.strat-section-title{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:17px;color:var(--text)}.strat-caret{display:inline-block;color:var(--text-muted);font-size:13px;width:10px;transition:transform .2s ease}.strat-caret.open{transform:rotate(90deg)}.strat-section-count{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:20px;padding:0 8px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;font-family:var(--mono);font-size:12px;color:var(--text-muted)}.strat-section-meta{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;color:var(--text-muted);flex-wrap:wrap}.strat-section-pnl{padding-left:8px;border-left:1px solid var(--border);font-weight:500}.strat-section-floating{padding-left:8px;border-left:1px solid var(--border);font-size:11px;font-weight:400}.strat-section-hint{padding-left:8px;border-left:1px solid var(--border);color:var(--text-dim);font-style:italic;font-family:var(--thai);font-size:11px}.strat-section-body{border-top:1px solid var(--border);overflow-x:auto}.strat-table{width:100%;border-collapse:collapse;font-size:13px}.strat-table thead th{text-align:left;padding:10px 12px;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim);font-weight:500;border-bottom:1px solid var(--border);background:var(--surface2)}.strat-table tbody td{padding:12px;border-bottom:1px solid var(--border);vertical-align:middle}.strat-table tbody td.mono{font-family:var(--mono)}.strat-table tbody tr:last-child td{border-bottom:none}.strat-table tbody tr.clickable:hover{background:var(--surface2)}.strat-type-group+.strat-type-group tr.strat-type-divider td{padding-top:18px}.strat-type-divider td{background:#0d111799;padding:8px 12px!important;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-size:11px;-webkit-user-select:none;user-select:none}.strat-type-divider.clickable:hover td{background:var(--surface2)}.strat-type-divider .strat-caret{margin-right:8px}.strat-type-divider .pill{margin-right:10px}.strat-type-label{color:var(--text-muted);letter-spacing:.05em;font-family:var(--thai)}.strat-type-count{color:var(--text-dim);font-family:var(--mono);margin-left:6px}.strat-row-name{color:var(--text);font-weight:500}.strat-row-sub{color:var(--text-dim);font-size:11px;margin-top:2px;max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.strat-row-actions{display:inline-flex;gap:6px;justify-content:flex-end}.permissions-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 900px){.permissions-grid{grid-template-columns:1fr}}.perm-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}.perm-row:last-child{border-bottom:none}.perm-row-info{flex:1;min-width:0}.perm-row-label{font-size:13px;color:var(--text);font-weight:500}.perm-row-hint{font-size:11px;color:var(--text-dim);margin-top:2px;font-family:var(--thai)}.perm-toggle{display:inline-flex;align-items:center;gap:8px;background:transparent;border:none;cursor:pointer;padding:0;font-family:var(--mono)}.perm-toggle:disabled{opacity:.5;cursor:not-allowed}.perm-toggle-track{width:36px;height:20px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;position:relative;transition:background .15s,border-color .15s;flex-shrink:0}.perm-toggle-thumb{position:absolute;top:1px;left:1px;width:16px;height:16px;background:var(--text-dim);border-radius:50%;transition:left .18s ease,background .15s}.perm-toggle.on .perm-toggle-track{background:#26a69a33;border-color:#26a69a8c}.perm-toggle.on .perm-toggle-thumb{left:17px;background:var(--green)}.perm-toggle-label{font-size:10px;letter-spacing:.15em;color:var(--text-dim);width:28px;text-align:left}.perm-toggle.on .perm-toggle-label{color:var(--green)}.perm-dirty-banner{background:#d4af371a;border-left:2px solid var(--gold);color:var(--gold);padding:8px 14px;font-size:12px;font-family:var(--thai);margin-bottom:14px;border-radius:2px}.perm-row.dirty{background:#d4af370d}.perm-dirty-pill{display:inline-block;margin-left:8px;padding:1px 7px;font-size:9px;font-family:var(--mono);letter-spacing:.1em;background:#d4af372e;color:var(--gold);border-radius:3px;border:1px solid rgba(212,175,55,.4)}.row-actions{display:inline-flex;align-items:center;gap:4px;justify-content:flex-end}.btn-icon{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;color:var(--text-dim);font-size:13px;line-height:1;cursor:pointer;border-radius:4px;transition:all .12s ease;padding:0}.btn-icon:hover{color:var(--gold);background:#d4af371a;border-color:#d4af3759}.btn-icon.danger:hover{color:var(--red);background:#ef53501a;border-color:#ef535059}.btn-icon:active{transform:scale(.94)}.btn-icon:focus-visible{outline:none;border-color:var(--gold)}.accounts-table{font-size:11.5px;table-layout:auto;width:100%}.accounts-table th{padding:8px 6px;font-size:9px;letter-spacing:.08em;white-space:nowrap}.accounts-table td{padding:7px 6px;white-space:nowrap}.accounts-table td:first-child,.accounts-table th:first-child{padding-left:10px}.accounts-table td:last-child,.accounts-table th:last-child{padding-right:10px}.accounts-table .strat-row-actions .btn-tiny{padding:3px 7px;font-size:10px}.btn-tiny{padding:4px 10px;font-size:11px;background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-family:inherit;transition:all .15s;box-sizing:border-box;min-height:26px;display:inline-flex;align-items:center;justify-content:center;line-height:1.15}.btn-tiny:hover{color:var(--text);border-color:var(--gold)}.btn-tiny.danger:hover{color:var(--red);border-color:var(--red)}.strat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.strat-card{background:var(--surface);border:1px solid var(--border);padding:18px;position:relative;overflow:hidden;cursor:pointer;transition:border-color .2s}.strat-card:hover{border-color:var(--border-active)}.strat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold)}.strat-card.c1:before{background:var(--blue)}.strat-card.c2:before{background:var(--purple)}.strat-card.c3:before{background:var(--orange)}.strat-card.c4:before{background:var(--green)}.strat-name{font-family:var(--serif);font-size:20px;margin-bottom:6px}.strat-type{font-size:10px;letter-spacing:.2em;color:var(--text-dim);text-transform:uppercase;margin-bottom:14px}.strat-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}.strat-stat{padding:8px 10px;background:var(--surface2)}.strat-stat-label{font-size:9px;letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase;margin-bottom:3px}.strat-stat-value{font-size:14px;color:var(--gold);font-weight:500}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.filter-bar .form-select,.filter-bar .form-input{width:auto;padding:7px 12px;font-size:12px}.filter-bar-v2{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.filter-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.filter-row .form-select,.filter-row .form-input{width:auto;padding:7px 12px;font-size:12px}.filter-search{flex:1;min-width:200px}.filter-advanced{padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:4px}.filter-daterange{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.filter-daterange label{font-size:10px;letter-spacing:.15em;text-transform:uppercase;margin-right:4px}.chip-group{display:inline-flex;gap:2px;padding:2px;background:var(--surface2);border:1px solid var(--border);border-radius:4px}.chip{padding:4px 10px;font-size:11px;background:transparent;border:none;color:var(--text-muted);font-family:var(--mono);cursor:pointer;border-radius:3px;transition:all .12s;letter-spacing:.03em}.chip:hover{color:var(--text)}.chip.active{background:#d4af371f;color:var(--gold)}.chip.active.win{background:#26a69a2e;color:var(--green)}.chip.active.loss{background:#ef53502e;color:var(--red)}.chip.active.long{background:#26a69a2e;color:var(--green)}.chip.active.short{background:#ef53502e;color:var(--red)}.chip.active.open{background:#4fc3f72e;color:var(--blue)}.summary-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:12px;font-family:var(--mono);font-size:12px;color:var(--text-muted);flex-wrap:wrap}.summary-bar .summary-sep{color:var(--border)}.summary-bar strong.green{color:var(--green)}.summary-bar strong.red{color:var(--red)}.pagination{position:fixed;bottom:0;left:var(--sidebar-w, 220px);transition:left .22s cubic-bezier(.4,0,.2,1);right:0;display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 24px;background:#080b10eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--border);z-index:50}.pagination-info{font-family:var(--mono);font-size:12px;color:var(--text-muted);min-width:60px;text-align:center}.pagination-size{display:flex;gap:4px;margin-left:12px;padding-left:12px;border-left:1px solid var(--border)}.pagination-size .btn{padding:4px 10px;font-size:11px;min-width:36px}.pagination-size .btn.active{background:#d4af3726;border-color:#d4af3766;color:var(--gold)}.page-with-pagination{display:flex;flex-direction:column;height:calc(100vh - 88px);min-height:0;gap:0}.main:has(>.page-with-pagination){padding-bottom:0}.main:has(>.page-with-pagination)>.page-with-pagination{height:calc(100vh - 28px)}.page-with-pagination>.panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;margin-bottom:0}.page-with-pagination>.panel>.table-wrap{flex:1;min-height:0;max-height:none!important;overflow:auto}.page-with-pagination>.pagination{position:static;left:auto;right:auto;bottom:auto;background:var(--surface);margin-top:0;flex-shrink:0}.col-freeze{position:sticky;z-index:1}td.col-freeze{background:var(--surface)}tr:hover td.col-freeze{background:#12181f}th.col-freeze{background:var(--surface2);z-index:4}.col-freeze-1{left:0;min-width:88px}.col-freeze-2{left:88px;min-width:96px}.col-freeze-2{box-shadow:2px 0 6px #0000004d}.col-freeze-strat{left:0;box-shadow:2px 0 6px #0000004d}.trades-table table{font-size:12px;table-layout:fixed;width:max-content}.trades-table th,.trades-table td{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-right:1px solid var(--border);min-width:0;box-sizing:border-box}.trades-table td>span{max-width:100%;overflow:hidden;text-overflow:ellipsis;display:inline-block;vertical-align:middle}.trades-table td>div.strat-cell{display:flex;align-items:center;gap:6px;width:100%;max-width:100%;overflow:hidden;container-type:inline-size}.trades-table td>div.strat-cell>.strat-cell-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 0;min-width:0}.trades-table td>div.strat-cell>.pill{flex:0 99 auto;min-width:0;overflow:hidden;text-overflow:clip}@container (max-width: 90px){.strat-cell>.pill{display:none}}.trades-table th{position:relative}.trades-table thead tr:first-child th{position:sticky;top:0;z-index:3;background:var(--surface)}.trades-table thead tr:nth-child(2) th{position:sticky;top:20px;z-index:3;background:var(--surface2)}.trades-table th.col-freeze-strat,.trades-table td.col-freeze-strat{position:sticky;z-index:2;background:var(--surface)}.trades-table thead tr:first-child th.col-freeze-strat,.trades-table thead tr:nth-child(2) th.col-freeze-strat{z-index:5}.trades-table thead tr:last-child th{border-bottom:2px solid var(--border-active)}.trades-table .th-group th{padding-top:4px;padding-bottom:2px}.trades-table thead tr:nth-child(2) th{padding-top:4px}.trades-table tbody tr:hover td{background:var(--surface2)}.trades-table .th-group th{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);text-align:center;padding:6px 8px;background:var(--surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border);font-weight:500}.trades-table th.num,.trades-table td.num{text-align:right}.col-resize-handle{position:absolute;right:-3px;top:0;bottom:0;width:6px;cursor:col-resize;z-index:5;background:transparent;transition:background .15s}.col-resize-handle:hover,.col-resize-handle:active{background:var(--gold)}.trades-toolbar{display:flex;justify-content:flex-end;padding:6px 0;gap:8px;flex-shrink:0}.col-picker{position:relative;display:inline-block}.col-picker-list{position:absolute;top:calc(100% + 4px);right:0;min-width:220px;max-height:400px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);box-shadow:0 8px 20px #00000080;z-index:100;padding:6px 0}.col-picker-head{display:flex;justify-content:space-between;align-items:center;padding:6px 12px 8px;border-bottom:1px solid var(--border);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim)}.col-picker-item{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:12px;cursor:pointer;transition:background .1s}.col-picker-item:hover{background:var(--surface2)}.col-picker-item input[type=checkbox]{margin:0;accent-color:var(--gold)}.nav-hero{background:linear-gradient(135deg,var(--surface) 0%,var(--surface2) 100%);border:1px solid var(--border);border-left:3px solid var(--gold);padding:20px 24px;margin-bottom:18px}.nav-hero-main .kpi-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px}.nav-hero-value{font-family:var(--serif);font-size:42px;color:var(--gold);line-height:1.1;margin-bottom:10px;letter-spacing:-.02em}.nav-hero-split{display:flex;gap:14px;align-items:center;flex-wrap:wrap;font-family:var(--mono);font-size:12px;color:var(--text-muted)}.nav-hero-sep{color:var(--border)}.dash-two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}@media (max-width: 900px){.dash-two-col{grid-template-columns:1fr}}.asset-list{display:flex;flex-direction:column;gap:10px}.asset-row{display:grid;grid-template-columns:130px 1fr 110px;gap:10px;align-items:center;font-size:12px}.asset-label{color:var(--text-muted);font-family:var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-bar-wrap{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}.asset-bar{height:100%;transition:width .3s ease;min-width:2px}.asset-value{text-align:right;font-family:var(--mono);font-weight:500}.asset-row.clickable{cursor:pointer;padding:4px 6px;margin:0 -6px;border-radius:4px;transition:background .15s}.asset-row.clickable:hover{background:var(--surface2)}.drilldown-panel{margin:4px 0 8px 20px;padding:12px;background:var(--surface2);border:1px solid var(--border);border-radius:4px}.drilldown-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:10px}.drill-label{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim);margin-bottom:3px}.drill-value{font-size:13px;color:var(--text)}.drill-trades{border-top:1px solid var(--border);padding-top:8px}.drill-trade-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:11px;border-bottom:1px solid rgba(255,255,255,.04)}.drill-trade-row:last-child{border-bottom:none}.checkbox-row{display:inline-flex;align-items:center;gap:8px;font-size:12px;cursor:pointer;color:var(--text-muted)}.checkbox-row input[type=checkbox]{accent-color:var(--gold);margin:0}.th-sort{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.th-sort:hover{color:var(--gold)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:8px}.toast{background:var(--surface);border:1px solid var(--border-active);padding:12px 18px;font-family:var(--thai);font-size:13px;color:var(--text);min-width:240px;animation:slideIn .25s;box-shadow:0 4px 24px #0006}.toast.success{border-left:3px solid var(--green)}.toast.error{border-left:3px solid var(--red)}.toast.info{border-left:3px solid var(--blue)}.loading{padding:40px;text-align:center;font-family:var(--thai);font-size:13px;color:var(--text-muted);font-weight:300}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#d4af3733;border-radius:3px}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:50;width:40px;height:40px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:18px;border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s;align-items:center;justify-content:center}.mobile-menu-btn:hover{background:var(--surface2);border-color:#d4af3766}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:60;opacity:0;pointer-events:none;transition:opacity .22s ease}.sidebar-backdrop.visible{opacity:1;pointer-events:auto}@media (max-width: 900px){.mobile-menu-btn{display:flex}.sidebar-backdrop{display:block}.sidebar{position:fixed;top:0;left:0;height:100vh;width:240px!important;min-width:240px!important;z-index:70;transform:translate(-100%);transition:transform .22s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 16px #0006}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:9px 12px;gap:10px}.sidebar.collapsed .nav-icon{font-size:15px}.sidebar .sidebar-toggle{display:none}.main{padding:64px 16px 60px;margin-left:0!important}:root{--sidebar-w: 0px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.form-grid,.form-grid-2,.strat-grid{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start;gap:12px}.topbar-right{width:100%;flex-wrap:wrap}.page-title{font-size:22px}.page-sub{font-size:12px}.nav-hero{padding:16px 18px}.nav-hero-value{font-size:32px}.dash-two-col{grid-template-columns:1fr}.modal-backdrop{padding:20px 12px}.modal{max-width:100%}.modal-header{padding:14px 16px}.modal-title{font-size:18px}.modal-body{padding:16px}.modal-footer{padding:12px 16px;flex-wrap:wrap;gap:8px}.modal-wide{width:100%!important}.bt-tabs-row{flex-wrap:wrap;gap:8px}.bt-tabs{flex-wrap:wrap}.bt-session-meta{font-size:12px}.bt-system-name{font-size:16px}.bt-session-actions{flex-wrap:wrap;gap:8px}.bt-kpi-strip{grid-template-columns:repeat(2,1fr);gap:8px}.bt-kpi-value{font-size:16px}.bt-year-chips{gap:6px}.bt-year-chip{min-width:100px}.trades-toolbar{flex-wrap:wrap;gap:8px}.trades-filter-bar{flex-wrap:wrap}.perf-controls{flex-wrap:wrap;gap:8px}.bt-table-wrap{max-height:60vh}.bt-pagination{flex-wrap:wrap;gap:8px}.bt-pagination-info{width:100%}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr}.main{padding:64px 12px 60px}.page-title{font-size:20px}.nav-hero-value{font-size:26px}.bt-kpi-strip{grid-template-columns:repeat(2,1fr)}.bt-year-chip{min-width:88px;padding:6px}.modal-backdrop{padding:12px 8px}.modal-body{padding:12px}.topbar-right .btn{flex:1;min-width:0}}.heatmap-wrap{overflow-x:auto;padding:6px 14px 14px}.heatmap{width:100%;border-collapse:separate;border-spacing:2px;font-size:12px;font-family:var(--mono)}.heatmap thead th{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);font-weight:500;padding:6px 0;text-align:center;background:transparent}.heatmap thead th.heatmap-year,.heatmap thead th.heatmap-total{text-align:left}.heatmap td.heatmap-year{text-align:left;color:var(--text-muted);padding:0 8px;font-size:12px;font-weight:500;width:52px}.heatmap td.heatmap-cell{padding:8px 4px;text-align:center;border-radius:3px;font-size:11px;min-width:58px;color:var(--text)}.heatmap td.heatmap-cell.empty{background:var(--surface2);color:var(--text-dim);font-size:10px}.heatmap td.heatmap-total{text-align:right;font-weight:500;border-left:1px solid var(--border);padding:8px 10px 8px 14px;min-width:72px}.corr-wrap{padding:10px 14px 14px;overflow-x:auto}.corr-matrix{border-collapse:separate;border-spacing:2px;font-family:var(--mono);font-size:12px}.corr-matrix thead th{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);font-weight:500;padding:6px 8px;text-align:center;background:transparent;min-width:72px}.corr-matrix th.corr-corner{min-width:130px}.corr-matrix td.corr-row-label{font-size:11px;color:var(--text-muted);padding:0 10px 0 4px;text-align:right;white-space:nowrap}.corr-matrix td.corr-cell{padding:8px 4px;text-align:center;border-radius:3px;font-size:12px;color:var(--text);min-width:58px}.corr-matrix td.corr-cell.diag{background:#d4af372e!important;color:var(--gold);font-weight:500}.corr-matrix td.corr-cell.empty{background:var(--surface2);color:var(--text-dim)}.corr-legend{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:10px;font-size:11px;color:var(--text-muted);font-family:var(--thai)}.corr-legend-item{display:inline-flex;align-items:center;gap:6px}.corr-legend .swatch{display:inline-block;width:14px;height:14px;border-radius:2px}.corr-legend-note{margin-left:auto;color:var(--text-dim);font-style:italic}.info-tip-wrap{position:relative;display:inline-flex;align-items:center;vertical-align:middle}.info-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:#e8e6e159;font-size:10px;font-style:italic;font-family:Georgia,serif;font-weight:700;cursor:help;margin-left:5px;flex-shrink:0;line-height:1;transition:background .15s,color .15s,border-color .15s;-webkit-user-select:none;user-select:none}.info-tip-wrap:hover .info-icon{background:#d4af3726;color:var(--gold);border-color:#d4af3759}.info-icon.pinned{background:#d4af3740;color:var(--gold);border-color:var(--gold);cursor:pointer}.info-tooltip.pinned{border-color:#d4af378c;padding-right:28px}.info-tooltip-close{position:absolute;top:4px;right:4px;width:20px;height:20px;border:none;background:transparent;color:#e8e6e173;cursor:pointer;font-size:12px;line-height:1;border-radius:4px;transition:background .15s,color .15s}.info-tooltip-close:hover{background:#ffffff14;color:var(--gold)}.info-tooltip{width:272px;max-width:calc(100vw - 16px);max-height:calc(100vh - 16px);overflow-y:auto;overflow-x:hidden;background:#111820;border:1px solid rgba(212,175,55,.22);border-radius:7px;padding:10px 12px;box-shadow:0 8px 28px #000000a6;font-size:12px;line-height:1.6;color:var(--text);white-space:normal;scrollbar-width:thin;scrollbar-color:rgba(212,175,55,.2) transparent;word-wrap:break-word;overflow-wrap:break-word}.info-tooltip:before,.info-tooltip:after{content:"";position:absolute;left:var(--caret-x, 50%);width:0;height:0;pointer-events:none}.info-tooltip.caret-up:before{top:-7px;margin-left:-7px;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:7px solid rgba(212,175,55,.22)}.info-tooltip.caret-up:after{top:-6px;margin-left:-6px;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #111820}.info-tooltip.caret-down:before{bottom:-7px;margin-left:-7px;border-left:7px solid transparent;border-right:7px solid transparent;border-top:7px solid rgba(212,175,55,.22)}.info-tooltip.caret-down:after{bottom:-6px;margin-left:-6px;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #111820}.info-tooltip.pinned.caret-up:before{border-bottom-color:#d4af378c}.info-tooltip.pinned.caret-down:before{border-top-color:#d4af378c}.info-tooltip::-webkit-scrollbar{width:4px}.info-tooltip::-webkit-scrollbar-thumb{background:#d4af3733;border-radius:2px}.tt-example{margin-top:7px;padding:5px 8px;background:#ffffff08;border-left:2px solid rgba(212,175,55,.3);border-radius:0 4px 4px 0;font-family:var(--mono);font-size:11px;color:var(--text-muted);line-height:1.75}pre.tt-example-pre,.tt-example-pre{white-space:pre;overflow-x:auto;margin:7px 0 0}.tt-target{margin-top:6px;font-size:11px;color:var(--gold);opacity:.9}.report-doc{display:flex;flex-direction:column;gap:18px}.report-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 0 18px;border-bottom:2px solid var(--gold);margin-bottom:6px}.report-brand{font-family:var(--serif);font-size:28px;letter-spacing:.04em;color:var(--text);font-weight:400}.report-brand span{color:var(--gold);font-style:italic}.report-tagline{font-family:var(--thai);font-size:12px;color:var(--text-dim);letter-spacing:.06em;margin-top:4px}.report-period{text-align:right}.report-period-label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.12em;margin-bottom:4px}.report-period-value{font-family:var(--serif);font-size:22px;color:var(--gold);font-weight:400}.report-disclaimer{margin-top:12px;padding:18px 20px;border-top:1px solid var(--border);background:var(--surface);border-radius:6px}.report-disclaimer-title{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px}.report-disclaimer-body{font-family:var(--thai);font-size:11px;color:var(--text-muted);line-height:1.7}.report-footer{margin-top:14px;padding-top:10px;border-top:1px dashed var(--border);font-size:10px;font-family:var(--mono);color:var(--text-dim);letter-spacing:.06em;text-align:center}@media print{@page{size:A4;margin:14mm}body{background:#fff!important;color:#111!important}.sidebar,.topbar,.report-controls,button,.nav-section,.toast{display:none!important}main,.layout-main{margin-left:0!important;padding:0!important}.report-doc{color:#111}.panel,.kpi{background:#fff!important;border:1px solid #ccc!important;box-shadow:none!important;page-break-inside:avoid}.panel-header,.report-disclaimer{background:#f5f5f0!important}.report-brand,.report-period-value,.report-brand span{color:#806000!important}.panel-title,.kpi-label,.kpi-value,.kpi-sub,table th,table td{color:#111!important}.pnl-pos,[style*=green]{color:#2a7a2a!important}.pnl-neg,[style*=red]{color:#b32020!important}[style*=gold]{color:#806000!important}}.backtester-page{display:flex;flex-direction:column;gap:16px;height:100%;overflow-y:auto}.bt-tabs-row{display:flex;align-items:flex-end;gap:12px;border-bottom:1px solid var(--border)}.bt-tabs-row .bt-tabs{border-bottom:none;flex:1}.bt-new-session-btn{white-space:nowrap;flex-shrink:0}.bt-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);padding-bottom:0;flex-wrap:wrap}.bt-tab{padding:8px 18px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-family:var(--mono);font-size:13px;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;position:relative;top:1px}.bt-tab:hover{color:var(--text)}.bt-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.bt-tab-group{background:#d4af370a;border-radius:4px 4px 0 0}.bt-tab-group.active{background:#d4af371a}.bt-tab-group-icon{margin-right:4px;font-size:11px}.bt-collide-badge{display:inline-block;margin-right:4px;color:var(--orange);font-size:11px;cursor:help}.bt-trade-row-collide td{background:#fb923c0f!important}.bt-dd-dist{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--orange);border-radius:6px;padding:10px 12px;margin:8px 0}.bt-dd-dist-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.bt-dd-dist-title{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--orange);font-family:var(--mono)}.bt-dd-dist-total{font-size:11px;color:var(--text-muted);font-family:var(--mono)}.bt-dd-dist-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.bt-dd-dist-col-label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.bt-dd-dist-row{display:grid;grid-template-columns:50px 1fr 70px;align-items:center;gap:8px;padding:2px 0;font-family:var(--mono);font-size:11px}.bt-dd-dist-row-label{color:var(--text-muted)}.bt-dd-dist-row-bar{position:relative;height:10px;background:#ffffff0a;border-radius:2px;overflow:hidden}.bt-dd-dist-row-bar-fill{height:100%;background:#fb923c8c;transition:width .2s}.bt-dd-dist-row-val{text-align:right;display:inline-flex;gap:4px;justify-content:flex-end}.bt-dd-dist-row-count{color:var(--orange);font-weight:500}.bt-dd-dist-row-pct{color:var(--text-dim)}.bt-drag-cell{text-align:center!important;color:var(--text-dim);cursor:grab;-webkit-user-select:none;user-select:none;font-size:11px;letter-spacing:-2px}.bt-drag-cell:hover{color:var(--gold)}.bt-trade-row-dragging td{opacity:.45;background:#d4af3714!important}.bt-trade-row-dragging .bt-drag-cell{cursor:grabbing}.bt-session-header{display:flex;flex-direction:column;align-items:stretch;gap:8px}.bt-session-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.bt-system-name{font-family:"DM Serif Display",serif;font-size:20px;color:var(--text)}.bt-meta-badge{padding:3px 10px;border-radius:12px;background:var(--surface2);border:1px solid var(--border);font-size:12px;font-family:var(--mono);color:var(--text-muted)}.bt-session-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.bt-inline-control{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--surface);border:1px solid var(--border);border-radius:5px;height:32px}.bt-inline-control-mode{padding-right:4px}.bt-inline-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-family:var(--mono)}.bt-inline-input{width:90px;background:var(--surface2);border:1px solid var(--border);color:var(--gold);padding:3px 6px;font-family:var(--mono);font-size:13px;border-radius:3px;text-align:right}.bt-inline-input:focus{outline:none;border-color:var(--gold)}.bt-inline-suffix{font-size:11px;color:var(--text-muted);font-family:var(--mono)}.bt-inline-value{font-family:var(--mono);font-size:14px;font-weight:500}.bt-inline-divider{width:1px;height:20px;background:var(--border);margin:0 2px}.bt-suggest-btn{background:transparent;border:1px dashed var(--gold);color:var(--gold);padding:4px 10px;font-family:var(--mono);font-size:11px;border-radius:4px;height:32px;cursor:pointer;white-space:nowrap;transition:background .15s,border-style .15s}.bt-suggest-btn:hover{background:#d4af371f;border-style:solid}.bt-kpi-strip{display:flex;gap:6px;flex-wrap:wrap}.bt-kpi{flex:1 1 80px;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:5px 8px}.bt-kpi-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1px}.bt-kpi-value{font-family:var(--mono);font-size:14px;color:var(--text)}.bt-year-chips{display:flex;flex-wrap:nowrap;gap:6px;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.bt-year-chips-inline{padding:8px 12px 10px;border-top:1px solid var(--border);background:#ffffff03}.bt-year-chips::-webkit-scrollbar{height:6px}.bt-year-chips::-webkit-scrollbar-track{background:transparent}.bt-year-chips::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.bt-year-chips::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.bt-year-chip{flex:0 0 110px;min-width:110px;max-width:110px;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:5px 8px;display:flex;flex-direction:column;gap:2px}.bt-year-chip-year{font-family:var(--mono);font-size:10px;color:var(--gold);letter-spacing:.04em;text-transform:uppercase}.bt-year-chip-wr{font-family:var(--mono);font-size:14px;font-weight:500;line-height:1.05}.bt-year-chip-bar{height:3px;background:var(--surface2);border-radius:2px;overflow:hidden}.bt-year-chip-bar-fill{height:100%;background:var(--green);transition:width .2s ease}.bt-year-chip-bar-fill.fail{background:var(--red)}.bt-year-chip-profit{display:flex;flex-direction:column;gap:1px;font-family:var(--mono);font-size:11px;margin-top:1px}.bt-year-chip-profit-row{display:flex;justify-content:space-between;align-items:baseline}.bt-year-chip-profit-label{font-size:8px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em}.bt-year-table-panel{padding:0}.bt-year-table-toggle{background:transparent;border:none;color:var(--gold);font-size:12px;font-family:var(--mono);cursor:pointer;padding:0;letter-spacing:.04em}.bt-year-table-toggle:hover{color:var(--text)}.bt-year-table-wrap{overflow-x:auto;border-top:1px solid var(--border)}.bt-year-table-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.bt-year-range-picker{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px}.bt-year-range-label{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim)}.bt-year-avg-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:11px;padding:2px 6px;border-radius:3px;cursor:pointer}.bt-year-avg-select:focus{outline:none;border-color:var(--gold)}.bt-year-table tbody tr.bt-year-avg-row-tr{background:#d4af370d}.bt-year-table tbody tr.bt-year-avg-row-tr:first-of-type td{border-top:1px solid var(--border)}.bt-year-table tbody tr.bt-year-avg-row-tr td{border-bottom:none}.bt-year-table{width:100%;border-collapse:collapse;font-size:12px}.bt-year-table th{background:var(--surface2);padding:7px 10px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);font-weight:500;border-bottom:1px solid var(--border);font-family:var(--mono);white-space:nowrap}.bt-year-table td{padding:7px 10px;border-bottom:1px solid var(--border);white-space:nowrap}.bt-year-table tbody tr.bt-year-row.clickable{cursor:pointer;transition:background .12s}.bt-year-table tbody tr.bt-year-row.clickable:hover{background:#d4af370a}.bt-year-table tbody tr.bt-month-row{background:#ffffff04}.bt-year-table tbody tr.bt-month-row td{border-bottom:1px solid rgba(255,255,255,.02)}.bt-year-table tbody tr.bt-year-row+tr.bt-month-row td{border-top:1px solid var(--border)}.bt-year-chip-meta{font-family:var(--mono);font-size:9px;color:var(--text-muted);letter-spacing:.02em;margin-top:1px}.bt-equity-chart{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px 16px 14px;margin:8px 0 10px}.bt-equity-chart-title{font-family:var(--serif);font-size:14px;font-style:italic;color:var(--text);text-align:center;margin-bottom:8px;letter-spacing:.02em}.bt-equity-chart-canvas{position:relative;height:280px}.not-found{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.not-found-inner{max-width:560px;width:100%;text-align:center;padding:48px 32px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--gold);border-radius:4px}.not-found-code{font-family:"DM Serif Display",serif;font-size:96px;line-height:1;color:var(--gold);letter-spacing:-.02em;margin-bottom:12px}.not-found-title{font-family:"DM Serif Display",serif;font-size:26px;color:var(--text);margin-bottom:16px}.not-found-path{display:inline-block;font-family:var(--mono);font-size:12px;color:var(--text-muted);background:var(--surface2);padding:4px 10px;border-radius:4px;margin-bottom:16px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.not-found-msg{color:var(--text-muted);font-size:13px;margin-bottom:28px;font-family:Noto Sans Thai,sans-serif}.not-found-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.not-found-actions .btn{text-decoration:none}.bt-trade-panel{flex:1;min-height:0;display:flex;flex-direction:column}.bt-table-wrap{overflow:auto;max-height:75vh;contain:layout paint}table.bt-trade-table{border-collapse:collapse;width:100%!important;min-width:max-content;table-layout:fixed!important;font-size:12.5px}.bt-trade-table th,.bt-trade-table td{box-sizing:border-box}.bt-trade-table th{background:var(--surface2);padding:7px 5px;text-align:right;color:var(--text-muted);font-weight:400;font-size:11px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:sticky;top:0;z-index:1}.bt-trade-table th:first-child,.bt-trade-table th:nth-child(2){text-align:left}.bt-trade-table .col-resize-handle:before{content:"";position:absolute;right:3px;top:25%;bottom:25%;width:1px;background:#d4af3759;transition:background .15s,width .15s}.bt-trade-table .col-resize-handle:hover:before{background:var(--gold);width:2px}.bt-trade-table td{padding:6px 5px;border-bottom:1px solid var(--border);text-align:right;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bt-trade-table td:first-child,.bt-trade-table td:nth-child(2){text-align:left}.bt-trade-table tr:hover td{background:#ffffff05}.bt-pagination{display:flex;align-items:center;gap:12px;padding:6px 10px;border-top:1px solid var(--border);background:var(--surface);font-size:11px;color:var(--text-muted);font-family:var(--mono)}.bt-pagination-info{flex:1}.bt-pagination-size,.bt-pagination-nav{display:inline-flex;align-items:center;gap:4px}.bt-pagination-label{font-size:10px;color:var(--text-dim);margin-right:4px;text-transform:uppercase;letter-spacing:.04em}.bt-pagination .btn-tiny.active{background:var(--gold);color:#080b10;border-color:var(--gold)}.bt-pagination-page{min-width:60px;text-align:center;color:var(--text);font-weight:500}.col-green{color:var(--green)!important}.col-red{color:var(--red)!important}.col-mono{font-family:var(--mono)}.modal-wide{width:min(780px,95vw)}.bt-tuning-bar{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--gold);padding:8px 12px;border-radius:6px}.bt-tuning-label,.bt-tuning-feedback{display:flex;flex-direction:column;gap:3px;min-width:70px}.bt-tuning-controls{flex:1;display:flex;align-items:center;gap:8px}.bt-tuning-mode{display:flex;flex-direction:column;gap:3px}.bt-mode-toggle{display:inline-flex;background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:2px;gap:2px}.bt-mode-btn{background:transparent;border:none;color:var(--text-muted);font-size:11px;font-family:var(--mono);padding:4px 10px;border-radius:3px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.bt-mode-btn:hover{color:var(--text)}.bt-mode-btn.active{background:var(--gold);color:#000;font-weight:500;box-shadow:0 0 6px #d4af374d}.bt-risk-slider{flex:1;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer}.bt-risk-slider::-webkit-slider-runnable-track{height:4px;background:var(--surface2);border-radius:2px}.bt-risk-slider::-moz-range-track{height:4px;background:var(--surface2);border-radius:2px}.bt-risk-slider::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:16px;height:16px;background:var(--gold);border-radius:50%;margin-top:-6px;cursor:pointer;box-shadow:0 0 8px #d4af3766}.bt-risk-slider::-moz-range-thumb{width:16px;height:16px;background:var(--gold);border:none;border-radius:50%;cursor:pointer;box-shadow:0 0 8px #d4af3766}.bt-risk-input{width:90px;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:6px 10px;font-family:var(--mono);font-size:14px;border-radius:4px;text-align:right}.bt-risk-input:focus{outline:none;border-color:var(--gold)}.bt-row-input{width:100%;min-width:0;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:4px 6px;font-family:var(--mono);font-size:12px;border-radius:3px;box-sizing:border-box}.bt-row-input[type=date],.bt-row-input[type=time]{min-width:0}.bt-row-input::-webkit-calendar-picker-indicator{padding:0;margin:0;width:12px;filter:invert(.5);opacity:.5;cursor:pointer}.bt-row-input::-webkit-inner-spin-button,.bt-row-input::-webkit-clear-button{display:none;-webkit-appearance:none}.bt-row-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}.bt-new-row{background:#d4af370a;border-top:2px solid rgba(212,175,55,.3)}.bt-new-row td{padding:6px 8px;position:sticky;bottom:0;z-index:2;background:var(--surface);border-top:2px solid rgba(212,175,55,.5);box-shadow:0 -4px 8px #00000040}.bt-new-row td:first-child{padding-left:10px;font-weight:500}.bt-csv-menu{position:relative;display:inline-block}.bt-csv-menu-list{position:absolute;top:calc(100% + 4px);right:0;z-index:20;min-width:180px;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:4px;box-shadow:0 6px 18px #0006;display:flex;flex-direction:column;gap:2px}.bt-csv-menu-item{background:transparent;border:none;color:var(--text);font-family:var(--mono);font-size:12px;text-align:left;padding:7px 10px;border-radius:3px;cursor:pointer;transition:background .12s}.bt-csv-menu-item:hover{background:var(--surface2);color:var(--gold)}.bt-filter-panel{display:flex;flex-wrap:wrap;align-items:center;gap:12px 14px;padding:10px 12px;background:#4fc3f70a;border-top:1px solid var(--border);border-bottom:1px solid rgba(79,195,247,.25)}.bt-filter-group{display:inline-flex;align-items:center;gap:6px}.bt-filter-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-right:2px}.bt-filter-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:4px 6px;font-family:var(--mono);font-size:12px;border-radius:3px;height:26px;box-sizing:border-box}.bt-filter-input:focus{outline:none;border-color:var(--blue)}.bt-filter-input-num{width:70px}.bt-filter-sep{color:var(--text-dim);font-size:10px}.bt-filter-summary{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--text-muted);letter-spacing:.03em}.btn.active{background:#4fc3f71f;border-color:#4fc3f780;color:var(--blue)}.bt-quick-add{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#d4af370a;border-top:1px solid var(--border);border-bottom:2px solid rgba(212,175,55,.3);flex-wrap:wrap}.bt-quick-add-label{font-family:var(--mono);font-size:11px;color:var(--gold);text-transform:uppercase;letter-spacing:.04em;font-weight:500;margin-right:4px}.bt-quick-add-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:5px 8px;font-family:var(--mono);font-size:12px;border-radius:3px;height:28px;box-sizing:border-box}.bt-quick-add-input:focus{outline:none;border-color:var(--gold)}.bt-quick-add-date{width:130px}.bt-quick-add-time{width:90px}.bt-quick-add-slr{width:70px}.bt-quick-add-rs{width:130px}.bt-quick-add-btn{padding:5px 14px;font-size:12px;height:28px}.bt-inline-form{display:flex;align-items:center;gap:6px;padding:4px;flex-wrap:wrap}.bt-inline-form-label{font-family:var(--mono);font-size:11px;color:var(--blue);text-transform:uppercase;letter-spacing:.04em;margin-right:4px}.bt-inline-form-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:4px 6px;font-family:var(--mono);font-size:12px;border-radius:3px;height:26px;box-sizing:border-box}.bt-inline-form-input:focus{outline:none;border-color:var(--gold)}.bt-inline-form-input[type=date]{width:120px}.bt-inline-form-time{width:80px}.bt-inline-form-input[type=number]{width:70px}.bt-inline-form select.bt-inline-form-input{width:130px}.bt-edit-row{background:#4fc3f70d}.bt-edit-row td{padding:6px 8px}
