.cn-route-loading{--cn-loading-bg:#fdfbf7;--cn-loading-accent:#b76e79;--cn-loading-accent-soft:#ead7db;--cn-loading-bar:#f0e3d5;background:radial-gradient(ellipse 80% 50% at 50% 0%, #b76e791f 0%, transparent 55%), linear-gradient(180deg, #f8f2ea 0%, var(--cn-loading-bg) 42%, var(--cn-loading-bg) 100%);justify-content:center;align-items:center;min-height:100dvh;padding:48px 24px;display:flex}.cn-route-loading__inner{flex-direction:column;align-items:center;gap:28px;width:min(320px,88vw);display:flex}.cn-route-loading__brand{opacity:0;margin:0;animation:.7s forwards cn-route-loading-brand-in}.cn-route-loading__brand .brand-logo{--brand-logo-height:clamp(2rem, 6vw, 2.75rem);object-position:center;margin:0 auto}.cn-route-loading__bars{flex-direction:column;align-items:center;gap:10px;width:100%;display:flex}.cn-route-loading__bar{background:var(--cn-loading-bar);opacity:0;border-radius:999px;width:100%;height:8px;animation:.55s forwards cn-route-loading-bar-in;display:block;position:relative;overflow:hidden;transform:translateY(8px)}.cn-route-loading__bar--lg{width:72%;height:10px;animation-delay:.12s}.cn-route-loading__bar:nth-child(2){width:88%;animation-delay:.2s}.cn-route-loading__bar--sm{width:48%;animation-delay:.28s}.cn-route-loading__bar:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff8c 42%,#b76e7959 50%,#ffffff8c 58%,#0000 100%);animation:1.35s ease-in-out infinite cn-route-loading-shimmer;position:absolute;inset:0;transform:translate(-100%)}.cn-route-loading__bar--lg:after{animation-delay:.1s}.cn-route-loading__bar:nth-child(2):after{animation-delay:.25s}.cn-route-loading__bar--sm:after{animation-delay:.4s}.cn-route-loading__pulse{background:var(--cn-loading-accent);opacity:.35;border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite cn-route-loading-pulse}@keyframes cn-route-loading-brand-in{to{opacity:1}}@keyframes cn-route-loading-bar-in{to{opacity:1;transform:translateY(0)}}@keyframes cn-route-loading-shimmer{to{transform:translate(100%)}}@keyframes cn-route-loading-pulse{0%,to{opacity:.25;transform:scale(.92)}50%{opacity:.85;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.cn-route-loading__brand,.cn-route-loading__bar{opacity:1;animation:none;transform:none}.cn-route-loading__bar:after,.cn-route-loading__pulse{animation:none}.cn-route-loading__pulse{opacity:.5}}
