.brand-logo{display:flex;align-items:center;gap:.65rem}.brand-logo__icon{flex-shrink:0;border-radius:8px;box-shadow:0 2px 10px #22c55e40}.brand-logo__text{display:flex;flex-direction:column;line-height:1.2}.brand-logo__title{font-size:1.05rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.brand-logo__subtitle{font-size:.75rem;color:var(--text-muted);font-weight:500}.auth-brand{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:1.25rem}.auth-brand .brand-logo__title{font-size:1.35rem;text-align:center}.auth-brand .brand-logo__icon{width:56px;height:56px;border-radius:14px}.mh-panel{position:relative;background:linear-gradient(180deg,#1e2a3a,#1a2332);border:1px solid var(--border);border-radius:16px;padding:0;overflow:hidden;box-shadow:0 4px 24px #00000040}.mh-panel__accent{height:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#22c55e)}.mh-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.35rem 1.5rem 1rem}.mh-header__left{display:flex;align-items:flex-start;gap:1rem}.mh-header__icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:#3b82f626;color:#60a5fa;flex-shrink:0}.mh-header__title{margin:0;font-size:1.15rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.mh-header__subtitle{margin:.2rem 0 0;font-size:.8rem;color:var(--text-muted)}.mh-stat-badge{display:flex;flex-direction:column;align-items:flex-end;padding:.5rem 1rem;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:10px}.mh-stat-badge__value{font-size:1.35rem;font-weight:700;color:#60a5fa;line-height:1.2}.mh-stat-badge__label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.mh-toolbar{padding:0 1.5rem 1rem}.mh-search{display:flex;align-items:center;gap:.5rem;padding:.35rem .35rem .35rem 1rem;background:var(--bg);border:1px solid var(--border);border-radius:12px;transition:border-color .2s,box-shadow .2s}.mh-search:focus-within{border-color:#3b82f699;box-shadow:0 0 0 3px #3b82f61f}.mh-search__icon{color:var(--text-muted);display:flex;flex-shrink:0}.mh-search__input{flex:1;min-width:0;border:none;background:transparent;color:var(--text);font-size:.9rem;font-family:inherit;padding:.5rem 0}.mh-search__input:focus{outline:none}.mh-search__input::placeholder{color:#64748b}.mh-btn{padding:.55rem 1.1rem;border-radius:8px;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;white-space:nowrap;transition:background .15s,transform .1s}.mh-btn:disabled{opacity:.5;cursor:not-allowed}.mh-btn--primary{background:var(--primary);color:#fff}.mh-btn--primary:hover:not(:disabled){background:var(--primary-hover)}.mh-btn--ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.mh-btn--ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text)}.mh-filter-chip{display:inline-flex;align-items:center;gap:.5rem;margin-top:.65rem;padding:.35rem .5rem .35rem .75rem;background:#8b5cf61f;border:1px solid rgba(139,92,246,.3);border-radius:20px;font-size:.8rem;color:#c4b5fd}.mh-filter-chip code{font-size:.75rem;color:#e9d5ff}.mh-filter-chip button{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:50%;background:#ffffff1a;color:var(--text);cursor:pointer;font-size:1rem;line-height:1}.mh-filter-chip button:hover{background:#fff3}.mh-alert{margin:0 1.5rem 1rem}.mh-table-wrap{margin:0 1rem 1rem;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--bg)}.mh-loading,.mh-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3.5rem 1.5rem;color:var(--text-muted)}.mh-empty svg{opacity:.35}.mh-table{width:100%;border-collapse:collapse;font-size:.875rem}.mh-table thead{position:sticky;top:0;z-index:2}.mh-table thead tr{background:#15202b}.mh-table th{padding:.85rem 1rem;text-align:left;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;border-bottom:1px solid var(--border);white-space:nowrap}.mh-table tbody tr{transition:background .12s}.mh-table tbody tr:nth-child(2n){background:#ffffff05}.mh-table tbody tr:hover{background:#3b82f60f}.mh-table td{padding:.85rem 1rem;border-bottom:1px solid rgba(45,58,79,.6);vertical-align:middle}.mh-table tbody tr:last-child td{border-bottom:none}.mh-col-num{width:48px;text-align:center}.mh-row-id{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 .35rem;border-radius:6px;background:var(--bg-elevated);font-size:.75rem;font-weight:600;color:var(--text-muted)}.mh-col-time{min-width:140px}.mh-time-date{display:block;font-weight:500;color:var(--text);font-size:.8rem}.mh-time-clock{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.1rem}.mh-col-cpu{min-width:100px}.mh-cpu{display:flex;flex-direction:column;gap:.35rem;min-width:72px}.mh-cpu__val{font-weight:600;font-size:.85rem;color:#60a5fa}.mh-cpu__bar{height:4px;background:var(--bg-elevated);border-radius:2px;overflow:hidden}.mh-cpu__fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:2px;transition:width .3s ease}.mh-col-energy{min-width:90px}.mh-energy-line{display:block;font-size:.8rem;font-weight:500}.mh-energy-line small{display:inline-block;width:2.2rem;font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.mh-energy-line--alt{margin-top:.2rem;color:var(--text-muted)}.mh-cell-muted{color:#64748b}.mh-mqtt-pill{display:inline-block;padding:.25rem .65rem;border-radius:20px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.mh-mqtt-pill--active{background:#22c55e26;color:#86efac;border:1px solid rgba(34,197,94,.35)}.mh-mqtt-pill--connected{background:#3b82f626;color:#93c5fd;border:1px solid rgba(59,130,246,.35)}.mh-mqtt-pill--inactive{background:#64748b33;color:#94a3b8;border:1px solid var(--border)}.mh-error-pill{display:inline-block;padding:.25rem .55rem;border-radius:6px;font-size:.78rem;font-weight:600;font-family:ui-monospace,monospace}.mh-error-pill--ok{background:#22c55e1f;color:#86efac}.mh-error-pill--warning{background:#f59e0b1f;color:#fcd34d}.mh-error-pill--error{background:#ef44441f;color:#fca5a5}.mh-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem 1.35rem;border-top:1px solid var(--border);background:#00000026}.mh-footer__range{margin:0;font-size:.85rem;color:var(--text-muted)}.mh-footer__range strong{color:var(--text);font-weight:600}.mh-footer__pages{margin:0;font-size:.8rem;color:var(--text-muted);font-weight:500}.mh-pagination{display:flex;align-items:center;gap:.35rem}.mh-page-nav{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s}.mh-page-nav:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--primary);color:#60a5fa}.mh-page-nav:disabled{opacity:.35;cursor:not-allowed}.mh-page-numbers{display:flex;align-items:center;gap:.25rem;padding:0 .25rem}.mh-page-num{min-width:36px;height:36px;padding:0 .5rem;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}.mh-page-num:hover:not(:disabled):not(.is-active){background:var(--bg-elevated);color:var(--text)}.mh-page-num.is-active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600;box-shadow:0 2px 8px #3b82f659}.mh-page-num:disabled{cursor:default}.mh-page-ellipsis{min-width:28px;text-align:center;color:var(--text-muted);font-size:.9rem;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.mh-header{padding:1rem}.mh-toolbar{padding:0 1rem 1rem}.mh-search{flex-wrap:wrap;padding:.75rem}.mh-search__input{width:100%;order:2;padding:.35rem 0}.mh-search__icon{order:1}.mh-btn{flex:1;order:3}.mh-table-wrap{margin:0 .75rem .75rem;overflow-x:auto}.mh-table{min-width:640px}.mh-footer{flex-direction:column;align-items:stretch;text-align:center;padding:1rem}.mh-footer__range,.mh-footer__pages{order:1}.mh-pagination{order:2;justify-content:center}.mh-page-num{min-width:32px;height:32px;font-size:.8rem}.mh-page-nav{width:32px;height:32px}}@media (max-width: 480px){.mh-page-numbers{display:none}.mh-header__stats{width:100%}.mh-stat-badge{flex-direction:row;align-items:center;justify-content:space-between;width:100%}}.e3504-wrap{display:flex;justify-content:center;padding:.5rem 0;width:300px}.e3504-panel{width:min(100%,340px);background:linear-gradient(180deg,#c5c9cc,#aeb3b8);border:2px solid #8f959b;border-radius:6px;box-shadow:inset 0 1px #ffffff73,0 8px 24px #00000047;overflow:hidden}.e3504-brand{background:linear-gradient(180deg,#6a9a9c,#5a8688);color:#fff;text-align:center;font-family:Arial Black,Arial Bold,Arial,sans-serif;font-size:1.05rem;letter-spacing:.08em;padding:.45rem .5rem;border-bottom:1px solid #4a7476}.e3504-display{background:#000;color:#fff;min-height:220px;padding:.55rem .65rem .45rem;font-family:Courier New,Lucida Console,monospace;font-size:.78rem;line-height:1.35;position:relative}.e3504-screen__top{display:grid;grid-template-columns:1fr auto;align-items:start;gap:.25rem;margin-bottom:.35rem}.e3504-screen__top--run{grid-template-columns:auto auto 1fr auto}.e3504-screen__mode{font-size:.72rem;letter-spacing:.04em}.e3504-screen__mode--run{margin-left:.75rem}.e3504-screen__hero{display:flex;align-items:flex-start;gap:.15rem;justify-self:end}.e3504-screen__hero-value{font-size:2.35rem;line-height:1;font-weight:700;letter-spacing:.02em}.e3504-screen__hero-unit{display:flex;flex-direction:column;font-size:.72rem;margin-top:.15rem}.e3504-screen__hero-unit small{font-size:.62rem;margin-top:.1rem}.e3504-screen__body{display:grid;grid-template-columns:18px 1fr;gap:.45rem;min-height:95px}.e3504-scale{width:2px;background:#fff;border-radius:1px;position:relative;margin-left:4px}.e3504-scale:before,.e3504-scale:after{content:"";position:absolute;left:-3px;width:8px;height:1px;background:#fff}.e3504-scale:before{top:18%}.e3504-scale:after{top:52%}.e3504-screen__manual-center{display:flex;align-items:center;justify-content:space-between;padding-right:.35rem}.e3504-screen__delta:before{content:"↕ ";font-size:.7rem}.e3504-screen__circle{width:1.15rem;height:1.15rem;border:1px solid #fff;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.65rem}.e3504-screen__divider{height:1px;background:#fff;margin:.35rem 0 .45rem}.e3504-screen__footer{display:flex;justify-content:space-between;align-items:flex-end;font-size:.74rem}.e3504-screen__pvsp{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.e3504-screen__program-list h4{margin:0 0 .35rem;font-size:.82rem;font-weight:700}.e3504-screen__program-list p{margin:.12rem 0}.e3504-screen__program-list strong{font-weight:700}.e3504-status-bar{display:grid;grid-template-columns:repeat(3,1fr) auto;align-items:end;gap:.35rem;background:linear-gradient(180deg,#6a9a9c,#5a8688);padding:.35rem .55rem .45rem;border-top:1px solid #4a7476}.e3504-status-item{display:flex;flex-direction:column;align-items:center;gap:.2rem}.e3504-status-item span{color:#fff;font-size:.58rem;font-family:Arial,sans-serif;letter-spacing:.02em}.e3504-status-led{width:1.35rem;height:1.35rem;background:linear-gradient(180deg,#1a4a7a,#0f3058);border:1px solid #0a2540;border-radius:2px;position:relative}.e3504-status-led:after{content:"";position:absolute;top:.28rem;right:.28rem;bottom:.28rem;left:.28rem;background:radial-gradient(circle,#fff,#b8d4ff 55%,#4a7ab8);border-radius:50%;opacity:.85}.e3504-model{align-self:center;color:#ffffffeb;font-size:.72rem;font-family:Arial,sans-serif;padding-left:.25rem}.e3504-keys{background:#c5c9cc;padding:.35rem .55rem .5rem;position:relative}.e3504-keys__ack{position:absolute;top:.15rem;left:.85rem;right:42%;height:.55rem;border:1px solid rgba(255,255,255,.85);border-bottom:none;border-radius:4px 4px 0 0;pointer-events:none}.e3504-keys__ack span{position:absolute;top:-.45rem;left:50%;transform:translate(-50%);font-size:.58rem;color:#2a3038;font-family:Arial,sans-serif}.e3504-keys__row{display:grid;grid-template-columns:repeat(4,1fr);gap:.45rem;margin-top:.35rem}.e3504-key{aspect-ratio:1;border:1px solid #7a8088;border-radius:3px;background:linear-gradient(180deg,#d8dce0,#b8bcc2);box-shadow:inset 0 1px #ffffff8c,0 2px 3px #0000002e;display:flex;align-items:center;justify-content:center;padding:.35rem;cursor:default}.e3504-key svg{width:70%;height:70%}.e3504-key--scroll svg,.e3504-key--loop svg{color:#1a3050}.e3504-key--arrow{background:linear-gradient(180deg,#c8ccd0,#a8acb2)}.e3504-nav{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:.35rem;padding:.45rem .55rem .55rem;background:#b0b5ba;border-top:1px solid #959aa0}.e3504-nav-btn{width:44px;height:36px;border:1px solid #7a8088;border-radius:4px;background:linear-gradient(180deg,#e2e5e8,#c4c8cd);box-shadow:inset 0 1px #ffffffa6,0 2px 4px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#1a3050;transition:transform .12s ease,box-shadow .12s ease}.e3504-nav-btn:hover{background:linear-gradient(180deg,#eef0f2,#d0d4d9)}.e3504-nav-btn:active{transform:translateY(1px);box-shadow:inset 0 2px 4px #0000002e}.e3504-nav-btn svg{width:1.25rem;height:1.25rem}.e3504-nav-label{text-align:center;font-size:.68rem;color:#2a3038;font-family:Arial,sans-serif;letter-spacing:.03em;text-transform:uppercase}.ecu-controller-section{display:flex;flex-direction:column;gap:.75rem}.ecu-controller-section h3{margin:0;font-size:1rem;color:var(--text)}.ecu-controller-layout{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-start;justify-content:center}@media (min-width: 960px){.ecu-controller-layout{justify-content:flex-start}}.ecu-dashboard{display:flex;flex-direction:column;gap:1.5rem}.ecu-selectors{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.ecu-select-wrap{display:flex;flex-direction:column;gap:.35rem;min-width:200px;flex:1}.ecu-select-wrap span{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.ecu-select-wrap select{padding:.65rem .85rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit;font-size:.9rem}.metaWrap{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.metaChip{background:#111c2d;border:1px solid var(--border);border-radius:8px;padding:6px 10px;min-width:100px}.metaChipLabel{display:block;font-size:10px;text-transform:uppercase;color:var(--text-muted)}.metaChipValue{display:block;font-size:12px;color:var(--text);margin-top:2px;word-break:break-word}.ecu-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#1a2332,#15202b);border:1px solid var(--border);border-radius:var(--radius)}.ecu-header__title-row{display:flex;align-items:center;gap:.75rem}.ecu-header h2{font-size:1.35rem;font-weight:700;margin:0}.ecu-pulse{width:10px;height:10px;border-radius:50%;background:#64748b;flex-shrink:0}.ecu-pulse[data-live=true]{background:#22c55e;box-shadow:0 0 #22c55e99;animation:ecu-pulse 2s infinite}@keyframes ecu-pulse{0%{box-shadow:0 0 #22c55e80}70%{box-shadow:0 0 0 10px #22c55e00}to{box-shadow:0 0 #22c55e00}}.ecu-header__meta{margin-top:.35rem;font-size:.85rem;color:var(--text-muted)}.ecu-header__meta code{color:var(--primary);font-size:.8rem}.ecu-header__actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.ecu-status-pill{font-size:.75rem;font-weight:600;padding:.4rem .85rem;border-radius:20px;text-transform:uppercase;letter-spacing:.05em}.ecu-status-pill.is-live{background:#22c55e26;color:#86efac;border:1px solid rgba(34,197,94,.35)}.ecu-status-pill.is-off{background:#ef44441f;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.ecu-refresh-btn{width:auto;padding:.5rem 1rem;font-size:.875rem}.ecu-empty-state{text-align:center;padding:3rem 1.5rem;background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius)}.ecu-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.ecu-metric{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.15rem 1.25rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .2s,transform .2s}.ecu-metric:hover{border-color:#3b82f666;transform:translateY(-1px)}.ecu-metric__top{display:flex;align-items:center;gap:.5rem}.ecu-metric__icon{font-size:1rem;opacity:.85}.ecu-metric__label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600}.ecu-metric__value{font-size:1.5rem;font-weight:700;line-height:1.2}.ecu-metric__unit{font-size:.85rem;font-weight:500;color:var(--text-muted);margin-left:.15rem}.ecu-metric__sub{font-size:.8rem;color:var(--text-muted)}.ecu-metric--primary .ecu-metric__value{color:#60a5fa}.ecu-metric--amber .ecu-metric__value{color:#fbbf24}.ecu-metric--green .ecu-metric__value,.ecu-metric--success .ecu-metric__value{color:#4ade80}.ecu-metric--warning .ecu-metric__value{color:#fbbf24}.ecu-metric--error .ecu-metric__value{color:#f87171}.ecu-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.ecu-chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;min-height:280px}.ecu-chart-card--wide{grid-column:1 / -1}.ecu-chart-card h3{font-size:.9rem;font-weight:600;color:var(--text-muted);margin-bottom:1rem}.ecu-chart-empty{height:200px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem}.ecu-tags-section,.ecu-history-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.ecu-tags-section h3,.ecu-history-section h3{font-size:.95rem;font-weight:600;color:var(--text-muted);margin-bottom:0}.ecu-tags-hint{font-size:.85rem;color:var(--text-muted);margin:.5rem 0 .75rem}.ecu-history-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.ecu-history-count{font-size:.8rem;color:var(--text-muted)}.ecu-search-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.ecu-search-input{flex:1;min-width:200px;padding:.65rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.9rem;font-family:inherit}.ecu-search-input:focus{outline:none;border-color:var(--primary)}.ecu-search-btn{width:auto;padding:.65rem 1.1rem;font-size:.875rem}.ecu-history-loading{display:flex;justify-content:center;padding:2.5rem}.ecu-row-num{color:var(--text-muted);font-size:.8rem;width:2.5rem}.ecu-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.ecu-page-btn{padding:.5rem .85rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s}.ecu-page-btn:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--primary)}.ecu-page-btn:disabled{opacity:.4;cursor:not-allowed}.ecu-page-info{font-size:.875rem;color:var(--text-muted);padding:0 .75rem;text-align:center}.ecu-page-info-sub{display:block;font-size:.75rem;margin-top:.15rem}@media (max-width: 600px){.ecu-search-bar{flex-direction:column}.ecu-search-btn{width:100%}.ecu-pagination{gap:.35rem}.ecu-page-btn{padding:.45rem .6rem;font-size:.8rem}.ecu-page-info-sub{display:none}}.ecu-tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.ecu-tag-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.25rem;position:relative}.ecu-tag-card--setpoint{cursor:pointer;border-color:#3b82f673;transition:border-color .15s,box-shadow .15s}.ecu-tag-card__edit{position:absolute;top:.5rem;right:.5rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;font-weight:700;color:var(--primary)}.ecu-tag-card__name{font-size:.8rem;font-weight:600;color:var(--text)}.ecu-tag-card__raw{font-size:.65rem;color:var(--primary);opacity:.9}.ecu-tag-card__value{font-size:1.1rem;font-weight:700;font-family:ui-monospace,monospace;color:#e2e8f0}.ecu-history-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.ecu-history-table{width:100%;border-collapse:collapse;font-size:.85rem;min-width:520px}.ecu-history-table th,.ecu-history-table td{padding:.65rem .85rem;text-align:left;border-bottom:1px solid var(--border)}.ecu-history-table th{color:var(--text-muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.04em}.ecu-error-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8rem;font-weight:600}.ecu-error-badge--ok{background:#22c55e26;color:#86efac}.ecu-error-badge--warning{background:#f59e0b26;color:#fcd34d}.ecu-error-badge--error{background:#ef444426;color:#fca5a5}@media (max-width: 900px){.ecu-charts-grid{grid-template-columns:1fr}.ecu-chart-card--wide{grid-column:1}}@media (max-width: 600px){.ecu-header{padding:1rem}.ecu-header h2{font-size:1.15rem}.ecu-metrics-grid{grid-template-columns:repeat(2,1fr)}.ecu-metric__value{font-size:1.2rem}.ecu-tags-grid{grid-template-columns:1fr}}.adm-app{display:flex;min-height:100vh;background:var(--bg)}.adm-app--loading{flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted)}.adm-sidebar{width:240px;flex-shrink:0;background:#121a26;border-right:1px solid var(--border);display:flex;flex-direction:column;transition:width .2s ease}.adm-sidebar--collapsed{width:64px}.adm-sidebar__head{display:flex;align-items:center;justify-content:space-between;padding:1rem .85rem;border-bottom:1px solid var(--border)}.adm-sidebar__label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700}.adm-sidebar__toggle{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:.85rem}.adm-sidebar__toggle:hover{color:var(--text)}.adm-sidebar__nav{padding:.75rem .5rem;display:flex;flex-direction:column;gap:.25rem}.adm-nav-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem .85rem;border:none;border-radius:8px;background:transparent;color:var(--text-muted);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;text-align:left;transition:background .15s,color .15s}.adm-nav-item:hover{background:#3b82f614;color:var(--text)}.adm-nav-item.is-active{background:#3b82f626;color:var(--primary);font-weight:600}.adm-sidebar--collapsed .adm-nav-item{justify-content:center;padding:.75rem}.adm-nav-item__icon{font-size:1.1rem;width:1.25rem;text-align:center}.adm-main{flex:1;display:flex;flex-direction:column;min-width:0;background:radial-gradient(ellipse 60% 40% at 100% 0%,rgba(59,130,246,.08),transparent),var(--bg)}.adm-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.75rem;border-bottom:1px solid var(--border);background:#121a2699;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:50}.adm-topbar__title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.adm-topbar__sub{font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.adm-topbar__actions{display:flex;align-items:center;gap:.75rem}.adm-topbar__user{display:flex;align-items:center;gap:.6rem;padding:.35rem .75rem .35rem .35rem;background:var(--bg-card);border:1px solid var(--border);border-radius:999px}.adm-topbar__avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#3b82f6);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff}.adm-topbar__user-text{display:flex;flex-direction:column;line-height:1.2}.adm-topbar__user-text span{font-size:.85rem;font-weight:600}.adm-topbar__user-text small{font-size:.7rem;color:var(--text-muted)}.adm-alerts{padding:0 1.75rem;margin-top:.75rem}.adm-alert{padding:.75rem 1rem;border-radius:8px;font-size:.9rem;margin-bottom:.5rem}.adm-alert--error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.adm-alert--success{background:#22c55e1f;border:1px solid rgba(34,197,94,.3);color:#86efac}.adm-alert--inline{margin:0 1.35rem 1rem}.adm-content{flex:1;padding:1.5rem 1.75rem 2.5rem;overflow:auto}.adm-btn{padding:.65rem 1.1rem;border-radius:8px;font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:filter .15s,background .15s;white-space:nowrap}.adm-btn:disabled{opacity:.5;cursor:not-allowed}.adm-btn--primary{background:linear-gradient(135deg,var(--primary),#2563eb);color:#fff}.adm-btn--primary:hover:not(:disabled){filter:brightness(1.08)}.adm-btn--ghost{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.adm-btn--ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text)}.adm-btn--danger{background:transparent;border:1px solid rgba(239,68,68,.4);color:#f87171}.adm-btn--danger-soft{background:#ef44441a;color:#f87171;border:1px solid rgba(239,68,68,.25);padding:.3rem .5rem}.adm-btn--compact{padding:.55rem .9rem;font-size:.8rem}.adm-btn--icon{min-width:30px;height:30px;padding:0}.adm-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.adm-panel--center{display:flex;align-items:center;justify-content:center;min-height:200px;padding:2rem}.adm-panel--table{display:flex;flex-direction:column}.adm-panel--form{max-width:520px}.adm-panel__head{padding:1.15rem 1.35rem;border-bottom:1px solid var(--border);background:#0000001f}.adm-panel__head--compact{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem}.adm-panel__head--row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.adm-panel__head h2,.adm-panel__head h3{font-size:1rem;font-weight:700}.adm-panel__head p{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.adm-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 .45rem;border-radius:999px;background:#3b82f626;color:var(--primary);font-size:.75rem;font-weight:700}.adm-badge--muted{background:var(--bg-elevated);color:var(--text-muted)}.adm-hero h2{font-size:1.5rem;margin-bottom:.35rem}.adm-hero p{color:var(--text-muted)}.adm-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1.5rem 0}.adm-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.35rem}.adm-stat-card--clickable{cursor:pointer;transition:border-color .2s,transform .15s}.adm-stat-card--clickable:hover{border-color:#3b82f666;transform:translateY(-2px)}.adm-stat-card__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.adm-stat-card__value{font-size:2rem;font-weight:700}.adm-stat-card__link{font-size:.8rem;color:var(--primary);margin-top:.25rem}.adm-quick-actions h3{font-size:1rem;margin-bottom:.75rem}.adm-quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.adm-quick-btn{display:flex;align-items:center;gap:1rem;padding:1rem 1.15rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;font-family:inherit;color:var(--text);transition:border-color .15s,background .15s}.adm-quick-btn:hover{border-color:var(--primary);background:#3b82f60f}.adm-quick-btn span:first-child{font-size:1.5rem;color:var(--primary)}.adm-quick-btn strong{display:block;font-size:.95rem}.adm-quick-btn small{color:var(--text-muted);font-size:.8rem}.adm-toolbar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:space-between;margin-bottom:.75rem}.adm-search-form{display:flex;flex-wrap:wrap;gap:.5rem;flex:1;min-width:280px}.adm-search-input{flex:1;min-width:200px;padding:.65rem .9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text);font-size:.9rem}.adm-search-input:focus{outline:none;border-color:var(--primary)}.adm-toolbar__filters{display:flex;gap:.5rem}.adm-select{padding:.6rem .85rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text);font-size:.85rem}.adm-users-meta{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.adm-users-meta strong{color:var(--text)}.adm-table-scroll{overflow-x:auto;max-height:calc(100vh - 320px);overflow-y:auto}.adm-table{width:100%;border-collapse:collapse;font-size:.875rem}.adm-table th{position:sticky;top:0;z-index:2;text-align:left;padding:.7rem 1.15rem;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:#151d2b;border-bottom:1px solid var(--border)}.adm-table td{padding:.75rem 1.15rem;border-bottom:1px solid var(--border);vertical-align:middle}.adm-table tbody tr:hover td{background:#3b82f60a}.adm-col-id{width:70px}.adm-muted{color:var(--text-muted);font-size:.85rem}.adm-code{font-family:ui-monospace,monospace;font-size:.78rem;background:#3b82f61a;color:#93c5fd;padding:.15rem .45rem;border-radius:4px}.adm-user-row{display:flex;align-items:center;gap:.6rem;font-weight:500}.adm-user-row__av{width:28px;height:28px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--primary)}.adm-pagination{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:1rem 1.15rem;border-top:1px solid var(--border);background:#0000001a}.adm-pagination__info{font-size:.85rem;color:var(--text-muted)}.adm-pagination__jump label{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-muted)}.adm-page-input{width:64px;padding:.35rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text)}.adm-companies-layout{display:grid;grid-template-columns:280px 1fr;gap:1.25rem;min-height:480px}.adm-companies-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden}.adm-list-search{margin:0 .75rem .75rem;padding:.55rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.85rem}.adm-company-nav{list-style:none;overflow-y:auto;flex:1;max-height:calc(100vh - 280px)}.adm-company-nav__item{width:100%;text-align:left;padding:.85rem 1rem;border:none;border-bottom:1px solid var(--border);background:transparent;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;gap:.2rem}.adm-company-nav__item:hover{background:#3b82f60f}.adm-company-nav__item.is-active{background:#3b82f61f;border-left:3px solid var(--primary);padding-left:calc(1rem - 3px)}.adm-company-nav__name{font-weight:600;font-size:.9rem;color:var(--text)}.adm-company-nav__meta{font-size:.72rem;color:var(--text-muted)}.adm-companies-detail{min-width:0}.adm-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.adm-eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);font-weight:700}.adm-detail-header h2{font-size:1.5rem;font-weight:700}.adm-detail-grid{display:flex;flex-direction:column;gap:1.25rem}.adm-inline-add{display:flex;gap:.5rem;padding:.85rem 1.15rem;border-bottom:1px solid var(--border);background:#00000014}.adm-inline-add input{flex:1;min-width:0;padding:.55rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text)}.adm-inline-add--multi input:first-child{flex:.7}.adm-form{padding:1.25rem 1.35rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.adm-field label{display:block;font-size:.8rem;font-weight:600;color:var(--text-muted);margin-bottom:.35rem}.adm-field input{width:100%;padding:.7rem .9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-family:inherit}.adm-form__actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.adm-empty-block{padding:2.5rem;text-align:center;color:var(--text-muted)}.adm-empty-block--large{min-height:360px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius)}.adm-empty-block p{color:var(--text);font-weight:600;margin-bottom:.25rem}.adm-empty-block--inline{padding:1.5rem}.adm-hint{padding:.75rem 1.15rem;font-size:.8rem;color:var(--text-muted);border-top:1px solid var(--border)}.adm-table-actions{text-align:right;width:48px}.ecu-company-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .85rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;font-weight:600}.ecu-company-badge span{color:var(--text-muted);font-weight:500;font-size:.85rem}.ecu-selectors--user{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.adm-panel--wide{grid-column:1 / -1}.adm-topic-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.adm-topic-card{border:1px solid var(--border);border-radius:12px;background:#ffffff05;overflow:hidden}.adm-topic-card__toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;background:#ffffff08}.adm-topic-card__toggle{display:flex;align-items:center;gap:.75rem;flex:1;border:none;background:transparent;color:var(--text);font:inherit;text-align:left;cursor:pointer;padding:0}.adm-topic-card__meta{color:var(--text-muted);font-size:.82rem}.adm-topic-write{padding:1rem 1rem 1.25rem;border-top:1px solid var(--border)}.adm-topic-write__head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.adm-topic-write__name{font-size:.95rem}.adm-topic-write__hint{margin:.35rem 0 0;color:var(--text-muted);font-size:.82rem}.adm-topic-write__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:1rem}.adm-topic-write__section{padding:1rem;border:1px solid var(--border);border-radius:10px;background:#00000026}.adm-topic-write__section h4{margin:0 0 .75rem;font-size:.92rem}.adm-toggle-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.85rem;font-size:.9rem}.adm-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem;font-size:.82rem;color:var(--text-muted)}.adm-field input{width:100%}.adm-pill{display:inline-flex;align-items:center;padding:.25rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600}.adm-pill--ok{background:#22c55e26;color:#86efac}.adm-pill--muted{background:#94a3b826;color:var(--text-muted)}.adm-tag-chips{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:0 0 .85rem;padding:0}.adm-tag-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .55rem;border-radius:999px;background:#3b82f626;border:1px solid rgba(59,130,246,.25)}.adm-tag-chip code{font-size:.78rem}.adm-tag-chip__remove{border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:1rem;line-height:1;padding:0}.adm-tag-chip__remove:hover{color:#fca5a5}.adm-tag-add{display:flex;gap:.5rem}.adm-tag-add input{flex:1}@media (max-width: 900px){.adm-sidebar{width:64px}.adm-sidebar__label,.adm-nav-item__label{display:none}.adm-nav-item{justify-content:center}.adm-companies-layout{grid-template-columns:1fr}.adm-company-nav{max-height:200px}.adm-topbar{flex-direction:column;align-items:flex-start}.adm-topic-write__grid{grid-template-columns:1fr}.adm-tag-add{flex-direction:column}}.ems-dashboard{display:flex;flex-direction:column;gap:1.5rem}.ems-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.ems-header__text{display:flex;flex-direction:column;gap:.35rem}.ems-header__actions{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.ems-header h1{font-size:1.75rem;margin-bottom:0}.ems-subtitle{color:var(--text-muted);font-size:.95rem}.ems-refresh-btn{width:auto}.ems-tab-bar{display:flex;flex-wrap:wrap;gap:.65rem;align-items:center}.ems-tab-btn{padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border);background:#0f172a8c;color:var(--text-muted);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,color .2s}.ems-tab-btn:hover{background:#3341558c;color:var(--text)}.ems-tab-btn--active{background:#3b82f626;border-color:var(--primary);color:var(--primary)}.ems-tab-bar__filters{margin-left:auto;display:flex;flex-wrap:wrap;align-items:center;gap:.65rem}.ems-tab-bar__filters .ems-furnace-filter{margin-left:0}.ems-furnace-filter{margin-left:auto;display:flex;align-items:center;gap:.5rem}.ems-furnace-filter span{font-size:.8rem;color:var(--text-muted)}.ems-furnace-filter select{min-width:150px;border:1px solid var(--border);border-radius:8px;background:#0f172a8c;color:var(--text);padding:.45rem .6rem;font:inherit}.ems-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.ems-stat-unit{display:block;font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.ems-stat-value--cost{color:var(--success)}.ems-table-panel h2{font-size:1rem;margin-bottom:1rem;color:var(--text-muted);font-weight:600}.ems-table-wrap{overflow-x:auto}.ems-table-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.85rem;flex-wrap:wrap}.ems-solar-filter-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.ems-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0206179e;display:flex;align-items:center;justify-content:center;z-index:1000}.ems-modal{width:min(560px,92vw);background:#0f172a;border:1px solid #334155;border-radius:12px;padding:1rem}.ems-modal h3{margin:0 0 .9rem;font-size:1rem}.ems-modal__row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.ems-modal__row label{display:flex;flex-direction:column;gap:.45rem;color:var(--text-muted);font-size:.85rem}.ems-modal__row input{border:1px solid var(--border);border-radius:8px;background:#0f172a8c;color:var(--text);padding:.45rem .6rem;font:inherit}.ems-modal__actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1rem}.ems-table-controls__limit{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.85rem}.ems-table-controls__limit select{border:1px solid var(--border);border-radius:8px;background:#0f172a8c;color:var(--text);padding:.35rem .55rem;font:inherit}.ems-table-controls__pager{display:flex;align-items:center;gap:.65rem;color:var(--text-muted);font-size:.85rem}.ems-table-controls__dates{display:flex;align-items:center;gap:.5rem}.ems-table-controls__dates input{border:1px solid var(--border);border-radius:8px;background:#0f172a8c;color:var(--text);padding:.35rem .55rem;font:inherit}.ems-machine-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.ems-machine-card{display:flex;flex-direction:column;gap:.35rem}.ems-machine-title{margin:0;color:var(--text-muted);font-size:.85rem}.ems-machine-value{margin:0;font-size:1.45rem;font-weight:700}.ems-machine-sub{margin:0;color:var(--text-muted);font-size:.82rem}.ems-advantages h2{margin-bottom:.8rem;font-size:1rem;color:var(--text-muted)}.ems-advantages__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.ems-adv-item{margin:0;padding:.8rem;border:1px solid var(--border);border-radius:10px;background:#0f172a59;color:var(--text);font-size:.88rem;line-height:1.45}.ems-solar-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.ems-solar-kpi{display:flex;flex-direction:column;gap:.35rem}.ems-solar-kpi__label{margin:0;font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.ems-solar-kpi__value{margin:0;font-size:1.35rem;font-weight:700}.ems-solar-kpi__value--small{font-size:1rem;line-height:1.35}.ems-solar-kpi__sub{margin:0;color:var(--text-muted);font-size:.8rem}.ems-solar-chart__head{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem}.ems-solar-chart__head h2{margin:0;font-size:1rem;color:var(--text-muted)}.ems-solar-chart__head span{color:var(--text-muted);font-size:.85rem}.ems-chart-empty{margin:0;padding:2.5rem 1rem;text-align:center;color:var(--text-muted);border:1px dashed var(--border);border-radius:10px;background:#0f172a59}.ems-chart-footnote{margin:.75rem 0 0;color:var(--text-muted);font-size:.82rem}.ems-dashboard .recharts-tooltip-wrapper .recharts-default-tooltip{background:#0f172a!important;border:1px solid #334155!important;border-radius:10px!important;box-shadow:0 8px 24px #00000059}.ems-dashboard .recharts-tooltip-label,.ems-dashboard .recharts-tooltip-item-name,.ems-dashboard .recharts-tooltip-item-value,.ems-dashboard .recharts-tooltip-item-list li{color:#e2e8f0!important}.ems-dashboard .recharts-tooltip-item-name{color:#cbd5e1!important}.ems-solar-pagination{margin-top:.8rem;display:flex;justify-content:flex-end;align-items:center;gap:.8rem}.ems-pq-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.ems-pq-kpi{display:flex;flex-direction:column;gap:.35rem}.ems-pq-kpi__label{margin:0;font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.ems-pq-kpi__value{margin:0;font-size:1.35rem;font-weight:700}.ems-pq-kpi--r{border-color:#ef4444;box-shadow:inset 4px 0 #ef4444,inset 0 0 0 1px #ef444438}.ems-pq-kpi--y{border-color:#eab308;box-shadow:inset 4px 0 #eab308,inset 0 0 0 1px #eab30838}.ems-pq-kpi--b{border-color:#3b82f6;box-shadow:inset 4px 0 #3b82f6,inset 0 0 0 1px #3b82f638}.ems-pq-kpi--r .ems-pq-kpi__label{color:#fca5a5}.ems-pq-kpi--y .ems-pq-kpi__label{color:#fde68a}.ems-pq-kpi--b .ems-pq-kpi__label{color:#93c5fd}.ems-pq-kpi--ry{border-color:#ef4444;box-shadow:inset 4px 0 #ef4444,inset 10px 0 #eab308,inset 0 0 0 1px #ef444429}.ems-pq-kpi--yb{border-color:#eab308;box-shadow:inset 4px 0 #eab308,inset 10px 0 #3b82f6,inset 0 0 0 1px #eab30829}.ems-pq-kpi--rb{border-color:#ef4444;box-shadow:inset 4px 0 #ef4444,inset 10px 0 #3b82f6,inset 0 0 0 1px #3b82f629}.ems-pq-score{border-width:2px}.ems-pq-score--excellent{border-color:#22c55e}.ems-pq-score--good{border-color:#38bdf8}.ems-pq-score--warning{border-color:#f59e0b}.ems-pq-score--critical{border-color:#ef4444}.ems-status{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:600}.ems-status--running{background:#22c55e26;color:#86efac}.ems-status--idle{background:#8b9cb326;color:var(--text-muted)}.ems-empty-row{text-align:center;color:var(--text-muted)}.ems-stat-value--small{font-size:.9rem;line-height:1.35}.ems-skeleton-card{min-height:86px;display:flex;flex-direction:column;gap:.5rem}.ems-skeleton{display:block;border-radius:8px;background-color:#94a3b824;background-image:linear-gradient(90deg,#94a3b814 25%,#94a3b857,#94a3b814 75%);background-size:220% 100%;animation:ems-skeleton-loading 1.2s ease-in-out infinite}.ems-skeleton--label{width:55%;height:12px}.ems-skeleton--value{width:78%;height:24px}.ems-skeleton--meta{width:90%;height:10px}.ems-skeleton--table{width:100%;height:18px}.ems-skeleton-chart{display:flex;flex-direction:column;gap:1rem}.ems-skeleton-chart__head{display:flex;justify-content:space-between;align-items:center;gap:1rem}.ems-skeleton--chart-title{width:180px;height:14px}.ems-skeleton--chart-meta{width:120px;height:12px}.ems-skeleton--chart{width:100%;height:260px;border-radius:12px}.ems-table .ems-skeleton--table{margin:.15rem 0}@keyframes ems-skeleton-loading{0%{background-position:100% 0}to{background-position:0 0}}@media (max-width: 768px){.ems-header h1{font-size:1.35rem}.ems-header__actions{width:100%;justify-content:space-between}}.sp-page{min-height:100vh;background:var(--bg);padding:1.5rem;max-width:1100px;margin:0 auto}.sp-page--center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;color:var(--text-muted)}.sp-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.sp-header h1{font-size:1.5rem;margin-bottom:.25rem}.sp-sub{color:var(--text-muted);font-size:.9rem}.sp-back{background:var(--bg-card);border:1px solid var(--border);color:var(--text);padding:.5rem .85rem;border-radius:8px;cursor:pointer;font-family:inherit;font-weight:600}.sp-back:hover{border-color:var(--primary)}.sp-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start}.sp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.35rem}.sp-field{margin-bottom:1.15rem}.sp-field label{display:block;font-size:.8rem;font-weight:600;color:var(--text-muted);margin-bottom:.4rem}.sp-field input{width:100%;padding:.75rem .9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:1.1rem;font-family:ui-monospace,monospace}.sp-field input:focus{outline:none;border-color:var(--primary)}.sp-field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.sp-readonly{padding:.75rem .9rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;font-family:ui-monospace,monospace;font-size:1.1rem;font-weight:700}.sp-tag-code{display:block;font-size:.85rem;color:var(--primary);margin-bottom:.25rem}.sp-tag-label{font-size:1rem;font-weight:600}.sp-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.sp-preview h2{font-size:1rem;margin-bottom:.35rem}.sp-hint{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.sp-mode{font-size:.8rem;color:var(--text-muted)}.sp-json{background:#0a1018;border:1px solid var(--border);border-radius:8px;padding:1rem;font-size:.75rem;line-height:1.45;overflow:auto;max-height:420px;color:#93c5fd;white-space:pre-wrap;word-break:break-word}.ecu-tag-card--setpoint{cursor:pointer;transition:border-color .15s,box-shadow .15s;position:relative}.ecu-tag-card--setpoint:hover{border-color:var(--primary);box-shadow:0 0 0 1px #3b82f659}.ecu-tag-card__edit{position:absolute;top:.5rem;right:.5rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--primary);font-weight:700}@media (max-width: 768px){.sp-layout,.sp-field-row{grid-template-columns:1fr}}:root{--bg: #0f1419;--bg-card: #1a2332;--bg-elevated: #243044;--text: #e8edf4;--text-muted: #8b9cb3;--primary: #3b82f6;--primary-hover: #2563eb;--success: #22c55e;--error: #ef4444;--border: #2d3a4f;--radius: 12px;--shadow: 0 8px 32px rgba(0, 0, 0, .35);font-family:DM Sans,system-ui,sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}a{color:var(--primary);text-decoration:none;font-weight:500}a:hover{text-decoration:underline}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(59,130,246,.25),transparent),var(--bg)}.auth-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow)}.auth-header{margin-bottom:1.5rem;text-align:center}.auth-header h1{font-size:1.75rem;font-weight:700;margin-bottom:.35rem}.auth-header p{color:var(--text-muted);font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-muted)}.form-group input{padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary)}.auth-footer{margin-top:1.5rem;text-align:center;font-size:.9rem;color:var(--text-muted)}.btn{padding:.75rem 1.25rem;border-radius:8px;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:background .2s,opacity .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-outline:hover{background:var(--bg-elevated)}.alert{padding:.75rem 1rem;border-radius:8px;font-size:.9rem;margin-bottom:1rem}.alert-error{background:#ef444426;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.alert-success{background:#22c55e26;color:#86efac;border:1px solid rgba(34,197,94,.3)}.page-center{min-height:100vh;display:flex;align-items:center;justify-content:center}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-layout{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.1rem}.logo-dot{width:10px;height:10px;background:var(--primary);border-radius:50%}.header-actions{display:flex;align-items:center;gap:1rem}.user-badge{font-size:.9rem;color:var(--text-muted);padding:.35rem .75rem;background:var(--bg-elevated);border-radius:20px}.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.25rem}.menu-toggle span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px}.dashboard-main{flex:1;padding:1.5rem;max-width:1200px;margin:0 auto;width:100%}.dashboard-main--ecu{max-width:1400px}.dashboard-layout--ecu{background:var(--bg)}.user-nav{display:flex;gap:.5rem;padding:0 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border);overflow-x:auto}.user-nav__tab{padding:.85rem 1.25rem;font-size:.9rem;font-weight:600;color:var(--text-muted);text-decoration:none;border-bottom:2px solid transparent;white-space:nowrap;transition:color .2s,border-color .2s}.user-nav__tab:hover{color:var(--text);text-decoration:none}.user-nav__tab--active{color:var(--primary);border-bottom-color:var(--primary)}.welcome-section{margin-bottom:2rem}.welcome-section h1{font-size:1.75rem;margin-bottom:.35rem}.text-muted{color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:.35rem}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:1.75rem;font-weight:700;color:var(--primary)}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.panel h2{font-size:1rem;margin-bottom:1rem;color:var(--text-muted);font-weight:600}.panel-wide{grid-column:1 / -1}.activity-list,.notification-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.activity-list li{display:flex;align-items:flex-start;gap:.75rem}.activity-dot{width:8px;height:8px;background:var(--primary);border-radius:50%;margin-top:.4rem;flex-shrink:0}.activity-list time{display:block;font-size:.8rem;color:var(--text-muted)}.notification{padding:.75rem 1rem;border-radius:8px;font-size:.9rem}.notification-success{background:#22c55e1f;border-left:3px solid var(--success)}.notification-info{background:#3b82f61f;border-left:3px solid var(--primary)}.profile-info{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.profile-info p{margin-bottom:.35rem;font-size:.95rem}.profile-info strong{color:var(--text-muted);font-weight:500}.panel-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.panel-header-row h2{margin-bottom:0}.mqtt-badge{font-size:.75rem;font-weight:600;padding:.35rem .75rem;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}.mqtt-connected{background:#22c55e26;color:#86efac}.mqtt-disconnected{background:#ef444426;color:#fca5a5}.ecu-meta{margin-bottom:1rem;font-size:.85rem;word-break:break-all}.mqtt-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.mqtt-table{width:100%;border-collapse:collapse;font-size:.875rem}.mqtt-table th,.mqtt-table td{padding:.65rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.mqtt-table th{color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase}.mqtt-table code{font-size:.8rem;color:var(--primary)}.mqtt-message{max-width:280px;word-break:break-word;font-family:ui-monospace,monospace;font-size:.8rem}.mqtt-empty{text-align:center;color:var(--text-muted);padding:2rem!important}@media (max-width: 768px){.menu-toggle{display:flex}.user-nav{padding:0 1rem}.user-nav__tab{padding:.75rem 1rem;font-size:.85rem}.header-actions{position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--bg-card);border-bottom:1px solid var(--border);padding:1rem;display:none}.header-actions.open{display:flex}.dashboard-header{flex-wrap:wrap;position:relative}.dashboard-grid{grid-template-columns:1fr}.welcome-section h1{font-size:1.35rem}.stat-value{font-size:1.5rem}.dashboard-main{padding:1rem}}@media (max-width: 480px){.auth-card{padding:1.5rem}.stats-grid{grid-template-columns:repeat(2,1fr)}}
