.app-loading{align-items:center;background:#1e1e1e;color:#f5f5f5;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #3a3a3a;border-radius:50%;border-top-color:#3b82f6;height:48px;width:48px}.app-loading p{color:#9ca3af;font-size:.95rem;margin-top:1rem}.nav-skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#2a2a2a 25%,#3a3a3a 50%,#2a2a2a 75%);border-radius:4px;height:36px;width:80px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.protected-route-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:400px}.protected-route-loading .loading-spinner{border-width:3px;height:40px;width:40px}.protected-route-loading p{color:#9ca3af;font-size:.9rem}.navbar{background:linear-gradient(145deg,#1f1f1f,#2b2b2b 40%,#3a3a3a,#2b2b2b 0,#1f1f1f);height:4.375rem;padding:0 1.25rem}.navbar,.navbar-content{align-items:center;display:flex}.navbar-content{justify-content:space-between;width:100%}.navbar-img{height:2.625rem;padding-right:.9375rem}.navbar-links,.navbar-right{align-items:center;display:flex}.navbar-links{gap:.9375rem;list-style:none;margin:0;padding:0;white-space:nowrap}.nav-link{border-radius:var(--radius-md);color:#e5e5e5;font-size:.875rem;padding:.375rem .625rem;text-decoration:none;transition:background-color .15s ease,color .15s ease}.nav-link:hover{background-color:#333}.nav-link-active{background-color:#3e3e3e;color:#fff}.nav-link-signin{background-color:#2563eb;color:#fff}.nav-link-pill:hover{background-color:#1d4ed8}.nav-logout-btn{background:none}.burger-btn,.nav-logout-btn{border:none;cursor:pointer;padding:0}.burger-btn{background:#0000;display:none;flex-direction:column;height:1.5rem;justify-content:space-around;width:1.5rem;z-index:1001}.burger-line{background-color:#e5e5e5;border-radius:.125rem;height:.1875rem;transition:all .3s ease;width:100%}.burger-line.open:first-child{transform:rotate(45deg) translate(.3125rem,.3125rem)}.burger-line.open:nth-child(2){opacity:0}.burger-line.open:nth-child(3){transform:rotate(-45deg) translate(.375rem,-.375rem)}.nav-skeleton{animation:loading 1.5s infinite;background:linear-gradient(90deg,#2a2a2a 25%,#333 50%,#2a2a2a 75%);background-size:200% 100%;border-radius:var(--radius-md);height:1.75rem;width:4rem}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width:48rem){.navbar{height:3.75rem;padding:0 1rem}.navbar-img{height:2rem;padding-right:0}.burger-btn{display:flex}.navbar-right{background:linear-gradient(180deg,#2b2b2b,#1f1f1f);box-shadow:-.25rem 0 .625rem #0000004d;flex-direction:column;height:calc(100dvh - 3.75rem);padding:1.5rem 1rem;position:fixed;right:-100%;top:3.75rem;transition:right .3s ease;width:16rem;z-index:1000}.navbar-right.menu-open{right:0}.navbar-links{align-items:stretch;flex-direction:column;gap:.5rem;width:100%}.nav-link,.navbar-links li{width:100%}.nav-link{border-radius:var(--radius-md);display:block;font-size:1rem;padding:.75rem 1rem;text-align:left}.nav-link-signin{margin-top:.5rem;text-align:center}.nav-skeleton{height:2.5rem;width:100%}}.browse{background:#1e1e1e;display:flex;flex-direction:column;min-height:100dvh;padding:1.875rem}.browse-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2.1875rem}.browse-stacks-search{background:#242424;border:1px solid #3a3a3a;border-radius:var(--radius-md);color:#f5f5f5;font-size:.9375rem;padding:.625rem 1rem;transition:.2s ease;width:21.25rem}.browse-stacks-search::placeholder{color:#7c7c7c}.browse-stacks-search:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.browse-stacks-filters{display:flex;gap:.75rem}.browse-stacks-filter-btn{background:#242424;border:1px solid #3a3a3a;border-radius:var(--radius-md);color:#b5b5b5;cursor:pointer;font-size:.8125rem;padding:.5rem 1rem;transition:.25s}.browse-stacks-filter-btn:hover{background:#2a2a2a;border-color:#3b82f6;color:#f5f5f5}.browse-stacks-section{background:#2a2a2a;border:1px solid #ffffff05;border-radius:var(--radius-xl);box-shadow:0 4px 25px #0003;margin-bottom:1.5625rem;padding:1.75rem}.browse-section-title{color:#f5f5f5;font-size:1.5rem;font-weight:600;margin:0}.browse-stack-list{grid-gap:1.75rem;display:grid;gap:1.75rem;grid-template-columns:repeat(6,minmax(0,1fr));padding-top:1.5625rem;width:100%}@media (max-width:80rem){.browse-stack-list{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width:64rem){.browse-stack-list{grid-template-columns:repeat(3,minmax(0,1fr))}}.pagination{align-items:center;display:flex;gap:1.5rem;justify-content:center;margin-top:2rem}.pagination-btn{background:#3b82f6;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:.25s}.pagination-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 0 15px #3b82f640;transform:translateY(-2px)}.pagination-btn:disabled{background:#4b5563;cursor:not-allowed;opacity:.5}.pagination-info{color:#d1d5db;font-size:.9375rem;font-weight:500}@media (max-width:48rem){.browse{padding:1rem}.browse-header{align-items:stretch;flex-direction:column;gap:1rem}.browse-stacks-search{width:100%}.browse-stacks-filters{flex-wrap:wrap;justify-content:center}.browse-stacks-section{border-radius:var(--radius-lg);padding:1rem}.browse-section-title{font-size:1.25rem}.browse-stack-list{gap:1rem}.pagination{flex-direction:column;gap:1rem}.pagination-btn{width:100%}}@media (max-width:30rem){.browse-stack-list{grid-template-columns:1fr}}.textDecoration-none{text-decoration:none}.skeleton-card{animation:pulse 1.5s ease-in-out infinite;background:#333;border-radius:8px;padding:16px}.skeleton{background:#575757;border-radius:4px;margin-bottom:12px}.skeleton-thumb{height:120px;width:100%}.skeleton-title{height:20px;width:70%}.skeleton-sub{height:16px;margin-bottom:0;width:50%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.stack-summary-card{background:linear-gradient(145deg,#3a3a3a,#2b2b2b 40%,#1f1f1f);border:1px solid #3b82f644;border-radius:var(--radius-xl);box-shadow:0 12px 28px #00000073;box-sizing:border-box;color:#f9fafb;display:flex;flex-direction:column;gap:.875rem;height:10.625rem;padding:.9375rem;position:relative;text-decoration:none;transition:.22s ease;width:100%}.stack-summary-card:hover{background:linear-gradient(145deg,#424242,#2e2e2e 40%,#1f1f1f);border-color:#3b82f6cc;box-shadow:0 16px 36px #0009;transform:translateY(-4px)}.stack-summary-header{align-items:center;display:flex;gap:.75rem;justify-content:space-between}.stack-summary-title{font-size:1.125rem;font-weight:800;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stack-summary-badge{border-radius:var(--radius-full);color:#fff;font-size:.75rem;font-weight:600;padding:.3125rem .75rem;white-space:nowrap}.stack-summary-badge-fullstack{background:#2cbfa5}.stack-summary-badge-backend{background:#7e28c7}.stack-summary-badge-frontend{background:#ec3636}.stack-summary-description{-webkit-line-clamp:1;-webkit-box-orient:vertical;color:#e5e7eb;display:-webkit-box;font-size:.875rem;line-height:1.5;max-width:100%;overflow:hidden;text-overflow:ellipsis}.stack-summary-footer{align-items:center;color:#d1d5db;display:flex;font-size:.875rem;gap:.625rem;margin-top:auto}.stack-summary-avatar{background-color:#ffffff22;border:1px solid #3b82f688;border-radius:50%;height:2.25rem;object-fit:cover;width:2.25rem}.stack-summary-username{font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:48rem){.stack-summary-card{height:auto;min-height:10rem;padding:1rem}.stack-summary-title{font-size:1rem}.stack-summary-badge{font-size:.6875rem;padding:.25rem .625rem}.stack-summary-avatar{height:2rem;width:2rem}.stack-summary-username{font-size:.8125rem}}.create-stack{align-items:flex-start;background:#1e1e1e;color:#f5f5f5;display:flex;justify-content:center;min-height:100dvh;padding:1.875rem}.create-stack-card{background:#2a2a2a;border:1px solid #ffffff10;border-radius:var(--radius-xl);box-shadow:0 12px 30px #0009;display:flex;flex-direction:column;gap:1.25rem;max-width:87.5rem;padding:1.5rem 1.75rem 1.25rem;width:100%}.create-stack-error{background-color:#ffebee;border-radius:var(--radius-sm);color:#d32f2f;font-size:.9rem;margin-bottom:1rem;padding:.75rem}.create-stack-error-title{font-weight:700;margin-bottom:.5rem}.create-stack-error-list{margin:.5rem 0 0;padding-left:1.25rem}.create-stack-header{display:flex;flex-direction:column;gap:.375rem}.create-stack-title-row{align-items:center;display:flex;gap:1rem;justify-content:space-between}.create-stack-name-input{background:#242424;border:1px solid #3a3a3a;border-radius:var(--radius-md);color:#f5f5f5;flex:1 1;font-size:1.125rem;font-weight:700;padding:.625rem .875rem}.create-stack-name-input::placeholder{color:#7c7c7c}.create-stack-name-input:focus{border-color:#3b82f6;outline:none}.create-stack-type-select{background:#3b82f6;border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;font-size:.8125rem;font-weight:600;padding:.5rem 1rem}.create-stack-author{color:#d1d5db;font-size:.875rem;margin:0}.create-stack-author span{font-weight:600}.create-stack-layout{grid-gap:1.75rem;display:grid;gap:1.75rem;grid-template-columns:16.25rem minmax(0,1fr)}.create-stack-left{display:flex;flex-direction:column;gap:.625rem}.create-stack-packages-header{align-items:center;display:flex;justify-content:space-between}.create-stack-packages-title{font-size:1.125rem;font-weight:600;margin:0}.create-stack-add-package{background:#3b82f6;border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;font-weight:700;height:1.625rem;width:1.625rem}.create-stack-packages-list{display:flex;flex-direction:column;gap:.5rem}.create-stack-empty-state{background:#242424;border:1px dashed #3a3a3a;border-radius:var(--radius-md);color:#9ca3af;font-size:.875rem;padding:2rem;text-align:center}.create-stack-package-item{align-items:center;background:#242424;border:1px solid #3a3a3a;border-radius:var(--radius-md);display:flex;gap:.75rem;justify-content:space-between;padding:.75rem;transition:background .2s}.create-stack-package-item:hover{background:#2a2a2a}.create-stack-package-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.create-stack-package-name{align-items:center;color:#f5f5f5;display:flex;font-size:.875rem;font-weight:600;gap:.375rem}.create-stack-verified-badge{align-items:center;background:#10b981;border-radius:50%;color:#fff;display:inline-flex;font-size:.625rem;font-weight:700;height:1rem;justify-content:center;width:1rem}.create-stack-package-link{color:#60a5fa;font-size:.75rem;overflow:hidden;text-decoration:none;text-overflow:ellipsis;white-space:nowrap}.create-stack-package-link:hover{text-decoration:underline}.create-stack-package-remove{align-items:center;background:#ef4444;border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.125rem;font-weight:700;height:1.5rem;justify-content:center;transition:background .2s;width:1.5rem}.create-stack-package-remove:hover{background:#dc2626}.create-stack-package-remove:disabled{cursor:not-allowed;opacity:.5}.create-stack-right{background:linear-gradient(145deg,#333,#272727 45%,#1f1f1f);border:1px solid #3b82f644;border-radius:var(--radius-lg);box-shadow:0 10px 26px #00000080;display:flex;padding:1rem 1.125rem}.create-stack-description{background:#0000;border:none;color:#e5e7eb;font-size:.875rem;line-height:1.6;min-height:13.75rem;outline:none;resize:vertical;width:100%}.create-stack-footer{display:flex;gap:.625rem;justify-content:flex-end;margin-top:.625rem}.create-stack-btn{border:none;border-radius:var(--radius-full);cursor:pointer;font-size:.875rem;font-weight:600;padding:.5625rem 1.125rem;text-decoration:none;transition:.2s ease}.create-stack-btn.secondary{background:#0000;border:1px solid #4b5563;color:#e5e5e5}.create-stack-btn.secondary:hover{background:#374151}.create-stack-btn.primary{background:#2563eb;color:#fff}.create-stack-btn.primary:hover{background:#1d4ed8}@media (max-width:48rem){.create-stack{padding:1rem}.create-stack-card{border-radius:var(--radius-lg);padding:1rem}.create-stack-layout{gap:1.25rem;grid-template-columns:1fr}.create-stack-title-row{align-items:stretch;flex-direction:column;gap:.75rem}.create-stack-name-input{font-size:1rem}.create-stack-type-select{align-self:flex-start}.create-stack-right{min-height:10rem}.create-stack-description{min-height:8rem}.create-stack-footer{flex-direction:column-reverse;gap:.5rem}.create-stack-btn{text-align:center;width:100%}}.modal-backdrop{align-items:center;animation:fadeIn .2s ease;background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-container{animation:scaleIn .2s ease;background:linear-gradient(145deg,#2a2a2a,#242424);border:1px solid #ffffff08;border-radius:var(--radius-lg);box-shadow:0 12px 40px #0009;display:flex;flex-direction:column;max-height:90vh;max-width:90%;overflow:hidden;padding:1.75rem;position:relative}.modal-sm{min-height:6.25rem;width:25rem}.modal-md{min-height:12.5rem;width:31.25rem}.modal-lg{min-height:21.875rem;width:40.625rem}@media (max-width:48rem){.modal-container{margin:1rem;max-width:calc(100% - 2rem);padding:1.25rem}.modal-lg,.modal-md,.modal-sm{max-width:100%;width:100%}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.add-package-modal{display:flex;flex-direction:column;max-height:90vh;overflow-y:auto}.add-package-modal-title{color:#f5f5f5;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.add-package-modal-error{background-color:#3a1f1f;border-left:3px solid #ff6b6b;border-radius:4px;color:#ff6b6b;font-size:.9rem;margin-bottom:1rem;padding:.75rem}.add-package-modal-type-selector{background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;display:flex;gap:1.5rem;margin-bottom:1.5rem;padding:1rem}.add-package-modal-radio{align-items:center;color:#e5e5e5;cursor:pointer;display:flex;font-size:.95rem;gap:.5rem}.add-package-modal-radio input[type=radio]{cursor:pointer;height:16px;width:16px}.add-package-modal-field{margin-bottom:1.5rem}.add-package-modal-field label{color:#e5e5e5;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.add-package-modal-input,.add-package-modal-select{background-color:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#f5f5f5;font-size:.95rem;padding:.75rem;transition:border-color .2s;width:100%}.add-package-modal-input:focus,.add-package-modal-select:focus{border-color:#3b82f6;outline:none}.add-package-modal-input::placeholder{color:#7c7c7c}.add-package-modal-select{cursor:pointer}.add-package-modal-link-preview{background-color:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;display:flex;flex-direction:column;font-size:.85rem;gap:.5rem;margin-top:.5rem;padding:.75rem}.add-package-modal-link-label{color:#9ca3af;font-size:.8rem;font-weight:500}.add-package-modal-link{color:#60a5fa;text-decoration:none;transition:color .2s;word-break:break-all}.add-package-modal-link:hover{color:#93c5fd;text-decoration:underline}.add-package-modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.add-package-modal-btn{border:none;border-radius:4px;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.add-package-modal-btn.primary{background-color:#3b82f6;color:#fff}.add-package-modal-btn.primary:hover{background-color:#2563eb}.add-package-modal-btn.secondary{background-color:initial;border:1px solid #4b5563;color:#e5e5e5}.add-package-modal-btn.secondary:hover{background-color:#374151}.add-package-modal-btn:disabled{cursor:not-allowed;opacity:.6}.email-verify-modal{color:#f5f5f5;position:relative}.email-verify-close{align-items:center;background:none;border:none;color:#7c7c7c;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;position:absolute;right:-8px;top:-8px;transition:color .2s;width:32px}.email-verify-close:hover{color:#f5f5f5}.email-verify-title{color:#f5f5f5;font-size:1.5rem;font-weight:600;margin:0 0 .5rem;text-align:center}.email-verify-subtitle{color:#7c7c7c;font-size:.9rem;margin:0 0 .5rem;text-align:center}.email-verify-help{color:#999;font-size:.8rem;font-style:italic;margin:0 0 1.5rem;text-align:center}.email-verify-error{background-color:#ffebee;color:#d32f2f}.email-verify-error,.email-verify-success{border-radius:8px;font-size:.9rem;margin-bottom:1rem;padding:.75rem}.email-verify-success{background-color:#e8f5e9;color:#2e7d32}.email-verify-form{display:flex;flex-direction:column;gap:1rem}.email-verify-field{display:flex;flex-direction:column;gap:.5rem}.email-verify-field label{color:#f5f5f5;font-size:.9rem;font-weight:500}.email-verify-field input{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#f5f5f5;font-family:Courier New,monospace;font-size:1.25rem;font-weight:600;letter-spacing:.25rem;padding:13px;text-align:center;transition:all .2s}.email-verify-field input::placeholder{color:#555;font-family:inherit;font-size:.9rem;font-weight:400;letter-spacing:normal}.email-verify-field input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.email-verify-field input:disabled{cursor:not-allowed;opacity:.6}.email-verify-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:13px;transition:all .2s}.email-verify-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.email-verify-btn:disabled{cursor:not-allowed;opacity:.6}.email-verify-resend{margin-top:.5rem;text-align:center}.email-verify-resend-btn{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:.9rem;padding:.5rem;text-decoration:none;transition:color .2s}.email-verify-resend-btn:hover:not(:disabled){color:#2563eb;text-decoration:underline}.email-verify-resend-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:480px){.email-verify-modal{padding:1.5rem 1rem}.email-verify-title{font-size:1.25rem}}.stacks{background:#1e1e1e;display:flex;flex-direction:column;min-height:100dvh;padding:1.875rem}.my-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2.1875rem}.my-search{background:#242424;border:1px solid #3a3a3a;border-radius:var(--radius-md);color:#f5f5f5;font-size:.9375rem;padding:.625rem 1rem;transition:.2s ease;width:21.25rem}.my-search::placeholder{color:#7c7c7c}.my-search:focus{border-color:#3b82f6;outline:none}.my-create{background:#3b82f6;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;text-decoration:none;transition:.25s}.my-create:hover{background:#2563eb;box-shadow:0 0 15px #3b82f640}.my-stacks-section{background:#2a2a2a;border:1px solid #ffffff05;border-radius:var(--radius-xl);box-shadow:0 4px 25px #0003;margin-bottom:1.5625rem;padding:1.75rem}.my-section-title{color:#f5f5f5;font-size:1.5rem;font-weight:600;margin:0}.my-stack-list{grid-gap:1.75rem;display:grid;gap:1.75rem;grid-template-columns:repeat(6,minmax(0,1fr));padding-top:1.5625rem;width:100%}@media (max-width:80rem){.my-stack-list{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width:64rem){.my-stack-list{grid-template-columns:repeat(3,minmax(0,1fr))}}.empty-state{align-items:center;display:flex;flex-direction:column;gap:1.5rem;padding:3rem 1.5rem;text-align:center}.empty-state-text{color:#9ca3af;font-size:1.125rem;margin:0}.empty-state-btn{background:#3b82f6;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:inline-block;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:.25s}.empty-state-btn:hover{background:#2563eb;box-shadow:0 0 15px #3b82f640;transform:translateY(-2px)}@media (max-width:48rem){.stacks{padding:1rem}.my-header{align-items:stretch;flex-direction:column;gap:1rem}.my-search{width:100%}.my-create{text-align:center}.my-stacks-section{border-radius:var(--radius-lg);padding:1rem}.my-section-title{font-size:1.25rem}.my-stack-list{gap:1rem}}@media (max-width:30rem){.my-stack-list{grid-template-columns:1fr}}.download-page{background:#1e1e1e;color:#f5f5f5;display:flex;flex-direction:column;min-height:100dvh;overflow-x:hidden}.download-hero{align-items:center;background:linear-gradient(145deg,#1f1f1f,#282f4a,#1f1f1f);border-bottom:1px solid #ffffff10;display:flex;flex-shrink:0;justify-content:center;padding:5rem 1.875rem;width:100%}.download-hero-content{align-items:center;display:flex;flex-direction:column;gap:1.5rem;max-width:50rem;text-align:center}.download-hero-title{color:#f5f5f5;font-size:3rem;font-weight:800;letter-spacing:.02em;margin:0}.download-hero-subtitle{color:#d1d5db;font-size:1.125rem;line-height:1.6;margin:0;max-width:37.5rem}.download-hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:.5rem}.download-btn{border:none;border-radius:var(--radius-full);cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s ease}.download-btn-primary{background:#2563eb;color:#fff}.download-btn-primary:hover{background:#1d4ed8;box-shadow:0 8px 20px #2563eb66;transform:translateY(-2px)}.download-btn-secondary{background:#0000;border:2px solid #4b5563;color:#e5e5e5}.download-btn-secondary:hover{background:#4b556344;border-color:#6b7280;transform:translateY(-2px)}.download-faq-section{flex:1 1;margin:0 auto;max-width:56.25rem;padding:3.75rem 1.875rem;width:100%}.download-faq-title{color:#f5f5f5;font-size:2rem;font-weight:700;margin:0 0 2rem;text-align:center}.download-faq-container{display:flex;flex-direction:column;gap:.75rem}.download-faq-item{background:#242424;border:1px solid #3a3a3a;border-radius:var(--radius-md);overflow:hidden;transition:border-color .2s ease}.download-faq-item:hover{border-color:#4b5563}.download-faq-question{align-items:center;background:#242424;border:none;color:#f5f5f5;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:1rem;justify-content:space-between;padding:1.25rem 1.5rem;text-align:left;transition:background .2s ease;width:100%}.download-faq-question:hover{background:#2a2a2a}.download-faq-question span:first-child{flex:1 1}.download-faq-icon{color:#9ca3af;display:inline-block;flex-shrink:0;font-size:.875rem;transition:transform .3s ease}.download-faq-icon.open{transform:rotate(180deg)}.download-faq-answer{animation:slideDown .3s ease;background:#1e1e1e;border-top:1px solid #3a3a3a;color:#e5e7eb;font-size:.9375rem;line-height:1.7;padding:0 1.5rem 1.25rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-.625rem)}to{opacity:1;transform:translateY(0)}}@media (max-width:58.25rem){.download-faq-section{padding:3.125rem 1.5rem}.download-faq-question{font-size:.9375rem;padding:1.125rem 1.25rem}.download-faq-answer{font-size:.875rem;padding:0 1.25rem 1.125rem}}@media (max-width:48rem){.download-hero{padding:3.125rem 1.25rem}.download-hero-content{gap:1.25rem}.download-hero-title{font-size:2rem}.download-hero-subtitle{font-size:1rem}.download-hero-buttons{flex-direction:column;gap:.75rem;width:100%}.download-btn{padding:.875rem 1.5rem;width:100%}.download-faq-section{padding:2.5rem 1.25rem}.download-faq-title{font-size:1.5rem;margin-bottom:1.25rem}.download-faq-question{font-size:.9375rem;padding:1rem}.download-faq-answer{font-size:.875rem;line-height:1.6;padding:0 1rem 1rem}}@media (max-width:30rem){.download-hero{padding:1.875rem 1rem}.download-hero-content{gap:.875rem}.download-hero-title{font-size:1.625rem;line-height:1.2}.download-hero-subtitle{font-size:.875rem;line-height:1.5}.download-btn{font-size:.875rem;padding:.75rem 1.25rem}.download-faq-section{padding:1.5rem 1rem}.download-faq-title{font-size:1.25rem;margin-bottom:1rem}.download-faq-question{font-size:.875rem;gap:.625rem;padding:.75rem}.download-faq-answer{font-size:.8125rem;padding:0 .75rem .75rem}.download-faq-icon{font-size:.75rem}}.forgot-password-page{align-items:center;background:#1e1e1e;display:flex;justify-content:center;min-height:100vh;padding:1rem}.forgot-password-container{background:#2a2a2a;border-radius:16px;box-shadow:0 4px 12px #0000004d;max-width:420px;padding:2.5rem;width:100%}.forgot-password-img{cursor:pointer;display:block;margin:0 auto 1.5rem;max-width:120px}.forgot-password-container h1{color:#f5f5f5;font-size:1.75rem;font-weight:600;margin:0 0 .5rem;text-align:center}.forgot-password-description{color:#7c7c7c;font-size:.9rem;line-height:1.5;margin:0 0 1.5rem;text-align:center}.forgot-password-form{display:flex;flex-direction:column;gap:1rem}.forgot-password-form .form-group{display:flex;flex-direction:column;gap:.5rem}.forgot-password-form label{color:#f5f5f5;font-size:.9rem;font-weight:500}.forgot-password-form input{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#f5f5f5;font-size:1rem;padding:13px;transition:all .2s}.forgot-password-form input::placeholder{color:#555}.forgot-password-form input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.forgot-password-form input:disabled{cursor:not-allowed;opacity:.6}.forgot-password-form .submit-button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:13px;transition:all .2s}.forgot-password-form .submit-button:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.forgot-password-form .submit-button:disabled{cursor:not-allowed;opacity:.6}@media (max-width:480px){.forgot-password-container{padding:2rem 1.5rem}.forgot-password-container h1{font-size:1.5rem}}.hero{background:linear-gradient(145deg,#1f1f1f,#282f4a,#1f1f1f);height:100%;justify-content:center;width:100%}.hero,.hero-content{align-items:center;display:flex}.hero-content{flex-direction:column}.hero-title{color:#e5e5e5;font-size:4.375rem;font-weight:800;margin:0}.hero-title span{color:#3b82f6}.hero-subtitle{color:#cfcfcf;font-size:1.25rem;margin-top:.5rem}.hero-buttons{display:flex;gap:.75rem;white-space:nowrap}.hero-btn{align-items:center;background-color:#3b82f644;border-radius:var(--radius-sm);color:#e5e5e5;display:flex;flex-direction:column;font-size:.875rem;padding:.375rem 1rem;text-decoration:none;width:3.4375rem}.hero-btn:hover{background-color:#1f1f1f}@media (max-width:48rem){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1rem;padding:0 1rem;text-align:center}.hero-buttons{gap:.5rem}.hero-btn{font-size:.75rem;min-width:3rem;padding:.375rem .75rem;width:auto}}@media (max-width:30rem){.hero-title{font-size:1.75rem}.hero-subtitle{font-size:.875rem}.hero-buttons{flex-wrap:wrap;justify-content:center}}.home{background-color:#262626;display:flex;flex-direction:column;min-height:100dvh}.home-banner{height:40dvh;width:100%}.home-content{width:100%}.home-stack-list{grid-gap:1.75rem;display:grid;gap:1.75rem;grid-template-columns:repeat(auto-fit,minmax(15rem,1fr));padding-top:.3125rem;width:100%}.home-trending{color:#e5e5e5;margin:2.5rem}.home-trending-title{font-size:1.5rem;font-weight:600}.home-trending-sub{color:#cfcfcf;font-size:.875rem}@media (max-width:48rem){.home-trending{margin:1.5rem}.home-trending-title{font-size:1.25rem}.home-trending-sub{font-size:.8125rem}.home-stack-list{gap:1rem}}@media (max-width:30rem){.home-trending{margin:1rem}.home-stack-list{grid-template-columns:1fr}}.login{align-items:center;background:#1e1e1e;display:flex;justify-content:center;min-height:100dvh;padding:1rem}.login-card{background:#2a2a2a;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000004d;max-width:26.25rem;padding:2.5rem;width:100%}.login-img{cursor:pointer;display:block;margin:0 auto 1.5rem;max-width:7.5rem}.login-message-success{background-color:#e8f5e9;border:1px solid #2e7d32;border-radius:var(--radius-md);color:#2e7d32}.login-message-info,.login-message-success{font-size:.9rem;margin-bottom:1rem;padding:.75rem}.login-message-info{background-color:#e3f2fd;border:1px solid #1976d2;border-radius:var(--radius-md);color:#1976d2}.login-message-error{background-color:#ffebee;border-radius:var(--radius-sm);color:#d32f2f;font-size:.9rem;margin-bottom:1rem;padding:.75rem}.login-title{color:#f5f5f5;font-size:1.75rem;font-weight:600;margin:0 0 .5rem;text-align:center}.login-subtitle{color:#7c7c7c;font-size:.9rem;margin:0 0 1.5rem;text-align:center}.login-form{gap:1rem}.login-field,.login-form{display:flex;flex-direction:column}.login-field{gap:.5rem}.login-field label{color:#f5f5f5;font-size:.9rem;font-weight:500}.login-field input{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:var(--radius-md);color:#f5f5f5;font-size:1rem;padding:.8125rem;transition:all .2s}.login-field input::placeholder{color:#555}.login-field input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.login-field input:disabled{cursor:not-allowed;opacity:.6}.login-btn{background:#3b82f6;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:.8125rem;transition:all .2s}.login-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.login-btn:disabled{cursor:not-allowed;opacity:.6}.login-links{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;text-align:center}.login-links a{color:#3b82f6;font-size:.9rem;text-decoration:none;transition:color .2s}.login-links a:hover{color:#2563eb;text-decoration:underline}@media (max-width:480px){.login-card{padding:2rem 1.5rem}.login-title{font-size:1.5rem}}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#2a2a2a;border-radius:8px;box-shadow:0 4px 20px #00000080;max-height:90vh;max-width:500px;overflow-y:auto;padding:2rem;width:100%}.modal-content-large{max-width:600px}.modal-title{color:#f5f5f5;font-size:1.5rem;font-weight:600;margin:0 0 .5rem;text-align:center}.modal-subtitle{color:#7c7c7c;font-size:.9rem;margin:0 0 1.5rem;text-align:center}.setup-step{display:flex;gap:1rem;margin-bottom:2rem}.step-number{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:600;height:32px;justify-content:center;width:32px}.step-content{flex:1 1}.step-content h3{color:#f5f5f5;font-size:1.1rem;margin:0 0 .5rem}.step-content p{color:#9ca3af;font-size:.9rem;margin:0 0 1rem}.qr-container{background:#fff;border-radius:8px;display:inline-block;margin:1rem 0;padding:1rem}.qr-code{display:block;height:200px;width:200px}.manual-key{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:4px;color:#3b82f6;cursor:text;font-family:Courier New,monospace;font-size:1.1rem;letter-spacing:.1rem;padding:1rem;text-align:center;-webkit-user-select:all;user-select:all}.verify-form{display:flex;flex-direction:column;gap:1rem}.verify-input{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:4px;color:#f5f5f5;font-family:Courier New,monospace;font-size:1.5rem;font-weight:600;letter-spacing:.5rem;padding:1rem;text-align:center;transition:all .2s}.verify-input::placeholder{color:#555;letter-spacing:normal}.verify-input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{color:#f5f5f5;font-size:.9rem;font-weight:500}.form-field input{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:4px;color:#f5f5f5;font-size:1rem;padding:.75rem;transition:all .2s}.form-field input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.recovery-codes-container{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr);margin:1.5rem 0}.recovery-code{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:4px;color:#3b82f6;font-family:Courier New,monospace;font-size:.95rem;padding:.75rem;text-align:center;-webkit-user-select:all;user-select:all}.modal-warning{background:#fef3c7;border-radius:4px;color:#92400e;font-size:.9rem;margin:1rem 0;padding:1rem}.modal-btn{border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s;width:100%}.modal-btn-primary{background:#3b82f6;color:#fff}.modal-btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.modal-btn-secondary{background:#4b5563;color:#fff}.modal-btn-secondary:hover:not(:disabled){background:#374151}.modal-btn-danger{background:#dc2626;color:#fff}.modal-btn-danger:hover:not(:disabled){background:#b91c1c}.modal-btn-text{background:#0000;color:#7c7c7c;margin-top:.5rem}.modal-btn-text:hover:not(:disabled){color:#f5f5f5}.modal-btn:disabled{cursor:not-allowed;opacity:.6}.modal-actions{display:flex;gap:1rem;margin-top:1rem}.modal-actions button{flex:1 1}.error-message{background:#ffebee;border-radius:4px;color:#d32f2f}.twofactor-status{background:#2a2a2a;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.status-message{border-radius:4px;font-size:.9rem;margin-bottom:1rem;padding:1rem}.status-error{background:#ffebee;color:#d32f2f}.status-success{background:#e8f5e9;color:#2e7d32}.status-info{margin-bottom:1.5rem}.status-row{align-items:center;border-bottom:1px solid #3a3a3a;display:flex;gap:1rem;padding:.75rem 0}.status-row:last-child{border-bottom:none}.status-label{color:#7c7c7c;font-size:.9rem;min-width:160px}.status-value{color:#f5f5f5;font-size:.9rem}.status-warning{color:#f59e0b}.status-badge{border-radius:12px;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.status-enabled{background:#dcfce7;color:#166534}.status-disabled{background:#f3f4f6;color:#4b5563}.status-actions{display:flex;flex-wrap:wrap;gap:1rem}.status-btn{border:none;border-radius:4px;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.status-btn-primary{background:#3b82f6;color:#fff}.status-btn-primary:hover{background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.status-btn-secondary{background:#4b5563;color:#fff}.status-btn-secondary:hover{background:#374151}.status-btn-danger{background:#dc2626;color:#fff}.status-btn-danger:hover{background:#b91c1c}@media (max-width:640px){.recovery-codes-container{grid-template-columns:1fr}.modal-actions,.status-actions,.status-row{flex-direction:column}.status-row{align-items:flex-start;gap:.5rem}.status-label{min-width:auto}}.email-verify-banner{align-items:center;background:linear-gradient(135deg,#3a2f1f,#2a2419);border:1px solid #d97706;border-radius:12px;box-shadow:0 4px 12px #d977061a;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.email-verify-banner-content{align-items:flex-start;display:flex;flex:1 1;gap:1rem}.email-verify-banner-icon{font-size:1.5rem;line-height:1}.email-verify-banner-text h3{color:#fbbf24;font-size:1rem;font-weight:600;margin:0 0 .25rem}.email-verify-banner-text p{color:#d1d5db;font-size:.875rem;line-height:1.5;margin:0}.email-verify-banner-message{border-radius:4px;font-size:.8rem;margin-top:.5rem;padding:.5rem}.email-verify-banner-message.success{background-color:#2e7d3233;color:#81c784}.email-verify-banner-message.error{background-color:#d32f2f33;color:#e57373}.email-verify-banner-actions{display:flex;flex-shrink:0;gap:.75rem}.email-verify-banner-btn{border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s;white-space:nowrap}.email-verify-banner-btn.primary{background:#d97706;color:#fff}.email-verify-banner-btn.primary:hover{background:#b45309;box-shadow:0 2px 8px #d977064d}.email-verify-banner-btn.secondary{background:#0000;border:1px solid #d97706;color:#d97706}.email-verify-banner-btn.secondary:hover{background:#d977061a}.email-verify-banner-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.email-verify-banner{align-items:stretch;flex-direction:column}.email-verify-banner-content{flex-direction:column;text-align:center}.email-verify-banner-icon{align-self:center}.email-verify-banner-btn{width:100%}}@media (max-width:480px){.email-verify-banner{padding:1rem}.email-verify-banner-text h3{font-size:.9rem}.email-verify-banner-text p{font-size:.8rem}}.my-account{align-items:flex-start;background:#1e1e1e;display:flex;justify-content:center;min-height:100dvh;padding:3.125rem 1.875rem}.my-account-container{max-width:43.75rem;width:100%}.my-account-header{margin-bottom:2.5rem;text-align:center}.my-account-title{color:#f5f5f5;font-size:2.25rem;font-weight:600;margin:0}.my-account-subtitle{color:#7c7c7c;font-size:.9375rem;margin:.75rem 0 0}.my-account-section{background:#2a2a2a;border:1px solid #ffffff05;border-radius:var(--radius-xl);box-shadow:0 4px 25px #0003;margin-bottom:1.75rem;padding:2rem}.my-account-section-title{color:#f5f5f5;font-size:1.375rem;font-weight:600;margin:0 0 1.5rem}.my-account-section-subtitle{color:#7c7c7c;font-size:.875rem;line-height:1.5;margin:0 0 1.25rem}.my-account-field{margin-bottom:1.375rem}.my-account-field:last-of-type{margin-bottom:0}.my-account-field label{color:#b5b5b5;display:block;font-size:.875rem;font-weight:500;margin-bottom:.625rem}.my-account-field input{background:#242424;border:1px solid #3a3a3a;border-radius:var(--radius-md);box-sizing:border-box;color:#f5f5f5;font-size:.9375rem;padding:.8125rem 1.125rem;transition:.2s ease;width:100%}.my-account-field input::placeholder{color:#7c7c7c}.my-account-field input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.my-account-field input:read-only:not([type=file]){background:#1e1e1e;cursor:not-allowed;opacity:.7}.my-account-btn{background:#3b82f6;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;margin-top:1rem;padding:.8125rem 1.75rem;transition:.25s}.my-account-btn:hover{background:#2563eb;box-shadow:0 0 15px #3b82f640;transform:translateY(-1px)}.my-account-btn:active{transform:translateY(0)}.my-account-avatar-container{margin:.625rem 0}.my-account-avatar{border:2px solid #ddd;border-radius:50%;height:9.375rem;object-fit:cover;width:9.375rem}.my-account-file-input{border:1px solid #ddd;border-radius:var(--radius-sm);cursor:pointer;margin:.625rem 0;padding:.5rem;width:100%}@media (max-width:48rem){.my-account{padding:1.5rem 1rem}.my-account-title{font-size:1.75rem}.my-account-section{border-radius:var(--radius-lg);padding:1.25rem}.my-account-section-title{font-size:1.25rem}.my-account-avatar{height:6rem;width:6rem}.my-account-btn{width:100%}}.register{align-items:center;background:#1e1e1e;display:flex;justify-content:center;min-height:100vh;padding:1rem}.register-card{background:#2a2a2a;border-radius:16px;box-shadow:0 4px 12px #0000004d;max-width:420px;padding:2.5rem;width:100%}.register-img{cursor:pointer;display:block;margin:0 auto 1.5rem;max-width:120px}.register-title{color:#f5f5f5;font-size:1.75rem;font-weight:600;margin:0 0 .5rem;text-align:center}.register-subtitle{color:#7c7c7c;font-size:.9rem;margin:0 0 1.5rem;text-align:center}.register-form{gap:1rem}.register-field,.register-form{display:flex;flex-direction:column}.register-field{gap:.5rem}.register-field label{color:#f5f5f5;font-size:.9rem;font-weight:500}.register-field input{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#f5f5f5;font-size:1rem;padding:13px;transition:all .2s}.register-field input::placeholder{color:#555}.register-field input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.register-field input:disabled{cursor:not-allowed;opacity:.6}.register-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:13px;transition:all .2s}.register-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.register-btn:disabled{cursor:not-allowed;opacity:.6}.register-links{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;text-align:center}.register-links a{color:#3b82f6;font-size:.9rem;text-decoration:none;transition:color .2s}.register-links a:hover{color:#2563eb;text-decoration:underline}@media (max-width:480px){.register-card{padding:2rem 1.5rem}.register-title{font-size:1.5rem}}.reset-password-page{align-items:center;background:#1e1e1e;display:flex;justify-content:center;min-height:100vh;padding:1rem}.reset-password-container{background:#2a2a2a;border-radius:16px;box-shadow:0 4px 12px #0000004d;max-width:420px;padding:2.5rem;width:100%}.reset-password-img{cursor:pointer;display:block;margin:0 auto 1.5rem;max-width:120px}.reset-password-container h1{color:#f5f5f5;font-size:1.75rem;font-weight:600;margin:0 0 .5rem;text-align:center}.reset-password-description{color:#7c7c7c;font-size:.9rem;line-height:1.5;margin:0 0 1.5rem;text-align:center}.reset-password-form{display:flex;flex-direction:column;gap:1rem}.reset-password-form .form-group{display:flex;flex-direction:column;gap:.5rem}.reset-password-form label{color:#f5f5f5;font-size:.9rem;font-weight:500}.reset-password-form input{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#f5f5f5;font-size:1rem;padding:13px;transition:all .2s}.reset-password-form input::placeholder{color:#555}.reset-password-form input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.reset-password-form input:disabled{cursor:not-allowed;opacity:.6}.reset-password-form .submit-button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:13px;transition:all .2s}.reset-password-form .submit-button:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.reset-password-form .submit-button:disabled{cursor:not-allowed;opacity:.6}.error-message{background-color:#ef444420;border:1px solid #ef4444;border-radius:8px;color:#ef4444;padding:.75rem}.error-message,.success-message{font-size:.9rem;margin-bottom:1rem}.success-message{background:#10b98150;border:1px solid #10b981;border-radius:8px;color:#10b981;padding:1rem;text-align:center}.back-to-login{margin-top:1rem;text-align:center}.back-to-login a{color:#3b82f6;font-size:.9rem;text-decoration:none;transition:color .2s}.back-to-login a:hover{color:#2563eb;text-decoration:underline}@media (max-width:480px){.reset-password-container{padding:2rem 1.5rem}.reset-password-container h1{font-size:1.5rem}}.stack-info-page{background:#1e1e1e;color:#f5f5f5;min-height:100dvh;padding:1.875rem}.stack-info-card{background:#2a2a2a;border:1px solid #ffffff08;border-radius:var(--radius-xl);box-shadow:0 4px 25px #00000055;display:flex;flex-direction:column;gap:1.375rem;margin:0 auto;max-width:90%;padding:1.5rem 1.75rem}.stack-info-header,.stack-info-left{display:flex;flex-direction:column;gap:.625rem}.stack-info-title{align-items:center;display:flex;gap:1rem;justify-content:space-between}.stack-info-name{font-size:1.625rem;font-weight:800;letter-spacing:.02em;margin:0}.stack-info-right-top{display:flex;gap:1rem}.stack-info-type-badge{border-radius:var(--radius-full);color:#fff;font-size:.8125rem;font-weight:600;padding:.375rem 1rem;white-space:nowrap}.stack-info-type-badge-fullstack{background:#2cbfa5}.stack-info-type-badge-backend{background:#7e28c7}.stack-info-type-badge-frontend{background:#ec3636}.stack-info-type-install{background:#3b82f6;border-radius:var(--radius-full);color:#fff;cursor:pointer;font-size:.8125rem;font-weight:600;padding:.375rem 1rem;transition:.25s;white-space:nowrap}.stack-info-type-install:hover{background:#2563eb;box-shadow:0 0 15px #3b82f640}.stack-info-delete-container{display:flex;justify-content:flex-end}.stack-info-delete-button{background:#dc2626;border:1px solid #b91c1c;border-radius:var(--radius-lg);color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1.25rem;transition:all .25s;white-space:nowrap}.stack-info-delete-button:hover{background:#b91c1c;box-shadow:0 0 15px #dc262640;transform:translateY(-1px)}.stack-info-author{color:#d1d5db;font-size:.875rem;margin:0}.stack-info-layout{grid-gap:1.75rem;display:grid;gap:1.75rem;grid-template-columns:16.25rem 1fr}.stack-info-packages-title{font-size:1.125rem;font-weight:600;margin:0}.stack-info-packages-list{display:flex;flex-direction:column;gap:.375rem;max-width:90%}.stack-info-package-btn .package-name{color:#f5f5f5;font-weight:500}.stack-info-package-btn .arrow{color:#9ca3af;font-size:1.125rem}.stack-info-package-btn{align-items:center;background:#2c2c2c;border:1px solid #3a3a3a;border-radius:var(--radius-md);color:#f5f5f5;cursor:pointer;display:flex;font-size:.9375rem;font-weight:500;justify-content:space-between;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease;width:100%}.stack-info-package-btn:hover{background:#353535;border-color:#4a4a4a;transform:translateX(2px)}.stack-info-right{background:linear-gradient(145deg,#333,#272727 45%,#1f1f1f);border:1px solid #3b82f644;border-radius:var(--radius-lg);box-shadow:0 10px 26px #00000080;color:#e5e7eb;line-height:1.6;max-height:calc(100vh - 11.25rem);overflow-y:auto;padding:1.125rem 1.25rem}.stack-info-description,.stack-info-no-packages{color:#9ca3af;font-size:.875rem;margin:0}.stack-info-package-verified{align-items:center;color:#22c55e;display:inline-flex;font-size:.75rem;gap:.25rem}.stack-info-package-verified-icon{font-size:.75rem}.stack-info-package-left{align-items:center;display:flex;gap:.5rem}@media (max-width:48rem){.stack-info-page{padding:1rem}.stack-info-card{max-width:100%;padding:1rem}.stack-info-layout{gap:1.25rem;grid-template-columns:1fr}.stack-info-title{align-items:flex-start;flex-direction:column;gap:.75rem}.stack-info-name{font-size:1.25rem}.stack-info-right-top{flex-wrap:wrap}.stack-info-packages-list{max-width:100%}.stack-info-right{max-height:none}}.protocol-modal-content{align-items:center;color:#f5f5f5;display:flex;flex-direction:column;gap:16px;text-align:center}.protocol-modal-title{color:#f5f5f5;font-size:22px;font-weight:700;margin:0}.protocol-modal-text{color:#d1d5db;font-size:14px;line-height:1.5;margin:0}.protocol-modal-spinner{animation:spin .8s linear infinite;border:4px solid #3a3a3a;border-radius:50%;border-top-color:#2cbfa5;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.protocol-modal-error-icon{font-size:48px;line-height:1}.protocol-modal-actions{display:flex;flex-direction:column;gap:10px;margin-top:8px;width:100%}.protocol-modal-download-btn{background:#2cbfa5;border:none;border-radius:10px;color:#041410;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:.2s ease;width:100%}.protocol-modal-download-btn:hover{background:#37d6a0;transform:translateY(-1px)}.protocol-modal-download-btn:active{transform:translateY(0)}.protocol-modal-close-btn{background:#0000;border:1px solid #3a3a3a;border-radius:10px;color:#d1d5db;cursor:pointer;font-size:14px;padding:10px 20px;transition:.2s ease;width:100%}.protocol-modal-close-btn:hover{border-color:#2cbfa5;color:#f5f5f5}.protocol-modal-close-btn:active{transform:scale(.98)}.twofactor-verify{align-items:center;background:#1e1e1e;display:flex;justify-content:center;min-height:100vh;padding:1rem}.twofactor-verify-card{background:#2a2a2a;border-radius:16px;box-shadow:0 4px 12px #0000004d;max-width:420px;padding:2.5rem;width:100%}.twofactor-verify-img{cursor:pointer;display:block;margin:0 auto 1.5rem;max-width:120px}.twofactor-verify-title{color:#f5f5f5;font-size:1.75rem;font-weight:600;margin:0 0 .5rem;text-align:center}.twofactor-verify-subtitle{color:#7c7c7c;font-size:.9rem;margin:0 0 1.5rem;text-align:center}.twofactor-verify-error{background-color:#ffebee;border-radius:8px;color:#d32f2f;font-size:.9rem;margin-bottom:1rem;padding:.75rem}.twofactor-verify-form{display:flex;flex-direction:column;gap:1rem}.twofactor-verify-field{display:flex;flex-direction:column;gap:.5rem}.twofactor-verify-field label{color:#f5f5f5;font-size:.9rem;font-weight:500}.twofactor-verify-field input{background:#1e1e1e;border:1px solid #3a3a3a;border-radius:8px;color:#f5f5f5;font-family:Courier New,monospace;font-size:1.25rem;font-weight:600;letter-spacing:.25rem;padding:13px;text-align:center;transition:all .2s}.twofactor-verify-field input::placeholder{color:#555;font-family:inherit;font-size:.9rem;font-weight:400;letter-spacing:normal}.twofactor-verify-field input:focus{border-color:#3b82f6;box-shadow:0 0 10px #3b82f625;outline:none}.twofactor-verify-field input:disabled{cursor:not-allowed;opacity:.6}.twofactor-verify-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:13px;transition:all .2s}.twofactor-verify-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.twofactor-verify-btn:disabled{cursor:not-allowed;opacity:.6}.twofactor-verify-links{margin-top:1rem;text-align:center}.twofactor-verify-toggle{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:.9rem;padding:.5rem;text-decoration:none;transition:color .2s}.twofactor-verify-toggle:hover:not(:disabled){color:#2563eb;text-decoration:underline}.twofactor-verify-toggle:disabled{cursor:not-allowed;opacity:.6}@media (max-width:480px){.twofactor-verify-card{padding:2rem 1.5rem}.twofactor-verify-title{font-size:1.5rem}}.error-boundary{align-items:center;background:linear-gradient(145deg,#1e1e1e,#242424);color:#f5f5f5;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.error-boundary-title{color:#fff;font-size:2rem;font-weight:600;margin-bottom:1rem}.error-boundary-message{color:#b0b0b0;font-size:1rem;margin-bottom:2rem;max-width:500px}.error-boundary-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.error-boundary-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.error-boundary-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.error-boundary-btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.error-boundary-btn-secondary{background:linear-gradient(135deg,#4b5563,#374151);color:#fff}.error-boundary-btn-secondary:hover{background:linear-gradient(135deg,#374151,#1f2937);box-shadow:0 4px 12px #4b556366;transform:translateY(-2px)}:root{--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:1rem;--radius-xl:1.125rem;--radius-full:999px}html{height:100%}body,html{background-color:#1e1e1e}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0;min-height:100%;overflow-x:hidden}#root{background-color:#1e1e1e;min-height:100dvh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.9f6bf9ca.css.map*/