.product-image-wrapper{width:100%;height:100%;position:relative}.product-image-loading-skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;animation:1.25s infinite product-image-shimmer;position:absolute;inset:0}.product-image-placeholder{border-radius:inherit;background:linear-gradient(135deg,#f5f5f5 0%,#e8e8e8 100%);flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.product-image-placeholder:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;animation:2s infinite shimmer;position:absolute;top:0;left:-100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.product-image-placeholder svg{opacity:.4;transition:opacity .3s}.product-image-placeholder:hover svg{opacity:.6}.product-image-placeholder span{color:#999;letter-spacing:.5px;text-transform:uppercase;z-index:1;font-size:12px;font-weight:500;position:absolute;bottom:20px}.product-image-container .product-image-placeholder{position:absolute;inset:0}.product-image{object-fit:cover;z-index:1;width:100%;height:100%;display:block;position:relative}@keyframes product-image-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}
.product-card{cursor:pointer;background:#fff;border-radius:10px;flex-direction:column;height:100%;transition:transform .3s,box-shadow .3s;display:flex;overflow:hidden;box-shadow:0 4px 12px #0000000d}.product-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000001a}.product-card:focus{outline-offset:2px;outline:2px solid #353493}.product-image-container{aspect-ratio:4/3;background:#f5f5f5;width:100%;position:relative;overflow:hidden}.product-image{transition:transform .3s}.product-card:hover .product-image{transform:scale(1.05)}.product-image-skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;width:100%;height:100%;animation:1.5s infinite shimmer;position:absolute;top:0;left:0}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.product-category-badge{color:#fff;text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#8a5cf6e6;border-radius:20px;padding:2px 7px;font-size:.65rem;font-weight:600;position:absolute;top:10px;left:10px}.product-stock-badge{color:#333;text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffc107e6;border-radius:20px;padding:2px 7px;font-size:.65rem;font-weight:600;position:absolute;top:10px;right:10px}.product-stock-badge.out-of-stock{color:#fff;background:#f44336e6}.product-content{flex-direction:column;flex:1;gap:6px;padding:clamp(.65rem,2.2vw,.9rem);display:flex}.product-name{color:#333;-webkit-line-clamp:2;line-clamp:2;text-overflow:ellipsis;-webkit-box-orient:vertical;min-height:2.4em;margin:0;font-size:clamp(.92rem,2.4vw,1.02rem);font-weight:700;line-height:1.25;display:-webkit-box;overflow:hidden}.product-description{color:#666;-webkit-line-clamp:2;line-clamp:2;text-overflow:ellipsis;-webkit-box-orient:vertical;flex:1;margin:0;font-size:clamp(.8rem,2vw,.88rem);line-height:1.35;display:-webkit-box;overflow:hidden}.product-footer{border-top:1px solid #f0f0f0;justify-content:space-between;align-items:center;margin-top:auto;padding-top:6px;display:flex}.product-price{color:#8a5cf6;font-size:clamp(1.02rem,2.9vw,1.22rem);font-weight:700}@media (min-width:768px){.product-card{border-radius:10px}.product-category-badge,.product-stock-badge{padding:3px 9px;font-size:clamp(.65rem,1.5vw,.75rem)}}
.product-grid-container{width:100%;max-width:1120px;margin:0 auto;padding:.75rem}.product-grid{grid-template-columns:1fr;gap:.85rem;width:100%;display:grid}.product-card-skeleton{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000000d}.skeleton-image{aspect-ratio:4/3;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;width:100%;animation:1.5s infinite shimmer}.skeleton-content{flex-direction:column;gap:10px;padding:clamp(.7rem,2.2vw,.95rem);display:flex}.skeleton-line{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;border-radius:4px;height:16px;animation:1.5s infinite shimmer}.skeleton-title{width:80%;height:20px}.skeleton-description{width:100%}.skeleton-price{width:40%;height:24px;margin-top:8px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.product-grid-empty{text-align:center;color:#999;flex-direction:column;justify-content:center;align-items:center;padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,2rem);display:flex}.product-grid-empty svg{color:#ccc;margin-bottom:1.5rem}.product-grid-empty h3{color:#666;margin:0 0 .5rem;font-size:clamp(1.25rem,4vw,1.5rem);font-weight:600}.product-grid-empty p{color:#999;margin:0;font-size:clamp(.95rem,3vw,1.05rem)}@media (min-width:768px){.product-grid-container{padding:clamp(.65rem,2vw,1.2rem)}.product-grid{grid-template-columns:repeat(2,1fr);gap:clamp(.7rem,2vw,1.15rem)}}@media (min-width:1024px){.product-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}}
.productos-page{min-height:calc(100dvh - var(--navbar-height,clamp(60px,8vw,96px)));background:linear-gradient(#f8f9fa 0%,#fff 50%);overflow-x:clip}.productos-header{color:#fff;background:linear-gradient(135deg,#353493 0%,#5d3e90 100%);width:100%;margin-bottom:.75rem;padding:1rem;position:relative;overflow:hidden}.productos-header:before{content:"";opacity:.3;background:url("data:image/svg+xml,<svg width=\"100\" height=\"100\" xmlns=\"http://www.w3.org/2000/svg\"><defs><pattern id=\"grid\" width=\"20\" height=\"20\" patternUnits=\"userSpaceOnUse\"><path d=\"M 20 0 L 0 0 0 20\" fill=\"none\" stroke=\"rgba(255,255,255,0.05)\" stroke-width=\"1\"/></pattern></defs><rect width=\"100\" height=\"100\" fill=\"url(%23grid)\"/></svg>");position:absolute;inset:0}.productos-header-content{text-align:center;z-index:1;max-width:1080px;margin:0 auto;position:relative}.productos-title{text-shadow:0 2px 10px #0003;letter-spacing:-.02em;margin:0 0 .35rem;font-size:clamp(1.5rem,4vw,2.1rem);font-weight:800}.productos-subtitle{opacity:.95;max-width:520px;margin:0 auto;font-size:clamp(.88rem,2.2vw,1rem);font-weight:400}.productos-content{z-index:1;position:relative}.productos-search-skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;border-radius:10px;width:min(1120px,100% - 1.5rem);height:48px;margin:0 auto .85rem;animation:1.3s infinite productos-shimmer}.productos-empty-state{justify-content:center;align-items:center;min-height:60vh;padding:clamp(2rem,6vw,4rem) clamp(1rem,4vw,2rem);display:flex}.productos-empty-content{text-align:center;color:#999}.productos-empty-content svg{color:#ddd;margin-bottom:2rem}.productos-empty-content h2{color:#666;margin:0 0 1rem;font-size:clamp(1.5rem,5vw,2rem);font-weight:700}.productos-empty-content p{color:#999;max-width:500px;margin:0;font-size:clamp(1rem,3vw,1.125rem)}@media (min-width:768px){.productos-header{margin-bottom:clamp(.9rem,2vw,1.35rem);padding:clamp(1.1rem,3vw,1.75rem) clamp(1rem,4vw,2.2rem)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes productos-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.productos-header,.productos-content{animation:.6s ease-out fadeIn}@media (prefers-reduced-motion:reduce){.productos-header,.productos-content{animation:none}}
