@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--primary-bg:#0a0a0a;--secondary-bg:#1a1a1a;--tertiary-bg:#2a2a2a;--accent-purple:#8b5cf6;--accent-green:#10b981;--accent-blue:#3b82f6;--text-primary:#fff;--text-secondary:#a1a1aa;--text-muted:#71717a;--border-color:#3f3f46;--border-hover:#52525b;--success:#22c55e;--warning:#f59e0b;--error:#ef4444;--gradient-purple:linear-gradient(135deg,#8b5cf6,#a855f7);--gradient-green:linear-gradient(135deg,#10b981,#059669);--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0a0a0a;background-color:var(--primary-bg);color:#fff;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1a1a1a;background:var(--secondary-bg)}::-webkit-scrollbar-thumb{background:#3f3f46;background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#52525b;background:var(--border-hover)}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.btn{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease-in-out}.btn-primary{background:linear-gradient(135deg,#8b5cf6,#a855f7);background:var(--gradient-purple);color:#fff}.btn-primary:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-secondary{background:#2a2a2a;background:var(--tertiary-bg);border:1px solid #3f3f46;border:1px solid var(--border-color);color:#fff;color:var(--text-primary)}.btn-secondary:hover{border-color:#52525b;border-color:var(--border-hover)}.btn-secondary:hover,.card{background:#1a1a1a;background:var(--secondary-bg)}.card{border:1px solid #3f3f46;border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;transition:all .2s ease-in-out}.card:hover{border-color:#52525b;border-color:var(--border-hover);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.text-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#8b5cf6,#a855f7);background:var(--gradient-purple);-webkit-background-clip:text;background-clip:text}.glass-effect{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1a1acc;border:1px solid #ffffff1a}.navbar{border-bottom:1px solid #ffffff1a;left:0;padding:1rem 0;position:fixed;right:0;top:0;z-index:1000}.navbar-container{align-items:center;display:flex;justify-content:space-between}.navbar-brand{align-items:center;color:var(--text-primary);display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;text-decoration:none}.brand-icon{color:var(--accent-purple)}.brand-text{font-size:1.25rem}.desktop-nav{gap:2rem}.desktop-nav,.nav-link{align-items:center;display:flex}.nav-link{border-radius:.5rem;color:var(--text-secondary);font-weight:500;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease-in-out}.nav-link:hover{background:#8b5cf61a;color:var(--text-primary)}.no-hover.nav-link:hover{background:none;color:var(--text-secondary);cursor:default}.nav-link.active{background:#8b5cf61a;color:var(--accent-purple)}.mobile-menu-btn{background:none;border:none;border-radius:.5rem;color:var(--text-primary);cursor:pointer;display:none;padding:.5rem;transition:all .2s ease-in-out}.mobile-menu-btn:hover{background:#ffffff1a}.mobile-nav{background:var(--secondary-bg);border-top:1px solid var(--border-color);display:none;flex-direction:column;gap:.5rem;left:0;opacity:0;padding:1rem;position:absolute;right:0;top:100%;transform:translateY(-100%);transition:all .3s ease-in-out}.mobile-nav.open{opacity:1;transform:translateY(0)}.mobile-nav-link{align-items:center;border-radius:.5rem;color:var(--text-secondary);display:flex;font-weight:500;gap:.75rem;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease-in-out}.mobile-nav-link:hover{background:#8b5cf61a;color:var(--text-primary)}.mobile-nav-link.active{background:#8b5cf61a;color:var(--accent-purple)}@media (max-width:768px){.desktop-nav{display:none}.mobile-menu-btn{display:block}.mobile-nav{display:flex}.navbar-brand{font-size:1.25rem}.brand-text{font-size:1rem}}.user-dropdown-container{position:relative}.user-button{background:none!important;border:none!important;cursor:pointer}.user-dropdown{animation:fadeInDropdown .15s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:var(--shadow-xl);min-width:140px;overflow:hidden;position:absolute;right:0;top:calc(100% + .5rem);z-index:1001}@keyframes fadeInDropdown{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;text-align:left;transition:background .15s,color .15s;width:100%}.dropdown-item:hover{background:var(--tertiary-bg);color:var(--accent-purple)}.logout-item{color:var(--error)}.logout-item:hover{background:#ef444414;color:var(--error)}.home{min-height:100vh}.hero{background:linear-gradient(135deg,var(--primary-bg) 0,var(--secondary-bg) 100%);overflow:hidden;padding:6rem 0 4rem;position:relative}.hero:before{background:radial-gradient(circle at 20% 80%,#8b5cf61a 0,#0000 50%),radial-gradient(circle at 80% 20%,#10b9811a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.hero .container{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;position:relative;z-index:1}.hero-title{color:var(--text-primary);font-size:3.5rem;font-weight:700;line-height:1.1;margin-bottom:1.5rem}.hero-subtitle{color:var(--text-secondary);font-size:1.25rem;line-height:1.6;margin-bottom:2rem}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}.hero-visual{align-items:center;display:flex;justify-content:center}.code-window{background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:.75rem;box-shadow:var(--shadow-xl);max-width:500px;overflow:hidden;width:100%}.window-header{align-items:center;background:var(--secondary-bg);border-bottom:1px solid var(--border-color);display:flex;gap:1rem;padding:.75rem 1rem}.window-controls{display:flex;gap:.5rem}.control{border-radius:50%;height:12px;width:12px}.control.red{background:#ef4444}.control.yellow{background:#f59e0b}.control.green{background:#22c55e}.window-title{color:var(--text-secondary);font-size:.875rem;font-weight:500}.window-content{font-family:Fira Code,Monaco,Consolas,monospace;font-size:.875rem;line-height:1.5;padding:1rem}.code-line{display:flex;gap:1rem;margin-bottom:.25rem}.line-number{color:var(--text-muted);min-width:2rem;text-align:right}.code-keyword{color:#c084fc;font-weight:600}.code-function{color:#60a5fa;font-weight:600}.code-string{color:#34d399}.code-variable{color:#fbbf24}.code-comment{color:var(--text-muted);font-style:italic}.features{background:var(--primary-bg);padding:6rem 0}.section-header{margin-bottom:4rem;text-align:center}.section-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.section-subtitle{color:var(--text-secondary);font-size:1.125rem;line-height:1.6;margin:0 auto;max-width:600px}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.feature-card{padding:2rem;text-align:center}.feature-icon{margin-bottom:1.5rem}.feature-title{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.feature-description{color:var(--text-secondary);line-height:1.6}.cta{background:linear-gradient(135deg,var(--secondary-bg) 0,var(--tertiary-bg) 100%);padding:6rem 0;text-align:center}.cta-content{margin:0 auto;max-width:600px}.cta-title{color:var(--text-primary);font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta-subtitle{color:var(--text-secondary);font-size:1.125rem;line-height:1.6;margin-bottom:2rem}@media (max-width:1024px){.hero .container{gap:3rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:3rem}.features-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (max-width:768px){.hero{padding:4rem 0 2rem}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.125rem}.hero-actions{justify-content:center}.cta-title,.section-title{font-size:2rem}.features-grid{grid-template-columns:1fr}.cta,.features{padding:4rem 0}}@media (max-width:480px){.hero-title{font-size:2rem}.hero-actions{align-items:center;flex-direction:column}.code-window{max-width:100%}.window-content{font-size:.75rem}}.projects{min-height:calc(100vh - 80px);padding:2rem 0}.projects-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;min-height:400px}.projects-header,.projects-loading{align-items:center;display:flex;gap:1rem}.projects-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:2rem}.header-content{flex:1 1}.page-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--text-primary) 0,var(--accent-purple) 100%);-webkit-background-clip:text;background-clip:text}.page-subtitle{font-size:1.1rem;max-width:600px}.projects-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem}.search-container{flex:1 1;max-width:400px;position:relative}.search-icon{color:var(--text-muted);left:1rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:color .2s ease}.search-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:.75rem;color:var(--text-primary);font-size:.95rem;font-weight:500;padding:.875rem 1rem .875rem 2.75rem;transition:all .2s ease;width:100%}.search-input:focus{background:var(--secondary-bg);border-color:var(--accent-purple);box-shadow:0 0 0 3px #8b5cf626;outline:none}.search-input:focus+.search-icon{color:var(--accent-purple)}.search-input::placeholder{color:var(--text-muted);font-weight:400}.filter-container{align-items:center;color:var(--text-secondary);display:flex;font-weight:500;gap:.75rem}.filter-select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:.75rem;color:var(--text-primary);cursor:pointer;font-size:.95rem;font-weight:500;min-width:140px;padding:.75rem 1rem;transition:all .2s ease}.filter-select:focus{background:var(--secondary-bg);border-color:var(--accent-purple);box-shadow:0 0 0 3px #8b5cf626;outline:none}.filter-select option{background:var(--secondary-bg);color:var(--text-primary);padding:.5rem}.projects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:2rem}.project-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:1rem;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.project-card:before{background:linear-gradient(90deg,var(--accent-purple),var(--accent-blue));content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.project-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-xl);transform:translateY(-4px)}.project-card:hover:before{opacity:1}.project-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.25rem;overflow:visible;position:relative;z-index:10}.project-info{flex:1 1;min-width:0}.project-name{word-wrap:break-word;color:var(--text-primary);font-size:1.25rem;font-weight:600;line-height:1.3;margin-bottom:.5rem}.visibility-badge{align-items:center;border-radius:1rem;display:inline-flex;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.visibility-badge.hidden{background:#ef444426;border:1px solid #ef44444d;color:var(--error)}.project-menu-btn{align-items:center;background:none;border:none;border-radius:.5rem;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;margin-left:.5rem;padding:.5rem;transition:all .2s ease}.project-menu-btn:hover{background:var(--tertiary-bg);color:var(--accent-purple);transform:scale(1.05)}.project-stats{flex:1 1;flex-direction:column;margin-bottom:1.5rem}.project-stats,.stat{display:flex;gap:.75rem}.stat{align-items:center;color:var(--text-secondary);font-size:.9rem;font-weight:500}.stat svg{color:var(--text-muted);flex-shrink:0}.project-actions{margin-top:auto}.project-btn{border-radius:.75rem;font-weight:600;justify-content:center;padding:.875rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.project-btn:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.empty-state{color:var(--text-secondary);grid-column:1/-1}.empty-icon{margin-bottom:1.5rem;opacity:.6}.empty-state h3{font-size:1.5rem;margin-bottom:.75rem}.empty-state p{font-size:1rem;line-height:1.6;margin-bottom:2rem;max-width:400px}.project-menu-container{position:relative}.project-menu-dropdown{animation:fadeInMenu .18s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:.75rem;box-shadow:var(--shadow-xl);min-width:180px;overflow:visible;position:absolute;right:0;top:2.2rem;z-index:1000}@keyframes fadeInMenu{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.menu-item{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.75rem;padding:.65rem 1.25rem;text-align:left;transition:background .15s,color .15s;width:100%}.menu-item:hover{background:var(--tertiary-bg);color:var(--accent-purple)}.menu-item.delete{color:var(--error)}.menu-item.delete:hover{background:#ef444414;color:var(--error)}.menu-item.export{position:relative}.export-submenu{animation:slideInSubmenu .15s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:var(--shadow-xl);left:100%;min-width:140px;overflow:visible;position:absolute;top:0;z-index:2100}@keyframes slideInSubmenu{0%{opacity:0;transform:translateX(-10px) scale(.98)}to{opacity:1;transform:translateX(0) scale(1)}}.submenu-item{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.6rem 1rem;text-align:left;transition:background .15s,color .15s;width:100%}.submenu-item:hover{background:var(--tertiary-bg);color:var(--accent-purple)}.error-message,.success-message{align-items:center;animation:slideInDown .3s cubic-bezier(.4,0,.2,1);border-radius:.75rem;box-shadow:var(--shadow-md);display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem}.success-message{background:#22c55e14;border:1px solid #22c55e2e;color:var(--success)}.error-message{background:#ef444414;border:1px solid #ef44442e}.message-close{background:none;border:none;border-radius:.25rem;color:inherit;cursor:pointer;margin-left:auto;padding:.25rem;transition:background .15s}.message-close:hover{background:#ffffff14}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:2000}.modal-content{animation:fadeInModal .22s cubic-bezier(.4,0,.2,1);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:1rem;box-shadow:var(--shadow-xl);max-height:90vh;max-width:420px;overflow-y:auto;width:100%}@keyframes fadeInModal{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1.25rem 1.5rem 1rem}.modal-header h3{color:var(--text-primary);font-size:1.18rem;font-weight:600;margin:0}.modal-close{background:none;border:none;border-radius:.5rem;color:var(--text-muted);cursor:pointer;padding:.5rem;transition:background .15s,color .15s}.modal-close:hover{background:var(--tertiary-bg);color:var(--accent-purple)}.modal-body{padding:1.5rem}.modal-body label{display:block;font-weight:500;margin-bottom:.5rem}.modal-body label,.modal-input{color:var(--text-primary);font-size:.95rem}.modal-input{background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:.5rem;padding:.75rem 1rem;transition:border .18s,box-shadow .18s;width:100%}.modal-input:focus{border-color:var(--accent-purple);box-shadow:0 0 0 2px #8b5cf61f;outline:none}.modal-input::placeholder{color:var(--text-muted)}.delete-warning{color:var(--text-secondary);text-align:center}.delete-warning p{line-height:1.6;margin-bottom:1rem}.delete-warning p:first-of-type{color:var(--text-primary);font-weight:500}.warning-text{background:#ef444414;border:1px solid #ef44442e;border-radius:.5rem;color:var(--text-muted);font-size:.95rem;margin-top:1rem;padding:1rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding:1rem 1.5rem 1.5rem}.btn-danger{background:linear-gradient(135deg,var(--error) 0,#dc2626 100%);color:#fff}.btn-danger:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-danger:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width:768px){.projects{padding:1rem 0}.projects-header{align-items:stretch;flex-direction:column;gap:1rem}.page-title{font-size:2rem}.projects-controls{align-items:stretch;flex-direction:column}.search-container{max-width:none}.filter-container{justify-content:center}.projects-grid{grid-template-columns:1fr}}@media (max-width:480px){.page-title{font-size:1.75rem}.project-card{padding:1rem}.project-name{font-size:1.125rem}.modal-content{max-width:98vw;padding:0}.modal-body,.modal-footer,.modal-header{padding-left:1rem;padding-right:1rem}.modal-footer{flex-direction:column;gap:.5rem}.modal-footer .btn{width:100%}}.analysis-status{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:.75rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:.5rem 0;padding:.75rem;transition:all .2s ease-in-out}.analysis-status:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.analysis-status.loading{align-items:center;background:var(--secondary-bg);border-color:var(--accent-blue);color:var(--text-primary);display:flex;gap:.75rem;padding:1rem 1.5rem}.analysis-status.error{background:#ef44441a;border-color:var(--error);color:var(--error);padding:1rem 1.5rem}.status-spinner{animation:spin 1s linear infinite;border-top:2px solid var(--border-color);border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-blue);height:16px;width:16px}.status-header{margin-bottom:.75rem}.status-header.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.status-header.clickable:hover{background:var(--tertiary-bg);border-radius:.5rem;margin:-.5rem;padding:.5rem}.header-left{gap:.5rem;margin-bottom:1rem}.header-left,.toggle-icon{align-items:center;display:flex}.toggle-icon{color:var(--text-secondary);transition:transform .2s ease-in-out}.status-header h4{-webkit-text-fill-color:#0000;background:var(--gradient-purple);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0}.progress-container{align-items:center;display:flex;gap:1rem}.progress-bar{border-radius:.5rem;flex:1 1}.progress-fill{background:var(--gradient-purple);border-radius:.5rem;transition:width .3s ease-in-out}.progress-text{color:var(--text-secondary);font-size:.75rem;font-weight:500;min-width:-webkit-fit-content;min-width:fit-content;white-space:nowrap}.executable-info{background:var(--primary-bg);border:1px solid var(--border-color);border-radius:.5rem;margin-bottom:.75rem;padding:.5rem}.executable-info h5{-webkit-text-fill-color:#0000;background:var(--gradient-purple);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 .5rem}.info-grid{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.info-item strong{color:var(--text-secondary);flex-shrink:0;min-width:100px}.status-badge{border-radius:.125rem;font-size:.5625rem;font-weight:400;gap:.125rem;padding:.0625rem .1875rem}.status-badge.success{background:#22c55e1a;border:1px solid #22c55e4d;color:var(--success)}.status-badge.pending{background:#f59e0b1a;border:1px solid #f59e0b4d;color:var(--warning)}.status-badge.processing{background:#3b82f61a;border:1px solid #3b82f64d;color:var(--accent-blue)}.status-steps{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.step{background:var(--tertiary-bg);border:1px solid var(--border-color);border-left:3px solid var(--text-muted);border-radius:.5rem;padding:.5rem;transition:all .2s ease-in-out}.step:hover{background:var(--secondary-bg);border-color:var(--border-hover)}.step-header{gap:.5rem;margin-bottom:.1rem}.step-header,.step-icon{align-items:center;display:flex}.step-icon{font-size:.875rem;font-weight:600;justify-content:center;min-width:18px;text-align:center}.step-name{color:var(--text-primary);flex:1 1;font-size:.875rem;font-weight:500}.step-status{background:var(--primary-bg);border-radius:.375rem;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase}.step-timing{color:var(--text-muted);font-size:.6875rem;font-weight:400;margin-left:1.5rem;margin-top:.1rem}.step-error{background:#ef44441a;border:1px solid var(--error);border-radius:.5rem;color:var(--error);font-size:.75rem;font-weight:400;margin-left:2.5rem;margin-top:.5rem;padding:.75rem}.step.step-completed{background:#22c55e0d;border-left-color:var(--success)}.step.step-completed .step-status{background:#22c55e1a;color:var(--success)}.step.step-completed .step-icon{color:var(--success)}.step.step-processing{background:#3b82f60d;border-left-color:var(--accent-blue)}.step.step-processing .step-status{background:#3b82f61a;color:var(--accent-blue)}.step.step-processing .step-icon{animation:spin 2s linear infinite;color:var(--accent-blue)}.step.step-failed{background:#ef44440d;border-left-color:var(--error)}.step.step-failed .step-status{background:#ef44441a;color:var(--error)}.step.step-failed .step-icon{color:var(--error)}.step.step-queued{background:#f59e0b0d;border-left-color:var(--warning)}.step.step-queued .step-status{background:#f59e0b1a;color:var(--warning)}.step.step-queued .step-icon{color:var(--warning)}.step.step-pending{background:var(--tertiary-bg);border-left-color:var(--text-muted)}.step.step-pending .step-status{background:var(--primary-bg);color:var(--text-muted)}.step.step-pending .step-icon{color:var(--text-muted)}.job-error{align-items:flex-start;background:#ef44441a;border:1px solid var(--error);border-radius:.5rem;color:var(--error);display:flex;font-size:.875rem;font-weight:400;gap:.5rem;margin-bottom:1rem;padding:1rem}.job-metadata{border-top:1px solid var(--border-color);color:var(--text-muted);font-size:.75rem;font-weight:400;line-height:1.5;padding-top:1rem}@media (max-width:768px){.analysis-status{margin:.75rem 0;padding:1rem}.progress-container{align-items:stretch;flex-direction:column;gap:.75rem}.progress-text{align-self:flex-end;font-size:.6875rem}.step-header{flex-wrap:wrap;gap:.5rem}.step-error,.step-timing{margin-left:1.5rem}.status-header h4{font-size:1rem}.step{padding:.75rem}.step-name{font-size:.8125rem}.info-grid{gap:.5rem;grid-template-columns:1fr}.info-item{align-items:flex-start;flex-direction:column;gap:.25rem}.info-item strong{min-width:0;min-width:auto}}.project-detail{min-height:calc(100vh - 80px);padding:2rem 0}.loading-spinner{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:400px}.spinner{border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-top-color:var(--primary-color)}.spinner.small{height:20px;width:20px}.spinner.tiny{border-width:1.5px;height:16px;width:16px}.error-message{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;display:flex;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.error-close{background:none;border:none;border-radius:4px;color:#dc2626;cursor:pointer;margin-left:auto;padding:.25rem;transition:background-color .2s}.error-close:hover{background:#fecaca}.success-message{align-items:center;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#166534;display:flex;font-size:.875rem;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.success-close{background:none;border:none;border-radius:4px;color:#166534;cursor:pointer;margin-left:auto;padding:.25rem;transition:background-color .2s}.success-close:hover{background:#bbf7d0}.upload-section{margin-bottom:3rem}.upload-area{background:var(--secondary-bg);border:2px dashed var(--border-color);border-radius:12px;overflow:hidden;padding:1.5rem 1rem;position:relative;text-align:center;transition:all .3s ease}.upload-area.drag-active{background:rgba(var(--primary-color-rgb),.05);border-color:var(--primary-color);transform:scale(1.02)}.upload-area.uploading{opacity:.7;pointer-events:none}.upload-label{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:1rem;transition:all .2s ease}.upload-label:hover{transform:translateY(-2px)}.upload-icon{color:var(--text-muted);transition:color .2s ease}.upload-area:hover .upload-icon{color:var(--primary-color)}.upload-label h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0}.upload-label p{color:var(--text-secondary);font-size:1rem;margin:0}.upload-hint{background:var(--primary-bg);border:1px solid var(--border-color);border-radius:20px;color:var(--text-muted);font-size:.875rem;padding:.5rem 1rem}.upload-progress{align-items:center;background:var(--primary-bg);border-radius:8px;box-shadow:0 4px 12px #0000001a;color:var(--text-primary);display:flex;font-weight:500;gap:.75rem;left:50%;padding:1rem 1.5rem;position:absolute;top:50%;transform:translate(-50%,-50%)}.multi-upload-progress{display:flex;flex-direction:column;gap:.75rem;min-width:300px;width:100%}.progress-header{align-items:center;color:var(--text-primary);display:flex;font-size:.9rem;font-weight:600;justify-content:space-between}.progress-percentage{color:var(--accent-purple);flex-shrink:0;font-weight:700;margin-left:.75rem}.progress-bar{background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,var(--accent-purple),#60a5fa);border-radius:4px;height:100%;transition:width .3s ease}.current-file{align-items:center;background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);display:flex;font-size:.85rem;gap:.5rem;padding:.5rem}.executables-section{margin-bottom:2rem}.executables-table-container{background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px;max-height:720px;overflow-y:auto;position:relative;z-index:1}.section-title{color:var(--text-primary);font-size:1.75rem;font-weight:600;margin-bottom:1.5rem}.empty-state{align-items:center;background:var(--secondary-bg);border:2px dashed var(--border-color);border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{color:var(--text-muted);margin-bottom:1rem}.empty-state h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.empty-state p{color:var(--text-secondary);margin:0}.table-container{background:var(--primary-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:visible;position:relative}.table-wrapper{overflow-x:auto;overflow-y:hidden;position:relative;width:100%}.table-container table{border:none;margin:0}.executables-table{background:var(--primary-bg);border-collapse:collapse;font-size:.875rem;margin:0;table-layout:fixed;width:100%}.executables-table th,.executables-table thead{background:var(--secondary-bg);border-bottom:2px solid var(--border-color)}.executables-table th{color:var(--text-primary);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:1rem;position:-webkit-sticky;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:10}.executables-table th:first-child{width:6%}.executables-table th:nth-child(2){width:38%}.executables-table th:nth-child(3){width:14%}.executables-table th:nth-child(4){width:42%}.executables-table td{word-wrap:break-word;background:var(--primary-bg);border-bottom:1px solid var(--border-color);color:var(--text-primary);overflow:visible;padding:1rem;vertical-align:middle}.executables-table tbody tr:last-child td{border-bottom:none}.executables-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.executables-table tbody tr:last-child{border-bottom:none}.executables-table tbody tr:hover,.executables-table tbody tr:hover td{background:var(--secondary-bg)}.filename-cell{align-items:center;display:flex;font-weight:500;gap:.5rem}.filename-cell svg{color:var(--text-muted)}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.75rem;font-weight:500;gap:.375rem;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.status-badge.success{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}.status-badge.pending{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.actions-cell{white-space:nowrap;width:1%}.action-buttons{gap:.75rem;justify-content:space-evenly;padding:0 .5rem;width:100%}.action-btn,.action-buttons{align-items:center;display:flex}.action-btn{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.action-btn:hover:not(:disabled){box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.action-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.action-btn.decompile{background:#3b82f6}.action-btn.decompile:hover:not(:disabled){background:#2563eb}.action-btn.analyze{background:#10b981}.action-btn.analyze:hover:not(:disabled){background:#059669}.action-btn.analyze:disabled{background:#6b7280;cursor:not-allowed;opacity:.5}.action-btn.analyze:disabled:hover{background:#6b7280;box-shadow:none;transform:none}.action-btn.delete{background:#ef4444}.action-btn.delete:hover:not(:disabled){background:#dc2626}.action-btn.delete-bndb{background:#f59e0b}.action-btn.delete-bndb:hover:not(:disabled){background:#d97706}.action-btn.view-functions{background:#8b5cf6}.action-btn.view-functions:hover:not(:disabled){background:#7c3aed}.action-btn.export-btn{background:#06b6d4}.action-btn.export-btn:hover:not(:disabled){background:#0891b2}.status-content{align-items:center;display:flex;gap:.5rem}.status-text{border:1px solid;border-radius:3px;font-size:.6rem;font-weight:600;letter-spacing:.3px;min-width:60px;padding:.2rem .4rem;text-align:center;text-transform:uppercase;white-space:nowrap}.status-text.complete{background-color:#ecfdf5;border-color:#a7f3d0;color:#059669}.status-text.decompiled{background-color:#f5f3ff;border-color:#c4b5fd;color:#7c3aed}.status-text.analyzing{background-color:#eff6ff;border-color:#93c5fd;color:#0284c7}.status-text.decompiling{background-color:#ecfeff;border-color:#67e8f9;color:#0891b2}.status-text.extracting{background-color:#f0fdf4;border-color:#86efac;color:#059669}.status-text.cpg-gen{background-color:#fef7ed;border-color:#fed7aa;color:#7c2d12}.status-text.queued{background-color:#fffbeb;border-color:#fcd34d;color:#d97706}.status-text.failed{background-color:#fef2f2;border-color:#fca5a5;color:#dc2626}.status-text.pending,.status-text.stale{background-color:#f9fafb;border-color:#d1d5db;color:#6b7280}.status-toggle-btn{align-items:center;background:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:.875rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.status-toggle-btn:hover{background:#5048e5;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.status-expanded-row{background:var(--secondary-bg)}.status-expanded-cell{border-top:1px solid var(--border-color);padding:1rem}.export-menu-container{display:inline-block;overflow:visible;position:relative}.export-menu{animation:slideDown .2s ease-out;background:var(--primary-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:160px;overflow:hidden;pointer-events:auto;position:fixed;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.export-menu-item{background:none;border:none;color:var(--text-primary);cursor:pointer;display:block;font-size:.875rem;padding:.75rem 1rem;text-align:left;transition:all .2s ease;width:100%}.export-menu-item:hover:not(:disabled){background:var(--secondary-bg);color:var(--accent-purple)}.export-menu-item:disabled{cursor:not-allowed;opacity:.6}.export-menu-item:first-child{border-radius:8px 8px 0 0}.export-menu-item:last-child{border-radius:0 0 8px 8px}.export-menu-item:only-child{border-radius:8px}.functions-section{background:var(--primary-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-top:2rem;overflow:visible}.functions-header{align-items:center;background:var(--secondary-bg);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1.5rem}.functions-header .section-title{color:var(--text-primary);font-size:1.25rem;margin:0}.close-functions-btn{align-items:center;background:var(--primary-bg);border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.close-functions-btn:hover{background:var(--secondary-bg);color:var(--text-primary)}.functions-table{background:var(--primary-bg);border-collapse:collapse;font-size:.875rem;max-width:100%;min-width:700px;position:relative;table-layout:fixed;width:100%}.functions-table *{box-sizing:border-box}.functions-table thead{background:var(--secondary-bg);position:relative}.functions-table th,.functions-table thead{border-bottom:2px solid var(--border-color)}.functions-table th{box-sizing:border-box;color:var(--text-primary);font-size:.75rem;font-weight:600;letter-spacing:.05em;overflow:hidden;padding:1rem;position:-webkit-sticky;position:sticky;text-align:left;text-overflow:ellipsis;text-transform:uppercase;top:0;vertical-align:top;white-space:nowrap;z-index:10}.functions-table th:first-child{min-width:200px;width:35%}.functions-table th:nth-child(2){min-width:120px;width:25%}.functions-table th:nth-child(3){min-width:100px;width:20%}.functions-table th:nth-child(4){min-width:150px;text-align:center;width:20%}.functions-table tbody{position:relative}.functions-table td{word-wrap:break-word;background:var(--primary-bg);border-bottom:1px solid var(--border-color);box-sizing:border-box;color:var(--text-primary);height:60px;overflow:hidden;padding:1rem;position:relative;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.functions-table tbody tr:last-child td{border-bottom:none}.functions-table tbody tr{border-bottom:1px solid var(--border-color);height:60px;position:relative;transition:background-color .2s ease}.functions-table tbody tr:last-child{border-bottom:none}.functions-table tbody tr:hover,.functions-table tbody tr:hover td{background:var(--secondary-bg)}.function-name-cell{align-items:center;display:flex;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-weight:500;gap:.5rem}.function-name-cell svg{color:var(--text-muted);flex-shrink:0}.address-cell{color:var(--text-primary)}.address-cell,.bytes-cell{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-weight:500}.bytes-cell{color:var(--text-muted)}.vulnerability-cell{max-width:150px;min-width:150px;overflow:hidden;padding:.5rem 1rem;text-align:center;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap;width:150px}.vulnerability-info{display:flex;flex-direction:column;gap:.25rem;min-height:40px;width:100%}.risk-badge,.vulnerability-info{align-items:center;justify-content:center}.risk-badge{border-radius:12px;display:inline-flex;font-size:.625rem;font-weight:600;height:20px;letter-spacing:.05em;max-width:80px;min-width:60px;padding:.25rem .5rem;text-transform:uppercase;white-space:nowrap}.risk-badge.high-risk{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.risk-badge.medium-risk{background:#fffbeb;border:1px solid #fed7aa;color:#d97706}.risk-badge.low-risk{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.probability{color:var(--text-primary);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-weight:500}.no-analysis,.probability{font-size:.75rem;height:16px;line-height:16px;white-space:nowrap}.no-analysis{color:var(--text-muted);font-style:italic}.loading-state{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;justify-content:center;padding:3rem 1rem}.loading-state .spinner{margin-bottom:1rem}.loading-state p{font-size:.875rem;margin:0}@media (max-width:1024px){.executables-table{font-size:.75rem;table-layout:auto}.executables-table td,.executables-table th{padding:.75rem .5rem}.functions-table{font-size:.75rem;table-layout:auto}.functions-table td,.functions-table th{padding:.75rem .5rem}.action-buttons{flex-direction:column;gap:.25rem}.action-btn{height:32px;width:32px}}@media (max-width:768px){.project-detail{padding:1rem 0}.page-title{font-size:2rem}.upload-area{padding:2rem 1rem}.upload-label h3{font-size:1.25rem}.table-container{overflow-x:auto;overflow-y:visible}.executables-table{min-width:800px}.functions-table{min-width:700px}.section-title{font-size:1.5rem}.functions-header .section-title{font-size:1.125rem}.empty-state{padding:3rem 1rem}.functions-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1rem}.close-functions-btn{align-self:flex-end}}.table-row{transition:background-color .2s ease}.analysis-status-section{margin-top:2rem}.analysis-status-section .section-title{-webkit-text-fill-color:#0000;background:var(--gradient-purple);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:1.875rem;font-weight:600;margin-bottom:1.5rem}.analysis-status-container{display:flex;flex-direction:column;gap:1.5rem}.executable-status-item{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;transition:all .2s ease-in-out}.executable-status-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.executable-status-title{align-items:center;border-bottom:1px solid var(--border-color);color:var(--text-primary);display:flex;font-size:1.125rem;font-weight:600;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem}.executable-status-title svg{color:var(--text-secondary);flex-shrink:0}@media (max-width:768px){.analysis-status-section .section-title{font-size:1.5rem}.analysis-status-container{gap:1rem}.executable-status-item{padding:1rem}.executable-status-title{font-size:1rem;gap:.5rem;padding-bottom:.5rem}}.executable-detail{min-height:calc(100vh - 80px);padding:2rem 0}.content-placeholder{align-items:center;display:flex;justify-content:center;min-height:400px}.placeholder-card{max-width:500px;padding:3rem 2rem;text-align:center}.placeholder-icon{color:var(--text-muted);margin-bottom:1rem}.placeholder-card h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.placeholder-card p{color:var(--text-secondary);line-height:1.6}@media (max-width:768px){.executable-detail{padding:1rem 0}.page-title{font-size:2rem}.placeholder-card{padding:2rem 1rem}}.create-project{min-height:calc(100vh - 80px);padding:2rem 0}.page-header{margin-bottom:2rem}.back-btn{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:1rem;padding:.5rem 0;transition:all .2s ease-in-out}.back-btn:hover,.page-title{color:var(--text-primary)}.page-title{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);font-size:1.125rem;line-height:1.6}.form-container{max-width:600px}.project-form{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:.75rem;padding:2rem}.form-group{margin-bottom:2rem}.form-label{align-items:center;display:flex;font-weight:600;gap:.5rem;margin-bottom:.75rem}.form-input,.form-label{color:var(--text-primary);font-size:.875rem}.form-input{background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:.5rem;padding:.75rem 1rem;transition:all .2s ease-in-out;width:100%}.form-input:focus{border-color:var(--accent-purple);box-shadow:0 0 0 3px #8b5cf61a;outline:none}.form-input.error{border-color:var(--error)}.form-help,.form-input::placeholder{color:var(--text-muted)}.form-help{font-size:.75rem;line-height:1.4;margin-top:.5rem}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:.75rem;padding:.5rem 0}.form-checkbox{display:none}.checkbox-custom{align-items:center;background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:.25rem;color:var(--accent-purple);display:flex;height:20px;justify-content:center;transition:all .2s ease-in-out;width:20px}.form-checkbox:checked+.checkbox-custom{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.checkbox-text{color:var(--text-primary);font-weight:500}.error-message{background:#ef44441a;border:1px solid #ef444433;border-radius:.375rem;color:var(--error);font-size:.875rem;margin-top:.5rem;padding:.5rem .75rem}.error-message.general{margin-bottom:1.5rem}.form-actions{border-top:1px solid var(--border-color);display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}.spinner.small{border-width:2px;height:16px;margin:0;width:16px}@media (max-width:768px){.create-project{padding:1rem 0}.page-title{font-size:2rem}.project-form{padding:1.5rem}.form-actions{flex-direction:column-reverse}.form-actions .btn{justify-content:center;width:100%}}@media (max-width:480px){.page-title{font-size:1.75rem}.project-form{padding:1rem}}.login-page{background:linear-gradient(135deg,#0a0a0a,#1a1a1a);justify-content:center;min-height:100vh}.login-card,.login-page{align-items:center;display:flex}.login-card{background:#1e1e28f2;border-radius:16px;box-shadow:0 4px 32px #0006;flex-direction:column;max-width:350px;padding:2.5rem 2rem 2rem;width:100%}.login-title{color:#8b5cf6;font-size:2rem;font-weight:700;letter-spacing:1px;margin-bottom:1.5rem}.login-form{gap:1.2rem;width:100%}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.4rem}.form-group label{color:#cbd5e1;font-size:1rem;font-weight:500}.form-group input{background:#18181b;border:1px solid #333;border-radius:8px;color:#f3f4f6;font-size:1rem;outline:none;padding:.6rem .8rem;transition:border .2s}.form-group input:focus{border:1.5px solid #8b5cf6}.password-input-wrapper{align-items:center;display:flex;gap:.5rem}.show-password-btn{background:none;border:none;color:#8b5cf6;cursor:pointer;font-size:.95rem;padding:0 .3rem;transition:color .2s}.show-password-btn:hover{color:#10b981}.error-message{background:#1e1e2a;border-radius:6px;color:#ef4444;font-size:.98rem;margin-bottom:.5rem;padding:.5rem .8rem;text-align:center}.password-label-row{align-items:center;display:flex;gap:.5rem;margin-bottom:.2rem}.form-group input[type=password],.form-group input[type=text]{box-sizing:border-box;width:100%}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;padding-top:80px}.fade-in{animation:fadeIn .5s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-color);border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-purple);height:40px;margin:2rem auto;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.main-content{padding-top:70px}.container{padding:0 .5rem}}
/*# sourceMappingURL=main.bd4b695c.css.map*/