:root{--accent:#4f8ef7;--accent2:#7c3aed;--btn-primary:#4f8ef7;--radius:6px;--radius-sm:4px;--radius-lg:6px;--border-color:#1f2937;--input-bg:#1f2937;--text-main:#f3f4f6}html.light{--border-color:#e2e8f0;--input-bg:#edf0f3;--text-main:#1e293b}header.topbar,main{opacity:0;pointer-events:none;transition:opacity .2s ease}html.tw-ready header.topbar,html.tw-ready main{opacity:1;pointer-events:auto}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#374151;border-radius:99px}html.light ::-webkit-scrollbar-thumb{background:#cbd5e1}body{background-color:#030712;color:#f3f4f6;font-family:Inter,sans-serif;transition:background-color .2s,color .2s;padding-top:60px}html.light body{background-color:#e8edf3;color:#1e293b}header.topbar{position:fixed;top:0;left:0;width:100%;z-index:50;background-color:#111827;border-bottom:1px solid #1f2937;box-shadow:0 2px 10px rgba(0,0,0,.3)}html.light header.topbar{background-color:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 10px rgba(0,0,0,.05)}.c-card{background-color:#111827;border:1px solid #1f2937;border-radius:var(--radius);box-shadow:0 4px 6px rgba(0,0,0,.2);transition:background-color .2s,border-color .2s}html.light .c-card{background-color:#fff;border-color:#e2e8f0;box-shadow:0 2px 4px rgba(0,0,0,.05)}.c-card-header{border-bottom:1px solid #1f2937;display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;gap:24px}html.light .c-card-header{border-bottom:1px solid #e2e8f0}.c-border-t{border-top:1px solid #374151;transition:border-color .2s}html.light .c-border-t{border-top:1px solid #cbd5e1}.c-card-header h2 i{color:var(--accent)!important}.c-title{color:#e2e8f0;transition:color .2s}html.light .c-title{color:#334155}.field-label{display:block;font-size:10px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}html.light .field-label{color:#64748b}.field-input{width:100%;padding:8px 12px;background-color:var(--input-bg);border:none;border-radius:var(--radius);color:#f3f4f6;font-size:13px;outline:0;transition:box-shadow .2s}.field-input:focus{outline:0;box-shadow:0 0 0 2px rgba(79,142,247,.3)}html.light .field-input{background-color:var(--input-bg);border:none;color:#0f172a}html.light .field-input:focus{outline:0;box-shadow:0 0 0 2px rgba(79,142,247,.2)}.field-input:disabled,.field-input[readonly]{background-color:var(--input-bg);border:none;color:#9ca3af;cursor:not-allowed}html.light .field-input:disabled,html.light .field-input[readonly]{background-color:var(--input-bg);border:none;color:#64748b}.checkbox-card{display:flex;align-items:center;gap:12px;padding:10px 12px;background-color:#1a2235;border:1px solid #1f2937;border-radius:var(--radius);transition:background-color .2s,border-color .2s}.checkbox-card>label{color:#cbd5e1}html.light .checkbox-card{background-color:#edf0f3;border-color:#dde3ea}html.light .checkbox-card>label{color:#334155}.group-container{padding:14px;background-color:rgba(26,34,53,.4);border:1px solid #1f2937;border-radius:var(--radius);transition:background-color .2s,border-color .2s}html.light .group-container{background-color:rgba(241,245,249,.4);border-color:#e2e8f0}.dispenser-card{display:flex;flex-direction:column;background-color:var(--input-bg);border:1px solid #374151;border-radius:var(--radius);padding:6px;box-shadow:0 1px 2px rgba(0,0,0,.15);transition:background-color .2s,border-color .2s}html.light .dispenser-card{background-color:var(--input-bg);border-color:#e2e8f0;box-shadow:0 1px 2px rgba(0,0,0,.05)}.dispenser-card label{font-size:8px;font-weight:700;color:#9ca3af;text-align:center;margin-bottom:2px;text-transform:uppercase}html.light .dispenser-card label{color:#64748b}.dispenser-card input{width:100%;text-align:center;font-size:12px;font-weight:700;background-color:var(--input-bg);border:none;outline:0;color:#f3f4f6}html.light .dispenser-card input{color:#0f172a}.topbar-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#1f2937;border:none;color:#9ca3af;cursor:pointer;font-size:13px;transition:all .2s}.topbar-btn:hover{background-color:#374151;color:#f3f4f6}html.light .topbar-btn{background-color:var(--input-bg);border:none;color:#64748b}html.light .topbar-btn:hover{background-color:var(--border-color);color:#1e293b}.json-display{background-color:#0c101a;border:1px solid var(--border-color,#1f2937);border-radius:var(--radius)}html.light .json-display{background-color:#f8f9fa;border-color:#e2e8f0}html.light #json-output{color:#64748b}.json-icons{background-color:rgba(12,16,26,.9);border:1px solid var(--border-color,#1f2937)}html.light .json-icons{background-color:rgba(248,249,250,.9);border-color:#e2e8f0}.json-icon-btn{color:#9ca3af;font-size:.875rem;transition:color .2s}.json-icon-btn:hover{color:#f3f4f6}html.light .json-icon-btn{color:#64748b}html.light .json-icon-btn:hover{color:#1e293b}.json-title{color:#9ca3af;transition:color .2s}.json-title i{color:var(--accent)!important}html.light .json-title{color:#475569}html.light .json-title i{color:#2563eb!important}.btn{background-color:var(--accent);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius);cursor:pointer;font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color .2s,box-shadow .2s}.btn:hover{filter:brightness(1.1)}.btn-success{background-color:#10b981}.btn-danger{background-color:#ef4444}.btn-warning{background-color:#6b7280}.btn-outline{background-color:transparent;border:1px solid var(--border-color);color:var(--text-main)}.btn-outline:hover{background-color:var(--input-bg)}.connection-status{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:8px;font-size:.75rem;font-weight:600;border:1px solid transparent}.status-connected{background-color:rgba(16,185,129,.1);color:#10b981;border-color:rgba(16,185,129,.2)}.status-disconnected{background-color:rgba(239,68,68,.1);color:#ef4444;border-color:rgba(239,68,68,.2)}.status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-connected .status-indicator{background-color:#10b981;box-shadow:0 0 6px #10b981}.status-disconnected .status-indicator{background-color:#ef4444;box-shadow:0 0 6px #ef4444}.process-item{padding:12px 14px;margin-bottom:10px;background-color:#1f2937;border-radius:var(--radius);cursor:pointer;transition:all .2s ease;border-left:4px solid #3498db;border-top:none;border-right:none;border-bottom:none;color:#f3f4f6;box-shadow:0 2px 4px rgba(0,0,0,.15)}.process-item:hover{background-color:#374151;transform:translateY(-1px)}.process-item.active{background-color:rgba(52,152,219,.15);border-left-color:#3498db;border-color:rgba(52,152,219,.3)}.process-name{font-weight:700;font-size:.95rem;margin-bottom:4px;color:#fff}.process-item.active .process-name{color:#3498db}.process-details{font-size:.8rem;color:#9ca3af}html.light .process-item{background-color:#eaedf0;border-top:none;border-right:none;border-bottom:none;color:#334155;box-shadow:0 1px 2px rgba(0,0,0,.05)}html.light .process-item:hover{background-color:#dde3ea}html.light .process-item.active{background-color:#e0f2fe;border-left-color:#2980b9;border-color:rgba(52,152,219,.2)}html.light .process-name{color:#1e293b}html.light .process-item.active .process-name{color:#2980b9}html.light .process-details{color:#64748b}.stage-item{padding:12px 14px;margin-bottom:10px;background-color:#1f2937;border-radius:var(--radius);cursor:pointer;transition:all .2s ease;border-left:4px solid #f39c12;border-top:none;border-right:none;border-bottom:none;color:#f3f4f6;box-shadow:0 2px 4px rgba(0,0,0,.15)}.stage-item:hover{background-color:#374151;transform:translateY(-1px)}.stage-item.active{background-color:rgba(243,156,18,.15);border-left-color:#f39c12;border-color:rgba(243,156,18,.3)}.stage-name{font-weight:700;font-size:.95rem;margin-bottom:4px;color:#fff}.stage-item.active .stage-name{color:#f39c12}.stage-details{font-size:.8rem;color:#9ca3af}html.light .stage-item{background-color:#eaedf0;border-top:none;border-right:none;border-bottom:none;color:#334155;box-shadow:0 1px 2px rgba(0,0,0,.05)}html.light .stage-item:hover{background-color:#dde3ea}html.light .stage-item.active{background-color:#fef3c7;border-left-color:#d35400;border-color:rgba(243,156,18,.2)}html.light .stage-name{color:#1e293b}html.light .stage-item.active .stage-name{color:#d35400}html.light .stage-details{color:#64748b}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center;color:#9ca3af;background-color:rgba(255,255,255,.01);border:2px dashed rgba(255,255,255,.05);border-radius:var(--radius)}.empty-state i{font-style:normal;font-size:2.25rem;margin-bottom:12px;opacity:.6}html.light .empty-state{background-color:rgba(0,0,0,.01);border-color:rgba(0,0,0,.08);color:#64748b}.progress-overlay{position:fixed;inset:0;background-color:rgba(3,7,18,.85);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:9999;flex-direction:column;padding:16px;box-sizing:border-box}html.light .progress-overlay{background-color:rgba(15,23,42,.45)}.progress-dialog{background-color:var(--bg-card,#111827);border:1px solid var(--border-color,#1f2937);padding:32px;border-radius:var(--radius,12px);box-shadow:0 25px 50px -12px rgba(0,0,0,.6);text-align:center;min-width:300px;max-width:calc(100vw - 48px);display:flex;flex-direction:column;align-items:center;gap:16px;animation:zoomIn .25s cubic-bezier(.16,1,.3,1)}html.light .progress-dialog{background-color:#fff;border-color:#e2e8f0;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04)}.spinner{border:3px solid var(--border-color,#1f2937);border-top:3px solid var(--accent-color,#4f8ef7);border-radius:50%;width:48px;height:48px;animation:spin 1s linear infinite}html.light .spinner{border-color:#e2e8f0;border-top-color:var(--accent-color,#4f8ef7)}#progress-message{font-size:.95rem;font-weight:700;color:var(--text-main,#f3f4f6)}html.light #progress-message{color:#0f172a}@keyframes spin{to{transform:rotate(360deg)}}@keyframes zoomIn{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.toast-container{position:fixed;bottom:24px;right:24px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:380px;width:calc(100% - 48px)}.toast{padding:12px 16px;border-radius:var(--radius);color:#fff;box-shadow:0 10px 15px -3px rgba(0,0,0,.3);display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.85rem;font-weight:600;animation:toastSlideIn .3s cubic-bezier(.16,1,.3,1);transition:all .3s ease;border:1px solid transparent}.toast-success{background-color:rgba(46,204,113,.95);border-color:rgba(46,204,113,.25)}.toast-error{background-color:rgba(231,76,60,.95);border-color:rgba(231,76,60,.25)}.toast-warning{background-color:rgba(243,156,18,.95);border-color:rgba(243,156,18,.25)}.toast-info{background-color:rgba(52,152,219,.95);border-color:rgba(52,152,219,.25)}.toast-message{flex:1}.toast-close{background:0 0;border:none;color:rgba(255,255,255,.7);font-size:1.25rem;cursor:pointer;line-height:1;transition:color .2s;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.toast-close:hover{color:#fff}@keyframes toastSlideIn{from{transform:translateY(12px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}