:root {
  --corely-loading-accent: #8b73ff;
  --corely-loading-accent-soft: rgb(139 115 255 / 0.16);
  --corely-loading-region-sheen: rgb(139 115 255 / 0.18);
  --corely-loading-skeleton: rgb(255 255 255 / 0.07);
  --corely-loading-skeleton-sheen: rgb(255 255 255 / 0.12);
}

html.light,
[data-theme="light"] {
  --corely-loading-skeleton: rgb(50 42 80 / 0.07);
  --corely-loading-skeleton-sheen: rgb(139 115 255 / 0.14);
}

.corely-loading-bar {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2147483000;
  width: 100%;
  height: 3px;
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  transition: opacity 180ms ease;
}

.corely-loading-bar::before {
  content: "";
  position: absolute;
  inset: 0;
  width: 42%;
  background: linear-gradient(90deg, transparent, var(--corely-loading-accent), transparent);
  transform: translateX(-120%);
  animation-name: corely-loading-bar;
  animation-duration: 1.15s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}

.corely-loading-bar.is-active {
  opacity: 1;
}

[data-corely-loading-region],
.corely-loading-region {
  position: relative;
  transition: opacity 180ms ease, filter 180ms ease;
}

[data-corely-loading-region][aria-busy="true"],
.corely-loading-region.is-loading {
  opacity: 0.88;
  filter: saturate(0.94);
}

[data-corely-loading-region][aria-busy="true"]::before,
.corely-loading-region.is-loading::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 5;
  height: 2px;
  overflow: hidden;
  pointer-events: none;
  border-radius: inherit;
  background: linear-gradient(90deg, transparent, var(--corely-loading-region-sheen), transparent);
  transform: translateX(-100%);
  animation-name: corely-region-loading-sweep;
  animation-duration: 1.35s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}

[data-corely-action-pending="true"] {
  pointer-events: none;
  opacity: 0.78;
  cursor: progress;
}

@keyframes corely-loading-bar {
  0% { transform: translateX(-120%); }
  100% { transform: translateX(260%); }
}

@keyframes corely-region-loading-sweep {
  100% { transform: translateX(100%); }
}

.corely-skeleton {
  position: relative;
  overflow: hidden;
  min-height: 88px;
  border-radius: 16px;
  background: var(--corely-loading-skeleton);
}

.corely-skeleton::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, var(--corely-loading-skeleton-sheen), transparent);
  transform: translateX(-100%);
  animation-name: corely-skeleton-shimmer;
  animation-duration: 1.35s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}

.corely-skeleton-grid {
  display: grid;
  gap: 14px;
}

.corely-skeleton-grid--cards {
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

@keyframes corely-skeleton-shimmer {
  100% { transform: translateX(100%); }
}

@media (prefers-reduced-motion: reduce) {
  .corely-loading-bar::before,
  [data-corely-loading-region][aria-busy="true"]::before,
  .corely-loading-region.is-loading::before,
  .corely-skeleton::after {
    animation-name: none;
    transform: none;
  }
}
