*{box-sizing:border-box}:root{--primary-color: #A2BF38;--primary-hover: #8ba12f;--secondary-color: #518C8C;--secondary-hover: #3d7272;--text-color: #333;--text-light: #666;--border-color: #e5e5e5;--bg-light: #f5f5f5}body{margin:0;font-family:Calibri,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;color:var(--text-color);background:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button,input,select,textarea{font-family:inherit}.header{position:sticky;top:0;z-index:100;background:#9bb736;padding:1.5rem 3rem}.header-container{max-width:1600px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center}.nav{display:flex;gap:2rem;align-items:center;justify-self:start}.logo{display:flex;justify-content:center;align-items:center;text-decoration:none}.logo-image{display:block;max-height:110px;width:auto;object-fit:contain}.header-right{display:flex;align-items:center;gap:1rem;justify-self:end}.cart-button{display:inline-block;background:#fff;color:#9bb736;border:none;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;text-decoration:none}.cart-button:hover{background:#f0f0f0}.search-form{display:flex;gap:.5rem;align-items:center;margin-left:1rem}.search-input{padding:.45rem .6rem;border-radius:6px;border:1px solid rgba(0,0,0,.12);width:220px;max-width:40vw}.search-btn{background:#fff;color:#9bb736;border:none;padding:.45rem .8rem;font-weight:600;border-radius:6px;cursor:pointer}.search-btn:hover{background:#f0f0f0}.nav-link{color:#fff;text-decoration:none;font-size:1.15rem;font-weight:600;background:none;border:none;cursor:pointer;padding:.5rem .75rem}.nav-link:hover{color:#e0e0e0}.nav-dropdown{position:relative}.nav-dropdown-btn{font-family:inherit;font-size:inherit;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid rgba(255,255,255,.3);border-radius:4px;transition:all .2s}.nav-dropdown-btn:hover{background:#ffffff26;border-color:#ffffff80}.dropdown-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid #e5e5e5;min-width:200px;box-shadow:0 4px 12px #00000026;border-radius:8px;padding:.5rem 0}.dropdown-menu a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:#333;text-decoration:none;font-size:.9rem;transition:background .2s}.dropdown-menu a:hover{background:#f9f9f9}.hamburger{display:none;flex-direction:column;justify-content:space-between;width:26px;height:20px;background:none;border:none;cursor:pointer;padding:0}.hamburger span{display:block;width:100%;height:3px;background:#fff;border-radius:3px;transition:transform .3s,opacity .3s}.hamburger--open span:nth-child(1){transform:translateY(8.5px) rotate(45deg)}.hamburger--open span:nth-child(2){opacity:0}.hamburger--open span:nth-child(3){transform:translateY(-8.5px) rotate(-45deg)}.mobile-overlay{position:fixed;inset:0;background:#0006;z-index:149}.mobile-nav{display:none;position:fixed;top:0;left:0;width:75%;max-width:300px;height:100dvh;background:#9bb736;z-index:150;flex-direction:column;padding:5rem 1.5rem 2rem;gap:.5rem;transform:translate(-100%);transition:transform .3s ease}.mobile-nav--open{transform:translate(0)}.mobile-nav-link{color:#fff;text-decoration:none;font-size:1.1rem;font-weight:600;padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.2);background:none;border:none;cursor:pointer;text-align:left}.mobile-search-form{display:flex;gap:.5rem;margin-bottom:1rem}.mobile-search-input{flex:1;padding:.6rem;border-radius:4px;border:none;font-size:.95rem}.mobile-search-btn{padding:.6rem 1rem;background:#fff;color:#9bb736;border:none;border-radius:4px;font-weight:600;cursor:pointer}.mobile-cart-btn{margin-top:auto;background:#fff;color:#9bb736;border:none;padding:.75rem 1.2rem;font-size:1rem;font-weight:700;cursor:pointer;border-radius:6px}@media(max-width:768px){.header{padding:1rem}.logo-image{max-height:90px}.nav,.cart-button,.search-form{display:none}.hamburger,.mobile-nav{display:flex}}.footer{background:#f5f5f5;border-top:1px solid #e5e5e5;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:2rem;display:flex;justify-content:space-between;align-items:center}.footer-brand h3{color:#9bb736;margin:0 0 .5rem;letter-spacing:2px}.footer-brand p{color:#666;margin:0;font-size:.9rem}.footer-info p{color:#666;margin:.25rem 0;font-size:.85rem}.footer-bottom{border-top:1px solid #e5e5e5;padding:1rem 2rem;text-align:center}.footer-bottom p{margin:0;color:#999;font-size:.8rem}@media(max-width:768px){.footer-container{flex-direction:column;gap:1.5rem;text-align:center}}.cart-overlay{position:fixed;inset:0;background:#00000080;z-index:200}.cart-sidebar{position:fixed;top:0;right:0;bottom:0;width:400px;max-width:100%;background:#fff;z-index:201;display:flex;flex-direction:column;box-shadow:-2px 0 10px #0000001a}.cart-header{padding:1.5rem;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;align-items:center}.cart-header h2{margin:0;font-size:1.25rem;color:#333}.close-cart{background:none;border:none;font-size:2rem;cursor:pointer;color:#666;line-height:1}.cart-empty{flex:1;display:flex;align-items:center;justify-content:center;color:#999}.cart-items{flex:1;overflow-y:auto;padding:1rem}.cart-item{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid #f0f0f0;position:relative}.cart-item-image{width:80px;height:80px;object-fit:cover;background:#f5f5f5}.cart-item-details{flex:1}.cart-item-details h4{margin:0 0 .25rem;font-size:.95rem;color:#333}.cart-item-variant{margin:0 0 .5rem;font-size:.8rem;color:#666}.cart-item-price{margin:0 0 .5rem;font-weight:600;color:#9bb736}.cart-item-quantity{display:flex;align-items:center;gap:.5rem}.cart-item-quantity button{width:28px;height:28px;border:1px solid #ddd;background:#fff;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center}.cart-item-quantity button:hover{background:#f5f5f5}.cart-item-quantity span{min-width:30px;text-align:center}.remove-item{position:absolute;top:1rem;right:0;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;line-height:1}.remove-item:hover{color:#c00}.cart-footer{padding:1.5rem;border-top:1px solid #e5e5e5}.cart-total{display:flex;justify-content:space-between;font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:#333}.checkout-button{width:100%;background:#518c8c;color:#fff;border:none;padding:1rem;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:.5rem}.checkout-button:hover{background:#3d7272}.whatsapp-button{width:100%;background:#a2bf38;color:#fff;border:1px solid #A2BF38;padding:1rem;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:.5rem}.whatsapp-button:hover{background:#8ba12f;border-color:#8ba12f;color:#fff}.clear-cart{width:100%;background:none;border:1px solid #ddd;padding:.75rem;font-size:.9rem;cursor:pointer;color:#666}.clear-cart:hover{background:#f5f5f5}@media(max-width:480px){.cart-sidebar{width:100%}}.product-card{display:flex;flex-direction:column;background:#fff;border:1px solid #e5e5e5;transition:border-color .2s,box-shadow .2s,transform .2s;text-decoration:none;color:inherit}.product-card:hover{border-color:#9bb736;box-shadow:0 4px 12px #0000001f;transform:scale(1.02)}.product-image-wrapper{position:relative;aspect-ratio:1;overflow:hidden;background:#f5f5f5}.product-image{width:100%;height:100%;object-fit:cover}.product-out-of-stock{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:#fff;padding:.5rem 1rem;font-size:.85rem;font-weight:600}.product-click-hint{position:absolute;bottom:0;left:0;right:0;background:#518c8cd9;color:#fff;padding:.5rem;font-size:.9rem;font-weight:500;text-align:center}.product-info{padding:1rem;flex:1;display:flex;flex-direction:column}.product-name{margin:0 0 .5rem;font-size:1rem;color:#333;font-weight:500}.product-price{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:#9bb736}.product-actions{margin-top:auto;display:flex;flex-direction:column;gap:.5rem}.btn-add-cart{background:var(--secondary-color);color:#fff;border:none;padding:.75rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-add-cart:hover:not(:disabled){background:var(--secondary-hover)}.btn-add-cart:disabled{background:#ccc;cursor:not-allowed}.btn-add-cart.added{background:var(--secondary-hover)}.btn-whatsapp{background:var(--primary-color);color:#fff;border:1px solid var(--primary-color);padding:.75rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.homepage{min-height:100vh}.categories-section{max-width:1200px;margin:0 auto;padding:3rem 2rem}.categories-section h2{margin:0 0 1.5rem;font-size:1.5rem;color:#333}.categories-links{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center}.featured-section{max-width:1200px;margin:0 auto;padding:2rem 3rem 3rem}.featured-section h2{margin:0 0 2rem;font-size:1.5rem;color:#333}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:2rem}.loading,.error,.no-products{text-align:center;padding:3rem;color:#666}.error{color:#c00}@media(max-width:768px){.categories-section,.featured-section{padding:2rem 1rem}.products-grid{gap:1rem}}.product-list-page{min-height:100vh;padding:2rem 0}.product-list-page .container{max-width:1200px;margin:0 auto;padding:0 2rem}.product-list-page h1{margin:0 0 2rem;font-size:1.75rem;color:#333}.product-search-form{display:none;gap:.5rem;margin-bottom:1.5rem;justify-content:center}.product-search-input{padding:.6rem .8rem;border-radius:6px;border:1px solid #ddd;font-size:1rem;width:100%;max-width:300px}.product-search-btn{background:#a2bf38;color:#fff;border:none;padding:.6rem 1.2rem;font-size:1rem;font-weight:600;border-radius:6px;cursor:pointer;transition:background .2s}.product-search-btn:hover{background:#8ba12f}.categories-links{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center;margin-bottom:2rem}.categories-links a{display:inline-flex;align-items:center;justify-content:center;text-align:center;background:#f5f5f5;border:1px solid #e5e5e5;color:#333;text-decoration:none;font-size:1.15rem;font-weight:700;padding:.35rem .5rem;border-radius:4px;transition:all .2s;white-space:nowrap}.categories-links a:hover{background:#a2bf38;color:#fff;border-color:#a2bf38}.categories-links a.category-new,.categories-links a[href*=productos-nuevos],.categories-links a[href*=PRODUCTOS]{background:#a2bf38!important;color:#fff!important;border-color:#a2bf38!important}.categories-links a.category-new:hover,.categories-links a[href*=productos-nuevos]:hover,.categories-links a[href*=PRODUCTOS]:hover{background:#8ba12f!important;border-color:#8ba12f!important}.product-list-page .products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:2rem}.product-list-page .loading,.product-list-page .error{text-align:center;padding:3rem;color:#666}.product-list-page .error{color:#c00}.load-more-container{display:flex;justify-content:center;margin-top:2rem}.load-more-btn{background-color:var(--primary-color);color:#fff;border:none;padding:.875rem 2.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.load-more-btn:hover{background-color:var(--primary-hover)}.all-loaded{color:#666;font-size:1rem;padding:1rem}@media(max-width:768px){.product-search-form.mobile-only{display:flex}.product-list-page .container{padding:0 1rem}.product-list-page h1{font-size:1.5rem}.product-list-page .products-grid{gap:1rem}}.product-detail-page{min-height:100vh;padding:2rem 0}.product-detail-page .container{max-width:1200px;margin:0 auto;padding:0 2rem}.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:3rem}.product-images{display:flex;flex-direction:column;gap:1rem}.thumbnail-list{display:flex;gap:.5rem;flex-wrap:wrap}.thumbnail{width:80px;height:80px;border:2px solid #e5e5e5;padding:0;cursor:pointer;background:none}.main-image{aspect-ratio:1;background:#f5f5f5;overflow:hidden}.main-image img{width:100%;height:100%;object-fit:cover}.thumbnail.active{border-color:#9bb736}.thumbnail img{width:100%;height:100%;object-fit:cover}.product-info h1{margin:0 0 1rem;font-size:1.75rem;color:#333}.product-info .product-price{font-size:1.5rem;font-weight:700;color:#9bb736;margin:0 0 1.5rem}.product-actions-top{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.btn-action{width:100%;padding:1rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-cart{background:var(--secondary-color);color:#fff}.btn-cart:hover:not(:disabled){background:var(--secondary-hover)}.btn-cart:disabled{background:#ccc;cursor:not-allowed}.btn-cart.added{background:var(--secondary-hover)}.btn-whatsapp{background:var(--primary-color);color:#fff;border:2px solid var(--primary-color)}.btn-whatsapp:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:#fff}.btn-pay{background:#7a9974;color:#fff}.btn-pay:hover{background:#6a8874}.quantity-selector{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.quantity-selector label{font-weight:500;color:#333}.quantity-selector input{width:80px;padding:.5rem;border:1px solid #e5e5e5;font-size:1rem;text-align:center}.variant-selector{margin-bottom:1.5rem}.variant-selector label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.variant-selector select{width:100%;padding:.75rem;border:1px solid #e5e5e5;font-size:1rem;background:#fff;cursor:pointer}.variant-attributes{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.attribute{background:#f5f5f5;padding:.4rem .8rem;font-size:.85rem;color:#666}.product-description{margin-bottom:1.5rem}.product-description h3{font-size:1rem;margin:0 0 .5rem;color:#333}.product-description p{margin:0;color:#666;line-height:1.6}.stock-info{margin-bottom:1rem;font-size:.9rem;color:#666}.product-detail-page .loading,.product-detail-page .error{text-align:center;padding:3rem;color:#666}.product-detail-page .error{color:#c00}@media(max-width:768px){.product-detail-page .container{padding:0 1rem}.product-detail{grid-template-columns:1fr;gap:2rem}.product-info h1{font-size:1.5rem}}.checkout-page{min-height:100vh;padding:2rem 0}.checkout-page .container{max-width:1000px;margin:0 auto;padding:0 2rem}.checkout-page h1{margin:0 0 2rem;font-size:1.75rem;color:#333}.checkout-layout{display:grid;grid-template-columns:1fr 350px;gap:3rem}.checkout-form-section h2,.order-summary h2{margin:0 0 1rem;font-size:1.25rem;color:#333}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #eee}.form-section:last-of-type{border-bottom:none}.form-group{display:flex;flex-direction:column;margin-bottom:1rem}.form-group label{margin-bottom:.5rem;font-weight:500;color:#333;font-size:.95rem}.form-group input,.form-group textarea,.form-group select{padding:.75rem;border:1px solid #e5e5e5;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#9bb736}.form-group textarea{resize:vertical}.checkbox-group{flex-direction:row;align-items:center;gap:.5rem}.checkbox-group input{width:auto;margin:0}.checkbox-group label{margin-bottom:0;font-weight:400}.shipping-options{display:flex;flex-direction:column;gap:.75rem}.shipping-option{display:flex;align-items:center;padding:1rem;border:1px solid #e5e5e5;border-radius:4px;cursor:pointer;transition:all .2s}.shipping-option:hover{border-color:#9bb736}.shipping-option.selected{border-color:#9bb736;background:#f9fbe6}.shipping-option input{margin-right:1rem;width:auto}.shipping-label{display:flex;justify-content:space-between;width:100%;align-items:center}.shipping-name{font-weight:500;color:#333}.shipping-price{font-weight:600;color:#9bb736}.privacy-notice{margin:1rem 0;font-size:.85rem;color:#666;line-height:1.5}.order-totals{padding:1rem 0;border-top:1px solid #e5e5e5;margin-top:1rem}.order-line{display:flex;justify-content:space-between;padding:.5rem 0;color:#666}.order-line.total{font-size:1.2rem;font-weight:700;color:#333;border-top:2px solid #e5e5e5;margin-top:.5rem;padding-top:1rem}.payment-info{margin-top:1.5rem;padding:1rem;background:#fff;border:1px solid #e5e5e5;border-radius:4px}.payment-info p{margin:0 0 .5rem;font-size:.9rem;color:#666}.payment-title{font-weight:600;color:#333!important;margin-bottom:.75rem!important}.payment-method{color:#9bb736!important;font-weight:600}.back-to-cart{display:block;text-align:center;margin-top:1rem;color:#666;text-decoration:none;font-size:.9rem}.back-to-cart:hover{color:#9bb736;text-decoration:underline}.submit-btn{background:#9bb736;color:#fff;border:none;padding:1rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;margin-top:1rem;transition:background .2s}.submit-btn:hover{background:#8aa52f}.order-summary{background:#f9f9f9;padding:1.5rem;border:1px solid #e5e5e5;height:fit-content}.order-items{margin-bottom:1rem;max-height:300px;overflow-y:auto}.order-item{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid #eee;align-items:flex-start}.order-item:last-child{border-bottom:none}.order-item-image{width:60px;height:60px;object-fit:cover;border-radius:4px;background:#f5f5f5}.order-item-info{flex:1}.order-item-info h4{margin:0 0 .25rem;font-size:.9rem;color:#333;font-weight:500}.order-item-variant{margin:0 0 .5rem;font-size:.75rem;color:#666}.order-item-quantity{display:flex;align-items:center;gap:.5rem}.order-item-quantity button{width:24px;height:24px;border:1px solid #ddd;background:#fff;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;border-radius:4px}.order-item-quantity button:hover{background:#f5f5f5;border-color:#9bb736}.order-item-quantity span{min-width:20px;text-align:center;font-size:.85rem;font-weight:500}.order-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.order-item-price{font-weight:600;color:#9bb736;font-size:.95rem}.order-item-remove{background:none;border:none;font-size:1.25rem;cursor:pointer;color:#999;line-height:1;padding:0}.order-item-remove:hover{color:#c00}.order-total{display:flex;justify-content:space-between;font-size:1.2rem;font-weight:700;color:#333;padding-top:1rem;border-top:2px solid #e5e5e5}.empty-cart,.order-success{text-align:center;padding:4rem 2rem}.empty-cart p,.order-success p{color:#666;margin-bottom:1.5rem}.empty-cart button,.order-success button{background:#9bb736;color:#fff;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:600;cursor:pointer}.order-success h1{color:#4caf50}@media(max-width:768px){.checkout-page .container{padding:0 1rem}.checkout-layout{grid-template-columns:1fr;gap:2rem}.order-summary{order:-1}}.cart-page{padding:2rem 0;min-height:calc(100vh - 200px)}.cart-page .container{max-width:1200px;margin:0 auto;padding:0 1rem}.cart-page h1{margin-bottom:2rem;font-size:1.75rem}.cart-layout{display:grid;grid-template-columns:1fr 350px;gap:2rem}@media(max-width:768px){.cart-layout{grid-template-columns:1fr}}.cart-items-list{display:flex;flex-direction:column;gap:1rem}.cart-item-card{display:flex;gap:1rem;padding:1rem;background:#fff;border:1px solid #e5e5e5;border-radius:8px}.cart-item-card-image{width:120px;height:120px;object-fit:cover;border-radius:4px}.cart-item-card-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.cart-item-card-title{font-weight:600;color:#333;text-decoration:none}.cart-item-card-title:hover{color:#007bff}.cart-item-card-variant{color:#666;font-size:.875rem}.cart-item-card-price{font-weight:500;margin-top:auto}.cart-item-card-quantity{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.cart-item-card-quantity button{width:28px;height:28px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:1rem}.cart-item-card-quantity button:hover{background:#f5f5f5}.cart-item-card-quantity span{min-width:24px;text-align:center}.cart-item-card-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between}.cart-item-card-total{font-weight:600;font-size:1.125rem}.cart-item-card-remove{width:28px;height:28px;border:none;background:transparent;color:#999;font-size:1.5rem;cursor:pointer;line-height:1}.cart-item-card-remove:hover{color:#dc3545}.clear-cart-btn{margin-top:1rem;padding:.5rem 1rem;border:1px solid #dc3545;background:transparent;color:#dc3545;border-radius:4px;cursor:pointer}.clear-cart-btn:hover{background:#dc3545;color:#fff}.cart-summary{background:#f9f9f9;padding:1.5rem;border-radius:8px;height:fit-content}.cart-summary h2{font-size:1.25rem;margin-bottom:1rem}.cart-totals{margin-bottom:1.5rem}.cart-line{display:flex;justify-content:space-between;padding:.5rem 0}.cart-line.total{font-weight:700;font-size:1.25rem;border-top:1px solid #ddd;padding-top:.75rem;margin-top:.5rem}.cart-actions{display:flex;flex-direction:column;gap:.75rem}.checkout-btn,.whatsapp-btn{width:100%;padding:.875rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.checkout-btn{background:var(--secondary-color);color:#fff}.checkout-btn:hover{background:var(--secondary-hover)}.whatsapp-btn{background:var(--primary-color);color:#fff}.whatsapp-btn:hover{background:var(--primary-hover)}.empty-cart{text-align:center;padding:4rem 2rem}.empty-cart p{font-size:1.25rem;color:#666;margin-bottom:1.5rem}.empty-cart button{padding:.75rem 2rem;background:#333;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem}.empty-cart button:hover{background:#555}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1}
