:root{--bg: #06060b;--bg-elevated: #0d0d14;--surface: rgba(255, 255, 255, .04);--surface-hover: rgba(255, 255, 255, .07);--border: rgba(255, 255, 255, .08);--border-bright: rgba(255, 255, 255, .14);--text: #f0f0f5;--text-muted: #8b8b9e;--text-dim: #5a5a6e;--accent: #7c3aed;--accent-2: #06b6d4;--accent-glow: rgba(124, 58, 237, .45);--success: #10b981;--error: #ef4444;--warning: #f59e0b;--radius: 14px;--radius-sm: 8px;--font: "Inter", system-ui, sans-serif;--font-display: "Space Grotesk", "Inter", system-ui, sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.landing-bg,.app-bg{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,black,transparent)}.grid-overlay--subtle{opacity:.35;mask-image:radial-gradient(ellipse 70% 50% at 50% 40%,black 20%,transparent 70%)}.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:float 12s ease-in-out infinite}.orb-1{width:500px;height:500px;background:#7c3aed;top:-10%;left:-5%}.orb-2{width:400px;height:400px;background:#06b6d4;top:30%;right:-10%;animation-delay:-4s}.orb-3{width:300px;height:300px;background:#ec4899;bottom:10%;left:30%;animation-delay:-8s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(.95)}}.glass{background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1.4rem;border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:600;font-size:.9rem;border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--accent),#5b21b6);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 30px var(--accent-glow)}.btn-glow{box-shadow:0 0 20px var(--accent-glow),0 0 60px #7c3aed26}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--border-bright);background:var(--surface-hover)}.btn-lg{padding:.85rem 2rem;font-size:1rem;border-radius:12px}.btn-sm{padding:.4rem .9rem;font-size:.8rem}.btn-full{width:100%}.brand{display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:700;font-size:1.15rem}.brand-icon{color:var(--accent-2);font-size:1.3rem}.gradient-text{background:linear-gradient(135deg,var(--accent-2),var(--accent),#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-badge{display:inline-block;padding:.35rem .9rem;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;background:#7c3aed26;border:1px solid rgba(124,58,237,.3);color:#c4b5fd;margin-bottom:1.25rem}.hero-badge.live{background:#10b9811f;border-color:#10b9814d;color:#6ee7b7;margin-bottom:0}.badge{font-size:.7rem;padding:.2rem .55rem;border-radius:999px;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.badge-vpn{background:#06b6d41f;color:#67e8f9;border:1px solid rgba(6,182,212,.25)}.landing{position:relative;z-index:1;min-height:100vh}.landing-nav{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;max-width:1200px;margin:0 auto}.nav-actions{display:flex;align-items:center;gap:1.5rem}.nav-link{color:var(--text-muted);font-size:.9rem;font-weight:500;transition:color .2s}.nav-link:hover{color:var(--text)}.landing-hero{position:relative;z-index:2;max-width:900px;margin:0 auto;padding:4rem 2rem 3rem;text-align:center}.landing-hero h1{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,4rem);font-weight:700;line-height:1.1;margin:0 0 1.25rem;letter-spacing:-.02em}.hero-sub{font-size:1.1rem;color:var(--text-muted);line-height:1.7;max-width:620px;margin:0 auto 2rem}.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:700px;margin:0 auto}.stat-card{padding:1.25rem 1rem;text-align:center}.stat-value{display:block;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text)}.stat-label{display:block;font-size:.75rem;color:var(--text-dim);margin-top:.25rem;text-transform:uppercase;letter-spacing:.05em}.landing-features{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:4rem 2rem;text-align:center}.landing-features h2{font-family:var(--font-display);font-size:2rem;margin:0 0 .5rem}.section-sub{color:var(--text-muted);margin:0 0 2.5rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;text-align:left}.feature-card{padding:1.75rem;transition:border-color .2s,transform .2s}.feature-card:hover{border-color:var(--border-bright);transform:translateY(-2px)}.feature-icon{font-size:1.75rem;display:block;margin-bottom:.75rem}.feature-card h3{font-family:var(--font-display);font-size:1.05rem;margin:0 0 .5rem}.feature-card p{font-size:.88rem;color:var(--text-muted);line-height:1.6;margin:0}.landing-cta{position:relative;z-index:2;max-width:700px;margin:0 auto;padding:2rem 2rem 4rem}.cta-card{padding:3rem 2rem;text-align:center}.cta-card h2{font-family:var(--font-display);font-size:1.75rem;margin:0 0 .75rem}.cta-card p{color:var(--text-muted);margin:0 0 1.5rem}.landing-footer{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--text-dim);font-size:.8rem;border-top:1px solid var(--border)}.footer-dot{opacity:.4}.auth-page{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.auth-split{position:relative;z-index:2;flex:1;display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1000px;margin:0 auto;padding:2rem;align-items:center}.auth-promo h1{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.8rem);font-weight:700;line-height:1.15;margin:0 0 1rem}.auth-promo p{color:var(--text-muted);line-height:1.7;margin:0 0 1.5rem}.auth-perks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.auth-perks li{color:var(--text-muted);font-size:.9rem;padding-left:1.5rem;position:relative}.auth-perks li:before{content:"✓";position:absolute;left:0;color:var(--accent-2);font-weight:700}.auth-form-wrap{display:flex;justify-content:center}.login-panel{width:100%;max-width:400px;padding:2rem}.login-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.login-panel-header h3{font-family:var(--font-display);font-size:1.35rem;margin:0}.login-description{color:var(--text-muted);font-size:.9rem;margin:0 0 .25rem}.login-status{font-size:.8rem;color:var(--text-dim);margin:0 0 1rem}.login-form{display:flex;flex-direction:column;gap:1rem;margin-top:1.25rem}.input-group{display:flex;flex-direction:column;gap:.35rem}.input-group span{font-size:.8rem;font-weight:500;color:var(--text-muted)}.input-group input{padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#0000004d;color:var(--text);font-size:.95rem;outline:none;transition:border-color .2s}.input-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #7c3aed26}.input-group input::placeholder{color:var(--text-dim)}.mode-switch{display:block;width:100%;margin-top:1.25rem;background:none;border:none;color:var(--accent-2);font-size:.85rem;font-weight:500;cursor:pointer;text-align:center;padding:.5rem;transition:color .2s}.mode-switch:hover{color:var(--text)}.app-layout{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.5rem;margin:.75rem 1rem 0;border-radius:var(--radius)}.app-nav{display:flex;gap:.25rem}.nav-item{padding:.45rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;color:var(--text-muted);transition:all .2s}.nav-item:hover{color:var(--text);background:var(--surface-hover)}.nav-item.active{color:var(--text);background:#7c3aed26}.app-header-right{display:flex;align-items:center;gap:.75rem}.user-chip{font-size:.8rem;padding:.3rem .75rem;border-radius:999px;background:#06b6d41a;border:1px solid rgba(6,182,212,.2);color:#67e8f9;font-weight:500}.app-main{position:relative;z-index:2;flex:1;padding:1rem 1.5rem 2rem}.workspace-hero{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.25rem}.workspace-hero h1{font-family:var(--font-display);font-size:1.5rem;margin:0 0 .25rem}.workspace-hero p{color:var(--text-muted);font-size:.9rem;margin:0}.layout-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:1.25rem}.panels{display:flex;flex-direction:column;gap:.75rem}.card,.panel{background:var(--surface);padding:1rem;border-radius:var(--radius);border:1px solid var(--border);backdrop-filter:blur(12px)}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.panel h3,.panel h2{font-family:var(--font-display);margin:0;font-size:1rem}.panel button{background:linear-gradient(135deg,var(--accent),#5b21b6);color:#fff;border:none;padding:.4rem .85rem;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s}.panel button:hover{box-shadow:0 4px 15px var(--accent-glow)}.panel button.secondary{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.panel button.secondary:hover{border-color:var(--border-bright);color:var(--text);box-shadow:none}.panel textarea{width:100%;padding:.6rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#00000040;color:var(--text);resize:vertical;font-family:var(--font)}.panel ul,.panel ol{padding-left:1.25rem;margin:.4rem 0 0;color:var(--text-muted);font-size:.88rem}.status-line{font-size:.85rem;color:var(--text-muted);margin:.25rem 0 0}.status-line.small{font-size:.75rem;color:var(--text-dim)}.beta-status{margin:.5rem 0;padding:.4rem .75rem;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem}.beta-status.pass{background:#10b9811f;color:#6ee7b7;border:1px solid rgba(16,185,129,.2)}.beta-status.fail{background:#ef44441a;color:#fca5a5;border:1px solid rgba(239,68,68,.2)}.errors{margin-top:.75rem;padding:.6rem;border-radius:var(--radius-sm);background:#ef444414;color:#fca5a5;border:1px solid rgba(239,68,68,.15);font-size:.85rem}.canvas-shell{width:100%}.canvas-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.5rem}.canvas-shell svg{border-radius:var(--radius);box-shadow:0 20px 50px #0006;width:100%}.canvas-shell rect{transition:stroke .2s ease}.canvas-shell rect:hover{stroke:var(--accent)}.export-actions{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.dashboard-actions .action-grid{display:grid;gap:.5rem;margin-top:.75rem}.dashboard-actions button{padding:.65rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s}.dashboard-actions button:hover{border-color:var(--accent);color:#c4b5fd;background:#7c3aed14}.profile-page{max-width:1040px;margin:0 auto;padding:1.5rem 1rem 3rem}.profile-page-header{margin-bottom:1.5rem}.profile-page-header h1{font-family:var(--font-display);margin:0 0 .35rem;font-size:1.75rem}.profile-page-header p{margin:0;color:var(--text-dim);font-size:.92rem}.profile-layout{display:grid;grid-template-columns:minmax(260px,300px) minmax(0,1fr);gap:1.25rem;align-items:start}.profile-sidebar{position:sticky;top:5.5rem}.profile-main{display:flex;flex-direction:column;gap:1.25rem;min-width:0}.profile-panel{padding:1.35rem 1.5rem}.profile-panel-title{font-family:var(--font-display);font-size:1.05rem;margin:0 0 1rem}.profile-account-head{display:flex;gap:1rem;align-items:flex-start}.profile-account-meta{flex:1;min-width:0;text-align:left}.profile-account-name{margin:0 0 .25rem;font-weight:600;font-size:1.05rem}.profile-account-id{margin:0 0 .5rem;font-size:.72rem;color:var(--text-dim);word-break:break-all}.profile-security-block+.profile-security-block{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.profile-security-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.profile-security-label{margin:0 0 .2rem;font-weight:600}.profile-security-hint{margin:0;font-size:.82rem;color:var(--text-dim);line-height:1.45}.profile-security-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.profile-security-badge{font-size:.72rem;padding:.2rem .55rem;border-radius:999px;background:#22c55e26;color:#86efac;border:1px solid rgba(34,197,94,.35)}.profile-security-note{margin:.5rem 0 0;font-size:.78rem;color:var(--text-dim);line-height:1.5}.profile-security-note p{margin:0 0 .35rem}.profile-security-note p:last-child{margin-bottom:0}.profile-2fa-setup,.profile-2fa-disable{margin-top:.85rem;display:grid;gap:.65rem}.profile-2fa-qr{width:180px;height:180px;border-radius:var(--radius-sm);background:#fff;padding:.35rem}.profile-security-msg{margin:.85rem 0 0;font-size:.82rem;color:#86efac}.profile-security-error{margin:.85rem 0 0;font-size:.82rem;color:var(--danger, #f87171)}.profile-github-sync-repo{display:grid;gap:.65rem;margin:1rem 0}.profile-github-sync-repo-actions,.profile-github-sync-actions{display:flex;flex-wrap:wrap;gap:.5rem}.profile-card{max-width:480px;margin:2rem auto;padding:2.5rem;text-align:center}.profile-avatar-block{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.25rem}.profile-avatar-btn{position:relative;width:80px;height:80px;border-radius:50%;border:2px solid var(--border);background:linear-gradient(135deg,var(--accent),var(--accent-2));padding:0;cursor:pointer;overflow:hidden;transition:border-color .2s}.profile-avatar-btn:hover:not(:disabled){border-color:var(--accent)}.profile-avatar-btn:disabled{opacity:.7;cursor:wait}.profile-avatar-initial{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:#fff}.profile-avatar-img{width:100%;height:100%;object-fit:cover;display:block}.profile-avatar-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000008c;color:#fff;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;opacity:0;transition:opacity .2s}.profile-avatar-btn:hover:not(:disabled) .profile-avatar-overlay,.profile-avatar-btn:focus-visible .profile-avatar-overlay{opacity:1}.profile-avatar-input{display:none}.profile-avatar-remove{font-size:.8rem}.profile-avatar-error{margin:0;font-size:.8rem;color:var(--danger, #f87171)}.profile-actions{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.profile-card h2{font-family:var(--font-display);margin:0 0 1.5rem}.profile-fields{display:flex;flex-direction:column;gap:1rem;text-align:left}.profile-field{padding:.85rem 1rem;border-radius:var(--radius-sm);background:#0003;border:1px solid var(--border)}.field-label{display:block;font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.field-value{font-weight:500}.field-value.mono{font-family:SF Mono,Fira Code,monospace;font-size:.85rem;color:var(--text-muted);word-break:break-all}.workspace-menu{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;margin-top:1rem}.workspace-card{text-align:left;padding:2rem;cursor:pointer;transition:border-color .2s,transform .2s;color:inherit;font:inherit}.workspace-card:hover{border-color:var(--accent);transform:translateY(-2px)}.workspace-card-icon{font-size:2rem;display:block;margin-bottom:.75rem}.workspace-card h2{font-family:var(--font-display);margin:0 0 .5rem;font-size:1.35rem}.workspace-card p{color:var(--text-muted);font-size:.9rem;line-height:1.6;margin:0 0 1rem}.workspace-card-cta{color:var(--accent-2);font-weight:600;font-size:.9rem}.status-banner{padding:.6rem 1rem;border-radius:var(--radius-sm);background:#7c3aed1a;border:1px solid rgba(124,58,237,.2);color:#c4b5fd;font-size:.85rem;margin-bottom:.5rem}.manager-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.manager-header h2{font-family:var(--font-display);margin:0;flex:1;font-size:1.35rem}.header-actions{display:flex;gap:.5rem}.manager:has(.board-layout){display:flex;flex-direction:column;min-height:0;height:calc(100vh - 5.5rem)}.manager-body{display:grid;grid-template-columns:240px 1fr;gap:1rem;flex:1;min-height:0;overflow:hidden}.manager-list{padding:0;display:flex;flex-direction:column;min-height:0;overflow:hidden}.manager-list:not(:has(.manager-list-scroll)){padding:1rem;overflow-y:auto}.manager-list-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:1rem 1rem .5rem;flex-shrink:0}.manager-list-actions{display:flex;align-items:center;gap:.2rem}.board-search-btn.active{color:var(--accent);background:#7c3aed1f}.board-search-bar{padding:0 1rem .5rem;flex-shrink:0}.board-search-bar input{width:100%;padding:.45rem .65rem;border-radius:8px;border:1px solid var(--border);background:#00000040;color:var(--text);font-size:.85rem}.board-search-bar input:focus{outline:none;border-color:var(--accent)}.board-search-results{display:flex;flex-direction:column;gap:.65rem}.board-search-group-head{display:flex;align-items:center;gap:.35rem;padding:.15rem .25rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim)}.board-search-folder{color:var(--accent-soft, #a78bfa);font-weight:600}.board-search-group-count{color:var(--text-dim)}.board-search-group-list{display:flex;flex-direction:column;gap:.25rem}.manager-list-scroll{flex:1;min-height:0;overflow-y:auto;padding:0 1rem 1rem;scrollbar-width:thin;scrollbar-color:rgba(124,58,237,.35) transparent}.manager-list h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin:0}.manager-editor{padding:1.25rem;overflow-y:auto;min-height:0}.list-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:.65rem .75rem;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--text);cursor:pointer;text-align:left;margin-bottom:.25rem;transition:all .15s}.list-item:hover{background:var(--surface-hover)}.list-item.active{background:#7c3aed1f;border-color:#7c3aed4d}.list-item-title{font-weight:600;font-size:.9rem}.list-item-meta{font-size:.75rem;color:var(--text-dim);margin-top:.15rem}.list-item-row{display:flex;align-items:center;gap:.65rem;width:100%}.list-item-text{display:flex;flex-direction:column;align-items:flex-start;min-width:0}.list-item-fallback-icon{font-size:1.1rem;width:28px;text-align:center;flex-shrink:0}.board-mini-icon{flex-shrink:0}.project-workspace{margin-bottom:1.25rem}.project-workspace.wokwi-style{position:relative;border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden;background:#12121a}.project-canvas-viewport{position:relative;min-height:440px;max-height:min(72vh,720px);overflow:auto;background:#0e0e14;scrollbar-width:thin;scrollbar-color:rgba(124,58,237,.4) transparent}.project-canvas-world{position:relative;overflow:hidden;touch-action:none}.project-canvas-toolbar{position:sticky;top:0;left:0;display:flex;gap:.35rem;z-index:20;padding:.65rem .75rem;justify-content:flex-end;align-items:center;background:linear-gradient(180deg,rgba(14,14,20,.95) 0%,rgba(14,14,20,.6) 70%,transparent 100%);pointer-events:none}.project-wire-route-label{margin-right:auto;max-width:min(42vw,520px);padding:.35rem .65rem;border-radius:var(--radius-sm);border:1px solid rgba(96,165,250,.35);background:#0c0c14e0;color:#bfdbfe;font-size:.72rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;user-select:none}.project-canvas-toolbar .canvas-tool-btn,.project-canvas-toolbar .canvas-tool-anchor,.project-canvas-toolbar .canvas-zoom-group,.project-workspace-settings{pointer-events:auto}.canvas-tool-anchor{position:relative}.canvas-zoom-group{display:inline-flex;align-items:center;gap:.15rem;padding:0 .15rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#0c0c14d9}.canvas-zoom-step{width:1.65rem!important;height:1.65rem!important;border:none!important;background:transparent!important}.canvas-zoom-label{font-size:.68rem;font-weight:600;color:var(--text-muted);min-width:2.5rem;text-align:center;user-select:none}.canvas-zoom-label.pin{min-width:3.6rem}.project-canvas-scaler{position:relative;transform-origin:0 0;background-color:#16161f;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px),radial-gradient(circle at 10px 10px,rgba(255,255,255,.07) 1.5px,transparent 1.5px);background-size:20px 20px,20px 20px,20px 20px}.canvas-tool-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#0c0c14d9;color:var(--text-muted);cursor:pointer;transition:all .15s}.canvas-tool-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text);border-color:#7c3aed59}.canvas-tool-btn.active{background:#7c3aed33;color:#c4b5fd;border-color:#7c3aed73}.canvas-tool-btn.active.danger{background:#ef444426;color:#fca5a5;border-color:#ef444459}.canvas-tool-btn:disabled{opacity:.35;cursor:not-allowed}.add-board-picker{min-width:200px;max-width:260px;padding:.5rem;border-radius:var(--radius-sm);border:1px solid var(--border);box-shadow:0 10px 28px #0006}.add-board-picker-portal{position:fixed;z-index:1200;width:260px}.add-board-picker-scroll{max-height:min(420px,58vh);overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:rgba(124,58,237,.45) transparent;padding-right:.15rem}.picker-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin:.25rem .5rem .5rem}.picker-empty{padding:.75rem .5rem;text-align:left;font-size:.8rem}.picker-board-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.5rem .6rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text);cursor:pointer;text-align:left;font-size:.85rem}.picker-board-item:hover{background:var(--surface-hover)}.project-canvas-empty{position:absolute;left:50%;top:45%;transform:translate(-50%,-50%);color:var(--text-dim);font-size:.95rem;padding:2rem;text-align:center;pointer-events:none;z-index:1;max-width:360px}.project-wires-layer{position:absolute;inset:0;pointer-events:none;z-index:5;overflow:visible}.project-pin-labels-layer{position:absolute;inset:0;pointer-events:none;z-index:7;overflow:visible}.project-pin-label-world{font-size:10px;font-weight:600;fill:#f8fafce6;paint-order:stroke fill;stroke:#000000b3;stroke-width:2.5px}.conn-wire-hit{pointer-events:stroke;cursor:pointer}.conn-wire{fill:none;stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round;opacity:.9;pointer-events:none}.conn-wire.selected{stroke-width:4.5;filter:drop-shadow(0 0 4px currentColor)}.conn-wire.hovered{stroke-width:4;opacity:1}.conn-wire-march{fill:none;stroke-width:4.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:8 14;opacity:.95;pointer-events:none;animation:conn-march .45s linear infinite}@keyframes conn-march{to{stroke-dashoffset:-22}}.wire-waypoint-handle{fill:#f59e0b;stroke:#fff;stroke-width:2;cursor:grab;pointer-events:all}.wire-waypoint-handle:active{cursor:grabbing}.wire-waypoint-draft{fill:#fbbf24;stroke:#fff;stroke-width:1.5;pointer-events:none}.project-workspace-settings{position:absolute;top:3.25rem;right:.75rem;z-index:40;width:280px;max-width:calc(100% - 1.5rem);padding:.75rem;border-radius:var(--radius-sm);border:1px solid var(--border);box-shadow:0 12px 32px #00000073}.project-workspace-settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.65rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.project-settings-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem;font-size:.78rem;color:var(--text-muted)}.project-settings-field input[type=range]{width:100%}.project-settings-color input[type=color]{width:100%;height:2rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;cursor:pointer}.project-settings-hint{margin:0 0 .65rem;font-size:.72rem;color:var(--text-dim)}.project-settings-hint.inline{margin:0}.project-settings-scope{display:flex;gap:.35rem}.scope-btn{flex:1;padding:.35rem .5rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#0c0c1499;color:var(--text-muted);font-size:.68rem;cursor:pointer;transition:all .15s}.scope-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.scope-btn.active{background:#7c3aed33;color:#c4b5fd;border-color:#7c3aed73}.scope-btn:disabled{opacity:.4;cursor:not-allowed}.conn-wire-flow{fill:none;stroke-width:2;stroke-dasharray:6 5;opacity:.75;pointer-events:none;animation:conn-flow .8s linear infinite}.wire-endpoint{pointer-events:none;stroke:#fff;stroke-width:2}.wire-endpoint.from{fill:#22c55e}.wire-endpoint.to{fill:#3b82f6}.wire-endpoint.blink{animation:wire-endpoint-blink 1.1s ease-in-out infinite}@keyframes wire-endpoint-blink{0%,to{opacity:1}50%{opacity:.3}}.conn-wire.running{stroke-width:4;opacity:1;filter:drop-shadow(0 0 4px currentColor);animation:conn-glow 1.2s ease-in-out infinite}.conn-wire.draft{stroke:#fbbf24!important;stroke-width:3.5;opacity:1;stroke-dasharray:8 5;animation:conn-flow .6s linear infinite}@keyframes conn-glow{50%{opacity:.75}}@keyframes conn-flow{to{stroke-dashoffset:-20}}.project-board-node{position:absolute;z-index:3;background:none;border:none;padding:0;user-select:none;touch-action:none;cursor:grab}.project-board-rotate-wrap{position:absolute;transform-origin:center center;pointer-events:none}.project-board-svg{pointer-events:none}.project-board-svg .project-pin,.project-board-svg .wokwi-pin{pointer-events:all}.project-board-node.selected{z-index:4}.project-board-node:active{cursor:grabbing}.project-board-svg{display:block;overflow:visible;pointer-events:none;filter:drop-shadow(0 8px 18px rgba(0,0,0,.55));transition:filter .15s,transform .15s}.project-board-svg.dragging{cursor:grabbing;filter:drop-shadow(0 12px 24px rgba(0,0,0,.65));transform:scale(1.02)}.project-board-svg.selected{filter:drop-shadow(0 0 14px rgba(124,58,237,.5)) drop-shadow(0 8px 18px rgba(0,0,0,.55))}.project-board-svg.running{filter:drop-shadow(0 0 10px rgba(52,211,153,.45)) drop-shadow(0 8px 18px rgba(0,0,0,.55))}.project-pin{cursor:pointer;pointer-events:all}.project-pin-hit-area{fill:transparent;pointer-events:all}.project-pin.wire-source circle:nth-of-type(2){stroke:#fbbf24;stroke-width:3}.project-pin.wire-target circle:nth-of-type(2){stroke:#38bdf8;stroke-width:2.5;filter:drop-shadow(0 0 4px rgba(56,189,248,.55))}.project-pin.wire-snap-target circle:nth-of-type(2){stroke:#38bdf8;stroke-width:3.5;filter:drop-shadow(0 0 8px rgba(56,189,248,.95))}.project-pin-label{font-size:11px;font-weight:700;fill:#f1f5f9;pointer-events:none}.project-pin-role{font-size:9px;fill:#94a3b8;pointer-events:none}.project-wire-hint{position:absolute;bottom:.75rem;right:.75rem;font-size:.72rem;color:var(--text-dim);z-index:5;pointer-events:none}.project-workspace:focus{outline:none}.project-workspace:focus-visible{box-shadow:inset 0 0 0 2px #7c3aed59;border-radius:8px}.project-run-badge{position:absolute;bottom:.75rem;left:.75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#6ee7b7;padding:.25rem .55rem;border-radius:999px;background:#10b9811f;border:1px solid rgba(52,211,153,.35);z-index:5;animation:run-pulse 1.5s ease-in-out infinite}@keyframes run-pulse{50%{opacity:.65}}.empty-hint{color:var(--text-dim);font-size:.9rem;text-align:center;padding:2rem 1rem}.warn-hint{color:var(--warning);font-size:.85rem;padding:.5rem .75rem;border-radius:var(--radius-sm);background:#f59e0b14;border:1px solid rgba(245,158,11,.2);margin-bottom:.75rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}.pins-section{margin-bottom:1.25rem}.pins-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.pins-header h3{font-size:.95rem;margin:0}.pins-table{display:flex;flex-direction:column;gap:.35rem}.pins-row{display:grid;grid-template-columns:1.5fr 60px 60px 2fr 32px;gap:.4rem;align-items:center}.pins-head{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);padding-bottom:.25rem}.pins-row input,.pins-row select,.connection-row select,.conn-comment{padding:.5rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#0000004d;color:var(--text);font-size:.85rem;outline:none}.pins-row input:focus,.connection-row select:focus,.conn-comment:focus{border-color:var(--accent)}.btn-icon{background:transparent;border:none;color:var(--text-dim);cursor:pointer;font-size:.9rem;padding:.25rem}.btn-icon:hover{color:var(--error)}.btn-danger{background:#ef444426;color:#fca5a5;border:1px solid rgba(239,68,68,.25);padding:.65rem 1.4rem;border-radius:var(--radius-sm);cursor:pointer;font-weight:600}.btn-danger:hover{background:#ef444440}.manager-actions{display:flex;gap:.75rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid var(--border)}.connection-card{padding:.75rem;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:.5rem;background:#00000026}.connection-row{display:grid;grid-template-columns:1fr 1fr auto 1fr 1fr 32px;gap:.4rem;align-items:center;margin-bottom:.4rem}.conn-arrow{color:var(--accent-2);font-weight:700;text-align:center}.conn-comment{width:100%;margin-bottom:.35rem}.conn-preview{font-size:.8rem;color:var(--text-dim);margin:0;font-family:SF Mono,Fira Code,monospace}.profile-sections{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:1.5rem}.profile-section{padding:1.25rem}.section-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-top h3{font-family:var(--font-display);margin:0;font-size:1rem}.profile-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.profile-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:var(--radius-sm);background:#0003;border:1px solid var(--border)}.item-title{font-weight:600;font-size:.9rem;display:block}.item-comment{font-size:.8rem;color:var(--text-dim);display:block;margin-top:.15rem}.item-meta{font-size:.75rem;color:var(--text-dim);white-space:nowrap;margin-left:1rem}.board-layout .manager-editor{min-width:0;overflow-x:hidden;height:100%;background:linear-gradient(180deg,#ffffff09,#ffffff05)}.board-layout .manager-list{border:1px solid rgba(124,58,237,.12);background:#0000002e}.board-layout .form-row .input-group span{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim)}.board-layout .form-row input{padding:.6rem .75rem;font-size:.88rem}.board-workspace{display:flex;flex-direction:column;min-width:0;min-height:0;height:100%;overflow:hidden}.board-workspace.ai-open{display:grid;grid-template-columns:minmax(0,1fr) clamp(320px,40vw,460px);gap:1rem;align-items:stretch}.board-workspace.ai-open .manager-editor{height:100%}.board-workspace.ai-open .board-canvas-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.65rem}.board-workspace.ai-open .board-canvas-container{max-width:100%;width:100%}.board-workspace.ai-open .board-canvas-container.wokwi-canvas{width:auto;max-width:100%}.board-workspace.ai-open .canvas-legend{gap:.5rem;font-size:.68rem}.board-ai-panel{min-width:0;width:100%;height:100%;min-height:0;display:flex;flex-direction:column;overflow:hidden;padding:0;border-radius:var(--radius);border:1px solid rgba(34,211,238,.16);background:linear-gradient(165deg,#06b6d412,#7c3aed0d);box-shadow:0 12px 40px #00000047,inset 0 1px #ffffff0a}.board-ai-panel .ai-chat-panel{position:relative;inset:auto;flex:1;min-height:0;height:100%;border-radius:var(--radius);background:transparent;border:none}.board-layout .manager-body{min-width:0}.board-canvas-wrap{margin:1rem 0;width:100%;min-width:0}.board-canvas-layout{display:grid;grid-template-columns:min(360px,100%) minmax(220px,1fr);gap:1rem;align-items:start;width:100%}.board-canvas-main{min-width:0;width:100%}.board-canvas-settings-col{min-width:0;width:100%;display:flex;justify-content:stretch;align-self:stretch}@media (max-width: 900px){.board-workspace.ai-open{grid-template-columns:1fr}.board-ai-panel{min-height:min(60vh,480px)}.board-canvas-layout{grid-template-columns:1fr}.board-canvas-settings-col{width:100%}.ai-chat-layout{grid-template-columns:1fr;grid-template-rows:1fr auto}.ai-chat-history-rail.open{width:100%;flex-direction:column}.ai-chat-history{width:100%;max-height:160px;border-left:none;border-top:1px solid var(--border)}.board-settings-trigger{align-items:flex-start}}.board-settings-trigger{position:relative;width:100%;display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.board-reset-btn{width:40px;height:40px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background:#00000040;color:var(--text-muted);transition:border-color .2s,color .2s,background .2s,opacity .2s}.board-reset-btn:hover:not(:disabled){border-color:#f59e0b;color:#fcd34d;background:#f59e0b1f}.board-reset-btn:disabled{opacity:.35;cursor:not-allowed}.board-filter-btn{width:40px;height:40px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background:#00000040;color:var(--text-muted);transition:border-color .2s,color .2s,background .2s}.board-filter-btn:hover,.board-filter-btn.active{border-color:var(--accent);color:#c4b5fd;background:#7c3aed1f}.board-toolbar-buttons{position:absolute;top:calc(-40px - .5rem);right:0;z-index:3;display:flex;align-items:center;justify-content:flex-end;gap:.4rem;flex-shrink:0}.board-side-panel-body{position:relative;width:100%;height:min(68vh,520px);min-height:300px;container-type:inline-size;container-name:side-panel;border-radius:var(--radius);background:#00000029;border:1px solid rgba(124,58,237,.14);box-shadow:inset 0 1px #ffffff08}.board-side-panel-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:1rem;text-align:center;color:var(--text-dim);font-size:.85rem}.board-ai-btn{width:auto;min-width:40px;height:40px;padding:0 .55rem;gap:.25rem;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background:#00000040;color:var(--text-muted);transition:border-color .2s,color .2s,background .2s}.board-ai-label{font-size:.72rem;font-weight:700;letter-spacing:.04em}.board-ai-btn:hover,.board-ai-btn.active{border-color:#22d3ee;color:#a5f3fc;background:#06b6d424}.ai-chat-panel{position:absolute;inset:0;z-index:10;width:100%;height:100%;max-height:none;display:flex;flex-direction:column;padding:0;overflow:hidden;box-shadow:none;border:none}.ai-chat-layout{display:grid;grid-template-columns:minmax(0,1fr) auto;height:100%;min-height:0;overflow:hidden}.ai-chat-history-rail{display:flex;flex-direction:row;align-items:stretch;min-height:0;height:100%;flex-shrink:0;overflow:hidden;width:0;opacity:0;pointer-events:none;transition:width .2s ease,opacity .2s ease}.ai-chat-history-rail.open{width:auto;opacity:1;pointer-events:auto}.ai-chat-history{display:flex;flex-direction:column;min-height:0;width:min(168px,36vw);border-left:1px solid var(--border);background:#0003;animation:ai-history-slide-in .18s ease}@keyframes ai-history-slide-in{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.ai-chat-history-header{display:flex;align-items:center;justify-content:space-between;gap:.35rem;padding:.55rem .6rem;border-bottom:1px solid var(--border);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.ai-chat-history-list{flex:1;min-height:0;overflow-y:auto;padding:.35rem;display:flex;flex-direction:column;gap:.25rem}.ai-chat-history-empty{margin:.5rem;font-size:.78rem;color:var(--text-dim)}.ai-history-item{display:flex;align-items:stretch;gap:.15rem;border-radius:8px;overflow:hidden}.ai-history-item.active{outline:1px solid rgba(34,211,238,.45)}.ai-history-select{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;padding:.45rem .5rem;border:none;background:transparent;color:var(--text);cursor:pointer;text-align:left}.ai-history-select:hover{background:#7c3aed1f}.ai-history-title{width:100%;font-size:.78rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ai-history-date{font-size:.68rem;color:var(--text-dim)}.ai-history-delete{width:28px;flex-shrink:0;border:none;background:transparent;color:var(--text-dim);cursor:pointer;opacity:0;transition:opacity .15s}.ai-history-item:hover .ai-history-delete,.ai-history-item.active .ai-history-delete{opacity:1}.ai-history-delete:hover{color:#f87171}.ai-chat-main{display:flex;flex-direction:column;flex:1;min-height:0;min-width:0;overflow:hidden;padding:.85rem .9rem .75rem;gap:.55rem}.ai-chat-header{display:flex;align-items:center;gap:.5rem;flex-shrink:0;padding-bottom:.55rem;border-bottom:1px solid rgba(34,211,238,.12)}.ai-chat-title-wrap{display:flex;align-items:center;gap:.55rem;flex:1;min-width:0}.ai-chat-icon{width:34px;height:34px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:.95rem;color:#a5f3fc;background:linear-gradient(135deg,#06b6d438,#7c3aed2e);border:1px solid rgba(34,211,238,.25)}.ai-chat-title{display:block;font-weight:700;font-size:.88rem;line-height:1.2}.ai-chat-subtitle{display:block;font-size:.68rem;color:var(--text-dim);margin-top:.1rem}.ai-chat-close{width:30px;height:30px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border);background:#0003;color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.ai-chat-close:hover{border-color:#f8717166;color:#fca5a5;background:#ef44441a}.ai-chat-header-actions{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.ai-settings-btn,.ai-history-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.2rem;width:30px;height:30px;padding:0;flex-shrink:0;border-radius:8px;border:1px solid var(--border);background:#00000038;color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.ai-settings-btn:hover,.ai-settings-btn.active{border-color:#a78bfa66;color:#c4b5fd;background:#7c3aed24}.ai-history-btn:hover,.ai-history-btn.active{border-color:#22d3ee59;color:#a5f3fc;background:#06b6d41f}.ai-history-count{position:absolute;top:-4px;right:-4px;min-width:.95rem;height:.95rem;padding:0 .2rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:700;background:#22d3eed9;color:#042f2e;border:1px solid rgba(0,0,0,.25)}.ai-chat-settings-popover{display:flex;flex-direction:column;gap:.45rem;flex-shrink:0;min-width:0;width:100%;padding:.65rem .7rem;border-radius:10px;background:#00000047;border:1px solid rgba(167,139,250,.2);box-shadow:0 8px 24px #00000040;animation:ai-settings-in .16s ease}@keyframes ai-settings-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ai-control-field{min-width:0;width:100%}.ai-control-field span{font-size:.68rem}.ai-control-select{width:100%;max-width:100%;min-width:0;box-sizing:border-box;padding:.45rem .55rem;border-radius:8px;border:1px solid var(--border);background:#0000004d;color:var(--text);font-size:.78rem;outline:none}.ai-model-row{display:flex;align-items:flex-end;gap:.35rem;min-width:0;width:100%;grid-column:1 / -1}.ai-model-row .ai-control-field{flex:1;min-width:0}.ai-other-btn{flex-shrink:0;height:2.05rem;padding:0 .55rem;font-size:.72rem;border:1px solid var(--border);border-radius:8px}.ai-other-btn.active{border-color:#22d3ee;color:#a5f3fc;background:#06b6d41f}.ai-chat-hint{font-size:.72rem;color:var(--text-dim);margin:0;flex-shrink:0;min-width:0;overflow-wrap:anywhere}.ai-chat-hint.warn{color:#fbbf24}.ai-chat-messages{flex:1;min-height:0;width:100%;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:.65rem;padding:.15rem .1rem;scrollbar-width:thin;scrollbar-color:rgba(34,211,238,.3) transparent}.ai-chat-empty-state{margin:auto 0;padding:1.25rem 1rem;text-align:center;border-radius:12px;border:1px dashed rgba(34,211,238,.2);background:#0000002e}.ai-chat-empty-icon{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;border-radius:12px;font-size:1.1rem;color:#a5f3fc;background:linear-gradient(135deg,#06b6d433,#7c3aed26);border:1px solid rgba(34,211,238,.22);margin-bottom:.65rem}.ai-chat-empty-title{margin:0 0 .4rem;font-size:.88rem;font-weight:700;color:var(--text)}.ai-chat-empty{font-size:.76rem;color:var(--text-dim);margin:0 0 .75rem;line-height:1.5}.ai-chat-empty-tips{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem;text-align:left}.ai-chat-empty-tips li{font-size:.72rem;color:var(--text-muted);padding:.35rem .55rem;border-radius:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.05)}.ai-chat-empty-tips li:before{content:"→ ";color:#22d3ee}.ai-msg-wrap{display:flex;flex-direction:column;gap:.2rem;max-width:94%}.ai-msg-wrap.user{align-self:flex-end;align-items:flex-end}.ai-msg-wrap.assistant{align-self:flex-start;align-items:flex-start}.ai-msg-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);padding:0 .25rem}.ai-msg-wrap.user .ai-msg-label{color:#c4b5fd}.ai-msg-wrap.assistant .ai-msg-label{color:#67e8f9}.ai-msg{font-size:.8rem;line-height:1.5;padding:.55rem .7rem;border-radius:12px;white-space:pre-wrap;word-break:break-word}.ai-msg.user{background:linear-gradient(135deg,#7c3aed59,#5b21b647);color:#f3e8ff;border:1px solid rgba(167,139,250,.25);border-radius:12px 12px 4px}.ai-msg.assistant{background:#0f172ab8;color:var(--text);border:1px solid rgba(34,211,238,.12);border-radius:12px 12px 12px 4px}.ai-msg.loading{opacity:.85;display:flex;align-items:center;gap:.45rem}.ai-typing-dots{display:inline-flex;gap:3px;align-items:center}.ai-typing-dots span{width:5px;height:5px;border-radius:50%;background:#22d3ee;animation:ai-dot-pulse 1.2s ease-in-out infinite}.ai-typing-dots span:nth-child(2){animation-delay:.15s}.ai-typing-dots span:nth-child(3){animation-delay:.3s}@keyframes ai-dot-pulse{0%,80%,to{opacity:.25;transform:scale(.85)}40%{opacity:1;transform:scale(1)}}.ai-chat-error{font-size:.72rem;color:#fca5a5;margin:0}.ai-chat-attachments{display:flex;flex-wrap:wrap;gap:.35rem;flex-shrink:0}.ai-chat-attachment{position:relative;width:52px;height:52px;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.ai-chat-attachment img{width:100%;height:100%;object-fit:cover}.ai-attachment-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border:none;border-radius:4px;background:#000000a6;color:#fff;font-size:.65rem;cursor:pointer}.ai-file-input{display:none}.ai-chat-composer{flex-shrink:0;padding:.55rem;border-radius:12px;background:#00000047;border:1px solid rgba(34,211,238,.14)}.ai-chat-input-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:.45rem;align-items:stretch;min-width:0;width:100%;box-sizing:border-box}.ai-attach-btn{align-self:stretch;min-width:2.4rem;padding:0;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background:#00000040;color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.ai-attach-btn:hover{border-color:#22d3ee59;color:#a5f3fc;background:#06b6d41a}.ai-chat-input-row textarea{width:100%;min-width:0;resize:none;min-height:2.85rem;max-height:5.5rem;padding:.55rem .7rem;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#00000052;color:var(--text);font-family:inherit;font-size:.82rem;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.ai-chat-input-row textarea:focus{outline:none;border-color:#22d3ee59;box-shadow:0 0 0 3px #06b6d41a}.ai-send-btn{align-self:stretch;min-width:4.6rem;padding:0 .85rem;border:none;border-radius:10px;font-size:.78rem;font-weight:700;cursor:pointer;color:#fff;background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 14px #7c3aed59;transition:opacity .15s,transform .15s}.ai-send-btn:hover:not(:disabled){transform:translateY(-1px)}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.profile-ai-settings{margin-bottom:0}.profile-ai-desc{font-size:.82rem;color:var(--text-dim);margin:0 0 .75rem;line-height:1.5}.profile-ai-desc a{color:#93c5fd}.profile-ai-grid{display:grid;gap:.65rem}.profile-ai-actions{display:flex;align-items:center;gap:.75rem;margin-top:.75rem}.profile-ai-msg{font-size:.78rem;color:var(--text-dim)}.manager-editor.filter-focus-active{position:relative}.filter-focus-overlay{position:absolute;inset:0;z-index:40;border:none;padding:0;margin:0;cursor:default;background:#06040e80;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:filter-focus-in .2s ease;border-radius:inherit}@keyframes filter-focus-in{0%{opacity:0;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0)}to{opacity:1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}}.manager-editor.filter-focus-active .board-toolbar-buttons{position:absolute;top:calc(-40px - .5rem);right:0;z-index:51;filter:none;opacity:1;pointer-events:auto}.manager-editor.filter-focus-active .board-side-panel-body{height:min(68vh,520px);min-height:300px}.manager-editor.filter-focus-active .board-settings-panel{z-index:51;filter:none;opacity:1;pointer-events:auto}.board-settings-panel{position:absolute;top:.5rem;right:0;left:auto;z-index:2;width:min(100%,300px);min-width:260px;max-height:min(68vh,520px);overflow-y:auto;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.65rem;box-shadow:0 16px 48px #00000073}.settings-accordion{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .75rem;border-radius:8px;border:1px solid var(--border);background:#0003;color:var(--text);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:border-color .2s,background .2s}.settings-accordion:hover,.settings-accordion.active{border-color:var(--accent);background:#7c3aed1a}.settings-accordion-body{margin-top:.5rem}.pin-accordion-body{display:flex;flex-direction:column;gap:.75rem}.pin-row-inset-settings{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.5rem}.pin-row-inset-settings input[type=range]{width:100%}.pin-row-counts{display:flex;flex-direction:column;gap:.45rem;margin-top:.65rem}.pin-row-count-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem}.pin-row-count-item{display:flex;align-items:center;gap:.3rem;font-size:.78rem}.pin-row-count-item>span{min-width:1rem;color:var(--text-muted)}.settings-hint{margin:0;font-size:.72rem;color:var(--text-muted);line-height:1.35}.pin-label.on-board{fill:#ffffffeb}.pin-label-settings{display:flex;flex-direction:column;gap:.45rem}.pin-label-toggles{display:flex;flex-wrap:wrap;gap:.35rem}.accordion-chevron{flex-shrink:0;transition:transform .2s}.accordion-chevron.open{transform:rotate(180deg)}.size-field{display:flex;align-items:flex-end;gap:.25rem}.size-reset-btn{min-width:32px;height:32px;padding:0;font-size:1rem;line-height:1}.size-section{display:flex;flex-direction:column;gap:.5rem}.mirror-btn{align-self:flex-start;border:1px solid var(--border);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.mirror-btn.active{border-color:var(--accent);color:#c4b5fd;background:#7c3aed26}.board-canvas-container{width:100%;max-width:360px;height:min(68vh,520px);min-height:300px;margin:0;display:flex;align-items:center;justify-content:center;padding:1.25rem;border-radius:var(--radius);background:radial-gradient(ellipse at 50% 30%,#7c3aed14,#00000047);border:1px solid rgba(124,58,237,.18);box-shadow:inset 0 1px #ffffff08}.board-canvas-container.wokwi-canvas{width:auto;height:auto;max-width:100%;max-height:min(78vh,620px);min-width:200px;min-height:200px}.board-canvas-container.wokwi-canvas .board-canvas-scaler{width:100%;height:100%}.board-canvas-scaler{width:auto;height:auto;max-width:100%;max-height:100%}.board-canvas{width:100%;height:100%;display:block;cursor:crosshair;border-radius:var(--radius)}.board-body{fill:#1a1a2e;stroke:#7c3aed80;stroke-width:2}.board-label{font-family:var(--font-display);pointer-events:none}.board-label-sub{font-family:var(--font);pointer-events:none}.edge-zone{fill:transparent;cursor:copy}.edge-zone.edge-l:hover{fill:#06b6d414}.edge-zone.edge-r:hover{fill:#7c3aed14}.edge-zone.edge-t:hover{fill:#10b98114}.edge-zone.edge-b:hover{fill:#ec489914}.resize-corner{fill:#7c3aedb3;stroke:#fff;stroke-width:1.5;cursor:nwse-resize}.resize-edge{fill:#06b6d4bf;stroke:#fff;stroke-width:1.5}.pin-quick-box{background:#0d0d14f2;border:1px solid var(--accent);border-radius:10px;padding:.6rem;display:flex;flex-direction:column;gap:.4rem;box-shadow:0 8px 30px #00000080}.pin-quick-title{font-size:.75rem;font-weight:600;color:#c4b5fd}.pin-quick-box input,.pin-quick-box select{padding:.4rem .5rem;border-radius:6px;border:1px solid var(--border);background:#0006;color:var(--text);font-size:.8rem}.pin-quick-actions{display:flex;gap:.35rem}.settings-label.span-row{width:100%;margin-bottom:.25rem}.color-picker{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}.color-swatch{width:32px;height:32px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s}.color-swatch:hover{transform:scale(1.08)}.color-swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--accent)}.color-custom{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-muted);cursor:pointer}.color-custom input[type=color]{width:32px;height:32px;border:none;border-radius:8px;padding:0;background:none;cursor:pointer}.color-code-row{display:flex;align-items:flex-end;gap:.5rem;margin-top:.5rem}.color-code-input{flex:1;min-width:0}.color-code-input input{width:100%;font-family:ui-monospace,monospace;font-size:.8rem}.color-code-preview{width:32px;height:32px;border-radius:8px;border:2px solid var(--border);flex-shrink:0}.settings-label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:.35rem}.side-toggles{display:flex;flex-wrap:wrap;gap:.35rem}.side-toggle{padding:.35rem .65rem;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer}.side-toggle.active{border-color:var(--accent);background:#7c3aed26;color:#c4b5fd}.side-toggle.all{border-color:var(--accent-2);color:#67e8f9}.toggle-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted);cursor:pointer}.bulk-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.bulk-row select,.bulk-count{padding:.4rem .6rem;border-radius:6px;border:1px solid var(--border);background:#0000004d;color:var(--text);font-size:.85rem}.bulk-count{width:64px}.size-row{display:flex;align-items:flex-end;gap:.75rem;flex-wrap:wrap}.input-group.compact input{width:90px}.chip-side.t{color:#6ee7b7}.chip-side.b{color:#f9a8d4}.board-pin{cursor:grab}.board-pin.selected circle{filter:drop-shadow(0 0 6px rgba(255,255,255,.5))}.wokwi-board-model{pointer-events:none}.wokwi-board-model text,.wokwi-board-model #pin-labels{display:none}.wokwi-board-model.labels-on-board #pin-labels,.wokwi-board-model.labels-on-board #pin-labels text,.wokwi-board-model.labels-on-board #pin-labels tspan{display:inline}.wokwi-pin-layer{pointer-events:none}.wokwi-pin{pointer-events:all;cursor:pointer}.wokwi-pin-hit{pointer-events:all}.wokwi-pin-dot{pointer-events:none;opacity:.92}.wokwi-pin-dot.emphasized{opacity:1}.wokwi-pin.project-pin.wire-source .wokwi-pin-dot{stroke:#fbbf24;stroke-width:.5px}.wokwi-pin.project-pin.wire-target .wokwi-pin-dot{stroke:#38bdf8;stroke-width:.45px;filter:drop-shadow(0 0 .5px rgba(56,189,248,.7))}.wokwi-pin.project-pin{cursor:pointer}.wokwi-pin.project-pin.wire-snap-target .wokwi-pin-dot{stroke:#38bdf8;stroke-width:.65px;filter:drop-shadow(0 0 1px rgba(56,189,248,.95))}.wokwi-pin-label{fill:var(--text);font-size:1.75px;font-weight:600;font-family:ui-monospace,monospace;pointer-events:none}.wokwi-pin-label.on-board{font-size:1.35px;fill:#f0f0f0;stroke:#000000bf;stroke-width:.18px;paint-order:stroke fill}.board-folder-add{min-width:2rem;padding-inline:.45rem}.board-folder-section,.default-boards-section{margin-top:.5rem}.default-boards-section{padding-bottom:.65rem;margin-bottom:.5rem;border-bottom:1px solid var(--border)}.board-folder-toggle{display:flex;align-items:center;gap:.35rem;width:100%;padding:.55rem .65rem;border:1px solid transparent;border-radius:var(--radius-sm);background:#7c3aed0f;color:var(--text);cursor:pointer;text-align:left;font-size:.82rem;font-weight:600;transition:background .15s,border-color .15s}.board-folder-toggle:hover{background:#7c3aed1f;border-color:#7c3aed38}.board-folder-toggle.open,.board-folder-toggle.active{background:#7c3aed29;border-color:#7c3aed59}.board-folder-chevron{width:.85rem;color:#c4b5fd;flex-shrink:0}.board-folder-icon{flex-shrink:0;font-size:.9rem}.board-folder-name{flex:1;text-align:left;font-size:.8rem}.default-boards-section .board-folder-name{text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;color:var(--text-dim)}.board-folder-count{font-size:.72rem;color:var(--text-dim);font-weight:500}.board-folder-panel{margin-top:.25rem;padding-left:.35rem;max-height:min(48vh,380px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(124,58,237,.35) transparent}.board-folder-panel.flat{max-height:none;overflow:visible}.default-boards-section .board-folder-panel{max-height:min(52vh,420px)}.board-folder-panel .list-item{padding-left:.5rem}.board-folder-move{max-width:280px;margin-bottom:.5rem}.board-folder-move select{width:100%}.wokwi-pin.selected .wokwi-pin-label{fill:#fff;font-weight:700}.wokwi-pin-focus-ring{pointer-events:none;filter:drop-shadow(0 0 .4px rgba(255,255,255,.8))}.board-canvas.wokwi-model{overflow:visible}.pin-label{fill:var(--text);font-size:9px;font-weight:600;pointer-events:none}.pin-role{fill:var(--text-dim);font-size:7px;pointer-events:none}.resize-handle{cursor:nwse-resize}.resize-handle rect{fill:#7c3aed99}.resize-handle path{stroke:#fff;stroke-width:1.5;fill:none}.canvas-legend{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.legend-item{display:flex;align-items:center;gap:.35rem}.legend-item .dot{width:8px;height:8px;border-radius:50%;display:inline-block}.role-legend-item{position:relative;cursor:help}.role-legend-label{border-bottom:1px dotted rgba(255,255,255,.25)}.role-tooltip{position:absolute;left:50%;bottom:calc(100% + .45rem);transform:translate(-50%);min-width:200px;max-width:260px;padding:.45rem .6rem;border-radius:8px;background:#0a0a12f5;border:1px solid var(--border-bright);color:var(--text);font-size:.72rem;line-height:1.35;text-align:center;box-shadow:0 8px 24px #00000073;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s,visibility .15s;z-index:40}.role-legend-item:hover .role-tooltip,.role-legend-item:focus-within .role-tooltip{opacity:1;visibility:visible}.pin-colors-section{display:flex;flex-direction:column;gap:.5rem}.pin-colors-header{display:flex;align-items:center;justify-content:flex-end;gap:.5rem}.auth-loading{padding:2rem;text-align:center;color:var(--text-muted)}.pin-colors-grid{display:flex;flex-direction:column;gap:.35rem}.pin-color-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.5rem;padding:.35rem .45rem;border-radius:8px;border:1px solid var(--border);background:#0003}.pin-color-label{font-size:.78rem;color:var(--text)}.pin-color-row input[type=color]{width:32px;height:28px;border:none;border-radius:6px;padding:0;background:none;cursor:pointer}.pin-color-row .role-tooltip{left:0;transform:none;min-width:180px}.legend-item.muted{color:var(--text-dim)}.pins-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.size-label{margin-left:auto;font-size:.75rem;color:var(--text-dim);font-family:SF Mono,Fira Code,monospace}.pin-editor{padding:1rem;margin-bottom:.75rem}.pin-editor-side{position:absolute;inset:0;margin-bottom:0;padding:.65rem .75rem;overflow:hidden;display:flex;flex-direction:column;gap:.25rem}.pin-editor-side .pin-editor-grid{flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding-right:.15rem}.pin-editor-side h4{margin:0 0 .35rem;font-size:.82rem}.pin-editor-side .input-group{gap:.2rem;min-width:0}.pin-editor-side .input-group span{font-size:.72rem;line-height:1.25;overflow-wrap:anywhere}.pin-editor-side .input-group input,.pin-editor-side select{padding:.45rem .55rem;font-size:.82rem;min-width:0}.pin-editor-side .pin-editor-grid{gap:.5rem;margin-bottom:.35rem}.pin-editor-side .pin-editor-actions{flex-shrink:0;margin-top:0;padding-top:.4rem;border-top:1px solid rgba(124,58,237,.12)}.pin-editor-side .pin-editor-inner-shifts{display:grid;grid-template-columns:1fr 1fr;gap:.35rem;grid-column:1 / -1}.pin-editor-side-inner .pin-editor-grid{gap:.35rem}.pin-editor-side-inner .input-group input[type=range]{height:1.1rem}.pin-editor-side-inner .pin-editor-actions{gap:.35rem}.pin-editor-side-inner .pin-editor-actions .btn{flex:1 1 auto;min-width:0;white-space:nowrap}.board-workspace.ai-open .pin-editor-side .pin-editor-grid{grid-template-columns:1fr;gap:.4rem}.board-workspace.ai-open .pin-editor-side .pin-editor-grid .span-2{grid-column:span 1}@container side-panel (max-width: 340px){.pin-editor-side .pin-editor-grid{grid-template-columns:1fr;gap:.4rem}.pin-editor-side .pin-editor-grid .span-2{grid-column:span 1}}.pin-editor h4{margin:0 0 .75rem;font-size:.9rem}.pin-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.75rem}.pin-editor-actions{display:flex;flex-wrap:wrap;gap:.5rem}.pin-editor-grid .span-2{grid-column:span 2}.pin-editor select{padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#0000004d;color:var(--text);font-size:.95rem;outline:none}.pin-editor input[type=range]{width:100%;accent-color:var(--accent)}.pins-list-compact{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.board-layout .manager-actions{padding-top:.5rem;border-top:1px solid rgba(124,58,237,.1);margin-top:.25rem}.board-layout .pin-chip{background:#00000038;border-color:#ffffff14}.board-layout .pin-chip.active{background:#7c3aed2e;border-color:#a78bfa59;box-shadow:0 0 12px #7c3aed26}.pin-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;border-radius:999px;border:1px solid var(--border);background:#0003;color:var(--text);font-size:.8rem;cursor:pointer}.pin-chip.active{border-color:var(--accent);background:#7c3aed26}.chip-side{font-weight:700;font-size:.7rem;padding:.1rem .35rem;border-radius:4px;background:#ffffff14}.chip-side.l{color:#67e8f9}.chip-side.r{color:#c4b5fd}.chip-role{font-size:.65rem;padding:.1rem .35rem;border-radius:4px}.chip-role.power{background:#f59e0b26;color:#fbbf24}.chip-role.ground{background:#9ca3af26;color:#d1d5db}.chip-role.digital{background:#06b6d426;color:#67e8f9}.chip-role.analog{background:#a855f726;color:#c084fc}.chip-role.clock{background:#22c55e26;color:#4ade80}.chip-role.control{background:#f472b626;color:#f9a8d4}@media (max-width: 1024px){.layout-grid{grid-template-columns:1fr}.auth-split{grid-template-columns:1fr;padding-top:1rem}.auth-promo{text-align:center}.auth-perks{align-items:center}.stats-row{grid-template-columns:repeat(2,1fr)}.manager-body,.profile-sections,.profile-layout{grid-template-columns:1fr}.profile-sidebar{position:static}.form-row{grid-template-columns:1fr}.connection-row{grid-template-columns:1fr 1fr}.conn-arrow{display:none}}@media (max-width: 640px){.landing-nav,.app-header{flex-wrap:wrap;gap:.75rem}.app-nav{order:3;width:100%;justify-content:center}.hero-cta{flex-direction:column;align-items:center}.stats-row{grid-template-columns:repeat(2,1fr)}}
