.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.loading-spinner{position:relative;display:flex;align-items:center;justify-content:center}.spinner-ring{position:absolute;border-radius:50%;border:3px solid transparent;border-top-color:#6090be;animation:spin 1s linear infinite}.spinner-ring:nth-child(1){width:30px;height:30px;animation-delay:0s}.spinner-ring:nth-child(2){width:22px;height:22px;border-top-color:#78aadb;animation-delay:.15s;animation-direction:reverse}.spinner-ring:nth-child(3){width:14px;height:14px;border-top-color:#34587b;animation-delay:.3s}.spinner-small .spinner-ring:nth-child(1){width:20px;height:20px}.spinner-small .spinner-ring:nth-child(2){width:14px;height:14px}.spinner-small .spinner-ring:nth-child(3){width:8px;height:8px}.spinner-large .spinner-ring:nth-child(1){width:50px;height:50px;border-width:4px}.spinner-large .spinner-ring:nth-child(2){width:38px;height:38px;border-width:4px}.spinner-large .spinner-ring:nth-child(3){width:26px;height:26px;border-width:4px}.loading-text{margin-top:15px;color:#6090be;font-size:12px;font-weight:500;animation:pulse 1.5s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.page-loading{min-height:200px;display:flex;align-items:center;justify-content:center}.skeleton{background:linear-gradient(90deg,#e8f1f8 25%,#d5e6f3,#e8f1f8 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.skeleton-text{height:12px;margin-bottom:8px}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.skeleton-title{height:18px;width:40%;margin-bottom:15px}.skeleton-avatar{width:60px;height:80px;border-radius:8px}.skeleton-box{height:100px;width:100%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.page-loader{padding:20px;min-height:300px}.page-loader-content{max-width:600px}.mini-loader{display:inline-flex;gap:3px;align-items:center;margin-left:5px}.mini-dot{width:4px;height:4px;background-color:#6090be;border-radius:50%;animation:mini-bounce 1.4s infinite ease-in-out both}.mini-dot:nth-child(1){animation-delay:-.32s}.mini-dot:nth-child(2){animation-delay:-.16s}@keyframes mini-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
