body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.min-h-screen{background-color:#f9fafb;min-height:100vh}.container{max-width:80rem}.text-center{text-align:center}.hero-section{background:linear-gradient(90deg,#2563eb,#1e40af);color:#fff;padding:4rem 0}.hero-title{font-size:3rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem}.hero-subtitle{color:#bfdbfe}.hero-description{color:#e0e7ff;font-size:1.25rem;margin:0 auto 2rem;max-width:48rem}.gun-selector{background:#fff;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;margin:0 auto;max-width:64rem;padding:1.5rem}.form-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.form-label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.select-wrapper{position:relative}.form-select{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#111827;font-size:1rem;padding:.75rem;width:100%}.form-select:focus{ring:2px;ring-color:#3b82f6;border-color:#3b82f6;outline:none}.form-select-disabled{background-color:#f3f4f6}.select-icon{color:#9ca3af;height:1.25rem;pointer-events:none;position:absolute;right:.75rem;top:.75rem;width:1.25rem}.btn-primary{align-items:center;background:#2563eb;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:inline-flex;font-weight:600;justify-content:center;padding:.75rem 1.5rem;text-decoration:none;transition:background-color .2s}.btn-primary:hover{background:#1d4ed8}.btn-search{gap:.5rem;padding:.75rem 1.5rem;width:100%}.btn-small{font-size:.875rem;padding:.5rem 1rem}.btn-icon{height:1.25rem;width:1.25rem}.features-section{background:#fff;padding:4rem 0}.section-header{margin-bottom:3rem;text-align:center}.section-title{color:#111827;font-size:1.875rem;font-weight:700;margin-bottom:1rem}.section-subtitle{color:#4b5563;font-size:1.125rem}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.feature-card{padding:1.5rem;text-align:center}.feature-icon{align-items:center;border-radius:50%;display:flex;height:4rem;justify-content:center;margin:0 auto 1rem;width:4rem}.feature-icon-blue{background:#dbeafe}.feature-icon-green{background:#dcfce7}.feature-icon-purple{background:#f3e8ff}.feature-icon .icon{height:2rem;width:2rem}.feature-icon-blue .icon{color:#2563eb}.feature-icon-green .icon{color:#16a34a}.feature-icon-purple .icon{color:#9333ea}.feature-title{color:#111827;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.feature-description{color:#4b5563;line-height:1.6}.categories-section{background:#f9fafb;padding:4rem 0}.categories-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.category-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;padding:1.5rem;text-align:center;transition:box-shadow .2s}.category-card:hover{box-shadow:0 10px 15px -3px #0000001a}.category-icon{font-size:3rem;margin-bottom:.75rem}.category-name{color:#111827;font-size:1rem;font-weight:600;margin-bottom:.25rem}.category-count{color:#4b5563;font-size:.875rem}.featured-section{background:#fff;padding:4rem 0}.parts-grid{grid-gap:2rem;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.part-card{border:1px solid #e5e7eb;border-radius:.5rem;transition:box-shadow .2s}.part-card:hover{box-shadow:0 10px 15px -3px #0000001a}.part-content{padding:1.5rem}.part-image{font-size:4rem;margin-bottom:1rem;text-align:center}.part-rating{margin-bottom:.75rem}.part-rating,.stars{align-items:center;display:flex}.star{height:1rem;width:1rem}.star-filled{fill:currentColor;color:#fbbf24}.star-empty{fill:none;color:#d1d5db}.rating-text{color:#4b5563;font-size:.875rem;margin-left:.5rem}.part-footer{align-items:center;display:flex;justify-content:space-between}.part-price{color:#16a34a;font-size:2rem}.footer{background:#111827;color:#fff;padding:3rem 0}.footer-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.footer-logo{align-items:center;display:flex;gap:.5rem;margin-bottom:1rem}.logo-icon{color:#60a5fa}.logo-text{margin:0}.brand-description{color:#9ca3af;line-height:1.6;margin:0}.footer-heading{color:#fff;font-size:1rem;font-weight:600;margin-bottom:1rem}.link-list{list-style:none;margin:0;padding:0}.link-list li{margin-bottom:.5rem}.footer-link{color:#9ca3af;text-decoration:none;transition:color .2s}.footer-link:hover{color:#fff}.footer-bottom{border-top:1px solid #374151;margin-top:2rem;padding-top:2rem;text-align:center}.copyright{color:#9ca3af;margin:0}@media (max-width:768px){.hero-title{font-size:2rem}.hero-description{font-size:1rem}.features-grid,.form-grid{grid-template-columns:1fr}.categories-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.footer-grid,.parts-grid{grid-template-columns:1fr}.footer-grid{text-align:center}.container{padding:0 .5rem}.categories-section,.featured-section,.features-section,.hero-section{padding:2rem 0}}.validation-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem;font-weight:500;margin-bottom:1rem;padding:.75rem 1rem;text-align:center}@media (max-width:480px){.gun-selector{padding:1rem}.hero-title{font-size:1.75rem}.part-price,.section-title{font-size:1.5rem}}.header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-bottom:1px solid #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:100}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.header-content{height:4rem;justify-content:space-between;position:relative}.header-content,.logo{align-items:center;display:flex}.logo{color:#1a202c;font-size:1.25rem;font-weight:700;gap:.5rem;text-decoration:none}.logo-icon{height:2rem;width:2rem}.logo-text{color:#1a202c;font-size:1.25rem;font-weight:700}.desktop-nav{align-items:center;display:flex;gap:2rem}.nav-link{color:#4a5568;font-weight:500;position:relative;text-decoration:none;transition:color .2s}.nav-link:hover{color:#667eea}.nav-link:after{background:#667eea;bottom:-.5rem;content:"";height:2px;left:0;position:absolute;transition:width .2s;width:0}.nav-link:hover:after{width:100%}.auth-buttons,.auth-section{align-items:center;display:flex;gap:.75rem}.login-btn{align-items:center;background:#0000;border:2px solid #4f46e5;border-radius:.5rem;color:#4f46e5;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;overflow:hidden;padding:.625rem 1.25rem;position:relative;text-decoration:none;transition:all .2s ease}.login-btn:hover{background:#4f46e5;box-shadow:0 4px 12px #4f46e54d;color:#fff;transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.signup-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;box-shadow:0 2px 4px #667eea33;color:#fff;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;overflow:hidden;padding:.625rem 1.25rem;position:relative;text-decoration:none;transition:all .2s ease}.signup-btn:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);box-shadow:0 6px 20px #667eea66;transform:translateY(-1px)}.signup-btn:active{transform:translateY(0)}.btn-icon{transition:transform .2s ease}.login-btn:hover .btn-icon,.signup-btn:hover .btn-icon{transform:translateX(2px)}.login-btn:focus,.signup-btn:focus{box-shadow:0 0 0 3px #4f46e533;outline:none}.user-menu-container{position:relative}.user-menu-trigger{align-items:center;background:none;border:none;border-radius:.5rem;cursor:pointer;display:flex;gap:.5rem;padding:.5rem;transition:background-color .2s}.user-menu-trigger:hover{background-color:#f7fafc}.user-icon{color:#4a5568;height:1.25rem;width:1.25rem}.user-name{color:#2d3748;font-weight:500}.admin-badge{background:#667eea;border-radius:9999px;color:#fff;font-size:.75rem;font-weight:500;padding:.125rem .375rem}.user-menu{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 10px 25px #0000001a;margin-top:.25rem;min-width:160px;position:absolute;right:0;top:100%;z-index:200}.user-menu-item{align-items:center;background:none;border:none;color:#4a5568;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.75rem 1rem;text-decoration:none;transition:background-color .2s;width:100%}.user-menu-item:hover{background-color:#f7fafc}.user-menu-item:first-child{border-radius:.5rem .5rem 0 0}.user-menu-item:last-child{border-radius:0 0 .5rem .5rem}.menu-item-icon{height:1rem;width:1rem}.logout-btn{color:#e53e3e}.logout-btn:hover{background-color:#fed7d7}.mobile-menu-btn{background:none;border:none;cursor:pointer;display:none;padding:.5rem}.mobile-nav{background:#fff;border-top:1px solid #e2e8f0;display:none;flex-direction:column;padding:1rem 0}.mobile-nav-link{color:#4a5568;font-weight:500;padding:.75rem 0;text-decoration:none;transition:color .2s}.mobile-nav-link:hover{color:#667eea}.logout-mobile{background:none;border:none;color:#e53e3e;cursor:pointer;font-size:1rem;padding:.75rem 0;text-align:left}.loading-container{align-items:center;display:flex;justify-content:center;min-height:50vh}.loading-spinner{text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto 1rem;width:40px}.loading-spinner p{color:#4a5568;font-weight:500}@media (max-width:768px){.desktop-nav{display:none}.mobile-menu-btn{display:block}.mobile-nav{display:flex}.auth-section,.user-name{display:none}.admin-badge{font-size:.625rem;padding:.125rem .25rem}}.tab-nav{align-items:center;border-bottom:2px solid #e2e8f0;flex-wrap:wrap;gap:1rem}.tab-btn{background:none;border-bottom:2px solid #0000;color:#4a5568;font-weight:500;padding:.75rem 1.5rem;transition:all .2s;white-space:nowrap}.tab-btn:hover{color:#667eea}.tab-btn.active{border-bottom-color:#667eea;color:#667eea}.btn-cancel{align-items:center;background:#f56565;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-left:auto;padding:.5rem 1rem;transition:all .2s}.btn-cancel:hover{background:#e53e3e;transform:translateY(-1px)}.btn-cancel .btn-icon{height:1rem;width:1rem}.form-section h2{color:#2d3748;font-size:1.5rem}.submit-btn{background:#667eea;border-radius:.375rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s}.submit-btn:hover:not(:disabled){background:#5a67d8;transform:translateY(-1px)}.btn-delete,.btn-edit{border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.btn-edit{background:#38a169}.btn-edit:hover{background:#2f855a;transform:translateY(-1px)}.btn-delete{background:#e53e3e}.btn-delete:hover{background:#c53030;transform:translateY(-1px)}.item-row{border:1px solid #e2e8f0;border-radius:.5rem;margin-bottom:1rem}.item-info h4{color:#2d3748}.item-info p{color:#718096}@media (max-width:768px){.tab-nav{align-items:stretch;flex-direction:column}.btn-cancel{margin-left:0;margin-top:1rem}.item-row{align-items:stretch;flex-direction:column;gap:1rem}.item-actions{justify-content:center}}.manage-section{margin-bottom:3rem}.manage-section h2{border-bottom:2px solid #e1e5e9;color:#333;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem}.items-list{display:flex;flex-direction:column;gap:1rem}.item-row{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;padding:1rem;transition:box-shadow .2s}.item-row:hover{box-shadow:0 2px 8px #0000001a}.item-info h4{color:#111827;font-size:1.125rem;margin:0 0 .25rem}.item-info p{color:#6b7280;font-size:.875rem;margin:0}.item-actions{display:flex;gap:.5rem}.btn-edit{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.btn-edit:hover{background:#2563eb}.btn-delete{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.btn-delete:hover{background:#dc2626}.form-section h2{margin-bottom:1rem}@media (max-width:768px){.item-row{align-items:stretch;flex-direction:column;gap:1rem}.item-actions{justify-content:center}}.admin-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1200px;padding:2rem}.admin-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin-bottom:3rem;padding:2rem;text-align:center}.admin-header h1{font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.admin-header p{font-size:1.2rem;margin:0;opacity:.9}.tab-nav{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;display:flex;gap:.5rem;margin-bottom:2rem;padding:.5rem}.tab-btn{background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:1rem 1.5rem;transition:all .3s ease}.tab-btn:hover{background:#f8f9fa;color:#333}.tab-btn.active{background:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff}.tab-content{background:#fff;border-radius:12px;box-shadow:0 2px 20px #0000001a;padding:2rem}.form-section h2{color:#333;font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.admin-form{max-width:800px}.form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:1.5rem}.form-group label{color:#333;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;padding:.75rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{font-family:inherit;min-height:100px;resize:vertical}.form-group select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;cursor:pointer;padding-right:2.5rem}.checkbox-group{margin:1.5rem 0}.checkbox-label{align-items:center;color:#333;cursor:pointer;display:flex;font-weight:500;gap:.5rem}.checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.submit-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 10px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:1rem 2rem;transition:all .3s ease}.submit-btn:hover:not(:disabled){box-shadow:0 4px 20px #667eea66;transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-icon{height:18px;width:18px}.success-message{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46;margin-bottom:1rem;padding:1rem}.error-message{background:#fee2e2;color:#991b1b;margin-bottom:1rem;padding:1rem}@media (max-width:768px){.admin-container{padding:1rem}.admin-header{padding:1.5rem}.admin-header h1{font-size:2rem}.tab-nav{flex-direction:column}.tab-btn{text-align:center}.form-grid{gap:1rem;grid-template-columns:1fr}.tab-content{padding:1.5rem}.image-upload-container{position:relative}.file-input{background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;cursor:pointer;padding:.75rem;transition:all .3s ease;width:100%}.file-input:hover{background:#f0f4ff;border-color:#667eea}.image-preview{display:inline-block;margin-top:1rem;position:relative}.image-preview img{border:2px solid #e5e7eb;border-radius:8px;max-height:200px;max-width:200px;object-fit:cover}.remove-image-btn{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:24px;justify-content:center;line-height:1;position:absolute;right:-10px;top:-10px;width:24px}.remove-image-btn:hover{background:#dc2626}}.auth-container{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;justify-content:center;min-height:100vh;padding:1rem}.auth-background{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 20px 40px #0000001a;max-width:420px;padding:2px;width:100%}.auth-card{background:#fff;border-radius:10px;padding:2rem}.auth-header{margin-bottom:2rem;text-align:center}.auth-logo{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.logo-icon{color:#667eea;height:32px;width:32px}.auth-logo h1{color:#1a202c;font-size:1.75rem;font-weight:700;margin:0}.auth-header h2{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.auth-header p{color:#718096;font-size:.875rem;margin:0}.auth-form{gap:1.5rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#374151;font-size:.875rem;font-weight:500}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#9ca3af;height:18px;left:12px;position:absolute;width:18px;z-index:1}.input-wrapper input{border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-size:.875rem;padding:12px 12px 12px 40px;transition:all .2s;width:100%}.input-wrapper input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.input-wrapper input:disabled{background-color:#f9fafb;cursor:not-allowed}.password-toggle{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:0;position:absolute;right:12px;transition:color .2s}.password-toggle:hover:not(:disabled){color:#667eea}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem;padding:12px;text-align:center}.field-error{color:#dc2626;font-size:.75rem;margin-top:.25rem}.auth-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.5rem;padding:12px 24px;transition:all .2s}.auth-button:hover:not(:disabled){box-shadow:0 10px 20px #667eea4d;transform:translateY(-1px)}.auth-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-icon{height:1rem;width:1rem}.auth-footer{margin-top:2rem;text-align:center}.auth-footer p{color:#4a5568;font-size:.875rem;margin-bottom:1rem}.auth-link{color:#667eea;font-weight:500;text-decoration:none;transition:color .2s}.auth-link:hover{color:#5a67d8;text-decoration:underline}.back-home-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:.875rem;padding:.5rem;text-decoration:none;transition:color .2s}.back-home-button:hover{color:#5a67d8;text-decoration:underline}.success-message{background-color:#f0fff4;border:1px solid #9ae6b4;border-radius:8px;color:#22543d;font-size:.875rem;padding:12px;text-align:center}@media (max-width:480px){.auth-container{padding:.5rem}.auth-card{padding:1.5rem}.auth-header h2{font-size:1.25rem}.auth-logo h1{font-size:1.5rem}}.auth-loading{animation:spin 1s ease-in-out infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;display:inline-block;height:16px;width:16px}.gun-details-container{background:#f8fafc;min-height:100vh}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:50vh;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:40px;margin-bottom:1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-container h2{color:#dc2626;margin-bottom:1rem}.breadcrumb{background:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 0}.back-btn{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;transition:color .2s}.back-btn:hover{color:#3b82f6}.back-icon{height:1rem;width:1rem}.gun-info-section{background:#fff;border-bottom:1px solid #e5e7eb;padding:3rem 0}.gun-info-grid{grid-gap:3rem;align-items:center;display:grid;gap:3rem;grid-template-columns:1fr 2fr}.gun-image-container{display:flex;justify-content:center}.gun-image{border-radius:12px;box-shadow:0 4px 12px #0000001a;height:auto;max-width:400px;width:100%}.gun-image-placeholder{align-items:center;background:#f3f4f6;border:2px dashed #d1d5db;border-radius:12px;color:#6b7280;display:flex;font-size:1.125rem;height:300px;justify-content:center;max-width:400px;width:100%}.gun-title{color:#111827;font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:2rem}.gun-specs{grid-gap:1rem;display:grid;gap:1rem}.spec-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:1rem 0}.spec-label{color:#374151;font-weight:600}.spec-value{color:#6b7280;font-weight:500}.compatible-parts-section{padding:3rem 0}.parts-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.parts-header h2{color:#111827;font-size:2rem;font-weight:700;margin:0}.parts-controls{align-items:center;display:flex;gap:1rem}.filter-controls{align-items:center;display:flex;gap:.5rem}.filter-icon{color:#6b7280;height:1.25rem;width:1.25rem}.category-filter{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;padding:.5rem 1rem}.view-controls{background:#f3f4f6;border-radius:6px;display:flex;padding:.25rem}.view-btn{background:none;border:none;border-radius:4px;cursor:pointer;padding:.5rem;transition:all .2s}.view-btn.active{background:#fff;box-shadow:0 1px 2px #0000001a}.view-icon{color:#6b7280;height:1.25rem;width:1.25rem}.view-btn.active .view-icon{color:#3b82f6}.no-parts-message{background:#fff;border-radius:12px;color:#6b7280;font-size:1.125rem;padding:3rem;text-align:center}.parts-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.part-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:transform .2s,box-shadow .2s}.part-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.part-image{align-items:center;background:#f8fafc;display:flex;height:150px;justify-content:center;overflow:hidden;width:100%}.part-img{height:100%;object-fit:cover;width:100%}.part-placeholder{color:#9ca3af;font-size:2rem}.part-info{padding:1.5rem}.part-name{color:#111827;font-size:1.125rem;font-weight:600;line-height:1.4;margin-bottom:.5rem}.part-manufacturer{color:#6b7280;font-size:.875rem;margin-bottom:.25rem}.part-category{color:#9ca3af;font-size:.75rem;font-weight:500;margin-bottom:1rem;text-transform:uppercase}.part-meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.part-price{color:#059669;font-size:1.25rem;font-weight:700}.verification-badge{border-radius:4px;font-size:.75rem;font-weight:500;padding:.25rem .5rem;text-transform:uppercase}.verification-badge.verified{background:#d1fae5;color:#065f46}.verification-badge.unverified{background:#fef3c7;color:#92400e}.parts-list{display:flex;flex-direction:column;gap:2rem}.category-group{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.category-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#374151;font-size:1.25rem;font-weight:600;margin:0;padding:1rem 1.5rem}.category-parts{display:flex;flex-direction:column}.part-list-item{grid-gap:1rem;align-items:center;border-bottom:1px solid #f3f4f6;display:grid;gap:1rem;grid-template-columns:80px 1fr auto auto;padding:1.5rem}.part-list-item:last-child{border-bottom:none}.part-list-image{align-items:center;background:#f8fafc;border-radius:8px;display:flex;height:80px;justify-content:center;overflow:hidden;width:80px}.part-list-img{height:100%;object-fit:cover;width:100%}.part-list-placeholder{color:#9ca3af;font-size:1.5rem}.part-list-info{flex:1 1}.part-list-name{color:#111827;font-size:1.125rem;font-weight:600;margin:0 0 .25rem}.part-list-manufacturer{color:#6b7280;font-size:.875rem;margin:0 0 .5rem}.part-list-description{color:#9ca3af;font-size:.875rem;line-height:1.4;margin:0}.part-list-meta{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem}.part-list-price{color:#059669;font-size:1.125rem;font-weight:700}@media (max-width:1024px){.gun-info-grid{gap:2rem;grid-template-columns:1fr;text-align:center}.parts-header{align-items:stretch;flex-direction:column}.parts-controls{justify-content:space-between}}@media (max-width:768px){.gun-title{font-size:2rem}.parts-grid{grid-template-columns:1fr}.part-list-item{gap:1rem;grid-template-columns:60px 1fr}.part-list-actions,.part-list-meta{grid-column:span 2;justify-self:stretch}.part-list-meta{align-items:center;flex-direction:row;justify-content:space-between;margin-top:1rem}.filter-controls{flex:1 1}.category-filter{width:100%}}@media (max-width:480px){.gun-details-container{padding:0}.compatible-parts-section,.gun-info-section{padding:2rem 0}.container{padding:0 1rem}.gun-title{font-size:1.75rem}.parts-controls{flex-direction:column;gap:1rem}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.09f5112c.css.map*/