:root{--bg:#f5f6f8;--surface:#fff;--border:#e2e5ea;--text:#1a1a1a;--text-muted:#6b7280;--accent:#3b82f6;--green:#22c55e;--red:#ef4444;--yellow:#eab308;color:var(--text);background:var(--bg);font-family:system-ui,-apple-system,sans-serif;font-size:14px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{margin:0}#root{min-height:100vh}.portal-layout{min-height:100vh;display:flex}.portal-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;display:flex}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:.65rem;padding:1.25rem;display:flex}.sidebar-logo{width:auto;height:32px}.brand-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-size:.65rem;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:.15rem;padding:.75rem;display:flex}.sidebar-link{color:var(--text-muted);border-radius:6px;padding:.55rem .75rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .1s;display:block}.sidebar-link:hover{background:var(--bg);color:var(--text)}.sidebar-link.active{color:var(--accent);background:#3b82f614;font-weight:600}.sidebar-mqtt{padding:.75rem 1.25rem}.mqtt-indicator{align-items:center;gap:.5rem;font-size:.75rem;font-weight:500;display:flex}.mqtt-dot{border-radius:50%;width:6px;height:6px}.mqtt-indicator.connected .mqtt-dot{background:var(--green)}.mqtt-indicator.connected{color:var(--green)}.mqtt-indicator.disconnected .mqtt-dot{background:var(--red)}.mqtt-indicator.disconnected{color:var(--red)}.sidebar-footer{border-top:1px solid var(--border);padding:1rem 1.25rem}.sidebar-user{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin-bottom:.5rem;font-size:.8rem;overflow:hidden}.sidebar-logout{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;width:100%;padding:.35rem .75rem;font-size:.75rem}.sidebar-logout:hover{border-color:var(--red);color:var(--red)}.portal-main{flex:1;min-width:0;padding:2rem;overflow-y:auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.page-header h1{font-size:1.5rem;font-weight:600}.page-header-actions{gap:.5rem;display:flex}.page-placeholder{text-align:center;padding:4rem 2rem}.page-placeholder h1{color:var(--text);margin-bottom:.5rem}.page-placeholder p{color:var(--text-muted)}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;font-weight:600}.btn-primary:hover{opacity:.9}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;font-weight:500}.btn-secondary:hover{background:var(--bg)}.btn-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;align-items:center;padding:.3rem;transition:color .1s;display:inline-flex}.btn-edit:hover{color:var(--accent)}.btn-delete:hover{color:var(--red)}.btn-save{color:var(--green)}.btn-save:hover{color:#16a34a}.btn-cancel:hover{color:var(--red)}.stats-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.25rem}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.stat-value{color:var(--text);margin-top:.25rem;font-size:1.8rem;font-weight:700}.stat-green{color:var(--green)}.stat-yellow{color:var(--yellow)}.stat-red{color:var(--red)}.dashboard-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.25rem}.dash-card-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:1rem;font-size:.8rem;font-weight:600}.dash-card-wide{grid-column:1/-1}.dash-empty{color:var(--text-muted);text-align:center;padding:1rem 0;font-size:.85rem}.dash-all-clear{color:var(--green);justify-content:center;align-items:center;gap:.5rem;padding:1.5rem 0;font-size:.9rem;font-weight:500;display:flex}.stat-separator{color:var(--text-muted);margin:0 .15rem;font-size:1.2rem;font-weight:400}.alert-row{border-radius:6px;align-items:center;gap:.75rem;margin-bottom:.4rem;padding:.65rem .75rem;font-size:.85rem;display:flex}.alert-red{background:#ef44440f}.alert-yellow{background:#eab3080f}.alert-icon{flex-shrink:0}.alert-red .alert-icon{color:var(--red)}.alert-yellow .alert-icon{color:var(--yellow)}.alert-content{flex-direction:column;flex:1;gap:.1rem;display:flex}.alert-title{font-weight:500}.alert-sub,.alert-account{color:var(--text-muted);font-size:.75rem}.status-row{border-bottom:1px solid #0000000a;align-items:center;gap:.75rem;padding:.5rem 0;font-size:.85rem;display:flex}.status-row:last-child{border-bottom:none}.status-name{flex:1;font-weight:500}.status-account{color:var(--text-muted);flex:1}.recent-row{cursor:pointer;border-bottom:1px solid #0000000a;align-items:center;gap:1rem;padding:.5rem 0;font-size:.85rem;display:flex}.recent-row:last-child{border-bottom:none}.recent-row:hover{color:var(--accent)}.sub-breakdown{flex-direction:column;gap:.6rem;display:flex}.sub-bar-row{align-items:center;gap:.75rem;font-size:.8rem;display:flex}.sub-bar-label{min-width:80px;color:var(--text-muted)}.sub-bar{background:var(--bg);border-radius:4px;flex:1;height:8px;overflow:hidden}.sub-bar-fill{border-radius:4px;height:100%;transition:width .3s}.tier-enterprise-bg{background:#a855f7}.tier-pro-bg{background:var(--accent)}.tier-basic-bg{background:var(--text-muted)}.sub-bar-count{text-align:right;min-width:20px;font-weight:600}.filter-row{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.filter-select{border:1px solid var(--border);color:var(--text);background:var(--surface);cursor:pointer;border-radius:6px;padding:.4rem .65rem;font-size:.8rem}.filter-select:focus{border-color:var(--accent);outline:none}.filter-count{color:var(--text-muted);margin-left:auto;font-size:.8rem}.mqtt-status-badge{border-radius:20px;padding:.25rem .65rem;font-size:.75rem;font-weight:600}.mqtt-status-badge.connected{color:var(--green);background:#22c55e1a}.mqtt-status-badge.disconnected{color:var(--red);background:#ef44441a}.live-device-row{border-bottom:1px solid #0000000a;align-items:center;gap:.75rem;padding:.6rem 0;font-size:.85rem;display:flex}.live-device-row:last-child{border-bottom:none}.live-device-info{flex-direction:column;flex:1;gap:.1rem;display:flex}.live-device-name{font-weight:500}.live-device-meta,.live-device-seen{color:var(--text-muted);font-size:.75rem}.live-device-slug{color:var(--text-muted);font-size:.7rem;font-weight:400}.btn-dismiss{color:#ccc;cursor:pointer;background:0 0;border:none;border-radius:4px;margin-left:.5rem;padding:.2rem;display:inline-flex}.btn-dismiss:hover{color:var(--red)}.status-dot-sm.stale{background:var(--yellow)}.facility-live-status{align-items:center;gap:.35rem;font-size:.75rem;font-weight:500;display:inline-flex}.live-online{color:var(--green)}.live-stale{color:var(--yellow)}.live-offline{color:var(--red)}.data-table{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.data-table-header{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg);align-items:center;gap:1rem;padding:.6rem 1.25rem;font-size:.7rem;font-weight:600;display:flex}.data-table-header span{flex:1}.data-table-row{cursor:pointer;border-bottom:1px solid #0000000a;align-items:center;gap:1rem;padding:.85rem 1.25rem;font-size:.9rem;transition:background .1s;display:flex}.data-table-row:last-child{border-bottom:none}.data-table-row:hover{background:#3b82f608}.data-table-row.editing{cursor:default;background:#3b82f60a}.data-table-row.editing:hover{background:#3b82f60a}.data-table-row span{flex:1}.cell-primary{color:var(--text);font-weight:500}.cell-muted{color:var(--text-muted)}.cell-mono{color:var(--text-muted);font-family:monospace;font-size:.8rem}.cell-actions{justify-content:flex-end;gap:.25rem;display:flex;flex:0 0 100px!important}.edit-input{border:1px solid var(--accent);background:var(--surface);width:100%;color:var(--text);border-radius:4px;padding:.35rem .5rem;font-size:.85rem}.edit-input:focus{outline:none;box-shadow:0 0 0 2px #3b82f633}.role-badge{text-transform:uppercase;border-radius:4px;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.role-badge.admin{color:var(--accent);background:#3b82f61a}.role-badge.owner{color:var(--green);background:#22c55e1a}.role-badge.employee{color:var(--text-muted);background:#6b72801a}.status-badge{align-items:center;gap:.35rem;font-size:.8rem;display:inline-flex}.status-dot-sm{border-radius:50%;width:6px;height:6px}.status-dot-sm.online{background:var(--green)}.status-dot-sm.offline{background:var(--red)}.status-dot-sm.unknown{background:#ccc}.table-empty{text-align:center;color:var(--text-muted);padding:3rem}.go-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:5px;padding:.3rem .75rem;font-size:.75rem;font-weight:600}.go-btn:hover{opacity:.9}.back-link{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;gap:.3rem;margin-bottom:1rem;font-size:.85rem;text-decoration:none;display:inline-flex}.back-link:hover{text-decoration:underline}.detail-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.detail-header h1{font-size:1.5rem}.detail-section{margin-bottom:2rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.section-header h2{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:.85rem;font-weight:600}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:360px;padding:2.5rem 2rem}.login-brand{justify-content:center;margin-bottom:1rem;display:flex}.login-logo{width:auto;height:40px}.login-card h1{text-align:center;margin-bottom:.25rem;font-size:1.2rem}.login-card .subtitle{text-align:center;color:var(--text-muted);margin-bottom:1.5rem;font-size:.85rem}.login-form{flex-direction:column;gap:1rem;display:flex}.login-field{flex-direction:column;gap:.3rem;display:flex}.login-field label{color:var(--text-muted);font-size:.8rem;font-weight:500}.login-field input{border:1px solid var(--border);border-radius:6px;padding:.6rem .75rem;font-size:.9rem}.login-field input:focus{border-color:var(--accent);outline:none}.login-error{color:var(--red);text-align:center;font-size:.8rem}.login-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-top:.5rem;padding:.65rem;font-size:.9rem;font-weight:600}.login-submit:hover{opacity:.9}.login-submit:disabled{opacity:.5}.inline-form{border-top:1px solid var(--border);background:var(--bg);flex-wrap:wrap;align-items:center;gap:.5rem;padding:.75rem 1.25rem;display:flex}.inline-form input,.inline-form select{border:1px solid var(--border);border-radius:6px;min-width:120px;padding:.45rem .65rem;font-size:.85rem}.inline-form input:focus,.inline-form select:focus{border-color:var(--accent);outline:none}.inline-form input[type=number]{width:70px;min-width:70px}.search-input{border:1px solid var(--border);border-radius:6px;min-width:200px;padding:.45rem .75rem;font-size:.85rem}.search-input:focus{border-color:var(--accent);outline:none}.modal-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:12px;width:100%;max-width:560px;max-height:90vh;padding:2rem;overflow-y:auto;box-shadow:0 16px 48px #00000026}.modal h2{margin-bottom:1.25rem;font-size:1.2rem}.form-grid{flex-direction:column;gap:.75rem;display:flex}.form-row{gap:.75rem;display:flex}.form-field{flex-direction:column;flex:1;gap:.25rem;display:flex}.form-field.full{flex:100%}.form-field label{color:var(--text-muted);font-size:.75rem;font-weight:500}.form-field input,.form-field select,.form-field textarea{border:1px solid var(--border);color:var(--text);background:var(--surface);border-radius:6px;padding:.5rem .65rem;font-family:inherit;font-size:.85rem}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--accent);outline:none}.form-field textarea{resize:vertical}.form-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:.5rem;font-size:.75rem;font-weight:600}.form-error{color:var(--red);background:#ef44440f;border:1px solid #ef444426;border-radius:6px;padding:.5rem .75rem;font-size:.8rem}.form-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem;display:flex}.form-select{border:1px solid var(--border);border-radius:6px;flex:1;padding:.45rem .65rem;font-size:.85rem}.detail-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:1.5rem;display:flex}.detail-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.6rem 1.25rem;font-size:.85rem;font-weight:500}.detail-tab:hover{color:var(--text)}.detail-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.5rem}.card-title{margin-bottom:.75rem;font-size:1rem;font-weight:600}.info-grid{flex-direction:column;gap:.5rem;display:flex}.info-row{border-bottom:1px solid #0000000a;padding:.5rem 0;font-size:.9rem;display:flex}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-muted);flex-shrink:0;min-width:140px}.facility-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.facility-meta{color:var(--text-muted);border-top:1px solid var(--border);gap:1rem;margin-top:.5rem;padding-top:.5rem;font-size:.8rem;display:flex}.tier-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:.15rem .5rem;font-size:.65rem;font-weight:700;display:inline-block}.tier-basic{color:var(--text-muted);background:#6b72801a}.tier-pro{color:var(--accent);background:#3b82f61a}.tier-enterprise{color:#a855f7;background:#a855f71a}.sub-status{text-transform:uppercase;border-radius:4px;padding:.15rem .5rem;font-size:.65rem;font-weight:600;display:inline-block}.status-active{color:var(--green);background:#22c55e1a}.status-trial{color:var(--yellow);background:#eab3081a}.status-expired{color:var(--red);background:#ef44441a}.cell-dba{color:var(--text-muted);font-size:.85rem;font-weight:400}.btn-danger{color:var(--red)!important;border-color:#ef44444d!important}.btn-danger:hover{background:#ef44440d!important}.chip-select{flex-wrap:wrap;gap:.35rem;display:flex}.chip{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:5px;padding:.25rem .6rem;font-size:.75rem;font-weight:500;transition:all .1s}.chip:hover{border-color:var(--accent);color:var(--text)}.chip.active{color:var(--accent);background:#3b82f61a;border-color:#3b82f64d}.chip-sub{opacity:.6;font-size:.65rem}.access-panel{background:var(--bg);border-bottom:1px solid var(--border);flex-direction:column;gap:.75rem;padding:1rem 1.25rem;display:flex}.access-section{align-items:flex-start;gap:.75rem;display:flex}.access-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);min-width:70px;padding-top:.3rem;font-size:.7rem;font-weight:600}.facility-detail-sub{align-items:center;gap:.75rem;margin-top:.35rem;font-size:.85rem;display:flex}.link-text{cursor:pointer;color:var(--accent)}.link-text:hover{text-decoration:underline}.bay-list{flex-direction:column;display:flex}.bay-row{border-bottom:1px solid #0000000a;align-items:center;gap:.75rem;padding:.65rem 0;display:flex}.bay-row:last-child{border-bottom:none}.bay-row-all{border-top:1px solid var(--border);margin-top:.25rem;padding-top:.75rem}.bay-name{flex:1;font-size:.9rem;font-weight:500}.bay-state{min-width:60px;font-size:.8rem;font-weight:600}.bay-state.on{color:var(--green)}.bay-state.off{color:var(--text-muted)}.bay-actions{gap:.35rem;display:flex}.btn-bay-cmd{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:5px;padding:.3rem .65rem;font-size:.75rem;font-weight:600;transition:all .1s}.btn-bay-cmd:disabled{opacity:.3;cursor:not-allowed}.btn-bay-start{color:var(--accent);border-color:#3b82f64d}.btn-bay-start:hover:not(:disabled){background:#3b82f60f}.btn-bay-stop{color:var(--red);border-color:#ef44444d}.btn-bay-stop:hover:not(:disabled){background:#ef44440a}.cmd-result{color:var(--accent);background:#3b82f60d;border-radius:6px;margin-top:.75rem;padding:.5rem .75rem;font-size:.8rem}.config-wizard{max-width:900px}.config-load-bar{color:var(--yellow);background:#eab3080f;border:1px solid #eab30833;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.6rem 1rem;font-size:.85rem;display:flex}.config-load-bar.config-loaded{color:var(--green);background:#22c55e0f;border-color:#22c55e33}.wizard-steps{border:1px solid var(--border);border-radius:8px;gap:0;margin-bottom:1.5rem;display:flex;overflow:hidden}.wizard-step{background:var(--surface);border:none;border-right:1px solid var(--border);cursor:pointer;color:var(--text-muted);flex:1;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.8rem;transition:all .1s;display:flex}.wizard-step:last-child{border-right:none}.wizard-step:hover{background:var(--bg)}.wizard-step.active{color:var(--accent);background:#3b82f60f}.wizard-step.done{color:var(--green)}.wizard-step-num{border:1.5px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:700;display:flex}.wizard-step.active .wizard-step-num{background:var(--accent);color:#fff;border-color:var(--accent)}.wizard-step.done .wizard-step-num{background:var(--green);color:#fff;border-color:var(--green)}.wizard-step-label{font-weight:500}.wizard-panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.5rem}.wizard-panel h3{margin-bottom:1rem;font-size:1.1rem}.wizard-hint{color:var(--text-muted);margin-bottom:1rem;font-size:.85rem}.wizard-nav{border-top:1px solid var(--border);justify-content:space-between;margin-top:1.5rem;padding-top:1rem;display:flex}.config-pdu-card{border:1px solid var(--border);background:var(--bg);border-radius:8px;margin-bottom:.75rem;padding:1rem}.config-pdu-card h4{margin-bottom:.75rem;font-size:.9rem}.config-bay-card{border:1px solid var(--border);background:var(--bg);border-radius:8px;margin-bottom:.75rem;padding:1rem}.config-bay-card h4{margin-bottom:.75rem;font-size:.9rem}.outlet-name-grid{grid-template-columns:repeat(2,1fr);gap:.4rem;display:grid}.outlet-name-row{align-items:center;gap:.5rem;display:flex}.outlet-num{background:var(--accent);color:#fff;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;font-weight:700;display:flex}.outlet-name-input{border:1px solid var(--border);border-radius:4px;flex:1;padding:.35rem .5rem;font-size:.8rem}.outlet-name-input:focus{border-color:var(--accent);outline:none}.outlet-picker-named{flex-wrap:wrap;gap:.35rem;display:flex}.outlet-btn-named{border:1px solid var(--border);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:5px;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.75rem;transition:all .1s;display:flex}.outlet-btn-named:hover:not(:disabled){border-color:var(--accent)}.outlet-btn-named.active{color:var(--accent);background:#3b82f61a;border-color:#3b82f666}.outlet-btn-named.taken{opacity:.4;cursor:not-allowed;border-style:dashed}.outlet-btn-num{font-weight:700}.outlet-btn-label{font-weight:400}.sequence-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.sequence-section{margin-bottom:1rem}.sequence-type{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem}.sequence-step{border-bottom:1px solid #0000000a;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.8rem;display:flex}.step-num{background:var(--bg);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.65rem;font-weight:700;display:flex}.step-label{color:var(--text-muted);min-width:40px}.step-select,.step-input{border:1px solid var(--border);border-radius:4px;padding:.25rem .4rem;font-size:.8rem}.step-unit{color:var(--text-muted);font-size:.75rem}.sequence-add{margin-top:.5rem}.config-device-row{border-bottom:1px solid #0000000a;padding:.75rem 0}.config-device-row:last-child{border-bottom:none}.config-bay{border-bottom:1px solid var(--border);padding:1rem 0}.config-bay:last-child{border-bottom:none}.config-bay-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.config-bay-header h4{font-size:.9rem;font-weight:600}.outlet-picker{gap:.25rem;display:flex}.outlet-btn{border:1px solid var(--border);width:30px;height:30px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:5px;font-size:.8rem;font-weight:600;transition:all .1s}.outlet-btn:hover{border-color:var(--accent);color:var(--text)}.outlet-btn.active{color:var(--accent);background:#3b82f61a;border-color:#3b82f666}.config-push-bar{background:var(--surface);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.ota-form{align-items:center;gap:.75rem;display:flex}.ota-url-input{border:1px solid var(--border);border-radius:6px;flex:1;padding:.5rem .75rem;font-family:monospace;font-size:.85rem}.ota-url-input:focus{border-color:var(--accent);outline:none}.fw-badge{color:var(--accent);background:#3b82f614;border-radius:4px;padding:.15rem .5rem;font-family:monospace;font-size:.7rem;font-weight:600;display:inline-block}.provision-layout{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.provision-config{flex-direction:column;display:flex}.provision-warning{color:var(--red);background:#ef44440f;border:1px solid #ef444433;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem}.btn-provision{width:100%;padding:.75rem;font-size:1rem}.btn-provision:disabled{opacity:.4}.manual-cmd-form{gap:.5rem;display:flex}.manual-cmd-form input{border:1px solid var(--border);border-radius:6px;flex:1;padding:.45rem .65rem;font-family:monospace;font-size:.85rem}.manual-cmd-form input:focus{border-color:var(--accent);outline:none}.provision-log{background:#1a1a1a;border-radius:10px;flex-direction:column;display:flex;overflow:hidden}.log-header{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.log-header .dash-card-title{color:#888}.log-output{color:#ccc;flex:1;min-height:400px;max-height:600px;padding:.75rem 1rem;font-family:monospace;font-size:.8rem;line-height:1.5;overflow-y:auto}.log-empty{color:#555}.log-line{white-space:pre-wrap;word-break:break-all}.log-send{color:#60a5fa}.log-portal{color:#22c55e}.log-esp{color:#a78bfa}.log-divider{color:#eab308}.page-loading{text-align:center;color:var(--text-muted);padding:4rem}
