:root{--bg-0: #ffffff;--bg-1: #f6f9fd;--bg-2: #eef3fa;--card: rgba(255, 255, 255, .92);--card-strong: #ffffff;--card-border: rgba(28, 50, 90, .1);--card-border-strong: rgba(28, 50, 90, .18);--text: #0f1d36;--text-2: #5a6786;--muted: #8d97b1;--brand: #61B6FF;--brand-deep: #2d8fe0;--brand-soft: rgba(97, 182, 255, .12);--grid: #61B6FF;--grid-glow: #88c8ff;--house: #2d8fe0;--chargers: #1ab692;--chargers-glow: #38d4af;--good: #1ab692;--warn: #e89b1f;--bad: #e0455f;--shadow-sm: 0 1px 2px rgba(28, 50, 90, .06);--shadow-md: 0 6px 18px rgba(28, 50, 90, .08);--shadow-lg: 0 18px 48px rgba(28, 50, 90, .14);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;height:100%}body{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-feature-settings:"ss01","cv01","cv11";font-size:14px;line-height:1.5;color:var(--text);background:radial-gradient(ellipse at 5% 0%,rgba(97,182,255,.18) 0%,transparent 55%),radial-gradient(ellipse at 95% 0%,rgba(97,182,255,.1) 0%,transparent 55%),radial-gradient(ellipse at 50% 100%,rgba(45,143,224,.08) 0%,transparent 55%),var(--bg-1);background-attachment:fixed;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}code{font-family:JetBrains Mono,monospace;font-size:.92em}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#1c325a26;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#1c325a4d}button{font:inherit;font-weight:600;letter-spacing:.01em;background:linear-gradient(135deg,var(--brand),var(--brand-deep));color:#fff;border:none;padding:10px 20px;border-radius:10px;cursor:pointer;transition:transform .12s ease,box-shadow .25s ease,opacity .15s;display:inline-flex;align-items:center;gap:8px}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #61b6ff73}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.45;cursor:not-allowed}button.ghost{background:#fff;border:1px solid var(--card-border-strong);color:var(--text)}button.ghost:hover:not(:disabled){background:var(--bg-2);box-shadow:none}button.danger{background:linear-gradient(135deg,#e0455f,#c93a52)}button.danger:hover:not(:disabled){box-shadow:0 6px 20px #e0455f59}button.sm{padding:6px 12px;font-size:12px}input,select,textarea{font:inherit;background:#fff;color:var(--text);border:1px solid var(--card-border-strong);padding:10px 14px;border-radius:10px;width:100%;transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #61b6ff33}label{display:block;font-size:11px;color:var(--text-2);margin-bottom:6px;letter-spacing:.06em;text-transform:uppercase;font-weight:600}.field{margin-bottom:16px}.row{display:flex;gap:14px;align-items:center;flex-wrap:wrap}.row>.field{flex:1;min-width:160px}.row.spread{justify-content:space-between}.app-shell{display:grid;grid-template-columns:250px 1fr;min-height:100vh}.sidebar{background:#ffffffd9;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-right:1px solid var(--card-border);padding:20px 14px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}.sidebar .brand{display:flex;align-items:center;gap:12px;padding:8px 8px 24px;border-bottom:1px solid var(--card-border);margin-bottom:16px}.sidebar .brand.brand-wordmark{display:block;text-align:left}.sidebar .brand-logo{display:block;height:36px;width:auto;max-width:100%;margin-bottom:8px}.sidebar .brand-name{font-weight:700;font-size:16px;line-height:1.2;color:var(--text)}.sidebar .brand-sub{font-size:10.5px;color:var(--text-2);letter-spacing:.06em;text-transform:uppercase;margin-top:2px;font-family:JetBrains Mono,monospace}.nav-group{font-size:10px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;padding:14px 12px 6px;font-weight:700}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--text-2);font-weight:500;font-size:13.5px;transition:background .15s,color .15s;border-left:2px solid transparent}.nav-item:hover{background:var(--brand-soft);color:var(--text)}.nav-item.active{background:var(--brand-soft);color:var(--text);border-left-color:var(--brand)}.nav-item .ico{width:16px;height:16px;opacity:.7;flex-shrink:0}.nav-item.active .ico{opacity:1;color:var(--brand)}.sidebar .footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--card-border);display:flex;flex-direction:column;gap:10px}.user-pill{display:flex;align-items:center;gap:10px;padding:10px;background:var(--bg-2);border-radius:10px}.user-pill .avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--brand),var(--brand-deep));border-radius:50%;display:grid;place-items:center;font-weight:700;color:#fff;font-size:13px;flex-shrink:0}.user-pill .meta{flex:1;min-width:0;overflow:hidden}.user-pill .meta .n{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.user-pill .meta .r{font-size:11px;color:var(--text-2);text-transform:capitalize}.lang-toggle{display:flex;gap:4px;background:var(--bg-2);border-radius:8px;padding:4px}.lang-toggle button{flex:1;background:transparent;border:none;color:var(--text-2);padding:5px 8px;font-size:11.5px;border-radius:6px;font-weight:600}.lang-toggle button:hover{background:#61b6ff1a;box-shadow:none;transform:none}.lang-toggle button.active{background:#fff;color:var(--brand-deep);box-shadow:var(--shadow-sm)}main.content{padding:28px 36px;max-width:1400px;width:100%}.page-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-header h1{margin:0;font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.page-header .subtitle{color:var(--text-2);font-size:13px;margin-top:4px}.page-actions{display:flex;gap:10px}.card{background:var(--card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:16px;position:relative}.card.tight{padding:16px}.card.compact{padding:12px 16px}.card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;gap:12px}.card-head h2{margin:0;font-size:11px;letter-spacing:.12em;color:var(--text-2);text-transform:uppercase;font-weight:700}.card-head .meta{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text-2)}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:16px}.kpi{background:#fff;border:1px solid var(--card-border);border-radius:var(--radius-md);padding:14px 18px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.kpi:after{content:"";position:absolute;top:0;right:0;bottom:0;width:3px;background:var(--brand);opacity:0;transition:opacity .3s}.kpi.accent:after{opacity:1}.kpi.accent-good:after{background:var(--good);opacity:1}.kpi.accent-warn:after{background:var(--warn);opacity:1}.kpi.accent-bad:after{background:var(--bad);opacity:1}.kpi .l{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);margin-bottom:6px;font-weight:600}.kpi .v{font-family:JetBrains Mono,monospace;font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--text)}.kpi .v.small{font-size:16px}.kpi .delta{font-size:11px;color:var(--text-2);margin-top:4px}table{width:100%;border-collapse:collapse}th,td{padding:12px 8px;text-align:left}thead th{font-weight:600;color:var(--text-2);font-size:11px;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--card-border)}tbody tr{border-bottom:1px solid var(--card-border);transition:background .15s}tbody tr:hover{background:var(--brand-soft)}tbody tr:last-child{border-bottom:none}td{font-size:13px;color:var(--text)}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;font-size:11px;font-weight:600;border-radius:999px;border:1px solid var(--card-border);letter-spacing:.04em;text-transform:uppercase;background:#fff}.badge.ok{color:var(--good);background:#1ab6921a;border-color:#1ab69266}.badge.warn{color:var(--warn);background:#e89b1f1a;border-color:#e89b1f66}.badge.bad{color:var(--bad);background:#e0455f1a;border-color:#e0455f66}.badge.info{color:var(--brand-deep);background:var(--brand-soft);border-color:#61b6ff73}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge.ok .dot{animation:pulse 2.5s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.flow-hero{position:relative;overflow:hidden;background:var(--card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-md);margin-bottom:16px}.flow-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top,rgba(97,182,255,.08),transparent 70%);pointer-events:none}.flow-svg{width:100%;height:auto;max-height:360px;display:block;position:relative}.flow-node-bg{fill:#fff;stroke:var(--card-border-strong);stroke-width:1}.flow-node-ring{fill:none;stroke:currentColor;stroke-width:2;opacity:.4}.flow-node.active .flow-node-ring{opacity:1;stroke-width:3;filter:url(#glow)}.flow-node-label{fill:var(--text-2);text-anchor:middle;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.flow-node-value{fill:var(--text);text-anchor:middle;font-family:JetBrains Mono,monospace;font-size:16px;font-weight:600}.flow-node-grid{color:var(--grid)}.flow-node-house{color:var(--house)}.flow-node-chargers{color:var(--chargers)}.flow-path{fill:none;stroke:#1c325a1f;stroke-width:12;stroke-linecap:round}.flow-path.active{stroke-dasharray:16 22;stroke-width:6;animation:flow-anim 1.6s linear infinite}.flow-path.import{stroke:url(#fp-import)}.flow-path.export{stroke:url(#fp-export)}.flow-path.charging{stroke:url(#fp-charging)}@keyframes flow-anim{to{stroke-dashoffset:-38}}.chart-card{background:#fff;border:1px solid var(--card-border);border-radius:var(--radius-md);padding:16px 20px;box-shadow:var(--shadow-sm)}.chart-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}.chart-head .title{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);font-weight:600}.chart-head .stat{font-family:JetBrains Mono,monospace;color:var(--text);font-size:14px;font-weight:600}.chart-svg{width:100%;height:120px;display:block}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative}.login-page:before,.login-page:after{content:"";position:absolute;width:600px;height:600px;border-radius:50%;filter:blur(80px);pointer-events:none;opacity:.5}.login-page:before{top:-200px;left:-200px;background:radial-gradient(circle,var(--brand),transparent 70%)}.login-page:after{bottom:-200px;right:-200px;background:radial-gradient(circle,var(--brand-deep),transparent 70%)}.login-card{width:100%;max-width:440px;background:var(--card-strong);-webkit-backdrop-filter:blur(28px);backdrop-filter:blur(28px);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-lg);position:relative;z-index:1}.login-card .brand{display:flex;align-items:center;gap:14px;margin-bottom:28px}.login-card .brand.brand-wordmark{flex-direction:column;align-items:flex-start;gap:8px}.login-card .brand-logo{display:block;height:56px;width:auto;max-width:100%}.login-card .brand-name{font-size:22px;font-weight:700;color:var(--text)}.login-card .brand-sub{font-size:12px;color:var(--text-2);letter-spacing:.04em}.login-card h1{margin:0 0 6px;font-size:24px;font-weight:700;color:var(--text)}.login-card .hint{color:var(--text-2);font-size:13px;margin-bottom:22px}.login-card .err{background:#e0455f1a;border:1px solid rgba(224,69,95,.4);color:var(--bad);padding:11px 14px;border-radius:10px;margin-bottom:16px;font-size:13px}.wizard-card{padding:28px 32px}.wizard-card h1{margin:0 0 20px;font-size:22px;font-weight:700;color:var(--text)}.wizard .steps{display:flex;gap:10px;margin-bottom:32px;position:relative}.wizard .step{flex:1;height:4px;background:var(--bg-2);border-radius:2px;position:relative;transition:background .4s}.wizard .step.active{background:linear-gradient(90deg,var(--brand),var(--brand-deep));box-shadow:0 0 12px #61b6ff66}.wizard .step-label{position:absolute;top:14px;left:0;font-size:11px;color:var(--text-2);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;font-weight:600}.wizard .step.active .step-label{color:var(--text)}.wizard-body{margin-top:20px;min-height:200px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1d3673;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:100;padding:24px;animation:fade-in .2s ease both}.modal{background:var(--card-strong);border:1px solid var(--card-border-strong);border-radius:var(--radius-xl);padding:28px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modal-in .25s cubic-bezier(.16,1,.3,1) both}.modal h1{margin:0 0 20px;font-size:20px;font-weight:700;color:var(--text)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.code-block{background:var(--bg-2);border:1px solid var(--card-border);border-radius:10px;padding:14px 18px;font-family:JetBrains Mono,monospace;font-size:13px;margin:12px 0;word-break:break-all;color:var(--brand-deep)}.slider-row{display:flex;align-items:center;gap:12px;background:var(--bg-2);padding:14px 18px;border-radius:var(--radius-md);border:1px solid var(--card-border)}input[type=range]{-webkit-appearance:none;background:transparent;flex:1;padding:0;border:none}input[type=range]::-webkit-slider-runnable-track{height:4px;background:#1c325a1f;border-radius:2px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:linear-gradient(135deg,var(--brand),var(--brand-deep));border-radius:50%;margin-top:-7px;box-shadow:0 2px 8px #61b6ff59}.online-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--good);box-shadow:0 0 8px var(--good);margin-right:6px;animation:pulse 2.5s infinite}.offline-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--muted);margin-right:6px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 1100px){.grid-3{grid-template-columns:1fr 1fr}}@media (max-width: 760px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto;padding:12px}main.content{padding:16px}.grid-2,.grid-3{grid-template-columns:1fr}}.fade-in{animation:fade-up .4s cubic-bezier(.16,1,.3,1) both}.fade-in:nth-child(2){animation-delay:.05s}.fade-in:nth-child(3){animation-delay:.1s}.fade-in:nth-child(4){animation-delay:.15s}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.empty{text-align:center;padding:40px 20px;color:var(--text-2)}.empty .icon{font-size:28px;opacity:.5;margin-bottom:8px}[data-tip]{position:relative}[data-tip]:hover:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--text);color:#fff;border:none;padding:6px 10px;border-radius:6px;font-size:11.5px;white-space:nowrap;z-index:50;pointer-events:none}
