body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--nav-height:72px;--mobile-nav-height:64px;--bg-dark:#0f172a}*{box-sizing:border-box;padding:0}*,body{margin:0}body{background-color:#0f172a;background-color:var(--bg-dark);color:#f8fafc;height:100dvh;overflow:hidden}.App{display:flex;flex-direction:column;height:100dvh;width:100%}.main-layout{background:radial-gradient(circle at top right,#3b82f61a,#0000),radial-gradient(circle at bottom left,#a855f70d,#0000);position:relative}.content-area,.main-layout{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.content-area{align-items:center;padding:1.5rem}.app-wrapper{display:flex;flex-direction:column;height:100%;max-width:900px;width:100%}@media (max-width:768px){.content-area{padding:.5rem .5rem calc(64px + env(safe-area-inset-bottom, 0px) + .5rem);padding-bottom:calc(var(--mobile-nav-height) + env(safe-area-inset-bottom, 0px) + .5rem)}}.chat-container{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#1e1f24b3;border:1px solid #ffffff1a;border-bottom:none;border-radius:20px 20px 0 0;box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;font-family:Inter,-apple-system,sans-serif;height:100%;margin:0 auto;max-width:900px;overflow:hidden;transition:all .3s ease;width:100%}.chat-messages{background:#0000;display:flex;flex:1 1;flex-direction:column;gap:1.25rem;overflow-y:auto;padding:1.5rem;scroll-behavior:smooth}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#0000}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.chat-bubble{animation:slideIn .3s cubic-bezier(.18,.89,.32,1.28);border-radius:18px;display:flex;flex-direction:column;line-height:1.5;max-width:85%;padding:1rem 1.25rem}.chat-bubble.user{align-self:flex-end;background:linear-gradient(135deg,#3b82f6,#2563eb);border-bottom-right-radius:4px;color:#fff}.chat-bubble.assistant{align-self:flex-start;background:#ffffff0d;border:1px solid #ffffff1a;border-bottom-left-radius:4px;color:#e2e8f0}.chat-role{font-size:.7rem;font-weight:700;letter-spacing:.05em;margin-bottom:.5rem;opacity:.6;text-transform:uppercase}.chat-bubble.user .chat-role{color:#fffc;text-align:right}.chat-text{margin:0;white-space:pre-wrap;word-break:break-all}.chat-input-form{align-items:center;background:#0f0f12e6;border-top:1px solid #ffffff0d;display:flex;gap:.75rem;padding:1.25rem}.chat-input-form input{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:14px;color:#fff;flex:1 1;font-size:.95rem;outline:none;padding:.875rem 1.25rem}.chat-input-form button{background:#3b82f6;border:none;border-radius:14px;color:#fff;cursor:pointer;flex-shrink:0;font-weight:600;min-width:80px;padding:.875rem 1.5rem}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.chat-container{border:none;border-radius:0;padding-bottom:calc(var(--mobile-nav-height) + env(safe-area-inset-bottom, 0px))}.chat-messages{gap:.75rem;padding:1rem}.chat-bubble{max-width:90%;padding:.625rem .875rem}.chat-input-form{bottom:0;gap:.5rem;padding:.625rem .75rem calc(.625rem + env(safe-area-inset-bottom, 0px));position:-webkit-sticky;position:sticky}.chat-input-form input{border-radius:10px;font-size:.9rem;padding:.625rem .875rem}.chat-input-form button{border-radius:10px;font-size:.875rem;min-width:64px;padding:.625rem 1rem}}.settings-container{background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000001a;color:#333;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0 auto;max-width:600px;padding:30px}.settings-title{border-bottom:2px solid #f0f0f0;color:#212529;font-size:1.5rem;margin-bottom:24px;margin-top:0;padding-bottom:12px}.settings-section{margin-bottom:32px}.settings-section h3{color:#495057;font-size:1.1rem;margin-bottom:16px}.settings-form{gap:16px}.form-group,.settings-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#6c757d;font-size:.9rem;font-weight:600}.form-group input,.form-group select{border:1px solid #ced4da;border-radius:8px;font-size:1rem;outline:none;padding:10px 14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#007bff}.save-button{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:8px;padding:12px;transition:background-color .2s}.save-button:hover{background:#0056b3}.model-select{background-color:#f8f9fa;width:100%}.helper-text{color:#6c757d;font-size:.8rem;margin-top:8px}.settings-status{animation:fadeIn .3s ease-out;background:#d4edda;border-radius:8px;color:#155724;font-size:.9rem;margin-bottom:20px;padding:12px;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.navigation-bar{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#0f172acc;border-bottom:1px solid #ffffff0d;display:flex;height:var(--nav-height);justify-content:space-between;padding:0 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.nav-brand{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#60a5fa,#a855f7);-webkit-background-clip:text;background-clip:text;cursor:default;font-size:1.5rem;font-weight:800}.nav-main-links{display:flex;gap:1.5rem;left:50%;position:absolute;transform:translateX(-50%)}.nav-link{align-items:center;border-radius:10px;color:#94a3b8;display:flex;font-weight:500;gap:8px;padding:8px 16px;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.nav-link:hover{background:#ffffff0d;color:#fff}.nav-link.active{background:#ffffff1a;color:#fff}.nav-link.active svg{color:#60a5fa}.nav-right-section{align-items:center;display:flex;gap:1rem}.desktop-settings{display:flex;gap:.5rem}.burger-toggle{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;color:#fff;cursor:pointer;display:none;padding:8px}.mobile-bottom-nav{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f172ae6;border-top:1px solid #ffffff1a;bottom:0;display:none;height:calc(var(--mobile-nav-height) + env(safe-area-inset-bottom, 0px));justify-content:space-around;left:0;padding-bottom:env(safe-area-inset-bottom);position:fixed;width:100%;z-index:1000}.mobile-nav-item{align-items:center;color:#94a3b8;display:flex;flex-direction:column;font-size:.75rem;font-weight:600;gap:4px;text-decoration:none}.mobile-nav-item.active{color:#60a5fa}.burger-menu{background:#1e293b;border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 10px 30px #00000080;opacity:0;overflow:hidden;pointer-events:none;position:fixed;right:1.5rem;top:calc(var(--nav-height) + 8px);transform:translateY(-10px) scale(.95);transition:all .2s cubic-bezier(.4,0,.2,1);width:240px;z-index:1001}.burger-menu.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}.burger-content{padding:1rem}.burger-content h4{color:#64748b;font-size:.7rem;letter-spacing:1px;margin-bottom:12px;padding:0 .5rem;text-transform:uppercase}.burger-item{align-items:center;border-radius:10px;color:#cbd5e1;display:flex;font-size:.9rem;gap:12px;padding:10px 12px;text-decoration:none;transition:background .2s}.burger-item:hover{background:#ffffff0d;color:#fff}.menu-backdrop{height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:999}@media (max-width:768px){.navigation-bar{height:60px;padding:0 1rem}.desktop-settings,.nav-main-links{display:none}.burger-toggle,.mobile-bottom-nav{display:flex}.burger-menu{right:1rem;top:70px;width:calc(100% - 2rem)}}.auth-container{align-items:center;display:flex;flex:1 1;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;justify-content:center;overflow-y:auto;padding:1rem}.auth-card,.auth-container{box-sizing:border-box;width:100%}.auth-card{border:1px solid #ffffff1a;border-radius:24px;box-shadow:0 20px 40px -15px #00000080;margin:auto;max-width:420px;padding:2.5rem;text-align:center}.auth-card.glass{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#1e293bb3}.auth-brand{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#60a5fa,#a855f7);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;letter-spacing:-.025em;margin-bottom:2rem}.auth-card h2{color:#fff;font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.5rem}.auth-card p{color:#94a3b8;font-size:.95rem;line-height:1.5;margin-bottom:2rem}.auth-form{text-align:left}.form-group{margin-bottom:1.25rem}.form-group label{color:#cbd5e1;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-group input{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;box-sizing:border-box;color:#fff;font-family:inherit;font-size:.95rem;outline:none;padding:.875rem 1rem;transition:all .2s ease;width:100%}.form-group input::placeholder{color:#475569}.form-group input:focus{background:#ffffff14;border-color:#60a5fa;box-shadow:0 0 0 4px #60a5fa26}.auth-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f640;box-sizing:border-box;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:.875rem;transition:all .2s ease;width:100%}.auth-button:hover:not(:disabled){box-shadow:0 6px 16px #3b82f659;transform:translateY(-2px)}.auth-button:disabled{background:#475569;box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.auth-error{align-items:center;background:#ef44441a;border:1px solid #ef444433;border-radius:12px;color:#f87171;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1.5rem;padding:.875rem}.auth-footer{color:#94a3b8;font-size:.95rem;margin-top:2rem}.auth-footer a{color:#60a5fa;font-weight:500;text-decoration:none;transition:color .2s ease}.auth-footer a:hover{color:#93c5fd;text-decoration:underline}@media (max-width:480px){.auth-card{border-radius:20px;padding:2rem 1.5rem}.auth-brand{font-size:2.25rem;margin-bottom:1.5rem}.auth-card h2{font-size:1.5rem}}.ship-builder{color:#e0e6f0;min-height:100vh;padding:24px 16px;position:relative}.builder-layout{align-items:flex-start;display:flex;gap:24px;margin:0 auto;max-width:900px}.inventory-panel,.schematic-panel{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;padding:20px;transition:box-shadow .3s ease,opacity .3s ease,filter .3s ease}.inventory-panel{flex:0 0 260px}.schematic-panel{flex:1 1}.panel-title{color:#7eb8d4;font-size:1rem;font-weight:600;letter-spacing:.06em;margin:0 0 4px;text-transform:uppercase}.panel-hint{color:#7a8899;font-size:.8rem;margin:0 0 16px}.ship-builder.tutorial-mode .inventory-panel:not(.tutorial-highlighted),.ship-builder.tutorial-mode .schematic-panel:not(.tutorial-highlighted){filter:blur(1.5px);opacity:.35;pointer-events:none}.tutorial-highlighted{border-color:#00d4ff!important;box-shadow:0 0 0 3px #00d4ff,0 0 24px #00d4ff73,0 0 60px #00d4ff26;position:relative;z-index:1010}.component-list{display:flex;flex-direction:column;gap:8px}.component-item{-webkit-user-drag:none;align-items:center;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;color:#d0dae8;cursor:pointer;display:flex;gap:12px;padding:10px 12px;text-align:left;transition:background .15s ease,border-color .15s ease,transform .1s ease;-webkit-user-select:none;user-select:none;width:100%}.component-item:hover{background:#00d4ff14;border-color:#00d4ff4d}.component-item:active{transform:scale(.97)}.component-item.selected{background:#00d4ff26;border-color:#00d4ff}.component-icon{flex-shrink:0;font-size:1.5rem}.component-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.component-name{color:#e0e6f0;font-size:.9rem;font-weight:600}.component-desc{color:#7a8899;font-size:.72rem}.selected-badge{background:#00d4ff26;border:1px solid #00d4ff66;border-radius:4px;color:#00d4ff;flex-shrink:0;font-size:.65rem;font-weight:700;letter-spacing:.07em;padding:2px 6px;text-transform:uppercase}.schematic-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);margin:0 auto;max-width:360px}.schematic-slot{-webkit-user-drag:none;align-items:center;aspect-ratio:1;background:#ffffff08;border:2px dashed #ffffff26;border-radius:10px;color:#5a6a7a;cursor:default;display:flex;flex-direction:column;font-size:.72rem;gap:4px;justify-content:center;transition:background .15s ease,border-color .15s ease,transform .1s ease,box-shadow .15s ease;-webkit-user-select:none;user-select:none}.schematic-slot.available{animation:pulse-slot 1.6s ease-in-out infinite;background:#00d4ff0f;border-color:#00d4ff80;color:#00d4ff;cursor:pointer}.schematic-slot.available:hover{background:#00d4ff24;border-color:#00d4ff;box-shadow:0 0 12px #00d4ff4d}.schematic-slot.available:active{transform:scale(.94)}.schematic-slot.occupied{background:#00d4ff12;border:2px solid #00d4ff40;color:#d0dae8;cursor:default}.slot-label{font-size:.7rem;text-align:center}.slot-icon{font-size:1.4rem}.slot-name{color:#7eb8d4;font-size:.65rem;text-align:center}@keyframes pulse-slot{0%,to{box-shadow:0 0 0 0 #00d4ff4d}50%{box-shadow:0 0 0 5px #00d4ff00}}@media (max-width:640px){.builder-layout{flex-direction:column}.inventory-panel{flex:none;width:100%}}.tutorial-overlay-dim{animation:fade-in .25s ease;background:#0000008c;inset:0;pointer-events:none;position:fixed;z-index:1005}.tutorial-banner{align-items:center;animation:slide-down .3s ease;background:linear-gradient(135deg,#0d2340,#0a1a30);border-bottom:2px solid #00d4ff;box-shadow:0 4px 20px #00d4ff33;display:flex;gap:16px;left:0;padding:12px 20px;position:fixed;right:0;top:0;z-index:1020}.tutorial-progress{display:flex;flex-shrink:0;gap:6px}.progress-dot{background:#fff3;border:1.5px solid #ffffff4d;border-radius:50%;height:10px;transition:background .3s ease,border-color .3s ease;width:10px}.progress-dot.active{background:#00d4ff;border-color:#00d4ff;box-shadow:0 0 8px #00d4ffb3}.tutorial-instruction{align-items:center;display:flex;flex:1 1;gap:10px}.tutorial-step-badge{background:#00d4ff1f;border:1px solid #00d4ff59;border-radius:4px;color:#00d4ff;flex-shrink:0;font-size:.7rem;font-weight:700;letter-spacing:.08em;padding:3px 8px;text-transform:uppercase}.instruction-text{color:#cdd8e8;font-size:.9rem;line-height:1.4;margin:0}.instruction-text strong{color:#fff}.instruction-text em{color:#00d4ff;font-style:normal;font-weight:600}.instruction-arrow{flex-shrink:0;font-size:1.1rem}.left-arrow,.right-arrow{color:#00d4ff}.tutorial-modal-overlay{align-items:center;animation:fade-in .2s ease;background:#000000bf;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:2000}.tutorial-modal{animation:scale-in .25s ease;background:linear-gradient(160deg,#0d1f35,#0a1525);border:1px solid #00d4ff40;border-radius:16px;box-shadow:0 0 0 1px #00d4ff1a,0 20px 60px #00000080,0 0 40px #00d4ff14;max-width:420px;padding:36px 32px;text-align:center;width:100%}.tutorial-modal h2{color:#e8f0fa;font-size:1.4rem;font-weight:700;margin:0 0 12px}.tutorial-modal p{color:#8a9eb8;font-size:.9rem;line-height:1.6;margin:0 0 24px}.tutorial-modal-icon{display:block;font-size:2.8rem;margin-bottom:16px}.tutorial-steps-preview{display:flex;flex-direction:column;gap:12px;margin:0 0 28px;text-align:left}.preview-step{align-items:flex-start;background:#ffffff0a;border:1px solid #ffffff12;border-radius:8px;color:#b0bfd4;display:flex;font-size:.85rem;gap:12px;line-height:1.4;padding:12px 14px}.preview-step strong{color:#e0e8f8}.step-num{align-items:center;background:#00d4ff;border-radius:50%;color:#001a2e;display:flex;flex-shrink:0;font-size:.8rem;font-weight:800;height:24px;justify-content:center;width:24px}.tutorial-modal.success{border-color:#00ffa04d;box-shadow:0 0 0 1px #00ffa01a,0 20px 60px #00000080,0 0 40px #00ffa014}.success-icon{align-items:center;background:linear-gradient(135deg,#00c896,#00ff9f);border-radius:50%;color:#001a14;display:flex;font-size:1.8rem;font-weight:800;height:64px;justify-content:center;margin:0 auto 16px;width:64px}.tutorial-btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px 28px;transition:opacity .15s ease,transform .1s ease}.tutorial-btn:active{transform:scale(.97)}.tutorial-btn.primary{background:linear-gradient(135deg,#0084b5,#00b4e0);color:#fff}.tutorial-btn.primary:hover{opacity:.9}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-down{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
/*# sourceMappingURL=main.f4481637.css.map*/