*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#3b82f6;--primary-dark:#1d4ed8;--primary-light:#93bbfd;--secondary:#10b981;--danger:#ef4444;--warning:#f59e0b;--success:#22c55e;--bg:#f1f5f9;--bg-dark:#0f172a;--card:#fff;--border:#e2e8f0;--text:#1e293b;--text-muted:#64748b;--shadow:0 1px 3px #00000014,0 1px 2px #0000000a;--shadow-lg:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000000f;--navbar-bg:linear-gradient(135deg,#0f172a,#1e3a5f);--navbar-text:#f1f5f9;--radius:0.75rem}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f1f5f9;background:var(--bg);color:#1e293b;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media (max-width:768px){html{font-size:14px}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9;background:var(--bg)}::-webkit-scrollbar-thumb{background:#e2e8f0;background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#64748b;background:var(--text-muted)}.app{display:flex;flex-direction:column;min-height:100vh}.loading-screen{color:var(--text-muted);font-size:1.2rem}.access-denied,.loading-screen{align-items:center;display:flex;justify-content:center;min-height:100vh}.access-denied{flex-direction:column;padding:2rem;text-align:center}.access-denied h2{color:var(--danger);margin-bottom:1rem}.navbar{align-items:center;background:var(--navbar-bg);border-bottom:none;box-shadow:0 4px 12px #00000026;display:flex;justify-content:space-between;padding:.75rem 2rem;position:sticky;top:0;z-index:100}.navbar-brand{color:#fff;font-size:1.35rem;font-weight:800;letter-spacing:.02em;text-decoration:none}.navbar-nav{align-items:center;display:flex;gap:.5rem;list-style:none}.nav-link{border-radius:var(--radius);color:var(--navbar-text);font-size:.9rem;font-weight:500;opacity:.85;padding:.5rem 1rem;text-decoration:none;transition:all .2s}.nav-link:hover{background:#ffffff1f;color:#fff;opacity:1}.nav-link.active{background:#ffffff2e;color:#fff;font-weight:600;opacity:1}.user-menu{align-items:center;display:flex;gap:.75rem}.user-badge{border:1px solid #ffffff26;border-radius:var(--radius);color:#ffffffe6;padding:.35rem .75rem}.lang-toggle,.user-badge{background:#ffffff1a;font-size:.8rem}.lang-toggle{border:1px solid #fff3;border-radius:var(--radius);color:#fff;padding:.35rem .65rem}.lang-toggle:hover{background:#fff3}.btn-logout{background:#ef444433;border:1px solid #ef44444d;border-radius:var(--radius);color:#fca5a5;cursor:pointer;font-size:.8rem;font-weight:500;padding:.4rem .85rem;transition:all .2s}.btn-logout:hover{background:#dc2626}.btn{align-items:center;border:none;border-radius:.375rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:#059669}.btn-danger{background:var(--danger)}.btn:disabled{cursor:not-allowed;opacity:.5}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-lg)}.card-header{border-bottom:2px solid var(--primary-light);color:var(--text);font-size:1rem;font-weight:700;padding-bottom:.5rem}.card-header,.form-group{margin-bottom:1rem}.form-label{color:var(--text);display:block;font-weight:500;margin-bottom:.5rem}.form-input{border:1px solid var(--border);border-radius:.375rem;font-size:.875rem;padding:.5rem .75rem;transition:all .2s;width:100%}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-select{background:#fff;border:1px solid var(--border);cursor:pointer;font-size:.875rem;padding:.5rem .75rem;width:100%}.alert,.form-select{border-radius:.375rem}.alert{margin-bottom:1rem;padding:1rem}.alert-success{background:#d1fae5;border:1px solid #6ee7b7;color:#065f46}.alert-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.alert-warning{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.alert-info{background:#dbeafe;border:1px solid #93c5fd;color:#1e40af}@media (max-width:768px){.navbar{gap:1rem;padding:1rem}.navbar,.navbar-nav{flex-direction:column}.nav-link,.navbar-nav{width:100%}.nav-link{text-align:center}.card{padding:1rem}}.login-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-container{max-width:440px;width:100%}.login-header{color:#fff;margin-bottom:2rem;text-align:center}.login-header h1{font-size:2rem;margin-bottom:.5rem}.login-header p{font-size:1rem;opacity:.9}.login-form{background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a;padding:2rem}.login-form h2{color:var(--text);margin-bottom:1.5rem;text-align:center}.btn-block{margin-top:1rem;width:100%}.login-help{border-top:1px solid var(--border);color:var(--text-muted);font-size:.875rem;margin-top:1.5rem;padding-top:1.5rem}.login-help p{margin:.5rem 0}@media (max-width:640px){.login-header h1{font-size:1.5rem}.login-form{padding:1.5rem}}.language-switcher{display:flex;gap:.5rem;position:absolute;right:1rem;top:1rem}.lang-btn{background:#0000;border:2px solid #ffffff80;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.375rem .75rem;transition:all .2s}.lang-btn:hover{background:#fff3}.lang-btn.active{background:#ffffff4d;border-color:#fff}.control-panel{margin-top:1.5rem}.control-panel-title{border-bottom:2px solid var(--primary);color:var(--text);font-size:1.25rem;font-weight:700;margin-bottom:1.5rem;padding-bottom:.75rem}.sim-mode-banner{background:linear-gradient(135deg,#fef9c3,#fef08a);border:1px solid #facc15;border-radius:.5rem;color:#854d0e;font-size:.875rem;font-weight:600;margin-bottom:1rem;padding:.5rem 1rem;text-align:center}.control-section{background:var(--card);border:1px solid var(--border);border-radius:.75rem;box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.control-section h3{border-bottom:2px solid var(--primary);color:var(--text);font-size:1rem;font-weight:700;margin-bottom:.5rem;padding-bottom:.5rem}.control-hint{color:var(--text-muted);font-size:.8rem;font-style:italic;margin-bottom:1rem}.control-feedback{align-items:center;border-radius:.5rem;display:flex;font-size:.875rem;font-weight:500;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem}.control-feedback.success{background:#d1fae5;color:#065f46}.control-feedback.error{background:#fee2e2;color:#991b1b}.control-feedback.info{background:#dbeafe;color:#1e40af}.feedback-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.25rem;line-height:1;padding:0 .25rem}.relay-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-top:1rem}.relay-control{align-items:center;background:var(--bg);border:2px solid var(--border);border-radius:.5rem;display:flex;flex-direction:column;gap:.35rem;padding:1rem;transition:all .3s}.relay-control.active{background:#f0fdf4;border-color:var(--success)}.relay-label{color:var(--text-muted);font-size:.875rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.relay-sublabel{color:var(--text-muted);font-size:.75rem}.relay-status{font-size:1.25rem;font-weight:700}.relay-control.active .relay-status{color:var(--success)}.toggle-btn{border:none;border-radius:.375rem;cursor:pointer;font-size:.8rem;font-weight:600;padding:.375rem 1rem;text-transform:uppercase;transition:all .2s}.toggle-btn:disabled{cursor:not-allowed;opacity:.45}.toggle-btn.off{background:var(--primary);color:#fff}.toggle-btn.off:hover:not(:disabled){background:var(--primary-dark)}.toggle-btn.on{background:var(--danger);color:#fff}.toggle-btn.on:hover:not(:disabled){background:#dc2626}.toggle-btn.large{font-size:.875rem;padding:.625rem 1.5rem}.mode-control{display:flex;gap:1rem;margin-top:.75rem}.mode-btn{background:var(--bg);border:2px solid var(--border);border-radius:.5rem;color:var(--text);cursor:pointer;flex:1 1;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.mode-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.mode-btn:hover:not(.active){border-color:var(--primary);color:var(--primary)}.hyper-control{background:var(--bg);border:2px solid var(--border);border-radius:.5rem;display:flex;flex-direction:column;gap:1rem;margin-top:.75rem;padding:1rem;transition:all .3s}.hyper-control.active{background:#fef2f2;border-color:var(--danger)}.hyper-status{align-items:center;display:flex;font-weight:600;gap:.75rem}.hyper-indicator{border-radius:50%;display:inline-block;flex-shrink:0;height:14px;width:14px}.hyper-indicator.on{background:var(--danger);box-shadow:0 0 8px var(--danger)}.hyper-indicator.off{background:var(--border)}.hyper-actions{display:flex;flex-direction:column;gap:.75rem}.hyper-sp-label{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.hyper-sp-label input{background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text);font-size:.875rem;padding:.375rem .5rem;width:80px}.hyper-btns{display:flex;flex-wrap:wrap;gap:.75rem}.hyper-on{background:var(--danger)!important}.hyper-off{background:var(--success)!important}.pump-control{background:var(--bg);border:2px solid var(--border);border-radius:.5rem;display:flex;flex-direction:column;gap:1rem;margin-top:.75rem;padding:1rem;transition:all .3s}.pump-control.active{background:#fff7ed;border-color:#f97316}.pump-btns{display:flex;flex-wrap:wrap;gap:.75rem}.pump-on{background:#f97316!important;color:#fff!important}.pump-on:hover:not(:disabled){background:#ea580c!important}.setpoints-form{display:flex;flex-direction:column;gap:1rem}.setpoints-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.setpoint-group h4{color:var(--primary);font-size:.9rem;font-weight:600;margin-bottom:.75rem}.setpoint-group label{align-items:center;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:.5rem}.setpoint-group label span{color:var(--text);font-size:.85rem;font-weight:500;white-space:nowrap}.setpoint-group input[type=number]{background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text);font-size:.9rem;padding:.5rem;text-align:right;width:120px}.setpoint-group input[type=number]:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.current-vals{background:var(--bg);border-radius:.25rem;color:var(--text-muted);font-family:monospace;font-size:.75rem;margin-top:.5rem;padding:.375rem .5rem}.btn-apply{align-self:flex-end;background:var(--primary);border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.625rem 2rem;transition:background .2s}.btn-apply:hover{background:var(--primary-dark)}.scenario-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-top:.75rem}.scenario-btn{background:var(--bg);border:2px solid var(--border);border-radius:.5rem;color:var(--text);cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1rem;transition:all .2s}.scenario-btn:hover{background:var(--card);border-color:var(--primary);transform:translateY(-1px)}.scenario-btn.success{border-color:var(--success);color:var(--success)}.scenario-btn.success:hover{background:#f0fdf4}.scenario-btn.danger{border-color:var(--danger);color:var(--danger)}.scenario-btn.danger:hover{background:#fef2f2}.control-loading{color:var(--text-muted);padding:2rem;text-align:center}@media (max-width:768px){.relay-grid{grid-template-columns:repeat(2,1fr)}.setpoints-grid{grid-template-columns:1fr}.hyper-btns,.mode-control,.pump-btns{flex-direction:column}.scenario-grid{grid-template-columns:repeat(2,1fr)}}.dashboard{background:var(--bg);min-height:100vh}.dashboard-content{padding:2rem}.container{margin:0 auto;max-width:1400px}.container h1{color:var(--text);margin-bottom:2rem}.metrics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:2rem}.metrics-grid.four-col{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.metric-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;padding:1.5rem;position:relative;text-align:center;transition:transform .2s,box-shadow .2s}.metric-card:before{background:linear-gradient(90deg,var(--primary),var(--secondary));content:"";height:4px;left:0;position:absolute;right:0;top:0}.metric-card.alarm-high:before,.metric-card.alarm-low:before{animation:alarm-pulse 1.5s ease-in-out infinite;background:linear-gradient(90deg,#ef4444,#dc2626)}.metric-card.alarm-high,.metric-card.alarm-low{background:linear-gradient(135deg,var(--card),#fff5f5);border-color:#fca5a5}@keyframes alarm-pulse{0%,to{opacity:1}50%{opacity:.5}}.metric-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.metric-label{color:var(--text-muted);font-size:.875rem;font-weight:600;margin-bottom:.5rem;text-transform:uppercase}.metric-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:.5rem}.metric-card.alarm-high .metric-value,.metric-card.alarm-low .metric-value{background:linear-gradient(135deg,#ef4444,#dc2626);-webkit-background-clip:text;background-clip:text}.metric-status{color:var(--text-muted);font-size:.875rem}.metric-detail{border-top:1px solid var(--border);color:var(--text-muted);font-size:.75rem;margin-top:.5rem;opacity:.8;padding-top:.5rem}.outputs-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.outputs-grid.di-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.output{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;font-size:.9rem;font-weight:600;gap:.25rem;padding:.875rem;text-align:center;transition:all .3s}.output-label{color:var(--text-muted);font-size:.8rem;font-weight:500}.output-state{font-size:1rem;font-weight:700}.output.active{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#16a34a;box-shadow:0 0 12px #22c55e4d;color:#fff}.output.active .output-label{color:#fffc}.loading{color:var(--text-muted);padding:3rem;text-align:center}@media (max-width:768px){.dashboard-content{padding:1rem}.metrics-grid{grid-template-columns:repeat(2,1fr)}.metric-value{font-size:2rem}}@media (max-width:480px){.metrics-grid{grid-template-columns:1fr}}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.dashboard-header h1{margin-bottom:0}.ws-status{border-radius:1rem;font-size:.875rem;font-weight:500;padding:.375rem .75rem}.ws-status.connected{background:#d1fae5;color:#065f46}.ws-status.disconnected{background:#fee2e2;color:#991b1b}.extended-io{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem}.extended-io .card{margin-bottom:0}.metric-card.mini{padding:1rem}.metric-card.mini:before{background:linear-gradient(90deg,var(--warning),var(--primary))}.metric-value.small{font-size:1.75rem}.metric-unit{color:var(--text-muted);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.output.di{font-size:.8rem;padding:.75rem .5rem}.data-controls{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.control-group{display:flex;flex-direction:column;gap:.25rem}.export-group{margin-left:auto}.export-buttons{display:flex;gap:.5rem}.chart-card{margin-bottom:1.5rem}.table-wrapper{max-height:500px;overflow-x:auto;overflow-y:auto}.data-table{border-collapse:collapse;font-size:.875rem;width:100%}.data-table td,.data-table th{border-bottom:1px solid var(--border);padding:.5rem .75rem;text-align:left;white-space:nowrap}.data-table th{font-weight:600;position:sticky;top:0;z-index:1}.data-table th,.data-table tr:hover{background:var(--bg)}.pagination{align-items:center;display:flex;gap:1rem;justify-content:center;padding:1rem}.lang-toggle{background:var(--bg);border:1px solid var(--border);border-radius:.375rem;cursor:pointer;font-size:.75rem;font-weight:600;padding:.375rem .75rem;transition:all .2s}.lang-toggle:hover{background:var(--primary);border-color:var(--primary);color:#fff}@media (max-width:768px){.data-controls{flex-direction:column}.export-group{margin-left:0}.control-group,.form-select{width:100%}}.export-profile-group{display:flex;flex-direction:column;gap:.4rem;position:relative}.export-profile-name{align-items:center;color:#374151;display:flex;font-size:.82rem;gap:.3rem}.export-profile-name strong{color:#1d4ed8}.export-info-btn{align-items:center;background:none;border:1px solid #93c5fd;border-radius:50%;color:#2563eb;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:.7rem;height:18px;justify-content:center;line-height:1;padding:0;width:18px}.export-info-btn:hover{background:#eff6ff}.export-profile-tooltip{background:#fff;border:1px solid #93c5fd;border-radius:8px;box-shadow:0 4px 16px #0000001f;color:#374151;display:flex;flex-direction:column;font-size:.82rem;gap:.2rem;left:0;min-width:240px;padding:.75rem;position:absolute;top:calc(100% + 4px);z-index:50}.export-manage-link{color:#2563eb;font-size:.8rem;font-weight:600;margin-top:.4rem;text-decoration:none}.export-manage-link:hover{text-decoration:underline}.tabs{border-bottom:2px solid var(--border);display:flex;gap:0;margin-bottom:1.5rem}.tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--text-muted);cursor:pointer;font-size:.9375rem;font-weight:500;margin-bottom:-2px;padding:.75rem 1.5rem;transition:all .2s}.tab.active,.tab:hover{color:var(--primary)}.tab.active{border-bottom-color:var(--primary)}.form-row{gap:1rem;margin-bottom:1rem}.form-row .form-group{flex:1 1;min-width:200px}.user-form{border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding-bottom:1.5rem}.role-badge{border-radius:1rem;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.role-user{background:#dbeafe;color:#1e40af}.role-supervisor{background:#d1fae5;color:#065f46}.role-webmaster{background:#fef3c7;color:#92400e}.btn-sm{font-size:.75rem;padding:.25rem .5rem}.delete-confirm-label{align-items:center;color:var(--danger);cursor:pointer;display:flex;font-weight:500;gap:.5rem}.system-info{display:flex;flex-direction:column;gap:.75rem}.info-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:.75rem}@media (max-width:768px){.tabs{overflow-x:auto}.tab{font-size:.875rem;padding:.5rem 1rem;white-space:nowrap}.form-row{flex-direction:column}.form-row .form-group{min-width:100%}}.settings-page{background:var(--bg);min-height:100vh}.settings-content{padding:2rem}.settings-content h1{color:var(--text);margin-bottom:1.5rem}.settings-card{background:var(--card);border:1px solid var(--border);border-radius:.75rem;box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.settings-card h2{border-bottom:2px solid var(--primary);color:var(--text);font-size:1.1rem;margin-bottom:1rem;padding-bottom:.5rem}.info-row{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.info-label{color:var(--text-muted);font-weight:600;min-width:100px}.info-value{color:var(--text)}.badge-role{background:var(--primary);border-radius:.25rem;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;padding:.2rem .6rem;text-transform:uppercase}.password-form{display:flex;flex-direction:column;gap:.75rem}.password-form label{display:flex;flex-direction:column;gap:.25rem}.password-form label span{color:var(--text);font-size:.85rem;font-weight:500}.password-form input{background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text);font-size:.9rem;padding:.625rem}.password-form input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.pref-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:.5rem 0}.pref-row span{color:var(--text);font-weight:500}.pref-row select{background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text);font-size:.9rem;min-width:140px;padding:.5rem .75rem}.pref-row select:focus{border-color:var(--primary);outline:none}.btn-primary{background:var(--primary);border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;margin-top:.5rem;padding:.625rem 1.5rem;transition:background .2s}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.settings-feedback{border-radius:.375rem;font-size:.875rem;font-weight:500;margin-bottom:1rem;padding:.625rem 1rem}.settings-feedback.success{background:#d1fae5;color:#065f46}.settings-feedback.error{background:#fee2e2;color:#991b1b}@media (max-width:768px){.settings-content{padding:1rem}.pref-row{align-items:flex-start;flex-direction:column;gap:.5rem}.pref-row select{width:100%}}.opcua-config-page{background:var(--bg);min-height:100vh}.opcua-config-content{padding:2rem}.opcua-config-content h1{color:var(--text);margin-bottom:.5rem}.webmaster-badge{background:#7c3aed;border-radius:.25rem;color:#fff;display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.05em;margin-bottom:1.5rem;padding:.2rem .7rem;text-transform:uppercase}.config-tabs{border-bottom:2px solid var(--border);display:flex;gap:.25rem;margin-bottom:1.5rem;overflow-x:auto}.tab-btn{background:none;border:none;border-bottom:3px solid #0000;color:var(--text-muted);cursor:pointer;font-size:.9rem;font-weight:500;margin-bottom:-2px;padding:.625rem 1.25rem;transition:color .2s,border-color .2s;white-space:nowrap}.tab-btn.active,.tab-btn:hover{color:var(--primary)}.tab-btn.active{border-bottom-color:var(--primary)}.config-card{background:var(--card);border:1px solid var(--border);border-radius:.75rem;box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.config-card h2{border-bottom:2px solid var(--primary);color:var(--text);font-size:1.1rem;margin-bottom:1rem;padding-bottom:.5rem}.config-card h3{color:var(--text);font-size:.95rem;margin:1rem 0 .5rem}.form-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.875rem}.form-row label{color:var(--text);font-size:.9rem;font-weight:500;min-width:160px}.form-row input[type=number],.form-row input[type=text],.form-row select{font-size:.9rem}.backup-textarea,.form-row input[type=number],.form-row input[type=text],.form-row select{background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text);flex:1 1;min-width:180px;padding:.5rem .75rem}.backup-textarea{font-family:monospace;font-size:.85rem;min-height:120px;resize:vertical}.form-row input:focus,.form-row select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.hint{color:var(--text-muted);font-size:.78rem;margin-top:.125rem}.node-filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.node-filter-bar input,.node-filter-bar select{background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text);font-size:.85rem;padding:.4rem .75rem}.node-filter-bar input{flex:1 1;min-width:180px}.node-table-wrap{overflow-x:auto}.node-table{border-collapse:collapse;font-size:.85rem;width:100%}.node-table th{background:var(--bg);border-bottom:2px solid var(--border);color:var(--text-muted);font-weight:600;padding:.625rem .75rem;text-align:left;white-space:nowrap}.node-table td{border-bottom:1px solid var(--border);padding:.5rem .75rem;vertical-align:middle}.node-table tr:hover td{background:#2563eb08}.node-table input[type=text]{width:120px}.node-table input[type=number],.node-table input[type=text]{background:var(--bg);border:1px solid var(--border);border-radius:.25rem;color:var(--text);font-size:.82rem;padding:.3rem .5rem}.node-table input[type=number]{width:80px}.node-table input[type=checkbox]{cursor:pointer;height:16px;width:16px}.node-id-cell{font-size:.78rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.datatype-badge,.node-id-cell{color:var(--text-muted);font-family:monospace}.datatype-badge{background:var(--border);border-radius:.2rem;display:inline-block;font-size:.75rem;padding:.1rem .4rem}.calc-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:1.5rem}.calc-item{display:flex;flex-direction:column;gap:.25rem}.calc-item label{color:var(--text-muted);font-size:.85rem;font-weight:500}.calc-item input,.calc-item select{background:var(--bg);border:1px solid var(--border);border-radius:.375rem;color:var(--text);font-size:.9rem;padding:.5rem .75rem}.calc-result{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd;border-radius:.75rem;padding:1.25rem}.calc-result h3{color:#1d4ed8;font-size:1rem;margin-bottom:.875rem}.calc-stat-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.calc-stat{background:#fff;border:1px solid #bfdbfe;border-radius:.5rem;padding:.75rem 1rem}.calc-stat .stat-label{color:#6b7280;font-size:.75rem;margin-bottom:.2rem}.calc-stat .stat-value{color:#1d4ed8;font-size:1.2rem;font-weight:700}.calc-stat .stat-unit{color:#6b7280;font-size:.75rem;margin-left:.25rem}.calc-note{color:#6b7280;font-size:.78rem;font-style:italic;margin-top:.875rem}.config-feedback{border-radius:.375rem;font-size:.875rem;font-weight:500;margin-bottom:1rem;padding:.625rem 1rem}.config-feedback.success{background:#d1fae5;color:#065f46}.config-feedback.error{background:#fee2e2;color:#991b1b}.btn-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.btn-save{background:var(--primary);border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.625rem 1.5rem;transition:background .2s}.btn-save:hover{background:var(--primary-dark)}.btn-save:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#0000;border:1px solid var(--primary);border-radius:.375rem;color:var(--primary);cursor:pointer;font-size:.9rem;font-weight:500;padding:.625rem 1.25rem;transition:background .15s,color .15s}.btn-secondary:hover{background:var(--primary);color:#fff}.table-pagination{align-items:center;color:var(--text-muted);display:flex;font-size:.85rem;gap:.75rem;margin-top:.75rem}.table-pagination button{background:var(--bg);border:1px solid var(--border);border-radius:.25rem;color:var(--text);cursor:pointer;padding:.3rem .75rem}.table-pagination button:disabled{cursor:not-allowed;opacity:.4}@media (max-width:768px){.opcua-config-content{padding:1rem}.config-tabs{flex-wrap:nowrap}.form-row{align-items:flex-start;flex-direction:column}.form-row label{min-width:0;min-width:auto}.form-row input[type=number],.form-row input[type=text],.form-row select{width:100%}}.status-dashboard{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.status-card{align-items:flex-start;background:#1e1e2e;background:var(--bg-card,#1e1e2e);border:1px solid var(--border);border-radius:.5rem;display:flex;flex:1 1 180px;font-size:.85rem;gap:.6rem;min-width:180px;padding:.75rem 1rem}.status-card.ok{border-left:3px solid #22c55e}.status-card.warn{border-left:3px solid #f59e0b}.status-card.error{border-left:3px solid #ef4444}.status-card .status-dot{border-radius:50%;flex-shrink:0;height:10px;margin-top:3px;width:10px}.status-card.ok .status-dot{background:#22c55e}.status-card.warn .status-dot{background:#f59e0b}.status-card.error .status-dot{background:#ef4444}.status-card>div{display:flex;flex-direction:column;gap:.15rem;min-width:0}.status-card strong{color:var(--text-muted);font-size:.8rem;letter-spacing:.04em;text-transform:uppercase}.status-card span{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-sub{color:var(--text-muted)!important;font-size:.78rem!important}.logs-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.log-level-select,.log-search{background:var(--bg);border:1px solid var(--border);border-radius:.25rem;color:var(--text);font-size:.85rem;padding:.35rem .6rem}.log-search{flex:1 1 220px}.auto-refresh-toggle{align-items:center;color:var(--text-muted);cursor:pointer;display:flex;font-size:.85rem;gap:.35rem;-webkit-user-select:none;user-select:none}.logs-table-wrapper{border:1px solid var(--border);border-radius:.375rem;max-height:500px;overflow-x:auto;overflow-y:auto}.logs-table{border-collapse:collapse;font-family:monospace;font-size:.8rem;width:100%}.logs-table th{background:#1e1e2e;background:var(--bg-card,#1e1e2e);border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.75rem;letter-spacing:.05em;padding:.5rem .75rem;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:1}.logs-table td{border-bottom:1px solid #ffffff0a;padding:.3rem .75rem;vertical-align:top;white-space:pre-wrap;word-break:break-word}.log-row:hover td{background:#ffffff08}.log-ts{color:var(--text-muted);min-width:160px;white-space:nowrap}.log-msg{color:var(--text)}.log-meta{color:var(--text-muted);display:block;font-size:.75rem;margin-top:.2rem}.log-badge{border-radius:.25rem;display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.04em;padding:.1rem .45rem;text-transform:uppercase}.log-badge-error{background:#ef44442e;color:#f87171}.log-badge-warn{background:#f59e0b2e;color:#fbbf24}.log-badge-info{background:#3b82f62e;color:#60a5fa}.log-badge-debug{background:#a78bfa2e;color:#c4b5fd}.log-badge-http{background:#22c55e2e;color:#4ade80}.log-row.log-error td{background:#ef44440d}.log-row.log-warn td{background:#f59e0b0d}.ec-container{max-width:860px}.ec-subtitle{color:#6b7280;font-size:.95rem;margin-bottom:1.5rem;margin-top:-.5rem}.ec-form{display:flex;flex-direction:column;gap:1.5rem}.ec-section{background:#fff;background:var(--card-bg,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;padding:1.25rem 1.5rem 1.5rem}.ec-section-defaults{background:#f0f7ff;border-color:#2563eb44}.ec-section-title{border-bottom:2px solid #2563eb22;color:#1e3a5f;font-size:1rem;font-weight:700;margin:0 0 1rem;padding-bottom:.5rem}.ec-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.ec-row-gap{gap:1rem}.ec-mt{margin-top:.875rem}.ec-field{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:180px}.ec-grid-2{grid-gap:.875rem 1rem;display:grid;gap:.875rem 1rem;grid-template-columns:1fr 1fr}.ec-span-2{grid-column:span 2}.ec-select{max-width:240px}.ec-select-sm{max-width:140px}.ec-input-sm,.ec-select-sm{font-size:.9rem;padding:.3rem .6rem}.ec-input-sm{max-width:100px}.ec-textarea{min-height:56px;resize:vertical}.ec-btn-sm{font-size:.85rem;padding:.3rem .75rem}.ec-hint{color:#6b7280;font-size:.88rem;margin:0 0 .75rem}.ec-hint-muted{color:#9ca3af;font-size:.88rem;font-style:italic;margin:.25rem 0}.ec-radio-label{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;gap:.35rem;padding:.3rem .6rem;transition:border-color .15s,background .15s}.ec-radio-label:has(input:checked){background:#eff6ff;border-color:#2563eb;color:#1d4ed8}.ec-radio-label input[type=radio]{accent-color:#2563eb}.ec-checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:.9rem;gap:.4rem}.ec-checkbox-label input[type=checkbox]{accent-color:#2563eb;height:15px;width:15px}.ec-checkboxes-row{display:flex;flex-wrap:wrap;gap:1rem}.ec-months-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(4,1fr);margin-top:.75rem}.ec-month-chip{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.85rem;padding:.5rem;text-align:center;transition:border-color .15s,background .15s,color .15s;-webkit-user-select:none;user-select:none}.ec-month-chip.active{background:#2563eb;border-color:#2563eb;color:#fff;font-weight:600}.ec-month-chip:hover:not(.active){background:#eff6ff;border-color:#93c5fd}.ec-format-chip{background:#fff;border:2px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;letter-spacing:.04em;padding:.5rem 1.25rem;transition:border-color .15s,background .15s,color .15s;-webkit-user-select:none;user-select:none}.ec-format-chip.active{background:#2563eb;border-color:#2563eb;color:#fff}.ec-format-chip:hover:not(.active){background:#eff6ff;border-color:#60a5fa}.ec-params-table{border:1px solid #e5e7eb;border-radius:6px;margin-top:.75rem;overflow:hidden}.ec-params-header,.ec-params-row{grid-gap:.5rem;align-items:center;display:grid;gap:.5rem;grid-template-columns:1fr 80px 80px;padding:.5rem 1rem}.ec-params-header{background:#374151;color:#fff;font-size:.82rem;font-weight:700;text-align:center}.ec-params-header span:first-child{text-align:left}.ec-params-row{border-top:1px solid #f3f4f6;font-size:.88rem;text-align:center}.ec-params-row:nth-child(2n){background:#f9fafb}.ec-params-row input[type=checkbox]{accent-color:#2563eb;height:15px;justify-self:center;width:15px}.ec-param-label{text-align:left}.ec-param-label code{background:#f3f4f6;border-radius:3px;color:#6b7280;font-size:.78rem;margin-left:.35rem;padding:1px 4px}.ec-generate{display:flex;justify-content:center;padding:.5rem 0}.ec-btn-generate{font-size:1rem;font-weight:700;letter-spacing:.04em;min-width:200px;padding:.75rem 2rem}.ec-profile-banner{background:#fff;border:1px solid #93c5fd;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;padding:.875rem 1rem}.ec-profile-info{display:flex;flex-direction:column;font-size:.93rem;gap:.2rem}.ec-profile-meta{color:#6b7280;font-size:.8rem}.ec-profile-details{background:#f0f7ff;border-radius:6px;color:#374151;display:flex;flex-direction:column;font-size:.87rem;gap:.25rem;margin-top:.25rem;padding:.75rem}.ec-alert-sm{font-size:.88rem;margin:.5rem 0;padding:.5rem .875rem}.btn-danger{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.4rem 1rem;transition:background .15s}.btn-danger:hover{background:#dc2626}.btn-danger:disabled{cursor:not-allowed;opacity:.5}@media (max-width:640px){.ec-grid-2{grid-template-columns:1fr}.ec-span-2{grid-column:span 1}.ec-months-grid{grid-template-columns:repeat(3,1fr)}}