*,:before,:after{box-sizing:border-box}body{margin:0}:root{--c-bg:#05080b;--c-surface:#090e13;--c-raised:#0d1620;--c-chrome:#f0a500;--c-chrome-dim:#f0a5002e;--c-chrome-glow:#f0a50059;--c-available:#00e87a;--c-preparing:#ffd600;--c-charging:#00b4ff;--c-finishing:#ff7048;--c-unavailable:#2e3f50;--c-faulted:#ff3348;--c-text:#8aa8bc;--c-text-hi:#c8dce8;--c-text-dim:#5a7a8e;--c-border:#111c26;--c-border-hi:#1a2d3e;--font:"Share Tech Mono", ui-monospace, monospace;--font-doc:"Inter", system-ui, sans-serif;font-family:var(--font);color:var(--c-text);-webkit-font-smoothing:antialiased;font-size:13px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--c-bg);background-image:radial-gradient(circle,#162030 1px,#0000 1px);background-size:22px 22px;min-height:100vh;margin:0}#root{min-height:100vh}.app{flex-direction:column;min-height:100vh;display:flex;position:relative}.app:after{content:"";pointer-events:none;z-index:9999;background:repeating-linear-gradient(#0000 0 3px,#0000000a 3px 4px);position:fixed;inset:0}.app-header{background:var(--c-surface);border-bottom:1px solid var(--c-chrome);align-items:center;gap:14px;height:48px;padding:0 20px;display:flex;position:relative;overflow:hidden}.app-header:before{content:"";background:var(--c-chrome);width:3px;position:absolute;top:0;bottom:0;left:0}.app-header:after{content:"";background:linear-gradient(to right, var(--c-chrome-dim), transparent);pointer-events:none;width:120px;position:absolute;top:0;bottom:0;left:3px}.app-logo{color:var(--c-chrome);z-index:1;font-size:18px;position:relative}.app-header h1{font-family:var(--font);letter-spacing:.2em;color:var(--c-chrome);text-transform:uppercase;z-index:1;font-size:13px;font-weight:400;position:relative}.app-header__spacer{flex:1}.app-header__meta{letter-spacing:.12em;color:var(--c-text-dim);font-size:11px}.app-main{background:var(--c-border-hi);flex:1;grid-template-columns:262px 330px 1fr;align-items:start;gap:1px;display:grid}.connectors-column{background:var(--c-surface);flex-direction:column;height:calc(100vh - 49px);display:flex;overflow:hidden}.connectors-column__header{border-bottom:1px solid var(--c-border-hi);background:var(--c-raised);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.connectors-column__title{letter-spacing:.2em;color:var(--c-chrome);-webkit-user-select:none;user-select:none;font-size:14px}.connectors-list{scrollbar-width:thin;scrollbar-color:var(--c-border-hi) transparent;flex:1;overflow-y:auto}.connectors-list::-webkit-scrollbar{width:3px}.connectors-list::-webkit-scrollbar-thumb{background:var(--c-border-hi)}.connectors-list .connector-card{border-bottom:1px solid var(--c-border-hi);min-height:auto}.btn-add{font-family:var(--font);letter-spacing:.15em;cursor:pointer;border:1px solid var(--c-chrome-dim);color:var(--c-chrome);background:0 0;border-radius:0;padding:4px 10px;font-size:10px;transition:background .15s,box-shadow .15s}.btn-add:hover{background:var(--c-chrome-dim);box-shadow:0 0 8px var(--c-chrome-glow)}.connector-card__title{justify-content:space-between;align-items:center;display:flex}.btn-remove{cursor:pointer;color:var(--c-text-dim);font-size:11px;line-height:1;font-family:var(--font);background:0 0;border:none;padding:2px 4px;transition:color .15s}.btn-remove:hover:not(:disabled){color:var(--c-faulted)}.btn-remove:disabled{opacity:.25;cursor:not-allowed}.status-override{border:1px solid var(--c-border-hi);border-left:2px solid var(--c-chrome-dim);background:color-mix(in srgb, var(--c-chrome) 3%, var(--c-raised));flex-direction:column;gap:6px;padding:10px;display:flex}.status-override__label{letter-spacing:.18em;color:var(--c-text-dim);font-size:9px}.status-override__row{gap:6px;display:flex}.status-select{background:var(--c-bg);border:1px solid var(--c-border-hi);color:var(--c-text-hi);font-family:var(--font);appearance:none;cursor:pointer;outline:none;flex:1;padding:6px 8px;font-size:12px}.status-select:focus{border-color:var(--c-chrome)}.status-select:disabled{opacity:.28;cursor:not-allowed}.status-select option{background:var(--c-surface);color:var(--c-text-hi)}.btn-set{font-family:var(--font);letter-spacing:.15em;cursor:pointer;border:1px solid var(--c-border-hi);color:var(--c-text);white-space:nowrap;background:0 0;border-radius:0;padding:6px 14px;font-size:10px;transition:background .15s,color .15s}.btn-set:hover:not(:disabled){background:var(--c-chrome-dim);color:var(--c-chrome);border-color:var(--c-chrome-dim)}.btn-set:disabled{opacity:.28;cursor:not-allowed}.panel{background:var(--c-surface);flex-direction:column;min-height:calc(100vh - 49px);display:flex}.panel-title{letter-spacing:.2em;color:var(--c-chrome);border-bottom:1px solid var(--c-border-hi);background:var(--c-raised);-webkit-user-select:none;user-select:none;flex-shrink:0;padding:10px 16px;font-size:14px}.panel-body{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex}.field{flex-direction:column;gap:4px;display:flex}.field span{letter-spacing:.18em;color:var(--c-text-dim);font-size:10px}.field input{background:var(--c-bg);border:1px solid var(--c-border-hi);border-left:2px solid var(--c-chrome-dim);color:var(--c-text-hi);font-family:var(--font);border-radius:0;outline:none;width:100%;padding:7px 10px;font-size:13px;transition:border-color .15s,box-shadow .15s}.field input:focus{border-color:var(--c-chrome);box-shadow:0 0 0 1px var(--c-chrome-dim), 0 0 10px var(--c-chrome-dim)}.field input:disabled{opacity:.28;cursor:not-allowed}.btn{font-family:var(--font);letter-spacing:.18em;cursor:pointer;background:0 0;border:1px solid;border-radius:0;width:100%;padding:9px 16px;font-size:11px;transition:background .15s,box-shadow .15s;position:relative}.btn:disabled{opacity:.28;cursor:not-allowed}.btn-primary{color:var(--c-chrome)}.btn-primary:hover:not(:disabled){background:var(--c-chrome-dim);box-shadow:0 0 14px var(--c-chrome-glow), inset 0 0 14px var(--c-chrome-dim)}.btn-danger{color:var(--c-faulted)}.btn-danger:hover:not(:disabled){background:#ff33481f;box-shadow:0 0 14px #ff33484d}.status-badge{border:1px solid var(--c-border-hi);letter-spacing:.15em;align-items:center;gap:10px;padding:8px 12px;font-size:11px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.status-connected{border-color:var(--c-available);color:var(--c-available)}.status-connected .status-dot{background:var(--c-available);box-shadow:0 0 6px var(--c-available)}.status-connecting{border-color:var(--c-preparing);color:var(--c-preparing)}.status-connecting .status-dot{background:var(--c-preparing);animation:.8s infinite blink}.status-disconnected{border-color:var(--c-border-hi);color:var(--c-text-dim)}.status-disconnected .status-dot{background:var(--c-text-dim)}.cp-lamp-wrap--available{--lamp-color:var(--c-available)}.cp-lamp-wrap--preparing{--lamp-color:var(--c-preparing)}.cp-lamp-wrap--charging{--lamp-color:var(--c-charging)}.cp-lamp-wrap--finishing{--lamp-color:var(--c-finishing)}.cp-lamp-wrap--unavailable{--lamp-color:var(--c-unavailable)}.cp-lamp-wrap--faulted{--lamp-color:var(--c-faulted)}.cp-lamp-wrap--suspendedevse,.cp-lamp-wrap--suspendedev{--lamp-color:var(--c-finishing)}.cp-lamp-wrap--reserved{--lamp-color:#a855f7}.cp-lamp-wrap{filter:drop-shadow(0 0 16px var(--lamp-color,transparent));justify-content:center;padding:12px 0 8px;transition:filter .5s;display:flex}.cp-lamp{clip-path:polygon(18% 0%,82% 0%,100% 18%,100% 82%,82% 100%,18% 100%,0% 82%,0% 18%);background:color-mix(in srgb, var(--lamp-color,var(--c-border)) 9%, var(--c-raised));flex-direction:column;justify-content:center;align-items:center;gap:4px;width:170px;height:170px;transition:background .4s;display:flex;position:relative}.cp-lamp:before{content:"";clip-path:polygon(18% 0%,82% 0%,100% 18%,100% 82%,82% 100%,18% 100%,0% 82%,0% 18%);border:1px solid color-mix(in srgb, var(--lamp-color,transparent) 30%, transparent);position:absolute;inset:8px}.cp-lamp__icon{color:var(--lamp-color,var(--c-text-dim));margin-bottom:2px;font-size:26px;line-height:1}.cp-lamp__state{letter-spacing:.25em;color:var(--lamp-color,var(--c-text-dim));font-size:13px}.cp-lamp__sub{letter-spacing:.15em;color:var(--c-text-dim);margin-top:2px;font-size:9px}.cp-lamp--preparing{animation:1s ease-in-out infinite lamp-prep}.cp-lamp--charging{animation:2s ease-in-out infinite lamp-charge}.cp-lamp--faulted{animation:.5s ease-in-out infinite lamp-fault}@keyframes lamp-prep{0%,to{opacity:1}50%{opacity:.55}}@keyframes lamp-charge{0%,to{filter:brightness()}50%{filter:brightness(1.35)}}@keyframes lamp-fault{0%,to{opacity:1}50%{opacity:.3}}.tx-readout{border:1px solid var(--c-border-hi);border-left:2px solid var(--c-chrome-dim)}.tx-readout__header{letter-spacing:.18em;color:var(--c-chrome);background:color-mix(in srgb, var(--c-chrome) 5%, var(--c-raised));border-bottom:1px solid var(--c-border-hi);padding:6px 10px;font-size:10px}.tx-readout__grid{background:var(--c-border);grid-template-columns:1fr 1fr;gap:1px;display:grid}.tx-cell{background:var(--c-raised);flex-direction:column;gap:4px;padding:8px 10px;display:flex}.tx-cell__label{letter-spacing:.18em;color:var(--c-text-dim);font-size:9px}.tx-cell__value{color:var(--c-text-hi);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.tx-cell__value--duration{color:var(--c-available);letter-spacing:.05em;font-size:17px}.tx-cell__value--energy{color:var(--c-charging);letter-spacing:.02em;font-size:20px}.tx-cell__unit{opacity:.6;font-size:11px}.log-panel{height:calc(100vh - 49px)}.log-panel .panel-body{padding:0;overflow:hidden}.log-count{letter-spacing:.1em;color:var(--c-text-dim);margin-left:auto;font-size:12px}.log-list{scrollbar-width:thin;scrollbar-color:var(--c-border-hi) transparent;flex:1;overflow-y:auto}.log-list::-webkit-scrollbar{width:3px}.log-list::-webkit-scrollbar-thumb{background:var(--c-border-hi)}.log-empty{text-align:center;letter-spacing:.15em;color:var(--c-text-dim);padding:40px 20px;font-size:11px}.log-entry{border-bottom:1px solid var(--c-border);cursor:pointer;border-left:2px solid #0000;padding:7px 14px;transition:background .1s}.log-entry:hover{background:var(--c-raised)}.log-entry--sent{border-left-color:var(--c-charging)}.log-entry--received{border-left-color:var(--c-available)}.log-entry--error{border-left-color:var(--c-faulted)}.log-entry__header{align-items:center;gap:7px;font-size:11px;display:flex}.log-dir{color:var(--c-text-dim);flex-shrink:0;width:14px;font-size:9px}.log-entry--sent .log-dir{color:var(--c-charging)}.log-entry--received .log-dir{color:var(--c-available)}.log-tag{letter-spacing:.1em;border:1px solid;flex-shrink:0;padding:1px 5px;font-size:9px}.log-tag--sent{color:var(--c-charging);border-color:var(--c-charging)}.log-tag--received{color:var(--c-available);border-color:var(--c-available)}.log-err-badge{border:1px solid var(--c-faulted);color:var(--c-faulted);letter-spacing:.1em;padding:1px 5px;font-size:9px}.log-action{color:var(--c-text-hi);letter-spacing:.04em;flex:1}.log-ts{color:var(--c-text-dim);font-size:10px}.log-preview{color:var(--c-text-dim);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;padding-left:21px;font-size:11px;overflow:hidden}.log-payload{font-family:var(--font);color:var(--c-text);background:var(--c-raised);border:1px solid var(--c-border-hi);border-left:2px solid var(--c-chrome-dim);white-space:pre-wrap;word-break:break-all;margin:6px 0 4px 21px;padding:8px 10px;font-size:11px}@keyframes blink{0%,to{opacity:1}50%{opacity:.15}}.btn-help{width:100%;font-family:var(--font);letter-spacing:.1em;cursor:pointer;border:1px dashed var(--c-border-hi);color:var(--c-text-dim);text-align:center;background:0 0;border-radius:0;padding:7px 12px;font-size:12px;transition:color .15s,border-color .15s}.btn-help:hover{color:var(--c-chrome);border-color:var(--c-chrome-dim)}
