body{margin:0;font-family:'Segoe UI',sans-serif;background:#0f172a;color:#fff}.main{display:flex;height:100vh}.sidebar-category{margin-bottom:12px;display:block}.sidebar-category summary{list-style:none;cursor:pointer;font-size:12px;font-weight:800;letter-spacing:.06em;color:#cbd5e1;text-transform:uppercase;margin:0 0 2px;padding:2px 2px}.sidebar-category summary::-webkit-details-marker{display:none}.sidebar-search-wrap{position:relative;margin-bottom:24px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#475569;pointer-events:none;transition:color .2s;z-index:1}#sidebarSearch{width:100%;background:#1e293b;border:1px solid rgba(148,163,184,.1);border-radius:10px;padding:10px 10px 10px 34px;color:#f1f5f9;font-size:12px;font-weight:500;outline:0;box-sizing:border-box;transition:all .2s}#sidebarSearch:focus{background:#0b1020;border-color:#38bdf8;box-shadow:0 0 12px rgba(56,189,248,.15)}#sidebarSearch:focus+.search-icon{color:#38bdf8}.sidebar-category h3{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;margin:0 0 10px 4px;display:flex;align-items:center;gap:8px}.sidebar-category h3::after{content:"";flex:1;height:1px;background:rgba(148,163,184,.1)}.draggable{background:rgba(30,41,59,.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);padding:8px 7px 9px;margin:0;border-radius:12px;text-align:center;cursor:grab;font-size:11px;font-weight:800;color:#f1f5f9;transition:transform .16s ease,box-shadow .2s ease,border-color .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;min-width:0;height:148px;min-height:148px;max-height:148px;vertical-align:top;box-sizing:border-box;box-shadow:0 4px 12px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.1);overflow:hidden}.palette-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;align-items:start;grid-auto-rows:max-content}.palette-grid>div[style*="font-size: 10px"]{margin:3px 0 0 2px!important;font-size:9px!important;letter-spacing:.08em!important;color:#64748b!important;grid-column:1/-1}.draggable:hover{border-color:rgba(56,189,248,.5);background:rgba(30,41,59,.7);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.4),0 0 15px rgba(56,189,248,.15),inset 0 1px 0 rgba(255,255,255,.2)}.draggable:active{cursor:grabbing}.draggable-icon{width:72px;height:72px;margin:3px 0 7px;border-radius:8px;background:rgba(15,23,42,.6);border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;color:#e2e8f0}.draggable-icon svg{width:50px;height:50px;display:block}.draggable-label{line-height:1.12;letter-spacing:.005em;color:#f1f5f9;font-size:11px;font-weight:800;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:3.4em;text-wrap:balance;word-break:break-word;width:100%}.sidebar-category .draggable.hidden{display:none!important}.icon-btn,.icon-btn-cloud,.icon-btn-danger,.icon-btn-primary,.icon-btn-run{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(30,41,59,.5);color:inherit;cursor:pointer;transition:all .2s cubic-bezier(.4, 0, .2, 1);padding:0;overflow:hidden;font-size:0}.icon-btn:hover{background:rgba(30,41,59,.8);border-color:currentColor;transform:translateY(-1px)}.icon-btn-primary{background:linear-gradient(135deg,#38bdf8,#2563eb);color:#fff;border:none;box-shadow:0 4px 12px rgba(37,99,235,.2)}.icon-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 15px rgba(37,99,235,.3)}.icon-btn-cloud{color:#38bdf8;background:rgba(56,189,248,.05);border-color:rgba(56,189,248,.2)}.icon-btn-cloud:hover{background:rgba(56,189,248,.1);border-color:rgba(56,189,248,.4)}.icon-btn-run{color:#22c55e;background:rgba(34,197,94,.05);border-color:rgba(34,197,94,.2)}.icon-btn-run:hover{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.4)}.icon-btn-danger{color:#ef4444;background:rgba(239,68,68,.05);border-color:rgba(239,68,68,.2)}.icon-btn-danger:hover{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.4)}.icon-btn.pulse{animation:icon-pulse 1.5s infinite}@keyframes icon-pulse{0%{box-shadow:0 0 0 0 rgba(56,189,248,.4)}70%{box-shadow:0 0 0 8px rgba(56,189,248,0)}100%{box-shadow:0 0 0 0 rgba(56,189,248,0)}}@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}.node{position:absolute;background:#1e293b;border:1px solid #334155;border-radius:8px;width:180px;box-sizing:border-box;color:#fff;user-select:none;box-shadow:0 4px 6px rgba(0,0,0,.3);z-index:10}.node.led-node{min-width:100px!important;background:0 0}.node-header{background:0 0;padding:8px 12px;border-radius:12px 12px 0 0;font-weight:800;font-size:12px;color:#56c2f9;text-transform:uppercase;letter-spacing:.05em;border-bottom:none}.node-title-wrap{display:flex;align-items:center;gap:6px}.node-body{position:relative;min-height:60px;padding:4px 0 10px;width:100%}.node-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.node-layer>.node{pointer-events:all}.node.sensor-realistic{border-radius:22px;border:2px solid rgba(71,85,105,.9);background:radial-gradient(140% 90% at 50% 12%,rgba(30,64,175,.24),rgba(2,6,23,.25) 45%,rgba(2,6,23,.92) 100%),linear-gradient(160deg,#0f172a 0,#0a1120 48%,#050b16 100%);box-shadow:0 18px 36px rgba(2,6,23,.62),inset 0 1px 0 rgba(148,163,184,.24),inset 0 -10px 22px rgba(0,0,0,.5);overflow:visible;width:270px;min-height:130px}.node.sensor-realistic .node-header{border-radius:16px 16px 14px 14px;margin:4px;background:linear-gradient(180deg,rgba(15,23,42,.96),rgba(13,22,40,.78));border:1px solid rgba(59,130,246,.16);min-height:40px;display:flex;align-items:center}.node.sensor-realistic .node-title-wrap>span:first-child{color:#38bdf8;letter-spacing:.08em;font-size:15px;text-shadow:0 0 12px rgba(56,189,248,.25)}.node.sensor-realistic .node-body{padding:8px 10px 14px;min-height:90px}.node.sensor-realistic .port{width:16px;height:16px;border-width:2px;border-color:#334155;background:radial-gradient(circle at 35% 35%,#cbd5e1 0,#94a3b8 45%,#475569 100%);box-shadow:0 0 0 2px rgba(15,23,42,.9),inset 0 0 0 1px rgba(255,255,255,.28),0 0 10px rgba(148,163,184,.22)}.node.sensor-realistic .port.connected{background:radial-gradient(circle at 35% 35%,#7dd3fc 0,#38bdf8 45%,#0c4a6e 100%)}.node.sensor-realistic .pot-slider{height:10px;border-radius:999px;border:1px solid rgba(148,163,184,.35);background:linear-gradient(180deg,rgba(30,41,59,.95),rgba(15,23,42,.85));box-shadow:inset 0 2px 4px rgba(2,6,23,.6)}.node.sensor-realistic .pot-slider::-webkit-slider-thumb{width:22px;height:22px;border-radius:50%;border:2px solid rgba(2,6,23,.8);background:radial-gradient(circle at 35% 30%,#22c55e 0,#16a34a 45%,#166534 100%);box-shadow:0 0 10px rgba(34,197,94,.35)}.node.sensor-realistic .pot-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;border:2px solid rgba(2,6,23,.8);background:radial-gradient(circle at 35% 30%,#22c55e 0,#16a34a 45%,#166534 100%);box-shadow:0 0 10px rgba(34,197,94,.35)}.node.sensor-realistic .pot-readout,.node.sensor-realistic .toggle-sw-label,.node.sensor-realistic .ultra-readout{text-shadow:0 0 8px rgba(56,189,248,.25);font-weight:800}.node.sensor-pir button{border:1px solid rgba(239,68,68,.45)!important;box-shadow:0 0 10px rgba(239,68,68,.25);border-radius:8px!important;font-size:15px!important;font-weight:800!important;letter-spacing:.04em;min-height:28px}.node.sensor-sound canvas{border-radius:6px}.node.sensor-realistic .sensor-face{width:100%;display:flex;align-items:center;justify-content:center;margin:4px 0 6px;pointer-events:none}.node.sensor-dht .dht-face{height:48px}.node.sensor-dht .dht-grid{width:66px;height:40px;padding:4px;border-radius:6px;border:1px solid rgba(125,211,252,.28);background:linear-gradient(180deg,rgba(8,47,73,.75),rgba(15,23,42,.8));display:grid;grid-template-columns:repeat(7,1fr);gap:2px;box-shadow:inset 0 0 12px rgba(0,0,0,.35)}.node.sensor-dht .dht-grid span{width:3px;height:3px;border-radius:50%;background:rgba(186,230,253,.65)}.node.sensor-ultra .ultra-face{gap:10px;height:52px;margin-top:0}.node.sensor-ultra .ultra-can{width:42px;height:42px;border-radius:50%;position:relative;border:2px solid rgba(203,213,225,.55);background:radial-gradient(circle at 35% 35%,#cbd5e1 0,#64748b 42%,#1e293b 100%);box-shadow:inset 0 0 8px rgba(2,6,23,.72),0 0 14px rgba(191,219,254,.35)}.node.sensor-ultra .ultra-inner{position:absolute;inset:8px;border-radius:50%;border:2px solid rgba(226,232,240,.5);background:radial-gradient(circle at 40% 40%,rgba(226,232,240,.55),rgba(15,23,42,.85))}.node.sensor-ultra .ultra-silk{position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.08em;color:rgba(125,211,252,.85);font-weight:800}.node.sensor-pir,.node.sensor-ultra{min-height:118px}.node.sensor-soil .soil-probe-wrap{height:38px}.node.sensor-soil .soil-probe-icon{width:52px;height:30px;border-radius:5px 5px 8px 8px;background:linear-gradient(180deg,rgba(22,101,52,.35),rgba(2,6,23,.65));border:1px solid rgba(34,197,94,.35);position:relative;box-shadow:inset 0 0 10px rgba(0,0,0,.35)}.node.sensor-soil .probe-trace{position:absolute;top:5px;width:4px;height:16px;border-radius:2px;background:linear-gradient(180deg,rgba(134,239,172,.8),rgba(22,163,74,.7))}.node.sensor-soil .probe-trace.left{left:16px}.node.sensor-soil .probe-trace.right{right:16px}.node.sensor-soil .probe-tip{position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);width:20px;height:8px;clip-path:polygon(0 0,100% 0,50% 100%);background:linear-gradient(180deg,rgba(34,197,94,.95),rgba(21,128,61,.95))}.port{position:absolute;width:14px;height:14px;background:#94a3b8;border:2px solid #1e293b;border-radius:50%;cursor:crosshair;z-index:20;transition:background .2s,transform .2s}.port.connected{background:#64748b;border-color:#475569}.port.connected:hover{background:#38bdf8;border-color:#0ea5e9;box-shadow:0 0 12px rgba(56,189,248,.9);transform:scale(1.2)}.wire-base{stroke:rgba(148,163,184,0.4);stroke-width:2.5px;fill:none;stroke-linejoin:round;stroke-linecap:round;transition:stroke .3s,stroke-width .3s}.wire-flow{stroke:rgba(56,189,248,0.8);stroke-width:2.5px;fill:none;stroke-dasharray:8,12;stroke-dashoffset:1000;animation:pcb-flow 20s linear infinite;stroke-linejoin:round;stroke-linecap:round;pointer-events:none}@keyframes pcb-flow{to{stroke-dashoffset:0}}.wire-highlight .wire-base{stroke:#38bdf8!important;stroke-width:4px!important;filter:drop-shadow(0 0 8px rgba(56, 189, 248, .6));opacity:1!important}.wire-highlight .wire-flow{stroke:#fff!important;stroke-width:3px!important}.wire-handle{width:10px;height:10px;background:#38bdf8;border:2px solid #fff;border-radius:50%;position:absolute;cursor:move;z-index:30;display:none;pointer-events:auto}.node:hover~#wires .wire-highlight .wire-handle,.port:hover~#wires .wire-highlight .wire-handle,.wire-g:hover .wire-handle{display:block}.canvas{width:5000px;height:5000px;position:relative;background-color:#020617;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:20px 20px;will-change:transform}.serial-box{width:250px;background:#000;padding:10px}#wires{position:absolute;width:100%;height:100%;pointer-events:none;z-index:1}.wire-flow{cursor:default}body.eraser-mode *{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' style='fill:red'><path d='M16.24 3.56l4.95 4.94c.78.79.78 2.05 0 2.84L12 20.53a4.008 4.008 0 01-5.66 0L2.83 17a4.008 4.008 0 010-5.66l9.17-9.17c.79-.79 2.05-.79 2.84 0l1.4 1.39z'/></svg>") 12 12,crosshair!important}.shorted{stroke:red!important;filter:drop-shadow(0 0 8px rgba(255, 0, 0, .8))!important;animation:none!important}.node.shorted{border-color:red!important;box-shadow:0 0 20px rgba(255,0,0,.8)!important}.port.connecting{background:#fbbf24!important;box-shadow:0 0 10px #fbbf24}.wire-shadow{stroke:#fbbf24;stroke-width:2;stroke-dasharray:5,5;fill:none;pointer-events:none}.servo-arm{position:absolute;width:40px;height:6px;background:#cbd5e1;border-radius:4px;top:50%;left:50%;transform-origin:0 50%;transform:translate(-10px,-50%) rotate(0);transition:transform .2s ease-out}.pot-slider{width:60px;margin:8px 0;cursor:pointer}.buzzer-aura{position:absolute;width:60px;height:60px;border-radius:50%;background:rgba(251,191,36,.2);top:50%;left:50%;transform:translate(-50%,-50%) scale(0);pointer-events:none;transition:transform .1s,opacity .1s}.rgb-preview{width:32px;height:32px;border-radius:50%;background:#0f172a;margin:8px auto 2px;border:1px solid rgba(255,255,255,.08);transition:background .15s,box-shadow .15s}.led-node{min-width:110px!important}.led-container{display:flex;justify-content:center;padding:12px 0}.led-svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:all .2s ease}.led-body{transition:fill .2s ease;stroke:rgba(255,255,255,0.15)}.led-svg.active{filter:url(#ledGlow) drop-shadow(0 0 15px rgba(239, 68, 68, .7))}.led-svg.active .led-body{stroke:rgba(255,255,255,0.4);animation:led-flicker .1s infinite alternate}@keyframes led-flicker{from{opacity:.95}to{opacity:1}}.led-legs-wrapper{display:none}.switch{position:relative;display:inline-block;width:32px;height:18px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#1e293b;transition:.4s;border:1px solid rgba(255,255,255,.1)}.slider:before{position:absolute;content:"";height:12px;width:12px;left:2px;bottom:2px;background-color:#94a3b8;transition:.4s}input:checked+.slider{background-color:#38bdf8;box-shadow:0 0 10px rgba(56,189,248,.3)}input:checked+.slider:before{transform:translateX(14px);background-color:#fff}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.backend-running-indicator{display:inline-block;width:8px;height:8px;background:#10b981;border-radius:50%;margin-right:6px;box-shadow:0 0 8px #10b981;animation:backend-pulse 1.5s infinite;vertical-align:middle}@keyframes backend-pulse{0%{transform:scale(.9);opacity:.7}50%{transform:scale(1.1);opacity:1}100%{transform:scale(.9);opacity:.7}}.motor-body{width:60px;height:60px;background:#475569;border-radius:50%;margin:10px auto;position:relative;border:2px solid #1e293b;box-shadow:inset 0 0 10px rgba(0,0,0,.5)}.motor-shaft{position:absolute;width:6px;height:40px;background:#94a3b8;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:3px;transition:transform .1s linear}.motor-shaft::after{content:"";position:absolute;width:20px;height:2px;background:#cbd5e1;top:5px;left:-7px}.driver-heatsink{width:80px;height:40px;background:#1e1e1e;margin:10px auto;display:flex;gap:4px;padding:2px;border-radius:4px}.heatsink-fin{flex:1;background:#334155;border-radius:1px}.driver-chip{width:40px;height:40px;background:#0f172a;margin:-10px auto 10px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:8px;color:#94a3b8;font-weight:700}.gps-antenna{width:50px;height:50px;background:#d1d5db;margin:10px auto;border-radius:4px;position:relative;border:1px solid #94a3b8}.gps-antenna::before{content:"GPS";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;color:#4b5563;font-weight:700}.gps-led{width:6px;height:6px;background:#10b981;border-radius:50%;position:absolute;top:5px;right:5px;opacity:.3}.gps-led.active{opacity:1;box-shadow:0 0 8px #10b981;animation:blink 1s infinite}@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}.esp32-board{position:absolute;inset:10px 15px;background:#111827;border-radius:8px;border:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;align-items:center;pointer-events:none;overflow:hidden}.esp32-module{width:85px;height:110px;background:linear-gradient(135deg,#374151,#1f2937);margin-top:12px;border-radius:4px;position:relative;border:1px solid rgba(255,255,255,.12);box-shadow:0 4px 15px rgba(0,0,0,.5)}.esp32-shield{position:absolute;inset:4px;background:linear-gradient(135deg,#cbd5e1,#94a3b8);border-radius:2px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#0f172a;padding:8px;border:1px solid rgba(255,255,255,.3);box-shadow:inset 0 0 10px rgba(0,0,0,.2)}.esp32-module::after,.esp32-module::before{content:"";position:absolute;top:15px;bottom:5px;width:6px;background:repeating-linear-gradient(to bottom,#d4af37 0,#d4af37 4px,transparent 4px,transparent 12px);z-index:5}.esp32-module::before{left:-3px}.esp32-module::after{right:-3px}.esp32-logo{font-weight:900;font-size:20px;letter-spacing:-.5px;line-height:1}.esp32-sub,.esp8266-sub{font-weight:700;font-size:7px;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;opacity:.8}.esp32-fcc,.esp8266-fcc{font-size:4.5px;font-family:monospace;opacity:.6;text-align:center}.arduino-chip-small,.esp32-chip-small{position:absolute;width:8px;height:8px;background:#0f172a;border:1px solid rgba(255,255,255,.1);border-radius:1px}.atmega-chip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100px;height:35px;background:#0f172a;border:1px solid #334155;border-radius:2px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);font-size:9px;font-weight:900;letter-spacing:1px;box-shadow:0 4px 10px rgba(0,0,0,.5)}.atmega-chip::before{content:"";position:absolute;inset:4px;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}.node.pkg-arduino .node-header,.node.pkg-driver .node-header,.node.pkg-esp32 .node-header,.node.pkg-esp8266 .node-header,.node.pkg-mcu .node-header,.node.pkg-regular .node-header{background:rgba(15,23,42,.8);backdrop-filter:blur(4px);margin:4px;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.node.pkg-arduino,.node.pkg-esp32,.node.pkg-esp8266,.node.pkg-mcu{width:200px}.node.pkg-driver,.node.pkg-regular{width:180px}.node.pkg-arduino,.node.pkg-driver,.node.pkg-esp32,.node.pkg-esp8266,.node.pkg-mcu,.node.pkg-regular{background:#111827!important;border:2px solid #334155!important;box-shadow:0 15px 35px rgba(0,0,0,.6)}.node.pkg-driver::before,.node.pkg-mcu::before,.node.pkg-regular::before{content:"";position:absolute;bottom:10px;left:-8px;right:-8px;z-index:-1}.node.pkg-driver::before,.node.pkg-regular::before{top:42px;background:repeating-linear-gradient(to bottom,transparent 0,transparent 6px,#475569 6px,#475569 12px,transparent 12px,transparent 30px)}.node.pkg-arduino::before,.node.pkg-esp32::before{top:42px;background:repeating-linear-gradient(to bottom,transparent 0,transparent 6px,#475569 6px,#475569 12px,transparent 12px,transparent 22px)}.node.pkg-esp8266::before{top:48px;background:repeating-linear-gradient(to bottom,transparent 0,transparent 6px,#475569 6px,#475569 12px,transparent 12px,transparent 25px)}.toggle-sw-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 8px}.toggle-sw{position:relative;display:inline-block;width:54px;height:28px;cursor:pointer}.toggle-sw input{opacity:0;width:0;height:0}.toggle-sw-knob{position:absolute;top:0;left:0;right:0;bottom:0;background:#1e293b;border-radius:28px;border:1px solid rgba(255,255,255,.12);transition:background .3s,box-shadow .3s}.toggle-sw-knob::before{position:absolute;content:"";width:20px;height:20px;left:3px;bottom:3px;background:linear-gradient(135deg,#94a3b8,#64748b);border-radius:50%;transition:transform .3s cubic-bezier(.4, 0, .2, 1),background .3s;box-shadow:0 2px 4px rgba(0,0,0,.4)}.toggle-sw input:checked+.toggle-sw-knob{background:#15803d;box-shadow:0 0 16px rgba(34,197,94,.5),inset 0 1px 2px rgba(0,0,0,.3)}.toggle-sw input:checked+.toggle-sw-knob::before{transform:translateX(26px);background:linear-gradient(135deg,#86efac,#22c55e);box-shadow:0 0 8px rgba(34,197,94,.6),0 2px 4px rgba(0,0,0,.3)}.toggle-sw-label{font-size:10px;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.08em;transition:color .3s;pointer-events:none}.dpin-badge{display:flex;align-items:center;justify-content:center;gap:5px;margin:10px 8px;padding:6px 10px;background:linear-gradient(135deg,rgba(34,197,94,.12),rgba(16,185,129,.08));border:1px solid rgba(34,197,94,.35);border-radius:8px;font-size:11px;font-weight:800;color:#22c55e;letter-spacing:.04em;pointer-events:none;animation:dpin-pulse 2s ease-in-out infinite}.dpin-icon{font-size:13px}@keyframes dpin-pulse{0%,100%{box-shadow:0 0 8px rgba(34,197,94,.15)}50%{box-shadow:0 0 20px rgba(34,197,94,.4)}}.sidebar-category{margin-bottom:12px;display:block}.sidebar-category summary{font-size:11px;font-weight:800;color:#94a3b8;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;margin-bottom:2px;list-style:none;display:flex;justify-content:space-between;align-items:center;user-select:none;transition:color .2s;grid-column:1/-1}.sidebar-category summary:hover{color:#e2e8f0}.sidebar-category summary::-webkit-details-marker{display:none}.sidebar-category summary::after{content:"\25bc";font-size:8px;transition:transform .2s cubic-bezier(.4, 0, .2, 1);transform:rotate(-90deg)}.sidebar-category[open] summary::after{transform:rotate(0)}.log-line{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-family:inherit;line-height:1.4}.log-icon{width:14px;height:14px;flex-shrink:0;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.log-text{flex:1;word-break:break-all}.component-param-menu{position:fixed;z-index:12000;width:250px;max-width:calc(100vw - 20px);background:rgba(10,15,28,.96);border:1px solid rgba(56,189,248,.25);border-radius:12px;box-shadow:0 16px 36px rgba(2,6,23,.55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#e2e8f0;padding:10px}.component-param-menu .param-title{font-size:11px;font-weight:800;letter-spacing:.08em;color:#38bdf8;text-transform:uppercase;margin-bottom:8px}.component-param-menu .param-body{display:flex;flex-direction:column;gap:8px}.component-param-menu .param-row{display:flex;flex-direction:column;gap:4px}.component-param-menu .param-head{display:flex;align-items:center;justify-content:space-between}.component-param-menu .param-label{font-size:11px;color:#cbd5e1}.component-param-menu .param-value{font-size:11px;color:#67e8f9;font-weight:700}.component-param-menu .param-slider{width:100%;accent-color:#22c55e}.component-param-menu .param-toggle-btn{width:100%;border:1px solid rgba(148,163,184,.35);background:rgba(30,41,59,.7);color:#e2e8f0;border-radius:8px;padding:8px 10px;font-size:12px;font-weight:700;cursor:pointer}.component-param-menu .param-toggle-btn:hover{border-color:rgba(34,197,94,.55)}.component-param-menu .param-empty{font-size:11px;color:#94a3b8}.resistor-symbol{width:80px;height:30px;margin:2px auto;background:url('assets/resistor.png') center/contain no-repeat;pointer-events:none}.diode-symbol{width:80px;height:30px;margin:10px auto;background:url('assets/diode.png') center/contain no-repeat;pointer-events:none}.capacitor-symbol{width:60px;height:40px;margin:10px auto;background:url('assets/capacitor.png') center/contain no-repeat;pointer-events:none}.transistor-symbol{width:60px;height:60px;margin:0 auto;background:url('assets/transistor.png') center/contain no-repeat;border:none;border-radius:0;pointer-events:none}.transistor-text{display:none;font-size:10px;font-weight:800;color:#cbd5e1;line-height:40px;pointer-events:none}.engine-toggle-wrap{display:flex;background:rgba(15,23,42,.4);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:2px;gap:1px}.editor-shell{background:#0f141a;border-radius:12px;margin:12px;border:1px solid rgba(148,163,184,.08);box-shadow:inset 0 2px 15px rgba(0,0,0,.4)}#line-numbers::-webkit-scrollbar{display:none}#line-numbers{-ms-overflow-style:none;scrollbar-width:none;overflow-y:hidden}#code{tab-size:4}#highlight-overlay{line-height:1.5!important}#highlight-overlay .tok-comment{color:#6b7280;font-style:italic}#highlight-overlay .tok-keyword{color:#c084fc;font-weight:600}#highlight-overlay .tok-builtin{color:#60a5fa}#highlight-overlay .tok-string{color:#f59e0b}#highlight-overlay .tok-number{color:#22c55e}#highlight-overlay .tok-boolean{color:#f472b6;font-weight:600}#highlight-overlay .tok-function{color:#38bdf8}#code::-webkit-scrollbar{width:10px;height:10px}#code::-webkit-scrollbar-thumb{background:rgba(148,163,184,.15);border-radius:5px;border:2px solid #0f141a}#code::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,.3)}#code::-webkit-scrollbar-track{background:0 0}.mode-btn{background:0 0;color:#94a3b8;border:none;padding:4px 10px;font-size:9px;font-weight:800;border-radius:6px;cursor:pointer;transition:all .3s cubic-bezier(.4, 0, .2, 1);text-transform:uppercase;letter-spacing:.05em}.mode-btn:hover{color:#f1f5f9;background:rgba(255,255,255,.05)}.mode-btn.active#modeLocalBtn{background:#38bdf8;color:#020617;box-shadow:0 4px 12px rgba(56,189,248,.25)}.mode-btn.active#modeCloudBtn{background:#a78bfa;color:#020617;box-shadow:0 4px 12px rgba(167,139,250,.25)}.engine-status-badge{font-size:9px;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:6px;padding:3px 6px;background:rgba(15,23,42,.3);border-radius:6px;border:1px solid rgba(255,255,255,.03)}.engine-status-badge.online{color:#22c55e}.sim-toggle-btn{background:rgba(15,23,42,.7);backdrop-filter:blur(12px);color:#38bdf8;border:1px solid rgba(56,189,248,.3);border-radius:10px;padding:8px 14px;font-size:11px;font-weight:800;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .4s cubic-bezier(.175, .885, .32, 1.275);box-shadow:0 8px 16px rgba(0,0,0,.4);text-transform:uppercase;letter-spacing:.08em}.sim-toggle-btn:hover{transform:translateY(-2px);border-color:#38bdf8;box-shadow:0 12px 24px rgba(56,189,248,.2)}.sim-toggle-btn:active{transform:translateY(0) scale(.98)}.sim-toggle-btn.running{background:rgba(56,189,248,.15);border-color:#38bdf8;color:#f1f5f9}.sim-logo-pulse{width:20px;height:20px;stroke-dasharray:60;stroke-dashoffset:60;filter:drop-shadow(0 0 4px rgba(56, 189, 248, .4));transition:all .3s}.running .sim-logo-pulse{animation:electric-pulse-flow 2s linear infinite,electric-glow-flicker .15s infinite alternate}@keyframes electric-pulse-flow{0%{stroke-dashoffset:60;opacity:.8}50%{stroke-dashoffset:0;opacity:1}100%{stroke-dashoffset:-60;opacity:.8}}@keyframes electric-glow-flicker{0%{filter:drop-shadow(0 0 5px rgba(56, 189, 248, .6)) brightness(1)}100%{filter:drop-shadow(0 0 15px rgba(56, 189, 248, .95)) brightness(1.3);transform:scale(1.05) rotate(.5deg)}}.import-btn{background:rgba(56,189,248,.1);color:#38bdf8;border:1px solid rgba(56,189,248,.3);border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.import-btn:hover{background:rgba(56,189,248,.2);border-color:#38bdf8}.multimeter-body{display:flex;flex-direction:column;align-items:center;padding:10px;width:160px}.multimeter-lcd{width:100%;background:#0f172a;border:1px solid rgba(56,189,248,.3);border-radius:6px;padding:12px 0;margin:5px 0 15px;text-align:center;box-shadow:inset 0 0 15px rgba(0,0,0,.5);position:relative;overflow:hidden}.multimeter-lcd::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(56,189,248,.3),transparent)}.multimeter-display{font-family:Consolas,Monaco,monospace;font-size:18px;font-weight:900;color:#38bdf8;text-shadow:0 0 10px rgba(56,189,248,.5);letter-spacing:.05em}.multimeter-unit{font-size:10px;color:rgba(148,163,184,.6);margin-top:2px;font-weight:800}.multimeter-labels{display:flex;justify-content:space-between;width:100%;padding:0 5px;margin-top:5px}.multimeter-label{font-size:9px;font-weight:800;color:#64748b}.multimeter-label.pos{color:#f87171}.multimeter-label.com{color:#94a3b8}.mm-btn{background:#1e293b;border:1px solid rgba(255,255,255,.1);color:#94a3b8;font-size:8px;font-weight:700;border-radius:3px;padding:2px 6px;cursor:pointer;transition:all .2s}.mm-btn:hover{background:#334155;color:#fff}.mm-btn.active{background:#38bdf8;color:#020617;border-color:#38bdf8;box-shadow:0 0 8px rgba(56,189,248,.4)}.hw-panel-section{padding:10px 4px}.hw-panel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.hw-pin{display:flex;flex-direction:column;align-items:center;gap:4px}.hw-led{width:14px;height:14px;border-radius:50%;background:#334155;transition:all .2s;box-shadow:inset 0 2px 4px rgba(0,0,0,.3)}.hw-led.on{background:#22c55e;box-shadow:0 0 10px #22c55e,inset 0 2px 4px rgba(0,0,0,.3)}.hw-label{font-size:8px;font-weight:800;color:#94a3b8;text-transform:uppercase}.hw-analog-item{margin-bottom:8px}.hw-analog-header{display:flex;justify-content:space-between;margin-bottom:4px}.hw-analog-bar-bg{height:4px;background:#1e293b;border-radius:2px;overflow:hidden}.hw-analog-bar{height:100%;background:#38bdf8;width:0%;transition:width .2s}.sidebar-category[id=hwPanelCategory] .hw-panel-content{background:rgba(15,23,42,.4);border-radius:8px;padding:12px;margin-top:8px}.hw-modal{position:fixed;top:100px;right:380px;width:320px;background:rgba(15,23,42,.85);backdrop-filter:blur(20px);border:1px solid rgba(251,191,36,.2);border-radius:16px;box-shadow:0 20px 50px rgba(0,0,0,.5),0 0 20px rgba(251,191,36,.05);z-index:10000;display:none;flex-direction:column;overflow:hidden;animation:slideIn .3s cubic-bezier(.16,1,.3,1)}@keyframes slideIn{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.hw-modal-header{padding:14px 18px;background:rgba(251,191,36,.1);border-bottom:1px solid rgba(251,191,36,.15);display:flex;justify-content:space-between;align-items:center;color:#eef2ff;font-size:13px;font-weight:700}.hw-modal-close{background:0 0;border:none;color:#94a3b8;font-size:20px;cursor:pointer;line-height:1;transition:color .2s}.hw-modal-close:hover{color:#ef4444}.hw-modal-body{padding:20px;overflow-y:auto}.node{pointer-events:auto;transition:background .2s,border .2s,box-shadow .2s}.arduino-chip,.atmega-chip,.buzzer-aura,.driver-chip,.driver-heatsink,.esp32-board,.led-container,.motor-body,.node .port,.node-visual,.rgb-preview,.sensor-face{pointer-events:auto}.node.led-node .node-visual,.node.pkg-driver .node-visual,.node.pkg-mcu .node-visual,.node.sensor-dht .node-visual,.node.sensor-ultra .node-visual,.node.show-params .node-visual{display:none}.node .port::before{content:"";position:absolute;top:50%;transform:translateY(-50%);width:8px;height:4px;background:rgba(148,163,184,.9);border-radius:2px;z-index:-1;box-shadow:0 1px 2px rgba(0,0,0,.5)}.node .port[style*="left: -7px"]::before{right:100%;margin-right:-4px}.node .port[style*="right: -7px"]::before{left:100%;margin-left:-4px}.node.no-toggle{background:#111827!important;border:2px solid #334155!important;backdrop-filter:none!important}