:root,[data-theme=dark]{--bg:#0d1117;--bg-1:#161b22;--bg-2:#1c2128;--bg-hover:#21262d;--border:#30363d;--border-hi:#6e7681;--text:#e6edf3;--text-2:#adb5bd;--text-3:#768390;--brand:#818cf8;--brand-dim:#818cf829;--brand-fg:#0d1117;--blue:#79c0ff;--blue-dim:#79c0ff24;--green:#56d364;--green-dim:#56d36424;--red:#ff7b72;--red-dim:#ff7b7224;--yellow:#e3b341;--brand-hover:#6366f1;--blue-hover:#8dc4ff;--green-hover:#3fb950;--red-hover:#ff7b7247;--btn-fg:#0d1117;--btn-fg-white:#fff;--r-sm:6px;--r-md:10px;--r-lg:16px;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif;--mono:"Geist Mono", ui-monospace, "Menlo", "Monaco", monospace;--shadow:0 8px 32px #0009;--header-h:48px;--log-h:180px}[data-theme=light]{--bg:#f9fafb;--bg-1:#fff;--bg-2:#eef1f5;--bg-hover:#e2e6eb;--border:#d0d7de;--border-hi:#aab3bb;--text:#1f2328;--text-2:#3d444d;--text-3:#5e6673;--brand:#6366f1;--brand-dim:#6366f11f;--brand-fg:#fff;--blue:#0969da;--blue-dim:#0969da1a;--green:#1a7f37;--green-dim:#1a7f371a;--red:#cf222e;--red-dim:#cf222e1a;--yellow:#9a6700;--shadow:0 4px 18px #0000001f;--brand-hover:#4f46e5;--blue-hover:#0558c4;--green-hover:#2c974b;--red-hover:#cf222e2e;--btn-fg:#fff;--btn-fg-white:#fff}[data-theme=light] .cm-wrap{background:var(--bg-1)}[data-theme=light] .cm-editor{--cm-active-line:#0000000a;color:var(--text)}[data-theme=dark] .cm-editor,:root .cm-editor{--cm-active-line:#ffffff08}[data-theme=light] .log-content{background:var(--bg)}[data-theme=light] .pdf-frame{background:var(--bg-2)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;min-height:0}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:0}input,textarea,select{font:inherit}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hi)}.icon-btn{border-radius:var(--r-sm);width:30px;height:30px;color:var(--text-2);justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.icon-btn.icon-btn--text{width:auto;padding:0 6px}.icon-btn:hover{background:var(--bg-hover);color:var(--text)}.icon-btn.active{background:var(--brand-dim);color:var(--brand)}.pill{background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.pill.green{background:var(--green-dim);border-color:var(--green);color:var(--green)}.pill.red{background:var(--red-dim);border-color:var(--red);color:var(--red)}.pill.blue{background:var(--blue-dim);border-color:var(--blue);color:var(--blue)}.pill.brand{background:var(--brand-dim);border-color:var(--brand);color:var(--brand)}.presence-wrap{display:inline-flex;position:relative}.presence-pill-btn{cursor:pointer;border:1px solid var(--blue);font:inherit;transition:background .12s,box-shadow .12s}.presence-pill-btn:hover,.presence-pill-btn.active{background:var(--blue-dim);box-shadow:0 0 0 2px #3b82f633}.presence-menu{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-md);min-width:220px;max-width:280px;max-height:280px;box-shadow:var(--shadow);z-index:1000;padding:6px;animation:.18s cubic-bezier(.2,.7,.2,1) actionsMenuIn;position:absolute;top:calc(100% + 6px);right:0;overflow-y:auto}.presence-menu-title{text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);padding:6px 10px 8px;font-size:11px;font-weight:700}.presence-menu-list{margin:0;padding:0;list-style:none}.presence-menu-item{border-radius:var(--r-sm);align-items:center;gap:10px;padding:8px 10px;display:flex}.presence-avatar{background:var(--brand-dim);width:28px;height:28px;color:var(--brand);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.presence-meta{flex-direction:column;gap:2px;min-width:0;display:flex}.presence-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.presence-you{color:var(--text-3);font-weight:500}.presence-email{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.presence-mobile-block{padding:8px 12px 4px}.presence-mobile-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);margin-bottom:6px;font-size:11px;font-weight:700}.presence-mobile-names{color:var(--text-2);font-size:13px;line-height:1.45}.btn{border-radius:var(--r-sm);white-space:nowrap;cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;transition:background .12s,border-color .12s,opacity .12s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{color:var(--text-2);border-color:var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.btn-primary{color:var(--brand-fg);background:var(--brand);border-color:var(--brand)}.btn-primary:hover:not(:disabled){background:#6366f1}.btn-blue{color:var(--btn-fg-white);background:var(--blue);border-color:var(--blue)}.btn-blue:hover:not(:disabled){background:var(--blue-hover)}.btn-danger{color:var(--red);border-color:var(--red-dim);background:var(--red-dim)}.btn-danger:hover:not(:disabled){background:var(--red-hover);color:var(--btn-fg-white)}.btn-compile{color:#fff;background:var(--green);border-color:var(--green);padding:6px 18px;font-size:13px;font-weight:700}.btn-compile:hover:not(:disabled){background:var(--green-hover)}.btn-compile.compiling{background:var(--yellow);border-color:var(--yellow);opacity:.9;animation:1.4s ease-in-out infinite pulse}.btn-compile.error{background:var(--red);border-color:var(--red)}@keyframes pulse{0%,to{opacity:.9}50%{opacity:.7}}.input{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-2);width:100%;color:var(--text);outline:none;padding:8px 12px;font-size:14px;transition:border-color .15s}.input:focus{border-color:var(--blue)}.input::placeholder{color:var(--text-3)}select.input.invite-role-select{appearance:none;cursor:pointer;background-color:var(--bg-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 7px center;background-repeat:no-repeat;background-size:14px;flex-shrink:0;width:102px;padding:7px 22px 7px 9px}[data-theme=light] select.input.invite-role-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}.toast{z-index:9999;box-shadow:var(--shadow);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:600;animation:.2s ease-out slideUp;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast.success{background:var(--green);color:var(--btn-fg)}.toast.error{background:var(--red);color:var(--bg-1)}.toast.info{background:var(--blue);color:var(--bg-1)}@keyframes slideUp{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.auth-page{background:var(--bg);grid-template-columns:1fr 480px;min-height:100vh;display:grid}.auth-hero{background:var(--bg-1);border-right:1px solid var(--border);flex-direction:column;justify-content:center;padding:clamp(2rem,5vw,5rem);display:flex;position:relative;overflow:hidden}.auth-hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#818cf81f 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;left:-200px}.auth-logo{align-items:center;gap:12px;margin-bottom:3rem;display:flex}.auth-logo-img{object-fit:contain;flex-shrink:0;width:auto;height:44px}.auth-logo-name{letter-spacing:-.03em;font-size:22px;font-weight:700}.auth-hero h1{letter-spacing:-.06em;background:linear-gradient(135deg, var(--text) 0%, var(--text-2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.2rem;font-size:clamp(2.2rem,4vw,3.6rem);font-weight:800;line-height:1}.auth-hero p{color:var(--text-2);max-width:480px;font-size:1.05rem;line-height:1.7}.auth-features{grid-template-columns:1fr 1fr;gap:12px;margin-top:2.4rem;display:grid}.auth-feature{border-radius:var(--r-md);border:1px solid var(--border);color:var(--text-2);background:#ffffff0a;align-items:center;gap:10px;padding:12px 14px;font-size:13px;font-weight:500;display:flex}[data-theme=light] .auth-feature{background:#00000008}.auth-feature svg{color:var(--brand);flex-shrink:0}.auth-workspace-preview{margin-top:2rem}.auth-workspace-preview .auth-workspace-preview-inner{padding:0}.auth-workspace-preview .lp-app-mock{border:1px solid var(--border);border-radius:14px;height:min(52vh,440px);min-height:320px}.auth-mobile-logo{align-items:center;gap:12px;margin-bottom:18px;display:none}.auth-form-area{background:var(--bg-1);flex-direction:column;justify-content:center;padding:clamp(1.5rem,4vw,4rem);display:flex}.auth-card{flex-direction:column;gap:16px;width:100%;max-width:380px;display:flex}.auth-card h2{letter-spacing:-.04em;font-size:1.5rem;font-weight:700}.auth-card p{color:var(--text-2);font-size:13px}.auth-toggle{background:var(--bg-2);border-radius:var(--r-sm);border:1px solid var(--border);gap:4px;padding:4px;display:flex}.auth-toggle button{color:var(--text-2);border-radius:4px;flex:1;padding:6px;font-size:13px;font-weight:600;transition:background .12s,color .12s}.auth-toggle button.active{background:var(--bg-hover);color:var(--text)}.auth-divider{color:var(--text-3);align-items:center;gap:12px;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-error{border-radius:var(--r-sm);background:var(--red-dim);border:1px solid var(--red);color:var(--red);padding:10px 14px;font-size:13px}.app{flex-direction:column;height:100%;min-height:0;max-height:100dvh;display:flex;overflow:hidden}.app-body{flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.resize-handle{z-index:10;background:0 0;flex-shrink:0;transition:background .12s}.resize-handle-v{cursor:col-resize;width:5px}.resize-handle-h{cursor:row-resize;height:5px}.resize-handle:hover,.resize-handle:active{background:var(--brand);opacity:.6}.sidebar-wrap{flex-direction:column;min-width:0;display:flex;overflow:hidden}.sidebar-wrap .sidebar{flex:1 1 0;height:100%;min-height:0;overflow:hidden}.right-panel-wrap{flex-direction:column;min-width:0;display:flex;overflow:hidden}.right-panel-wrap .right-panel{flex:1;overflow:hidden}.app-header{height:var(--header-h);background:var(--bg-1);border-bottom:1px solid var(--border);z-index:110;flex-shrink:0;align-items:center;gap:8px;min-width:0;padding:0 14px;display:flex;position:relative}.header-logo{align-items:center;gap:8px;margin-right:4px;display:flex}.header-logo-img{object-fit:contain;flex-shrink:0;width:auto;height:26px}.header-sep{background:var(--border);width:1px;height:20px;margin:0 4px}.header-project{border-radius:var(--r-sm);color:var(--text);background:0 0;border:1px solid #0000;align-items:center;gap:6px;max-width:220px;padding:4px 10px;font-size:13px;font-weight:600;transition:background .12s;display:flex;overflow:hidden}.header-project:hover{background:var(--bg-hover);border-color:var(--border)}.header-project span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.header-project-name{cursor:text}.header-project-name:hover{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.header-project-rename{background:var(--bg-2);border:1px solid var(--brand);border-radius:var(--r-sm);color:var(--text);outline:none;width:auto;min-width:80px;max-width:200px;padding:1px 6px;font-size:13px;font-weight:600}.header-spacer{flex:1}.header-pills,.header-actions{align-items:center;gap:6px;display:flex}.dirty-dot{background:var(--yellow);border-radius:50%;flex-shrink:0;width:7px;height:7px}.sidebar{background:var(--bg-1);border-right:1px solid var(--border);flex-direction:column;min-width:0;height:100%;min-height:0;display:flex;overflow:hidden}.sidebar-collapsed-rail{flex-direction:column;align-items:center;gap:4px;padding:8px 4px;display:flex}.sidebar-section{flex-direction:column;min-height:0;display:flex}.sidebar-section--grow{flex:1 1 0;min-height:0;overflow:hidden}.sidebar-section-header{letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);justify-content:space-between;align-items:center;padding:12px 14px 6px;font-size:11px;font-weight:800;display:flex}.sidebar-section-header .actions{gap:2px;display:flex}.project-list{flex:1;padding:0 6px 6px;overflow-y:auto}.project-item{border-radius:var(--r-sm);cursor:pointer;color:var(--text-2);border:1px solid #0000;align-items:center;gap:8px;padding:8px 10px;font-size:13px;font-weight:500;transition:background .1s,color .1s;display:flex}.project-item:hover{background:var(--bg-hover);color:var(--text)}.project-item.active{background:var(--brand-dim);color:var(--brand);border-color:#818cf840}.project-item .name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.project-item .role{color:var(--text-3);flex-shrink:0;font-size:11px}.sidebar-divider{background:var(--border);height:1px;margin:4px 0}.file-tree{padding:0 6px 6px}.sidebar-section--grow .file-tree{-webkit-overflow-scrolling:touch;flex:1 1 0;min-height:0;overflow-y:auto}.tree-node{-webkit-user-select:none;user-select:none}.tree-row{border-radius:var(--r-sm);cursor:pointer;color:var(--text-2);white-space:nowrap;align-items:center;gap:4px;padding:4px 8px;font-size:13px;transition:background .1s,color .1s;display:flex;overflow:hidden}.tree-row:hover{background:var(--bg-hover);color:var(--text)}.tree-row.active{background:var(--brand-dim);color:var(--brand)}.tree-row.active .tree-name{color:var(--brand)}.tree-chevron{color:var(--text-3);flex-shrink:0;transition:transform .15s}.tree-chevron.open{transform:rotate(90deg)}.tree-icon{flex-shrink:0}.tree-name{text-overflow:ellipsis;flex:1;overflow:hidden}.tree-children{padding-left:14px}.sidebar-outline-panel{flex-direction:column;flex:0 auto;min-height:0;max-height:min(28vh,220px);display:flex;overflow:hidden}.sidebar-outline-panel .sidebar-outline-scroll{-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow-y:auto}.sidebar-bottom{border-top:1px solid var(--border);padding:8px;padding-bottom:max(8px, env(safe-area-inset-bottom,0px));background:var(--bg-1);flex-direction:column;flex-shrink:0;gap:6px;margin-top:auto;display:flex}.sidebar-bottom-row{gap:6px;display:flex}.new-project-form,.join-project-form{align-items:center;gap:6px;display:flex}.new-project-form input,.join-project-form input{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-2);color:var(--text);outline:none;flex:1;min-width:0;padding:5px 8px;font-size:12px}.new-project-form input:focus,.join-project-form input:focus{border-color:var(--blue)}.editor-column{flex-direction:column;flex:1 1 0;min-width:0;min-height:0;display:flex;overflow:hidden}.editor-area{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden;container-type:inline-size}.tab-bar{background:var(--bg-1);border-bottom:1px solid var(--border);flex-shrink:0;align-items:stretch;display:flex}.tab-bar-tabs{flex:1;align-items:center;min-width:0;display:flex;overflow-x:auto}.tab-bar-tabs::-webkit-scrollbar{height:0}.tab-bar-actions{border-left:1px solid var(--border);background:var(--bg-1);flex-shrink:0;align-items:center;gap:6px;padding:0 10px;display:flex}@container (width<=620px){.tab-bar-actions .btn-label{display:none}}.file-tab{cursor:pointer;color:var(--text-2);border-right:1px solid var(--border);white-space:nowrap;border-bottom:2px solid #0000;flex-shrink:0;align-items:center;gap:5px;padding:8px 12px;font-size:12.5px;transition:background .1s,color .1s;display:flex;position:relative}.file-tab:hover{background:var(--bg-hover);color:var(--text)}.file-tab.active{background:var(--bg);color:var(--text);border-bottom-color:var(--brand)}.file-tab svg{flex-shrink:0}.tab-close{width:16px;height:16px;color:var(--text-3);opacity:0;cursor:pointer;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;margin-left:2px;transition:opacity .1s,background .1s;display:inline-flex}.file-tab:hover .tab-close,.file-tab.active .tab-close{opacity:1}.tab-close:hover{background:var(--bg-hover);color:var(--text)}.tree-action{opacity:0}.tree-node:hover .tree-action{opacity:1}.cm-wrap{flex:1;position:relative;overflow:auto}.cm-wrap .cm-editor{height:100%}.cm-wrap .cm-editor.cm-focused{outline:none}.cm-wrap .cm-scroller{font-family:var(--mono)!important;font-size:14px!important}.editor-status-bar{background:var(--bg-1);border-top:1px solid var(--border);color:var(--text-3);flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;min-width:0;padding:4px 12px 4px 14px;font-size:11px;font-weight:500;display:flex;overflow:hidden}.editor-status-bar-left{flex:1;align-items:center;gap:6px;min-width:0;display:flex;overflow:hidden}.editor-status-file{text-overflow:ellipsis;white-space:nowrap;flex:0 auto;min-width:0;max-width:min(200px,38vw);overflow:hidden}.editor-status-sep{opacity:.65;flex-shrink:0}.editor-status-noshrink{white-space:nowrap;flex-shrink:0}.editor-status-hints{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-3);flex:auto;overflow:hidden}.editor-status-bar-right{flex-shrink:0;align-items:center;padding-left:8px;display:flex}.editor-status-state.saved{color:var(--green)}.editor-status-state.unsaved{color:var(--yellow)}.editor-status-state.view-only{color:var(--text-3)}.log-drawer{background:var(--bg-1);border-top:1px solid var(--border);min-height:0;padding-bottom:env(safe-area-inset-bottom,0px);z-index:2;flex-direction:column;flex-shrink:0;transition:height .18s;display:flex;overflow:hidden}.log-drawer.collapsed{height:32px;min-height:32px}.log-drawer.expanded{height:var(--log-h)}.log-bar{padding:6px 12px;padding-right:max(12px, env(safe-area-inset-right,0px));cursor:pointer;border-bottom:1px solid var(--border);min-width:0;color:var(--text-2);flex-shrink:0;align-items:center;gap:8px;font-size:12px;font-weight:600;transition:background .1s;display:flex}.log-bar-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.log-bar-icon{flex-shrink:0;align-items:center;display:flex}.log-bar-chevron{opacity:.85;flex-shrink:0;align-items:center;display:flex}.log-bar:hover{background:var(--bg-hover)}.log-bar.success{color:var(--green)}.log-bar.error{color:var(--red)}.log-bar.idle{color:var(--text-3)}.log-content{font-family:var(--mono);color:var(--text-2);white-space:pre-wrap;word-break:break-all;flex:1;padding:8px 14px;font-size:12px;line-height:1.6;overflow-y:auto}.log-content.has-error{color:var(--red)}.right-panel{background:var(--bg-1);border-left:1px solid var(--border);flex-direction:column;width:100%;min-width:0;display:flex;overflow:hidden}.panel-nav{background:var(--bg-1);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:2px;padding:0 8px;display:flex;overflow-x:auto}.panel-nav::-webkit-scrollbar{height:0}.panel-tab{color:var(--text-2);cursor:pointer;white-space:nowrap;border-bottom:2px solid #0000;flex-shrink:0;align-items:center;gap:4px;padding:10px 10px 8px;font-size:11px;font-weight:600;transition:color .1s;display:flex}.panel-tab:hover{color:var(--text)}.panel-tab.active{color:var(--text);border-bottom-color:var(--brand)}.panel-tab-label{font-size:11px}.panel-main{flex-direction:row;flex:1;min-height:0;display:flex;overflow:hidden}.panel-body{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.panel-side-strip{border-left:1px solid var(--border);background:var(--bg-1);flex-direction:column;flex-shrink:0;align-items:center;gap:2px;width:36px;padding:4px 0;display:flex;overflow-y:auto}.panel-side-strip::-webkit-scrollbar{width:0}.panel-side-btn{border-radius:var(--r-sm);width:28px;height:28px;color:var(--text-2);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.panel-side-btn:hover{background:var(--bg-hover);color:var(--text)}.panel-side-btn.active{color:var(--brand);background:var(--bg-2)}.left-action-strip{border-right:1px solid var(--border);background:var(--bg-1);flex-direction:column;flex-shrink:0;align-items:center;gap:2px;width:36px;padding:4px 0;display:flex;overflow-y:auto}.left-action-strip::-webkit-scrollbar{width:0}.left-action-btn{border-radius:var(--r-sm);width:28px;height:28px;color:var(--text-2);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.left-action-btn:hover{background:var(--bg-hover);color:var(--text)}.left-action-btn.active{color:var(--brand);background:var(--bg-2)}.pdf-pane{flex-direction:column;flex:1;display:flex;overflow:hidden}.pdf-frame{background:var(--bg-1);border:0;flex:1;width:100%}.pdf-empty{text-align:center;color:var(--text-3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:2rem;display:flex}.pdf-empty h3{color:var(--text-2);font-size:15px;font-weight:600}.pdf-empty p{max-width:240px;font-size:13px;line-height:1.6}.chat-pane{flex-direction:column;flex:1;display:flex;overflow:hidden}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:14px;display:flex;overflow-y:auto}.chat-msg{border-radius:var(--r-md);border:1px solid #0000;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.chat-msg:hover{background:var(--bg-2);border-color:var(--border)}.chat-msg.mine .chat-msg-author{color:var(--blue)}.chat-msg.mine .chat-msg-text{color:var(--text)}.chat-msg-header{align-items:baseline;gap:6px;display:flex}.chat-msg-author{color:var(--brand);font-size:12px;font-weight:700}.chat-msg-time{color:var(--text-3);font-size:11px;font-weight:500}.chat-msg-text{color:var(--text-2);font-size:13px;font-weight:450;line-height:1.55}.chat-input-row{border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:10px 12px;display:flex}.chat-input-row input{flex:1}.chat-empty{color:var(--text-3);flex:1;justify-content:center;align-items:center;font-size:13px;display:flex}.comments-pane{flex-direction:column;flex:1;display:flex;overflow:hidden}.comments-list{flex-direction:column;flex:1;gap:6px;padding:10px;display:flex;overflow-y:auto}.comment-thread{border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-2);overflow:hidden}.comment-thread.resolved{opacity:.65}.comment-thread-header{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-2);align-items:center;gap:6px;padding:8px 10px;font-size:12px;font-weight:600;display:flex}.comment-thread-header:hover{background:var(--bg-hover)}.comment-thread-location{font-family:var(--mono);color:var(--brand);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.comment-thread-body{border-top:1px solid var(--border)}.comment-item{border-bottom:1px solid var(--border);padding:8px 10px}.comment-item:last-child{border-bottom:none}.comment-item-resolved{opacity:.6}.comment-item-header{align-items:center;gap:6px;margin-bottom:4px;display:flex}.comment-author{color:var(--text);flex:1;font-size:11px;font-weight:700}.comment-time{color:var(--text-3);font-size:10px}.comment-item-text{color:var(--text-2);font-size:12px;line-height:1.55}.comment-resolved-by{color:var(--green,#3fb950);align-items:center;gap:4px;margin-top:4px;font-size:10px;display:flex}.btn-resolve{cursor:pointer;color:var(--green,#3fb950);background:#3fb9501f;border:1px solid #3fb9504d;border-radius:4px;align-items:center;gap:3px;padding:2px 7px;font-size:10px;font-weight:600;transition:background .15s;display:inline-flex}.btn-resolve:hover{background:#3fb95038}.btn-resolve-undo{background:var(--bg-hover);color:var(--text-3);border-color:var(--border)}.btn-resolve-undo:hover{background:var(--bg-2)}.comment-card{border-radius:var(--r-md);background:var(--bg-2);border:1px solid var(--border);padding:10px 12px}.comment-meta{color:var(--text-2);margin-bottom:4px;font-size:11px;font-weight:600}.comment-text{color:var(--text);font-size:13px;font-weight:500;line-height:1.55}.comment-location{color:var(--text-3);font-size:11px;font-weight:500;font-family:var(--mono);margin-top:4px}.comment-line-overlay{pointer-events:none;z-index:4;position:absolute;inset:0;overflow:visible}.cli-group{pointer-events:all;flex-direction:column;gap:3px;display:flex;position:absolute;right:14px;transform:translateY(-50%)}.cli-bubble{background:linear-gradient(#818cf82e, #818cf82e), var(--bg);-webkit-backdrop-filter:blur(6px)saturate(140%);cursor:default;-webkit-user-select:none;user-select:none;white-space:nowrap;border:1px solid #818cf88c;border-radius:99px;align-items:center;gap:5px;max-width:240px;padding:3px 9px 3px 8px;font-size:11px;transition:background .15s,border-color .15s,box-shadow .15s;display:inline-flex;overflow:hidden;box-shadow:0 2px 8px #00000040}.cli-bubble.hovered{background:linear-gradient(#818cf847, #818cf847), var(--bg);border-color:var(--brand);max-width:none;overflow:visible;box-shadow:0 4px 14px #00000052}[data-theme=light] .cli-bubble{background:linear-gradient(#6366f124, #6366f124), var(--bg-1);border-color:#6366f18c;box-shadow:0 2px 8px #0000001a}[data-theme=light] .cli-bubble.hovered{background:linear-gradient(#6366f138, #6366f138), var(--bg-1);box-shadow:0 4px 14px #00000029}.cli-author{color:var(--brand);flex-shrink:0;font-size:10px;font-weight:700}.cli-text{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.cli-bubble.hovered .cli-text{max-width:160px}.cli-resolve-btn{background:var(--green,#3fb950);color:var(--bg-1);cursor:pointer;pointer-events:all;white-space:nowrap;border:none;border-radius:99px;flex-shrink:0;align-items:center;margin-left:5px;padding:1px 8px;font-size:10px;font-weight:700;transition:opacity .15s;display:inline-flex}.cli-resolve-btn:hover{opacity:.82}.cli-actions{justify-content:center;align-items:center;gap:4px;display:inline-flex}.cli-hide-btn{background:var(--bg-2);width:22px;height:22px;color:var(--text-2);border:1px solid var(--border);cursor:pointer;pointer-events:all;border-radius:50%;flex-shrink:0;place-items:center;padding:0;transition:opacity .15s,background .15s;display:inline-grid}.cli-hide-btn:hover{opacity:.9;background:var(--bg-hover)}.cm-comment-hover-tip{z-index:9999;background:var(--bg-2);border:1px solid var(--border);pointer-events:all;border-radius:8px;min-width:190px;max-width:300px;padding:6px 0;position:fixed;box-shadow:0 2px 8px #0000001f}.cm-cht-item{flex-direction:column;gap:3px;padding:6px 10px;display:flex}.cm-cht-sep{border-bottom:1px solid var(--border);margin-bottom:2px;padding-bottom:8px}.cm-cht-author{color:var(--brand);font-size:10px;font-weight:700}.cm-cht-text{color:var(--text-2);word-break:break-word;font-size:11px;line-height:1.5}.cm-cht-resolve-btn{background:var(--green,#3fb950);color:var(--bg-1);cursor:pointer;border:none;border-radius:99px;align-self:flex-start;margin-top:5px;padding:3px 10px;font-size:10px;font-weight:700;transition:opacity .15s}.cm-cht-resolve-btn:hover{opacity:.82}.cm-cht-actions{justify-content:center;align-items:center;gap:6px;margin-top:5px;display:flex}.cm-cht-hide-btn{background:var(--bg);width:24px;height:24px;color:var(--text-2);border:1px solid var(--border);cursor:pointer;border-radius:50%;place-items:center;padding:0;transition:opacity .15s,background .15s;display:inline-grid}.cm-cht-hide-btn:hover{opacity:.9;background:var(--bg-hover)}.ai-fix-card{border-radius:var(--r-md);background:var(--brand-dim);border:1px solid var(--brand);margin:12px;padding:12px}.ai-fix-card h4{color:var(--brand);margin-bottom:8px;font-size:12px;font-weight:700}.ai-fix-card pre{font-family:var(--mono);color:var(--text-2);white-space:pre-wrap;word-break:break-all;max-height:160px;margin-bottom:10px;font-size:11px;overflow-y:auto}.versions-pane{flex-direction:column;flex:1;display:flex;overflow:hidden}.version-list{flex-direction:column;flex:1;gap:8px;padding:14px;display:flex;overflow-y:auto}.version-card{border-radius:var(--r-md);background:var(--bg-2);border:1px solid var(--border);align-items:center;gap:10px;padding:10px 12px;display:flex}.version-info{flex:1}.version-label{color:var(--text);font-size:13px;font-weight:600}.version-date{color:var(--text-3);margin-top:2px;font-size:11px;font-weight:500}.save-version-row{border-top:1px solid var(--border);gap:8px;padding:10px 12px;display:flex}.save-version-row input{flex:1}.activity-pane{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.activity-item{border-radius:var(--r-sm);align-items:flex-start;gap:10px;padding:8px 10px;display:flex}.activity-item:hover{background:var(--bg-hover)}.activity-dot{background:var(--border-hi);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.activity-text{flex:1}.activity-who{color:var(--text);font-size:12px;font-weight:700}.activity-action{color:var(--text-2);font-size:12px;font-weight:500}.activity-when{color:var(--text-3);margin-top:2px;font-size:11px;font-weight:500}.settings-pane{flex-direction:column;gap:20px;padding:20px;display:flex;overflow-y:auto}.settings-group{flex-direction:column;gap:10px;display:flex}.settings-group h3{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-size:12px;font-weight:700}.settings-field{flex-direction:column;gap:5px;display:flex}.settings-field label{color:var(--text-2);font-size:12px;font-weight:600}.settings-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.settings-row:last-child{border-bottom:0}.settings-row label{color:var(--text);font-size:13px}.settings-row p{color:var(--text-2);margin-top:2px;font-size:12px}.toggle{flex-shrink:0;width:38px;height:22px;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-track{background:var(--border);cursor:pointer;border-radius:999px;transition:background .18s;position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--brand)}.toggle-thumb{background:var(--bg-1);pointer-events:none;border-radius:50%;width:16px;height:16px;transition:transform .18s;position:absolute;top:3px;left:3px}.toggle input:checked~.toggle-thumb{transform:translate(16px)}.invite-row{border-top:1px solid var(--border);gap:8px;padding:10px 12px;display:flex}.invite-row input{flex:1}.overlay{z-index:200;background:#0009;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dialog{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);width:380px;box-shadow:var(--shadow);flex-direction:column;gap:16px;padding:28px;animation:.15s ease-out scaleIn;display:flex}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.dialog h2{font-size:16px;font-weight:700}.dialog p{color:var(--text-2);font-size:13px}.dialog-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.overlay .dialog,.modal-overlay .modal-body,.modal-overlay .tpl-grid-wrap,.modal-overlay .tpl-categories{scrollbar-width:none;-ms-overflow-style:none}.overlay .dialog::-webkit-scrollbar{width:0;height:0;display:none}.modal-overlay .modal-body::-webkit-scrollbar{width:0;height:0;display:none}.modal-overlay .tpl-grid-wrap::-webkit-scrollbar{width:0;height:0;display:none}.modal-overlay .tpl-categories::-webkit-scrollbar{width:0;height:0;display:none}.hide-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.hide-scrollbar::-webkit-scrollbar{width:0;height:0;display:none}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin}.mobile-only-btn,.mobile-panel-btn{display:none}.mobile-actions-wrap{flex:none;width:30px;height:30px;display:none;position:relative}.mobile-actions-wrap>.icon-btn{width:100%;height:100%}.mobile-actions-menu{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow);z-index:1000;transform-origin:100% 0;flex-direction:column;gap:1px;min-width:200px;padding:5px;animation:.18s cubic-bezier(.2,.7,.2,1) actionsMenuIn;display:flex;position:absolute;top:calc(100% + 6px);right:0}@keyframes actionsMenuIn{0%{opacity:0;transform:translateY(-8px)scale(.94)}to{opacity:1;transform:translateY(0)scale(1)}}.mobile-actions-menu button{border-radius:var(--r-sm);color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:0;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:flex}.mobile-actions-menu button:hover,.mobile-actions-menu button:focus-visible{background:var(--bg-hover);color:var(--text);outline:none}.mobile-actions-menu button svg{color:var(--brand);flex-shrink:0}.mobile-actions-sep{background:var(--border);height:1px;margin:4px 2px}.mobile-scrim{inset:var(--header-h) 0 0 0;-webkit-backdrop-filter:blur(2px);z-index:90;background:#00000080;animation:.15s ease-out scrimFade;display:none;position:fixed}@keyframes scrimFade{0%{opacity:0}to{opacity:1}}@media (width<=900px){.mobile-only-btn,.mobile-actions-wrap{display:inline-flex}.mobile-scrim{display:block}.resize-handle-v{display:none!important}.sidebar-wrap{top:var(--header-h);max-height:calc(100dvh - var(--header-h));z-index:100;animation:.22s cubic-bezier(.2,.7,.2,1) drawerSlideLeft;bottom:0;left:0;box-shadow:0 12px 36px #0006;width:min(280px,84vw)!important;position:fixed!important}.sidebar-wrap .sidebar{border-right:0}.right-panel-wrap{top:var(--header-h);max-height:calc(100dvh - var(--header-h));z-index:100;transition:transform .22s cubic-bezier(.2,.7,.2,1);bottom:0;right:0;transform:translate(100%);box-shadow:-12px 0 36px #0006;width:min(420px,92vw)!important;position:fixed!important}.right-panel-wrap.mobile-open{transform:translate(0)}.right-panel-wrap .right-panel{border-left:0}.editor-column{width:100%;min-width:0}}@keyframes drawerSlideLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@media (width<=600px){:root{--header-h:52px}.app-header{gap:4px;padding:0 8px}.app-header .header-sep,.app-header .header-pills{display:none}.header-project{max-width:140px;padding:4px 6px;font-size:12.5px}.header-logo-img{height:22px}.btn-back-dash{padding:6px;font-size:0}.btn-back-dash svg{margin:0}.icon-btn{width:36px;height:36px}.icon-btn.icon-btn--text{width:auto;height:36px;padding:0 10px;font-size:13px}.mobile-actions-wrap{width:36px;height:36px}.tab-bar-actions{gap:4px;padding:0 6px}.tab-bar-actions .btn-label{display:none}.file-tab{padding:8px 10px;font-size:12px}.btn{padding:8px 12px}.btn-compile{padding:8px 14px}.log-drawer.expanded{height:140px}.cm-wrap .cm-scroller{font-size:13.5px!important}.right-panel-wrap{width:92vw!important}.sidebar-wrap{width:86vw!important}.left-action-strip{display:none}.toast{max-width:none;bottom:16px;left:12px;right:12px;transform:none}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}}@container (width<=520px){.editor-status-hints,.editor-status-sep--hide-sm{display:none}}@container (width<=380px){.editor-status-bar{gap:6px;padding:4px 8px;font-size:10.5px}.editor-status-file{max-width:28vw}}@media (width<=900px){.panel-side-strip{display:none}}@media (width<=600px){.panel-tab{padding:11px 9px 9px}.panel-tab-label{font-size:12px}.chat-input-row,.comments-pane>div[style*="display: flex"]:first-child{padding:10px}.chat-input-row .btn{padding:8px 14px}.invite-row{flex-wrap:wrap}.invite-row input{flex:100%;min-width:0}.settings-pane{gap:16px;padding:16px}.save-version-row{flex-wrap:wrap}.save-version-row input{flex:100%}}@media (width<=860px){.auth-page{grid-template-columns:1fr}.auth-hero{display:none}.auth-form-area{justify-content:flex-start;align-items:center;min-height:100vh;padding:20px}.auth-mobile-logo{display:flex}.auth-card{width:min(100%,420px)}.auth-features{grid-template-columns:1fr}}@media (width<=420px){.auth-card{gap:12px}.auth-card h2{font-size:1.3rem}}@media (width<=600px){.modal-overlay{align-items:stretch;padding:0}.modal-box{border:0;border-radius:0;width:100%;max-width:100%;height:100vh;max-height:100vh}.modal-box-lg{flex-direction:column;width:100%;height:100dvh;min-height:0;max-height:100dvh;display:flex}.modal-box-lg .modal-body--template-picker{flex:1;min-height:0;padding:16px;overflow:hidden}.modal-header{background:var(--bg-1);z-index:2;padding:14px 16px 12px;position:sticky;top:0}.modal-body{padding:16px}.modal-footer{background:var(--bg-1);z-index:2;flex-shrink:0;padding:12px 16px;position:sticky;bottom:0}.modal-body-tpl{flex-direction:column;align-items:stretch;gap:12px;min-height:0}.modal-body-tpl .tpl-categories{border-right:none;border-bottom:1px solid var(--border);flex-flow:wrap;flex-shrink:0;align-content:flex-start;align-items:flex-start;gap:6px;width:100%;padding-bottom:10px;padding-right:0;overflow:visible}.modal-body-tpl .tpl-cat-item{white-space:nowrap;flex:none;align-self:flex-start;width:auto;padding:6px 10px}.modal-body-tpl .tpl-grid-wrap{-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow-y:auto}.dialog{justify-content:flex-start;padding:20px;overflow-y:auto;border-radius:0!important;width:100%!important;max-width:100%!important;height:100vh!important;max-height:100vh!important}.overlay{align-items:stretch;padding:0}}.lp-root{background:var(--bg);min-height:100vh;color:var(--text);font-family:var(--font);overflow-x:hidden}.lp-nav{z-index:100;border-bottom:1px solid #0000;align-items:center;height:64px;padding:0 24px;transition:background .25s,border-color .25s,-webkit-backdrop-filter .25s,backdrop-filter .25s;display:flex;position:fixed;top:0;left:0;right:0}.lp-nav-scrolled{-webkit-backdrop-filter:blur(14px);border-bottom-color:var(--border);background:#0f1419d9}[data-theme=light] .lp-nav-scrolled{background:#f9fafbe0}.lp-nav-inner{justify-content:flex-start;align-items:center;gap:24px;width:100%;max-width:none;margin:0 auto;display:flex;position:relative}.lp-nav-links{flex:auto;justify-content:center;gap:28px;min-width:0;display:flex}.lp-nav-links a{color:var(--text-2);font-size:14px;font-weight:500;text-decoration:none;transition:color .15s}.lp-nav-links a:hover{color:var(--text)}.lp-nav-actions{flex-shrink:0;align-items:center;gap:10px;margin-left:auto;display:flex}.lp-nav-mobile{flex-shrink:0;margin-left:auto;display:none;position:relative}.lp-nav-hamburger{width:36px;height:36px}.lp-nav-mobile-scrim{z-index:99;background:#00000073;animation:.15s ease-out scrimFade;position:fixed;inset:64px 0 0}.lp-nav-mobile-panel{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-md);min-width:min(280px,100vw - 32px);box-shadow:var(--shadow);z-index:200;flex-direction:column;gap:2px;padding:6px;animation:.18s cubic-bezier(.2,.7,.2,1) actionsMenuIn;display:flex;position:absolute;top:calc(100% + 8px);right:0}.lp-nav-mobile-panel>a[role=menuitem]{border-radius:var(--r-sm);color:var(--text-2);padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:block}.lp-nav-mobile-panel>a[role=menuitem]:hover,.lp-nav-mobile-panel>a[role=menuitem]:focus-visible{background:var(--bg-hover);color:var(--text);outline:none}.lp-nav-mobile-sep{background:var(--border);height:1px;margin:4px 2px}.lp-nav-mobile-row{border-radius:var(--r-sm);width:100%;font:inherit;color:var(--text-2);cursor:pointer;text-align:left;background:0 0;border:0;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:background .12s,color .12s;display:flex}.lp-nav-mobile-row:hover,.lp-nav-mobile-row:focus-visible{background:var(--bg-hover);color:var(--text);outline:none}.lp-nav-mobile-row--ghost{border:1px solid var(--border);color:var(--text-2);background:0 0}.lp-nav-mobile-row--primary{background:var(--brand);color:#fff;justify-content:center;margin-top:2px;font-weight:700}.lp-nav-mobile-row--primary:hover,.lp-nav-mobile-row--primary:focus-visible{background:var(--brand-hover);color:#fff}.lp-nav-mobile-row--primary svg{flex-shrink:0}.lp-nav-theme{width:34px;height:34px;color:var(--text-2);border-radius:8px;place-items:center;transition:background .15s,color .15s;display:grid}.lp-nav-theme:hover{background:var(--bg-hover);color:var(--text)}.lp-logo{flex-shrink:0;align-items:center;gap:10px;display:flex}.lp-logo-img{object-fit:contain;flex-shrink:0;width:auto;height:34px}.lp-logo-name{letter-spacing:-.02em;font-size:18px;font-weight:800}.lp-btn-primary{background:var(--brand);color:#fff;white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:8px 18px;font-size:14px;font-weight:700;transition:opacity .15s,transform .12s;display:inline-flex}.lp-btn-primary:hover{opacity:.88;transform:translateY(-1px)}.lp-btn-ghost{border:1px solid var(--border);color:var(--text-2);white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.lp-btn-ghost:hover{background:var(--bg-hover);color:var(--text);border-color:var(--border-hi)}.lp-btn-hero{background:var(--brand);color:#fff;letter-spacing:-.01em;border-radius:12px;align-items:center;gap:8px;padding:14px 28px;font-size:16px;font-weight:800;transition:transform .12s,opacity .15s;animation:2.4s ease-in-out infinite lp-pulse;display:inline-flex;box-shadow:0 0 #818cf859}.lp-btn-hero:hover{opacity:.92;transform:translateY(-2px)}@keyframes lp-pulse{0%,to{box-shadow:0 0 #818cf859}50%{box-shadow:0 0 0 10px #818cf800}}.lp-hero{flex-direction:column;min-height:620px;display:flex;position:relative;overflow:clip}.lp-hero-bg{pointer-events:none;background-image:radial-gradient(circle, var(--border) 1px, transparent 1px);opacity:.5;background-size:32px 32px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(100% 70% at 50% 0,#000 30%,#0000 100%);mask-image:radial-gradient(100% 70% at 50% 0,#000 30%,#0000 100%)}.lp-hero-inner{text-align:center;flex-direction:column;flex-shrink:0;align-items:center;width:100%;max-width:1060px;margin:0 auto;padding:80px 24px 16px;display:flex;position:relative}.lp-hero-overline{letter-spacing:.1em;text-transform:uppercase;color:var(--brand);justify-content:center;align-items:center;gap:8px;margin-bottom:16px;font-size:12px;font-weight:700;display:flex}.lp-hero-overline-dot{background:var(--brand);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite lp-ping}.lp-hero-identity{flex-direction:column;align-items:center;margin-bottom:20px;display:flex}.lp-hero-logo-img{object-fit:contain;flex-shrink:0;width:auto;height:60px;margin-bottom:16px;animation:.6s both lp-fadein}@keyframes lp-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.lp-hero-title-block{text-align:center;flex-direction:column;flex:1;align-items:center;min-width:0;display:flex}.lp-hero-headline{letter-spacing:-.04em;margin-bottom:14px;font-size:clamp(32px,4.5vw,62px);font-weight:900;line-height:1.05}.lp-hero-punct{color:var(--brand)}.lp-hero-hl{-webkit-text-stroke:2px var(--brand);color:#0000}[data-theme=light] .lp-hero-hl{-webkit-text-stroke:2.5px var(--brand)}.lp-hero-desc{color:var(--text-2);text-align:center;max-width:540px;margin-bottom:20px;font-size:15px;line-height:1.6}.lp-hero-ctas{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.lp-btn-hero{background:var(--brand);color:#fff;letter-spacing:-.01em;border-radius:10px;align-items:center;gap:8px;padding:13px 26px;font-size:15px;font-weight:800;transition:transform .12s,box-shadow .15s;display:inline-flex;box-shadow:0 4px 20px #818cf84d}.lp-btn-hero:hover{transform:translateY(-2px);box-shadow:0 8px 28px #818cf866}.lp-btn-hero-ghost{border:1.5px solid var(--border-hi);color:var(--text-2);border-radius:10px;align-items:center;gap:6px;padding:13px 22px;font-size:15px;font-weight:600;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.lp-btn-hero-ghost:hover{background:var(--bg-hover);color:var(--text);text-decoration:none}.lp-hero-pill-track{flex-wrap:wrap;gap:8px;display:flex}.lp-hero-pill{background:var(--bg-1);border:1px solid var(--border);color:var(--text-2);border-radius:999px;align-items:center;gap:6px;padding:6px 13px;font-size:12.5px;font-weight:600;display:inline-flex}.lp-hero-pill svg{color:var(--brand);flex-shrink:0}.lp-hero-mockup-wrap{width:100%;max-width:min(100%,900px);margin:0 auto;padding:0 24px;overflow:visible}.lp-app-mock{border:1px solid var(--border);background:var(--bg-1);border-radius:14px;flex-direction:column;height:min(58vh,620px);min-height:480px;font-size:12px;display:flex;overflow:hidden;box-shadow:0 8px 48px #00000059,inset 0 1px #ffffff0a}.lp-mock-appheader{background:var(--bg-1);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;height:42px;padding:0 12px;display:flex}.lp-mock-logo{width:auto;height:22px}.lp-mock-sep{background:var(--border);flex-shrink:0;width:1px;height:16px}.lp-mock-projectname{color:var(--text);font-size:12.5px;font-weight:600}.lp-mock-dirty{background:var(--yellow);border-radius:50%;flex-shrink:0;width:6px;height:6px}.lp-mock-spacer{flex:1}.lp-mock-mpill{border-radius:999px;padding:3px 9px;font-size:11px;font-weight:600}.lp-mock-mpill.green{color:var(--green);background:var(--green-dim)}.lp-mock-mpill.blue{color:var(--blue);background:var(--blue-dim)}.lp-mock-icon-sq{background:var(--bg-2);border:1px solid var(--border);border-radius:5px;flex-shrink:0;width:22px;height:22px}.lp-mock-appbody{flex:1;grid-template-columns:176px 1fr 212px;min-height:0;display:grid;overflow:hidden}.lp-mock-appsidebar{background:var(--bg-1);border-right:1px solid var(--border);flex-direction:column;padding:8px 0;display:flex;overflow:hidden}.lp-mock-slabel{letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);padding:6px 12px 4px;font-size:10px;font-weight:800}.lp-mock-sitem{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;padding:5px 12px;font-size:12px;overflow:hidden}.lp-mock-sitem-active{background:var(--brand-dim);color:var(--brand)}.lp-mock-sitem-tex{font-family:var(--mono);font-size:11.5px}.lp-mock-sitem-sub{color:var(--text-3);padding-left:24px;font-size:11px}.lp-mock-sdivider{background:var(--border);height:1px;margin:6px 0}.lp-mock-apeditor{background:var(--bg);flex-direction:column;display:flex;overflow:hidden}.lp-mock-tabbar{background:var(--bg-1);border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.lp-mock-tab{color:var(--text-2);border-right:1px solid var(--border);font-size:12px;font-family:var(--mono);border-bottom:2px solid #0000;padding:7px 13px}.lp-mock-tab-active{color:var(--text);background:var(--bg);border-bottom-color:var(--brand)}.lp-mock-projects-screen{flex:1;grid-template-columns:170px 1fr;min-height:0;display:grid;position:relative}.lp-mock-projects-sidebar{border-right:1px solid var(--border);background:var(--bg-1);padding:10px 8px}.lp-mock-new-project{background:var(--brand);color:#fff;text-align:left;border-radius:8px;width:100%;padding:7px 8px;font-size:11px;font-weight:700}.lp-mock-projects-nav-item{color:var(--text-2);border-radius:7px;margin-top:6px;padding:7px 8px;font-size:11px}.lp-mock-projects-nav-item.active{background:var(--brand-dim);color:var(--brand);font-weight:700}.lp-mock-projects-main{background:var(--bg);flex-direction:column;padding:14px 16px;display:flex}.lp-mock-projects-title{letter-spacing:-.02em;margin-bottom:10px;font-size:21px;font-weight:900}.lp-mock-projects-search{border:1px solid var(--border);color:var(--text-3);border-radius:9px;padding:8px 10px;font-size:12px}.lp-mock-projects-empty{text-align:center;color:var(--text-3);flex-direction:column;align-items:center;gap:8px;margin:auto;font-size:12px;display:flex}.lp-mock-projects-folder{border:1px solid var(--border);background:var(--bg-1);width:54px;height:40px;color:var(--text-3);text-transform:uppercase;border-radius:8px;place-items:center;font-size:10px;display:grid}.lp-mock-projects-cta{background:var(--brand);color:#fff;border-radius:8px;margin-top:2px;padding:7px 12px;font-size:11px;font-weight:700}.lp-mock-drop-overlay{border:1px dashed var(--brand);text-align:center;background:#1216219e;flex-direction:column;justify-content:center;align-items:center;padding:16px;animation:.2s ease-out lp-mock-overlay-fade;display:flex;position:absolute;inset:0}.lp-mock-drop-overlay-icon{color:var(--brand);letter-spacing:.06em;text-transform:uppercase;font-size:14px;font-weight:800}.lp-mock-drop-overlay-title{color:#d5ddff;margin-top:8px;font-size:17px;font-weight:800}.lp-mock-drop-overlay-sub{color:#b5c0e8;margin-top:6px;font-size:12px}.lp-mock-drop-overlay-file{color:#fff;background:#ffffff14;border:1px solid #ffffff42;border-radius:8px;margin-top:10px;padding:8px 11px;font-size:11px;font-weight:700}.lp-mock-pipeline{border:1px solid var(--border);background:var(--bg-1);border-radius:10px;margin:8px 12px 4px;padding:8px 10px}.lp-mock-pipeline-status{color:var(--text-2);align-items:center;gap:6px;font-size:10.5px;display:flex}.lp-mock-pipeline-dot{background:var(--blue);border-radius:999px;width:7px;height:7px;animation:1s ease-in-out infinite lp-mock-live-blink}.lp-mock-progress-track{background:var(--bg-2);border-radius:999px;width:100%;height:5px;margin-top:6px;overflow:hidden}.lp-mock-progress-fill{border-radius:inherit;background:linear-gradient(90deg, var(--brand), var(--blue));height:100%;transition:width .6s}.lp-mock-pipeline-extracting .lp-mock-pipeline-dot{background:#f59e0b}.lp-mock-pipeline-compiling .lp-mock-pipeline-dot{background:var(--green);animation:1.2s ease-in-out infinite lp-mock-live-pulse;box-shadow:0 0 #10b98173}.lp-mock-pipeline-preview .lp-mock-pipeline-dot{background:var(--green);animation:none}.lp-mock-codelines{font-family:var(--mono);flex:1;padding:8px 0;overflow:hidden}.lp-mock-cl{color:var(--text);align-items:baseline;gap:12px;padding:0 14px;line-height:1.7;display:flex}.lp-mock-cl-active{background:#818cf80f}.lp-cl-n{text-align:right;min-width:18px;color:var(--text-3);-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:11px}.lp-cl-kw{color:#79c0ff}.lp-cl-br{color:#ff7b72}.lp-cl-cmt{color:#6e7681}.lp-cl-math{color:#e3b341}.lp-mock-statusbar{background:var(--bg-1);border-top:1px solid var(--border);color:var(--text-3);flex-shrink:0;align-items:center;gap:12px;padding:3px 14px;font-size:10px;display:flex}.lp-mock-sb-dot{background:var(--border-hi);border-radius:50%;flex-shrink:0;width:3px;height:3px}.lp-mock-saved{color:var(--green)}.lp-mock-appright{border-left:1px solid var(--border);background:var(--bg-1);flex-direction:column;display:flex;overflow:hidden}.lp-mock-righttabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.lp-mock-rtab{text-align:center;color:var(--text-2);border-bottom:2px solid #0000;flex:1;padding:8px 0;font-size:11px;font-weight:600}.lp-mock-rtab-active{color:var(--text);border-bottom-color:var(--brand)}.lp-mock-pdfpane{background:#6b7280;flex:1;justify-content:center;align-items:flex-start;padding:10px 6px;display:flex;overflow:hidden}.lp-mock-pdfpane-extracting .lp-mock-pdfpage{opacity:.3;filter:blur(.6px);transform:scale(.98)}.lp-mock-pdfpane-compiling .lp-mock-pdfpage{opacity:.55;position:relative;transform:scale(.99)}.lp-mock-pdfpane-compiling .lp-mock-pdfpage:after{content:"";background:linear-gradient(110deg,#0000 25%,#ffffff73 50%,#0000 75%);animation:1.1s linear infinite lp-mock-scan;position:absolute;inset:0;transform:translate(-120%)}.lp-mock-pdfpane-preview .lp-mock-pdfpage{opacity:1;filter:none;transition:opacity .35s,transform .35s;transform:scale(1)}@keyframes lp-mock-live-blink{0%,to{opacity:1}50%{opacity:.35}}@keyframes lp-mock-live-pulse{0%,to{box-shadow:0 0 #10b98173}50%{box-shadow:0 0 0 6px #10b98100}}@keyframes lp-mock-scan{to{transform:translate(130%)}}@keyframes lp-mock-overlay-fade{0%{opacity:0}to{opacity:1}}.lp-mock-pdfpage{background:var(--bg-1);border-radius:2px;width:100%;max-width:180px;padding:14px 12px;box-shadow:0 4px 20px #00000059}.lp-mock-pdftitle{color:#111;text-align:center;margin-bottom:2px;font-size:8px;font-weight:700}.lp-mock-pdfauthors{color:#555;text-align:center;margin-bottom:6px;font-size:7px}.lp-mock-pdfsec{color:#111;margin:5px 0 3px;font-size:7.5px;font-weight:700}.lp-mock-pdfl{background:#ccc;border-radius:2px;height:3.5px;margin-bottom:3px}.lp-mock-pdfl.w60{width:60%}.lp-mock-pdfl.w70{width:70%}.lp-mock-pdfl.w75{width:75%}.lp-mock-pdfl.w80{width:80%}.lp-mock-pdfl.w85{width:85%}.lp-mock-pdfl.w90{width:90%}.lp-mock-pdfl.w95{width:95%}.lp-mock-pdfmath{color:#111;text-align:center;padding:5px 0;font-size:9px;font-style:italic}@keyframes lp-ping{0%,to{box-shadow:0 0 #818cf880}50%{box-shadow:0 0 0 5px #818cf800}}.lp-stats-bar{flex-wrap:wrap;justify-content:center;align-items:center;gap:0;max-width:1180px;margin:0 auto;padding:28px 0 48px;display:flex}.lp-stat{text-align:center;padding:16px 48px}.lp-stat-num{letter-spacing:-.02em;background:linear-gradient(135deg, var(--brand), var(--blue));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:900}.lp-stat-label{color:var(--text-3);margin-top:4px;font-size:13px;font-weight:500}.lp-stat-sep{background:var(--border);width:1px;height:48px}.lp-screenshot-section{padding:0 0 56px}.lp-screenshot-section .lp-hero-mockup-wrap{max-width:min(100%,880px);margin-top:8px}.lp-section{padding:96px 24px;position:relative}.lp-section-alt{background:var(--bg-1);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.lp-section-inner{max-width:1180px;margin:0 auto}.lp-section-header{text-align:center;margin-bottom:64px}.lp-section-badge{border:1px solid var(--border);color:var(--brand);letter-spacing:.06em;text-transform:uppercase;border-radius:999px;align-items:center;gap:6px;margin-bottom:16px;padding:5px 14px;font-size:12px;font-weight:700;display:inline-flex}.lp-section-title{letter-spacing:-.025em;margin-bottom:16px;font-size:clamp(26px,3.5vw,40px);font-weight:900;line-height:1.15}.lp-section-sub{color:var(--text-2);max-width:640px;margin:0 auto;font-size:16px;line-height:1.7}.lp-features-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.lp-feature-card{background:var(--bg-1);border:1px solid var(--border);border-radius:16px;padding:24px 22px;transition:border-color .2s,transform .2s,box-shadow .2s}.lp-feature-card:hover{border-color:var(--border-hi);transform:translateY(-3px);box-shadow:0 12px 36px #00000040}.lp-feature-icon{border-radius:12px;flex-shrink:0;place-items:center;width:46px;height:46px;margin-bottom:16px;display:grid}.lp-feature-title{margin-bottom:8px;font-size:15px;font-weight:700}.lp-feature-desc{color:var(--text-2);font-size:13px;line-height:1.65}.lp-workflow-steps{flex-direction:column;gap:0;max-width:760px;margin:0 auto;display:flex;position:relative}.lp-workflow-steps:before{content:"";background:linear-gradient(to bottom, var(--brand), transparent);width:2px;position:absolute;top:48px;bottom:48px;left:36px}.lp-workflow-step{align-items:flex-start;gap:24px;padding:28px 0;display:flex}.lp-workflow-step-num{color:var(--brand);letter-spacing:.08em;text-align:center;min-width:28px;padding-top:14px;font-size:11px;font-weight:800}.lp-workflow-step-icon{background:var(--bg-2);border:1px solid var(--border);z-index:1;border-radius:12px;flex-shrink:0;place-items:center;width:48px;height:48px;display:grid;position:relative}.lp-workflow-step-body h3{letter-spacing:-.01em;margin-bottom:8px;font-size:17px;font-weight:700}.lp-workflow-step-body p{color:var(--text-2);font-size:14px;line-height:1.7}.lp-spotlight{grid-template-columns:1fr 1fr;align-items:center;gap:72px;margin-bottom:100px;display:grid}.lp-spotlight:last-child{margin-bottom:0}.lp-spotlight-reverse .lp-spotlight-content{order:2}.lp-spotlight-reverse .lp-spotlight-mock{order:1}.lp-spotlight-list{flex-direction:column;gap:10px;margin-top:20px;list-style:none;display:flex}.lp-spotlight-list li{color:var(--text-2);align-items:center;gap:10px;font-size:14px;display:flex}.lp-mock-error{border:1px solid var(--border);background:var(--bg-1);border-radius:14px;overflow:hidden;box-shadow:0 16px 56px #0006}.lp-mock-bar{justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:700;display:flex}.lp-mock-bar.red{background:var(--red-dim);border-bottom:1px solid var(--red);color:var(--red)}.lp-mock-btns{gap:6px;display:flex}.lp-mock-btn{border:1px solid var(--border);color:var(--text);background:var(--bg-2);cursor:pointer;border-radius:6px;padding:5px 10px;font-size:12px}.lp-mock-btn-outline{border:1px solid var(--border);color:var(--text-2);cursor:pointer;background:0 0;border-radius:6px;padding:5px 10px;font-size:12px}.lp-mock-ai-box{padding:14px 16px}.lp-mock-ai-header{color:var(--brand);align-items:center;gap:6px;margin-bottom:10px;font-size:12px;font-weight:700;display:flex}.lp-mock-apply{background:var(--brand);color:#fff;cursor:pointer;border-radius:6px;margin-left:auto;padding:4px 12px;font-size:11px;font-weight:700}.lp-mock-pre{font-family:var(--mono);color:var(--text-2);background:var(--bg);border:1px solid var(--border);white-space:pre-wrap;border-radius:8px;margin:0;padding:12px 14px;font-size:12px;line-height:1.6}.lp-mock-collab{border:1px solid var(--border);background:var(--bg-1);border-radius:14px;flex-direction:column;gap:10px;padding:16px;display:flex;overflow:hidden;box-shadow:0 16px 56px #0006}.lp-mock-member{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;align-items:center;gap:12px;padding:10px 12px;display:flex}.lp-mock-avatar{width:36px;height:36px;color:var(--btn-fg);border-radius:50%;flex-shrink:0;place-items:center;font-size:14px;font-weight:800;display:grid}.lp-mock-member-info{flex:1;min-width:0}.lp-mock-member-name{font-size:13px;font-weight:600}.lp-mock-member-status{color:var(--text-3);align-items:center;gap:5px;margin-top:2px;font-size:12px;display:flex}.lp-mock-online-dot{background:var(--green);border-radius:50%;flex-shrink:0;width:7px;height:7px}.lp-mock-chat-preview{background:var(--bg);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.lp-mock-chat-msg{color:var(--text-2);font-size:13px;line-height:1.5}.lp-mock-chat-msg strong{color:var(--text)}.lp-caps-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.lp-cap-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;align-items:flex-start;gap:14px;padding:18px 16px;transition:border-color .2s,transform .2s;display:flex}.lp-cap-card:hover{border-color:var(--border-hi);transform:translateY(-2px)}.lp-cap-icon{flex-shrink:0;margin-top:1px}.lp-cap-title{margin-bottom:4px;font-size:14px;font-weight:700}.lp-cap-desc{color:var(--text-2);font-size:12.5px;line-height:1.6}.lp-pricing-grid{grid-template-columns:1fr 1.1fr 1fr;align-items:start;gap:24px;max-width:860px;margin:0 auto;display:grid}.lp-pricing-card{border:1px solid var(--border);background:var(--bg-1);border-radius:18px;flex-direction:column;gap:14px;padding:30px 26px;display:flex;position:relative}.lp-pricing-highlighted{border-color:var(--brand);background:var(--bg-2);box-shadow:0 0 0 1px var(--brand), 0 16px 48px #818cf826}.lp-pricing-badge{background:var(--brand);color:#fff;letter-spacing:.04em;white-space:nowrap;border-radius:999px;padding:4px 14px;font-size:11px;font-weight:800;position:absolute;top:-13px;left:50%;transform:translate(-50%)}.lp-pricing-name{letter-spacing:-.01em;font-size:18px;font-weight:800}.lp-pricing-price{letter-spacing:-.03em;color:var(--brand);font-size:30px;font-weight:900}.lp-pricing-users{color:var(--text-3);border-bottom:1px solid var(--border);padding-bottom:12px;font-size:13px}.lp-pricing-features{flex-direction:column;flex:1;gap:10px;list-style:none;display:flex}.lp-pricing-features li{color:var(--text-2);align-items:center;gap:8px;font-size:13.5px;display:flex}.lp-pricing-btn{border:1.5px solid var(--border);width:100%;color:var(--text-2);border-radius:10px;justify-content:center;align-items:center;gap:6px;margin-top:6px;padding:11px 0;font-size:14px;font-weight:700;transition:background .15s,border-color .15s,color .15s;display:flex}.lp-pricing-btn:hover{background:var(--bg-hover);border-color:var(--border-hi);color:var(--text)}.lp-pricing-btn-primary{background:var(--brand);border-color:var(--brand);color:#fff}.lp-pricing-btn-primary:hover{background:var(--brand-hover);border-color:var(--brand-hover);color:#fff}.lp-pricing-note{text-align:center;color:var(--text-3);justify-content:center;align-items:center;gap:7px;margin-top:28px;font-size:13px;display:flex}.lp-cta{text-align:center;background:var(--bg-1);border-top:1px solid var(--border);padding:96px 24px;position:relative;overflow:hidden}.lp-cta-glow{pointer-events:none;background:radial-gradient(circle,#818cf81f 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.lp-cta-inner{max-width:680px;margin:0 auto;position:relative}.lp-cta-logo-img{object-fit:contain;width:auto;height:56px;margin:0 auto 20px;display:block}.lp-cta-title{letter-spacing:-.025em;margin-bottom:16px;font-size:clamp(28px,4vw,44px);font-weight:900;line-height:1.1}.lp-cta-sub{color:var(--text-2);margin-bottom:36px;font-size:16px;line-height:1.7}.lp-btn-cta{color:#fff;letter-spacing:-.01em;background:linear-gradient(135deg,#818cf8,#6366f1);border-radius:14px;align-items:center;gap:9px;margin-bottom:24px;padding:16px 36px;font-size:17px;font-weight:800;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 8px 32px #818cf84d}.lp-btn-cta:hover{transform:translateY(-3px);box-shadow:0 14px 44px #818cf866}.lp-cta-trust{color:var(--text-3);flex-wrap:wrap;justify-content:center;gap:24px;font-size:13px;display:flex}.lp-cta-trust span{align-items:center;gap:6px;display:flex}.lp-footer{background:var(--bg);border-top:1px solid var(--border);padding:40px 24px}.lp-footer-inner{text-align:center;flex-direction:column;align-items:center;gap:16px;max-width:1180px;margin:0 auto;display:flex}.lp-footer-logo{align-items:center;gap:10px;display:flex}.lp-footer-tagline{color:var(--text-2);font-size:14px;font-style:italic}.lp-footer-links{flex-wrap:wrap;justify-content:center;align-items:center;gap:24px;display:flex}.lp-footer-links a{color:var(--text-3);font-size:13.5px;transition:color .15s}.lp-footer-links a:hover{color:var(--text);text-decoration:none}.lp-footer-signin{color:var(--brand);font-size:13.5px;font-weight:600;transition:opacity .15s}.lp-footer-signin:hover{opacity:.75}.lp-footer-copy{color:var(--text-3);font-size:12px}@media (width<=1100px){.lp-features-grid,.lp-caps-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.lp-hero{min-height:0;overflow:visible}.lp-hero-inner{gap:12px;padding:72px 20px 14px}.lp-hero-overline{letter-spacing:.08em;margin-bottom:0;font-size:11px}.lp-hero-logo-img{height:48px;margin-bottom:0}.lp-hero-identity{margin-bottom:0}.lp-hero-headline{margin-bottom:0;font-size:clamp(28px,6.5vw,44px);line-height:1.1}.lp-hero-desc{margin-bottom:0;padding:0 4px;font-size:14px}.lp-hero-pill-track{justify-content:center;gap:6px}.lp-hero-hl{-webkit-text-stroke:0;paint-order:normal;color:var(--brand);text-shadow:none}[data-theme=light] .lp-hero-hl{-webkit-text-stroke:0;color:var(--brand)}.lp-hero-preview{display:none}.lp-features-grid,.lp-caps-grid{grid-template-columns:repeat(2,1fr)}.lp-spotlight,.lp-spotlight-reverse{grid-template-columns:1fr;gap:36px}.lp-spotlight-reverse .lp-spotlight-content,.lp-spotlight-reverse .lp-spotlight-mock{order:0}.lp-pricing-grid{grid-template-columns:1fr;max-width:380px}.lp-nav-links{display:none}.lp-nav-actions.lp-nav-actions--desktop{display:none!important}.lp-nav-mobile{display:block}.lp-stat{padding:12px 28px}.lp-mock-appbody{grid-template-rows:minmax(0,1fr);grid-template-columns:minmax(96px,118px) minmax(0,1fr) minmax(128px,34%)}.lp-mock-apeditor{min-height:0}.lp-mock-appright{border-left:1px solid var(--border);border-top:none;min-height:0;display:flex}.lp-mock-projects-screen{grid-template-columns:142px 1fr}}@media (width<=600px){.lp-nav{padding:0 12px}.lp-features-grid,.lp-caps-grid{grid-template-columns:1fr}.lp-hero{min-height:0;padding-top:0}.lp-hero-inner{gap:10px;padding:68px 16px 10px}.lp-hero-overline{letter-spacing:.07em;margin-bottom:0;padding:0 8px;font-size:10px;line-height:1.35}.lp-hero-logo-img{height:44px;margin-bottom:0}.lp-hero-identity{margin-bottom:0}.lp-hero-headline{letter-spacing:-.035em;margin-bottom:0;padding:0 4px;font-size:clamp(24px,8.2vw,34px);line-height:1.14}.lp-hero-hl{-webkit-text-stroke:0;paint-order:normal;color:var(--brand);text-shadow:none}[data-theme=light] .lp-hero-hl{-webkit-text-stroke:0;color:var(--brand)}.lp-hero-desc{max-width:100%;margin-bottom:0;padding:0 4px;font-size:14px;line-height:1.55}.lp-hero-ctas{flex-direction:column;gap:10px;width:100%;max-width:100%;padding:0 4px}.lp-hero-ctas .lp-btn-hero,.lp-hero-ctas .lp-btn-hero-ghost{justify-content:center;width:100%;max-width:400px;margin-left:auto;margin-right:auto}.lp-hero-pill-track{justify-content:center;gap:6px;padding:0 4px 4px}.lp-hero-pill{padding:5px 10px;font-size:11px}.lp-hero-title{font-size:36px}.lp-stats-bar{gap:0}.lp-stat-sep{display:none}.lp-stat{padding:12px 16px}.lp-hero-mockup-wrap{max-width:100%;padding:0 14px}.lp-app-mock{border-radius:12px;height:min(62vh,520px);min-height:380px}.lp-mock-appheader{gap:6px;padding:0 8px}.lp-mock-projectname{white-space:nowrap;text-overflow:ellipsis;max-width:120px;overflow:hidden}.lp-mock-mpill,.lp-mock-icon-sq{display:none}.lp-mock-appbody{grid-template-rows:minmax(0,1fr);grid-template-columns:minmax(0,1fr) minmax(104px,42%)}.lp-mock-appsidebar{display:none}.lp-mock-apeditor{min-width:0;min-height:0}.lp-mock-appright{border-left:1px solid var(--border);border-top:none;min-width:0;min-height:0;display:flex}.lp-mock-projects-screen{grid-template-columns:1fr}.lp-mock-projects-sidebar{display:none}.lp-mock-projects-main{padding:12px}.lp-mock-projects-title{font-size:16px}.lp-mock-drop-overlay-title{font-size:14px}.lp-mock-statusbar span:first-child,.lp-mock-statusbar span:nth-child(2),.lp-mock-statusbar span:nth-child(3){display:none}.lp-screenshot-section{padding-bottom:40px}}.dashboard{background:var(--bg);height:100vh;color:var(--text);flex-direction:column;display:flex}.dash-header{height:var(--header-h);background:var(--bg-1);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:0 20px;display:flex}.dash-header-logo{align-items:center;display:flex}.dash-header-actions{align-items:center;gap:6px;display:flex}.dash-user-pill{background:var(--bg-2);border:1px solid var(--border);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;display:flex}.dash-user-avatar{background:var(--brand);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:flex}.dash-user-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-weight:500;overflow:hidden}.dash-body{flex:1;display:flex;overflow:hidden}.dash-sidebar{background:var(--bg-1);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;padding:16px 0;display:flex;overflow-y:auto}.dash-new-wrap{padding:0 12px 16px;position:relative}.dash-new-btn{justify-content:flex-start;gap:6px;width:100%}.dash-new-btn>:last-child{flex-shrink:0;margin-left:auto}.dash-new-menu{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow);z-index:200;flex-direction:column;gap:1px;padding:4px;display:flex;position:absolute;top:calc(100% - 4px);left:12px;right:12px}.dash-new-menu button{border-radius:var(--r-sm);color:var(--text-2);text-align:left;align-items:center;gap:8px;width:100%;padding:7px 10px;font-size:13px;transition:background .1s,color .1s;display:flex}.dash-new-menu button:hover{background:var(--bg-hover);color:var(--text)}.dash-new-menu-sep{background:var(--border);height:1px;margin:4px 0}.dash-new-menu-label{letter-spacing:.5px;color:var(--text-3);text-transform:uppercase;padding:4px 10px 2px;font-size:10px;font-weight:600}.dash-nav{flex-direction:column;gap:1px;padding:0 8px;display:flex}.dash-nav-item{border-radius:var(--r-sm);color:var(--text-2);text-align:left;align-items:center;gap:8px;width:100%;padding:7px 10px;font-size:13px;transition:background .1s,color .1s;display:flex}.dash-nav-item:hover{background:var(--bg-hover);color:var(--text)}.dash-nav-item.active{background:var(--brand-dim);color:var(--brand);font-weight:600}.dash-nav-count{background:var(--bg-2);color:var(--text-3);text-align:center;border-radius:10px;min-width:18px;margin-left:auto;padding:0 6px;font-size:11px}.dash-nav-item.active .dash-nav-count{background:var(--brand-dim);color:var(--brand)}.dash-sidebar-sep{background:var(--border);height:1px;margin:12px}.dash-nav-section-label{letter-spacing:.5px;color:var(--text-3);text-transform:uppercase;align-items:center;gap:5px;padding:4px 18px 6px;font-size:10px;font-weight:700;display:flex}.dash-tag-item{align-items:center;gap:6px;display:flex;position:relative}.dash-tag-item .dash-tag-actions{align-items:center;gap:2px;margin-left:auto;display:none}.dash-tag-item:hover .dash-tag-actions{display:flex}.dash-tag-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.dash-tag-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.dash-tag-action-btn{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:2px;display:inline-flex}.dash-tag-action-btn:hover{background:var(--bg-hover);color:var(--text)}.dash-tag-rename-input{border:1px solid var(--brand);border-radius:var(--r-sm);background:var(--bg);color:var(--text);outline:none;flex:1;min-width:0;padding:2px 6px;font-size:12px}.dash-tag-new-row{align-items:center;gap:6px;padding:3px 18px;display:flex}.dash-row-tags{flex-wrap:wrap;gap:4px;margin-top:3px;display:flex}.dash-tag-chip{border:1px solid #0000;border-radius:999px;align-items:center;padding:1px 7px;font-size:10px;font-weight:600;display:inline-flex}.dash-tag-dropdown{z-index:200;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;gap:2px;min-width:150px;padding:4px;display:flex;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 6px 24px #0000002e}.dash-tag-dropdown-item{border-radius:var(--r-sm);color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:7px;padding:6px 10px;font-size:12px;display:flex}.dash-tag-dropdown-item:hover{background:var(--bg-hover)}.dash-tag-dropdown-item.checked{color:var(--brand)}.dash-tag-check{margin-left:auto;font-size:12px;font-weight:700}.dash-main{flex-direction:column;flex:1;gap:0;padding:28px 32px;display:flex;overflow-y:auto}.dash-main-top{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.dash-main-top-right{align-items:center;gap:6px;display:flex}.dash-title{color:var(--text);font-size:20px;font-weight:700}.dash-search-wrap{flex-shrink:0;align-items:center;margin-bottom:16px;display:flex;position:relative}.dash-search-icon{color:var(--text-3);pointer-events:none;position:absolute;left:12px}.dash-search{border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-2);width:100%;color:var(--text);outline:none;padding:9px 12px 9px 36px;font-size:14px;transition:border-color .15s}.dash-search:focus{border-color:var(--blue)}.dash-search::placeholder{color:var(--text-3)}.dash-search-clear{color:var(--text-3);border-radius:4px;padding:2px;position:absolute;right:10px}.dash-search-clear:hover{color:var(--text);background:var(--bg-hover)}.dash-trash-banner{border-radius:var(--r-sm);background:var(--red-dim);border:1px solid var(--red);color:var(--red);flex-shrink:0;align-items:center;gap:8px;margin-bottom:16px;padding:10px 16px;font-size:13px;display:flex}.dash-loading{color:var(--text-3);justify-content:center;align-items:center;gap:10px;padding:60px 0;display:flex}.dash-empty{color:var(--text-3);text-align:center;flex-direction:column;align-items:center;gap:14px;padding:80px 0;display:flex}.dash-table-wrap{border:1px solid var(--border);border-radius:var(--r-md);flex-shrink:0;overflow:hidden}.dash-table{border-collapse:collapse;width:100%;font-size:13px}.dash-table thead tr{background:var(--bg-2);border-bottom:1px solid var(--border)}.dash-table th{text-align:left;color:var(--text-3);white-space:nowrap;padding:10px 16px;font-size:12px;font-weight:600}.dash-row{border-bottom:1px solid var(--border);transition:background .1s}.dash-row:last-child{border-bottom:none}.dash-row:hover{background:var(--bg-hover)}.dash-row td{vertical-align:middle;padding:10px 16px}.dash-row-icon{border-radius:var(--r-sm);background:var(--brand-dim);width:28px;height:28px;color:var(--brand);justify-content:center;align-items:center;display:flex}.dash-row-name{color:var(--text);text-align:left;cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;font-size:13px;font-weight:500;transition:color .12s;display:flex}.dash-row-name:hover:not(:disabled){color:var(--brand)}.dash-row-name:disabled{opacity:.5;cursor:not-allowed}.dash-row-owner{color:var(--text-3);font-size:12px}.dash-row-time{color:var(--text-3);white-space:nowrap;align-items:center;gap:6px;font-size:12px;display:flex}.dash-row-actions{opacity:0;justify-content:flex-end;align-items:center;gap:2px;transition:opacity .15s;display:flex}.dash-row:hover .dash-row-actions{opacity:1}.dash-badge{border-radius:999px;align-items:center;padding:1px 7px;font-size:10px;font-weight:600;line-height:1.5;display:inline-flex}.dash-badge.archived{background:var(--yellow-dim,#e3b34126);color:var(--yellow);border:1px solid var(--yellow)}.dash-badge.shared{background:var(--blue-dim);color:var(--blue);border:1px solid var(--blue)}.danger-hover:hover{color:var(--red)!important}.dash-ctx-menu{z-index:500;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow);flex-direction:column;gap:1px;min-width:180px;padding:4px;display:flex;position:fixed}.dash-ctx-menu button{border-radius:var(--r-sm);color:var(--text-2);text-align:left;align-items:center;gap:8px;width:100%;padding:7px 12px;font-size:13px;transition:background .1s,color .1s;display:flex}.dash-ctx-menu button:hover{background:var(--bg-hover);color:var(--text)}.dash-ctx-menu button.danger{color:var(--red)}.dash-ctx-menu button.danger:hover{background:var(--red-dim)}.dash-ctx-sep{background:var(--border);height:1px;margin:4px 0}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);flex-direction:column;width:460px;max-width:95vw;display:flex}.modal-box-lg{width:780px;max-height:85vh}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-header h3{font-size:16px;font-weight:700}.modal-body{flex:1;padding:20px;overflow-y:auto}.modal-label{color:var(--text-3);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:14px 20px;display:flex}.dash-drop-zone{border:2px dashed var(--border);border-radius:var(--r-md);text-align:center;color:var(--text-3);cursor:pointer;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;font-size:14px;transition:border-color .15s,background .15s;display:flex}.dash-drop-zone:hover{border-color:var(--brand);background:var(--brand-dim);color:var(--text)}.modal-body-tpl{align-items:stretch;gap:16px;min-height:360px;display:flex}.modal-body--template-picker{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.modal-body--template-picker .modal-body-tpl{flex:1;min-height:0}.tpl-categories{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:2px;width:160px;padding-right:12px;display:flex}.tpl-cat-item{border-radius:var(--r-sm);color:var(--text-2);text-align:left;align-items:center;gap:7px;width:100%;padding:7px 10px;font-size:12px;transition:background .1s,color .1s;display:flex}.tpl-cat-item:hover{background:var(--bg-hover);color:var(--text)}.tpl-cat-item.active{background:var(--brand-dim);color:var(--brand);font-weight:600}.tpl-grid-wrap{flex:1;min-width:0;overflow-y:auto}.tpl-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;padding-top:4px;display:grid}.tpl-card{border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-2);text-align:left;cursor:pointer;flex-direction:column;padding:0;transition:border-color .15s,background .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.tpl-card:hover{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-dim)}.tpl-card:disabled{opacity:.6;cursor:not-allowed}.tpl-thumb{border-bottom:1px solid var(--border);aspect-ratio:3/4;background:#f4f5f7;justify-content:center;align-items:stretch;width:100%;display:flex;position:relative;overflow:hidden}.tpl-thumb-img{object-fit:cover;object-position:top center;width:100%;height:100%;display:block}.tpl-thumb-svg{flex-shrink:0;width:100%;height:auto;display:block}.tpl-thumb-loading{pointer-events:none;background:#0000000f;animation:1.4s ease-in-out infinite tpl-pulse;position:absolute;inset:0}@keyframes tpl-pulse{0%,to{opacity:.3}50%{opacity:.7}}.tpl-thumb-skeleton{background:var(--bg-3,#2a2d36);width:100%;height:100%;color:var(--text-3);justify-content:center;align-items:center;display:flex}.tpl-card-icon{border-radius:var(--r-sm);background:var(--bg);width:32px;height:32px;color:var(--brand);flex-shrink:0;justify-content:center;align-items:center;display:flex}.tpl-card-info{flex:1;min-width:0;padding:10px 11px 11px}.tpl-card-name{color:var(--text);margin-bottom:3px;font-size:12px;font-weight:600}.tpl-card-desc{color:var(--text-3);margin-bottom:5px;font-size:10.5px;line-height:1.4}.tpl-card-cat{text-transform:uppercase;letter-spacing:.4px;color:var(--brand);align-items:center;gap:4px;font-size:10px;font-weight:600;display:inline-flex}.tpl-busy{color:var(--text-3);position:absolute;top:8px;right:8px}.spinning{animation:.8s linear infinite spin}.btn-back-dash{color:var(--text-3);border-radius:var(--r-sm);align-items:center;gap:6px;padding:4px 8px;font-size:12px;transition:background .1s,color .1s;display:inline-flex}.btn-back-dash:hover{background:var(--bg-hover);color:var(--text)}@media (width<=1024px){.dash-sidebar{width:200px}.dash-main{padding:24px 22px}}@media (width<=900px){.dash-sidebar{top:var(--header-h);z-index:100;width:min(280px,84vw);transition:transform .22s cubic-bezier(.2,.7,.2,1);position:fixed;bottom:0;left:0;transform:translate(-100%);box-shadow:0 12px 36px #0006}.dash-sidebar.mobile-open{transform:translate(0)}.dash-main{padding:20px 18px}.dash-user-name{display:none}.dash-user-pill{padding:4px 6px}}@media (width<=600px){.dash-header{gap:4px;padding:0 8px}.dash-header-actions{gap:4px}.dash-header-actions .btn-ghost{padding:6px 10px;font-size:12px}.dash-header-actions .icon-btn--text{display:none}.dash-main{padding:14px 12px}.dash-title{font-size:17px}.dash-table-wrap{border-radius:var(--r-md);-webkit-overflow-scrolling:touch;overflow-x:auto}.dash-table{min-width:460px}.dash-table th:nth-child(3),.dash-row td:nth-child(3){display:none}.dash-row td{padding:12px 10px}.dash-row-name{font-size:13.5px}.dash-row-actions{opacity:1}.dash-row-actions .icon-btn{width:32px;height:32px}.modal-body-tpl .tpl-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}}
