:root{--bg:#0f1116;--panel:#181b22;--panel-2:#1f232b;--border:#2a2e38;--text:#c9d1d9;--text-dim:#8b95a4;--accent:#4f9eff;--green:#3fb950;--red:#f85149;--orange:#f0883e;--yellow:#d29922;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font:14px/1.5 system-ui,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body,#root{min-height:100vh;margin:0}h1,h2,h3{color:#fff;font-weight:600}h1{margin:0 0 12px;font-size:18px}h2{margin:0 0 6px;font-size:20px}small{color:var(--text-dim);font-size:12px}label{color:var(--text-dim);font-size:12px;display:block}input,select,textarea{background:var(--bg);width:100%;color:var(--text);border:1px solid var(--border);font:inherit;border-radius:4px;padding:6px 10px}input:focus,select:focus{outline:1px solid var(--accent)}button{border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;font:inherit;border-radius:4px;padding:6px 12px}button:hover:not(:disabled){background:var(--border)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover:not(:disabled){filter:brightness(1.1)}button.danger{border-color:var(--red);color:var(--red);background:0 0}button.danger:hover:not(:disabled){background:var(--red);color:#fff}.app{grid-template-columns:240px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;padding:16px;display:flex}.station-list{flex-direction:column;flex:1;gap:4px;margin-bottom:12px;display:flex;overflow-y:auto}.station-link{color:var(--text);border-radius:4px;grid-template-columns:10px 1fr auto;align-items:center;gap:8px;padding:8px 10px;font-size:13px;text-decoration:none;display:grid}.station-link:hover{background:var(--panel-2)}.station-link.active{background:var(--panel-2);color:#fff}.station-link .identity{font-weight:500}.dot{background:var(--text-dim);border-radius:50%;width:8px;height:8px}.dot.on{background:var(--green);box-shadow:0 0 6px var(--green)}.dot.off{background:var(--text-dim)}.new-btn{background:var(--panel-2);border:1px dashed var(--border);text-align:center;color:var(--text);border-radius:4px;padding:8px 12px;font-size:13px;text-decoration:none;display:block}.new-btn:hover{border-color:var(--accent);color:var(--accent)}.empty{text-align:center;color:var(--text-dim);padding:16px;font-size:12px}.empty-main{color:var(--text-dim);padding:32px}.main{max-height:100vh;padding:24px;overflow-y:auto}.form{max-width:800px}.form fieldset{border:1px solid var(--border);border-radius:6px;margin-bottom:16px;padding:16px}.form legend{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;padding:0 8px;font-size:12px}.form label{margin-bottom:12px}.form input,.form select{margin-top:4px}.form .row{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.form .connector-row{grid-template-columns:80px 120px 100px 100px 110px 32px;align-items:end;gap:12px;margin-bottom:8px;display:grid}.form .rm{border-color:var(--red);color:var(--red);background:0 0;padding:4px 8px}.form .add{margin-top:8px}.form-actions{justify-content:flex-end;gap:8px;display:flex}.error{border:1px solid var(--red);color:var(--red);background:#f851491a;border-radius:4px;margin:8px 0;padding:8px 12px;font-size:13px}.control{flex-direction:column;gap:16px;min-height:calc(100vh - 48px);display:flex}.control-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.control-header .actions{align-items:center;gap:8px;display:flex}.badge{letter-spacing:.5px;border-radius:10px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.badge.on{color:var(--green);background:#3fb95033}.badge.off{color:var(--text-dim);background:#8b95a433}.control-body{flex:1;grid-template-columns:1fr 520px;gap:16px;min-height:0;display:grid}.connectors{flex-direction:column;gap:12px;min-width:0;display:flex}.connector-card{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:16px}.cc-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cc-title{color:#fff;font-weight:600}.cc-title small{margin-left:8px;font-weight:400}.status-badge{letter-spacing:.5px;border-radius:10px;padding:3px 10px;font-size:11px;font-weight:600}.status-avail{color:var(--green);background:#3fb95026}.status-prep{color:var(--yellow);background:#d2992226}.status-charging{color:var(--accent);background:#4f9eff33;animation:2s ease-in-out infinite pulse}.status-suspended{color:var(--orange);background:#f0883e33}.status-finishing{color:var(--yellow);background:#d2992226}.status-off{color:var(--text-dim);background:#8b95a426}.status-fault{color:var(--red);background:#f8514933}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}.soc{margin:14px 0}.soc-bar{background:var(--panel-2);border:1px solid var(--border);border-radius:14px;height:28px;position:relative;overflow:hidden}.soc-fill{background:linear-gradient(90deg,#3fb950,#4f9eff);height:100%;transition:width .6s}.soc-label{color:#fff;text-shadow:0 1px 2px #00000080;justify-content:center;align-items:center;font-weight:600;display:flex;position:absolute;inset:0}.metrics{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px;display:grid}.metrics div{background:var(--panel-2);border-radius:4px;padding:8px 12px}.metrics label{text-transform:uppercase;letter-spacing:.5px;font-size:11px}.metrics span{color:#fff;font-size:16px;font-weight:600}.cc-actions{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.log-panel{background:var(--panel);border:1px solid var(--border);border-radius:8px;flex-direction:column;min-height:0;display:flex;overflow:hidden}.ocpp-log{flex-direction:column;height:100%;min-height:0;display:flex}.ocpp-log header{border-bottom:1px solid var(--border);color:#fff;background:var(--panel-2);padding:10px 14px;font-weight:600}.ocpp-log ol{flex:1;margin:0;padding:0;font-family:ui-monospace,Consolas,monospace;font-size:11px;list-style:none;overflow-y:auto}.ocpp-log li{border-bottom:1px solid var(--border)}.log-row{text-align:left;width:100%;font:inherit;cursor:pointer;color:var(--text);background:0 0;border:none;grid-template-columns:80px 16px 140px 1fr;gap:8px;padding:4px 12px;display:grid}.log-row:hover{background:var(--panel-2)}.log-row .ts{color:var(--text-dim)}.log-row .dir{font-weight:700}.in .log-row .dir{color:var(--accent)}.out .log-row .dir{color:var(--orange)}.log-row .action{color:#fff;font-weight:500}.log-row .preview{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.payload{background:var(--bg);border-top:1px solid var(--border);white-space:pre-wrap;word-break:break-all;color:var(--text-dim);margin:0;padding:8px 14px;font-size:11px}.login-page{background:var(--bg);justify-content:center;align-items:center;height:100vh;display:flex}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:12px;width:320px;padding:28px 28px 24px;display:flex}.login-card h2{margin:0}.login-card .muted{color:var(--text-dim);margin:0 0 8px;font-size:13px}.login-card label{color:var(--text-dim);flex-direction:column;gap:4px;font-size:12px;display:flex}.login-card input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:4px;padding:8px 10px;font-size:14px}.login-card .error{color:#f3a;background:#dc3c3c26;border-radius:4px;padding:6px 10px;font-size:12px}.login-card button{margin-top:6px;padding:9px}.who{border-top:1px solid var(--border);color:var(--text-dim);justify-content:space-between;align-items:center;padding:10px 14px;font-size:12px;display:flex}.who strong{color:var(--text)}.link-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px}.link-btn:hover{text-decoration:underline}
