*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.table{display:table}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.italic{font-style:italic}.blur{--tw-blur: blur(8px);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)}.invert{--tw-invert: invert(100%);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)}.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)}.\!transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--bg: #eef2f7;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #f1f5f9;--border: #dbe2ea;--border-strong: #cbd5e1;--text: #1f2937;--text-soft: #475569;--text-muted: #64748b;--text-faint: #94a3b8;--accent: #2563eb;--accent-soft: #eff6ff;--accent-border: #93c5fd;--ok-bg: #f0fdf4;--ok-border: #bbf7d0;--ok-text: #166534;--err-bg: #fef2f2;--err-border: #fecaca;--err-text: #991b1b;--warn-bg: #fffbeb;--warn-border: #fde68a;--warn-text: #92400e;--paper: #ffffff;--shadow: 0 10px 30px rgba(30, 41, 59, .08);color:var(--text);background:var(--bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color-scheme:light}[data-theme=dark]{--bg: #0b1220;--surface: #131c2e;--surface-2: #18233a;--surface-3: #1e2a44;--border: #283955;--border-strong: #36486b;--text: #e2e8f0;--text-soft: #b6c2d6;--text-muted: #8da2bd;--text-faint: #64748b;--accent: #60a5fa;--accent-soft: #1d3358;--accent-border: #3b6cb7;--ok-bg: #0c2a1b;--ok-border: #1d5c3a;--ok-text: #6ee7a8;--err-bg: #331417;--err-border: #7a2c33;--err-text: #fda4af;--warn-bg: #33270e;--warn-border: #7a5c1e;--warn-text: #fcd34d;--shadow: 0 10px 30px rgba(0, 0, 0, .45);color-scheme:dark}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg);color:var(--text);transition:background .2s ease,color .2s ease}button,input,select{font:inherit}.app-shell{width:min(1680px,100%);margin:0 auto;padding:20px 24px 36px;box-sizing:border-box}.app-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-bottom:16px;padding:16px 20px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:var(--shadow)}.app-brand{display:flex;align-items:center;gap:14px}.app-logo{display:grid;place-items:center;width:42px;height:42px;border-radius:10px;background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent)}.app-brand h1{margin:0;font-size:19px;font-weight:800;letter-spacing:-.01em;color:var(--text)}.app-brand p{margin:2px 0 0;color:var(--text-muted);font-size:12px}.app-header-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.meta-chip{border:1px solid var(--border);border-radius:999px;background:var(--surface-2);color:var(--text-soft);padding:5px 11px;font-size:11px;font-weight:700;letter-spacing:.02em}.icon-button{display:grid;place-items:center;width:32px;height:32px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text-soft);cursor:pointer}.icon-button:hover{border-color:var(--accent-border);color:var(--accent)}.workspace-grid{display:grid;grid-template-columns:440px minmax(0,1fr);gap:16px;align-items:start}.sidebar{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:var(--shadow);overflow:hidden}.main-workspace{min-width:0}.control-block{padding:18px;border-bottom:1px solid var(--border)}.control-block:last-child{border-bottom:0}.control-title{margin:0 0 12px;color:var(--text-soft);font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.selector-panel{display:grid;gap:16px}.segmented{display:flex;gap:0;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);overflow:hidden}.segmented button{flex:1;min-height:34px;border:0;border-right:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:600}.segmented button:last-child{border-right:0}.segmented button.active{background:var(--accent-soft);color:var(--accent);font-weight:800}.field-label{display:block;margin:0 0 5px;color:var(--text-muted);font-size:11px;font-weight:600}.model-note{margin:10px 0 0;color:var(--text-muted);font-size:11px;line-height:1.5}.text-field{width:100%;height:34px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);padding:0 10px;box-sizing:border-box}.text-field:focus{outline:2px solid var(--accent-border);outline-offset:-1px}.field-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:12px}.field-alert{margin:12px 0 0}.sidebar-actions .example-row{display:flex;gap:8px}.action-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.action-button{display:inline-flex;align-items:center;gap:6px;min-height:32px;border:1px solid var(--border);border-radius:7px;background:var(--surface);color:var(--text-soft);cursor:pointer;font-size:12px;font-weight:600;padding:0 11px;white-space:nowrap}.action-button:hover:not(:disabled){border-color:var(--accent-border);color:var(--accent)}.action-button:disabled{opacity:.45;cursor:not-allowed}.action-button.primary{background:var(--accent);border-color:var(--accent);color:#fff}.action-button.primary:hover:not(:disabled){color:#fff;filter:brightness(1.07)}.autosave-note{margin:12px 0 0;color:var(--text-faint);font-size:10px}.result-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;padding:8px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:var(--shadow)}.result-tabs button{display:inline-flex;align-items:center;gap:7px;min-height:34px;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text-muted);cursor:pointer;font-size:12.5px;font-weight:600;padding:0 13px;white-space:nowrap}.result-tabs button:hover{color:var(--text-soft);background:var(--surface-2)}.result-tabs button.active{border-color:var(--accent-border);background:var(--accent-soft);color:var(--accent);font-weight:800}.tab-badge{display:inline-grid;place-items:center;min-width:18px;height:18px;border-radius:999px;background:var(--err-text);color:var(--surface);font-size:10px;font-weight:800;padding:0 4px}[data-theme=dark] .tab-badge{color:#131c2e}.validation-status{display:inline-flex;align-items:center;gap:7px;margin-left:auto;min-width:116px;justify-content:flex-end;padding:0 12px;height:34px;border-radius:8px;font-size:12px;font-weight:700;color:var(--text-muted);white-space:nowrap}.validation-status-dot{width:8px;height:8px;border-radius:999px;background:currentColor;flex:none}.validation-status-busy{color:var(--text-muted)}.validation-status-busy .validation-status-dot{animation:validation-pulse 1s ease-in-out infinite}.validation-status-ok{color:var(--ok-text)}.validation-status-warn{color:var(--warn-text)}@keyframes validation-pulse{0%,to{opacity:.35}50%{opacity:1}}@media (prefers-reduced-motion: reduce){.validation-status-busy .validation-status-dot{animation:none}}.tab-panel{display:none}.tab-panel.active{display:block;animation:panel-in .22s ease}@keyframes panel-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.panel{margin:0 0 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:var(--shadow);overflow:hidden}.output-panel{padding:20px}h2{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:0 0 18px;color:var(--text);font-size:14px;font-weight:800}.panel-hint{color:var(--text-faint);font-size:11px;font-weight:500}.panel-header-actions{display:inline-flex;gap:6px;margin-left:auto}.panel-header-actions button{min-width:40px;height:26px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-soft);cursor:pointer;font-size:11px;font-weight:600}.panel-header-actions button:hover{border-color:var(--accent-border);color:var(--accent)}.state-variable-line{margin:-6px 0 14px;color:var(--text-soft);font-size:13px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:12px}th,td{border:1px solid var(--border);padding:8px;text-align:center;white-space:nowrap;color:var(--text)}th{color:var(--text-muted);font-size:11px;font-weight:800;background:var(--surface-2)}.compact-table{margin-top:14px}.compact-table th,.compact-table td{padding:6px}.bit-button{width:28px;height:24px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);cursor:pointer}.bit-button:hover{background:var(--accent-soft);border-color:var(--accent-border)}.bit-button.moore-output{border-color:var(--accent-border);background:var(--accent-soft)}.equation-table td:nth-child(3){text-align:left}.formula{color:var(--text);font-family:Times New Roman,Georgia,serif;font-size:17px;font-style:italic;font-weight:700}.formula sub{bottom:-.25em;font-size:65%;font-style:italic;line-height:0;position:relative;vertical-align:baseline}.excitation-layout{display:grid;grid-template-columns:minmax(0,1fr) 230px;gap:18px;align-items:start}.excitation-cell{background:var(--surface-2);font-weight:700}.excitation-rule-card{border:1px solid var(--border);border-radius:10px;background:var(--surface-2);padding:14px}.excitation-rule-card h3{margin:0 0 10px;color:var(--text-soft);font-size:12px;font-weight:800}.excitation-rule-card p{margin:12px 0 0;color:var(--text-muted);font-size:11px;line-height:1.55}.kmap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;align-items:start}.kmap-card{min-width:0;border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:0 10px 22px #1e293b0f;overflow:hidden}.kmap-card-header{display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px;align-items:start;padding:14px 16px 12px;border-bottom:1px solid var(--border);background:var(--surface-2)}.kmap-card-title,.kmap-expression,.kmap-legend-block{min-width:0}.kmap-card-title strong{display:block;margin-top:3px;color:var(--text)}.kmap-expression .formula{display:block;margin-top:3px;color:var(--text);overflow-wrap:anywhere}.kmap-section-label{display:block;color:var(--text-faint);font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.kmap-table-scroll{width:100%;overflow-x:auto;overflow-y:hidden;padding:14px 16px 12px;box-sizing:border-box}.kmap-table{border-collapse:collapse;width:-moz-max-content;width:max-content;min-width:320px}.kmap-table th{min-width:44px;padding:5px 8px;background:var(--surface-3);color:var(--text-muted);font-family:Times New Roman,Georgia,serif;font-size:13px;font-style:italic;font-weight:700}.kmap-corner{position:relative;min-width:52px;background:linear-gradient(to top right,transparent calc(50% - .5px),var(--border-strong),transparent calc(50% + .5px)),var(--surface-3)!important}.kmap-corner-row{position:absolute;left:6px;bottom:3px;font-size:11px}.kmap-corner-col{position:absolute;right:6px;top:3px;font-size:11px}.kmap-cell{min-width:44px;min-height:44px;padding:4px 6px;background:var(--surface-2);text-align:center}.kmap-cell small{display:block}.kmap-legend{display:flex;flex-wrap:wrap;gap:6px 14px;margin:6px 0 0;padding:0;list-style:none}.kmap-legend-block{padding:12px 16px 14px;border-top:1px solid var(--border);background:var(--surface-2)}.kmap-legend li{display:inline-flex;align-items:center;gap:6px}.kmap-legend .formula{font-size:13px}.kmap-legend-swatch{width:11px;height:11px;border-radius:3px;opacity:.75}.kmap-cell small{color:var(--text-faint);font-size:9px}.kmap-cell span{font-family:Times New Roman,Georgia,serif;font-size:16px;font-weight:700;color:var(--text)}.kmap-cell.value-1{background:var(--accent-soft)}.kmap-cell.value-dc{background:var(--surface-2)}.circuit-panel,.timing-panel{padding:0 0 16px}.timing-panel{--bg-card: #ffffff;--bg-waveform: #fbfdff;--grid-major: #e5ebf3;--grid-minor: #f2f6fb;--signal-clk: #2563eb;--signal-reset: #f59e0b;--signal-digital: #334155;--signal-z: #059669;--cursor: #2563eb;--cycle-highlight: #eaf3ff;--pass-bg: #dcfce7;--pass-border: #22c55e;--pass-text: #166534;--fail-bg: #fee2e2;--fail-border: #ef4444;--fail-text: #991b1b;--debug-bg: #f1f5f9;--debug-border: #cbd5e1;--debug-text: #1f2937}.diagram-tools{display:flex;flex-wrap:wrap;gap:10px;padding:16px 20px 0}.diagram-tools button{min-width:42px;height:30px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-soft);cursor:pointer;font-size:11px;font-weight:600}.diagram-tools button:first-child{background:var(--accent);border-color:var(--accent);color:#fff;padding:0 12px}.diagram-tools button:hover:not(:disabled):not(:first-child){border-color:var(--accent-border);color:var(--accent)}.diagram-tools button:disabled{color:var(--text-faint);cursor:not-allowed;opacity:.55}.diagram-tools button.is-active:not(:first-child){border-color:var(--accent-border);background:var(--accent-soft);color:var(--accent)}.diagram-probe{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:12px 20px 0;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2)}.diagram-probe .probe-label{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.probe-toggle,.probe-action{height:28px;padding:0 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-soft);cursor:pointer;font-size:11.5px;font-weight:600}.probe-toggle b{font-weight:800}.probe-toggle.value-1{border-color:#86efac;color:#15803d}.probe-toggle.value-0{color:var(--text-muted)}.probe-action{font-weight:700;color:var(--accent);border-color:var(--accent-border)}.probe-action:hover{background:var(--accent-soft)}.diagram-alert{margin:12px 20px 0;border-radius:6px;padding:9px 12px;font-size:12px;white-space:pre-line}.diagram-alert.error{border:1px solid var(--err-border);background:var(--err-bg);color:var(--err-text)}.diagram-alert.warning{border:1px solid var(--warn-border);background:var(--warn-bg);color:var(--warn-text)}.diagram-hint{margin:10px 20px 0;font-size:11.5px;color:var(--text-muted)}.stage-wrap{position:relative;width:100%;min-height:360px;max-height:min(72vh,760px);overflow:auto;margin-top:14px;background:var(--paper)}.stage-wrap .konvajs-content{display:block}.component-card{position:absolute;top:14px;right:14px;width:248px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 12px 32px #0f172a2e;padding:12px 14px;z-index:5}.component-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.component-card-title{font-size:13.5px;font-weight:800;color:var(--text)}.component-card-subtitle{margin-top:2px;font-size:11px;color:var(--text-muted)}.component-card-close{border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:18px;line-height:1;padding:0 2px}.component-card-close:hover{color:var(--text)}.component-card-pins{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.component-card-section{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:5px}.component-card-pins ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.component-card-pins li{display:flex;align-items:baseline;justify-content:space-between;gap:6px;font-size:11px}.component-card-pins .pin-name{font-weight:700;color:var(--accent);font-family:Times New Roman,serif;font-style:italic}.component-card-pins .pin-signal{color:var(--text-soft);text-align:right;word-break:break-all}.component-card-empty{font-size:11px;color:var(--text-faint)}.timing-toolbar-card{display:flex;align-items:flex-end;flex-wrap:wrap;gap:12px;margin:16px 20px 0;border:1px solid var(--border);border-radius:10px;background:var(--bg-card);box-shadow:0 8px 24px #1e293b14;padding:12px}.timing-config{padding:0}.timing-config-enhanced{display:flex;align-items:flex-end;justify-content:flex-start;flex-wrap:wrap;gap:10px}.timing-input-control{min-width:min(420px,100%);flex:1 1 360px}.timing-config .text-field{max-width:none}.timing-sim-status,.timing-step-status{border:1px solid var(--border);border-radius:5px;padding:5px 8px;font-size:10px;font-weight:800}.timing-sim-status.pass,.timing-step-status.pass{border-color:var(--pass-border);background:var(--pass-bg);color:var(--pass-text)}.timing-sim-status.fail,.timing-step-status.fail{border-color:var(--fail-border);background:var(--fail-bg);color:var(--fail-text)}.simulation-controls{display:flex;align-items:center;flex-wrap:wrap;gap:9px;padding:0}.simulation-controls button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:30px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-soft);cursor:pointer;font-size:11px;font-weight:600;padding:0 11px;white-space:nowrap}.simulation-controls button:hover:not(:disabled){border-color:var(--accent-border);color:var(--accent)}.simulation-controls button:disabled{color:var(--text-faint);cursor:not-allowed;opacity:.55}.simulation-speed{display:inline-flex;align-items:center;gap:8px;margin-left:0;color:var(--text-muted);font-size:11px;font-weight:700}.simulation-speed input{width:130px;accent-color:var(--accent)}.simulation-speed strong{min-width:48px;color:var(--text-soft);font-size:11px}.timing-export-tools{margin-left:auto;padding:0}.timing-export-tools button:first-child{background:var(--surface);border-color:var(--border);color:var(--text-soft)}.timing-scroll{width:100%;max-height:min(72vh,760px);overflow-x:auto;overflow-y:auto;margin-top:16px;background:var(--bg-card)}.interactive-timing-scroll{margin-inline:20px;border:1px solid var(--border);border-radius:12px;background:var(--bg-card);box-shadow:0 10px 26px #1e293b14;overflow:hidden}.timing-scroll>div{min-width:100%}.timing-svg,.interactive-timing-svg{display:block;max-width:none}.interactive-timing-frame{display:grid;grid-template-columns:136px minmax(0,1fr);min-width:100%;background:var(--bg-card)}.timing-label-rail{position:sticky;left:0;z-index:2;border-right:1px solid var(--grid-major);background:#f8fafc;box-shadow:8px 0 14px #94a3b814}.timing-label-gutter{border-bottom:1px solid var(--grid-major)}.timing-signal-label{display:flex;align-items:center;gap:9px;border-bottom:1px solid var(--grid-major);color:#374151;font-size:12px;font-weight:800;padding:0 14px;white-space:nowrap}.timing-signal-dot{width:8px;height:8px;border-radius:999px;background:var(--signal-digital)}.timing-signal-dot-clock{background:var(--signal-clk)}.timing-signal-dot-reset{background:var(--signal-reset)}.timing-signal-dot-bus{background:#94a3b8}.timing-waveform-viewport{min-width:0;overflow-x:auto;overflow-y:hidden;background:var(--bg-waveform)}.timing-cycle-hitbox{cursor:pointer}.timing-simulator-grid{display:grid;grid-template-columns:minmax(260px,.8fr) minmax(320px,1.2fr);gap:14px;padding:16px 20px 0}.timing-state-card,.timing-console-card{border:1px solid var(--border);border-radius:8px;background:var(--surface-2);overflow:hidden}.timing-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 12px;border-bottom:1px solid var(--border)}.timing-card-header h2{margin:0}.timing-card-header span:not(.timing-step-status){color:var(--text-muted);font-size:11px;font-weight:800}.timing-state-flow{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:18px 16px 12px}.timing-state-flow span{display:grid;min-height:48px;place-items:center;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-family:Cascadia Mono,Consolas,monospace;font-size:20px;font-weight:800}.timing-state-flow strong{display:grid;min-width:34px;min-height:34px;place-items:center;border-radius:999px;background:var(--accent);color:#fff;font-size:12px}.timing-current-values{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:0;padding:0 16px 16px}.timing-current-values div{border:1px solid var(--border);border-radius:7px;background:var(--surface);padding:9px}.timing-current-values dt{color:var(--text-muted);font-size:10px;font-weight:800;text-transform:uppercase}.timing-current-values dd{margin:4px 0 0;color:var(--text);font-family:Cascadia Mono,Consolas,monospace;font-size:14px;font-weight:800}.timing-console{min-height:132px;max-height:240px;margin:12px;overflow:auto;border:1px solid #26344d;border-radius:6px;background:#0f172a;color:#e5edf6;padding:10px;font-family:Cascadia Mono,Consolas,monospace;font-size:11.5px;line-height:1.55;white-space:pre-wrap}.timing-console-line.pass{color:#86efac}.timing-console-line.fail{color:#fca5a5}.timing-console-line.active{display:inline-block;width:100%;background:#2563eb2e}.timing-trace{padding:0 20px}.timing-trace h2{margin-top:16px}.timing-trace table{margin-top:8px}.interactive-timing-table tbody tr{cursor:pointer}.interactive-timing-table tbody tr.active-cycle-row td{background:var(--accent-soft)}.timing-result-cell{font-weight:800}.timing-result-cell.pass{color:var(--ok-text)}.timing-result-cell.fail{color:var(--err-text)}.state-diagram-panel{display:flex;flex-direction:column;overflow:hidden}.state-diagram-panel h2{flex:0 0 auto;margin:0;padding:14px 16px;border-bottom:1px solid var(--border)}.state-diagram-scroll{flex:1 1 auto;display:grid;place-items:center;overflow:auto;min-height:360px;background:var(--paper)}.state-diagram-svg{display:block;max-width:none;background:#fff}.state-node{fill:#fff;stroke:#dc2626;stroke-width:4px}.state-node-text{fill:#111827;font-family:Times New Roman,Georgia,serif;font-size:22px;font-weight:700}.state-node-text-single{font-size:24px}.state-node-divider{stroke:#111827;stroke-linecap:round;stroke-width:2px}.state-edge{fill:none;stroke:#111827;stroke-linecap:round;stroke-width:2.25px}.state-initial-arrow{fill:none;stroke:#2563eb;stroke-linecap:round;stroke-width:2.5px}.state-initial-marker{fill:#2563eb}.state-initial-label{fill:#2563eb;font-family:Times New Roman,Georgia,serif;font-size:13px;font-style:italic;font-weight:700}.state-edge-marker{fill:#111827}.state-edge-label-bg{fill:#ffffffdb;stroke:#cbd5e1cc;stroke-width:1px}.state-edge-label{fill:#111827;font-family:Times New Roman,Georgia,serif;font-size:18px;font-weight:700}.sim-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.sim-button{display:inline-flex;align-items:center;gap:6px;min-height:30px;border:1px solid var(--border);border-radius:7px;background:var(--surface);color:var(--text-soft);cursor:pointer;font-size:12px;font-weight:600;padding:0 11px;transition:border-color .15s ease,color .15s ease,background .15s ease}.sim-button:hover:not(:disabled){border-color:var(--accent-border);color:var(--accent)}.sim-button:disabled{opacity:.45;cursor:not-allowed}.sim-button.sim-primary{background:var(--accent);border-color:var(--accent);color:#fff}.sim-button.sim-primary:hover:not(:disabled){color:#fff;filter:brightness(1.07)}.sim-toggle{min-height:30px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:700;padding:0 13px;transition:all .15s ease}.sim-toggle.on{border-color:var(--accent);background:var(--accent);color:#fff}.sim-divider{width:1px;height:20px;background:var(--border)}.sim-readout{color:var(--text-muted);font-size:12px}.sim-readout strong{margin-left:3px;color:var(--accent);font-family:Cascadia Mono,SFMono-Regular,Consolas,monospace;font-size:13px}.sim-alert{margin:12px 16px 0}.sim-history{display:flex;align-items:center;flex-wrap:wrap;gap:5px;padding:10px 16px;border-bottom:1px solid var(--border)}.sim-chip{border:1px solid var(--border);border-radius:5px;background:var(--surface-2);color:var(--text-muted);padding:2px 8px;font-family:Cascadia Mono,SFMono-Regular,Consolas,monospace;font-size:11px;position:relative}.sim-chip:not(:last-child):after{content:"→";position:absolute;right:-10px;color:var(--text-faint)}.sim-chip.current{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:700;animation:chip-in .25s ease}@keyframes chip-in{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.state-node-active{stroke:#2563eb;animation:node-pulse 1.4s ease-in-out infinite}@keyframes node-pulse{0%,to{stroke-width:4px}50%{stroke-width:6.5px}}.state-edge-active{stroke:#2563eb;stroke-width:3.25px}.state-active-marker{fill:#2563eb}.state-edge{transition:stroke .2s ease,stroke-width .2s ease}@media (prefers-reduced-motion: reduce){.tab-panel.active,.sim-chip.current,.state-node-active{animation:none}body,.sim-button,.sim-toggle,.state-edge{transition:none}}.state-diagram-placeholder{display:grid;height:100%;min-height:360px;place-items:center;padding:18px;color:var(--text-muted);font-size:14px;text-align:center}.validation-stack{display:grid;gap:0}.lint-panel{padding:18px 20px 20px}.lint-clear{display:flex;align-items:center;gap:9px;border:1px solid var(--ok-border);border-radius:8px;background:var(--ok-bg);color:var(--ok-text);padding:12px 14px;font-size:13px;font-weight:600}.lint-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}.lint-item{display:flex;align-items:flex-start;gap:10px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);padding:11px 13px}.lint-item svg{flex:0 0 auto;margin-top:2px}.lint-item.error{border-color:var(--err-border);background:var(--err-bg);color:var(--err-text)}.lint-item.warning{border-color:var(--warn-border);background:var(--warn-bg);color:var(--warn-text)}.lint-item.info{color:var(--text-soft)}.lint-code{display:block;font-size:10px;font-weight:800;letter-spacing:.04em;opacity:.8}.lint-item p{margin:3px 0 0;font-size:12px;line-height:1.5}.verification-panel{padding:18px 20px 20px}.verification-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.verification-header h2{margin:0}.verification-badge{border:1px solid var(--border);border-radius:5px;padding:5px 9px;font-size:11px;font-weight:800}.verification-badge.pass{border-color:var(--ok-border);background:var(--ok-bg);color:var(--ok-text)}.verification-badge.fail{border-color:var(--err-border);background:var(--err-bg);color:var(--err-text)}.verification-badge.warning{border-color:var(--warn-border);background:var(--warn-bg);color:var(--warn-text)}.verification-checks{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:10px}.verification-check{border:1px solid var(--border);border-radius:8px;padding:10px;background:var(--surface-2)}.verification-check strong{display:block;color:var(--text);font-size:12px}.verification-check span{display:inline-block;margin-top:6px;font-size:10px;font-weight:800}.verification-check p{margin:7px 0 0;color:var(--text-muted);font-size:11px;line-height:1.45}.verification-check.pass span{color:var(--ok-text)}.verification-check.fail span{color:var(--err-text)}.verification-check.skipped span{color:var(--warn-text)}.verification-section{margin-top:16px}.verification-section h3{margin:0 0 8px;color:var(--text);font-size:12px;font-weight:800}.verification-list{margin:0;padding-left:18px;color:var(--text-muted);font-size:12px;line-height:1.55}.verification-message-cell{max-width:340px;text-align:left;white-space:normal}.code-generator-panel{display:flex;min-height:420px;flex-direction:column;overflow:hidden}.code-generator-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.code-generator-header h2{margin:0}.code-status{border:1px solid var(--border);border-radius:5px;padding:5px 8px;font-size:10px;font-weight:800}.code-status.pass{border-color:var(--ok-border);background:var(--ok-bg);color:var(--ok-text)}.code-status.fail{border-color:var(--err-border);background:var(--err-bg);color:var(--err-text)}.code-status.pending{border-color:var(--warn-border);background:var(--warn-bg);color:var(--warn-text)}.code-generator-message{display:grid;flex:1;place-items:center;padding:18px;color:var(--text-muted);font-size:14px;text-align:center}.code-generator-alert{margin:12px 16px 0}.code-generator-alert-action{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.code-generator-alert-action button{display:inline-flex;align-items:center;gap:6px;min-height:30px;border:1px solid var(--accent);border-radius:6px;background:var(--accent);color:#fff;cursor:pointer;font-size:12px;font-weight:700;padding:0 12px;white-space:nowrap}.code-generator-alert-action button:hover{filter:brightness(1.07)}.code-generator-interactive{display:flex;min-height:0;flex:1 1 auto;flex-direction:column}.code-tabs{display:flex;flex:0 0 auto;gap:6px;padding:12px 16px 8px;overflow-x:auto}.code-tabs button,.code-actions button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:30px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-soft);cursor:pointer;font-size:11px;font-weight:600;white-space:nowrap}.code-tabs button{padding:6px 9px}.code-tabs button.active{border-color:var(--accent-border);background:var(--accent-soft);color:var(--accent)}.code-actions{display:flex;flex-wrap:wrap;gap:8px;padding:10px 16px 14px;border-top:1px solid var(--border)}.code-actions button{padding:6px 9px}.code-actions button:disabled,.code-tabs button:disabled{color:var(--text-faint);cursor:not-allowed;opacity:.55}.code-block{flex:1 1 auto;min-height:240px;margin:0 16px 10px;overflow:auto;border:1px solid var(--border);border-radius:6px;background:#0f172a;color:#e5edf6;padding:12px;font-family:Cascadia Mono,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:11.5px;line-height:1.55;white-space:pre}.code-block code{font-family:inherit}.code-generator-testbench-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.88fr);gap:12px;margin:0 16px 10px;min-height:360px}.code-block-embedded{margin:0;min-height:360px}.simulation-panel{display:flex;min-width:0;min-height:360px;flex-direction:column;overflow:hidden;border:1px solid var(--border);border-radius:6px;background:var(--surface-2)}.simulation-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 12px;border-bottom:1px solid var(--border)}.simulation-header h3{margin:0;color:var(--text);font-size:12px;font-weight:800}.simulation-status{border:1px solid var(--border);border-radius:5px;padding:4px 7px;font-size:10px;font-weight:800}.simulation-status.pass{border-color:var(--ok-border);background:var(--ok-bg);color:var(--ok-text)}.simulation-status.fail{border-color:var(--err-border);background:var(--err-bg);color:var(--err-text)}.simulation-status.idle{color:var(--text-muted)}.simulation-actions{padding:10px 12px 0}.simulation-actions button{display:inline-flex;align-items:center;gap:7px;min-height:30px;border:1px solid var(--accent);border-radius:6px;background:var(--accent);color:#fff;cursor:pointer;font-size:11px;font-weight:700;padding:0 11px;white-space:nowrap}.simulation-actions button:hover{filter:brightness(1.07)}.simulation-actions button:disabled{cursor:not-allowed;filter:none;opacity:.6}.simulation-error{margin:10px 12px 0}.simulation-console{min-height:114px;max-height:190px;margin:10px 12px 12px;overflow:auto;border:1px solid #26344d;border-radius:6px;background:#0f172a;color:#e5edf6;padding:10px;font-family:Cascadia Mono,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:11.5px;line-height:1.55;white-space:pre-wrap}.simulation-console-line.pass{color:#86efac}.simulation-console-line.fail{color:#fca5a5}.simulation-console-line.muted{color:#8da2bd}.simulation-table-wrap{margin:0 12px 12px;overflow:auto}.simulation-table{min-width:680px}.simulation-table th,.simulation-table td{padding:7px}.simulation-result-cell{font-weight:800}.simulation-result-cell.pass{color:var(--ok-text)}.simulation-result-cell.fail{color:var(--err-text)}.tok-keyword{color:#7dd3fc;font-weight:600}.tok-number{color:#fbbf24}.tok-comment{color:#8da2bd;font-style:italic}.tok-system{color:#c4b5fd}.code-generator-pdf-content{display:none}.code-pdf-status,.code-pdf-verification{margin:0 16px 12px;color:var(--text-soft);font-size:12px}.code-pdf-verification{padding-left:18px;line-height:1.5}.diagram-placeholder{display:grid;min-height:240px;place-items:center;color:var(--text-muted);font-size:14px;text-align:center;padding:14px}.export-button{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text-soft);padding:7px 11px;cursor:pointer;font-size:12px;font-weight:600;white-space:nowrap}.export-button:hover{border-color:var(--accent-border);color:var(--accent)}.export-controls{display:inline-flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}.export-option{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:11px;font-weight:600;white-space:nowrap}.export-option input{accent-color:var(--accent)}@media (max-width: 1180px){.workspace-grid,.excitation-layout,.timing-simulator-grid,.code-generator-testbench-layout{grid-template-columns:1fr}}@media (max-width: 760px){.app-shell{padding:12px}.app-header{padding:13px 14px}.field-row{grid-template-columns:1fr}.simulation-speed{width:100%;margin-left:0}.simulation-speed input{flex:1}.timing-current-values{grid-template-columns:repeat(2,minmax(0,1fr))}.kmap-grid{grid-template-columns:minmax(0,1fr);gap:16px}.kmap-card-header{grid-template-columns:1fr;gap:10px;padding:12px}.kmap-table-scroll,.kmap-legend-block{padding-inline:12px}.result-tabs{gap:4px;padding:6px}.result-tabs button{font-size:11.5px;padding:0 9px}}.pdf-export-root{background:#f8fafc}.pdf-export-root .tab-panel{display:block!important}.pdf-export-root .result-tabs,.pdf-export-root .sidebar-actions,.pdf-export-root .icon-button{display:none!important}.pdf-export-root .code-generator-panel{max-height:none;overflow:visible}.pdf-export-root .code-generator-interactive,.pdf-export-root .code-actions{display:none}.pdf-export-root .code-generator-pdf-content{display:block}.pdf-export-root .code-generator-pdf-content h3{margin:14px 16px 8px;color:var(--text);font-size:12px;font-weight:800}.pdf-export-root .code-block{max-height:none;white-space:pre-wrap}
