:root{--background-color: #f5f5f7;--surface-color: #ffffff;--surface-elevated-color: #ffffff;--primary-text-color: #111827;--secondary-text-color: #6b7280;--muted-text-color: #9ca3af;--accent-color: #007aff;--accent-color-hover: #0060d0;--accent-soft: rgba(0, 122, 255, .08);--drag-insert-color: #0a84ff;--drag-insert-glow: rgba(10, 132, 255, .22);--train-color: #007aff;--train-soft: rgba(0, 122, 255, .12);--eval-color: #34c759;--eval-soft: rgba(52, 199, 89, .12);--border-color: #d1d5db;--border-subtle: rgba(209, 213, 219, .9);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--resize-bar-thickness: 10px;--shadow-soft: 0 18px 45px rgba(15, 23, 42, .08);--shadow-subtle: 0 10px 30px rgba(15, 23, 42, .06);--shadow-color: rgba(0, 0, 0, .12);--transition-speed: .16s ease-out;--font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, Helvetica, Arial, sans-serif}body.dark-mode{--background-color: #0a0a0a;--surface-color: #141414;--surface-elevated-color: #1b1b1b;--primary-text-color: #f5f5f5;--secondary-text-color: #d4d4d4;--muted-text-color: #a3a3a3;--accent-color: #3b82f6;--accent-color-hover: #2563eb;--accent-soft: rgba(59, 130, 246, .15);--drag-insert-color: #60a5fa;--drag-insert-glow: rgba(96, 165, 250, .26);--train-color: #3b82f6;--train-soft: rgba(59, 130, 246, .18);--eval-color: #10b981;--eval-soft: rgba(16, 185, 129, .18);--border-color: #404040;--border-subtle: rgba(64, 64, 64, .6);--shadow-soft: 0 18px 45px rgba(0, 0, 0, .6);--shadow-subtle: 0 10px 30px rgba(0, 0, 0, .4);--shadow-color: rgba(0, 0, 0, .7)}html,body{margin:0;padding:0;font-family:var(--font-family);background:var(--background-color);color:var(--primary-text-color);height:100%;overflow:hidden;transition:background-color .3s ease,color .3s ease}body:not(.dark-mode){background:radial-gradient(circle at top,#e5e7eb 0,#f9fafb 55%)}body.dark-mode{background:radial-gradient(circle at top,#0a0a0a 0,#1a1a1a 55%)}.container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.25rem;background:linear-gradient(135deg,#f9fafbeb,#f3f4f6eb);border-bottom:1px solid var(--border-subtle);box-shadow:var(--shadow-subtle);z-index:1000}.header-controls-left{display:flex;align-items:center;gap:.75rem;flex-wrap:nowrap}body.dark-mode .app-header{background:linear-gradient(135deg,#1a1a1ae0,#0a0a0ae0)}.branding-text{color:var(--primary-text-color);font-weight:600;font-size:.9rem}.branding-text-w{color:#16a34a}.branding-text-l{color:#dc2626}.header-status-bar{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;width:fit-content;max-width:80vw;box-sizing:border-box;font-size:.78rem;font-weight:600;padding:4px 12px;border-radius:20px;opacity:0;transition:opacity .2s ease;pointer-events:none;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.header-status-bar.visible{opacity:1;pointer-events:auto;cursor:pointer}.header-status-bar.status-error{background:#ef44441f;border:1px solid rgba(239,68,68,.35);color:#ef4444}.header-status-bar.status-pending{background:#d977061a;border:1px solid rgba(217,119,6,.3);color:#d97706}.header-status-bar.status-success{background:#22c55e1f;border:1px solid rgba(34,197,94,.35);color:#22c55e}.logo-link{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--primary-text-color);font-weight:600;font-size:.9rem;border-radius:var(--radius-md);transition:background-color var(--transition-speed),opacity var(--transition-speed)}.logo-link:hover{background-color:#0000000a;opacity:.9}body.dark-mode .logo-link:hover{background-color:#ffffff14}.logo-img{height:32px;width:auto;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.workspace-row{display:flex;align-items:flex-start;gap:.5rem;padding:0 .75rem .75rem;background:var(--background-color);flex:1;overflow-y:scroll;overflow-x:hidden;position:relative}.main-area{flex:1 1 auto;display:flex;flex-direction:column;gap:.2rem;background:var(--background-color)}.main-content{flex:1 1 auto;display:flex;flex-direction:column;gap:.2rem;background:var(--background-color);overflow-x:hidden;overflow-y:auto;min-height:calc(100vh - 220px);padding-bottom:.75rem;padding-right:.75rem;margin-right:-.75rem;padding-left:.75rem;margin-left:-.75rem}*{scrollbar-width:none;scrollbar-color:transparent transparent;-ms-overflow-style:none}*::-webkit-scrollbar{width:0;height:0;display:none}.main-section-insert-line,.signal-card-insert-line,.inspector-card-insert-line{height:3px;margin:4px 0;border-radius:999px;background:linear-gradient(90deg,color-mix(in srgb,var(--accent-color) 94%,white 6%),color-mix(in srgb,var(--accent-color) 72%,white 28%),color-mix(in srgb,var(--accent-color) 94%,white 6%));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 30%,transparent),0 0 12px color-mix(in srgb,var(--accent-color) 42%,transparent);pointer-events:none}.signals-board .signal-card-insert-line,.inspector-container .inspector-card-insert-line{width:100%;flex:0 0 auto;display:block;position:relative;z-index:9;height:4px;margin:8px 0;background:linear-gradient(90deg,color-mix(in srgb,var(--accent-color) 96%,white 4%),color-mix(in srgb,var(--accent-color) 74%,white 26%),color-mix(in srgb,var(--accent-color) 96%,white 4%));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 40%,transparent),0 0 14px color-mix(in srgb,var(--accent-color) 50%,transparent)}.signals-board.is-card-dnd-active .signal-card-insert-line{height:4px;margin:6px 0;z-index:7;position:relative;background:linear-gradient(90deg,color-mix(in srgb,var(--accent-color) 98%,white 2%),color-mix(in srgb,var(--accent-color) 78%,white 22%),color-mix(in srgb,var(--accent-color) 98%,white 2%));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 48%,transparent),0 0 18px color-mix(in srgb,var(--accent-color) 58%,transparent)}.inspector-container.is-left-panel-dnd-active .inspector-card-insert-line{height:4px;margin:6px 0;z-index:10;position:relative;background:linear-gradient(90deg,color-mix(in srgb,var(--accent-color) 98%,white 2%),color-mix(in srgb,var(--accent-color) 78%,white 22%),color-mix(in srgb,var(--accent-color) 98%,white 2%));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 48%,transparent),0 0 18px color-mix(in srgb,var(--accent-color) 58%,transparent)}.signals-board.is-card-dnd-active .inspector-panel-splitter.signal-card-splitter{opacity:.3}.signals-board.is-card-dnd-active .inspector-panel-splitter.signal-card-splitter,.inspector-container.is-left-panel-dnd-active .inspector-panel-splitter{pointer-events:none}.signals-board.is-card-dnd-active .inspector-panel-splitter.signal-card-splitter:before,.inspector-container.is-left-panel-dnd-active .inspector-panel-splitter:before{animation:none!important;background:linear-gradient(90deg,transparent 0%,var(--border-color) 50%,transparent 100%);opacity:.22}.plots-board-title[draggable=true],.grid-wrapper-title[draggable=true],.signal-card-title[draggable=true],.inspector-title[draggable=true]{cursor:grab}.plots-board-title.is-dragging,.grid-wrapper-title.is-dragging,.signal-card.is-dragging .signal-card-title,.card.is-dragging .inspector-title{cursor:grabbing;opacity:.72}@keyframes drag-insert-pulse{0%{transform:scaleX(.9);opacity:.7;background-position:100% 50%}to{transform:scaleX(1.03);opacity:1;background-position:0% 50%}}*::-webkit-scrollbar-button{width:0;height:0;display:none}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-track-piece{background:transparent}*::-webkit-scrollbar-corner{background:transparent}*::-webkit-scrollbar-thumb{background:transparent;border-radius:99px}.inspector-container.open.lowered{scrollbar-gutter:auto}.agent-header{position:sticky;display:flex;flex-direction:column;width:calc(100% + 1.5rem);margin:0 -.75rem;padding:0 .75rem .75rem;top:0;z-index:10;background:var(--background-color);flex-shrink:0;box-sizing:border-box}.signals-board{display:flex;flex-direction:column;gap:.75rem;width:100%;margin:.25rem 0 .35rem;flex:0 0 auto;overflow-x:hidden;overflow-y:auto}.signals-board.plots-board-empty{display:flex!important;min-height:0;padding-bottom:0}.signals-board.plots-board-empty .plots-board-header{margin-bottom:0}.plots-board-header,.grid-wrapper-header{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;position:sticky;top:8px;z-index:25;padding:.35rem .45rem;min-height:30px;background:color-mix(in srgb,var(--surface-color) 90%,transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-bottom:1px solid var(--border-subtle);margin-bottom:.75rem;border-radius:8px}.plots-board-header{justify-content:flex-start;margin-bottom:0}.plots-board-title{font-size:.92rem;font-weight:600;letter-spacing:.02em;color:var(--primary-text-color);display:flex;align-items:center;gap:8px}.plots-board-title[draggable=true],.grid-wrapper-title[draggable=true],.signal-card-title[draggable=true]{cursor:grab}.plots-board-title[draggable=true]:active,.grid-wrapper-title[draggable=true]:active,.signal-card-title[draggable=true]:active{cursor:grabbing}.plots-board-title,.grid-wrapper-title,.signal-card-title,.inspector-title{position:relative}.signals-board.plots-board-collapsed{overflow:hidden}.signals-board.plots-board-collapsed>.plots-board-header .collapse-btn,.signals-board.plots-board-collapsed>.plots-board-header .plots-board-title{transition:none!important}.signals-board.plots-board-collapsed>.plots-board-header .collapse-btn:hover{transform:none}.signals-board.plots-board-collapsed>.plots-board-header [data-hover-hint]:hover:after,.signals-board.plots-board-collapsed>.plots-board-header [data-hover-hint]:focus-visible:after{content:none}.signals-board.plots-board-collapsed>.signal-card,.signals-board.plots-board-collapsed>.inspector-panel-splitter.signal-card-splitter{display:none}.main-vertical-resize-handle{width:100%;height:var(--resize-bar-thickness);display:flex;align-items:center;justify-content:center;gap:5px;cursor:ns-resize;-webkit-user-select:none;user-select:none;border-radius:8px;transition:background-color .2s ease;margin:2px 0 6px}#plots-board-resize-handle,#grid-height-resize-handle{margin:0;flex:0 0 var(--resize-bar-thickness);height:var(--resize-bar-thickness);opacity:1;background:transparent;border-radius:0;gap:0;cursor:ns-resize;position:relative}#plots-board-resize-handle.plots-board-handle-hidden{display:none!important}.signals-board.plots-board-collapsed:not(.plots-board-empty)+#plots-board-resize-handle{display:none!important}#plots-board-resize-handle:before,#grid-height-resize-handle:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,var(--border-color) 50%,transparent 100%);clip-path:polygon(0 50%,8% 42%,20% 30%,50% 12%,80% 30%,92% 42%,100% 50%,92% 58%,80% 70%,50% 88%,20% 70%,8% 58%)}#plots-board-resize-handle:hover:before,#plots-board-resize-handle.dragging:before,#grid-height-resize-handle:hover:before,#grid-height-resize-handle.dragging:before{background:linear-gradient(90deg,transparent 0%,var(--accent-color) 50%,transparent 100%);animation:splitter-heartbeat 1s ease-in-out infinite;box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 42%,transparent),0 0 20px color-mix(in srgb,var(--accent-color) 60%,transparent)}#plots-board-resize-handle.dragging:before,#grid-height-resize-handle.dragging:before{box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 48%,transparent),0 0 24px color-mix(in srgb,var(--accent-color) 68%,transparent)}#plots-board-resize-handle span,#grid-height-resize-handle span{display:none}body.resizing-main-vertical{cursor:ns-resize!important;-webkit-user-select:none!important;user-select:none!important}body.resizing-main-vertical *{cursor:ns-resize!important}body.dark-mode .main-vertical-resize-handle:hover,body.dark-mode .main-vertical-resize-handle.dragging{background:#ffffff14}.signal-card{background:var(--surface-elevated-color);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-subtle);padding:.75rem;display:flex;flex-direction:column;flex:0 0 auto;position:relative;overflow:hidden}body.dark-mode .signal-card{border-color:var(--border-color)}.signal-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.35rem;min-height:36px}.signal-card-title{font-weight:700;font-size:.95rem;margin:0;cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity var(--transition-speed)}.signal-card-title:hover{opacity:.7}.signal-card-subtitle{color:var(--muted-text-color);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;margin:0}.signal-card-controls{display:flex;gap:.4rem;flex-wrap:nowrap;flex-shrink:0}.signal-card-controls .signal-btn-small:last-child{margin-left:auto}.signal-btn-small{padding:4px 10px;font-size:.8rem;font-weight:600;border:1px solid var(--border-subtle);background:var(--surface-color);color:var(--primary-text-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-speed);display:inline-flex;align-items:center;justify-content:center}.signal-btn-small:hover{filter:brightness(.96);transform:translateY(-1px);background:var(--accent-soft);border-color:var(--accent-color)}.signal-color-picker{width:20px;height:20px;min-width:20px;min-height:20px;border:1px solid var(--border-subtle);border-radius:50%;cursor:pointer;padding:0;background:#fff}.signal-color-picker:hover{border-color:var(--accent-color);box-shadow:0 0 0 2px #0000001a}.signal-card canvas{width:100%!important;height:100%!important;max-width:100%!important;max-height:100%!important;display:block}.signal-card-resize-handle{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;background:transparent;transition:background-color .2s ease;z-index:100;display:none;pointer-events:none}.signal-card-resize-handle:hover{background:var(--accent-color, #007aff);opacity:.5}.grid-wrapper{position:relative;width:100%;flex:1;overflow-y:hidden;overflow-x:hidden;display:flex;flex-direction:column;height:100%}.grid-wrapper-title{font-size:.92rem;font-weight:600;letter-spacing:.02em;color:var(--primary-text-color);display:flex;align-items:center;gap:8px;padding:0}#grid-settings-toggle.icon-btn{padding:0;width:20px;height:20px;border-radius:50%;position:relative;background:#0000000d;border:none;box-shadow:none;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:var(--secondary-text-color);opacity:1}#grid-settings-toggle.icon-btn .btn-label{display:none}#grid-settings-toggle.icon-btn:hover{background:#0000001a;color:var(--primary-text-color);box-shadow:none}body.dark-mode #grid-settings-toggle.icon-btn{background:#ffffff14;color:var(--secondary-text-color);border:none}body.dark-mode #grid-settings-toggle.icon-btn:hover{background:#ffffff26;color:var(--primary-text-color)}#grid-settings-toggle.active{background:var(--accent-soft);color:var(--accent-color);box-shadow:none}body.dark-mode #grid-settings-toggle.active{background:#3b82f633;color:var(--accent-color);box-shadow:none}.view-controls{display:flex;flex-direction:column;gap:1rem;padding:0;width:100%}.view-controls .control-group{display:flex;align-items:center;justify-content:space-between;width:100%}.view-controls .control-group>label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-text-color);font-weight:500;font-family:inherit}.view-controls input[type=number]{height:28px;font-size:.85rem;padding:4px 10px;width:72px;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-sm);background:#fff9;color:var(--text-color);font-weight:500;text-align:center;transition:all .15s ease}.view-controls input[type=number]:hover{border-color:#0000001f;background:#fffc}.view-controls input[type=number]:focus{outline:none;border-color:var(--accent-color);background:#fff;box-shadow:0 0 0 3px #3b82f61a}body.dark-mode .view-controls input[type=number]{background:#ffffff0d;border-color:#ffffff1a}body.dark-mode .view-controls input[type=number]:hover{background:#ffffff14;border-color:#ffffff26}.view-controls select{height:28px;font-size:.85rem;padding:4px 28px 4px 10px;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-sm);background:#fff9;color:var(--text-color);font-weight:500;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23666' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:all .15s ease}.view-controls select:hover{border-color:#0000001f;background-color:#fffc}.view-controls select:focus{outline:none;border-color:var(--accent-color);background-color:#fff;box-shadow:0 0 0 3px #3b82f61a}body.dark-mode .view-controls select{background-color:#ffffff0d;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23aaa' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");border-color:#ffffff1a}body.dark-mode .view-controls select:hover{background-color:#ffffff14;border-color:#ffffff26}.resolution-group{flex-direction:column;align-items:flex-start!important;gap:8px;background:transparent;padding:0;border-radius:0}body.dark-mode .resolution-group{background:transparent}.res-row-header label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-text-color);font-weight:500;font-family:inherit;margin-bottom:4px}.res-row-controls{display:flex;align-items:center;width:100%;gap:12px;padding:2px 0}.auto-checkbox{display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.auto-checkbox input{display:none}.auto-checkbox .checkmark{width:16px;height:16px;border:1.5px solid var(--border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;background:var(--surface-color);transition:all .2s ease}.auto-checkbox input:checked~.checkmark{background:var(--accent-color);border-color:var(--accent-color)}.auto-checkbox input:checked~.checkmark:after{content:"";width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg) translate(-1px,-1px)}.auto-checkbox .label-text{font-size:.85rem;color:var(--secondary-text-color)}.auto-checkbox input:checked~.label-text{color:var(--accent-color);font-weight:500}.resolution-group .slider-wrapper{flex-grow:1;display:flex;align-items:center}.resolution-group input[type=range]{width:100%;height:3px;margin:0;cursor:pointer;-webkit-appearance:none;appearance:none;background:transparent;outline:none}.resolution-group input[type=range]::-webkit-slider-runnable-track{width:100%;height:3px;background:linear-gradient(to right,#00000014,#0000001f);border-radius:2px}.resolution-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:#fff;border:2px solid rgba(0,0,0,.2);border-radius:50%;cursor:pointer;margin-top:-5.5px;box-shadow:0 1px 3px #00000026;transition:all .15s ease}.resolution-group input[type=range]::-webkit-slider-thumb:hover{border-color:var(--accent-color);box-shadow:0 2px 6px #0003,0 0 0 4px #3b82f61a}.resolution-group input[type=range]::-moz-range-track{width:100%;height:3px;background:linear-gradient(to right,#00000014,#0000001f);border-radius:2px}.resolution-group input[type=range]::-moz-range-thumb{width:14px;height:14px;background:#fff;border:2px solid rgba(0,0,0,.2);border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #00000026;transition:all .15s ease}.resolution-group input[type=range]::-moz-range-thumb:hover{border-color:var(--accent-color);box-shadow:0 2px 6px #0003,0 0 0 4px #3b82f61a}body.dark-mode .resolution-group input[type=range]::-webkit-slider-runnable-track{background:linear-gradient(to right,#ffffff14,#ffffff1f)}body.dark-mode .resolution-group input[type=range]::-webkit-slider-thumb{background:#fffffff2;border-color:#ffffff4d}body.dark-mode .resolution-group input[type=range]::-moz-range-track{background:linear-gradient(to right,#ffffff14,#ffffff1f)}body.dark-mode .resolution-group input[type=range]::-moz-range-thumb{background:#fffffff2;border-color:#ffffff4d}.res-value{font-size:.8rem;font-weight:500;color:var(--secondary-text-color);text-align:right;min-width:38px;font-variant-numeric:tabular-nums;font-family:inherit}.grid-settings-overlay{position:absolute;top:calc(100% + 6px);right:0;left:auto;width:260px;margin:0;background:#fffffffa;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);z-index:1000;padding:.55rem .65rem;transition:all .2s cubic-bezier(.34,1.3,.64,1);display:flex;flex-direction:column;gap:.4rem;border-radius:12px;box-shadow:0 8px 28px #00000024;border:1px solid rgba(0,0,0,.08);height:auto;opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.grid-settings-overlay.grid-settings-overlay-floating{position:fixed;inset:0 auto auto 0}.grid-settings-overlay.open-upward{top:auto;bottom:calc(100% + 6px)}.grid-settings-overlay .view-controls{display:flex;flex-direction:column;gap:.35rem}.grid-settings-overlay .control-group.resolution-group{display:flex;flex-direction:column;gap:2px}.grid-settings-overlay .res-row-header label{font-size:.7rem;font-weight:600;color:var(--secondary-text-color);text-transform:uppercase;letter-spacing:.03em}.grid-settings-overlay .res-row-controls{display:flex;align-items:center;gap:6px}.grid-settings-overlay .slider-wrapper{flex:1 1 auto;min-width:0}.grid-settings-overlay .slider-wrapper input[type=range]{width:100%}.grid-settings-overlay .res-value{font-size:.72rem;min-width:36px;text-align:right;color:var(--secondary-text-color);font-weight:600}.grid-settings-overlay .res-value-input{width:34px;border:1px solid rgba(0,0,0,.12);border-radius:5px;background:#0000000a;padding:1px 3px;font-size:.72rem;text-align:right;outline:none;appearance:textfield;-moz-appearance:textfield}.grid-settings-overlay .res-value-input::-webkit-inner-spin-button,.grid-settings-overlay .res-value-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.grid-settings-overlay .res-value-input:focus{border-color:var(--accent-color);background:#ffffffe6}.grid-settings-overlay .control-button.primary{width:100%;margin-top:4px;padding:.3rem .5rem;font-size:.75rem;border-radius:8px}.grid-settings-overlay.collapsed{opacity:0;pointer-events:none;transform:translateY(-8px) scale(.96)}.grid-settings-overlay.open-upward.collapsed{transform:translateY(8px) scale(.96)}#details-body{position:relative;display:flex;flex-direction:column}body.dark-mode .grid-settings-overlay{background:#232323eb;border-color:#ffffff1f;box-shadow:0 8px 32px #00000080}@media(max-width:1100px){.workspace-row{flex-direction:column;padding-left:1.25rem}#cells-grid{max-width:100%;margin-left:0;margin-right:0}}.color-inputs{display:flex;align-items:center;gap:.75rem}.color-picker-wrapper{display:flex;align-items:center;gap:.5rem}.split-colors .row{display:flex;flex-direction:column;gap:12px;align-items:flex-start}.split-colors .row-label{padding-top:0;font-weight:600;color:var(--primary-text-color);margin-bottom:-4px}.split-colors .row-controls{display:flex!important;flex-direction:column!important;gap:12px;width:100%}.color-picker-wrapper{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.color-picker-wrapper label,.color-picker-wrapper .chip{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary-text-color);font-weight:500;flex-shrink:0;min-width:50px}.color-picker{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:26px;height:26px;background-color:transparent;border-radius:999px;border:1.5px solid var(--border-color);cursor:pointer;padding:0;overflow:hidden;transition:border-color var(--transition-speed),box-shadow var(--transition-speed),transform var(--transition-speed)}.color-picker::-webkit-color-swatch-wrapper{padding:0;border-radius:999px}.color-picker::-webkit-color-swatch,.color-picker::-moz-color-swatch{border-radius:999px;border:none}input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none!important;padding:0!important;cursor:pointer}input[type=color]::-webkit-color-swatch-wrapper{padding:0;border-radius:50%}input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}input[type=color]::-moz-color-swatch{border:none;border-radius:50%}.color-picker:hover{transform:translateY(-1px);border-color:var(--accent-color);box-shadow:0 10px 24px #0f172a24}.control-group{display:flex;align-items:center;gap:.5rem}.control-group label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-text-color);white-space:nowrap}.options-button{background:transparent;border:1px solid transparent;color:var(--secondary-text-color);font-size:1.3rem;cursor:pointer;padding:0;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:background-color var(--transition-speed),border-color var(--transition-speed),color var(--transition-speed),transform var(--transition-speed)}.options-button:hover{color:var(--primary-text-color);border-color:var(--border-subtle);background-color:#007aff0f;transform:translateY(-1px)}#toggle-training{background:#ffffffd9;border-radius:999px;padding:.5rem 1.1rem;font-size:.85rem;font-weight:600;border:1px solid var(--border-subtle);cursor:pointer;color:var(--secondary-text-color);transition:background-color var(--transition-speed),color var(--transition-speed),border-color var(--transition-speed),box-shadow var(--transition-speed),transform var(--transition-speed)}#toggle-training.running{background:#fef2f2e6;color:#b91c1c;border-color:#fecacaf2}#toggle-training.paused{background:#ecfdf5e6;color:#15803d;border-color:#bbf7d0f2}#toggle-training.pending{background:#fef3c7e6;color:#b45309;border-color:#fde68af2}#toggle-training:disabled{cursor:not-allowed;opacity:.7}#toggle-training.sandbox-disabled,.training-controls #toggle-training.sandbox-disabled,.training-mode-trigger.sandbox-disabled,#toggle-auditor.sandbox-disabled,#manual-data-save-btn.sandbox-disabled{background:#e5e7ebeb!important;color:#6b7280!important;border-color:#d1d5dbf2!important;box-shadow:none!important;cursor:not-allowed!important;opacity:1!important}.training-mode-trigger.sandbox-disabled{border-left-color:#9ca3af73!important}#toggle-training:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px #0f172a24}.control-group input[type=number],.control-group select{background-color:#ffffffd9;color:#1f2937;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:.45rem .75rem;font-size:.9rem;width:45px;height:15px;text-align:center;transition:border-color var(--transition-speed),box-shadow var(--transition-speed),background-color var(--transition-speed);-webkit-appearance:none;appearance:none}#zoom-level{width:80px;min-width:80px;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1em 1em;padding-right:1.75rem}#cell-size{width:70px;min-width:70px;height:36px;padding:.45rem .75rem;box-sizing:border-box}#image-magnification{width:80px;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.1em 1.1em;padding-right:1.9rem;text-align-last:center}.control-group input[type=number]:focus,.control-group select:focus{outline:none;border-color:#007affa6;box-shadow:0 0 0 4px #007aff1f;background-color:#ffffffeb}body.dark-mode .control-group input[type=number],body.dark-mode .control-group select,body.dark-mode #cell-size,body.dark-mode #zoom-level{background-color:#ffffff14!important;color:var(--primary-text-color)!important;border-color:var(--border-subtle)}body.dark-mode .control-group input[type=number]:focus,body.dark-mode .control-group select:focus,body.dark-mode #cell-size:focus,body.dark-mode #zoom-level:focus{background-color:#ffffff24!important;color:var(--primary-text-color)!important;border-color:#3b82f6a6}[data-section=segmentation],body.classification-mode [data-section=segmentation]{display:none}body.segmentation-mode [data-section=segmentation]{display:block}.slider-container{display:flex;align-items:center;gap:1rem;flex-grow:1;min-width:300px}.slider-label-group{display:flex;flex-direction:row;align-items:center;justify-content:center;min-width:60px}.slider-label-group.left{text-align:left}.slider-label-group.right{text-align:right;gap:10px;padding-left:.75rem}.batch-index-label{font-size:.85rem;font-weight:600;color:var(--primary-text-color);letter-spacing:-.01em;line-height:1;position:relative;top:1px}.stat-column{display:flex;flex-direction:column;gap:2px;align-items:flex-end}.stat-row{display:flex;align-items:center;gap:6px;line-height:1.2}.stat-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-text-color)}.stat-count.primary{font-size:.9rem;font-weight:700;color:var(--primary-text-color)}.stat-count.secondary{font-size:.75rem;font-weight:600;color:var(--secondary-text-color);opacity:.7}.active-row .stat-label{color:var(--muted-text-color);opacity:.6}.active-row .stat-count.secondary{color:var(--secondary-text-color);font-size:.75rem}.slider-wrapper{position:relative;width:100%;z-index:1}.slider{-webkit-appearance:none;appearance:none;margin:0;width:100%;height:4px;background:linear-gradient(90deg,#007aff2e,#d1d5db);border-radius:999px;outline:none;cursor:pointer;transition:box-shadow var(--transition-speed),background var(--transition-speed)}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#fffffff5;border-radius:50%;border:2px solid rgba(0,122,255,.8);cursor:pointer;box-shadow:0 0 0 3px #007aff38;transition:transform var(--transition-speed),box-shadow var(--transition-speed),border-color var(--transition-speed),background-color var(--transition-speed)}.slider::-moz-range-thumb{width:16px;height:16px;background:#fffffff5;border-radius:50%;border:2px solid rgba(0,122,255,.8);cursor:pointer;box-shadow:0 0 0 3px #007aff38;transition:transform var(--transition-speed),box-shadow var(--transition-speed),border-color var(--transition-speed),background-color var(--transition-speed)}.slider:hover::-webkit-slider-thumb,.slider:hover::-moz-range-thumb{transform:scale(1.05);box-shadow:0 0 0 4px #007aff52}#slider-tooltip{position:absolute;bottom:26px;transform:translate(-50%);background-color:#ffffffeb;color:var(--primary-text-color);padding:3px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;white-space:nowrap;pointer-events:none;opacity:0;border:1px solid var(--border-subtle);box-shadow:0 8px 18px #0f172a1f;transition:opacity var(--transition-speed);z-index:2}body.dark-mode #slider-tooltip{background-color:#1f2937f2;border-color:#6b728066;box-shadow:0 8px 18px #00000059}.slider-wrapper .slider:hover+#slider-tooltip,.slider-wrapper .slider:focus-visible+#slider-tooltip{opacity:1}.bottom-bar{position:sticky;bottom:0;display:flex;justify-content:center;align-items:center;padding:.4rem 1rem;background:linear-gradient(135deg,#f9fafbf0,#f3f4f6f0);border-top:1px solid var(--border-subtle);box-shadow:0 -2px 8px #0000000d;z-index:20;flex-shrink:0}body.dark-mode .bottom-bar{background:linear-gradient(135deg,#1a1a1ae0,#0a0a0ae0)}.bottom-bar .slider-container{width:100%}.info-group{color:var(--secondary-text-color);font-size:.9rem}.chat-input-container{display:flex;align-items:center;gap:.75rem;width:calc(100% + 1.5rem);margin:0 -.75rem;padding:0 .75rem;box-sizing:border-box}#chat-input{flex-grow:1;background-color:#ffffffd9;color:#1f2937;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:.9rem;transition:border-color var(--transition-speed),box-shadow var(--transition-speed),background-color var(--transition-speed)}#chat-input:focus{outline:none;border-color:#007affa6;box-shadow:0 0 0 4px #007aff1f;background-color:#ffffffeb}body.dark-mode #chat-input{background-color:#ffffff14!important;color:var(--primary-text-color)!important;border-color:var(--border-subtle)}body.dark-mode #chat-input:focus{background-color:#ffffff24!important;color:var(--primary-text-color)!important}#chat-send{background:linear-gradient(135deg,var(--accent-color),var(--accent-color-hover));color:#fff;border:none;border-radius:50%;width:36px;height:36px;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #007aff59;transition:transform var(--transition-speed),box-shadow var(--transition-speed),background var(--transition-speed);flex-shrink:0}#chat-send .send-icon{display:block}#chat-send .loading-spinner{display:none;animation:spin 1s linear infinite}#chat-send:hover{transform:scale(1.05);box-shadow:0 6px 18px #007aff73}#chat-send:active{transform:scale(.95)}#chat-send.loading{cursor:pointer;pointer-events:auto}#chat-send.loading:hover{background:#dc2626;box-shadow:0 4px 12px #dc262666}#chat-send.loading .send-icon{display:none}#chat-send.loading .loading-spinner{display:block}#chat-send:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:0 2px 6px #007aff33}#chat-send:disabled:hover{transform:none;box-shadow:0 2px 6px #007aff33}#toggle-history{background:#007aff14;color:var(--accent-color);border:1px solid rgba(0,122,255,.2);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:1.1rem;cursor:pointer;height:34px;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition-speed);margin-left:.5rem}#toggle-history:hover{background:#007aff1f;border-color:#007aff4d;transform:translateY(-1px)}#toggle-history.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 4px 12px #007aff40}body.dark-mode #toggle-history{background:#007aff1f;border-color:#007aff40;color:var(--accent-color)}body.dark-mode #toggle-history.active{background:var(--accent-color);color:#fff}#cells-grid{display:grid;position:relative;gap:4px;width:100%;margin:0;padding:4px;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-sizing:border-box;background:radial-gradient(circle at top,#e5e7ebd9,#f9fafbd9);justify-content:center;align-content:start;justify-items:stretch}.grid-content{display:block;min-height:100vh;background:var(--background-color)}body.dark-mode #cells-grid{background:radial-gradient(circle at top,#1a1a1ad9,#0a0a0ad9);border-color:var(--border-subtle)}.cell{background-color:var(--surface-color);border-radius:0;border:1px solid rgba(148,163,184,.35);box-sizing:border-box;overflow:hidden;position:relative;box-shadow:0 1px #0f172a0a;transition:border-color .14s ease;content-visibility:auto;contain:layout style paint}.cell:hover{border-color:#94a3b88c}.cell.discarded{opacity:.55;filter:grayscale(85%)}.cell.discarded:before{content:"";position:absolute;inset:0;background-color:#f871712e;pointer-events:none;z-index:3}.cell.discarded img{filter:grayscale(100%)}.cell.selected:after{content:"";position:absolute;inset:0;border-radius:inherit;border:6px solid rgba(0,122,255,.9);background:radial-gradient(circle,rgba(0,122,255,.2),transparent 55%);pointer-events:none;z-index:5;box-shadow:0 0 0 4px #007aff33}.cell.train.selected:after{border-color:var(--train-color);background:radial-gradient(circle,var(--train-soft),transparent 55%);box-shadow:0 0 0 4px #007aff1f}.cell.eval.selected:after{border-color:var(--eval-color);background:radial-gradient(circle,var(--eval-soft),transparent 55%);box-shadow:0 0 0 4px #34c75929}.cell.discarded.selected:after{border-color:#dc2626;background:radial-gradient(circle,rgba(248,113,113,.2),transparent 55%)}.cell .cell-label{position:absolute;bottom:0;left:0;width:100%;box-sizing:border-box;background:linear-gradient(to top,#ffffffeb,#ffffff40);color:var(--primary-text-color);padding:5px 6px;font-size:.72rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.cell.train .cell-label{background:linear-gradient(to top,#007aff24,#fff9)}.cell.eval .cell-label{background:linear-gradient(to top,#34c75929,#fff9)}.cell .cell-label:empty{display:none}body.dark-mode .cell .cell-label{background:linear-gradient(to top,#000000a6,#00000014);color:var(--primary-text-color)}.toggle-button{position:relative;width:40px;height:40px;border:1px solid var(--border-subtle);background-color:#ffffffc7;border-radius:14px;font-size:20px;font-weight:700;cursor:pointer;transition:transform var(--transition-speed),box-shadow var(--transition-speed),border-color var(--transition-speed),background-color var(--transition-speed);padding:0;display:flex;align-items:center;justify-content:center;color:var(--secondary-text-color)}#dark-mode-toggle{border-radius:50%;width:36px;height:36px}.toggle-button:hover{background-color:#ffffffe6;border-color:#007aff59;box-shadow:0 12px 30px #0f172a24;transform:translateY(-1px)}.toggle-button.expanded{color:#dc2626}.toggle-button.collapsed{color:#16a34a}body.dark-mode .toggle-button{background-color:#1a1a1ab8;border-color:var(--border-subtle)}body.dark-mode .toggle-button:hover{background-color:#1a1a1ae6}.options-panel{display:flex;flex-direction:column;gap:12px;padding:.75rem 1rem;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-subtle);box-sizing:border-box;width:"auto";height:"auto";max-width:100%;flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;padding-right:calc(1rem + 4px)}.inspector-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:10px;border-bottom:1px solid var(--border-subtle);min-height:28px;position:relative}.inspector-header-actions{display:flex;align-items:center;gap:4px;position:relative}.icon-btn{background:transparent;border:none;color:var(--secondary-text-color);cursor:pointer;padding:6px;display:flex;align-items:center;gap:6px}.split-colors .row-controls{flex-direction:column;gap:8px;align-items:flex-start}.row-controls.list{max-height:"auto"}.help{font-size:.8rem;color:var(--muted-text-color);margin-bottom:6px}.switch{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-speed)}.icon-btn:hover{background:var(--accent-soft);color:var(--accent-color)}#manual-data-save-btn{border:1px solid color-mix(in srgb,var(--accent-color) 38%,transparent);background:color-mix(in srgb,var(--accent-color) 14%,var(--surface-color));color:var(--accent-color);border-radius:10px}#manual-data-save-btn:hover{background:color-mix(in srgb,var(--accent-color) 22%,var(--surface-color));border-color:color-mix(in srgb,var(--accent-color) 58%,transparent)}.grid-wrapper-header #manual-data-save-btn{padding:0;width:20px;height:20px;border-radius:50%;border:none;background:color-mix(in srgb,var(--accent-color) 16%,transparent);color:var(--accent-color);display:inline-flex;align-items:center;justify-content:center}.grid-wrapper-header #manual-data-save-btn .btn-label{display:none}.grid-wrapper-header #manual-data-save-btn:hover{background:color-mix(in srgb,var(--accent-color) 26%,transparent);border-color:transparent}.manual-save-context-menu{position:fixed;z-index:2000;min-width:240px;padding:6px;border-radius:10px;border:1px solid var(--border-color);background:var(--surface-elevated-color);box-shadow:var(--shadow-soft)}.manual-save-context-menu button{width:100%;border:none;background:transparent;color:var(--primary-text-color);text-align:left;padding:8px 10px;border-radius:8px;cursor:pointer}.manual-save-context-menu button:hover{background:var(--accent-soft);color:var(--accent-color)}.icon-btn .btn-label{font-size:.72rem;font-weight:500;margin-left:0}.inspector-title{font-size:.92rem;font-weight:550;color:var(--primary-text-color);display:flex;align-items:center;gap:8px}.inspector-search{height:34px;border-radius:10px;border:1px solid var(--border-subtle);padding:0 10px;background:#ffffffb8;color:var(--primary-text-color);outline:none;transition:box-shadow var(--transition-speed),border-color var(--transition-speed)}.inspector-search:focus{border-color:#007aff8c;box-shadow:0 0 0 4px #007aff1f}body.dark-mode .inspector-search{background:#ffffff14;color:var(--primary-text-color)}.inspector-section{padding:10px 6px;border-bottom:1px solid var(--border-subtle);overflow-x:hidden;word-wrap:break-word;overflow-wrap:break-word}.inspector-section:last-child{border-bottom:none;display:flex;flex-direction:column}.inspector-section>summary{list-style:none;cursor:pointer;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-text-color);padding:6px 0}.inspector-section>summary::-webkit-details-marker{display:none}.inspector-group{padding:6px 0 2px}.inspector-section:last-child .inspector-group{display:flex;flex-direction:column}.row{display:grid;grid-template-columns:90px 1fr;gap:12px;align-items:start;padding:8px 0}.row-label{font-size:.82rem;color:var(--secondary-text-color);padding-top:6px}.row-controls{display:flex;align-items:flex-start;margin-bottom:6px}.option-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-text-color);margin-bottom:.35rem;display:block}.details-options-row{display:flex;flex-direction:column;align-items:stretch;flex:1;width:100%;min-width:0;box-sizing:border-box;padding-right:2px;min-height:0;overflow-y:auto;overflow-x:hidden}#metadata-content .row{display:flex;flex-direction:column;gap:6px}#metadata-content .row-label{min-width:0;padding-top:0}#metadata-content .row-controls{width:100%;margin-bottom:0}#metadata-content .details-options-row .checkbox-wrapper{justify-content:flex-start;text-align:left}.options-row>label{min-width:70px;margin-right:10px;font-size:.82rem;color:var(--secondary-text-color)}.checkbox-inputs,.color-inputs{display:flex;flex-wrap:wrap;gap:10px}.options-panel .checkbox-wrapper{display:flex;align-items:center;gap:.55rem;font-size:.78rem;font-weight:500;color:var(--primary-text-color);padding:6px 8px;border-radius:10px;border:1px solid transparent;transition:background-color var(--transition-speed),border-color var(--transition-speed);flex-shrink:0;width:100%;box-sizing:border-box;min-width:0}.options-panel .checkbox-wrapper:hover{background:#007aff0d;border-color:#007aff24}.options-panel .checkbox-wrapper input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;min-width:14px;min-height:14px;flex-shrink:0;border-radius:4px;border:1.5px solid var(--border-subtle);background-color:#ffffffe6;cursor:pointer;position:relative;transition:border-color var(--transition-speed),background-color var(--transition-speed),box-shadow var(--transition-speed)}.options-panel .checkbox-wrapper input[type=checkbox]:checked{border-color:#007affe6;background-color:#007affe6;box-shadow:0 0 0 3px #007aff24}.options-panel .checkbox-wrapper input[type=checkbox]:after{content:"";width:8px;height:8px;border-radius:2px;background:transparent;position:absolute;top:2px;left:2px;transition:background-color var(--transition-speed)}.options-panel .checkbox-wrapper input[type=checkbox]:checked:after{background:#fff}.options-panel .checkbox-wrapper span,.options-panel .checkbox-wrapper .sortable-label{flex:1;font-size:inherit;font-weight:inherit;color:inherit;min-width:0;white-space:normal;overflow-wrap:break-word;line-height:1.3}[data-hover-hint]{position:relative}[data-hover-hint]:hover:after,[data-hover-hint]:focus-visible:after{content:none}body.light-mode [data-hover-hint]:hover:after,body.light-mode [data-hover-hint]:focus-visible:after{content:none}#floating-hover-hint{position:fixed;left:0;top:0;max-width:min(320px,calc(100vw - 24px));background-color:#1f2937f2;color:#f1f5f9;padding:6px 12px;border-radius:6px;font-size:.75rem;line-height:1.25;white-space:nowrap;z-index:10050;border:1px solid rgba(107,114,128,.4);box-shadow:0 8px 18px #00000059;pointer-events:none;opacity:0;visibility:hidden}#floating-hover-hint.visible{opacity:1;visibility:visible}body.light-mode #floating-hover-hint{background-color:#fffffff2;color:#1f2937;border-color:#94a3b866;box-shadow:0 8px 18px #0f172a1f}.options-panel .toggle-all-wrapper{background:#007aff08;border-bottom:1px solid var(--border-subtle)!important;margin-bottom:8px!important;padding:8px!important;font-weight:600}.options-panel .toggle-all-wrapper:hover,body.dark-mode .options-panel .toggle-all-wrapper{background:#007aff14}body.dark-mode .options-panel .toggle-all-wrapper:hover{background:#007aff1f}.checkbox-inputs label{display:inline-flex;align-items:center;gap:.45rem;padding:.25rem .65rem;border-radius:999px;background:#94a3b81f;color:var(--secondary-text-color);font-size:.85rem;font-weight:550;font-family:inherit;cursor:pointer;transition:background-color var(--transition-speed),color var(--transition-speed),box-shadow var(--transition-speed),transform var(--transition-speed),border-color var(--transition-speed);border:1px solid rgba(148,163,184,.18)}.checkbox-inputs label:hover{background:#94a3b829;transform:translateY(-.5px)}.checkbox-inputs label.disabled{opacity:.5;cursor:not-allowed;background:#94a3b814;border-color:#94a3b81f;color:var(--muted-text-color)}.checkbox-inputs label.disabled:hover{background:#94a3b814;transform:none}.checkbox-inputs label.disabled[title]{position:relative;cursor:help}.checkbox-inputs label.disabled[title]:hover:after{content:attr(title);position:absolute;bottom:120%;left:50%;transform:translate(-50%);background-color:#1f2937f2;color:#f1f5f9;padding:6px 12px;border-radius:6px;font-size:.75rem;white-space:nowrap;z-index:10;border:1px solid rgba(107,114,128,.4);box-shadow:0 8px 18px #00000059;pointer-events:none}body.light-mode .checkbox-inputs label.disabled[title]:hover:after{background-color:#fffffff2;color:#1f2937;border-color:#94a3b866;box-shadow:0 8px 18px #0f172a1f}.checkbox-inputs label.train{border:1px solid rgba(0,122,255,.22);background:#007aff0d;color:var(--train-color)}.checkbox-inputs label.eval{border:1px solid rgba(52,199,89,.22);background:#34c7590d;color:var(--eval-color)}.checkbox-inputs input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:5px;border:1.5px solid var(--border-subtle);background-color:#ffffffeb;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:border-color var(--transition-speed),background-color var(--transition-speed),box-shadow var(--transition-speed),transform var(--transition-speed)}.checkbox-inputs input[type=checkbox]:checked{border-color:#007affe6;background-color:#007affe6;box-shadow:0 0 0 3px #007aff24;transform:translateY(-.5px)}.checkbox-inputs input[type=checkbox]:after{content:"";width:8px;height:8px;border-radius:2px;background:transparent;transition:background-color var(--transition-speed)}.checkbox-inputs input[type=checkbox]:checked:after{background:#fff}.checkbox-inputs label.train input[type=checkbox]:checked{border-color:var(--train-color);background-color:var(--train-color);box-shadow:0 0 0 3px #007aff24}.checkbox-inputs label.eval input[type=checkbox]:checked{border-color:var(--eval-color);background-color:var(--eval-color);box-shadow:0 0 0 3px #34c75924}.context-menu{position:fixed;background-color:#ffffffeb;border:1px solid rgba(209,213,219,1);border-radius:14px;box-shadow:0 22px 60px #0f172a40;padding:.2rem 0;z-index:1000;min-width:180px;display:none}body.dark-mode .context-menu{background-color:#1f2937f2;border:1px solid rgba(75,85,99,.6);box-shadow:0 22px 60px #00000073}.context-menu.visible{display:block}.context-menu-item{padding:.55rem .95rem;cursor:pointer;color:var(--primary-text-color);font-size:.85rem;display:flex;align-items:center;justify-content:space-between;gap:.4rem;transition:background-color var(--transition-speed),color var(--transition-speed),transform var(--transition-speed)}.context-menu-item:hover{background-color:#007aff14;transform:translate(1px)}body.dark-mode .context-menu-item:hover{background-color:#007aff26}.context-menu-item.danger{color:#b91c1c}body.dark-mode .context-menu-item.danger{color:#f87171}.context-menu-separator{height:1px;background-color:var(--border-color);margin:.4rem 0}body.dark-mode .context-menu-separator{background-color:#4b556380}.tooltip-header{font-weight:650;font-size:.9rem;margin-bottom:.4rem;padding-bottom:.4rem;border-bottom:1px solid var(--border-color);color:var(--accent-color)}.tooltip-section{margin:.3rem 0;color:var(--primary-text-color);word-break:break-word;font-size:.85rem}.tooltip-section strong{color:var(--secondary-text-color);margin-right:.5rem}.image-res-group{display:flex;align-items:center;gap:.6rem;padding:.45rem .75rem;background:#ffffffd9;border:1px solid var(--border-subtle);border-radius:var(--radius-md);height:36px;box-sizing:border-box}.image-res-group label{display:flex;align-items:center;gap:.4rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-text-color);cursor:pointer;-webkit-user-select:none;user-select:none}.image-res-group input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border-subtle);background-color:#fffffff2;cursor:pointer;position:relative;transition:border-color var(--transition-speed),background-color var(--transition-speed),box-shadow var(--transition-speed)}.image-res-group input[type=checkbox]:checked{border-color:#007affe6;background-color:#007affe6;box-shadow:0 0 0 3px #007aff24}.image-res-group input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:10px;font-weight:800}.image-res-group input[type=range]{-webkit-appearance:none;appearance:none;width:120px;height:4px;background:linear-gradient(90deg,#007aff26,#d1d5db);border-radius:999px;outline:none;cursor:pointer;transition:opacity var(--transition-speed)}.image-res-group input[type=range]:disabled{opacity:.4;cursor:not-allowed}.image-res-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:#fffffff5;border-radius:50%;border:2px solid rgba(0,122,255,.85);cursor:pointer;box-shadow:0 0 0 3px #007aff24;transition:transform var(--transition-speed),box-shadow var(--transition-speed)}.image-res-group input[type=range]::-moz-range-thumb{width:14px;height:14px;background:#fffffff5;border-radius:50%;border:2px solid rgba(0,122,255,.85);cursor:pointer;box-shadow:0 0 0 3px #007aff24;transition:transform var(--transition-speed),box-shadow var(--transition-speed)}.image-res-group input[type=range]:not(:disabled):hover::-webkit-slider-thumb,.image-res-group input[type=range]:not(:disabled):hover::-moz-range-thumb{transform:scale(1.08);box-shadow:0 0 0 4px #007aff33}.image-res-group #image-resolution-value{font-size:.8rem;color:var(--secondary-text-color);min-width:38px;text-align:right;font-weight:600}.workspace-row{display:flex;margin-left:1px;align-items:flex-start}#inspector-resize-handle{position:relative;right:auto;top:auto;width:var(--resize-bar-thickness);min-height:64px;align-self:stretch;flex:0 0 var(--resize-bar-thickness);display:flex;align-items:center;justify-content:center;cursor:ew-resize;-webkit-user-select:none;user-select:none;background:transparent;transition:background .2s ease;z-index:100}#inspector-resize-handle:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,var(--border-color) 50%,transparent 100%);clip-path:polygon(50% 12%,58% 20%,70% 30%,88% 50%,70% 70%,58% 80%,50% 88%,42% 80%,30% 70%,12% 50%,30% 30%,42% 20%)}#inspector-resize-handle:hover:before,#inspector-resize-handle.dragging:before{background:linear-gradient(180deg,transparent 0%,var(--accent-color) 50%,transparent 100%);animation:splitter-heartbeat 1s ease-in-out infinite;box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 42%,transparent),0 0 22px color-mix(in srgb,var(--accent-color) 62%,transparent)}#inspector-resize-handle .resize-dots{display:flex;flex-direction:column;gap:3px;opacity:0;transition:opacity .2s ease}#inspector-resize-handle:hover .resize-dots,#inspector-resize-handle.dragging .resize-dots{opacity:0}#inspector-resize-handle .resize-dots span{width:4px;height:4px;background:var(--secondary-text-color, #6b7280);border-radius:50%}#inspector-resize-handle:hover .resize-dots span,#inspector-resize-handle.dragging .resize-dots span{background:var(--accent-color)}body.dark-mode #inspector-resize-handle:hover:before,body.dark-mode #inspector-resize-handle.dragging:before{background:linear-gradient(180deg,transparent 0%,var(--accent-color) 50%,transparent 100%)}body.dark-mode #inspector-resize-handle .resize-dots span{background:var(--secondary-text-color, #9ca3af)}body.dark-mode #inspector-resize-handle:hover .resize-dots span,body.dark-mode #inspector-resize-handle.dragging .resize-dots span{background:var(--accent-color)}body.resizing-inspector{cursor:ew-resize!important;-webkit-user-select:none!important;user-select:none!important}body.resizing-inspector *{cursor:ew-resize!important}.inspector-container{position:sticky;top:10px;display:flex;flex-direction:column;gap:10px;width:260px;min-width:180px;max-width:560px;max-height:calc(100vh - 90px);overflow-x:visible;overflow-y:auto;transition:opacity .2s ease;flex-shrink:0;margin-right:1px}body.resizing-inspector .inspector-container{transition:none!important}.inspector-container.open{height:calc(100vh - 90px)}.inspector-container.lowered{margin-top:10px}.inspector-container.closed{width:28px}.inspector-handle{position:absolute;right:-12px;top:10px;padding:6px 10px;background:var(--panel-bg, #1f2430);color:var(--text-secondary, #c5d1e2);border:1px solid var(--border-color, #2d3545);border-radius:12px;cursor:pointer;writing-mode:vertical-rl;text-orientation:mixed;font-size:12px;-webkit-user-select:none;user-select:none;box-shadow:0 4px 12px #00000026}.inspector-container.closed .options-panel,.inspector-container.closed .training-status{display:none}.inspector-section .section-title{font-weight:700;margin-bottom:6px;font-size:.9rem}.inspector-section.combined .row-label{min-width:64px}.compact-switches{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:center;width:100%;box-sizing:border-box}#segmentation-classes-slot{width:100%}#segmentation-classes-slot .checkbox-inputs{display:flex;flex-direction:column;gap:8px;width:100%}.segmentation-class-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:28px;box-sizing:border-box}.segmentation-class-main{display:flex;align-items:center;gap:.55rem;flex:1 1 auto;min-width:0}.segmentation-class-name{font-size:.78rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.segmentation-class-color{width:20px;height:20px;border:none!important;padding:0!important;border-radius:50%;cursor:pointer;flex-shrink:0}.split-colors .row-controls{width:100%;box-sizing:border-box}.control-group.wide input,.control-group.wide select{width:110px;box-sizing:border-box}.training-card{display:flex;flex-direction:column;gap:0;border:1px solid var(--border-color, #d7dce8);border-radius:12px;padding:.75rem 1rem;margin-bottom:0;height:fit-content;box-shadow:0 4px 12px #00000014;overflow-x:hidden;word-wrap:break-word;flex-shrink:0}.training-card .card-body{flex:1;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;padding-top:12px}.training-hyperparams{display:flex;flex-direction:column;margin-top:12px;padding-top:8px;border-top:1px solid var(--border-subtle, rgba(0, 0, 0, .05))}.signals-card{display:flex;flex-direction:column;gap:0;padding:.75rem 1rem;word-wrap:break-word;overflow-x:hidden}.signals-card-body{flex:1;display:flex;flex-direction:column;align-items:stretch;padding-top:8px;min-height:0;overflow-y:auto}.training-metrics{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--primary-text-color);width:100%}.hp-header{display:flex;align-items:center;justify-content:space-between;padding:4px 0;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.7rem;font-weight:600;color:var(--secondary-text-color);text-transform:uppercase;letter-spacing:.05em;opacity:.7;transition:opacity .2s ease}.hp-header:hover{opacity:1}body.dark-mode .inspector-container .inspector-title{color:var(--primary-text-color)}.hp-header.hp-static{cursor:default;margin-top:2px}.hp-header.hp-static:hover{opacity:.7}.hp-header .chevron{transition:transform .3s ease}.hp-header.active .chevron{transform:rotate(180deg)}.hp-content{display:flex;flex-direction:column;gap:6px;margin-top:8px;overflow:hidden;transition:all .3s ease}.hp-content.hidden,.details-section-content.hidden{display:none}.hp-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.hp-row label{font-size:.8rem;color:var(--secondary-text-color);font-weight:400;flex:1 1 auto;min-width:0}.hp-row label:after{content:":";margin-right:4px}.hp-row input{width:85px;height:22px;font-size:.8rem;padding:0 6px;border-radius:4px;border:1px solid transparent;background:transparent;color:var(--primary-text-color);text-align:right;transition:all .15s ease;font-family:var(--font-mono, monospace)}.hp-row input::-webkit-outer-spin-button,.hp-row input::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none;margin:0}.hp-row input[type=number]{-moz-appearance:textfield;appearance:textfield}.hp-row input:hover{background:var(--surface-color-subtle, rgba(0, 0, 0, .03));border-color:var(--border-color)}.hp-row input:focus{outline:none;background:var(--surface-color, #fff);border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f61a;width:100px}body.dark-mode .hp-row input{color:#e0e0e0}body.dark-mode .hp-row input:hover{background:#ffffff0d}body.dark-mode .hp-row input:focus{background:#ffffff14}.hp-row .input-container{display:flex;align-items:center;gap:6px;margin-left:auto;justify-content:flex-end;min-width:120px}.hp-readonly{width:auto;min-height:22px;font-size:.8rem;color:var(--primary-text-color);text-align:right;font-family:var(--font-mono, monospace);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;pointer-events:none}.status-icon.visible{opacity:1}.status-icon.saving:after{content:"";width:8px;height:8px;border:1.5px solid var(--accent-color);border-right-color:transparent;border-radius:50%;animation:hp-spin .8s linear infinite}.status-icon.success:after{content:"✓";color:#10b981;font-size:12px;font-weight:800}@keyframes hp-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}body.dark-mode .training-card{border-color:var(--border-color)}body.dark-mode .signals-card,body.dark-mode .signals-card .inspector-title,body.dark-mode .signals-card .card-header,body.dark-mode .signals-card .signals-card-body,body.dark-mode .signals-card .training-metrics,body.dark-mode .signals-card .training-metrics .hp-row label,body.dark-mode .signals-card .training-metrics .hp-readonly{color:var(--primary-text-color)}.card{border:1px solid var(--border-color, #d7dce8);border-radius:12px;box-shadow:0 4px 12px #00000014;overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.card-body{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:4px}.training-summary{font-size:11px;color:var(--text-secondary, #4a5568);display:flex;flex-direction:column;gap:10px;flex:1;width:100%}.training-subsection{display:flex;flex-direction:column;gap:6px;padding-top:8px;border-top:1px solid var(--border-subtle, rgba(0, 0, 0, .05))}.training-summary .training-subsection:first-child{padding-top:0;border-top:none}.training-progress-container{display:flex;flex-direction:column;gap:4px;width:100%;margin-top:auto}.progress-info-row{display:flex;justify-content:space-between;align-items:flex-end;width:100%;padding:0 2px}.training-steps{font-size:11px;font-weight:500;color:var(--primary-text-color);letter-spacing:.01em}.progress-bar-container{width:100%;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#10b981);transition:width .3s ease}.progress-bar-fill.eval-mode{background:#f97316}.progress-bar-fill.eval-mode:after{content:none}.training-steps.eval-mode{visibility:hidden;position:relative}.training-steps.eval-mode:after{content:"Evaluation";visibility:visible;position:absolute;left:0;top:0;color:var(--primary-text-color);font-weight:500}.training-percentage{font-size:11px;font-weight:600;color:var(--secondary-text-color)}.training-metrics{display:flex;flex-direction:column;justify-content:center;flex:1;gap:6px;width:100%;margin-bottom:0;overflow-x:hidden}.training-metric-item{display:flex;justify-content:space-between;align-items:center;padding:2px;overflow-x:hidden;min-width:0}.training-metric-name{font-weight:400;color:#718096;font-size:11px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:8px}.training-metric-value{font-weight:600;color:var(--primary-text-color, #2d3748);font-size:11px;font-variant-numeric:tabular-nums;flex-shrink:0;text-align:right;min-width:fit-content}body.dark-mode .signals-card .inspector-title,body.dark-mode .signals-card .training-metrics .hp-row label,body.dark-mode .signals-card .training-metrics .hp-readonly{color:var(--primary-text-color)}body.dark-mode .signals-card .training-metrics{font-size:.8rem}.training-stats-small{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.training-stats-small .stat-label{font-size:11px;color:var(--text-secondary, #6b7280)}.training-stats-small .stat-value{font-size:12px;font-weight:600}.training-status .status-text{display:flex;flex-direction:column;gap:2px;font-size:12px;color:var(--text-secondary, #c5d1e2)}.training-status .pill,#training-state-pill{display:inline-block;width:10px;height:10px;border-radius:50%;padding:0;font-size:0;transition:all .2s ease;vertical-align:middle}.connection-status{font-size:.75rem;color:var(--secondary-text-color);font-weight:400;margin-left:4px;animation:pulse-opacity 2s ease-in-out infinite}@keyframes pulse-opacity{0%,50%,to{opacity:1}}.board-header-dock{position:sticky;top:0;z-index:1200;display:none;flex-direction:column;gap:6px;padding:0 0 6px;background:linear-gradient(180deg,var(--background-color) 0%,color-mix(in srgb,var(--background-color) 92%,transparent) 100%)}.board-header-dock.active{display:flex}.board-header-dock>.plots-board-header,.board-header-dock>.grid-wrapper-header{width:100%;margin-bottom:0;box-sizing:border-box;box-shadow:0 8px 18px #0f172a1f}.board-header-placeholder{width:100%;flex:0 0 auto}.pill-running{background:#22c55e;box-shadow:0 0 0 2px #22c55e33;animation:pulse-dot 1.5s ease-in-out infinite;border:none}.pill-running:before{content:none}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.pill-paused{background:#9ca3af;border:none}.pill-paused:before{content:none}.pill-running:hover,.pill-paused:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0f172a1a}body.dark-mode .pill-running{background:#22c55e;border:none;box-shadow:0 0 0 2px #22c55e4d}body.dark-mode .pill-running:before{content:none}body.dark-mode .pill-paused{background:#6b7280;border:none}body.dark-mode .pill-paused:before{content:none}.pill-pending{background:#f59e0b;box-shadow:0 0 0 2px #f59e0b33;animation:pulse-dot 1.5s ease-in-out infinite;border:none}.pill-pending:before{content:none}body.dark-mode .pill-pending{background:#fbbf24;box-shadow:0 0 0 2px #fbbf244d}body.dark-mode .pill-pending:before{content:none}.collapse-btn{background:transparent;border:none;color:var(--text-secondary, #4a5568);cursor:pointer;font-size:16px;transition:transform .15s ease;margin-left:auto}#details-body{overflow-y:auto;padding-right:4px}.card.collapsed{min-height:0!important;height:auto!important;flex:0 0 auto!important;padding:.75rem 1rem!important;padding-bottom:10px!important;overflow:visible!important;display:flex!important;flex-direction:column!important;opacity:1!important;visibility:visible!important}.card.collapsed .card-header,.card.collapsed .inspector-header{border-bottom:none!important;display:flex!important}.card.collapsed .card-body,.card.collapsed .tagger-body,.card.collapsed #details-body,#options-panel.collapsed #details-body{display:none!important}.collapse-btn{background:#0000000d;border:none;color:var(--text-secondary);cursor:pointer;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;margin-left:auto}.collapse-btn:hover{background:#0000001a;color:var(--primary-text-color);transform:scale(1.05)}.collapse-btn svg{width:12px;height:12px;stroke-width:2.5}body.dark-mode .collapse-btn{background:#ffffff1a}body.dark-mode .collapse-btn:hover{background:#fff3}.main-content{flex:1;min-width:0}.image-detail-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.image-detail-modal.visible{display:flex;opacity:1}.modal-backdrop{position:absolute;inset:0;background:#0f172a59}.tagging-modal .modal-backdrop{background:#fff6}body.dark-mode .tagging-modal .modal-backdrop{background:#0006}.modal-container{position:relative;width:95vw;max-width:1600px;height:92vh;background:var(--surface-color);border-radius:var(--radius-lg);box-shadow:0 25px 50px #00000080;overflow:hidden;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;background:#00000080;color:#fff;border:none;border-radius:50%;font-size:28px;line-height:1;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease,transform .2s ease}.modal-close:hover{background:#000000b3;transform:scale(1.1)}.modal-nav{position:absolute;top:50%;width:48px;height:48px;background:#0006;color:#fff;border:none;font-size:28px;font-weight:300;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease,transform .2s ease,opacity .2s ease;opacity:0;border-radius:8px;pointer-events:none;transform:translateY(-50%) scale(.96)}.modal-nav:hover{background:#000000b3;opacity:1;transform:scale(1.05)}.modal-nav:disabled{opacity:.2;cursor:not-allowed}.modal-nav:disabled:hover{background:#0006;transform:scale(1)}.modal-nav-prev{left:14px;margin-right:0}.modal-nav-next{right:14px;margin-left:0}.modal-controls-below{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 12px;background:var(--surface-color);border-top:1px solid var(--border-color);min-height:0;font-family:inherit;font-size:inherit}.modal-controls-group{position:static;transform:none;display:flex;flex-direction:column;align-items:center;gap:12px;z-index:100;opacity:1;transition:opacity .2s ease;pointer-events:auto;font-family:inherit}.modal-image-container:hover .modal-controls-group{opacity:1;pointer-events:auto}.image-detail-modal.controls-active .modal-controls-group{opacity:1}.modal-nav-controls{position:absolute;inset:0;pointer-events:none;z-index:25}.modal-image-container:hover .modal-nav,.image-detail-modal.controls-active .modal-image-container .modal-nav{opacity:.72;pointer-events:auto;transform:translateY(-50%) scale(1)}.modal-image-container:hover .modal-nav:disabled,.image-detail-modal.controls-active .modal-image-container .modal-nav:disabled{opacity:.2}.modal-resize-handle{position:absolute;z-index:130;width:16px;height:16px}.modal-resize-bottom-left{left:0;bottom:0;cursor:nesw-resize;background:linear-gradient(225deg,transparent 40%,rgba(0,122,255,.38) 40%);border-radius:0 0 0 16px}.modal-resize-bottom-right{right:0;bottom:0;cursor:nwse-resize;background:linear-gradient(135deg,transparent 40%,rgba(0,122,255,.38) 40%);border-radius:0 0 16px}.modal-resize-bottom-left:hover{background:linear-gradient(225deg,transparent 40%,rgba(0,122,255,.6) 40%)}.modal-resize-bottom-right:hover{background:linear-gradient(135deg,transparent 40%,rgba(0,122,255,.6) 40%)}.modal-overlay-toggles{position:static;transform:none;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:400px;z-index:120}.modal-toggle{padding:.42rem .72rem;border:1px solid rgba(255,255,255,.22);border-radius:999px;background:#0f172a9e;color:#ffffffc7;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);font-size:.76rem;font-weight:600;cursor:pointer;transition:background-color .18s ease,color .18s ease,border-color .18s ease}.modal-toggle:hover{background:#0f172ac7;color:#fff}.modal-toggle.active{background:#007affeb;border-color:#bfdbfef2;color:#fff}.modal-toggle:disabled{cursor:not-allowed;opacity:.45;background:#0f172a66;color:#ffffff73;border-color:#ffffff1a}.modal-toggle:disabled:hover{background:#0f172a66;color:#ffffff73}.modal-toggle.hidden{display:none!important}.modal-content{display:flex;height:100%;gap:0;min-width:0}.modal-metadata{width:360px;height:auto;max-width:450px;min-width:280px;flex:0 0 360px;background:var(--surface-elevated-color);border-right:none;padding:2rem;overflow-y:auto;display:flex;flex-direction:column}.modal-pane-resize-handle{width:var(--resize-bar-thickness);flex:0 0 var(--resize-bar-thickness);cursor:col-resize;position:relative;background:transparent;z-index:4}.modal-pane-resize-handle:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,var(--border-color) 50%,transparent 100%);clip-path:polygon(50% 12%,58% 20%,70% 30%,88% 50%,70% 70%,58% 80%,50% 88%,42% 80%,30% 70%,12% 50%,30% 30%,42% 20%)}.modal-pane-resize-handle:hover:before,body.resizing-modal-pane .modal-pane-resize-handle:before{background:linear-gradient(180deg,transparent 0%,var(--accent-color) 50%,transparent 100%);animation:splitter-heartbeat 1s ease-in-out infinite}.modal-title{font-size:1.5rem;font-weight:700;color:var(--primary-text-color);margin:0 0 1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}#image-detail-modal .modal-title{text-align:center}.modal-stats-container{display:flex;flex-direction:column;gap:1rem}.modal-stat-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--surface-color);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);transition:background-color .2s ease}.modal-stat-item:hover{background:var(--accent-soft)}.modal-stat-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-text-color)}.modal-stat-value{font-size:1rem;font-weight:500;color:var(--primary-text-color);word-break:break-word}.modal-stat-item{cursor:grab;padding:.75rem}.modal-stat-item:active{cursor:grabbing}.modal-stat-item.dragging{opacity:.5;transform:scale(.95)}.modal-image-section{flex:1;display:flex;flex-direction:column;background:var(--background-color);overflow:hidden;min-width:0;min-height:0}.modal-image-container{flex:1;display:flex;align-items:center;justify-content:center;background:var(--background-color);padding:2rem;overflow:hidden;position:relative;width:100%;height:auto;min-width:0;min-height:0;box-sizing:border-box}.metadata-overview-container{min-height:80px;max-height:100px;padding:1rem;background:var(--surface-elevated-color);border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;position:relative;overflow-y:auto}.metadata-overview-container.drag-over{background:#3b82f61a;border-top:2px solid var(--primary-color)}#chat-input.drag-over,#chat-history-input.drag-over{border-color:var(--accent-color);box-shadow:0 0 0 2px var(--accent-soft)}.metadata-overview-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--muted-text-color);text-align:center;pointer-events:none}.metadata-overview-hint{margin:0;font-size:.9rem;opacity:.7}.metadata-overview-display{display:flex;flex-direction:column;gap:.5rem;width:100%;height:100%;align-items:center;justify-content:center}.metadata-overview-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-text-color)}.metadata-overview-value{font-size:1.1rem;font-weight:600;color:var(--primary-text-color);word-break:break-word;text-align:center}.modal-image.loading{opacity:.6}body.dark-mode .modal-backdrop{background:#000000eb}body.dark-mode .modal-stat-item{background:var(--surface-elevated-color)}body.dark-mode .modal-stat-item:hover{background:#3b82f61a}body.dark-mode .metadata-overview-container{background:var(--surface-color);border-top:1px solid var(--border-subtle)}body.dark-mode .metadata-overview-container.drag-over{background:#3b82f626;border-top:2px solid rgba(59,130,246,.5)}@media(max-width:900px){.modal-content{flex-direction:column}.modal-pane-resize-handle{display:none}.modal-metadata{width:100%;flex:0 0 auto;min-width:100%;max-height:40%;border-right:none;border-bottom:1px solid var(--border-color)}.modal-image-section{flex:1;display:flex;flex-direction:column}.modal-image-container{flex:1}.metadata-overview-container{min-height:60px;max-height:80px}}.tagging-container{max-width:480px;height:auto;min-height:280px;display:flex;flex-direction:column;border:1px solid var(--border-subtle);box-shadow:0 10px 40px #00000014,0 1px 2px #0000000d;overflow:hidden}body.dark-mode .tagging-container{box-shadow:0 20px 60px #00000080,0 0 0 1px #ffffff0d}.tagging-content{height:auto;display:block;overflow:visible}.tagging-panel{width:100%!important;min-width:0!important;border-right:none!important;padding:24px 32px!important;display:block!important;overflow:visible!important;box-sizing:border-box!important}.tagging-panel .modal-title{font-size:1.25rem;font-weight:700;margin:0 0 20px!important;padding:0!important;letter-spacing:-.02em;line-height:1.2}.tag-input-group{margin-bottom:1.5rem}.tag-input-field{display:block;width:100%!important;box-sizing:border-box!important;padding:10px 12px!important;font-size:.9rem!important;height:40px!important;border-radius:8px!important;border:1px solid var(--border-color)!important;background:var(--background-color)!important;transition:all .2s ease!important}.tag-input-field:focus{background:var(--surface-color)!important;border-color:var(--accent-color)!important;box-shadow:0 0 0 3px var(--accent-soft)!important;outline:none!important}.quick-tags-section{margin-bottom:2rem;flex-grow:1}.quick-tags-container{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;max-height:200px;overflow-y:auto;padding:4px}.quick-tag-btn{background:var(--background-color);border:1px solid var(--border-subtle);border-radius:6px;padding:5px 10px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s ease;color:var(--secondary-text-color)}.quick-tag-btn:hover{background:var(--surface-color);color:var(--accent-color);border-color:var(--accent-color);transform:none;box-shadow:0 2px 5px #0000000d}.tagging-actions{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border-subtle)}body.dark-mode .quick-tag-btn{background:var(--surface-elevated-color)}.control-button{padding:.6rem 1.25rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-speed);border:1px solid var(--border-subtle);background:var(--surface-color);color:var(--primary-text-color);display:inline-flex;align-items:center;justify-content:center}.control-button:hover{filter:brightness(.96);transform:translateY(-1px)}.control-button.primary{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 4px 12px #007aff26}.control-button.primary:hover{background:var(--accent-color-hover);box-shadow:0 4px 15px #007aff40}.control-button.danger{color:var(--secondary-text-color);border-color:var(--border-subtle);background:transparent}.control-button.danger:hover{background:#ef44440d;color:#ef4444;border-color:#ef444433;box-shadow:none;transform:translateY(-1px)}.refresh-container{position:relative;display:flex;align-items:center}.refresh-button{padding:0;width:36px;height:36px;border-radius:50%;position:relative;background:var(--surface-color);border:1px solid var(--border-color);box-shadow:0 2px 8px #0000000a;transition:all .3s ease;z-index:2}.refresh-popover{position:absolute;top:calc(100% + 8px);left:0;background:#fffffffa;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(0,0,0,.08);box-shadow:0 12px 48px #00000026;z-index:10000;display:flex;transition:all .25s cubic-bezier(.34,1.56,.64,1);pointer-events:all;opacity:1;border-radius:20px}.refresh-popover.hidden{opacity:0;pointer-events:none}.refresh-popover.horizontal{flex-direction:row;align-items:center;width:auto;min-width:250px;gap:12px;padding:8px 14px;border-radius:999px}.refresh-popover.vertical{flex-direction:column;width:auto;min-width:260px;gap:0;padding:16px;border-radius:24px}.refresh-section{display:flex;flex-direction:column;gap:8px;width:100%}.refresh-row{display:flex;flex-direction:row;align-items:center;gap:10px}.refresh-section-divider{height:1px;background:#0000001a;margin:8px 0}.refresh-popover-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--secondary-text-color);display:block;white-space:nowrap}.switch-premium{position:relative;display:inline-block;width:34px;height:20px;flex-shrink:0}.switch-premium input{opacity:0;width:0;height:0}.slider-pill{position:absolute;cursor:pointer;inset:0;background-color:#0000001a;transition:.4s;border-radius:20px}.slider-pill:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 1px 3px #0003}.switch-premium input:checked+.slider-pill{background-color:var(--eval-color)}.switch-premium input:checked+.slider-pill:before{transform:translate(14px)}.refresh-input-divider{width:1px;height:18px;background:#00000014;margin:0 2px}.refresh-input-group{display:flex;align-items:center;background:#0000000a;border:1px solid rgba(0,0,0,.08);border-radius:999px;padding:2px 10px;transition:all .3s ease;height:28px;opacity:1}.refresh-input-group.disabled{opacity:.25;pointer-events:none;background:#0000000d;border-color:transparent;filter:grayscale(1)}.refresh-input-group:focus-within{background:#fff;border-color:var(--accent-color);box-shadow:0 0 0 3px #007aff1a}.refresh-input-group input{background:transparent;border:none;width:42px;font-size:.85rem;font-weight:700;color:var(--primary-text-color);padding:0;text-align:center}.refresh-input-group input::-webkit-inner-spin-button,.refresh-input-group input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.refresh-input-group input:focus{outline:none}.refresh-input-group .unit{font-size:.7rem;font-weight:600;color:var(--muted-text-color);margin-left:4px}.refresh-send-btn{width:28px;height:28px;border-radius:50%;background:var(--accent-color);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);padding:0;flex-shrink:0}.refresh-send-btn:hover{background:var(--accent-color-hover);transform:scale(1.1);box-shadow:0 2px 8px #007aff4d}.refresh-send-btn:active{transform:scale(.95)}.clear-cache-btn{width:100%;padding:10px 16px;background:var(--accent-color);color:#fff;border:none;border-radius:var(--radius-md, 8px);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.clear-cache-btn:hover{background:var(--accent-color-hover);transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.clear-cache-btn:active{transform:translateY(0);box-shadow:0 2px 6px #007aff33}body.dark-mode .slider-pill{background-color:#ffffff26}body.dark-mode .refresh-popover{background:#232323eb;border-color:#ffffff1f;box-shadow:0 8px 32px #00000080}body.dark-mode .refresh-input-divider,body.dark-mode .refresh-section-divider{background:#ffffff26}body.dark-mode .refresh-input-group{background:#ffffff0f;border-color:#ffffff1a}body.dark-mode .refresh-input-group:focus-within{background:#ffffff1a;border-color:var(--accent-color)}body.dark-mode .refresh-input-group input{color:#fff}#resume-steps-popup.resume-steps-popover{min-width:32px;max-width:min(92vw,420px);padding:14px;gap:12px}#resume-steps-popup .resume-steps-group{width:100%}#resume-steps-popup .resume-steps-group .res-row-controls{gap:10px}#resume-steps-popup .resume-steps-input-group{min-width:110px;justify-content:space-between}#resume-steps-popup .resume-steps-input-group input{width:56px;text-align:right;font-variant-numeric:tabular-nums}#resume-steps-popup .resume-steps-actions{width:100%;justify-content:flex-end;gap:8px;margin-top:2px}#resume-steps-popup .resume-steps-actions .control-button{min-width:86px}.refresh-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.refresh-icon{transition:all .3s cubic-bezier(.34,1.56,.64,1);color:var(--secondary-text-color);opacity:.7}.refresh-button:hover{border-color:var(--accent-color);background:var(--surface-elevated-color);box-shadow:0 4px 12px #00000014}.refresh-button:hover .refresh-icon{color:var(--accent-color);opacity:1}.refresh-button.refreshing .refresh-icon{animation:spin .5s linear infinite;color:var(--eval-color);opacity:1}.refresh-config-trigger{position:absolute;bottom:-2px;right:-2px;width:18px;height:18px;padding:0;background:var(--surface-color);border:1px solid var(--border-color);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;color:var(--secondary-text-color);opacity:.6;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 4px #0000000d}.refresh-config-trigger:hover{background:var(--surface-elevated-color);color:var(--accent-color);opacity:1;transform:scale(1.15);box-shadow:0 3px 8px #0000001a}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-dot-simple{0%{transform:scale(1);box-shadow:0 0 #34c7594d}70%{transform:scale(1.1);box-shadow:0 0 0 6px #34c75900}to{transform:scale(1);box-shadow:0 0 #34c75900}}.refresh-button.is-polling{border-color:#34c75933}body.dark-mode .refresh-button{background:#28282899;border-color:#ffffff1a}body.dark-mode .refresh-config-trigger{background-color:#282828;border-color:#ffffff1a;color:#888}body.dark-mode .control-button{background:#1f1f1f;border-color:#333}body.dark-mode .control-button.danger{background:#ef44441a}.current-tag-chip{background:var(--accent-soft);color:var(--accent-color);border:1px solid transparent;display:flex;align-items:center;gap:6px;padding-right:8px}.current-tag-chip:hover{background:#ef444414;color:#ef4444;border-color:#ef444433}.remove-x{font-size:1rem;font-weight:400;opacity:.5;margin-top:-1px}.current-tag-chip:hover .remove-x{opacity:1}.tagging-modal .modal-close{width:32px;height:32px;top:16px;right:16px;font-size:1.25rem;background:var(--surface-color);border:1px solid var(--border-subtle);color:var(--secondary-text-color);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.tagging-modal .modal-close:hover{background:var(--background-color);color:var(--primary-text-color);transform:rotate(90deg);border-color:var(--border-color)}#cells-grid.painter-active{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M18.375 2.625a2.121 2.121 0 1 1 3 3L12 15l-4 1 1-4Z"/><path d="m15 5 3 3"/><path d="M6.5 20c.5-2 1.5-2.5 3-2.5 1.5 0 2 1.5 2 2H6.5Z"/></svg>') 0 24,crosshair!important}#cells-grid.painter-active .cell{cursor:inherit!important}#painter-new-tag{width:28px;height:28px;border-radius:50%;border:1px solid var(--border-color);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;padding:0;color:var(--secondary-text-color)}#painter-new-tag:hover:not(:disabled){background:var(--accent-soft);color:var(--accent-color);border-color:var(--accent-color)}#painter-new-tag:disabled{opacity:.5;cursor:not-allowed}.switch{position:relative;display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--secondary-text-color);cursor:pointer}.switch input{opacity:0;width:0;height:0}.switch span{position:relative;width:36px;height:20px;background-color:var(--border-color);border-radius:99px;transition:.3s;display:inline-block;margin-right:6px;flex-shrink:0}.switch span:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 2px #00000026}.switch input:checked+span{background-color:var(--accent-color)}.switch input:checked+span:before{transform:translate(16px)}.switch input:disabled+span{opacity:.35;cursor:not-allowed}label.disabled{opacity:.45;cursor:not-allowed}.brush-chip{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:999px;padding:4px 10px;font-size:.8rem;cursor:pointer;transition:all .2s;color:var(--secondary-text-color)}.brush-chip:hover{border-color:var(--accent-color);color:var(--primary-text-color)}.brush-chip.active{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 2px 6px #007aff4d}.tagging-panel .inspector-header{margin-bottom:.5rem}.tagging-panel .row-controls{flex-direction:column;align-items:flex-start}.painter-toggle-row{margin-bottom:1rem}.painter-switch{display:flex!important;align-items:center;justify-content:space-between;width:100%;cursor:pointer}.painter-switch .label-text{font-size:.9rem;font-weight:500;color:var(--primary-text-color)}.painter-switch input{display:none}.painter-switch .slider-round{position:relative;width:40px;height:22px;background-color:var(--border-color);border-radius:99px;transition:.3s;flex-shrink:0}.painter-switch .slider-round:before{content:"";position:absolute;height:18px;width:18px;left:2px;bottom:2px;background-color:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 2px #0003}.painter-switch input:checked+.slider-round{background-color:var(--accent-color)}.painter-switch input:checked+.slider-round:before{transform:translate(18px)}.painter-brush-row{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.painter-brush-row .section-subtitle{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary-text-color);font-weight:600}.tag-brushes-container{display:flex;flex-wrap:wrap;gap:8px}.empty-state{font-size:.85rem;color:var(--muted-text-color);font-style:italic;padding:.5rem 0}.brush-chip{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:6px;padding:4px 10px;font-size:.85rem;cursor:pointer;transition:all .2s ease;color:var(--primary-text-color);font-weight:500;display:inline-flex;align-items:center;gap:4px}.brush-chip:hover{background-color:var(--surface-hover-color, #f3f4f6);border-color:var(--border-subtle);transform:translateY(-1px)}.brush-chip.active{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 2px 5px #007aff40}.control-button.dashed{background-color:transparent;border:1px dashed var(--border-color);color:var(--secondary-text-color);transition:all .2s}.control-button.dashed:hover{border-color:var(--accent-color);color:var(--accent-color);background-color:var(--accent-soft)}.control-button.full-width{width:100%;justify-content:center;padding:.6rem}.tags-list{display:flex;flex-wrap:wrap;gap:6px;max-height:200px;overflow-y:auto}.tag-chip{font-size:.8rem;padding:4px 8px;border-radius:99px;background:var(--surface-color);border:1px solid var(--border-color);color:var(--secondary-text-color);cursor:pointer;transition:.1s;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:4px}.tag-chip.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 2px 5px #0000001a}.tag-chip:hover{border-color:var(--accent-color)}.tag-chip.active:hover{background:var(--accent-color-hover)}.empty-state{font-size:.8rem;color:var(--muted-text-color);text-align:center;width:100%;padding:1rem 0;font-style:italic}.control-button.small{padding:4px 10px;font-size:.8rem}.tagger-card{min-height:200px;padding:.75rem 1rem;box-sizing:border-box}.tagger-body{padding:0!important;display:flex;flex-direction:column;gap:0}.tagger-section{padding:1rem 1.25rem;border-bottom:1px solid var(--border-subtle)}.tagger-section:last-child{border-bottom:none}.section-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-text-color);font-weight:600;margin-bottom:.75rem}.tags-list{display:flex;flex-wrap:wrap;gap:8px;max-height:180px;overflow-y:auto;padding:2px}.tag-chip{font-size:.85rem;padding:6px 14px;border-radius:8px;background:var(--surface-elevated-color);border:1.5px solid var(--border-color);color:var(--primary-text-color);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;gap:6px;font-weight:500;box-shadow:0 1px 2px #0000000a}.tag-chip:hover{border-color:var(--accent-color);background:var(--accent-soft);transform:translateY(-1px);box-shadow:0 4px 8px #00000014}.tag-chip.active{background:linear-gradient(135deg,var(--accent-color),var(--accent-color-hover));color:#fff;border-color:var(--accent-color);box-shadow:0 4px 12px #007aff4d;font-weight:600}.tag-chip.active:hover{background:linear-gradient(135deg,var(--accent-color-hover),var(--accent-color));box-shadow:0 6px 16px #007aff66}.empty-state{font-size:.85rem;color:var(--muted-text-color);text-align:center;width:100%;padding:1.5rem 0;font-style:italic;line-height:1.5}.new-tag-btn{width:100%;padding:.65rem 1rem!important;font-size:.9rem!important;font-weight:600!important;border-radius:var(--radius-md)!important;display:flex;align-items:center;justify-content:center;gap:4px}.switch.compact{font-size:0;margin:0}.switch.compact span{width:44px;height:26px;margin:0}.switch.compact span:before{width:20px;height:20px;bottom:3px;left:3px}.switch.compact input:checked+span:before{transform:translate(18px)}body.dark-mode .tag-chip{background:#ffffff0d;border-color:var(--border-color)}body.dark-mode .tag-chip:hover{background:#3b82f626}.tagger-card{min-height:auto;display:flex;flex-direction:column}.tagger-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.tagger-section:first-child{flex:1;overflow:hidden;display:flex;flex-direction:column}.tags-list{flex:1;overflow-y:auto;max-height:140px}.tagger-section:last-child{flex-shrink:0}.new-tag-btn{width:100%;padding:.5rem 1rem!important;font-size:.85rem!important;font-weight:500!important;border-radius:8px!important;display:flex;align-items:center;justify-content:center;gap:6px;background:transparent!important;border:1.5px dashed var(--border-color)!important;color:var(--secondary-text-color)!important;box-shadow:none!important;transition:all .15s ease!important}.new-tag-btn:hover{background:var(--accent-soft)!important;border-color:var(--accent-color)!important;color:var(--accent-color)!important;transform:none!important;box-shadow:none!important}.new-tag-btn span{font-size:1rem;font-weight:400}body.dark-mode .new-tag-btn{border-color:var(--border-color)!important;color:var(--secondary-text-color)!important}body.dark-mode .new-tag-btn:hover{background:#3b82f61a!important;border-color:var(--accent-color)!important;color:var(--accent-color)!important}.new-tag-btn{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.painter-mode-section{padding:.75rem 1rem!important}.painter-mode-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.painter-mode-label{font-size:.85rem;font-weight:500;color:var(--primary-text-color)}.tags-section{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:.75rem 1rem!important}.add-tag-section{padding:.75rem 1rem!important;border-top:1px solid var(--border-subtle)}.add-tag-input-wrapper{display:flex;gap:.5rem;align-items:stretch}.new-tag-input{flex:1;background-color:var(--surface-elevated-color);color:var(--primary-text-color);border:1.5px solid var(--border-color);border-radius:8px;padding:.5rem .75rem;font-size:.85rem;transition:border-color .15s ease,box-shadow .15s ease}.new-tag-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #007aff1a}.new-tag-input::placeholder{color:var(--muted-text-color)}.add-tag-btn{flex-shrink:0;width:36px;height:36px;border-radius:8px;background:var(--accent-color);border:none;color:#fff;font-size:1.2rem;font-weight:400;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #007aff33}.add-tag-btn:hover{background:var(--accent-color-hover);transform:translateY(-1px);box-shadow:0 4px 8px #007aff4d}.add-tag-btn:active{transform:translateY(0)}body.dark-mode .new-tag-input{background-color:#ffffff0d;border-color:var(--border-color)}body.dark-mode .new-tag-input:focus{border-color:var(--accent-color);background-color:#ffffff14}.card.tagger-card{flex-shrink:0;min-height:250px}.painter-mode-section{padding:1rem 1.25rem!important;border-bottom:1px solid var(--border-subtle)}.painter-mode-row{height:24px}.tags-section{padding:1rem 12px 1rem 1.25rem!important;flex:1;min-height:100px}.add-tag-section{padding:1rem 1.25rem!important;background:var(--background-color)}.add-tag-input-wrapper{height:36px}.new-tag-input{height:100%;box-shadow:0 1px 2px #0000000d}.add-tag-btn{height:100%;width:40px;border-radius:8px;padding:0}.card.tagger-card{min-height:auto}.compact-header{display:flex;justify-content:space-between;align-items:center}.header-controls{display:flex;align-items:center;gap:8px}.mode-label{font-size:.8rem;font-weight:700;color:var(--secondary-text-color);text-transform:uppercase;letter-spacing:.05em;-webkit-user-select:none;user-select:none;cursor:default;display:flex;align-items:center;gap:8px;position:relative;padding-left:14px}.mode-label:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background-color:#34c759;box-shadow:0 0 6px #34c75966;opacity:0;transition:opacity .3s ease}body:has(#painter-toggle:checked) .mode-label:before{opacity:1}.compact-body{display:flex;flex-direction:column;padding:0!important}.tags-flow-container{display:flex;flex-wrap:wrap;gap:8px;padding:.75rem 1rem;align-items:center;min-height:44px}.tags-flow-container .tag-chip{padding:6px 12px;font-size:.85rem;border-radius:999px;background:var(--surface-elevated-color);border:1px solid var(--border-color);color:var(--primary-text-color);cursor:pointer;transition:all .15s ease;white-space:nowrap}.tags-flow-container .tag-chip:hover{border-color:var(--accent-color);background:var(--accent-soft)}.tags-flow-container .tag-chip.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.inline-tag-input{display:flex;align-items:center;background:var(--surface-color);border:1px solid var(--border-color);border-radius:999px;padding:2px 4px 2px 10px;flex:1 1 80px;min-width:80px;max-width:100%;height:30px;transition:all .2s ease}.inline-tag-input:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 3px #007aff1f;flex-grow:10}.inline-tag-input .new-tag-input{flex:1;border:none;background:transparent;padding:0;font-size:.8rem;height:100%;color:var(--primary-text-color);outline:none;min-width:40px}.inline-tag-input .new-tag-input::placeholder{color:var(--muted-text-color)}.add-tag-btn-inline{width:22px;height:22px;border-radius:50%;border:none;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s ease}.add-tag-btn-inline:hover{transform:scale(1.1);box-shadow:0 2px 8px #007aff4d}.painter-controls-row{display:flex;align-items:center;justify-content:space-between;margin-top:.25rem;padding:0 .5rem;border-top:1px solid var(--border-subtle);height:40px;min-height:40px;width:100%;box-sizing:border-box;flex-shrink:0}.painter-controls-group{display:flex;align-items:center;gap:.75rem;margin:0;height:100%}.switch-tiny{position:relative;display:inline-block;width:50px;height:22px;margin:0}.switch-tiny input{opacity:0;width:0;height:0}.switch-tiny span{position:absolute;cursor:pointer;inset:0;background-color:#0000001a;transition:.4s cubic-bezier(.34,1.56,.64,1);border-radius:999px;border:1px solid var(--border-color)}body.dark-mode .switch-tiny span{background-color:#ffffff14}.switch-tiny span:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;transition:.4s cubic-bezier(.34,1.56,.64,1);border-radius:50%;box-shadow:0 1px 3px #0003}.switch-tiny input:checked+span{background-color:var(--accent-color);border-color:var(--accent-color)}.switch-tiny input:checked+span:before{transform:translate(28px)}.segmented-control{display:flex;background:var(--surface-elevated-color);border:1px solid var(--border-color);border-radius:999px;padding:1px;gap:1px;height:22px;width:50px;box-sizing:border-box}.segmented-control .segment{flex:1;height:18px;border:none;background:transparent;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted-text-color);transition:all .2s ease}.segmented-control .segment:hover{background:#0000000d;color:var(--primary-text-color)}.segmented-control .segment.active{background:var(--accent-color);color:#fff;box-shadow:0 2px 4px #007aff40}.segmented-control .segment svg{stroke-linecap:round;stroke-linejoin:round}body.dark-mode .segmented-control{background:#ffffff14;border-color:var(--border-color)}body.dark-mode .segmented-control .segment:hover{background:#ffffff1a}body.dark-mode .inline-tag-input{background:#ffffff0d}.compact-list{padding:.75rem 1rem!important;max-height:120px;gap:6px}.compact-list .tag-chip{padding:4px 10px;font-size:.8rem;border-radius:6px}.tagger-footer{padding:.75rem 1rem;border-top:1px solid var(--border-subtle);background:var(--surface-color)}.compact-input{height:32px;gap:6px}.compact-input .new-tag-input{font-size:.8rem;padding:.25rem .75rem;border:none;background:transparent;border-bottom:1.5px solid var(--border-color);border-radius:0;box-shadow:none}.compact-input .new-tag-input:focus{border-color:var(--accent-color);box-shadow:none}.compact-input .add-tag-btn{width:28px;background:transparent;color:var(--accent-color);border:1px solid transparent;box-shadow:none}.compact-input .add-tag-btn:hover{background:var(--accent-soft);border-color:var(--accent-soft);transform:none}body.dark-mode .compact-input .new-tag-input{background:transparent;border-bottom-color:var(--border-color)}body.dark-mode .compact-input .new-tag-input:focus{border-bottom-color:var(--accent-color)}.tagger-footer{padding:.5rem .75rem!important}.compact-input{width:100%!important;display:flex!important;align-items:center!important;background:var(--surface-color)!important;border:1px solid var(--border-color)!important;border-radius:6px!important;height:30px!important;padding:0 4px!important;box-sizing:border-box!important}.compact-input:focus-within{border-color:var(--accent-color)!important;box-shadow:0 0 0 2px #007aff1a!important}.compact-input .new-tag-input{flex:1!important;width:100%!important;border:none!important;background:transparent!important;padding:0 6px!important;font-size:.8rem!important;height:100%!important;outline:none!important;box-shadow:none!important}.compact-input .add-tag-btn{flex-shrink:0!important;width:24px!important;height:24px!important;display:flex!important;align-items:center!important;justify-content:center!important;border-radius:4px!important;color:var(--secondary-text-color)!important;padding:0!important}.compact-input .add-tag-btn:hover{background:var(--accent-soft)!important;color:var(--accent-color)!important}.new-tag-input:focus{box-shadow:none!important}.tagger-footer{padding:.75rem 1rem!important;background:transparent!important;border-top:1px solid var(--border-subtle)}.compact-input{width:100%!important;height:36px!important;background:var(--surface-color)!important;border:1px solid var(--border-color)!important;border-radius:999px!important;display:flex!important;align-items:center!important;padding:2px 4px 2px 12px!important;box-shadow:0 1px 2px #00000008!important;transition:all .2s ease}.compact-input:focus-within{border-color:var(--accent-color)!important;box-shadow:0 0 0 3px #007aff1f!important;background:var(--surface-elevated-color)!important}.compact-input .new-tag-input{flex:1!important;border:none!important;background:transparent!important;padding:0!important;font-size:.9rem!important;height:100%!important;color:var(--primary-text-color)!important}.compact-input .add-tag-btn{width:28px!important;height:28px!important;border-radius:50%!important;border:none!important;background:var(--accent-color)!important;color:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important;margin-left:4px!important;opacity:.9;transition:all .2s ease!important}.compact-input .add-tag-btn:hover{opacity:1;transform:scale(1.05)}.compact-input .add-tag-btn svg{width:14px;height:14px;stroke-width:2.5}body.dark-mode .compact-input:focus-within{background:#ffffff14!important}.mode-label{display:flex;align-items:center}.tagger-card{transition:box-shadow .3s ease,border-color .3s ease!important}body:has(#painter-toggle:checked) .tagger-card{border-color:var(--accent-color)!important;box-shadow:0 0 15px #007aff26!important}#cells-grid.painter-active{background:radial-gradient(circle at top,#007aff08 0,#f9fafbd9 55%)!important;border-color:var(--accent-color)!important;transition:all .4s ease}#cells-grid.painter-active{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32" fill="none"><circle cx="16" cy="16" r="6" stroke="rgba(0,122,255,0.8)" stroke-width="2"/><circle cx="16" cy="16" r="1" fill="rgba(0,122,255,0.8)"/></svg>') 16 16,crosshair!important}#cells-grid.painter-active .cell:hover{border-color:var(--accent-color)!important;box-shadow:0 0 12px #007aff33!important;z-index:5}body.dark-mode:has(#painter-toggle:checked) .tagger-card{box-shadow:0 0 20px #3b82f640!important;border-color:var(--accent-color)!important}body.dark-mode #cells-grid.painter-active{background:radial-gradient(circle at top,#3b82f614 0,#0a0a0af2 55%)!important}body.dark-mode #cells-grid.painter-active .cell:hover{box-shadow:0 0 15px #3b82f64d!important}body.dark-mode #cells-grid.painter-active{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32" fill="none"><circle cx="16" cy="16" r="6" stroke="rgba(100,180,255,1)" stroke-width="2"/><circle cx="16" cy="16" r="1.5" fill="rgba(100,180,255,1)"/></svg>') 16 16,crosshair!important}body.dark-mode .tagger-card{border-color:var(--border-color)!important}body.dark-mode .tagger-header{border-bottom-color:var(--border-color)}body.dark-mode .tagger-footer{background:transparent!important;border-top-color:var(--border-color)}body.dark-mode .tag-chip{background:var(--surface-elevated-color);border-color:var(--border-color);color:var(--primary-text-color)}.inspector-container.open.lowered{--inspector-top-offset: 10px;--inspector-bottom-clearance: 12px;height:calc(100vh - var(--inspector-top-offset) - var(--inspector-bottom-clearance));max-height:calc(100vh - var(--inspector-top-offset) - var(--inspector-bottom-clearance));overflow-y:auto;overscroll-behavior:contain}.inspector-container.open.lowered>.card{flex:0 0 auto;min-height:0;display:flex;flex-direction:column;overflow:hidden}.inspector-container.open.lowered>.training-card .card-body,.inspector-container.open.lowered>.signals-card .card-body,.inspector-container.open.lowered>.tagger-card .tagger-body,.inspector-container.open.lowered>#options-panel #details-body,.inspector-container.open.lowered>#options-panel .card-body{min-height:0;overflow-y:auto;overscroll-behavior:contain}.inspector-container.open.lowered>#options-panel{flex:1 1 auto;max-height:none;min-height:0;overflow:visible}body.dark-mode .tag-chip.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}body.dark-mode .compact-input{background:#ffffff0d!important;border-color:var(--border-color)!important}.mode-switcher{display:flex;background:var(--surface-color);border:1px solid var(--border-color);border-radius:6px;overflow:hidden;margin-right:8px}.mode-btn{padding:3px 10px;font-size:.85rem;font-weight:600;border:none;background:transparent;color:var(--secondary-text-color);cursor:pointer;transition:all .15s ease;border-right:1px solid var(--border-color)}.workspace-row{min-height:0;align-items:stretch}.workspace-row .inspector-container.open,.workspace-row .inspector-container.open.lowered{height:100%;max-height:100%;top:0}.workspace-row .inspector-container.open.lowered{margin-top:0}.workspace-row{overflow-y:hidden}.workspace-row .main-area{min-height:0}.workspace-row .main-content{min-height:0;height:100%;overflow-y:auto}.mode-btn:last-child{border-right:none}.mode-btn:hover{background:var(--accent-soft);color:var(--accent-color)}.mode-btn.active{background:var(--accent-color);color:#fff}.mode-btn.remove-mode{background:transparent;color:var(--secondary-text-color)}.mode-btn.remove-mode:hover{background:var(--accent-soft);color:var(--accent-color)}body.dark-mode .mode-switcher{background:#ffffff0d}.tag-chip{position:relative;padding-right:24px}.tag-chip .delete-tag{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;background:#00000026;border:none;color:var(--primary-text-color);font-size:10px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all .15s ease;padding:0}.tag-chip:hover .delete-tag{display:flex}.tag-chip .delete-tag:hover{background:#ef4444;color:#fff;transform:translateY(-50%) scale(1.1)}body.dark-mode .tag-chip .delete-tag{background:#ffffff26}body.dark-mode .tag-chip .delete-tag:hover{background:#ef4444}.chat-result-panel{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;width:100%;margin:0 auto;background-color:#fffffff2;border:1px solid var(--accent-color);border-left:4px solid var(--accent-color);border-radius:var(--radius-md);padding:1rem 1.25rem;box-shadow:0 4px 12px #007aff26;box-sizing:border-box;animation:slideDown .3s ease-out;z-index:20}body.dark-mode .chat-result-panel{background-color:#1e1e1ef2;border-top-color:var(--border-subtle);border-right-color:var(--border-subtle);border-bottom-color:var(--border-subtle)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chat-result-content{flex-grow:1;font-family:SF Mono,Roboto Mono,monospace;font-size:.95rem;color:var(--primary-text-color);white-space:pre-wrap;line-height:1.5}.chat-result-close{background:none;border:none;font-size:1.25rem;color:var(--muted-text-color);cursor:pointer;padding:4px;line-height:1;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.chat-result-close:hover{color:var(--primary-text-color);background-color:#0000000d}body.dark-mode .chat-result-close:hover{background-color:#ffffff1a}.chat-history-panel{--chat-history-default-width: 525px;--chat-history-default-height: 700px;display:none;flex-direction:column;position:fixed;top:140px;right:20px;width:var(--chat-history-default-width);height:var(--chat-history-default-height);max-width:75vw;max-height:90vh;min-width:calc(var(--chat-history-default-width) * .25);min-height:calc(var(--chat-history-default-height) * .25);overflow:hidden;background:#ffffffd9;border:1px solid rgba(0,0,0,.1);border-radius:16px;box-shadow:0 10px 40px #00000026,0 0 0 1px #ffffff80 inset;z-index:1500}.chat-history-panel.expanded{top:86px;left:50%;right:auto;transform:translate(-50%);width:min(1470px,96vw);height:calc(100vh - 156px);max-width:96vw;max-height:calc(100vh - 156px)}.chat-history-panel.expanded .resize-left,.chat-history-panel.expanded .resize-bottom{display:none}body.dark-mode .chat-history-panel{background:#1c1c1ed9;border-color:#ffffff1a;box-shadow:0 10px 40px #0006,0 0 0 1px #ffffff1a inset}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.resize-handle{position:absolute;z-index:10}.resize-left{left:0;top:0;bottom:0;width:8px;cursor:ew-resize;background:transparent}.resize-left:hover{background:#007aff26}.resize-bottom{left:0;right:0;bottom:0;height:8px;cursor:ns-resize;background:transparent}.resize-bottom:hover{background:#007aff26}.resize-bottom-left{left:0;bottom:0;width:16px;height:16px;cursor:nesw-resize;background:linear-gradient(225deg,transparent 40%,rgba(0,122,255,.3) 40%);border-radius:0 0 0 16px}.resize-bottom-left:hover{background:linear-gradient(225deg,transparent 40%,rgba(0,122,255,.5) 40%)}.resize-bottom-right{right:0;bottom:0;width:16px;height:16px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 40%,rgba(0,122,255,.3) 40%);border-radius:0 0 16px}.resize-bottom-right:hover{background:linear-gradient(135deg,transparent 40%,rgba(0,122,255,.5) 40%)}.chat-history-list{display:flex;flex-direction:column;gap:16px;padding:20px;overflow-y:auto;max-height:none;flex:1 1 auto;min-height:0;scroll-behavior:smooth}.history-item{display:flex;flex-direction:column;gap:6px;animation:slideUpFade .3s ease-out}.history-item.user{align-items:flex-end}.history-item.agent{align-items:flex-start}.msg-bubble{padding:10px 16px;border-radius:18px;font-size:.95rem;line-height:1.4;max-width:80%;position:relative;word-wrap:break-word}.history-item.user .msg-bubble{background-color:#007aff;color:#fff;border-bottom-right-radius:4px;box-shadow:0 1px 2px #0000001a}.history-item.agent .msg-bubble{background-color:#0000000d;color:var(--primary-text-color);border-bottom-left-radius:4px;border:1px solid rgba(0,0,0,.05)}body.dark-mode .history-item.agent .msg-bubble{background-color:#ffffff1a;border-color:#ffffff0d;color:var(--primary-text-color)}.msg-meta{font-size:.75rem;color:var(--muted-text-color);margin:0 4px;opacity:.7}.chat-history-footer{border-top:1px solid rgba(0,0,0,.05);padding:10px 16px;display:flex;justify-content:center;align-items:center;background-color:#fffffff2;margin-top:auto}body.dark-mode .chat-history-footer{border-top-color:#ffffff1a;background-color:#1c1c1ef2}.chat-history-clear,.chat-history-export{background:none;border:none;font-size:.85rem;color:var(--muted-text-color);cursor:pointer;opacity:.8;transition:opacity .2s}.chat-history-clear:hover,.chat-history-export:hover{opacity:1;text-decoration:underline}.chat-history-header{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.06);background-color:#ffffffeb;cursor:grab;-webkit-user-select:none;user-select:none}body.dark-mode .chat-history-header{border-bottom-color:#ffffff1f;background-color:#1c1c1eeb}.chat-history-title{font-size:.86rem;font-weight:600;color:var(--secondary-text-color);letter-spacing:.02em;text-transform:uppercase}.chat-history-expand{width:28px;height:28px;border-radius:8px;border:1px solid rgba(0,122,255,.28);background:#007aff1a;color:var(--accent-color);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color var(--transition-speed),transform var(--transition-speed)}.chat-history-expand:hover{background:#007aff29}.chat-history-panel.expanded .chat-history-expand{transform:rotate(180deg)}.chat-history-header .chat-history-export{margin-left:auto}.chat-history-input-row{display:none;align-items:center;gap:8px;width:100%}.chat-history-panel.expanded .chat-history-input-row{display:flex}#chat-history-input{flex:1 1 auto;background-color:#ffffffe0;color:#1f2937;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:.9rem}body.dark-mode #chat-history-input{background-color:#ffffff14;color:var(--primary-text-color)}#chat-history-send{background:linear-gradient(135deg,var(--accent-color),var(--accent-color-hover));color:#fff;border:none;border-radius:50%;width:34px;height:34px;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}#chat-history-send .send-icon{display:block}#chat-history-send .loading-spinner{display:none;animation:spin 1s linear infinite}#chat-history-send.loading .send-icon{display:none}#chat-history-send.loading .loading-spinner{display:block}.agent-waiting-indicator{display:inline-flex;align-items:center;gap:8px;color:var(--secondary-text-color)}.agent-waiting-indicator .waiting-refresh-icon{width:15px;height:15px;animation:spin .9s linear infinite}@keyframes popIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.msg-bubble code{font-family:SF Mono,Menlo,monospace;background:#00000014;padding:2px 4px;border-radius:4px;font-size:.9em}body.dark-mode .msg-bubble code{background:#ffffff26}@keyframes typingDot{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-4px);opacity:1}}.typing-dots{display:flex;gap:4px;align-items:center;height:20px;padding:4px 0}.typing-dots span{width:6px;height:6px;background-color:currentColor;border-radius:50%;animation:typingDot 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.cell.empty{background:var(--background-color);border:1px dashed var(--border-subtle);box-shadow:none;opacity:.35;pointer-events:none}.cell.empty img,.cell.empty .cell-label{opacity:0}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-3px) rotate(-.5deg)}40%{transform:translate(3px) rotate(.5deg)}60%{transform:translate(-3px) rotate(-.5deg)}80%{transform:translate(3px) rotate(.5deg)}}.shake-animation{animation:shake .4s cubic-bezier(.36,.07,.19,.97) both;color:#ff3b30!important;text-shadow:0 0 10px rgba(255,59,48,.2)}.view-controls input#cell-size.invalid-input{border:1.5px solid #ff3b30!important;background-color:#fff1f0!important;box-shadow:0 0 0 2px #ff3b301a!important;animation:shake .4s cubic-bezier(.36,.07,.19,.97) both}.modal-image{max-width:100%;max-height:100%;object-fit:contain;transition:transform .1s ease-out;cursor:grab;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.modal-image.grabbing{cursor:grabbing}.zoom-controls{position:static;display:flex;gap:8px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;padding:8px 12px;border-radius:20px;z-index:100;opacity:1;pointer-events:auto}.zoom-btn{background:color-mix(in srgb,var(--surface-color) 88%,transparent);border:1px solid color-mix(in srgb,var(--border-color) 82%,transparent);color:var(--text-color);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1;transition:all .2s ease;padding:0;box-shadow:0 10px 24px #0f172a1f}.zoom-btn:hover{background:color-mix(in srgb,var(--surface-color) 96%,var(--accent-color, #007aff) 4%);border-color:var(--accent-color, #007aff);color:var(--accent-color, #007aff);transform:translateY(-1px)}.zoom-btn:active{transform:translateY(0) scale(.95)}body.dark-mode .zoom-btn{background:#0f172aad;border-color:#ffffff38;color:#fffffff5;box-shadow:0 10px 24px #00000052}body.dark-mode .zoom-btn:hover{background:#0f172ae6;border-color:#bfdbfeeb;color:#fff}#zoom-reset-btn{width:auto;padding:0 10px;border-radius:16px;font-size:13px;font-weight:600}.training-controls{display:flex;align-items:center;position:relative;margin-left:12px}.training-controls #toggle-training{border-top-right-radius:0;border-bottom-right-radius:0;margin-right:0;position:relative;z-index:2;margin-left:-4px;height:36px;padding:0 1.25rem;display:flex;align-items:center;justify-content:center;border:1px solid transparent;border-right:1px solid rgba(255,255,255,.3);min-width:100px;font-weight:600}.training-mode-trigger{height:36px;padding:0;border:none;border-left:1px solid rgba(0,0,0,.08);border-top-right-radius:12px;border-bottom-right-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;min-width:26px;box-shadow:0 4px 12px #00000014}.training-controls #toggle-training.paused,.training-mode-trigger.paused{background-color:#34c75926!important;color:#34c759!important}.training-controls #toggle-training.running,.training-mode-trigger.running{background-color:#ff950026!important;color:#ff9500!important}.training-mode-trigger.paused{border-left-color:#34c7594d}.training-mode-trigger.running{border-left-color:#ff95004d}.training-mode-trigger.pending{background-color:#fef3c7e6!important;color:#b45309!important;border-left-color:#b4530959!important;cursor:not-allowed;opacity:.85}.training-mode-trigger:disabled{cursor:not-allowed}.training-controls #toggle-training.sandbox-disabled:hover,.training-mode-trigger.sandbox-disabled:hover,#toggle-auditor.sandbox-disabled:hover,#manual-data-save-btn.sandbox-disabled:hover{filter:none;transform:none;background-color:#e5e7ebeb!important}.training-mode-trigger:hover{filter:brightness(.9)}.training-mode-trigger:hover{background-color:var(--accent-color-hover)}.mode-option{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;background:#00000005;border:1px solid transparent;border-radius:14px;cursor:pointer;text-align:left;font-size:.95rem;color:var(--primary-text-color);transition:all .2s ease}.mode-option:hover{background-color:#0000000f;transform:translate(2px)}.mode-option.active{background-color:var(--accent-soft);color:var(--accent-color);border-color:#007aff26;font-weight:600}.mode-icon{font-size:1.25em;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px;box-shadow:0 2px 6px #0000000d}body.dark-mode .mode-icon{background:#ffffff1a}body.dark-mode .mode-option:hover{background-color:#ffffff1a}body.dark-mode .training-controls #toggle-training{border-right-color:#ffffff26}#training-mode-popover{left:auto;right:-50px;top:calc(100% + 10px);padding:8px;border-radius:16px;min-width:140px}#training-mode-popover .refresh-popover-label{margin-bottom:6px;margin-left:4px;font-size:.65rem}#training-mode-popover .mode-option{padding:6px 8px;border-radius:8px;font-size:.85rem;gap:8px}.workspace-row{padding-top:.75rem;overflow-y:hidden}.main-area{min-height:0}.main-content{min-height:0!important;height:100%;overflow-y:auto}.signals-board{flex:0 0 auto}.grid-wrapper{flex:0 0 auto;height:auto;min-height:0;overflow:visible}.mode-option.pending,.mode-option:disabled{cursor:not-allowed;opacity:.65;pointer-events:none}.inspector-panel-splitter{height:var(--resize-bar-thickness);border-radius:0;background:transparent;cursor:row-resize;margin:0;flex:0 0 var(--resize-bar-thickness);opacity:1;position:relative}#plots-board-resize-handle:hover:after,#grid-height-resize-handle:hover:after,.inspector-panel-splitter:hover:after{content:"Double click to auto resize";position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%);padding:6px 10px;border-radius:999px;background:#0f172ae6;color:#fff;font-size:.72rem;font-weight:600;line-height:1;letter-spacing:.01em;white-space:nowrap;pointer-events:none;z-index:40;box-shadow:0 10px 24px #0f172a2e}#inspector-resize-handle:hover:after,.modal-pane-resize-handle:hover:after{content:"Double click to auto resize";position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);padding:6px 10px;border-radius:999px;background:#0f172ae6;color:#fff;font-size:.72rem;font-weight:600;line-height:1;letter-spacing:.01em;white-space:nowrap;pointer-events:none;z-index:40;box-shadow:0 10px 24px #0f172a2e}body.dark-mode #plots-board-resize-handle:hover:after,body.dark-mode #grid-height-resize-handle:hover:after,body.dark-mode .inspector-panel-splitter:hover:after,body.dark-mode #inspector-resize-handle:hover:after,body.dark-mode .modal-pane-resize-handle:hover:after{background:#f4f4f5eb;color:#111827;box-shadow:0 10px 24px #00000052}.signals-board .inspector-panel-splitter.signal-card-splitter:hover:after,body.dark-mode .signals-board .inspector-panel-splitter.signal-card-splitter:hover:after{content:none}.inspector-panel-splitter:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,var(--border-color) 50%,transparent 100%);clip-path:polygon(0 50%,8% 42%,20% 30%,50% 12%,80% 30%,92% 42%,100% 50%,92% 58%,80% 70%,50% 88%,20% 70%,8% 58%)}.inspector-panel-splitter:hover:before,.inspector-panel-splitter.dragging:before{background:linear-gradient(90deg,transparent 0%,var(--accent-color) 50%,transparent 100%);animation:splitter-heartbeat 1s ease-in-out infinite;box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 42%,transparent),0 0 20px color-mix(in srgb,var(--accent-color) 60%,transparent)}.inspector-panel-splitter.dragging:before{box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-color) 48%,transparent),0 0 24px color-mix(in srgb,var(--accent-color) 68%,transparent)}.signals-board .inspector-panel-splitter.signal-card-splitter{margin:-6px 0}body.resizing-inspector-panels{-webkit-user-select:none;user-select:none;cursor:row-resize!important}body.resizing-inspector-panels *{cursor:row-resize!important}.grid-wrapper{position:relative}body.dark-mode #grid-height-resize-handle:hover:before,body.dark-mode #grid-height-resize-handle.dragging:before{background:linear-gradient(90deg,transparent 0%,var(--accent-color) 50%,transparent 100%)}@keyframes splitter-heartbeat{0%,to{transform:scale(.94);opacity:.72}40%{transform:scale(1.02);opacity:1}55%{transform:scale(.98);opacity:.9}72%{transform:scale(1.06);opacity:1}}.grid-wrapper-header{flex-shrink:0;position:sticky!important;top:0!important;z-index:300!important}.main-content .grid-wrapper{overflow-y:visible!important}.grid-wrapper-header-controls{display:flex;align-items:center;gap:.5rem;flex:1 1 auto;min-width:0}.grid-wrapper-header .collapse-btn{margin-left:.25rem;flex-shrink:0}.grid-settings-overlay.grid-settings-inline{position:static;top:auto;right:auto;left:auto;width:100%;margin:0;padding:.1rem 0;background:transparent;border:none;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:0;display:block;opacity:1;transform:none;pointer-events:auto;z-index:1}.grid-settings-overlay.grid-settings-inline.collapsed{display:none;opacity:0;pointer-events:none}.grid-settings-overlay.grid-settings-inline .view-controls{flex-direction:row;align-items:center;gap:.6rem;width:100%}.grid-settings-overlay.grid-settings-inline .control-group.resolution-group{min-width:0;flex:1 1 0;gap:4px}.grid-settings-overlay.grid-settings-inline .res-row-header label{font-size:.66rem}.grid-settings-overlay.grid-settings-inline .res-row-controls{gap:8px;padding:0}.grid-settings-overlay.grid-settings-inline .res-value{min-width:44px;font-size:.74rem}.grid-settings-overlay.grid-settings-inline .control-button{width:auto!important;margin-top:0!important;padding:.35rem .65rem;font-size:.75rem;white-space:nowrap}.grid-wrapper-collapsed #cells-grid{display:none!important}.grid-width-resize-handle{position:absolute;top:0;right:0;width:8px;height:100%;cursor:ew-resize;z-index:6}.grid-width-resize-handle:hover{background:linear-gradient(180deg,transparent 0%,var(--accent-color) 40%,var(--accent-color) 60%,transparent 100%);opacity:.35}body.resizing-grid-width{-webkit-user-select:none;user-select:none;cursor:ew-resize!important}body.resizing-grid-width *{cursor:ew-resize!important}.signal-card.is-dragging{opacity:.6;transform:scale(.99)}.ws-blocking-action-overlay{position:fixed;inset:0;z-index:20000;display:flex;align-items:center;justify-content:center}.ws-blocking-action-overlay.is-hidden{display:none}.ws-blocking-action-blur{position:absolute;inset:0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0a101c59}.ws-blocking-action-dialog{position:relative;width:min(540px,92vw);border-radius:16px;border:1px solid var(--border-color);background:var(--surface-color);box-shadow:0 24px 60px #00000047;padding:22px;display:flex;flex-direction:column;align-items:center;gap:12px}.ws-blocking-action-dismiss{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:999px;border:1px solid var(--border-color);background:var(--surface-elevated-color);color:var(--secondary-text-color);cursor:pointer;font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.ws-blocking-action-dismiss:hover{color:var(--primary-text-color);border-color:var(--accent-color)}.ws-blocking-action-title{font-size:1rem;font-weight:700;color:var(--primary-text-color);text-align:center}.ws-blocking-action-message{font-size:.92rem;color:var(--secondary-text-color);text-align:center}.ws-blocking-action-elapsed{font-size:.82rem;color:var(--secondary-text-color);text-align:center;opacity:.9}.ws-blocking-action-spinner{width:30px;height:30px;border-radius:50%;border:3px solid var(--border-color);border-top-color:var(--accent-color);animation:ws-blocking-spin 1s linear infinite}.ws-blocking-action-close{border:1px solid var(--border-color);background:var(--surface-elevated-color);color:var(--primary-text-color);border-radius:999px;padding:6px 14px;cursor:pointer}.metadata-histogram-btn{margin-left:6px;width:20px;height:20px;border-radius:50%;border:1px solid var(--border-color);background:var(--surface-color);color:var(--secondary-text-color);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.metadata-histogram-btn:hover{color:var(--accent-color);border-color:var(--accent-color)}.metadata-histogram-btn.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.metadata-histogram-track{position:absolute;inset:auto 0 0;height:56px;display:none;align-items:flex-end;justify-content:stretch;gap:1px;pointer-events:auto;z-index:0;padding:0 0 10px;cursor:pointer}.metadata-histogram-track.active{display:flex}.slider-wrapper:has(.metadata-histogram-track.active){min-height:64px;display:flex;align-items:flex-end}.metadata-histogram-bar{flex:1 1 auto;background:var(--accent-color);border-radius:2px 2px 0 0;transition:transform .12s ease,filter .12s ease,box-shadow .12s ease;pointer-events:auto;cursor:pointer}.metadata-histogram-bar:hover,.metadata-histogram-bar.hovered{transform:translateY(-1px) scaleY(1.03);filter:brightness(1.35) saturate(1.2);box-shadow:0 0 0 1px #ffffff8c,0 0 10px var(--accent-soft)}.metadata-histogram-tooltip{position:absolute;left:8px;bottom:calc(100% - 4px);transform:translate(-50%);padding:6px 8px;border-radius:6px;font-size:11px;line-height:1.2;color:#fff;background:#111827e6;border:1px solid rgba(255,255,255,.12);opacity:0;pointer-events:none;white-space:nowrap;z-index:4}.metadata-histogram-tooltip.active{opacity:1}.slider-wrapper .slider{position:relative;z-index:2}.metadata-histogram-error-toast{border:1px solid rgba(239,68,68,.45);background:#ef44441a;color:#ef4444;border-radius:8px;padding:8px 10px;font-size:12px}@keyframes ws-blocking-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-image.fit-to-container{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain}.modal-image.original-size{width:auto;height:auto;max-width:none;max-height:none;object-fit:none}
