:root{font-family:Segoe UI,system-ui,sans-serif}.system-detail{color:#e0e0e0;background:linear-gradient(#060a14 0%,#0d1525 40%,#0a1020 100%);flex:1;min-height:0;padding:24px 32px 48px;overflow-y:auto}.sd-page-header{text-align:center;margin-bottom:24px}.sd-page-header h2{color:#fff;margin-bottom:6px;font-size:1.5rem;font-weight:700}.sd-page-header p{color:#64748b;font-size:.9rem}.sd-sim-controls{justify-content:center;align-items:center;gap:14px;margin-top:14px;display:flex}.sd-sim-btn{color:#34d399;cursor:pointer;background:#34d3991a;border:1px solid #34d399;border-radius:8px;padding:8px 24px;font-size:.85rem;font-weight:600;transition:all .2s}.sd-sim-btn:hover{background:#34d39933}.sd-sim-btn.active{color:#f87171;background:#ef444426;border-color:#ef4444}.sd-sim-hint{color:#475569;font-size:.8rem}.sd-wiring-diagram{background:#080c18e6;border:1px solid #ffffff0f;border-radius:16px;margin-bottom:32px;padding:16px;overflow:hidden}.sd-wiring-svg{width:100%;height:auto;display:block}.sd-clickable{cursor:pointer}.sd-clickable:hover rect{stroke-width:2px;stroke:#6ee7b7}.sd-flow-line{animation:.6s linear infinite sd-dash-flow}.sd-flow-line-down{animation:.6s linear infinite sd-dash-flow-down}@keyframes sd-dash-flow{0%{stroke-dashoffset:0}to{stroke-dashoffset:-20px}}@keyframes sd-dash-flow-down{0%{stroke-dashoffset:0}to{stroke-dashoffset:-20px}}.sd-pulse-ring{transform-origin:50%;animation:1.5s ease-out infinite sd-pulse}.sd-pulse-ring.delay1{animation-delay:.4s}@keyframes sd-pulse{0%{r:25;opacity:.6}to{r:55;opacity:0}}.sd-blink{animation:.8s ease-in-out infinite sd-blink-anim}@keyframes sd-blink-anim{0%,to{opacity:1}50%{opacity:.2}}.sd-bounce{animation:.6s ease-in-out infinite alternate sd-bounce-anim}@keyframes sd-bounce-anim{0%{transform:translateY(0)}to{transform:translateY(-4px)}}.sd-fade-in{animation:.4s ease-in sd-fade}@keyframes sd-fade{0%{opacity:0}to{opacity:1}}.sd-info-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;display:grid}.sd-info-card{text-align:center;background:#0f172acc;border:1px solid #ffffff14;border-radius:12px;padding:20px;transition:border-color .2s}.sd-info-card:hover{border-color:#34d3994d}.sd-info-card.shelly{background:#34d3990a;border-color:#34d39933}.sd-info-icon{margin-bottom:10px;font-size:2rem}.sd-info-title{color:#fff;margin-bottom:8px;font-size:.95rem;font-weight:700}.sd-info-desc{color:#94a3b8;font-size:.8rem;line-height:1.6}.sd-detail-section{margin-bottom:36px}.sd-detail-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.sd-detail-card{background:#0f172ad9;border:1px solid #1e293b;border-radius:12px;transition:border-color .3s;overflow:hidden}.sd-detail-card.recommended{border-color:#34d3994d}.sd-detail-card.alternative{border-color:#fbbf2433}.sd-detail-card:hover{border-color:#34d39999}.sd-detail-badge{color:#34d399;background:#34d39914;border-bottom:1px solid #34d3991a;padding:8px 16px;font-size:.85rem;font-weight:700}.sd-detail-badge.alt{color:#fbbf24;background:#fbbf2414;border-color:#fbbf241a}.sd-detail-media{background:#0003;justify-content:center;gap:8px;padding:16px;display:flex}.sd-detail-img{object-fit:contain;border-radius:8px;max-width:48%;max-height:180px}.sd-detail-body{padding:16px}.sd-detail-body h4{color:#e2e8f0;margin:0 0 8px;font-size:.95rem}.sd-detail-price{color:#34d399;background:#34d3991a;border-radius:12px;margin-bottom:12px;padding:3px 10px;font-size:.8rem;font-weight:600;display:inline-block}.sd-detail-specs{margin:0 0 12px;padding:0;list-style:none}.sd-detail-specs li{color:#cbd5e1;align-items:center;gap:6px;padding:4px 0;font-size:.82rem;display:flex}.sd-check{font-size:.75rem}.sd-detail-note{color:#94a3b8;background:#34d3990d;border-left:3px solid #34d399;border-radius:0 6px 6px 0;padding:8px 12px;font-size:.8rem;font-style:italic}.sd-detail-card.alternative .sd-detail-note{background:#fbbf240d;border-left-color:#fbbf24}.sd-cable-card{background:#0f172ad9;border:1px solid #1e293b;border-radius:12px;align-items:center;gap:24px;padding:20px;display:flex}.sd-cable-media{flex-shrink:0}.sd-cable-img{background:#0000004d;border-radius:8px;width:200px;height:auto;padding:8px}.sd-cable-body h4{color:#e2e8f0;margin:0 0 6px;font-size:.95rem}.sd-cable-desc{color:#94a3b8;margin:0 0 12px;font-size:.82rem;line-height:1.5}.sd-cable-wires{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.sd-wire-item{color:#cbd5e1;align-items:center;gap:8px;font-size:.82rem;display:flex}.sd-wire-dot{border:1px solid #ffffff1a;border-radius:50%;flex-shrink:0;width:12px;height:12px}.sd-cable-notes{flex-wrap:wrap;gap:12px;display:flex}.sd-cable-notes span{color:#64748b;background:#1e293b80;border-radius:8px;padding:4px 10px;font-size:.78rem}.sd-hw-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.sd-hw-card{background:#0f172ad9;border:1px solid #1e293b;border-radius:12px;transition:border-color .3s;overflow:hidden}.sd-hw-card:hover{border-color:#64748b66}.sd-hw-img-wrap{background:#00000040;justify-content:center;align-items:center;min-height:180px;padding:16px;display:flex}.sd-hw-img{object-fit:contain;border-radius:6px;max-width:100%;max-height:170px}.sd-hw-body{padding:16px}.sd-hw-body h4{color:#e2e8f0;margin:0 0 8px;font-size:.92rem}.sd-hw-qty{color:#34d399;background:#34d3991a;border-radius:10px;margin-bottom:12px;padding:2px 10px;font-size:.75rem;font-weight:600;display:inline-block}.sd-hw-specs{border-collapse:collapse;width:100%;margin-bottom:12px}.sd-hw-specs td{border-bottom:1px solid #1e293b99;padding:5px 8px;font-size:.78rem}.sd-hw-specs td:first-child{color:#64748b;width:40%;font-weight:500}.sd-hw-specs td:last-child{color:#cbd5e1}.sd-hw-note{color:#94a3b8;background:#34d3990d;border-left:3px solid #34d399;border-radius:0 6px 6px 0;padding:8px 12px;font-size:.78rem;font-style:italic}.sd-hw-img-wrap.icon-only{background:#0f172a99;min-height:140px}.sd-hw-icon{filter:grayscale(.2);font-size:4rem}.sd-power-section{margin-bottom:32px}.sd-power-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.sd-power-card{background:#0f172acc;border:1px solid #ef444426;border-radius:10px;overflow:hidden}.sd-power-header{color:#f87171;background:#ef444414;padding:10px 14px;font-size:.85rem;font-weight:600}.sd-power-body{flex-direction:column;gap:8px;padding:12px 14px;display:flex}.sd-power-item{color:#cbd5e1;align-items:center;gap:8px;font-size:.8rem;display:flex}.sd-pw-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sd-pw-dot.kc{background:#34d399}.sd-pw-dot.sensor{background:#3b82f6}.sd-pw-dot.th{background:#64b5f6}.sd-panel-section{margin-bottom:48px}.sd-section-title{color:#fff;border-bottom:1px solid #34d39933;margin-bottom:16px;padding-bottom:8px;font-size:1.15rem;font-weight:700}.sd-panel-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.sd-panel-card{background:#0f172ab3;border:1px solid;border-radius:10px;overflow:hidden}.sd-panel-header{align-items:center;gap:8px;padding:10px 12px;display:flex}.sd-panel-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.sd-panel-label{color:#fff;flex:1;font-size:.85rem;font-weight:600}.sd-panel-count{color:#94a3b8;font-size:.75rem}.sd-panel-lamps{flex-wrap:wrap;gap:4px;padding:8px 12px 12px;display:flex}.sd-lamp-tag{background:#ffffff08;border:1px solid;border-radius:4px;padding:2px 8px;font-size:.75rem;font-weight:500;display:inline-block}@media (width<=900px){.sd-info-row,.sd-panel-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.sd-info-row{grid-template-columns:1fr}.system-detail{padding:16px}}.cs-page{max-width:1300px;margin:0 auto;padding:20px}.cs-header{text-align:center;margin-bottom:24px}.cs-header h2{color:#93c5fd;margin-bottom:6px;font-size:1.4rem}.cs-header p{color:#64748b;font-size:.85rem}.cs-sim-controls{justify-content:center;align-items:center;gap:12px;margin-top:12px;display:flex}.cs-sim-btn{color:#94a3b8;cursor:pointer;background:#0f172acc;border:1px solid #334155;border-radius:8px;padding:8px 18px;font-size:.85rem;transition:all .3s}.cs-sim-btn:hover{color:#60a5fa;border-color:#60a5fa}.cs-sim-btn.active{color:#60a5fa;background:#60a5fa26;border-color:#60a5fa}.cs-sim-hint{color:#475569;font-size:.75rem}.cs-live-row{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.cs-live-card{cursor:pointer;background:#0f172acc;border:1px solid #1e293b;border-radius:12px;padding:16px;transition:all .3s}.cs-live-card:hover{border-color:#334155;transform:translateY(-2px)}.cs-live-card.active{background:#60a5fa0d;border-color:#60a5fa;box-shadow:0 0 25px #60a5fa26}.cs-live-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.cs-area-label{color:#e2e8f0;font-size:.95rem;font-weight:700}.cs-door-badge{border:1px solid;border-radius:20px;padding:3px 10px;font-size:.7rem;font-weight:600}.cs-temp-display{align-items:center;gap:8px;margin-bottom:8px;display:flex}.cs-temp-icon{font-size:1.6rem}.cs-temp-value{letter-spacing:-1px;font-size:2rem;font-weight:800}.cs-temp-bar-wrap{margin-bottom:8px}.cs-temp-bar{border-radius:3px;height:6px;transition:width .5s,background .5s}.cs-temp-range{justify-content:space-between;margin-top:2px;display:flex}.cs-temp-range span{color:#475569;font-size:.6rem}.cs-live-status{text-align:center;min-height:20px}.cs-alert{color:#ef4444;font-size:.8rem;font-weight:700;animation:.8s infinite csBlink}.cs-alert.warn{color:#fbbf24}.cs-ok{color:#34d399;font-size:.8rem}@keyframes csBlink{0%,to{opacity:1}50%{opacity:.3}}.cs-wiring-diagram{background:#0f172a99;border:1px solid #1e293b;border-radius:12px;margin-bottom:24px;padding:10px;overflow:hidden}.cs-wiring-svg{width:100%;height:auto;display:block}.cs-clickable{cursor:pointer}.cs-clickable:hover{fill:#60a5fa0d}.cs-blink{animation:.6s infinite csBlink}.cs-fade-in{animation:.4s ease-in csFadeIn}@keyframes csFadeIn{0%{opacity:0}to{opacity:1}}.cs-flow-line{animation:.5s linear infinite csFlowDash}@keyframes csFlowDash{0%{stroke-dashoffset:16px}to{stroke-dashoffset:0}}.cs-section{margin-bottom:28px}.cs-section-title{color:#93c5fd;border-bottom:1px solid #1e293b;margin-bottom:12px;padding-bottom:8px;font-size:1.1rem}.cs-info-text{color:#fcd34d;background:#fbbf240f;border:1px solid #fbbf2433;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:.85rem}.cs-info-text strong{color:#fbbf24}.cs-hw-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.cs-hw-card{background:#0f172acc;border:1px solid #1e293b;border-radius:10px;transition:border-color .3s;overflow:hidden}.cs-hw-card:hover{border-color:#334155}.cs-hw-img-wrap{background:#1e293b66;justify-content:center;align-items:center;min-height:120px;padding:12px;display:flex}.cs-hw-img-wrap.icon-only{min-height:120px}.cs-hw-icon{font-size:3.5rem}.cs-hw-img{object-fit:contain;border-radius:6px;max-width:100%;max-height:110px}.cs-hw-body{padding:12px 14px}.cs-hw-body h4{color:#e2e8f0;margin-bottom:6px;font-size:.85rem}.cs-hw-qty{color:#93c5fd;background:#60a5fa26;border-radius:12px;margin-bottom:8px;padding:2px 10px;font-size:.7rem;font-weight:600;display:inline-block}.cs-hw-specs{border-collapse:collapse;width:100%;margin-bottom:8px}.cs-hw-specs td{border-bottom:1px solid #1e293b;padding:3px 6px;font-size:.72rem}.cs-hw-specs td:first-child{color:#64748b;width:35%}.cs-hw-specs td:last-child{color:#cbd5e1}.cs-hw-note{color:#475569;border-top:1px solid #1e293b;margin-top:4px;padding-top:6px;font-size:.7rem;font-style:italic}.pn-page{max-width:1200px;margin:0 auto;padding:24px}.pn-hero{text-align:center;background:linear-gradient(135deg,#0f172ae6,#1e3a8a4d);border:1px solid #1e3a8a;border-radius:16px;margin-bottom:28px;padding:40px 20px 30px;position:relative;overflow:hidden}.pn-hero:before{content:"";pointer-events:none;background:radial-gradient(circle at 30%,#3b82f61a,#0000 60%),radial-gradient(circle at 70%,#8b5cf614,#0000 60%);position:absolute;inset:0}.pn-hero-badge{color:#fff;letter-spacing:3px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:20px;margin-bottom:14px;padding:4px 20px;font-size:.75rem;font-weight:800;display:inline-block}.pn-hero-title{color:#e2e8f0;letter-spacing:-.5px;margin-bottom:8px;font-size:1.8rem;font-weight:800}.pn-hero-sub{color:#94a3b8;margin-bottom:14px;font-size:.95rem}.pn-hero-meta{color:#64748b;justify-content:center;gap:24px;font-size:.8rem;display:flex}.pn-download-btn{color:#60a5fa;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#3b82f61f,#8b5cf614);border:1px solid #3b82f666;border-radius:10px;margin-top:16px;padding:10px 28px;font-size:.9rem;font-weight:600;transition:all .25s}.pn-download-btn:hover{background:linear-gradient(135deg,#3b82f638,#8b5cf626);border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 4px 16px #3b82f633}.pn-download-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.pn-pdf-mode .pn-no-print,.pn-pdf-mode .pn-add-row-btn,.pn-pdf-mode .pn-reset-btn,.pn-pdf-mode .pn-del-btn,.pn-pdf-mode .pn-td-action,.pn-pdf-mode .pn-th-act,.pn-pdf-mode .pn-add-img-btn{display:none!important}.pn-pdf-mode .pn-price-input,.pn-pdf-mode .pn-name-input,.pn-pdf-mode .pn-qty-input,.pn-pdf-mode .pn-sat-input{box-shadow:none!important;color:inherit!important;background:0 0!important;border:none!important;padding:0!important}.pn-pdf-mode .pn-section{page-break-inside:avoid;break-inside:avoid}.pn-pdf-mode .pn-table-wrap{page-break-inside:avoid;break-inside:avoid;overflow:visible!important}.pn-pdf-mode .pn-table{page-break-inside:auto}.pn-pdf-mode .pn-table thead{display:table-header-group}.pn-pdf-mode .pn-table tr{page-break-inside:avoid;break-inside:avoid}.pn-pdf-mode .pn-hero{page-break-after:avoid}.pn-pdf-mode .pn-timeline,.pn-pdf-mode .pn-payment-grid,.pn-pdf-mode .pn-garansi-grid{page-break-inside:avoid;break-inside:avoid}.pn-summary-row{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px;display:grid}.pn-sum-card{text-align:center;background:#0f172acc;border:1px solid #1e293b;border-radius:12px;padding:20px;transition:all .3s}.pn-sum-card:hover{border-color:#334155;transform:translateY(-3px)}.pn-sum-card.hw{border-left:3px solid #f59e0b}.pn-sum-card.sw{border-left:3px solid #3b82f6}.pn-sum-card.install{border-left:3px solid #f59e0b}.pn-sum-card.total{background:#10b9810a;border-left:3px solid #10b981}.pn-sum-icon{margin-bottom:6px;font-size:2rem}.pn-sum-label{color:#94a3b8;text-transform:uppercase;letter-spacing:1px;font-size:.8rem;font-weight:600}.pn-sum-value{color:#e2e8f0;margin:4px 0;font-size:1.4rem;font-weight:800}.pn-sum-value.grand{color:#34d399;font-size:1.6rem}.pn-sum-detail{color:#475569;font-size:.75rem}.pn-section{margin-bottom:32px}.pn-section-header{border-bottom:1px solid #1e293b;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px;padding-bottom:10px;display:flex}.pn-section-actions{align-items:center;gap:8px;display:flex}.pn-add-row-btn{color:#34d399;cursor:pointer;background:#34d39914;border:1px solid #34d3994d;border-radius:6px;padding:5px 14px;font-size:.75rem;font-weight:600;transition:all .2s}.pn-add-row-btn:hover{background:#34d39926;border-color:#34d399}.pn-reset-btn{color:#94a3b8;cursor:pointer;background:#94a3b80f;border:1px solid #94a3b833;border-radius:6px;padding:5px 12px;font-size:.75rem;transition:all .2s}.pn-reset-btn:hover{color:#cbd5e1;background:#94a3b81f}.pn-section-header h2{color:#e2e8f0;font-size:1.15rem;font-weight:700}.pn-section-badge{color:#fbbf24;background:#f59e0b1f;border:1px solid #f59e0b33;border-radius:20px;padding:4px 14px;font-size:.72rem;font-weight:600}.pn-section-badge.sw{color:#60a5fa;background:#3b82f61f;border-color:#3b82f633}.pn-section-badge.install{color:#fbbf24;background:#f59e0b1f;border-color:#f59e0b33}.pn-section-badge.preview{color:#a78bfa;background:#8b5cf61f;border-color:#8b5cf633}.pn-table-wrap{background:#0f172a99;border:1px solid #1e293b;border-radius:10px;overflow-x:auto}.pn-table{border-collapse:collapse;width:100%;font-size:.82rem}.pn-table thead{background:#1e293bcc}.pn-table th{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid #334155;padding:12px 14px;font-size:.72rem;font-weight:700}.pn-th-no{text-align:center;width:40px}.pn-th-qty,.pn-th-sat{text-align:center;width:60px}.pn-th-harga,.pn-th-total{text-align:right;width:140px}.pn-th-act{width:36px}.pn-table tbody tr{transition:background .2s}.pn-table tbody tr:hover{background:#3b82f60a}.pn-table td{color:#cbd5e1;border-bottom:1px solid #1e293b;padding:10px 14px}.pn-td-no{text-align:center;color:#475569;font-weight:600}.pn-td-nama{font-weight:500}.pn-name-input{color:#e2e8f0;background:#1e293b99;border:1px solid #334155;border-radius:6px;flex:1;padding:5px 8px;font-size:.8rem;font-weight:500;transition:border-color .2s}.pn-name-input:focus{border-color:#60a5fa;outline:none;box-shadow:0 0 0 2px #60a5fa26}.pn-nama-wrap{align-items:center;gap:10px;display:flex}.pn-row-img{object-fit:contain;cursor:pointer;background:#1e293b80;border-radius:5px;flex-shrink:0;width:38px;height:38px;padding:2px;transition:transform .2s,box-shadow .2s}.pn-row-img:hover{transform:scale(1.15);box-shadow:0 0 12px #60a5fa4d}.pn-td-qty{text-align:center;color:#60a5fa;font-weight:700}.pn-qty-input{color:#60a5fa;text-align:center;background:#1e293bcc;border:1px solid #334155;border-radius:6px;width:55px;padding:5px 4px;font-size:.8rem;font-weight:700;transition:border-color .2s}.pn-qty-input:focus{border-color:#60a5fa;outline:none;box-shadow:0 0 0 2px #60a5fa26}.pn-qty-input::-webkit-inner-spin-button{opacity:.3}.pn-td-sat{text-align:center;color:#64748b}.pn-sat-input{color:#94a3b8;text-align:center;background:#1e293b99;border:1px solid #334155;border-radius:6px;width:55px;padding:5px 4px;font-size:.78rem;transition:border-color .2s}.pn-sat-input:focus{border-color:#60a5fa;outline:none;box-shadow:0 0 0 2px #60a5fa26}.pn-td-action{text-align:center;width:36px}.pn-del-btn{color:#64748b;cursor:pointer;background:#ef44440f;border:1px solid #ef444433;border-radius:6px;width:26px;height:26px;font-size:.75rem;transition:all .2s}.pn-del-btn:hover{color:#ef4444;background:#ef444426;border-color:#ef4444}.pn-td-harga{text-align:right;color:#94a3b8;white-space:nowrap}.pn-price-input{color:#fbbf24;text-align:right;background:#1e293bcc;border:1px solid #334155;border-radius:6px;width:120px;padding:5px 8px;font-size:.8rem;font-weight:600;transition:border-color .2s}.pn-price-input:focus{border-color:#60a5fa;outline:none;box-shadow:0 0 0 2px #60a5fa26}.pn-price-input::-webkit-inner-spin-button{opacity:.3}.pn-td-total{text-align:right;color:#e2e8f0;white-space:nowrap;font-weight:700}.pn-td-desc{color:#64748b;font-size:.78rem}.pn-table tfoot td{border-top:2px solid #334155;padding:14px;font-weight:800}.pn-tf-label{text-align:right;color:#94a3b8;font-size:.85rem}.pn-tf-label.grand{color:#34d399;font-size:1rem}.pn-tf-value{text-align:right;color:#fbbf24;white-space:nowrap;font-size:1rem}.pn-tf-value.sw{color:#60a5fa}.pn-tf-value.grand{color:#34d399;font-size:1.2rem}.pn-grand-row{background:#10b9810f}.sw-table .pn-th-nama{width:35%}.sw-val{color:#60a5fa!important}.rekap-table .pn-th-total{width:200px}.pn-sw-note{color:#475569;border-left:2px solid #1e293b;margin-top:8px;padding-left:14px;font-size:.75rem;font-style:italic}.pn-sw-intro{color:#94a3b8;margin-bottom:18px;font-size:.85rem;line-height:1.65}.pn-sw-intro strong{color:#e2e8f0}.tech-table .pn-td-layer{color:#cbd5e1;white-space:nowrap;font-weight:600}.tech-table .pn-td-tech{color:#94a3b8}.tech-table .pn-td-note{color:#64748b;font-size:.82rem}.pn-timeline{padding:20px 0;position:relative}.pn-timeline:before{content:"";background:linear-gradient(#1e3a8a,#3b82f6,#1e3a8a);width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.pn-timeline-item{align-items:flex-start;width:50%;margin-bottom:24px;display:flex;position:relative}.pn-timeline-item.left{text-align:right;align-self:flex-start;padding-right:40px}.pn-timeline-item.right{margin-left:50%;padding-left:40px}.pn-timeline-dot{color:#60a5fa;z-index:2;background:#1e3a8a;border:2px solid #3b82f6;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:flex;position:absolute}.pn-timeline-item.left .pn-timeline-dot{right:-16px}.pn-timeline-item.right .pn-timeline-dot{left:-16px}.pn-timeline-content{flex:1}.pn-timeline-week{color:#60a5fa;margin-bottom:4px;font-size:.78rem;font-weight:600}.pn-timeline-content h4{color:#e2e8f0;margin:0 0 4px;font-size:.9rem}.pn-timeline-content p{color:#64748b;margin:0;font-size:.78rem;line-height:1.5}.pn-payment-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.pn-payment-card{background:#0f172a80;border:1px solid #1e293b;border-radius:12px;padding:20px;transition:border-color .2s}.pn-payment-card:hover{border-color:#334155}.pn-pay-step{color:#475569;margin-bottom:6px;font-size:.75rem}.pn-payment-card h4{color:#e2e8f0;margin:0 0 8px;font-size:1rem}.pn-pay-amount{color:#94a3b8;font-size:.85rem}.pn-pay-amount strong{color:#3b82f6;font-size:1rem}.pn-garansi-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.pn-garansi-card{background:#0f172a66;border:1px solid #1e293b;border-radius:12px;padding:18px}.pn-garansi-card.full{grid-column:1/-1}.pn-garansi-card h4{color:#e2e8f0;margin:0 0 6px;font-size:.9rem}.pn-garansi-card p{color:#64748b;margin:0;font-size:.8rem;line-height:1.5}.support-table .pn-td-layer{color:#cbd5e1;font-weight:600}.support-table .pn-td-total{color:#60a5fa;font-weight:600}.pn-preview-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.pn-preview-card{text-align:center;background:#0f172acc;border:1px solid #1e293b;border-radius:12px;padding:20px;transition:all .3s}.pn-preview-card:hover{border-color:#3b82f6;transform:translateY(-3px);box-shadow:0 8px 30px #3b82f61a}.pn-preview-icon{margin-bottom:10px;font-size:2.5rem}.pn-preview-card h4{color:#e2e8f0;margin-bottom:6px;font-size:.95rem}.pn-preview-card p{color:#64748b;font-size:.78rem;line-height:1.5}.pn-notes{background:#fbbf240a;border:1px solid #fbbf2426;border-radius:12px;margin-bottom:24px;padding:20px 24px}.pn-notes h3{color:#fbbf24;margin-bottom:10px;font-size:1rem}.pn-notes ul{margin:0;padding:0;list-style:none}.pn-notes li{color:#94a3b8;padding:5px 0 5px 18px;font-size:.82rem;position:relative}.pn-notes li:before{content:"•";color:#fbbf24;font-weight:700;position:absolute;left:0}.pn-notes li strong{color:#e2e8f0}.pn-footer{text-align:center;color:#475569;border-top:1px solid #1e293b;padding:20px;font-size:.8rem}.pn-footer-date{color:#64748b;margin-top:4px;font-weight:600}.pn-popup-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9999;background:#000c;justify-content:center;align-items:center;animation:.2s pnFadeIn;display:flex;position:fixed;inset:0}@keyframes pnFadeIn{0%{opacity:0}to{opacity:1}}.pn-popup{background:#0f172a;border:1px solid #334155;border-radius:16px;flex-direction:column;align-items:center;max-width:600px;max-height:80vh;padding:20px;display:flex;position:relative;box-shadow:0 25px 60px #0009}.pn-popup-close{color:#94a3b8;cursor:pointer;background:0 0;border:none;font-size:1.3rem;transition:color .2s;position:absolute;top:10px;right:14px}.pn-popup-close:hover{color:#ef4444}.pn-popup-img{object-fit:contain;border-radius:10px;max-width:100%;max-height:60vh}.pn-popup-label{color:#94a3b8;text-align:center;margin-top:12px;font-size:.85rem}.pn-add-img-btn{color:#475569;cursor:pointer;background:#1e293b80;border:2px dashed #334155;border-radius:5px;flex-shrink:0;width:38px;height:38px;font-size:1.2rem;transition:all .2s}.pn-add-img-btn:hover{color:#60a5fa;background:#60a5fa14;border-color:#60a5fa}.pn-picker{background:#0f172a;border:1px solid #334155;border-radius:16px;width:90vw;max-width:700px;max-height:85vh;padding:24px;position:relative;overflow-y:auto;box-shadow:0 25px 60px #0009}.pn-picker-title{color:#e2e8f0;margin-bottom:16px;padding-right:30px;font-size:1rem}.pn-picker-current{background:#1e293b99;border:1px solid #1e293b;border-radius:8px;align-items:center;gap:12px;margin-bottom:16px;padding:10px 14px;display:flex}.pn-picker-current span{color:#64748b;font-size:.8rem}.pn-picker-current img{object-fit:contain;border-radius:6px;width:50px;height:50px}.pn-picker-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;display:grid}.pn-picker-item{cursor:pointer;background:#0f172acc;border:2px solid #1e293b;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;transition:all .2s;display:flex}.pn-picker-item:hover{background:#3b82f60f;border-color:#3b82f6}.pn-picker-item.active{background:#60a5fa1a;border-color:#60a5fa;box-shadow:0 0 12px #60a5fa33}.pn-picker-item img{object-fit:contain;border-radius:6px;width:60px;height:60px}.pn-picker-item span{color:#94a3b8;text-align:center;font-size:.65rem;line-height:1.3}.pn-picker-item.active span{color:#60a5fa;font-weight:600}.pn-picker-remove{color:#f87171;cursor:pointer;background:#ef444414;border:1px solid #ef44444d;border-radius:8px;margin:0 auto;padding:8px 20px;font-size:.8rem;transition:all .2s;display:block}.pn-picker-remove:hover{background:#ef444426;border-color:#ef4444}*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface-2:#232736;--border:#2d3142;--text:#e8e8ec;--text-dim:#8b8fa3;--blue:#4e8cff;--green:#34d399;--yellow:#fbbf24;--red:#f87171;--radius:12px}body{background:var(--bg);color:var(--text);height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;overflow:hidden}#root{height:100vh}.app{flex-direction:column;height:100vh;display:flex}.tab-scroll-wrap{flex:1;min-height:0;overflow-y:auto}.app-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.header-left{align-items:center;gap:16px;display:flex}.header-left h1{font-size:1.2rem;font-weight:700}.header-badge{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:.75rem}.header-actions{align-items:center;gap:8px;display:flex}.btn-action{border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;padding:6px 14px;font-size:.8rem;font-weight:500;transition:all .2s}.btn-action:hover{background:var(--border)}.btn-save{border-color:var(--green);color:var(--green)}.btn-save:hover{background:#34d39926}.btn-export{border-color:var(--blue);color:var(--blue)}.btn-export:hover{background:#4e8cff26}.btn-reset{border-color:var(--red);color:var(--red)}.btn-reset:hover{background:#f8717126}.btn-grid{border-color:var(--yellow);color:var(--yellow)}.btn-admin{color:#888!important;background:#78787826!important;border-color:#888!important;font-size:.75rem!important}.btn-admin-on{color:#ffc107!important;background:#ffc10733!important;border-color:#ffc107!important;font-size:.75rem!important}.zoom-label{color:var(--text-dim);text-align:center;min-width:40px;font-size:.8rem}.main-content{flex:1;min-height:0;display:flex;overflow:hidden}.tab-nav{background:#0a0f19f2;border-bottom:1px solid #ffffff14;gap:0;padding:0 16px;display:flex}.tab-btn{color:#888;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 24px;font-size:.85rem;transition:all .2s}.tab-btn:hover{color:#bbb;background:#ffffff08}.tab-btn.tab-active{color:#34d399;background:#34d3990d;border-bottom-color:#34d399}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:16px;width:220px;padding:16px;display:flex;overflow-y:auto}.sidebar h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-size:.85rem}.panel-list{flex-direction:column;gap:4px;display:flex}.panel-item{color:var(--text);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;width:100%;padding:8px 10px;font-size:.82rem;transition:all .2s;display:flex}.panel-item:hover{background:var(--surface-2)}.panel-item.active{background:var(--surface-2);border-color:var(--panel-color);box-shadow:inset 3px 0 0 var(--panel-color)}.panel-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;box-shadow:0 0 6px}.panel-name{flex:1;font-weight:500}.panel-letter{color:var(--text-dim);font-size:.75rem}.panel-count{background:var(--surface-2);color:var(--text-dim);border-radius:10px;padding:1px 7px;font-size:.7rem}.selected-info{background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--blue);padding:12px}.selected-info h4{color:var(--blue);margin-bottom:8px;font-size:.8rem}.info-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:4px 0;font-size:.8rem;display:flex}.info-label{color:var(--text-dim)}.info-value{font-family:Courier New,monospace;font-weight:600}.info-hint{color:var(--text-dim);margin-top:8px;font-size:.7rem;line-height:1.5}.sidebar-help{background:var(--surface-2);border-radius:var(--radius);margin-top:auto;padding:12px}.sidebar-help h4{color:var(--text-dim);margin-bottom:8px;font-size:.8rem}.sidebar-help ul{color:var(--text-dim);font-size:.75rem;line-height:2;list-style:none}.floor-plan-scroll-area{flex:1;min-height:0;overflow:auto}.floor-plan-wrapper{width:fit-content;padding:20px}.floor-plan-container{border-radius:var(--radius);border:2px solid var(--border);-webkit-user-select:none;user-select:none;display:inline-block;position:relative;overflow:hidden;box-shadow:0 0 40px #00000080}.floor-plan-img{pointer-events:none;max-width:100%;height:auto;display:block}.lamps-overlay{width:100%;height:100%;position:absolute;top:0;left:0}.grid-overlay{pointer-events:none;z-index:5;background:repeating-linear-gradient(90deg,#ffffff0a 0 1px,#0000 1px 5%),repeating-linear-gradient(0deg,#ffffff0a 0 1px,#0000 1px 5%);width:100%;height:100%;position:absolute;top:0;left:0}.wiring-svg{pointer-events:none;z-index:6;width:100%;height:100%;position:absolute;top:0;left:0}.wiring-line{animation:1.2s linear infinite electric-flow}@keyframes electric-flow{0%{stroke-dashoffset:0}to{stroke-dashoffset:-1.6px}}.walkway-line{animation:2s linear infinite walkway-flow}@keyframes walkway-flow{0%{stroke-dashoffset:0}to{stroke-dashoffset:-1.8px}}.btn-wiring{color:#fbbf24;border-color:#fbbf24}.lamp-marker{cursor:grab;z-index:10;touch-action:none;flex-direction:column;align-items:center;gap:1px;transition:filter .2s;display:flex;position:absolute;transform:translate(-50%,-50%)}.lamp-marker:active{cursor:grabbing}.panel-box-marker{cursor:grab;z-index:8;touch-action:none;background:color-mix(in srgb, var(--box-color) 25%, transparent);border:2px solid var(--box-color);border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:0;width:48px;height:32px;transition:all .2s;display:flex;position:absolute;transform:translate(-50%,-50%)}.panel-box-marker:active{cursor:grabbing}.panel-box-marker:hover{background:color-mix(in srgb, var(--box-color) 40%, transparent);z-index:12;transform:translate(-50%,-50%)scale(1.1)}.panel-box-marker.selected{background:color-mix(in srgb, var(--box-color) 50%, transparent);box-shadow:0 0 12px var(--box-color);z-index:12;border-width:3px}.box-line{color:#fff;text-shadow:0 1px 3px #000000b3;letter-spacing:.5px;font-size:7px;font-weight:800;line-height:1.2}.lamp-glow{background:radial-gradient(circle, var(--lamp-color) 0%, transparent 70%);opacity:.4;pointer-events:none;border-radius:50%;width:32px;height:32px;animation:2s ease-in-out infinite pulse-glow;position:absolute}.lamp-light-area{pointer-events:none;z-index:0;background:radial-gradient(circle,#ffc8008c 0%,#ffb40059 20%,#ffa0002e 45%,#ff8c000f 70%,#0000 100%);border-radius:50%;width:200px;height:200px;animation:3s ease-in-out infinite light-breathe;position:absolute}.lamp-light-area-inner{pointer-events:none;z-index:0;background:radial-gradient(circle,#ffe664b3 0%,#ffd23c66 40%,#ffbe1e26 70%,#0000 100%);border-radius:50%;width:100px;height:100px;animation:3s ease-in-out .5s infinite light-breathe;position:absolute}@keyframes light-breathe{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.lamp-on .lamp-glow{opacity:.5;width:36px;height:36px}.lamp-on .lamp-icon{filter:drop-shadow(0 0 8px var(--lamp-color)) drop-shadow(0 0 16px #ffeb9680)}.lamp-off .lamp-glow{opacity:0;animation:none}.lamp-off .lamp-icon{filter:grayscale()brightness(.5);font-size:16px}.lamp-off .lamp-label{color:#999;box-shadow:none;background:#555}.lamp-icon{filter:drop-shadow(0 0 6px var(--lamp-color));z-index:2;font-size:20px;line-height:1}.lamp-label{color:#fff;background:var(--lamp-color);white-space:nowrap;z-index:2;border-radius:6px;padding:1px 5px;font-size:9px;font-weight:700;line-height:1.3;box-shadow:0 1px 4px #0006}.lamp-marker.selected .lamp-glow{opacity:.7;width:44px;height:44px;animation:.8s ease-in-out infinite pulse-selected}.lamp-marker.selected .lamp-icon{font-size:24px}.lamp-marker.selected .lamp-label{box-shadow:0 0 8px var(--lamp-color);font-size:10px}@keyframes pulse-glow{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@keyframes pulse-selected{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.9;transform:scale(1.6)}}.btn-lamp-on{color:#ffd600!important;background:#ffeb3b26!important;border-color:#ffd600!important}.btn-lamp-off{color:#888!important;background:#64646426!important;border-color:#888!important}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.sensor-marker{z-index:15;pointer-events:auto;cursor:grab;flex-direction:column;align-items:center;gap:2px;display:flex;position:absolute;transform:translate(-50%,-50%)}.sensor-marker:active{cursor:grabbing}.sensor-selected{z-index:22}.sensor-selected .sensor-icon{filter:drop-shadow(0 0 8px #00c853e6);font-size:20px}.sensor-selected .sensor-label{background:#00c853e6;box-shadow:0 0 8px #00c85380}.sensor-idle .sensor-radar{display:none}.sensor-idle .sensor-icon{filter:grayscale()brightness(.5);opacity:.5}.sensor-idle .sensor-label{color:#ffffff80;background:#64646499}.sensor-active .sensor-radar-ring{border-color:#ff3c3cb3!important}.sensor-active .sensor-sweep{background:conic-gradient(#0000 0deg,#ff3c3c73 0deg,#ff3c3c26 90deg,#0000 90deg)!important}.sensor-active .sensor-icon{filter:drop-shadow(0 0 10px #ff3c3ce6);font-size:20px;animation:.5s ease-in-out infinite alternate sensor-alert-pulse}.sensor-active .sensor-label{color:#fff;background:#ff3c3cd9;box-shadow:0 0 10px #ff3c3c99}@keyframes sensor-alert-pulse{0%{transform:scale(1)}to{transform:scale(1.3)}}.sensor-radar{pointer-events:none;border-radius:50%;width:140px;height:140px;position:absolute}.sensor-radar-ring{border:2px solid #00643c80;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.sensor-radar-ring.ring1{width:70px;height:70px;animation:2s ease-out infinite radar-pulse}.sensor-radar-ring.ring2{width:105px;height:105px;animation:2s ease-out .4s infinite radar-pulse}.sensor-radar-ring.ring3{width:140px;height:140px;animation:2s ease-out .8s infinite radar-pulse}.sensor-sweep{background:conic-gradient(#0000 0deg,#00503259 0deg,#0050321f 90deg,#0000 90deg);border-radius:50%;width:140px;height:140px;animation:2.5s linear infinite radar-sweep;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes radar-pulse{0%{opacity:.8;transform:translate(-50%,-50%)scale(.5)}to{opacity:0;transform:translate(-50%,-50%)scale(1.2)}}@keyframes radar-sweep{0%{transform:translate(-50%,-50%)rotate(0)}to{transform:translate(-50%,-50%)rotate(360deg)}}.sensor-icon{z-index:2;filter:drop-shadow(0 0 4px #005032cc);font-size:16px;line-height:1}.sensor-label{color:#fff;z-index:2;letter-spacing:.5px;background:#005a37d9;border-radius:4px;padding:1px 5px;font-size:7px;font-weight:800;box-shadow:0 1px 4px #0006}.cable-waypoint{z-index:20;cursor:grab;pointer-events:auto;flex-direction:column;align-items:center;gap:1px;display:flex;position:absolute;transform:translate(-50%,-50%)}.cable-waypoint:active{cursor:grabbing}.cable-wp-dot{background:var(--wp-color,#fff);width:10px;height:10px;box-shadow:0 0 6px var(--wp-color,#fff), 0 0 12px #00000080;border:2px solid #fff;border-radius:50%;transition:transform .15s}.cable-waypoint:hover .cable-wp-dot{transform:scale(1.4)}.cable-wp-label{color:#fff;white-space:nowrap;pointer-events:none;background:#000000b3;border-radius:3px;padding:0 3px;font-size:6px;font-weight:700}.cable-route-editor{background:var(--surface);border:1px solid #ffffff14;border-radius:8px;margin-top:8px;padding:10px}.cable-route-editor h4{color:var(--primary);margin:0 0 6px;font-size:12px}.cable-panel-list{flex-direction:column;gap:4px;display:flex}.cable-panel-row{color:var(--text-secondary);align-items:center;gap:6px;font-size:10px;display:flex}.cable-panel-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.cable-panel-name{color:var(--text);flex:1;font-weight:600}.btn-add-wp{color:var(--primary);cursor:pointer;background:#ffffff0d;border:1px solid #fff3;border-radius:4px;padding:1px 6px;font-size:9px;font-weight:700}.btn-add-wp:hover{background:#ffffff26}.cable-wp-count{color:var(--text-secondary);opacity:.7;font-size:9px}.btn-cable-edit{color:#ff9800!important;background:#ff980026!important;border-color:#ff9800!important}.btn-sensor-on{color:#00c853!important;background:#00c85326!important;border-color:#00c853!important}.sim-stats-panel{z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none;background:#0f1117eb;border:1px solid #4e8cff4d;border-radius:12px;min-width:280px;padding:12px 16px;position:absolute;top:10px;left:10px;box-shadow:0 4px 20px #0006}.sim-stats-header{letter-spacing:1.5px;color:#ff5252;align-items:center;gap:8px;margin-bottom:10px;font-size:11px;font-weight:700;display:flex}.sim-stats-dot{background:#ff5252;border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite sim-dot-blink}@keyframes sim-dot-blink{0%,to{opacity:1}50%{opacity:.3}}.sim-stats-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;display:grid}.sim-stat-card{text-align:center;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;padding:8px 10px}.sim-stat-value{color:#fff;font-size:22px;font-weight:700;line-height:1.2}.sim-stat-unit{color:#8b8fa3;font-size:12px;font-weight:400}.sim-stat-label{color:#8b8fa3;margin-top:2px;font-size:10px}.sim-stats-saving{flex-direction:column;gap:4px;display:flex}.sim-saving-bar{background:#ffffff1a;border-radius:3px;width:100%;height:6px;overflow:hidden}.sim-saving-fill{background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:3px;height:100%;transition:width .3s}.sim-saving-text{color:#8bc34a;font-size:11px}.sim-saving-text strong{color:#4caf50;font-size:13px}.walker-icon{z-index:25;pointer-events:none;will-change:left, top;flex-direction:column;align-items:center;gap:2px;display:flex;position:absolute}.walker-emoji{z-index:2;filter:drop-shadow(0 0 6px #fffc)drop-shadow(0 0 12px #0096ff80);font-size:28px;animation:.5s ease-in-out infinite walker-bounce}.walker-label{color:#fff;z-index:2;letter-spacing:.5px;background:#2196f3d9;border-radius:4px;padding:1px 6px;font-size:7px;font-weight:800;box-shadow:0 1px 4px #0006}.walker-detection-ring{pointer-events:none;border:2px dashed #2196f366;border-radius:50%;width:70px;height:70px;animation:1.5s ease-out infinite walker-detect-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes walker-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes walker-detect-pulse{0%{opacity:.6;transform:translate(-50%,-50%)scale(.7)}to{opacity:0;transform:translate(-50%,-50%)scale(1.3)}}.btn-walker{color:#2196f3!important;background:#2196f326!important;border-color:#2196f3!important}.btn-walker-active{animation:1.5s ease-in-out infinite btn-pulse;color:#4caf50!important;background:#4caf5040!important;border-color:#4caf50!important}@keyframes btn-pulse{0%,to{box-shadow:0 0 4px #4caf504d}50%{box-shadow:0 0 12px #4caf5099}}.forklift-icon{z-index:25;pointer-events:none;will-change:left, top;flex-direction:column;align-items:center;gap:2px;display:flex;position:absolute}.forklift-emoji{font-size:26px;animation:.8s ease-in-out infinite forklift-shake}.forklift-label{color:#fff;white-space:nowrap;letter-spacing:.3px;border-radius:6px;padding:1px 5px;font-size:8px;font-weight:700;box-shadow:0 1px 4px #0006}@keyframes forklift-shake{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-1px)rotate(-1deg)}75%{transform:translateY(-1px)rotate(1deg)}}.exhaust-fan-container{z-index:30;pointer-events:none;flex-direction:column;align-items:center;display:flex;position:absolute;transform:translate(-50%,-50%)scale(1.6)}.exhaust-fan-blade{width:30px;height:30px;position:relative}.exhaust-fan-blade.spinning{animation:.8s linear infinite fan-spin}.fan-off .exhaust-fan-blade{opacity:.4;animation:none}.fan-off .exhaust-fan-blade .blade{background:#666}.fan-off .exhaust-fan-icon{filter:grayscale()brightness(.5);opacity:.5}.fan-off .exhaust-label{color:#999;background:#3c3c3cb3}.fan-on .exhaust-fan-blade .blade{background:#4caf50}.fan-on .exhaust-fan-icon{filter:drop-shadow(0 0 4px #4caf5099);opacity:1}.fan-on .exhaust-label{color:#fff;background:#4caf50d9}.exhaust-fan-blade .blade{background:#555;border-radius:2px;width:12px;height:3px;position:absolute;top:50%;left:50%}.exhaust-fan-blade .b1{transform:translate(-50%,-50%)rotate(0)}.exhaust-fan-blade .b2{transform:translate(-50%,-50%)rotate(90deg)}.exhaust-fan-blade .b3{transform:translate(-50%,-50%)rotate(45deg)}.exhaust-fan-blade .b4{transform:translate(-50%,-50%)rotate(135deg)}.exhaust-fan-blade:after{content:"";background:#333;border-radius:50%;width:7px;height:7px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.exhaust-fan-icon{filter:drop-shadow(0 0 3px #64646480);opacity:.7;font-size:18px;position:absolute;top:-1px}.exhaust-label{color:#fff;white-space:nowrap;letter-spacing:.3px;background:#505050d9;border-radius:3px;margin-top:1px;padding:1px 4px;font-size:6px;font-weight:700}.exhaust-wind{pointer-events:none;width:26px;height:40px;position:absolute;bottom:100%;left:50%;overflow:visible;transform:translate(-50%)}.wind-particle{color:#b4d2f0cc;text-shadow:0 0 4px #b4d2f080;font-size:12px;animation:1.8s ease-out infinite wind-rise;position:absolute;bottom:0;left:50%}.wind-particle.p2{color:#b4d2f099;font-size:10px;animation-delay:.35s;left:25%}.wind-particle.p3{color:#b4d2f0b3;font-size:11px;animation-delay:.7s;left:75%}.wind-particle.p4{color:#b4d2f080;font-size:9px;animation-delay:1.1s;left:35%}.wind-particle.p5{color:#b4d2f099;font-size:11px;animation-delay:1.5s;left:65%}@keyframes fan-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.th-sensor-card{z-index:28;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;cursor:grab;touch-action:none;background:#0a0f198c;border:1px solid #34d39959;border-radius:8px;min-width:62px;padding:4px 7px;transition:border-color .5s,box-shadow .5s;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px 10px #0006}.th-sensor-card:active{cursor:grabbing}.th-sensor-card.th-hot{border-color:#ff525299;animation:1s ease-in-out infinite th-blink-red;box-shadow:0 2px 12px #ff525240}.th-sensor-card.th-humid{border-color:#2196f399;animation:1s ease-in-out infinite th-blink-blue;box-shadow:0 2px 12px #2196f340}.th-sensor-card.th-hot.th-humid{border-color:#ff9800b3;animation:.8s ease-in-out infinite th-blink-orange;box-shadow:0 2px 14px #ff980059}@keyframes th-blink-red{0%,to{background:#0a0f198c;border-color:#ff525299}50%{background:#ff323240;border-color:#ff5252}}@keyframes th-blink-blue{0%,to{background:#0a0f198c;border-color:#2196f399}50%{background:#2178f333;border-color:#2196f3}}@keyframes th-blink-orange{0%,to{background:#0a0f198c;border-color:#ff9800b3}50%{background:#ff64004d;border-color:#ff3c00}}.th-sensor-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;margin-bottom:2px;padding-bottom:2px;display:flex}.th-sensor-id{color:#34d399e6;letter-spacing:.5px;font-size:7px;font-weight:800}.th-sensor-status{font-size:8px;line-height:1}.th-sensor-status.th-ok{color:#34d399}.th-sensor-status.th-warn{color:#ff5252;animation:1s ease-in-out infinite th-warn-blink}@keyframes th-warn-blink{0%,to{opacity:1}50%{opacity:.3}}.th-sensor-row{align-items:center;gap:3px;line-height:1.4;display:flex}.th-icon{font-size:10px;line-height:1}.th-value{color:#fff;text-align:right;min-width:28px;font-family:Courier New,monospace;font-size:11px;font-weight:700}.th-unit{color:#ffffff80;font-size:8px;font-weight:500}.th-hot .th-value:first-of-type,.th-sensor-card.th-hot .th-sensor-row:first-of-type .th-value{color:#ff8a80}.th-sensor-card.th-humid .th-sensor-row:nth-child(2) .th-value{color:#82b1ff}@keyframes wind-rise{0%{opacity:.8;transform:translateY(0)translate(0)scale(1)}50%{opacity:.5;transform:translateY(-25px)translate(3px)scale(.8)}to{opacity:0;transform:translateY(-50px)translate(-2px)scale(.5)}}
