:root{color-scheme:dark light;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--top-bar-height:3.25rem;--status-chip-width:12.5rem;--max-width:min(1200px, 100rem);--brand-bg:#2b261f;--brand-bg-darker:#2b261f;--brand-surface:#2b261f;--brand-accent:#5a5244;--brand-accent-hover:#887350;--brand-accent-focus:#6b6253;--brand-accent-rgb:200,160,91;--brand-slate:#494135;--brand-accent-focus-ring:rgba(200,160,91,0.35);--brand-accent-soft:#f7ebd8;--brand-accent-soft-rgb:247,235,216;--glass-highlight:rgba(255,255,255,0.18);--glass-border:rgba(255,255,255,0.32);--glass-shadow:rgba(0,0,0,0.35);--brand-bg-gradient:radial-gradient(circle at top left, #5a5244 0%, #2b261f 55%, #18130d 100%);--brand-surface-gradient:linear-gradient(135deg, #2b261f 0%, #18130d 100%);--text-primary:#f8f8ff;--text-secondary:#ddd2c2;--text-muted:#c5c5f5;--text-light:#e0e0e0;--text-warn-alt:#f1c40f;--text-error-alt:#ff6b6b;--overlay-04:rgba(255,255,255,0.04);--overlay-05:rgba(255,255,255,0.05);--overlay-06:rgba(255,255,255,0.06);--overlay-08:rgba(255,255,255,0.08);--overlay-10:rgba(255,255,255,0.10);--overlay-12:rgba(255,255,255,0.12);--overlay-15:rgba(255,255,255,0.15);--overlay-16:rgba(255,255,255,0.16);--overlay-18:rgba(255,255,255,0.18);--overlay-25:rgba(255,255,255,0.25);--overlay-40:rgba(255,255,255,0.40);--accent-tint-15:rgba(var(--brand-accent-rgb),0.15);--accent-tint-18:rgba(var(--brand-accent-rgb),0.18);--accent-tint-20:rgba(var(--brand-accent-rgb),0.20);--accent-tint-30:rgba(var(--brand-accent-rgb),0.30);--accent-tint-35:rgba(var(--brand-accent-rgb),0.35);--accent-tint-40:rgba(var(--brand-accent-rgb),0.40);--accent-tint-45:rgba(var(--brand-accent-rgb),0.45);--state-success:#86efac;--state-success-bg:rgba(34,197,94,0.15);--state-success-border:rgba(34,197,94,0.4);--state-warn:#facc15;--state-warn-bg:rgba(245,158,11,0.15);--state-warn-border:rgba(245,158,11,0.4);--state-error:#f87171;--state-error-bg:rgba(239,68,68,0.15);--state-error-border:rgba(239,68,68,0.4);--panel-overlay:rgba(15,23,42,0.25);--panel-bg-deep:rgba(15,23,42,0.92);--border-default:var(--overlay-12);--border-strong:var(--overlay-18);--border-subtle:var(--overlay-10);--input-bg:#2a2a2a;--input-border:#555;--input-focus-border:var(--brand-accent-focus);--shadow-20:rgba(0,0,0,0.2);--shadow-30:rgba(0,0,0,0.3);--shadow-35:rgba(0,0,0,0.35);--shadow-40:rgba(0,0,0,0.4);--shadow-50:rgba(0,0,0,0.5);--backdrop-dim:rgba(0,0,0,0.6);--focus-ring:var(--accent-tint-35);background:var(--brand-bg);background:var(--brand-bg-gradient);color:var(--text-primary)}body{margin:0;padding:0;min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--overlay-05);border-bottom:1px solid var(--border-default);backdrop-filter:blur(18px);position:relative;z-index:10}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 1rem;height:var(--top-bar-height);display:flex;align-items:stretch;gap:0}.brand{display:flex;align-items:center;height:100%;box-sizing:border-box;flex:1 0}.brand-logo{height:calc(var(--top-bar-height) - .5rem);width:auto;display:block;margin-right:.75rem;object-fit:contain;filter:drop-shadow(0 4px 10px var(--shadow-35))}.brand h1{margin:0;font-size:1.5rem;font-weight:700}.status-bar{display:flex;flex:1 0;height:100%;align-items:stretch;justify-content:space-evenly;gap:0}@media (max-width:800px){.brand{flex:1 1 100%;padding-right:.75rem}.status-bar{flex:1 1 100%;justify-content:flex-start;gap:.75rem}}.status-entry{position:relative;background:var(--overlay-06);border:1px solid var(--border-default);display:flex;flex-direction:column;justify-content:center;height:100%;box-sizing:border-box;padding:0;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.status-entry:focus-within,.status-entry:hover{border-color:var(--accent-tint-40);background:var(--accent-tint-18);box-shadow:0 8px 24px var(--accent-tint-20)}.status-entry:focus-visible{outline:0;box-shadow:0 0 0 3px var(--focus-ring)}.status-entry[open]{border-color:var(--accent-tint-45);background:var(--accent-tint-15);box-shadow:0 10px 30px var(--panel-overlay)}.status-summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:.75rem;height:100%;padding:0 1rem;box-sizing:border-box;line-height:1}.status-summary .chip{height:calc(var(--top-bar-height) - 14px);display:inline-flex;align-items:center;justify-content:center;min-width:var(--status-chip-width);box-sizing:border-box;white-space:nowrap}.status-summary::-webkit-details-marker{display:none}.status-title{font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.8rem;color:var(--text-secondary)}.status-content{margin-top:.75rem;display:flex;flex-direction:column;gap:.75rem}.status-entry[open]>.status-content{position:absolute;top:calc(100% + 8px);left:0;right:0;width:auto;margin-top:0;background:var(--panel-bg-deep);border:1px solid var(--border-strong);border-radius:12px;box-shadow:0 16px 40px var(--shadow-35);padding:.85rem 1rem;z-index:20;box-sizing:border-box;overflow:hidden}.status-entry[open] .camera-toolbar select{min-width:0;width:100%}.status-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.workspace{flex:1;width:100%;padding:2.5rem 1rem 3rem;display:flex;justify-content:center;box-sizing:border-box}.workspace-inner{width:100%;max-width:var(--max-width)}.container{max-width:var(--max-width);margin:0 auto;padding:2rem 1rem 3rem}header p{max-width:60ch}.note{font-size:.9rem;color:var(--text-muted)}.controls{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}button{padding:.6rem 1.2rem;border-radius:6px;border:none;background:var(--brand-accent);color:var(--text-primary);cursor:pointer;font-weight:600}button[disabled]{opacity:.5;cursor:not-allowed}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.toast-backdrop{position:fixed;inset:0;z-index:1900;background:var(--backdrop-dim);backdrop-filter:blur(2px)}.toast-container{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2000;display:flex;flex-direction:column;gap:.75rem;width:min(420px,calc(100vw - 2rem));max-height:calc(100vh - 2rem);overflow:auto}.toast{background:var(--overlay-06);border:1px solid var(--border-default);border-radius:12px;padding:.9rem 1rem;box-shadow:0 10px 30px var(--shadow-35);backdrop-filter:blur(18px)}.toast-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.toast-close{padding:.35rem .6rem;border-radius:8px;background:var(--overlay-08);border:1px solid var(--border-subtle);color:var(--text-primary);cursor:pointer;line-height:1}.toast-close:hover{background:var(--overlay-12)}.toast[data-level=warn]{border-color:var(--state-warn-border)}.toast[data-level=error]{border-color:var(--state-error-border)}.toast-title{font-weight:700;margin-bottom:.25rem}.toast-message{color:var(--text-secondary);white-space:pre-line}.toast-command-row{margin-top:.75rem;display:flex;align-items:center;gap:.5rem}.toast-command-label{color:var(--text-secondary);font-size:.85rem;white-space:nowrap}.toast-command{flex:1;padding:.5rem .6rem;border-radius:8px;background:var(--overlay-05);border:1px solid var(--border-subtle);overflow:auto;white-space:pre}.toast-copy{padding:.45rem .8rem;border-radius:8px}.checklist{margin-top:1.5rem}.cards-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width:920px){.cards-grid{grid-template-columns:1fr 1fr}}.card{background:var(--overlay-06);border:1px solid var(--border-default);border-radius:16px;padding:1rem;box-shadow:0 4px 20px var(--shadow-20)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.card-sub{margin:.25rem 0 .5rem;color:var(--text-secondary)}.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .6rem;border-radius:999px;font-size:.85rem;line-height:1;border:1px solid transparent}.chip[data-state=ok]{background:var(--state-success-bg);border-color:var(--state-success-border);color:var(--state-success)}.chip[data-state=warn]{background:var(--state-warn-bg);border-color:var(--state-warn-border);color:var(--state-warn)}.chip[data-state=error]{background:var(--state-error-bg);border-color:var(--state-error-border);color:var(--state-error)}.status li,.status ul{list-style:none;padding:0;margin:0}.status{margin-top:2rem;background:var(--overlay-05);border-radius:12px;padding:1rem}.status li[data-level=info]{color:var(--text-primary)}.status li[data-level=warn]{color:var(--text-warn-alt)}.status li[data-level=error]{color:var(--text-error-alt)}.command-panel{margin-top:2rem}#command-form{display:flex;flex-direction:column;gap:.75rem}#command-input{padding:.6rem .8rem;border-radius:6px;border:1px solid var(--overlay-15);background:var(--overlay-05);color:inherit}.log{margin-top:2rem}#log-output{background:var(--shadow-50);border-radius:10px;padding:1rem;min-height:240px;max-height:480px;overflow-y:auto;white-space:pre-wrap}.stats{margin-top:0;background:var(--overlay-05);border-radius:12px;padding:1rem}.stats h2{margin-top:0;margin-bottom:.75rem;font-size:1rem;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem 1.25rem;align-items:stretch}.stat-item{display:flex;flex-direction:column;gap:.15rem;align-items:center;text-align:center}.stat-item--highlight{grid-column:1/-1;padding:.6rem .8rem;border-radius:10px;background:var(--overlay-06);border:1px solid var(--accent-tint-30);box-shadow:0 4px 16px var(--shadow-20);flex-direction:row;align-items:center;justify-content:space-between;text-align:left}.stat-item--highlight .stat-label{font-size:.85rem}.stat-item--highlight .stat-value{font-size:1.4rem}.stat-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.stat-value{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.details-summary-row{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem}.details-summary-sub{font-size:.85rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.loadout{margin-top:0;background:var(--overlay-05);border-radius:12px;padding:1rem}.loadout-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.loadout-option{background:var(--overlay-06);border:1px solid var(--border-default);border-radius:12px;padding:.75rem .85rem;color:var(--text-primary);cursor:pointer;display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:.75rem;text-align:left;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease,transform .2s ease}.loadout-option:hover{border-color:var(--accent-tint-40);background:var(--accent-tint-15);box-shadow:0 8px 24px var(--accent-tint-20);transform:translateY(-1px)}.loadout-option:active{transform:translateY(0)}.loadout-option[aria-pressed=true]{border-color:var(--accent-tint-45);background:var(--accent-tint-18);box-shadow:0 10px 30px var(--panel-overlay)}.loadout-option:focus-visible{outline:0;box-shadow:0 0 0 3px var(--focus-ring)}.loadout-icon{width:40px;height:24px;color:var(--text-primary);opacity:.95}.loadout-name{font-weight:650}.loadout-mag{font-variant-numeric:tabular-nums;color:var(--text-secondary)}.camera{margin-top:0;display:flex;flex-direction:column;gap:1rem}.camera-actions,.camera-toolbar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.camera-toolbar label{font-weight:600}#camera-select{min-width:220px;padding:.5rem .75rem;border-radius:6px;border:1px solid var(--overlay-25);background:var(--overlay-08);color:var(--text-primary)}#camera-select option,.camera-toolbar select option{background-color:var(--brand-surface);color:var(--text-primary)}#camera-select option:checked,#camera-select option:hover,.camera-toolbar select option:checked,.camera-toolbar select option:hover{background-color:var(--brand-slate);color:var(--text-primary)}#camera-select:focus{outline:0;border-color:var(--brand-accent);box-shadow:0 0 0 3px var(--focus-ring)}.camera-toolbar button{padding:.5rem .9rem}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border-radius:8px;background:var(--overlay-10);border:1px solid var(--overlay-16)}.icon-button:hover{background:var(--overlay-16)}.icon-button svg{color:var(--text-primary);width:20px;height:20px}#camera-stop{display:none!important}.camera-preview{margin-top:1.25rem}.details{margin:0}.aux-panel{margin-top:1.5rem;background:var(--overlay-05);border:1px solid var(--border-default);border-radius:12px;overflow:hidden}.aux-tabs{display:flex;align-items:center;gap:.25rem;padding:.35rem;background:0 0;border-bottom:1px solid var(--border-default)}.aux-tab{appearance:none;border:1px solid transparent;background:0 0;color:var(--text-secondary);padding:.5rem .85rem;border-radius:10px;cursor:pointer;font-weight:700;letter-spacing:.03em;text-transform:uppercase;font-size:.8rem}.aux-tab:hover{background:var(--overlay-08);border-color:var(--border-subtle)}.aux-tab[aria-selected=true]{background:var(--overlay-06);border-color:var(--accent-tint-30);color:var(--text-primary)}.aux-tab:focus-visible{outline:0;box-shadow:0 0 0 3px var(--focus-ring)}.aux-panels{padding:.75rem}.aux-panel-body[hidden]{display:none!important}.aux-panel .loadout,.aux-panel .stats{margin-top:0;background:0 0;border-radius:0;padding:0}.loadout-header{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;margin:0 0 .75rem}.loadout-header-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-weight:700}.loadout-current{font-size:.9rem;color:var(--text-secondary);white-space:nowrap}.settings{margin-top:0;background:var(--overlay-05);border-radius:12px;padding:1rem}.settings-list{display:flex;flex-direction:column;gap:1.25rem}.setting-item{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.85rem 0;border-bottom:1px solid var(--border-subtle)}.setting-item:last-child{border-bottom:none}.setting-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.setting-label{font-weight:600;font-size:.95rem;color:var(--text-primary)}.setting-description{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.toggle-switch{position:relative;display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;user-select:none;flex-shrink:0}.toggle-switch input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;display:inline-block;width:52px;height:28px;background:var(--overlay-15);border:1px solid var(--border-default);border-radius:14px;transition:all .25s ease;flex-shrink:0}.toggle-slider::before{content:'';position:absolute;height:20px;width:20px;left:3px;top:3px;background:var(--text-primary);border-radius:50%;transition:transform .25s ease;box-shadow:0 2px 4px var(--shadow-20)}.toggle-switch input:checked+.toggle-slider{background:var(--brand-accent);border-color:var(--brand-accent-hover)}.toggle-switch input:checked+.toggle-slider::before{transform:translateX(24px)}.toggle-switch:hover .toggle-slider{background:var(--overlay-18)}.toggle-switch input:checked:hover+.toggle-slider{background:var(--brand-accent-hover)}.toggle-switch input:focus-visible+.toggle-slider{outline:0;box-shadow:0 0 0 3px var(--focus-ring)}.toggle-labels{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;min-width:70px}.toggle-label-off,.toggle-label-on{transition:opacity .2s ease,color .2s ease}.toggle-switch input:not(:checked)~.toggle-labels .toggle-label-off{color:var(--text-primary);opacity:1}.toggle-switch input:not(:checked)~.toggle-labels .toggle-label-on{color:var(--text-secondary);opacity:.5}.toggle-switch input:checked~.toggle-labels .toggle-label-off{color:var(--text-secondary);opacity:.5}.toggle-switch input:checked~.toggle-labels .toggle-label-on{color:var(--text-primary);opacity:1}@media (max-width:640px){.setting-item{flex-direction:column;align-items:flex-start;gap:.75rem}.toggle-switch{align-self:stretch;justify-content:space-between}}.details details{margin-top:1.5rem;background:var(--overlay-04);border:1px solid var(--border-default);border-radius:12px;padding:.5rem .75rem}.details summary{cursor:pointer;font-weight:600;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.details summary::-webkit-details-marker{display:none}.details summary::after{content:'';width:8px;height:8px;border-right:2px solid var(--text-secondary);border-bottom:2px solid var(--text-secondary);transform:rotate(45deg);transition:transform 260ms ease;flex:0 0 auto}.details details[open] summary::after{transform:rotate(-135deg)}.details-content{display:block;max-height:0;opacity:0;overflow:hidden;padding-top:0;transform:translateY(-4px);transition:max-height 260ms cubic-bezier(.2, 0, 0, 1),opacity 260ms ease,padding-top 260ms ease,transform 260ms ease}@media (prefers-reduced-motion:reduce){.details summary::after{transition:none}.details-content{transition:none;transform:none}}.app-stage{margin-bottom:1.5rem}.stage-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stage-pane{background:var(--overlay-04);border:1px solid var(--border-default);border-radius:12px;padding:.75rem;min-width:0}.stage-title{margin:0 0 .5rem;font-size:1rem;color:var(--text-secondary)}.stage-title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.stage-title-row .stage-title{margin:0}#results-target-select{min-width:120px;padding:.35rem .6rem;border-radius:6px;border:1px solid var(--overlay-25);background:var(--overlay-08);color:var(--text-primary)}#results-target-select option{background-color:var(--brand-surface);color:var(--text-primary)}#results-target-select:focus{outline:0;border-color:var(--brand-accent);box-shadow:0 0 0 3px var(--focus-ring)}.stage-actions{margin-top:.75rem;display:flex;align-items:center;gap:1rem}.stage-actions button{height:32px;padding:.25rem .75rem;display:flex;align-items:center;gap:.5rem}.control-group{display:flex;align-items:center;gap:.5rem}.control-group label{font-weight:600;color:var(--text-light);white-space:nowrap;line-height:1;margin-top:-5px}.control-group input[type=number]{height:32px;width:80px;padding:.25rem .5rem;background-color:var(--input-bg);border:1px solid var(--input-border);border-radius:4px;color:var(--text-light);font-size:.9rem;text-align:center;box-sizing:border-box}.control-group input[type=number]:focus{outline:0;border-color:var(--brand-accent-focus);box-shadow:0 0 0 2px var(--brand-accent-focus-ring)}.stage-actions button{display:flex;align-items:center;gap:.5rem;transition:all .2s ease;font-size:.9rem}.stage-actions button:hover{background:var(--brand-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-tint-30)}.stage-actions button:active{transform:translateY(0)}.stage-actions button svg{flex-shrink:0}#camera-canvas,#left-canvas,#right-canvas{display:block;width:100%;height:auto;aspect-ratio:16/9;border-radius:8px;border:1px solid var(--overlay-15);background:var(--brand-surface);background:var(--brand-surface-gradient);opacity:0;transition:opacity .2s ease-in}#camera-canvas.has-content,#left-canvas.has-content,#right-canvas.has-content{opacity:1}@media (max-width:820px){.stage-grid{grid-template-columns:1fr}}.stage-header-tabs{display:flex;align-items:flex-end;gap:.5rem;border-bottom:1px solid var(--border-default)}.stage-header-tabs .stage-title{flex-shrink:0;align-self:flex-start}.tab-bar{display:flex;flex:1;min-width:0;align-items:center}.tab-list{display:flex;flex:1;min-width:0;list-style:none;margin:0;padding:0;overflow-x:auto;overflow-y:hidden;mask-image:linear-gradient(to right,black calc(100% - 40px),transparent 100%)}.tab{display:flex;align-items:center;gap:.25rem;padding:.5rem .5rem;position:relative;background:var(--overlay-04);border:1px solid var(--border-default);border-bottom:none;border-radius:8px 8px 0 0;margin-right:-1px;cursor:pointer;transition:all .2s ease,flex-grow .15s ease-out;flex:1 1 0;max-width:220px}.tab:not(.active):hover{background:var(--overlay-10);z-index:1}.tab.active{background:var(--brand-bg-darker);border-bottom-color:var(--brand-bg-darker);z-index:2;font-weight:600}.tab-title{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tab-title[contenteditable=true]{background:var(--overlay-10);border-radius:4px;outline:2px solid var(--brand-accent);cursor:text}.tab-close{background:0 0;border:none;padding:0;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;opacity:.7;flex-shrink:0;display:none}.tab.active{min-width:40px}.tab.active .tab-close{display:flex}.tab-close:hover{background:var(--overlay-16);opacity:1}.tab-close svg{width:14px;height:14px;stroke:currentColor}.tab-add{background:0 0;border:none;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px;margin-left:.25rem;cursor:pointer;flex-shrink:0}.tab-add:hover{background:var(--overlay-15)}.tab-add svg{stroke:currentColor}#right-canvas{margin-top:-1px;border-top:none;border-top-left-radius:0;border-top-right-radius:0}#left-canvas{cursor:zoom-in}.canvas-modal-backdrop{position:fixed;inset:0;background:var(--backdrop-dim);z-index:999;opacity:0;transition:opacity .3s ease}.canvas-modal-backdrop.backdrop-visible{opacity:1}#left-canvas.canvas-fullscreen{cursor:zoom-out;box-shadow:0 10px 30px var(--shadow-50)}.tab-list::-webkit-scrollbar{height:6px}.tab-list::-webkit-scrollbar-track{background:0 0;margin:0 4px}.tab-list::-webkit-scrollbar-thumb{background-color:var(--overlay-25);border-radius:3px}.tab-list::-webkit-scrollbar-thumb:hover{background-color:var(--overlay-40)}.tab-list.no-grow .tab{flex-grow:0}