@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}}}@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;--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{.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.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}.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))}}: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{flex:1;justify-content:center;display:flex}.header-right{gap:4px;display:flex}.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}.toolbar{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}.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 .joint-paper{border:none}.joint-port-body:hover{r:6;stroke-width:2px}::-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{width:460px}.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}.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}@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}
