.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;padding:2rem}.loading-container.full-page{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:rgba(255,255,255,.9);z-index:var(--z-modal)}.spinner{display:flex;align-items:center;justify-content:center}.spinner-small{width:40px;height:40px}.spinner-medium{width:60px;height:60px}.spinner-large{width:80px;height:80px}.spinner-primary .spinner-border{border:4px solid rgba(255,149,0,.2);border-top:4px solid var(--oranye-01);border-radius:50%;width:100%;height:100%;animation:spin 1s linear infinite}.spinner-secondary .spinner-border{border:4px solid rgba(0,168,232,.2);border-top:4px solid var(--blue-01);border-radius:50%;width:100%;height:100%;animation:spin 1s linear infinite}.spinner-light .spinner-border{border:4px solid rgba(0,0,0,.1);border-top-color:rgba(0,0,0,.5);border-radius:50%;width:100%;height:100%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{margin-top:1rem;font-size:var(--font-md);color:var(--grey-text)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skeleton-card{width:100%;border-radius:var(--radius-lg);overflow:hidden;background-color:#fff;box-shadow:var(--shadow-sm);height:300px}.skeleton-image{width:100%;height:220px;background-color:#f0f0f0;position:relative;overflow:hidden}.skeleton-image:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite;transform:translateX(-100%)}.skeleton-content{padding:16px 20px}.skeleton-title{height:24px;width:80%;background-color:#f0f0f0;border-radius:4px;margin-bottom:12px;position:relative;overflow:hidden}.skeleton-title:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite;transform:translateX(-100%)}.skeleton-location{height:16px;width:60%;background-color:#f0f0f0;border-radius:4px;position:relative;overflow:hidden}.skeleton-location:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite;transform:translateX(-100%)}.skeleton-product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:20px;gap:20px;width:100%;padding:20px}.skeleton-detail{width:100%;max-width:1070px;margin:0 auto;padding:20px}.skeleton-detail-image{width:100%;height:400px;background-color:#f0f0f0;border-radius:var(--radius-lg);margin-bottom:20px;position:relative;overflow:hidden}.skeleton-detail-image:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite;transform:translateX(-100%)}.skeleton-detail-content{width:100%}.skeleton-detail-title{height:36px;width:60%;background-color:#f0f0f0;border-radius:4px;margin-bottom:16px;position:relative;overflow:hidden}.skeleton-detail-title:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite;transform:translateX(-100%)}.skeleton-detail-info{height:24px;width:40%;background-color:#f0f0f0;border-radius:4px;margin-bottom:24px;position:relative;overflow:hidden}.skeleton-detail-info:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite;transform:translateX(-100%)}.skeleton-detail-description{height:16px;width:100%;background-color:#f0f0f0;border-radius:4px;margin-bottom:10px;position:relative;overflow:hidden}.skeleton-detail-description:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite;transform:translateX(-100%)}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}@media (max-width:768px){.skeleton-product-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.skeleton-detail-image{height:300px}}@media (max-width:576px){.skeleton-product-grid{grid-template-columns:1fr}.skeleton-detail-image{height:200px}}