:root{font-family:IBM Plex Sans,Aptos,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{width:100%;height:100%;overflow:hidden}body{margin:0;display:flex;place-items:stretch;min-width:320px;min-height:100vh}.node{cursor:move;transition:filter .2s,transform .2s}.node:hover{filter:brightness(1.08)}.node.dragging{cursor:grabbing;filter:brightness(1.15)}.node.selected .node-body{filter:brightness(1.08)}.selection-indicator{animation:dash 1s linear infinite}@keyframes dash{to{stroke-dashoffset:-8}}.node-body{transition:all .2s}.pin{cursor:crosshair;transition:all .2s}.pin:hover{r:7;filter:brightness(1.2)}.input-pin:hover{stroke:var(--wire-active);stroke-width:2}.output-pin:hover{stroke:var(--text-primary);stroke-width:2}.output-bulb-glass,.output-bulb-neck,.output-bulb-base,.output-bulb-thread,.output-bulb-filament{transition:fill .35s ease,stroke .35s ease,filter .35s ease,opacity .35s ease}.output-bulb-thread,.output-bulb-filament{fill:none;stroke-linecap:round;stroke-linejoin:round}.output-bulb.is-off .output-bulb-glass{fill:var(--bg-tertiary);stroke:var(--output-outline, var(--gate-output));stroke-width:2.4;filter:drop-shadow(0 0 1px var(--output-outline, var(--gate-output)))}.output-bulb.is-off .output-bulb-neck,.output-bulb.is-off .output-bulb-base{fill:#505050;stroke:#6a6a6a;stroke-width:1.6}.output-bulb.is-off .output-bulb-thread{stroke:#7b7b7b;stroke-width:1.2;opacity:.85}.output-bulb.is-off .output-bulb-filament{stroke:#8a8a8a;stroke-width:2}.output-bulb.is-on .output-bulb-glass{fill:var(--output-on);stroke:var(--output-on-glow);stroke-width:2.8;filter:drop-shadow(0 0 4px var(--output-on-glow)) drop-shadow(0 0 12px var(--output-on-glow));animation:output-bulb-pulse 1.15s ease-in-out infinite}.output-bulb.is-on .output-bulb-neck,.output-bulb.is-on .output-bulb-base{fill:#9d9d9d;stroke:#c9c9c9;stroke-width:1.6}.output-bulb.is-on .output-bulb-thread{stroke:#f0f0f0;stroke-width:1.2}.output-bulb.is-on .output-bulb-filament{stroke:#ffe6ab;stroke-width:2.3;filter:drop-shadow(0 0 7px #ffe6ab)}@keyframes output-bulb-pulse{0%{opacity:.95;filter:drop-shadow(0 0 3px var(--output-on-glow)) drop-shadow(0 0 10px var(--output-on-glow))}50%{opacity:1;filter:drop-shadow(0 0 6px var(--output-on-glow)) drop-shadow(0 0 16px var(--output-on-glow))}to{opacity:.95;filter:drop-shadow(0 0 3px var(--output-on-glow)) drop-shadow(0 0 10px var(--output-on-glow))}}.delete-button{cursor:pointer;opacity:.8;transition:opacity .2s}.delete-button:hover{opacity:1}.input-value{font-family:var(--font-tech);transition:fill .2s,filter .2s}.input-value.is-on{fill:var(--input-on);animation:input-value-pulse 1.05s ease-in-out infinite}.input-value.is-off{fill:var(--signal-off);filter:none}@keyframes input-value-pulse{0%{filter:drop-shadow(0 0 2px var(--input-on)) drop-shadow(0 0 7px var(--input-on-glow));opacity:1}50%{filter:drop-shadow(0 0 1px var(--input-on)) drop-shadow(0 0 12px var(--input-on-glow));opacity:.86}to{filter:drop-shadow(0 0 2px var(--input-on)) drop-shadow(0 0 7px var(--input-on-glow));opacity:1}}.workspace{flex:1;position:relative;background-color:var(--bg-primary);overflow:hidden}.workspace-svg{width:100%;height:100%;cursor:default}.workspace-svg.panning{cursor:grabbing}.workspace-controls{position:absolute;bottom:16px;right:16px;display:flex;flex-direction:column;gap:6px;align-items:flex-end}.workspace-controls button{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-strong);padding:8px 12px;border-radius:2px;cursor:pointer;font-size:11px;text-transform:uppercase;letter-spacing:.08em;transition:background-color .2s,color .2s,border-color .2s;box-shadow:0 8px 18px #0000004d}.workspace-controls button:hover{background-color:var(--accent);border-color:var(--accent-hover);color:var(--accent-contrast)}.zoom-info{background-color:var(--bg-tertiary);color:var(--text-secondary);padding:6px 10px;border-radius:2px;font-size:11px;border:1px solid var(--border-strong);box-shadow:0 8px 18px #0000004d;font-family:var(--font-tech);letter-spacing:.08em;text-transform:uppercase}.canvas-hint{position:absolute;top:14px;left:50%;transform:translate(-50%);background:linear-gradient(180deg,var(--hint-top) 0%,var(--hint-bottom) 100%);color:var(--text-primary);border:1px solid var(--border-strong);padding:8px 14px;border-radius:2px;font-size:11px;font-weight:500;font-family:var(--font-tech);letter-spacing:.04em;box-shadow:0 10px 18px #00000059;animation:slideDown .25s ease-out;max-width:calc(100% - 24px);text-align:center}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:960px){.workspace-controls{right:10px;bottom:10px}.workspace-controls button{padding:6px 10px}.canvas-hint{top:8px;font-size:10px;padding:7px 10px}}.palette{width:220px;background-color:var(--bg-secondary);border-right:1px solid var(--border-strong);display:flex;flex-direction:column;overflow-y:auto}.palette-header{border-bottom:1px solid var(--border-strong);padding:10px 12px 12px}.palette-title{padding:0;margin-bottom:10px;font-size:13px;font-weight:600;font-family:var(--font-tech);letter-spacing:.08em;text-transform:uppercase;color:var(--text-primary)}.palette-toggle-group{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.palette-toggle{background:var(--bg-tertiary);border:1px solid var(--border-strong);color:var(--text-secondary);border-radius:2px;font-size:10px;font-weight:600;font-family:var(--font-tech);letter-spacing:.08em;text-transform:uppercase;padding:6px 4px;cursor:pointer;transition:background-color .2s,color .2s,border-color .2s}.palette-toggle:hover{border-color:var(--accent);color:var(--text-primary)}.palette-toggle.active{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent-hover)}.palette-section{border-bottom:1px solid var(--border-color)}.palette-section h4{padding:12px 16px 8px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin:0;font-family:var(--font-tech)}.palette-items{padding:12px;display:flex;flex-direction:column;gap:8px}.palette-item{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:2px;padding:12px;display:flex;align-items:center;gap:12px;cursor:grab;transition:border-color .2s,background-color .2s,transform .2s;-webkit-user-select:none;user-select:none}.palette-item:hover{transform:translate(3px);border-color:var(--accent);background-color:var(--bg-elevated)}.palette-item:active{cursor:grabbing}.palette-icon{width:36px;height:36px;border-radius:2px;border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;font-family:var(--font-tech);font-weight:700;font-size:13px;color:var(--icon-color, #111111);flex-shrink:0;text-shadow:0 1px 0 rgba(255,255,255,.2)}.palette-icon svg{width:24px;height:24px;overflow:visible}.palette-item span{font-size:12px;font-weight:500;letter-spacing:.04em}.palette-help{margin-top:auto;padding:16px;border-top:1px solid var(--border-strong);font-size:12px;color:var(--text-secondary);line-height:1.6;background:linear-gradient(180deg,transparent 0%,var(--panel-fade) 100%)}.palette-help strong{color:var(--text-primary);display:block;margin-bottom:8px;font-family:var(--font-tech);letter-spacing:.05em;text-transform:uppercase}.palette-help ul{list-style:none;padding-left:0}.palette-help li{margin-bottom:6px;padding-left:16px;position:relative}.palette-help li:before{content:">";position:absolute;left:0;color:var(--text-primary)}.palette-examples{display:flex;flex-direction:column;gap:8px;margin-top:8px}.example-button{padding:12px;background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:2px;color:var(--text-primary);font-size:12px;font-weight:600;font-family:var(--font-tech);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:background-color .2s,border-color .2s,transform .2s;text-align:left}.example-button:hover{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent-hover);transform:translateY(-1px)}.example-button.hazard{border-style:dashed;background:var(--bg-elevated)}.example-button.hazard:hover{background:var(--danger-hover);color:var(--text-primary)}@media(max-width:960px){.palette{width:100%;max-height:30vh;border-right:none;border-bottom:1px solid var(--border-strong)}.palette-items{gap:6px}}.sidebar{width:300px;background-color:var(--bg-secondary);border-left:1px solid var(--border-strong);display:flex;flex-direction:column;overflow-y:auto}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border-strong)}.sidebar-tabs button{flex:1;background-color:var(--bg-tertiary);color:var(--text-secondary);border:none;border-right:1px solid var(--border-color);padding:12px 8px;cursor:pointer;font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;transition:background-color .2s,color .2s;border-bottom:2px solid transparent}.sidebar-tabs button:last-child{border-right:none}.sidebar-tabs button:hover{background-color:var(--bg-elevated);color:var(--text-primary)}.sidebar-tabs button.active{background-color:var(--bg-elevated);color:var(--accent);border-bottom-color:var(--accent-hover)}.sidebar-content{flex:1;padding:18px;overflow-y:auto}.sidebar-section h3{font-family:var(--font-tech);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;color:var(--text-primary)}.sidebar-section h4{font-family:var(--font-tech);font-size:12px;font-weight:600;margin-bottom:8px;color:var(--text-primary);letter-spacing:.04em}.stats{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:2px;padding:12px;margin-bottom:16px}.stat-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-color)}.stat-item:last-child{border-bottom:none}.stat-label{color:var(--text-secondary);font-size:12px}.stat-value{font-family:var(--font-tech);color:var(--text-primary);font-weight:600;font-size:13px}.button-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.btn-primary,.btn-secondary,.btn-danger{padding:10px 12px;border-radius:2px;border:1px solid var(--border-strong);cursor:pointer;font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;transition:background-color .2s,color .2s,border-color .2s;text-align:left}.btn-primary{background-color:var(--accent);color:var(--accent-contrast);border-color:var(--accent-hover)}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-strong)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-elevated);border-color:var(--accent)}.btn-danger{background-color:var(--danger);color:var(--text-primary);border-style:dashed}.btn-danger:hover:not(:disabled){background-color:var(--danger-hover);border-color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}.analysis-info{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:2px;padding:12px;margin-bottom:16px;font-size:12px;line-height:1.7}.analysis-info p{margin:4px 0}.analysis-info strong{color:var(--text-primary);font-family:var(--font-tech)}.warning{margin-top:8px;padding:10px;background-color:var(--bg-tertiary);border-left:3px solid var(--text-secondary);border-radius:2px;font-size:12px;color:var(--text-secondary);line-height:1.4}.info{margin-top:8px;padding:10px;background-color:var(--bg-tertiary);border-left:3px solid var(--border-strong);border-radius:2px;font-size:12px;color:var(--text-secondary);line-height:1.4}.help-section{margin-top:20px;padding:16px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:2px}.help-section ul{list-style:none;padding:0;margin-top:8px}.help-section li{padding:6px 0;font-size:12px;color:var(--text-secondary);line-height:1.5}.help-section kbd{background-color:var(--bg-primary);border:1px solid var(--border-strong);border-radius:2px;padding:2px 6px;font-size:11px;font-family:var(--font-tech);color:var(--text-primary)}.presets-list{display:flex;flex-direction:column;gap:12px}.preset-item{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:2px;padding:12px;transition:border-color .2s,background-color .2s}.preset-item:hover{border-color:var(--accent);background-color:var(--bg-elevated)}.preset-info h4{font-size:13px;margin-bottom:6px;color:var(--text-primary);font-family:var(--font-tech)}.preset-info p{font-size:12px;color:var(--text-secondary);line-height:1.4;margin-bottom:10px}.preset-item .btn-secondary{width:100%;text-align:center;font-size:11px;padding:8px}.sidebar-footer{padding:16px;border-top:1px solid var(--border-strong);text-align:center;color:var(--text-secondary);font-size:11px;margin-top:auto;font-family:var(--font-tech);letter-spacing:.06em}@media(max-width:960px){.sidebar{width:100%;max-height:34vh;border-left:none;border-top:1px solid var(--border-strong)}.sidebar-content{padding:14px}}:root{--font-ui: "IBM Plex Sans", "Aptos", "Segoe UI", sans-serif;--font-tech: "JetBrains Mono", "IBM Plex Mono", "SFMono-Regular", Menlo, Consolas, monospace;--bg-primary: #060606;--bg-secondary: #0f0f0f;--bg-tertiary: #171717;--bg-elevated: #1f1f1f;--border-color: #2f2f2f;--border-strong: #454545;--text-primary: #f4f4f4;--text-secondary: #b5b5b5;--accent: #efefef;--accent-hover: #ffffff;--accent-contrast: #070707;--danger: #2a2a2a;--danger-hover: #333333;--header-top: #121212;--header-bottom: #0d0d0d;--hint-top: #131313;--hint-bottom: #0d0d0d;--panel-fade: #101010;--bg-ornament-a: #121212;--bg-ornament-b: #111111;--gate-and: #81a0eb;--gate-or: #d8a37a;--gate-not: #d67f7f;--gate-xor: #9a87d8;--gate-xnor: #7fa8d1;--gate-input: #79ce99;--gate-output: #d37f7f;--gate-clock: #bea168;--gate-display: #8bb0cf;--gate-flipflop: #9f8dc8;--gate-gray: #83b8c6;--gate-mux: #93a8cf;--gate-demux: #9f95ce;--gate-progress: #d4af73;--gate-fa1: #82c29c;--wire-active: #f2f2f2;--wire-inactive: #777;--signal-on: #f8f8f8;--signal-off: #555;--signal-on-glow: #f6f6f6;--input-on: #35d475;--input-on-glow: #95f7be;--output-on: #d63f3f;--output-on-glow: #ff9d9d;--pin-idle: #333;--pin-idle-stroke: #555;--pin-output-stroke: #d0d0d0;--grid-line: #242424}:root.theme-invert{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #f0f0f0;--bg-elevated: #e9e9e9;--border-color: #cdcdcd;--border-strong: #b5b5b5;--text-primary: #151515;--text-secondary: #4d4d4d;--accent: #111111;--accent-hover: #000000;--accent-contrast: #ffffff;--danger: #e1e1e1;--danger-hover: #d5d5d5;--header-top: #fdfdfd;--header-bottom: #ececec;--hint-top: #f7f7f7;--hint-bottom: #ececec;--panel-fade: #ededed;--bg-ornament-a: #f0f0f0;--bg-ornament-b: #ececec;--wire-active: #1f1f1f;--wire-inactive: #8f8f8f;--signal-on: #262626;--signal-off: #9b9b9b;--signal-on-glow: #555555;--gate-display: #557493;--gate-gray: #4f7c8a;--gate-mux: #5f6f97;--gate-demux: #6f659d;--gate-progress: #8f7447;--gate-fa1: #4d7f63;--pin-idle: #d7d7d7;--pin-idle-stroke: #a9a9a9;--pin-output-stroke: #383838;--grid-line: #d8d8d8}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-ui);background:radial-gradient(circle at 15% 0,var(--bg-ornament-a) 0%,transparent 28%),radial-gradient(circle at 85% 100%,var(--bg-ornament-b) 0%,transparent 34%),var(--bg-primary);color:var(--text-primary);overflow:hidden}.app-container{width:100vw;height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(180deg,var(--header-top) 0%,var(--header-bottom) 100%);border-bottom:1px solid var(--border-strong);padding:12px 18px;display:flex;justify-content:space-between;align-items:center;gap:12px;box-shadow:0 12px 24px #00000059}.app-header h1{flex:1;min-width:0;font-family:var(--font-tech);font-size:15px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions{display:flex;align-items:center;gap:8px}.language-picker{display:flex;align-items:center;gap:6px;font-family:var(--font-tech);color:var(--text-secondary);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.language-select{min-width:64px;font-family:var(--font-tech);background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-strong);padding:7px 8px;border-radius:2px;cursor:pointer;font-size:12px;letter-spacing:.08em;text-transform:uppercase;transition:background-color .2s,color .2s,border-color .2s}.language-select:hover{background-color:var(--accent);border-color:var(--accent-hover);color:var(--accent-contrast)}.theme-toggle,.sidebar-toggle{font-family:var(--font-tech);background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-strong);padding:7px 12px;border-radius:2px;cursor:pointer;font-size:12px;letter-spacing:.08em;text-transform:uppercase;transition:background-color .2s,color .2s,border-color .2s}.theme-toggle:hover,.sidebar-toggle:hover{background-color:var(--accent);border-color:var(--accent-hover);color:var(--accent-contrast)}.app-main{flex:1;display:flex;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}button{font-family:var(--font-tech)}input,select,textarea{font-family:var(--font-tech);background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);padding:7px 10px;border-radius:2px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-hover)}.cookie-consent-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1200;padding:16px}.cookie-consent-modal{width:min(520px,100%);background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border:1px solid var(--border-strong);border-radius:6px;padding:20px;box-shadow:0 24px 48px #00000059}.cookie-consent-modal h2{margin-bottom:8px;font-family:var(--font-tech);font-size:16px;letter-spacing:.06em;text-transform:uppercase}.cookie-consent-modal p{margin-bottom:16px;color:var(--text-secondary);line-height:1.45}.cookie-consent-actions{display:flex;justify-content:flex-end;gap:10px}.cookie-consent-actions button{border:1px solid var(--border-strong);border-radius:3px;padding:8px 14px;cursor:pointer;font-size:12px;letter-spacing:.05em;text-transform:uppercase;transition:background-color .2s,color .2s,border-color .2s}.cookie-accept{background:var(--accent);color:var(--accent-contrast)}.cookie-accept:hover{background:var(--accent-hover)}.cookie-decline{background:var(--bg-tertiary);color:var(--text-primary)}.cookie-decline:hover{border-color:var(--text-secondary)}.cookie-warning{position:fixed;right:14px;bottom:14px;z-index:1100;background:var(--bg-secondary);border:1px solid var(--border-strong);border-left:4px solid #d04f4f;color:var(--text-primary);padding:10px 12px;font-size:12px;border-radius:4px;max-width:min(420px,calc(100vw - 28px))}@media(max-width:960px){.app-header{padding:10px 12px;gap:10px}.app-header h1{font-size:11px;letter-spacing:.06em}.header-actions{gap:6px}.theme-toggle,.sidebar-toggle{font-size:10px;padding:6px 8px}.app-main{flex-direction:column}.cookie-consent-actions{flex-direction:column;align-items:stretch}}
