.landing-page{min-height:100vh;display:flex;flex-direction:column}body.has-fixed-footer .hero{padding-bottom:calc(24px + var(--footer-h))}.sidebar{display:flex;flex-direction:column;border-right:1px solid var(--border);padding:14px;gap:14px;background:var(--bg-elev);position:sticky;top:var(--header-h);align-self:start;height:calc(100vh - var(--header-h));overflow:hidden}.sidebar-header{display:flex;flex-direction:column;gap:10px}.sidebar-mobile-controls,.close-sidebar-btn{display:none}.chat-list{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:10px}.chat-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px;border:1px solid #1f2a44;background:#0e1424;border-radius:12px;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}.chat-item.active{border-color:#2c5db2}.chat-item .title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-item .actions{display:flex;gap:6px}.sidebar-footer{display:flex;flex-direction:column;gap:8px;position:sticky;bottom:0;background:var(--bg-elev);padding-top:8px;border-top:1px solid var(--border)}@media (max-width: 980px){.sidebar-mobile-controls{display:flex}.close-sidebar-btn{display:inline-flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;height:100vh;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:20}.sidebar.open{transform:translate(0)}}.messages{flex:1;overflow-y:auto;padding:0 18px 18px;display:flex;flex-direction:column;gap:14px;background:var(--bg)}.message{display:grid;grid-template-columns:36px 1fr;gap:10px}.avatar{width:36px;height:36px;border-radius:10px;background:#1b2230;display:grid;place-items:center;color:#9fb7ff;font-weight:600;border:1px solid var(--border)}.avatar-icon{font-size:20px}.avatar-logo{width:28px;height:28px;object-fit:contain;border-radius:4px;filter:invert(1) brightness(1.1)}.bubble-msg{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:10px 12px;line-height:1.6}.bubble-msg.user{background:#1b2230;border-color:#28324a}.bubble-msg h1,.bubble-msg h2,.bubble-msg h3,.bubble-msg h4,.bubble-msg h5,.bubble-msg h6{margin:.8em 0 .5em;font-weight:600;line-height:1.3}.bubble-msg h1:first-child,.bubble-msg h2:first-child,.bubble-msg h3:first-child,.bubble-msg h4:first-child,.bubble-msg h5:first-child,.bubble-msg h6:first-child{margin-top:0}.bubble-msg h1{font-size:1.5em}.bubble-msg h2{font-size:1.3em}.bubble-msg h3{font-size:1.15em}.bubble-msg h4{font-size:1.05em}.bubble-msg h5{font-size:1em}.bubble-msg h6{font-size:.95em}.bubble-msg p{margin:.8em 0;line-height:1.6}.bubble-msg p:first-child{margin-top:0}.bubble-msg p:last-child{margin-bottom:0}.bubble-msg strong{font-weight:600}.bubble-msg em{font-style:italic}.bubble-msg code{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-family:Monaco,Menlo,Courier New,monospace;font-size:.9em}.bubble-msg pre{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px;overflow-x:auto;margin:.8em 0}.bubble-msg pre code{background:none;border:none;padding:0;display:block;line-height:1.5}.bubble-msg ul,.bubble-msg ol{margin:.8em 0;padding-left:1.5em;line-height:1.6}.bubble-msg ul{list-style-type:disc}.bubble-msg ol{list-style-type:decimal}.bubble-msg li{margin:.3em 0}.bubble-msg blockquote{border-left:3px solid var(--primary);padding-left:12px;margin:.8em 0;color:var(--muted);font-style:italic}.bubble-msg a{color:var(--primary);text-decoration:none}.bubble-msg a:hover{text-decoration:underline}.bubble-msg hr{border:none;border-top:1px solid var(--border);margin:1em 0}.bubble-msg table{border-collapse:collapse;width:100%;margin:.8em 0}.bubble-msg table th,.bubble-msg table td{border:1px solid var(--border);padding:8px 12px;text-align:left}.bubble-msg table th{background:var(--bg);font-weight:600}.meta{color:var(--muted);font-size:12px;margin-top:6px}.attachments-wrap{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.attach-chip{display:flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--panel);border-radius:10px;padding:4px;font-size:12px;max-width:100%}.messages .attach-chip img{max-width:600px;max-height:450px;width:auto;height:auto;object-fit:contain;border-radius:8px;background:#0b0e13;cursor:pointer;display:block}@media (max-width: 980px){.messages .attach-chip img{max-width:500px;max-height:375px}}@media (max-width: 640px){.messages .attach-chip img{max-width:100%;max-height:300px}}.typing{display:inline-flex;align-items:center;gap:6px}.typing .dot{width:6px;height:6px;border-radius:50%;background:var(--muted);opacity:.35;animation:typing-bounce 1s infinite ease-in-out}.typing .dot:nth-child(2){animation-delay:.15s}.typing .dot:nth-child(3){animation-delay:.3s}@keyframes typing-bounce{0%,80%,to{transform:translateY(0);opacity:.35}40%{transform:translateY(-4px);opacity:1}}.typing .step-summary{color:var(--muted);font-size:12px;margin-left:6px}.composer{padding:10px 16px;padding-bottom:max(10px,env(safe-area-inset-bottom));border-top:1px solid var(--border);background:var(--bg-elev)}#composerForm{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:10px;align-items:end}.composer-left{display:flex;align-items:center}.input-textarea{resize:none;max-height:160px;min-height:40px;overflow:auto}.hints{color:var(--muted);padding:6px 2px;font-size:12px}.attach-preview{display:flex;align-items:center;gap:8px;grid-column:1 / -1;flex-wrap:wrap;padding:4px 0}.attach-chip{display:flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--panel);border-radius:10px;padding:4px 8px;white-space:nowrap;font-size:12px}.attach-chip img{width:32px;height:32px;object-fit:cover;border-radius:6px}.attach-chip .del{cursor:pointer;color:#ff6b6b;font-weight:700;padding-left:4px}.settings-panel{padding:18px;background:var(--bg);overflow:auto;height:100%}.settings-panel h2{margin-top:0;display:flex;align-items:center;gap:8px}.setting-item{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;border:1px solid var(--border);background:var(--panel);border-radius:12px;padding:12px;margin-bottom:10px}.setting-item.danger{border-color:#3b2026;background:#1c0f12}.accordion .accordion-header{width:100%;display:flex;justify-content:flex-start;align-items:center;cursor:pointer;gap:8px}.accordion .accordion-header>span:nth-child(2){flex-shrink:0}.accordion .accordion-header .spinner,.accordion .accordion-header .status{margin-left:auto}.accordion .accordion-arrow{transition:transform .2s ease}.accordion.open .accordion-arrow{transform:rotate(90deg)}.accordion .accordion-content{display:none;width:100%;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.accordion.open .accordion-content{display:block}.doc-empty{color:var(--muted);padding:12px;text-align:center}.document-list{margin-top:10px}.drop-zone{border:2px dashed var(--border);border-radius:12px;padding:20px;text-align:center;color:var(--muted);cursor:pointer;margin-bottom:15px;transition:all .2s ease}.drop-zone p{margin:0}.drop-zone:hover,.drop-zone.dragover{border-color:var(--primary);background:color-mix(in oklab,var(--primary),transparent 90%)}.document-list-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;background:var(--bg);margin-bottom:5px}.document-info{flex:1;overflow:hidden}.document-info .doc-name{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.document-info .doc-size{font-size:12px;color:var(--muted)}.feature-request-panel{padding:18px;background:var(--bg);overflow:auto;height:100%}.feature-request-panel h2{margin-top:0;margin-bottom:12px;display:flex;align-items:center;gap:8px}.feature-description-text{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:20px;padding:12px;background:var(--panel);border:1px solid var(--border);border-radius:8px}.features-list{margin-top:24px}.feature-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;transition:all .2s ease}.feature-card:hover,.feature-card.expanded{border-color:var(--primary)}.feature-header{cursor:pointer;-webkit-user-select:none;user-select:none}.feature-main{display:flex;flex-direction:column;gap:12px}.feature-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.expand-arrow{color:var(--muted);font-size:12px;transition:transform .2s ease;flex-shrink:0}.feature-title{margin:0;font-size:16px;font-weight:600;color:var(--text);flex:1}.status-badge-small{padding:3px 8px;border-radius:10px;font-size:11px;font-weight:600;color:#0b0e13;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.vote-progress{display:flex;flex-direction:column;gap:6px}.progress-bar-bg{width:100%;height:8px;background:var(--panel);border:1px solid var(--border);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));transition:width .3s ease;border-radius:4px}.progress-text{font-size:12px;color:var(--muted)}.vote-buttons{display:flex;gap:8px;flex-wrap:wrap}.vote-buttons .btn{flex:1;min-width:100px}.feature-description{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.description-content{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:12px;line-height:1.6;white-space:pre-wrap;margin-bottom:12px}.feature-meta{display:flex;gap:8px;font-size:12px;color:var(--muted);align-items:center}.chat-page{min-height:100vh;display:flex;flex-direction:column}.app-shell{display:grid;grid-template-columns:280px 1fr;height:calc(100vh - var(--header-h));overflow:hidden}@media (max-width: 980px){.app-shell{grid-template-columns:1fr}}:root{--bg: #0b0e13;--bg-elev: #11151d;--panel: #0f131a;--text: #e6e9ef;--muted: #98a1b3;--primary: #58a6ff;--primary-600: #3d8bff;--danger: #ff5c7a;--accent: #4ade80;--border: #1e2532;--shadow: 0 10px 30px rgba(0, 0, 0, .45);--header-h: 64px;--footer-h: 76px}.theme-light{--bg: #f7f8fb;--bg-elev: #ffffff;--panel: #ffffff;--text: #151923;--muted: #5b6374;--border: #e6e8ef;--shadow: 0 10px 30px rgba(0, 0, 0, .08)}.theme-light .setting-item.danger{background:#fff5f5;border-color:#f7d4d4;color:#c53030}.theme-light .chat-item{background:#e9eef6;border-color:#dbe1ec}.theme-light .bubble-msg.user{background:#e1eafc;border-color:#d1daeb;color:#1c2b4d}.theme-light .bubble-msg{background:#fff;border-color:#e6e8ef;color:#151923}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}#root{min-height:100vh}.hidden{display:none!important}.spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;display:inline-block;margin-left:8px}@keyframes spin{to{transform:rotate(360deg)}}.status{margin-left:8px;font-size:12px;font-weight:600;display:inline-flex;align-items:center}.status.success{color:#22c55e}.status.error{color:#ef4444}.btn{border:1px solid var(--border);background:var(--bg-elev);color:var(--text);padding:10px 14px;border-radius:10px;cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow);font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:6px;font-family:inherit}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#0b0e13;border-color:transparent}.btn-primary:hover{background:var(--primary-600)}.btn-secondary{background:transparent}.btn-ghost{background:transparent;border-color:var(--border)}.btn-danger{background:var(--danger);color:#fff;border-color:transparent}.btn-xs{padding:4px 8px;font-size:12px;border-radius:6px}.btn-lg{padding:12px 18px;font-weight:600;border-radius:12px;font-size:15px}.btn.full{width:100%}.btn .icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px}.input{width:100%;background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:12px 14px;outline:none;box-shadow:var(--shadow);font-size:14px;font-family:inherit}.input:focus{border-color:var(--primary)}.site-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:color-mix(in oklab,var(--bg),transparent 10%);height:var(--header-h)}.brand{display:flex;align-items:center;gap:10px;font-weight:600}.brand-txt{display:flex;flex-direction:column}.brand-subtitle{color:var(--muted);font-weight:400;font-size:12px;margin-top:2px}.brand.small .brand-name{font-size:18px}.logo{width:32px;height:32px;object-fit:contain;border-radius:6px}.theme-dark .logo{filter:invert(1) hue-rotate(180deg) brightness(1.2) saturate(.8)}.theme-light .logo{filter:none}.drone-img{max-width:520px;width:100%;height:auto;filter:drop-shadow(0 10px 25px rgba(0,0,0,.55));opacity:.95;margin-left:16px}.drone-img-left{max-width:400px;width:100%;height:auto;filter:drop-shadow(0 10px 25px rgba(0,0,0,.55));opacity:.95;margin-top:24px}#sidebarToggle{display:none}.brand-name{font-size:18px}.top-nav{display:flex;align-items:center;gap:10px}.user-pill{display:flex;align-items:center;gap:8px;background:var(--panel);padding:6px 12px;border-radius:12px;border:1px solid var(--border);font-weight:500}.hero{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;padding:48px 24px 24px;max-width:1200px;margin:0 auto;min-height:calc(100vh - var(--header-h) - var(--footer-h))}.hero-content{display:flex;flex-direction:column;justify-content:center}.hero-content h1{font-size:clamp(32px,4vw,52px);margin:0 0 12px;letter-spacing:-.02em}.subtitle{color:var(--muted);margin:0 0 24px}.hero-art{position:relative;display:flex;align-items:center;justify-content:center;flex-direction:column}.glass-card{position:relative;width:100%;max-width:520px;aspect-ratio:4/3;background:linear-gradient(180deg,color-mix(in oklab,var(--panel),transparent 35%),var(--panel));border:1px solid var(--border);border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}.bubble{position:absolute;top:10%;right:-8%;width:180px;height:180px;background:radial-gradient(circle at 30% 30%,var(--primary),transparent 60%);filter:blur(12px);opacity:.3}.bubble.small{top:auto;bottom:10%;left:-8%;width:140px;height:140px;background:radial-gradient(circle at 30% 30%,var(--accent),transparent 60%)}.bubble.tiny{top:45%;left:60%;width:80px;height:80px;background:radial-gradient(circle at 30% 30%,#a78bfa,transparent 60%);opacity:.4}.mock-chat{position:absolute;top:18px;right:18px;bottom:18px;left:18px;display:flex;flex-direction:column;gap:10px;overflow:auto}.msg{max-width:85%;padding:10px 12px;border-radius:14px;line-height:1.4;border:1px solid var(--border);font-size:14px}.msg.user{align-self:flex-end;background:#1b2240;color:#dbe7ff}.msg.bot{align-self:flex-start;background:#141a22;color:var(--text)}.site-footer{display:flex;align-items:center;justify-content:center;flex-direction:column;padding:8px 20px;border-top:1px solid var(--border);color:var(--muted);font-size:13px;gap:6px;text-align:center}.landing-footer{position:fixed;left:0;right:0;bottom:0;height:var(--footer-h);padding:14px 28px;background:var(--bg-elev);z-index:10}.footer-links{display:flex;align-items:center;gap:8px}.made-with-love{color:var(--muted)}.link{color:var(--primary);text-decoration:none}.link:hover{text-decoration:underline}.modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;z-index:50}.modal.open{display:block}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-card{position:relative;max-width:760px;margin:10vh auto;background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.auth-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.auth-card{border:1px solid var(--border);background:var(--panel);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow)}.auth-card h3{margin:0 0 6px}.chat-title-wrap{position:sticky;top:0;z-index:2;padding:12px 18px;background:var(--bg);text-align:center;border-bottom:1px solid var(--border);margin-bottom:6px}.chat-title-pill{display:inline-block;padding:10px 16px;border:1px solid var(--border);background:var(--bg-elev);border-radius:12px;font-weight:600;box-shadow:var(--shadow);max-width:70%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.content{position:relative;overflow-y:hidden;display:flex;flex-direction:column;height:100%}.main{display:grid;grid-template-rows:1fr auto;height:calc(100vh - var(--header-h));overflow:hidden}.sidebar-backdrop{display:none}@media (max-width: 980px){.hero{grid-template-columns:1fr}#sidebarToggle{display:flex!important;align-items:center}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:19;opacity:0;pointer-events:none;transition:opacity .3s ease-in-out}.app-shell.sidebar-open .sidebar-backdrop{opacity:1;pointer-events:auto}.auth-grid{grid-template-columns:1fr}.drone-img{margin:12px auto 0;max-width:420px}.drone-img-left{max-width:320px;margin:16px 0 0}}@media (max-width: 640px){.site-header{padding:12px 16px}.brand-txt{display:none}.hero{padding:24px 16px 16px;gap:24px}.hero-content h1{font-size:28px}.landing-footer{padding:10px 16px;height:auto}}
