@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-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--ease-out:cubic-bezier(0, 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)}}@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 components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.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,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.lowercase{text-transform:lowercase}.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,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-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root{--bg-primary:#f0f0f0;--bg-secondary:#f7f7f7;--bg-tertiary:#fff;--bg-hover:#e8e8e8;--bg-canvas:#faf9f6;--border:#d0d0d0;--border-light:#bbb;--text-primary:#1a1a1a;--text-secondary:#555;--text-muted:#888;--accent:#2563eb;--accent-dim:#1d4ed8;--accent-text:#fff;--header-bg:#1e293b;--header-text:#e2e8f0;--header-muted:#94a3b8;--header-border:#334155;--font-mono:"IBM Plex Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-mono);background:var(--bg-primary);color:var(--text-primary);height:100vh;overflow:hidden}#root{flex-direction:column;height:100vh;display:flex}.app-layout{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{background:var(--header-bg);border-bottom:1px solid var(--header-border);justify-content:space-between;align-items:center;height:40px;min-height:40px;padding:0 12px;display:flex}.header-left{align-items:center;gap:8px;display:flex}.header-logo{flex-shrink:0;width:26px;height:26px}.header-brand{flex-direction:column;gap:0;line-height:1;display:flex}.app-title{letter-spacing:4px;color:var(--header-text);font-size:13px;font-weight:700;line-height:1}.app-subtitle{letter-spacing:1.5px;color:var(--header-muted);margin-top:1px;font-size:6px;font-weight:400;line-height:1}.app-version{color:var(--header-muted);border:1px solid var(--header-border);border-radius:2px;padding:1px 4px;font-size:8px}.header-center{scrollbar-width:thin;scrollbar-color:var(--header-border) transparent;flex:1;justify-content:flex-start;min-width:0;display:flex;overflow:auto visible}.header-center::-webkit-scrollbar{height:3px}.header-center::-webkit-scrollbar-track{background:0 0}.header-center::-webkit-scrollbar-thumb{background:var(--header-border);border-radius:2px}.header-right{align-items:center;gap:4px;display:flex}.header-diagram-info{align-items:center;gap:6px;margin-right:8px;display:flex}.header-diagram-name{font-family:var(--font-mono);color:var(--header-text,#e2e8f0);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;border:1px solid #0000;border-radius:3px;max-width:200px;padding:2px 8px;font-size:10px;font-weight:600;transition:border-color .15s,background .15s;overflow:hidden}.header-diagram-name:hover{background:#ffffff0d;border-color:#fff3}.header-name-input{font-family:var(--font-mono);color:#fff;background:#ffffff1a;border:1px solid #2563eb;border-radius:3px;outline:none;width:180px;padding:2px 8px;font-size:10px;font-weight:600}.panel-toggle{font-family:var(--font-mono);letter-spacing:1px;background:var(--header-border);color:var(--header-muted);border:1px solid var(--header-border);cursor:pointer;padding:4px 8px;font-size:9px;font-weight:500;transition:all .15s}.panel-toggle:hover{color:var(--header-text);background:#475569}.panel-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent)}.app-body{flex:1;display:flex;overflow:hidden}.canvas-area{background:var(--bg-canvas);flex:1;position:relative;overflow:hidden}.app-footer{height:24px;min-height:24px;color:var(--header-muted);background:var(--header-bg);border-top:1px solid var(--header-border);letter-spacing:.5px;justify-content:space-between;align-items:center;padding:0 12px;font-size:8px;display:flex}.footer-copyright{letter-spacing:.3px;color:#64748b;font-size:7px}.footer-right{align-items:center;gap:8px;display:flex}.footer-build{color:#64748b;font-family:IBM Plex Mono,monospace;font-size:7px}.footer-refresh-btn{letter-spacing:.5px;color:#f59e0b;cursor:pointer;background:0 0;border:1px solid #f59e0b44;border-radius:2px;padding:0 4px;font-family:IBM Plex Mono,monospace;font-size:7px;font-weight:600;line-height:14px;transition:all .15s}.footer-refresh-btn:hover{color:#fbbf24;background:#f59e0b22;border-color:#f59e0b}.toolbar{white-space:nowrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.toolbar-group{align-items:center;gap:3px;display:flex}.toolbar-group button{font-family:var(--font-mono);background:var(--header-border);color:var(--header-muted);border:1px solid var(--header-border);cursor:pointer;justify-content:center;align-items:center;min-width:28px;height:24px;padding:3px 6px;font-size:9px;font-weight:500;transition:all .15s;display:flex}.toolbar-group button:hover{color:var(--header-text);background:#475569}.toolbar-group button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.toolbar-label{color:var(--header-muted);text-align:center;min-width:36px;padding:0 4px;font-size:9px}.toolbar-divider{background:var(--header-border);width:1px;height:16px;margin:0 4px}.toolbar-spacer{flex:1}.toolbar-hint{color:var(--header-muted);letter-spacing:.3px;font-size:8px}.wire-type-select{font-family:var(--font-mono);background:var(--header-border);color:var(--header-text);border:1px solid var(--header-border);cursor:pointer;height:24px;padding:2px 4px;font-size:9px}.wire-color-indicator{border-radius:1px;width:16px;height:3px}.component-library{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;width:240px;min-width:240px;display:flex;overflow:hidden}.panel-header{letter-spacing:2px;color:var(--text-secondary);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 12px;font-size:9px;font-weight:600;display:flex}.search-box{border-bottom:1px solid var(--border);padding:6px 8px}.search-box input{width:100%;font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;padding:4px 8px;font-size:9px}.search-box input:focus{border-color:var(--accent)}.search-box input::placeholder{color:var(--text-muted)}.category-list{flex:1;overflow-y:auto}.category-section{border-bottom:1px solid var(--border)}.category-header{width:100%;font-family:var(--font-mono);letter-spacing:1px;color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;border-left:3px solid;align-items:center;gap:6px;padding:6px 8px;font-size:9px;font-weight:600;transition:background .15s;display:flex}.category-header:hover{background:var(--bg-hover)}.category-icon{text-align:center;width:16px;font-size:12px}.category-name{flex:1}.category-count{color:var(--text-muted);font-size:8px;font-weight:400}.category-arrow{color:var(--text-muted);font-size:10px;transition:transform .15s}.category-arrow.open{transform:rotate(90deg)}.device-list{padding:2px 0}.device-item{width:100%;font-family:var(--font-mono);color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;flex-wrap:wrap;align-items:baseline;gap:4px;padding:5px 12px 5px 20px;font-size:9px;transition:background .1s;display:flex}.device-item:hover{background:var(--bg-hover)}.device-name{font-size:9px;font-weight:500}.device-subtitle{color:var(--text-muted);font-size:7px}.device-ports{color:var(--text-muted);margin-left:auto;font-size:7px}.add-device-btn{font-family:var(--font-mono);letter-spacing:.5px;color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;padding:2px 8px;font-size:8px;font-weight:600;transition:all .15s}.add-device-btn:hover{background:var(--accent);color:#fff}.device-item-row{align-items:stretch;display:flex}.device-item-row .device-item{flex:1;min-width:0}.fav-btn{color:var(--text-muted);cursor:pointer;opacity:.3;background:0 0;border:none;align-items:center;padding:0 6px;font-size:10px;transition:all .15s;display:flex}.device-item-row:hover .fav-btn{opacity:.7}.fav-btn:hover,.fav-btn-active{color:#d97706;opacity:1!important}.properties-panel{background:var(--bg-secondary);border-left:1px solid var(--border);flex-direction:column;width:260px;min-width:260px;display:flex;overflow-y:auto}.prop-type-badge{letter-spacing:1px;color:var(--accent);border:1px solid var(--accent);border-radius:2px;padding:1px 4px;font-size:7px;font-weight:600}.empty-state{text-align:center;padding:20px 12px}.empty-state p{color:var(--text-muted);font-size:9px;line-height:1.5}.prop-content{flex:1;padding:8px;overflow-y:auto}.prop-group{margin-bottom:10px}.prop-group label{letter-spacing:1px;color:var(--text-secondary);text-transform:uppercase;margin-bottom:3px;font-size:8px;font-weight:600;display:block}.prop-group input[type=text],.prop-group input[type=number],.prop-group textarea,.prop-group select{width:100%;font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;padding:4px 6px;font-size:9px}.prop-group input:focus,.prop-group textarea:focus,.prop-group select:focus{border-color:var(--accent)}.prop-group input[type=color]{background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;width:100%;height:28px;padding:2px}.prop-row{align-items:center;gap:4px;display:flex}.prop-row input[type=number]{width:70px}.prop-mini-label{color:var(--text-muted);width:12px;font-size:8px}.wire-type-row{align-items:center;gap:6px;display:flex}.wire-color-swatch{border:1px solid var(--border);border-radius:2px;flex-shrink:0;width:12px;height:12px}.wire-type-row select{flex:1}.wire-color-row{align-items:center;gap:6px;display:flex}.wire-color-picker{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:3px;flex-shrink:0;width:28px;height:22px;padding:0}.wire-color-picker::-webkit-color-swatch-wrapper{padding:1px}.wire-color-picker::-webkit-color-swatch{border:none;border-radius:2px}.wire-color-hex{color:var(--text-muted);min-width:56px;font-family:IBM Plex Mono,monospace;font-size:9px}.wire-color-reset{color:#2563eb;cursor:pointer;letter-spacing:.04em;background:#eff6ff;border:1px solid #bfdbfe;border-radius:3px;padding:2px 6px;font-family:IBM Plex Mono,monospace;font-size:8px;font-weight:600;transition:background .15s}.wire-color-reset:hover{background:#dbeafe}.wire-flip-btn{color:#1a1a1a;cursor:pointer;letter-spacing:.04em;background:#f5f5f0;border:1px solid #d4d4d0;border-radius:3px;width:100%;padding:5px 10px;font-family:IBM Plex Mono,monospace;font-size:9px;font-weight:600;transition:background .15s}.wire-flip-btn:hover{background:#e8e8e0}.wire-color-note{color:var(--text-muted);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:8px;display:block}.prop-value-text{color:var(--text-primary);font-size:9px}.prop-source-list{flex-wrap:wrap;gap:4px;display:flex}.prop-source-badge{color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border);border-radius:2px;padding:1px 6px;font-size:8px}.device-profile-section{border:1px solid var(--border);background:var(--bg-tertiary);border-radius:3px;padding:8px}.device-profile-image{border:1px solid var(--border);background:var(--bg-primary);border-radius:2px;width:100%;margin-bottom:6px;overflow:hidden}.device-profile-image img{object-fit:contain;width:100%;height:auto;max-height:140px;display:block}.device-profile-image.edit-mode img{max-height:100px}.device-profile-row{align-items:baseline;gap:6px;margin-bottom:3px;display:flex}.device-profile-key{font-family:var(--font-mono);letter-spacing:.5px;color:var(--text-muted);flex-shrink:0;width:50px;font-size:7px;font-weight:600}.device-profile-value{font-family:var(--font-mono);color:var(--text-primary);word-break:break-all;font-size:8px}.device-profile-desc{font-family:var(--font-mono);color:var(--text-secondary);max-height:60px;margin-bottom:4px;font-size:8px;line-height:1.4;overflow-y:auto}.device-profile-datasheet{font-family:var(--font-mono);letter-spacing:.5px;color:var(--accent);border:1px solid var(--accent);border-radius:2px;padding:2px 6px;font-size:7px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-block}.device-profile-datasheet:hover{background:var(--accent);color:#fff}.prop-source-link{cursor:pointer;text-decoration:none;transition:all .15s}.prop-source-link:hover{background:var(--bg-hover);border-color:var(--accent)}.source-link{cursor:pointer;text-decoration:none;transition:background .15s}.source-link:hover{background:var(--bg-hover)}.source-price{font-family:var(--font-mono);color:#059669;margin-left:4px;font-size:7px;font-weight:600}.source-date{font-family:var(--font-mono);color:var(--text-muted);margin-left:auto;font-size:6px}.diagram-canvas{cursor:crosshair}.diagram-canvas.drag-over{outline-offset:-2px;background:#2563eb05;outline:2px dashed #2563eb}.rubber-band{background:#2563eb14;border:1px solid #2563eb;border-radius:1px}.diagram-canvas .joint-paper{border:none}.diagram-device-item[draggable=true]{cursor:grab}.diagram-device-item[draggable=true]:active{cursor:grabbing}.instance-nav-header{border-top:1px solid #334155;align-items:center;gap:4px;margin-top:4px;display:flex;padding-top:6px!important}.instance-nav-header:hover{color:#e2e8f0}.instance-nav-row{cursor:pointer;color:#94a3b8;align-items:center;gap:6px;padding:4px 8px;font-size:10px;transition:background .15s,color .15s;display:flex}.instance-nav-row:hover{color:#e2e8f0;background:#ffffff0a}.instance-nav-row.active{color:#60a5fa;background:#2563eb1f}.instance-nav-icon{text-align:center;flex-shrink:0;width:16px;font-size:11px}.instance-nav-name{white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:IBM Plex Mono,monospace;overflow:hidden}.instance-nav-order{color:#475569;flex-shrink:0;font-size:8px;font-weight:600}.instance-nav-locate{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:1px solid #0000;border-radius:3px;flex-shrink:0;margin-left:auto;padding:1px 4px;font-size:11px;transition:opacity .15s,color .15s,background .15s,border-color .15s}.instance-nav-row:hover .instance-nav-locate{opacity:1}.instance-nav-locate:hover{color:var(--accent);border-color:var(--accent);background:#2563eb14}.diagram-device-locate{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:1px solid #0000;border-radius:3px;flex-shrink:0;padding:2px 5px;font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600;transition:opacity .15s,color .15s,border-color .15s,background .15s}.diagram-device-item:hover .diagram-device-locate{opacity:1}.diagram-device-locate:hover{color:var(--accent);border-color:var(--accent);background:#2563eb14}.joint-port-body:hover{r:6;stroke-width:2px}.startup-overlay{z-index:500;background:var(--bg-primary);justify-content:center;align-items:center;display:flex;position:fixed;inset:44px 0 28px}.startup-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;flex-direction:column;align-items:center;gap:16px;padding:48px 64px;display:flex;box-shadow:0 4px 24px #00000014}.startup-logo{opacity:.9;width:80px;height:80px}.startup-title{letter-spacing:3px;color:var(--text-primary);margin:0;font-family:IBM Plex Mono,monospace;font-size:20px;font-weight:700}.startup-subtitle{letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;margin:0 0 8px;font-family:IBM Plex Mono,monospace;font-size:10px}.startup-actions{gap:16px;margin-top:8px;display:flex}.startup-action-btn{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:center;gap:12px;min-width:200px;padding:16px 24px;transition:all .15s;display:flex}.startup-action-btn:hover{background:var(--bg-hover);border-color:var(--border-light);box-shadow:0 2px 8px #0000000f}.startup-action-icon{color:var(--text-primary);background:var(--bg-primary);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:22px;font-weight:600;display:flex}.startup-action-title{letter-spacing:1px;color:var(--text-primary);font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600;display:block}.startup-action-desc{color:var(--text-muted);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:9px;display:block}.startup-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;margin-top:4px;padding:6px 12px;font-family:IBM Plex Mono,monospace;font-size:10px}.startup-hash-msg{color:#d97706;text-align:center;background:#fffbeb;border:1px solid #fde68a;border-radius:4px;margin-bottom:12px;padding:6px 12px;font-family:IBM Plex Mono,monospace;font-size:10px}.startup-name-section{width:100%;margin-top:8px}.startup-name-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-family:IBM Plex Mono,monospace;font-size:9px;font-weight:600;display:block}.startup-name-row{gap:6px;width:100%;display:flex}.startup-name-input{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);border-radius:4px;outline:none;flex:1;padding:8px 12px;font-family:IBM Plex Mono,monospace;font-size:12px;transition:border-color .15s}.startup-name-input:focus{border-color:#2563eb}.startup-name-input::placeholder{color:var(--text-muted)}.startup-name-submit{color:#fff;cursor:pointer;letter-spacing:.05em;white-space:nowrap;background:#2563eb;border:none;border-radius:4px;padding:8px 16px;font-family:IBM Plex Mono,monospace;font-size:10px;font-weight:600;transition:background .15s}.startup-name-submit:hover:not(:disabled){background:#1d4ed8}.startup-name-submit:disabled{opacity:.4;cursor:not-allowed}.startup-name-cancel{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-top:6px;padding:4px;font-family:IBM Plex Mono,monospace;font-size:9px}.startup-name-cancel:hover{color:var(--text-primary)}.recent-diagrams{border-top:1px solid var(--border);width:100%;margin-top:16px;padding-top:12px}.recent-diagrams-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-family:IBM Plex Mono,monospace;font-size:9px;font-weight:600}.recent-item{border:1px solid var(--border);cursor:pointer;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px 10px;transition:background .15s,border-color .15s;display:flex}.recent-item:hover{background:var(--bg-secondary);border-color:#2563eb}.recent-item.pending{background:#fffbeb;border-color:#d97706}.recent-item-info{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.recent-item-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:500;overflow:hidden}.recent-item-id{color:#2563eb;white-space:nowrap;background:#eff6ff;border:1px solid #bfdbfe;border-radius:3px;flex-shrink:0;padding:1px 5px;font-family:IBM Plex Mono,monospace;font-size:9px}.recent-item-meta{flex-shrink:0;align-items:center;gap:8px;display:flex}.recent-item-time,.recent-item-cells{color:var(--text-muted);font-family:IBM Plex Mono,monospace;font-size:9px}.recent-item-delete{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:14px;line-height:1;transition:color .15s,background .15s}.recent-item-delete:hover{color:#dc2626;background:#fef2f2}.recent-empty{color:var(--text-muted);text-align:center;padding:12px;font-family:IBM Plex Mono,monospace;font-size:9px}.header-diagram-id{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe;border-radius:3px;padding:2px 6px;font-family:IBM Plex Mono,monospace;font-size:9px}.modal-diagram-id{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe;border-radius:3px;margin-left:8px;padding:2px 6px;font-family:IBM Plex Mono,monospace;font-size:9px}.modal-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:12px;display:flex}.modal-tab{letter-spacing:1px;color:var(--text-muted);cursor:pointer;text-align:center;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 12px;font-family:IBM Plex Mono,monospace;font-size:10px;font-weight:600;transition:all .15s}.modal-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-tab.active{color:var(--text-primary);border-bottom-color:#059669}.search-group-header{letter-spacing:2px;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:4px;padding:8px 8px 4px;font-family:IBM Plex Mono,monospace;font-size:8px;font-weight:700}.empty-panel-message{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px 16px;display:flex}.empty-panel-message span{color:var(--text-muted);letter-spacing:.5px;font-family:IBM Plex Mono,monospace;font-size:9px}.empty-panel-message .empty-icon{opacity:.3;margin-bottom:4px;font-size:28px}.get-devices-btn{letter-spacing:1px;color:#fff;cursor:pointer;background:#059669;border:none;border-radius:4px;justify-content:center;align-items:center;gap:6px;width:100%;margin-bottom:8px;padding:10px;font-family:IBM Plex Mono,monospace;font-size:10px;font-weight:700;transition:background .15s;display:flex}.diagram-device-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:8px;padding:6px 8px;transition:background .1s;display:flex}.diagram-device-item:hover{background:var(--bg-hover)}.diagram-device-icon{flex-shrink:0;font-size:14px}.diagram-device-info{flex:1;min-width:0}.diagram-device-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-family:IBM Plex Mono,monospace;font-size:9px;font-weight:600;display:block;overflow:hidden}.diagram-device-sub{color:var(--text-muted);font-family:IBM Plex Mono,monospace;font-size:8px;display:block}.diagram-device-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.diagram-device-count{color:var(--text-muted);background:var(--bg-primary);border-radius:3px;flex-shrink:0;padding:2px 6px;font-family:IBM Plex Mono,monospace;font-size:8px}.diagram-device-remove,.diagram-device-remove-one{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:1px solid #0000;border-radius:3px;padding:1px 4px;font-family:IBM Plex Mono,monospace;font-size:9px;font-weight:600;transition:opacity .15s,color .15s,border-color .15s}.diagram-device-item:hover .diagram-device-remove,.diagram-device-item:hover .diagram-device-remove-one{opacity:1}.diagram-device-remove:hover{color:#dc2626;background:#fef2f2;border-color:#dc2626}.diagram-device-remove-one:hover{color:#d97706;background:#fffbeb;border-color:#d97706}.prop-device-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:4px;padding:4px 0 8px;display:flex}.prop-category-badge{font-family:var(--font-mono);color:var(--text-secondary);border:1px solid var(--border);letter-spacing:.5px;border-radius:3px;padding:2px 6px;font-size:8px;font-weight:600}.prop-count-badge{font-family:var(--font-mono);color:var(--text-muted);font-size:8px}.prop-ports-summary{flex-wrap:wrap;gap:3px;margin-top:2px;display:flex}.prop-port-chip{font-family:var(--font-mono);color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border);border-left:2px solid var(--border);white-space:nowrap;border-radius:2px;padding:1px 4px;font-size:7px;font-weight:500}.prop-edit-ports-btn{font-family:var(--font-mono);letter-spacing:.5px;color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:2px;margin-left:auto;padding:1px 5px;font-size:7px;font-weight:600;transition:background .1s}.prop-edit-ports-btn:hover{background:#2563eb14}.prop-edit-ports-apply{color:#059669;border-color:#059669}.prop-edit-ports-apply:hover{background:#05966914}.prop-port-actions{gap:4px;margin-left:auto;display:flex}.prop-category-select{font-family:var(--font-mono);letter-spacing:.5px;cursor:pointer;background:0 0;border:1px solid;border-radius:3px;outline:none;padding:2px 4px;font-size:8px;font-weight:600}.prop-category-select:focus{box-shadow:0 0 0 1px #2563eb4d}.prop-group>label{align-items:center;gap:4px;display:flex}.prop-danger-zone{border-top:1px dashed var(--border);margin-top:12px;padding-top:8px}.prop-presentation-order{text-align:center;width:60px}.prop-presentation-clear{font-family:var(--font-mono);color:#6b7280;cursor:pointer;letter-spacing:.5px;background:0 0;border:1px solid #d1d5db;border-radius:3px;padding:2px 6px;font-size:8px;font-weight:600}.prop-presentation-clear:hover{color:#374151;background:#f3f4f6;border-color:#9ca3af}.prop-remove-btn{width:100%;font-family:var(--font-mono);color:#dc2626;cursor:pointer;letter-spacing:.5px;background:0 0;border:1px solid #fca5a5;border-radius:4px;padding:6px;font-size:9px;font-weight:600;transition:background .15s,border-color .15s;display:block}.prop-remove-btn:hover{background:#fef2f2;border-color:#dc2626}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.title-block-editor{border-bottom:1px solid var(--border)}.title-block-editor .prop-content{padding:6px 8px}.title-block-editor .prop-group{margin-bottom:6px}.legend-block{border-bottom:1px solid var(--border);padding:8px}.legend-header{letter-spacing:2px;color:var(--text-secondary);margin-bottom:6px;font-size:8px;font-weight:600}.legend-items{flex-direction:column;gap:3px;display:flex}.legend-item{color:var(--text-primary);align-items:center;gap:6px;font-size:8px;display:flex}.legend-swatch{border-radius:1px;flex-shrink:0;width:24px;height:3px}.notes-block{border-bottom:1px solid var(--border)}.notes-count{color:var(--text-muted);font-size:8px;font-weight:400}.notes-list{padding:0 8px}.note-item{align-items:center;gap:4px;margin-bottom:3px;display:flex}.note-number{color:var(--text-muted);flex-shrink:0;width:16px;font-size:8px}.note-input{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid #0000;outline:none;flex:1;padding:2px 4px;font-size:8px}.note-input:focus{border-color:var(--accent)}.note-remove{font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:12px;line-height:1}.note-remove:hover{color:#dc2626}.note-add{gap:4px;padding:4px 8px 8px;display:flex}.note-add input{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;flex:1;padding:3px 6px;font-size:8px}.note-add input::placeholder{color:var(--text-muted)}.note-add input:focus{border-color:var(--accent)}.note-add button{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;padding:2px 8px;font-size:12px}.note-add button:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.note-add button:disabled{opacity:.4;cursor:default}.modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;width:380px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #00000026}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.modal-header h2{letter-spacing:2px;color:var(--text-primary);font-size:10px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:18px;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:14px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:6px;padding:10px 14px;display:flex}.modal-btn{font-family:var(--font-mono);letter-spacing:.5px;border:1px solid var(--border);cursor:pointer;padding:6px 14px;font-size:9px;font-weight:500;transition:all .15s}.modal-btn.secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.modal-btn.secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-btn.primary:hover{background:var(--accent-dim)}.modal-btn:disabled{opacity:.5;cursor:default}.export-format-row{gap:4px;display:flex}.export-format-btn{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;text-align:center;flex:1;padding:6px 14px;font-size:9px;font-weight:500;transition:all .15s}.export-format-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.export-format-btn.active{background:var(--accent-dim);color:#fff;border-color:var(--accent)}.export-filename{color:var(--text-secondary);font-size:9px}.export-error{color:#ef4444;background:#ef44441a;border:1px solid #ef44444d;margin-top:8px;padding:6px 8px;font-size:9px}.export-success{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e4d;margin-top:8px;padding:6px 8px;font-size:9px}.file-actions{flex-direction:column;gap:4px;display:flex}.file-action-btn{width:100%;font-family:var(--font-mono);background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;text-align:left;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.file-action-btn:hover:not(:disabled){background:var(--bg-hover)}.file-action-btn:disabled{opacity:.5;cursor:default}.file-action-icon{color:var(--accent);text-align:center;width:24px;font-size:16px}.file-action-title{color:var(--text-primary);font-size:10px;font-weight:500;display:block}.file-action-desc{color:var(--text-muted);margin-top:1px;font-size:8px;display:block}.toolbar-group button:disabled{opacity:.3;cursor:default}.toolbar-group button:disabled:hover{background:var(--header-border);color:var(--header-muted)}.add-device-modal{flex-direction:column;width:520px;max-height:80vh;display:flex}.add-device-tabs{border-bottom:1px solid var(--border);display:flex}.add-device-tab{font-family:var(--font-mono);letter-spacing:1px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:6px 14px;font-size:9px;font-weight:600;transition:all .15s}.add-device-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.add-device-tab:hover{color:var(--text-primary)}.add-device-content{flex-direction:column;flex:1;padding:10px 14px;display:flex;overflow:hidden}.add-device-search{margin-bottom:8px}.add-device-search input{width:100%;font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;padding:6px 8px;font-size:9px}.add-device-search input:focus{border-color:var(--accent)}.add-device-search input::placeholder{color:var(--text-muted)}.add-device-categories{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.add-device-category-btn{font-family:var(--font-mono);letter-spacing:.5px;background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:2px;padding:3px 8px;font-size:8px;font-weight:500;transition:all .15s}.add-device-category-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.add-device-category-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.add-device-results{border:1px solid var(--border);border-radius:3px;flex:1;overflow-y:auto}.add-device-group-header{font-family:var(--font-mono);letter-spacing:1px;background:var(--bg-secondary);border-bottom:1px solid var(--border);text-transform:uppercase;z-index:1;padding:6px 8px;font-size:8px;font-weight:600;position:sticky;top:0}.add-device-item{background:var(--bg-tertiary);border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:8px;padding:8px 10px;transition:background .1s;display:flex}.add-device-item:last-child{border-bottom:none}.add-device-item:hover{background:var(--bg-hover)}.add-device-item.staged{opacity:.6;cursor:default}.add-device-item-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.add-device-item-name{font-family:var(--font-mono);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:9px;font-weight:600;overflow:hidden}.add-device-item-sub{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:8px;overflow:hidden}.add-device-item-desc{color:var(--text-muted);font-size:7px}.add-device-item-tags{flex-wrap:wrap;gap:3px;margin-top:2px;display:flex}.add-device-tag{font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border);border-radius:2px;padding:1px 4px;font-size:7px}.add-device-item-actions{flex-shrink:0}.add-device-add-btn{font-family:var(--font-mono);letter-spacing:.5px;background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:2px;padding:3px 8px;font-size:8px;font-weight:600;transition:background .15s}.add-device-add-btn:hover{background:var(--accent-dim)}.add-device-staged-badge{font-family:var(--font-mono);letter-spacing:1px;color:var(--text-muted);border:1px solid var(--border);border-radius:2px;padding:2px 6px;font-size:7px;font-weight:600}.add-device-empty{text-align:center;color:var(--text-muted);padding:20px;font-size:9px}.get-devices-btn{width:100%;font-family:var(--font-mono);letter-spacing:1px;background:var(--accent);color:#fff;border:1px solid var(--accent);cursor:pointer;text-align:center;padding:8px;font-size:9px;font-weight:600;transition:background .15s}.get-devices-btn:hover{background:var(--accent-dim)}.modal-header-actions{align-items:center;gap:8px;display:flex}.add-device-search-row{gap:4px;display:flex}.add-device-search-row input{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;flex:1;padding:6px 8px;font-size:9px}.add-device-search-row input:focus{border-color:var(--accent)}.add-device-search-row input::placeholder{color:var(--text-muted)}.ai-lookup-btn{flex-shrink:0;min-width:36px;letter-spacing:1px!important;padding:6px 10px!important;font-weight:600!important}.ai-lookup-hint{color:var(--text-muted);margin:2px 0 6px;font-size:9px;line-height:1.3}.url-import-tips{border:1px solid var(--header-border);background:var(--panel-bg);border-radius:4px;margin-top:12px;padding:8px}.url-import-tip-list{color:var(--text-muted);margin:4px 0 0;padding-left:16px;font-size:9px;line-height:1.6}.add-device-quick-actions{gap:6px;margin-top:12px;display:flex}.search-results{margin-top:10px}.search-results-label{letter-spacing:1px;color:var(--text-secondary);text-transform:uppercase;margin-bottom:4px;font-size:8px;font-weight:600;display:block}.search-results-list{border:1px solid var(--border);border-radius:3px;max-height:200px;overflow-y:auto}.search-result-item{width:100%;font-family:var(--font-mono);background:var(--bg-tertiary);border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;align-items:center;gap:8px;padding:6px 8px;transition:background .1s;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-hover)}.search-result-icon{text-align:center;flex-shrink:0;width:20px;font-size:14px}.search-result-info{flex:1;min-width:0}.search-result-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:9px;font-weight:600;display:block;overflow:hidden}.search-result-subtitle{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:7px;display:block;overflow:hidden}.search-result-meta{flex-shrink:0;align-items:center;gap:6px;display:flex}.search-result-category{letter-spacing:.5px;border:1px solid;border-radius:2px;padding:1px 4px;font-size:7px;font-weight:600}.search-result-ports{color:var(--text-muted);font-size:7px}.edit-device-fields{margin-bottom:10px}.edit-device-fields .prop-row{align-items:flex-end;gap:8px;display:flex}.edit-device-fields .prop-group input,.edit-device-fields .prop-group select{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;width:100%;padding:4px 6px;font-size:9px}.edit-device-fields .prop-group input:focus,.edit-device-fields .prop-group select:focus{border-color:var(--accent)}.device-sources{margin-top:8px}.device-sources label{letter-spacing:1px;color:var(--text-secondary);text-transform:uppercase;margin-bottom:3px;font-size:8px;font-weight:600;display:block}.source-item{color:var(--text-primary);align-items:center;gap:6px;padding:2px 0;font-size:8px;display:flex}.source-badge{font-size:10px}.source-name{color:var(--text-secondary)}.save-to-lib-check{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;font-size:8px;display:flex}.save-to-lib-check input[type=checkbox]{cursor:pointer;width:12px;height:12px}.add-device-footer{justify-content:space-between}.modal-footer-buttons{gap:6px;display:flex}.ai-loading-state{flex-direction:column;align-items:center;gap:12px;padding:30px 20px;display:flex}.ai-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ai-loading-text{color:var(--text-primary);letter-spacing:.5px;font-size:10px;font-weight:500}.ai-loading-hint{color:var(--text-muted);font-size:8px}.ai-error-state{flex-direction:column;gap:10px;display:flex}.ai-raw-output{width:100%;font-family:var(--font-mono);background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);resize:vertical;padding:6px;font-size:8px}.ai-error-actions{gap:6px;display:flex}.port-editor{margin-top:8px}.port-editor-header label{letter-spacing:1px;color:var(--text-secondary);text-transform:uppercase;margin-bottom:4px;font-size:8px;font-weight:600;display:block}.port-editor-list{flex-direction:column;gap:3px;max-height:180px;display:flex;overflow-y:auto}.port-editor-row{align-items:center;gap:3px;padding:2px 0;display:flex}.port-group-select{flex-shrink:0;align-items:center;gap:3px;display:flex}.port-group-dot{border:1px solid #00000026;border-radius:50%;flex-shrink:0;width:8px;height:8px}.port-select{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;width:90px;padding:2px 3px;font-size:8px}.port-select:focus{border-color:var(--accent)}.port-position-select{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;flex-shrink:0;width:32px;padding:2px 3px;font-size:8px}.port-position-select:focus{border-color:var(--accent)}.port-label-input{font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);outline:none;flex:1;min-width:60px;padding:2px 4px;font-size:8px}.port-label-input:focus{border-color:var(--accent)}.port-label-input::placeholder{color:var(--text-muted)}.port-delete-btn{font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:14px;line-height:1}.port-delete-btn:hover{color:#dc2626}.port-add-btn{font-family:var(--font-mono);letter-spacing:.5px;color:var(--accent);border:1px dashed var(--border);cursor:pointer;text-align:center;background:0 0;width:100%;margin-top:4px;padding:4px 8px;font-size:8px;font-weight:600;transition:all .15s}.port-add-btn:hover{border-color:var(--accent);background:#2563eb0d}.device-preview-container{background:var(--bg-canvas);border:1px solid var(--border);border-radius:3px;justify-content:center;margin-bottom:8px;padding:12px 8px;display:flex}.device-preview-node{border:1.5px solid #1a1a1a;border-radius:4px;flex-direction:column;align-items:stretch;padding:4px 0;display:flex;position:relative}.preview-body{flex:1;align-items:stretch;display:flex}.preview-center{flex-direction:column;flex:1;justify-content:center;align-items:center;min-width:60px;padding:6px 4px;display:flex}.preview-name{font-family:var(--font-mono);color:#1a1a1a;text-align:center;font-size:9px;font-weight:600;line-height:1.2}.preview-subtitle{font-family:var(--font-mono);color:#666;text-align:center;margin-top:2px;font-size:7px}.preview-ports{flex-shrink:0;display:flex}.preview-ports-top,.preview-ports-bottom{flex-direction:row;justify-content:center;gap:8px;padding:2px 8px}.preview-ports-left,.preview-ports-right{flex-direction:column;justify-content:center;gap:4px;padding:2px 4px}.preview-port{border:1px solid #fff;border-radius:50%;flex-shrink:0;width:8px;height:8px}.preview-port-row{align-items:center;gap:3px;display:flex}.preview-port-row-left,.preview-port-row-right{flex-direction:row}.preview-port-label{font-family:var(--font-mono);color:#888;white-space:nowrap;font-size:6px}.image-picker-collapsed{margin-bottom:8px}.image-picker-search-btn{color:#94a3b8;width:100%;font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;background:#1e293b;border:1px dashed #334155;border-radius:4px;padding:8px 12px;font-size:11px;transition:all .15s}.image-picker-search-btn:hover{color:#e2e8f0;background:#334155;border-color:#475569}.image-picker-preview{background:#0f172a;border:1px solid #1e293b;border-radius:4px;align-items:center;gap:10px;padding:6px;display:flex}.image-picker-thumb{object-fit:contain;background:#1e293b;border-radius:3px;flex-shrink:0;width:64px;height:64px}.image-picker-actions{flex-direction:column;gap:4px;display:flex}.image-picker-btn{color:#94a3b8;font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:3px;padding:3px 8px;font-size:9px;transition:all .15s}.image-picker-btn:hover{color:#e2e8f0;background:#334155}.image-picker-btn.danger:hover{color:#fca5a5;background:#7f1d1d;border-color:#dc2626}.image-picker-expanded{background:#0f172a;border:1px solid #1e293b;border-radius:4px;margin-bottom:8px;padding:8px}.image-picker-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.image-picker-title{font-family:var(--font-mono);color:#64748b;letter-spacing:2px;font-size:10px;font-weight:600}.image-picker-close{color:#475569;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:14px}.image-picker-close:hover{color:#94a3b8}.image-picker-search-row{gap:4px;margin-bottom:8px;display:flex}.image-picker-search-row input[type=text]{flex:1;min-width:0}.image-picker-error{color:#f87171;font-family:var(--font-mono);padding:4px 0;font-size:10px}.image-picker-loading{color:#64748b;font-family:var(--font-mono);justify-content:center;align-items:center;gap:8px;padding:16px 0;font-size:10px;display:flex}.image-picker-loading .ai-spinner{width:16px;height:16px}.image-picker-grid{grid-template-columns:repeat(4,1fr);gap:4px;max-height:200px;display:grid;overflow-y:auto}.image-picker-cell{aspect-ratio:1;cursor:pointer;background:#1e293b;border:2px solid #0000;border-radius:4px;padding:0;transition:border-color .15s;overflow:hidden}.image-picker-cell:hover{border-color:#3b82f6}.image-picker-cell.selected{border-color:#22c55e}.image-picker-cell img{object-fit:cover;width:100%;height:100%}.image-picker-empty{text-align:center;color:#475569;font-family:var(--font-mono);padding:16px 0;font-size:10px}.canvas-controls{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ae0;border:1px solid #334155;border-radius:6px;flex-direction:column;gap:2px;padding:4px;display:flex;position:absolute;bottom:16px;right:16px;box-shadow:0 2px 12px #0003}.canvas-ctrl-btn{font-family:var(--font-mono);letter-spacing:.5px;color:#94a3b8;cursor:pointer;white-space:nowrap;text-align:center;background:0 0;border:none;border-radius:3px;min-width:40px;padding:5px 8px;font-size:9px;font-weight:600;transition:all .12s}.canvas-ctrl-btn:hover{color:#e2e8f0;background:#334155}.canvas-ctrl-btn:active{background:#475569}.canvas-ctrl-btn.active{color:#60a5fa;background:#1e3a5f;border-color:#2563eb}.canvas-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.canvas-ctrl-btn:disabled:hover{color:#94a3b8;background:0 0}.canvas-ctrl-zoom{font-family:var(--font-mono);color:#64748b;text-align:center;letter-spacing:.5px;-webkit-user-select:none;user-select:none;padding:2px 8px;font-size:8px;font-weight:500}.canvas-ctrl-divider{background:#334155;height:1px;margin:2px 4px}.canvas-ctrl-group{color:#60a5fa;font-weight:700}.canvas-ctrl-group:hover{color:#fff;background:#1e40af}.canvas-ctrl-present{color:#22c55e;font-weight:700}.canvas-ctrl-present:hover{color:#fff;background:#16a34a}.presentation-bar{z-index:200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f172af2;border-top:1px solid #334155;align-items:center;gap:12px;padding:8px 16px;display:flex;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -2px 16px #00000040}.presentation-nav{align-items:center;gap:4px;display:flex}.presentation-btn{font-family:var(--font-mono);color:#94a3b8;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #334155;border-radius:4px;padding:4px 10px;font-size:10px;font-weight:600;transition:all .12s}.presentation-btn:hover{color:#e2e8f0;background:#334155;border-color:#475569}.presentation-btn.active{color:#22c55e;border-color:#22c55e}.presentation-counter{font-family:var(--font-mono);color:#cbd5e1;letter-spacing:1px;text-align:center;min-width:48px;font-size:10px;font-weight:600}.presentation-dots{align-items:center;gap:4px;padding:0 4px;display:flex}.presentation-dot{cursor:pointer;background:#1e293b;border:1px solid #475569;border-radius:50%;width:8px;height:8px;padding:0;transition:all .12s}.presentation-dot:hover{background:#334155;border-color:#94a3b8}.presentation-dot.active{background:#2563eb;border-color:#3b82f6;box-shadow:0 0 6px #2563eb80}.presentation-label{font-family:var(--font-mono);letter-spacing:1.5px;color:#e2e8f0;text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:9px;font-weight:600;overflow:hidden}.presentation-auto{align-items:center;gap:4px;display:flex}.presentation-speed{font-family:var(--font-mono);color:#94a3b8;cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:3px;padding:3px 4px;font-size:9px}.presentation-export{color:#93c5fd;border-color:#1e40af}.presentation-export:hover{color:#fff;background:#2563eb;border-color:#2563eb}.presentation-export:disabled{opacity:.5;cursor:wait}.presentation-exit{color:#f87171;border-color:#7f1d1d}.presentation-exit:hover{color:#fff;background:#dc2626;border-color:#dc2626}.prop-embedded-list{flex-direction:column;gap:2px;margin-top:3px;display:flex}.prop-embedded-item{font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:3px;width:100%;padding:4px 8px;font-size:8px;font-weight:500;transition:all .12s}.prop-embedded-item:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.panel-section-label{font-family:var(--font-mono);letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;margin-bottom:6px;font-size:7px;font-weight:600}.diagram-device-name-row{align-items:center;gap:6px;display:flex}.diagram-device-count-badge{font-size:9px;font-weight:700;font-family:var(--font-mono);color:var(--accent);white-space:nowrap;background:#dbeafe;border-radius:3px;padding:0 4px;line-height:16px}.diagram-device-category{font-size:7px;font-weight:600;font-family:var(--font-mono);letter-spacing:.8px;border:1px solid;border-radius:2px;margin-top:2px;padding:0 4px;line-height:14px;display:inline-block}.staged-device-item{background:#eff6ff;animation:2s ease-in-out infinite staged-pulse;border-color:var(--accent)!important}.staged-device-item:hover{background:#dbeafe}@keyframes staged-pulse{0%,to{opacity:1}50%{opacity:.85}}.staged-place-badge{color:var(--accent);letter-spacing:.5px;background:#dbeafe;border-radius:3px;padding:1px 5px;font-size:8px;font-weight:700}.save-flash{animation:1.2s ease-out save-flash-anim;color:#059669!important}@keyframes save-flash-anim{0%{background:#059669;color:#fff!important}60%{background:#059669;color:#fff!important}to{background:0 0;color:#059669!important}}.review-btn{color:#7c3aed!important;font-weight:600!important}.review-btn:hover{background:#f5f3ff!important}.review-modal{max-width:520px}.review-intro{text-align:center;padding:20px 0}.review-intro-text{color:var(--text-secondary);margin-bottom:16px;font-size:10px;line-height:1.6}.review-start-btn{padding:8px 24px!important;font-size:11px!important}.review-results{padding:4px 0}.review-score-section{text-align:center;border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:12px}.review-score{font-size:28px;font-weight:700;font-family:var(--font-mono)}.review-summary{color:var(--text-secondary);margin-top:4px;font-size:10px}.review-issues{margin-bottom:12px}.review-issue{border-left:3px solid #0000;border-radius:4px;gap:8px;margin-bottom:4px;padding:8px;display:flex}.review-issue-error{background:#fef2f2;border-left-color:#dc2626}.review-issue-warning{background:#fffbeb;border-left-color:#d97706}.review-issue-info{background:#eff6ff;border-left-color:#2563eb}.review-issue-icon{flex-shrink:0;font-size:12px}.review-issue-content{flex-direction:column;gap:2px;font-size:9px;display:flex}.review-issue-device{color:var(--text-primary);font-size:9px;font-weight:700}.review-issue-message{color:var(--text-primary)}.review-issue-suggestion{color:var(--text-muted);font-style:italic}.review-suggestions{margin-bottom:8px}.review-suggestion-item{color:var(--text-secondary);gap:6px;padding:4px 0;font-size:9px;display:flex}.review-suggestion-bullet{color:var(--accent);flex-shrink:0}.web-search-results{border:1px solid var(--border);border-radius:3px;margin-top:10px;overflow:hidden}.web-search-results .panel-section-label{background:var(--bg-secondary);border-bottom:1px solid var(--border);margin-bottom:0;padding:6px 8px}.web-search-results-list{max-height:240px;overflow-y:auto}.web-search-result-item{width:100%;font-family:var(--font-mono);background:var(--bg-tertiary);border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;flex-direction:column;gap:2px;padding:8px 10px;transition:background .1s;display:flex}.web-search-result-item:last-child{border-bottom:none}.web-search-result-item:hover{background:#eff6ff}.web-search-result-title{color:var(--accent);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:9px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.web-search-result-meta{flex-direction:column;gap:1px;display:flex}.web-search-result-domain{color:#059669;letter-spacing:.3px;font-size:8px;font-weight:600}.web-search-result-snippet{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:8px;line-height:1.3;display:-webkit-box;overflow:hidden}.find-online-hint{font-family:var(--font-mono);color:var(--text-muted);margin:2px 0 6px;font-size:8px;line-height:1.4}.find-online-divider{align-items:center;gap:8px;margin:14px 0 10px;display:flex}.find-online-divider:before,.find-online-divider:after{content:"";background:var(--border);flex:1;height:1px}.find-online-divider span{font-family:var(--font-mono);letter-spacing:1px;color:var(--text-muted);white-space:nowrap;font-size:8px;font-weight:600}.diagram-viewer{background:var(--bg-canvas);width:100vw;height:100vh;font-family:var(--font-mono);flex-direction:column;display:flex;overflow:hidden}.diagram-viewer.dark{--bg-canvas:#0f172a}.dv-header{background:var(--header-bg);height:44px;color:var(--header-text);border-bottom:1px solid var(--header-border);z-index:10;flex-shrink:0;align-items:center;gap:12px;padding:0 16px;font-size:12px;display:flex}.dv-brand{letter-spacing:2px;color:#60a5fa;font-size:14px;font-weight:600}.dv-info{flex:1;align-items:baseline;gap:8px;min-width:0;display:flex}.dv-name{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.dv-id{color:var(--header-muted);font-size:10px}.dv-controls{align-items:center;gap:4px;display:flex}.dv-controls button{font-family:var(--font-mono);color:var(--header-muted);border:1px solid var(--header-border);cursor:pointer;background:0 0;border-radius:4px;padding:4px 8px;font-size:10px;font-weight:600;transition:color .15s,border-color .15s,background .15s}.dv-controls button:hover{color:var(--header-text);border-color:var(--header-muted);background:#ffffff0d}.dv-controls button.active{color:var(--accent);border-color:var(--accent)}.dv-zoom{color:var(--header-muted);text-align:center;min-width:40px;font-size:10px}.dv-canvas{cursor:grab;flex:1;position:relative;overflow:hidden}.dv-canvas.dragging{cursor:grabbing}.dv-canvas svg{transform-origin:0 0;position:absolute;top:0;left:0}.dv-footer{background:var(--header-bg);height:28px;color:var(--header-muted);border-top:1px solid var(--header-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px;font-size:9px;display:flex}.dv-footer-actions{align-items:center;gap:12px;display:flex}.dv-open-editor{font-family:var(--font-mono);color:#60a5fa;cursor:pointer;background:0 0;border:1px solid #60a5fa;border-radius:3px;padding:2px 8px;font-size:9px;font-weight:600;transition:background .15s,color .15s}.dv-open-editor:hover{color:#93bbfc;background:#60a5fa1a}.dv-loading{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.dv-loading-brand{letter-spacing:4px;color:#60a5fa;font-size:28px;font-weight:600}.dv-loading-text{color:var(--text-muted);font-size:12px;animation:1.5s ease-in-out infinite dv-pulse}@keyframes dv-pulse{0%,to{opacity:.4}50%{opacity:1}}.dv-loading-error{color:#dc2626;font-size:12px}.dv-back-link{color:#60a5fa;font-size:11px;text-decoration:none}.dv-back-link:hover{text-decoration:underline}.export-modal-wide{max-width:520px}.export-hint{color:var(--text-muted);font-size:9px}.share-divider{align-items:center;gap:8px;margin:14px 0 10px;display:flex}.share-divider:before,.share-divider:after{content:"";background:var(--border);flex:1;height:1px}.share-divider span{font-family:var(--font-mono);letter-spacing:1px;color:var(--text-muted);white-space:nowrap;font-size:8px;font-weight:600}.share-section{flex-direction:column;gap:4px;display:flex}.share-publish-btn{font-family:var(--font-mono);color:#fff;background:var(--accent);cursor:pointer;letter-spacing:.5px;border:none;border-radius:4px;padding:8px 16px;font-size:10px;font-weight:600;transition:background .15s}.share-publish-btn:hover:not(:disabled){background:var(--accent-dim)}.share-publish-btn:disabled{opacity:.5;cursor:not-allowed}.share-hint{color:var(--text-muted);font-size:8px}.share-url-row{gap:4px;display:flex}.share-url-input{font-family:var(--font-mono);background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;flex:1;min-width:0;padding:6px 8px;font-size:9px}.share-url-input:focus{border-color:var(--accent);outline:none}.share-url-input.embed-code{font-size:8px}.share-copy-btn{font-family:var(--font-mono);color:var(--accent);border:1px solid var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:4px 10px;font-size:9px;font-weight:600;transition:background .15s,color .15s}.share-copy-btn:hover{background:#2563eb14}.file-menu-container{z-index:200;position:relative}.file-menu-trigger{font-family:var(--font-mono);color:var(--header-muted);cursor:pointer;letter-spacing:.02em;background:0 0;border:1px solid #0000;border-radius:4px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;transition:all .15s;display:flex}.file-menu-trigger:hover{color:var(--header-text);border-color:var(--header-border);background:#ffffff0f}.file-menu-trigger.active{color:var(--header-text);border-color:var(--header-border);background:#ffffff1a}.file-menu-dropdown{background:var(--bg-tertiary);border:1px solid var(--border);z-index:300;border-radius:6px;min-width:220px;padding:4px 0;position:absolute;top:calc(100% + 4px);left:0;box-shadow:0 8px 24px #00000026}.file-menu-item{width:100%;font-family:var(--font-mono);color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:6px 12px;font-size:11px;transition:background .1s;display:flex}.file-menu-item:hover:not(:disabled){background:var(--bg-hover)}.file-menu-item:disabled{opacity:.35;cursor:default}.file-menu-item-icon{width:18px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.file-menu-item-label{flex:1;font-weight:500}.file-menu-item-shortcut{color:var(--text-muted);margin-left:auto;padding-left:12px;font-size:10px}.file-menu-separator{background:var(--border);height:1px;margin:3px 8px}.header-save-status{font-family:var(--font-mono);letter-spacing:.05em;border-radius:3px;margin-left:6px;padding:2px 6px;font-size:9px;font-weight:600}.header-save-status.saving{color:var(--header-muted)}.header-save-status.saved{color:#4ade80}.workspace-files{width:100%;margin-top:16px}.workspace-files-title{font-family:var(--font-mono);letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;padding:0 4px;font-size:9px;font-weight:700}.skin-selector{background:var(--bg-primary);z-index:9999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.skin-selector-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;flex-direction:column;align-items:center;width:100%;max-width:560px;padding:40px 48px;display:flex}.skin-selector-header{flex-direction:column;align-items:center;margin-bottom:32px;display:flex}.skin-selector-logo{width:48px;height:48px;margin-bottom:12px}.skin-selector-title{font-family:var(--font-mono);letter-spacing:.15em;color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:700}.skin-selector-subtitle{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.08em;font-size:9px}.skin-selector-label{font-family:var(--font-mono);letter-spacing:.12em;color:var(--text-muted);align-self:flex-start;margin-bottom:16px;font-size:9px;font-weight:700}.skin-selector-options{flex-direction:column;gap:12px;width:100%;display:flex}.skin-option{background:var(--bg-secondary);border:2px solid var(--border);cursor:pointer;text-align:left;font-family:var(--font-mono);border-radius:6px;align-items:center;gap:16px;padding:16px 20px;transition:border-color .15s,background .15s;display:flex}.skin-option:hover{background:var(--bg-hover);border-color:currentColor}.skin-option-icon{text-align:center;flex-shrink:0;width:40px;font-size:28px}.skin-option-info{flex-direction:column;flex:1;gap:2px;display:flex}.skin-option-name{letter-spacing:.1em;font-size:16px;font-weight:700}.skin-option-title{letter-spacing:.08em;color:var(--text-secondary);font-size:10px;font-weight:600}.skin-option-subtitle{color:var(--text-muted);letter-spacing:.05em;font-size:9px}.skin-option-desc{color:var(--text-muted);margin-top:4px;font-size:9px;line-height:1.4}.skin-option-arrow{opacity:0;flex-shrink:0;font-size:20px;font-weight:700;transition:opacity .15s}.skin-option:hover .skin-option-arrow{opacity:1}@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-ease{syntax:"*";inherits:false}
