.navbar{position:fixed;width:100%;top:0;left:0;background:#0b1426d1;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(59,130,246,.08);z-index:100}.nav-inner{width:100%;max-width:1440px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;height:64px;padding:0 16px}@media(min-width:640px){.nav-inner{padding:0 24px}}@media(min-width:1024px){.nav-inner{padding:0 48px}}@media(min-width:1280px){.nav-inner{padding:0 80px}}@media(min-width:1536px){.nav-inner{padding:0 120px}}.logo-link{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.logo-img{height:36px;width:auto}@media(min-width:640px){.logo-img{height:60px}}.nav-links{display:flex;align-items:center;gap:32px}@media(min-width:1024px){.nav-links{gap:40px}}.nav-links a{color:#94a3b8;text-decoration:none;font-size:14px;font-weight:500;transition:color .2s ease;position:relative;white-space:nowrap}.nav-links a:hover{color:#e6edf7}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:#2563eb;transition:width .2s ease}.nav-links a:hover:after{width:100%}.footer{padding:48px 0;border-top:1px solid rgba(59,130,246,.1);text-align:center;color:#64748b;font-size:13px;background:#070c18}.home{padding-top:64px}.hero{min-height:50vh;display:flex;align-items:center;padding:80px 0 40px}.hero-inner{text-align:center;max-width:720px}.hero h1{font-size:48px;line-height:1.15;margin-bottom:20px;letter-spacing:-.5px}.hero-subtitle{color:#94a3b8;font-size:17px;margin-bottom:36px;line-height:1.7}.hero-actions button{padding:14px 36px;font-size:16px;width:auto}.section-sm{padding:48px 0}.features-grid{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}.feature-card{background:#101b33;padding:32px;border-radius:16px;width:300px;border:1px solid rgba(59,130,246,.15);box-shadow:0 2px 16px #00000026;transition:border-color .2s ease}.feature-card:hover{border-color:#3b82f64d}.feature-card h3{font-size:16px;margin-bottom:12px;color:#e6edf7}.feature-card p{color:#94a3b8;font-size:14px;line-height:1.7}.note-box{text-align:center;max-width:700px;margin:0 auto;background:#2563eb14;border:1px solid rgba(59,130,246,.15);border-radius:12px;padding:20px 32px;color:#94a3b8;font-size:14px;line-height:1.7}.note-box strong{color:#60a5fa;font-weight:600}.visualizer-page{min-height:calc(100vh - 80px);background:linear-gradient(135deg,#0a0e1a,#0f1628,#0a1020);padding:0}.upload-section{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 80px);padding:2rem;gap:1.5rem}.upload-hero{text-align:center;max-width:600px}.upload-icon{font-size:4rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.upload-hero h1{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#60a5fa,#a78bfa,#f472b6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.75rem}.upload-subtitle{color:#ffffff8c;font-size:1rem;line-height:1.6}.drop-zone{width:100%;max-width:480px;border:2px dashed rgba(96,165,250,.3);border-radius:16px;padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:#ffffff05}.drop-zone:hover{border-color:#60a5fa99;background:#60a5fa0d;transform:translateY(-2px)}.drop-zone.has-file{border-color:#34d39980;background:#34d3990d}.drop-prompt .drop-icon{font-size:2.5rem;display:block;margin-bottom:.75rem}.drop-prompt p{color:#fff9;margin-bottom:.5rem}.drop-hint{color:#ffffff4d;font-size:.85rem}.file-preview{display:flex;align-items:center;justify-content:center;gap:.5rem}.file-icon{font-size:1.5rem}.file-name{color:#34d399;font-weight:600}.file-size{color:#fff6;font-size:.9rem}.upload-btn,.generate-btn{padding:.9rem 2.5rem;font-size:1.05rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;color:#fff;width:100%;max-width:480px}.upload-btn{background:linear-gradient(135deg,#3b82f6,#8b5cf6)}.upload-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #3b82f659}.generate-btn{background:linear-gradient(135deg,#10b981,#059669)}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #10b98159}.upload-btn:disabled,.generate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.download-btn{display:block;text-align:center;padding:.9rem 2rem;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;text-decoration:none;border-radius:12px;font-weight:600;font-size:1.05rem;margin-top:.75rem;transition:all .3s ease}.download-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #6366f159}.back-btn{width:100%;padding:.7rem;background:transparent;border:1px solid rgba(255,255,255,.1);color:#ffffff80;border-radius:10px;cursor:pointer;font-size:.9rem;transition:all .3s;margin-top:.5rem}.back-btn:hover{border-color:#ffffff4d;color:#fffc}.error-message{color:#f87171;background:#f8717114;border:1px solid rgba(248,113,113,.2);border-radius:10px;padding:.75rem 1rem;font-size:.9rem;width:100%}.loading-spinner{animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.workspace-layout{display:grid;grid-template-columns:1fr 380px;height:calc(100vh - 80px);gap:0}.visualizer-panel{display:flex;flex-direction:column;background:#080c18;border-right:1px solid rgba(255,255,255,.06)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06);background:#ffffff05}.panel-header h2{font-size:1rem;font-weight:600;color:#e2e8f0;margin:0}.viewer-badge{font-size:.7rem;padding:.25rem .6rem;background:#60a5fa1a;border:1px solid rgba(96,165,250,.2);border-radius:20px;color:#60a5fa;font-weight:500}.viser-iframe{flex:1;width:100%;border:none;background:#000}.viewer-placeholder{flex:1;display:flex;align-items:center;justify-content:center;color:#ffffff4d;font-size:.95rem;padding:2rem;text-align:center}.config-panel{display:flex;flex-direction:column;background:#0f1423f2;overflow:hidden}.config-scroll{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.config-scroll::-webkit-scrollbar{width:4px}.config-scroll::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.config-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:1rem}.config-card h3{font-size:.9rem;font-weight:600;color:#e2e8f0;margin:0 0 .75rem}.card-hint{font-size:.75rem;color:#ffffff59;margin:-.5rem 0 .75rem}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.7rem;color:#fff6;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:.9rem;color:#e2e8f0;font-weight:500}.info-value.mono{font-family:JetBrains Mono,monospace;font-size:.8rem}.config-input{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.4rem .6rem;color:#e2e8f0;font-size:.85rem;width:100%;box-sizing:border-box;transition:border-color .2s}.config-input:focus{outline:none;border-color:#60a5fa80}.group-item{background:#60a5fa0a;border:1px solid rgba(96,165,250,.1);border-radius:10px;padding:.75rem;margin-bottom:.5rem;transition:all .3s}.group-item.excluded{opacity:.4;border-color:#ffffff0d;background:#ffffff03}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.toggle-label{display:flex;align-items:center;gap:.5rem;color:#fffc;font-size:.85rem;cursor:pointer}.toggle-label input[type=checkbox]{accent-color:#60a5fa}.group-name-input{background:transparent;border:1px solid transparent;color:#e2e8f0;font-size:.85rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;width:120px;transition:border-color .2s}.group-name-input:focus{outline:none;border-color:#60a5fa66;background:#ffffff08}.group-badge{font-size:.65rem;padding:.15rem .5rem;border-radius:10px;font-weight:600;white-space:nowrap}.group-badge.chain{background:#60a5fa1f;color:#60a5fa}.group-badge.parallel_gripper{background:#f472b61f;color:#f472b6}.group-badge.joints{background:#fbbf241f;color:#fbbf24}.group-details{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.detail-item{font-size:.75rem;color:#ffffff73}.detail-item strong{color:#fff9}.group-joints-list{display:flex;flex-wrap:wrap;gap:.3rem}.joint-tag{font-size:.65rem;padding:.15rem .4rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:4px;color:#ffffff80;font-family:JetBrains Mono,monospace}.config-row{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.75rem}.config-label{font-size:.75rem;color:#ffffff80;font-weight:500}.config-select{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.5rem .6rem;color:#e2e8f0;font-size:.85rem;cursor:pointer;transition:border-color .2s}.config-select:focus{outline:none;border-color:#60a5fa80}.config-select option{background:#1a1f35;color:#e2e8f0}.generate-section{display:flex;flex-direction:column;gap:.5rem}@media(max-width:900px){.workspace-layout{grid-template-columns:1fr;grid-template-rows:50vh auto}.visualizer-panel{border-right:none;border-bottom:1px solid rgba(255,255,255,.06)}}.robot-type-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:.2rem .55rem;border-radius:20px;white-space:nowrap}.robot-type-badge.support-full{background:#34d3991f;border:1px solid rgba(52,211,153,.3);color:#34d399}.robot-type-badge.support-partial{background:#fbbf241f;border:1px solid rgba(251,191,36,.3);color:#fbbf24}.robot-type-badge.support-limited{background:#f871711f;border:1px solid rgba(248,113,113,.3);color:#f87171}.support-warning{display:flex;align-items:flex-start;gap:.75rem;padding:.9rem 1rem;border-radius:12px;font-size:.82rem;line-height:1.55}.support-warning .warning-icon{font-size:1.15rem;flex-shrink:0;margin-top:.05rem}.support-warning div{flex:1}.support-warning strong{display:block;font-size:.85rem;margin-bottom:.3rem}.support-warning p{margin:0;opacity:.85}.support-warning.full{background:#34d39912;border:1px solid rgba(52,211,153,.2);color:#a7f3d0}.support-warning.full strong{color:#34d399}.support-warning.partial{background:#fbbf2412;border:1px solid rgba(251,191,36,.2);color:#fde68a}.support-warning.partial strong{color:#fbbf24}.support-warning.limited{background:#f8717112;border:1px solid rgba(248,113,113,.2);color:#fecaca}.support-warning.limited strong{color:#f87171}.about{padding-top:120px;padding-bottom:80px}.about h1{font-size:36px;margin-bottom:24px;color:#e6edf7}.about h2{font-size:22px;margin-top:48px;margin-bottom:16px;color:#e6edf7;position:relative;padding-left:16px}.about h2:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;background:#2563eb;border-radius:2px}.about p{color:#94a3b8;margin-bottom:16px;max-width:750px;line-height:1.8;font-size:15px}.about .intro{font-size:17px;color:#94a3b8;margin-bottom:24px}.about .highlight{font-size:18px;font-weight:600;color:#2563eb;margin:28px 0}.about ul{max-width:750px;padding-left:24px;margin-bottom:20px}.about li{color:#94a3b8;font-size:14px;line-height:2.2}.about .focus-list li{color:#94a3b8;font-size:15px}.about .feature-list li{list-style-type:none;position:relative;padding-left:4px}.about .feature-list li:before{content:"→";position:absolute;left:-20px;color:#2563eb;font-weight:600}.about .audience-list li{list-style-type:disc}.about .audience-list li::marker{color:#64748b}.about .vision-closing{margin-top:24px;font-style:italic;color:#94a3b8;font-size:16px;line-height:1.9;border-left:2px solid rgba(37,99,235,.3);padding-left:20px}body{margin:0;background:linear-gradient(180deg,#0f1e3a,#0b1426,#070c18);background-attachment:fixed;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#e6edf7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{max-width:1152px;margin:0 auto;padding:0 24px}h1{margin:0;font-weight:700;color:#e6edf7}h2,h3{margin:0;font-weight:600;color:#e6edf7}p{margin:0;line-height:1.7}button{font-family:Inter,sans-serif;padding:12px 32px;background:#2563eb;border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s ease,box-shadow .2s ease;box-shadow:0 2px 8px #2563eb40}button:hover{background:#1d4ed8;box-shadow:0 4px 16px #2563eb59}button:disabled{opacity:.6;cursor:not-allowed}.card{background:#101b33;padding:40px;border-radius:16px;border:1px solid rgba(59,130,246,.15);box-shadow:0 4px 24px #0003}label{font-size:13px;font-weight:500;margin-bottom:6px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}input,select{padding:11px 14px;background:#0b1426;border:1px solid rgba(59,130,246,.2);border-radius:8px;color:#e6edf7;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s ease}input:focus,select:focus{outline:none;border-color:#2563eb}a{color:#2563eb;text-decoration:none;transition:color .2s ease}a:hover{color:#3b82f6}.field{margin-bottom:20px;display:flex;flex-direction:column}.subtitle{margin-bottom:24px;color:#94a3b8;font-size:15px}.status{margin-top:20px;font-size:14px;color:#94a3b8}.download{display:block;margin-top:16px;text-align:center;color:#2563eb;text-decoration:none;font-weight:600;font-size:14px}.download:hover{color:#3b82f6}.generator-page{padding-top:96px;padding-bottom:80px;min-height:100vh}.generator-page .app{display:flex;justify-content:center;align-items:flex-start}.generator-page .card{width:640px;max-width:90vw}.generator-page h1{font-size:24px;letter-spacing:.3px;margin-bottom:4px}.generator-page button{width:100%}.instructions{margin-bottom:24px}.instructions h3{font-size:14px;font-weight:600;margin-bottom:20px;color:#2563eb;text-transform:uppercase;letter-spacing:.8px}.instruction-steps{display:flex;flex-direction:column;gap:20px}.step{display:flex;gap:14px;align-items:flex-start}.step-num{background:#2563eb;color:#fff;font-weight:700;font-size:12px;width:24px;height:24px;min-width:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:2px}.step p{color:#94a3b8;font-size:13px;margin:4px 0;line-height:1.6}.step strong{color:#e6edf7;font-size:14px}.step ul{margin:6px 0 0;padding-left:18px;color:#94a3b8;font-size:13px;line-height:1.8}.step code{background:#2563eb1f;padding:2px 7px;border-radius:4px;font-size:12px;color:#60a5fa;font-family:SF Mono,Fira Code,monospace}.divider{border:none;border-top:1px solid rgba(59,130,246,.12);margin:28px 0}.support-page{padding-top:96px;padding-bottom:80px;min-height:100vh}.support-container{display:flex;justify-content:center;align-items:flex-start}.support-container .card{width:560px;max-width:90vw}.support-container h1{font-size:24px;margin-bottom:4px}.support-form{margin-top:8px}.support-form textarea{width:100%;padding:11px 14px;background:#0b1426;border:1px solid rgba(59,130,246,.2);border-radius:8px;color:#e6edf7;font-family:Inter,sans-serif;font-size:14px;resize:vertical;min-height:100px;transition:border-color .2s ease;box-sizing:border-box}.support-form textarea:focus{outline:none;border-color:#2563eb}.support-form button{width:100%;margin-top:4px}.optional{font-weight:400;color:#64748b;text-transform:none;letter-spacing:0}.file-hint{font-size:12px;color:#64748b;margin-top:4px}.status-msg{margin-top:20px;padding:12px 16px;border-radius:8px;font-size:14px;text-align:center}.status-msg.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.25);color:#4ade80}.status-msg.error{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#f87171}html,body,#root{height:100%;margin:0}*{box-sizing:border-box}body{margin:0;background-color:#0f1117;color:#e6e9f2;font-family:Inter,sans-serif}.container{max-width:1200px;margin:0 auto;padding:0 24px}.section{padding:120px 0}.section-sm{padding:80px 0}
