@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", monospace;--spacing:.25rem;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-bg-deep:#060b14;--color-bg-surface:#0d1424;--color-bg-card:#111827;--color-border:#1e2d45;--color-wire-off:#2d3f55;--color-wire-on:#06b6d4;--color-switch-on:#1d4ed8;--color-led-off:#1e2d45;--color-led-on:#fbbf24;--color-gate-fill:#111827;--color-gate-stroke:#2d3f55;--color-gate-active:#06b6d4;--color-accent:#06b6d4;--color-accent-dim:#0e7490;--color-text:#e2e8f0;--color-text-muted:#64748b}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.pointer-events-none{pointer-events:none}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.mx-auto{margin-inline:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.inline{display:inline}.table{display:table}.max-w-\[720px\]{max-width:720px}.max-w-\[760px\]{max-width:760px}.max-w-\[780px\]{max-width:780px}.max-w-\[820px\]{max-width:820px}.max-w-\[900px\]{max-width:900px}.max-w-\[1000px\]{max-width:1000px}.flex-shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.opacity-40{opacity:.4}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{background-color:var(--color-bg-deep);color:var(--color-text);font-family:var(--font-sans);height:100vh;margin:0;overflow:hidden}@media(max-width:768px){body{height:auto;overflow-y:auto}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg-surface)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-accent-dim)}.app-shell{grid-template-rows:56px 1fr;grid-template-columns:240px 1fr;width:100vw;height:100dvh;display:grid}@media(max-width:768px){.app-shell{grid-template-rows:56px auto 1fr;grid-template-columns:1fr;height:auto;min-height:100dvh}}.topnav{background:var(--color-bg-surface);border-bottom:1px solid var(--color-border);z-index:100;grid-area:1/1/auto/-1;align-items:center;gap:.5rem;padding:0 1rem;display:flex;position:sticky;top:0}.sidebar{background:var(--color-bg-surface);border-right:1px solid var(--color-border);z-index:90;grid-area:2/1;padding:1rem 0;overflow-y:auto}@media(max-width:768px){.sidebar{border-right:none;border-bottom:1px solid var(--color-border);white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;grid-row:2;padding:0;display:flex;overflow:auto visible}.sidebar::-webkit-scrollbar{display:none}}.main-canvas{background:var(--color-bg-deep);grid-area:2/2;padding:2rem;overflow-y:auto}@media(max-width:768px){.main-canvas{grid-area:3/1;padding:1.5rem 1rem 8rem}}.topnav-logo{background:linear-gradient(135deg,var(--color-accent),#7c3aed);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.topnav-title{letter-spacing:.01em;color:var(--color-text-muted);white-space:nowrap;font-size:.9rem;font-weight:500}.topnav-author{background:linear-gradient(135deg,var(--color-accent) 0%,#a78bfa 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-left:.25rem;font-weight:700;position:relative}.topnav-author:after{content:"";background:linear-gradient(90deg,transparent,var(--color-accent),transparent);opacity:.5;width:100%;height:1px;position:absolute;bottom:-2px;left:0}.topnav-badge{color:var(--color-accent);font-size:.7rem;font-family:var(--font-mono);letter-spacing:.05em;background:#06b6d41f;border:1px solid #06b6d44d;border-radius:999px;margin-left:auto;padding:.2rem .6rem;font-weight:500}.sidebar-section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);margin-top:1rem;padding:0 1.25rem .5rem;font-size:.65rem;font-weight:600}@media(max-width:768px){.sidebar-section-label{display:none}}.sidebar-section-label:first-child{margin-top:0}.sidebar-link{color:var(--color-text-muted);border-left:2px solid #0000;align-items:center;gap:.625rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:450;text-decoration:none;transition:all .15s;display:flex;position:relative}@media(max-width:768px){.sidebar-link{border-bottom:2px solid #0000;border-left:none;padding:1rem 1.25rem}.sidebar-link.active{border-bottom-color:var(--color-accent);border-left-color:#0000}}.sidebar-link:hover{color:var(--color-text);border-left-color:var(--color-border);background:#ffffff0a}.sidebar-link.active{color:var(--color-accent);border-left-color:var(--color-accent);background:#06b6d414;font-weight:500}.sidebar-link-icon{opacity:.7;flex-shrink:0;width:16px;height:16px}.sidebar-link.active .sidebar-link-icon{opacity:1}.page-header{margin-bottom:2rem}.page-title{color:var(--color-text);margin:0 0 .5rem;font-size:1.75rem;font-weight:700;line-height:1.2}.page-subtitle{color:var(--color-text-muted);margin:0;font-size:.9rem}.circuit-grid{gap:1.5rem;display:grid}.circuit-grid-3{grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}.circuit-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;padding:1.5rem;transition:border-color .2s;position:relative;overflow:hidden}.circuit-card:before{content:"";pointer-events:none;background:linear-gradient(135deg,#06b6d408,#0000 60%);border-radius:16px;position:absolute;inset:0}.circuit-card:hover{border-color:#06b6d44d}.circuit-card-title{letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent);font-size:.8rem;font-weight:600;font-family:var(--font-mono);align-items:center;gap:.5rem;margin:0 0 1rem;display:flex}.circuit-card-title:before{content:"";background:var(--color-accent);width:6px;height:6px;box-shadow:0 0 6px var(--color-accent);border-radius:50%;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.circuit-svg{width:100%;height:auto;display:block;overflow:visible}.switch-body{cursor:pointer;filter:drop-shadow(0 0 #0000);transition:all .2s}.switch-body:hover{filter:drop-shadow(0 0 4px #06b6d466)}.switch-body.on rect{fill:var(--color-switch-on);stroke:#3b82f6}.switch-body.on .switch-label{fill:#93c5fd}.wire{stroke:var(--color-wire-off);stroke-width:2.5px;stroke-linecap:round;fill:none;filter:none;transition:stroke .2s,filter .2s}.wire.active{stroke:var(--color-wire-on);filter:drop-shadow(0 0 3px #06b6d4b3)}.junction-dot{fill:var(--color-wire-off);transition:fill .2s,filter .2s}.junction-dot.active{fill:var(--color-wire-on);filter:drop-shadow(0 0 3px #06b6d4b3)}.ic-trace{stroke:#1e3a5f;stroke-width:1.5px;stroke-linecap:round;fill:none;transition:stroke .2s,filter .2s,stroke-dasharray .2s}.ic-trace.active{stroke:#06b6d4;filter:drop-shadow(0 0 3px #06b6d499)}.ic-body{fill:url(#ic-grad);stroke:#334155;stroke-width:2px}.ic-pin-label{fill:#64748b;font-family:var(--font-mono);font-size:9px;font-weight:500}.channel-badge{font-family:var(--font-mono);color:var(--color-accent);background:#06b6d41a;border:1px solid #06b6d44d;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.gate-body{fill:var(--color-gate-fill);stroke:var(--color-gate-stroke);stroke-width:1.5px;transition:stroke .2s,filter .2s}.gate-body.active{stroke:var(--color-gate-active);filter:drop-shadow(0 0 4px #06b6d466)}.gate-label{fill:var(--color-text-muted);font-family:var(--font-mono);pointer-events:none;font-size:10px;font-weight:600;transition:fill .2s}.gate-label.active{fill:var(--color-accent)}.led-body{fill:var(--color-led-off);stroke:#2d3f55;stroke-width:1.5px;filter:none;transition:fill .2s,filter .2s}.led-body.active{fill:var(--color-led-on);stroke:#f59e0b;filter:drop-shadow(0 0 8px #fbbf24cc)drop-shadow(0 0 16px #fbbf2466)}.led-label{fill:var(--color-text-muted);font-family:var(--font-mono);pointer-events:none;font-size:9px;font-weight:500}.led-value{font-family:var(--font-mono);fill:var(--color-text-muted);pointer-events:none;font-size:11px;font-weight:700;transition:fill .2s}.led-value.active{fill:#fbbf24}.truth-table-wrap{border-top:1px solid var(--color-border);margin-top:1.25rem;padding-top:1rem}.truth-table-title{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin:0 0 .625rem;font-size:.7rem;font-weight:600}.truth-table{border-collapse:collapse;width:100%;font-family:var(--font-mono);font-size:.8rem}.truth-table th{color:var(--color-accent);text-align:center;border-bottom:1px solid var(--color-border);padding:.3rem .75rem;font-weight:600}.truth-table td{color:var(--color-text-muted);text-align:center;border-bottom:1px solid #1e2d4580;padding:.25rem .75rem;transition:background .15s,color .15s}.truth-table tr.truth-row-active td{color:var(--color-accent);background:#06b6d40f}.hero{max-width:720px;padding:3rem 0 2rem}.hero-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);background:#06b6d41a;border:1px solid #06b6d433;border-radius:999px;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.3rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.hero-title{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#e2e8f0,#94a3b8);-webkit-background-clip:text;background-clip:text;margin:0 0 1rem;font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1}.hero-title span{background:linear-gradient(135deg,var(--color-accent),#7c3aed);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-desc{color:var(--color-text-muted);margin:0 0 2rem;font-size:1.05rem;line-height:1.7}.hero-actions{flex-wrap:wrap;gap:.75rem;display:flex}.btn-primary{background:var(--color-accent);color:#0a0f1a;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary:hover{background:#22d3ee;transform:translateY(-1px);box-shadow:0 8px 16px #06b6d44d}.btn-secondary{color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn-secondary:hover{border-color:var(--color-accent);color:var(--color-accent);background:#06b6d40f}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:2.5rem;display:grid}.feature-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;transition:border-color .2s,transform .2s}.feature-card:hover{border-color:#06b6d44d;transform:translateY(-2px)}.feature-icon{background:#06b6d41f;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:.75rem;display:flex}.feature-title{color:var(--color-text);margin:0 0 .35rem;font-size:.875rem;font-weight:600}.feature-desc{color:var(--color-text-muted);margin:0;font-size:.8rem;line-height:1.5}.ha-output-labels{flex-wrap:wrap;gap:1rem;margin-top:1rem;display:flex}.ha-output-badge{font-family:var(--font-mono);color:var(--color-text-muted);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem .875rem;font-size:.8rem;display:flex}.ha-output-dot{background:var(--color-led-off);border-radius:50%;width:10px;height:10px;transition:background .2s,box-shadow .2s}.ha-output-dot.active{background:var(--color-led-on);box-shadow:0 0 8px #fbbf24cc}@media(max-width:768px){.app-shell{grid-template-rows:56px auto 1fr;grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--color-border);flex-direction:row;grid-area:2/1;gap:.5rem;padding:.5rem 1rem;display:flex;overflow:auto hidden}.sidebar-section-label{display:none}.sidebar-link{white-space:nowrap;border-bottom:2px solid #0000;border-left:none;padding:.4rem .75rem}.sidebar-link.active{border-bottom-color:var(--color-accent);border-left:none}.main-canvas{grid-area:3/1;padding:1.25rem}}.two-col-grid{grid-template-columns:1fr 1fr;gap:1.5rem;max-width:100%;display:grid}@media(max-width:900px){.two-col-grid{grid-template-columns:1fr}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
