:root {
  --goo-skeleton-base: #e8ebee;
  --goo-skeleton-highlight: #f8f9fa;
  --goo-skeleton-border: #dfe3e6;
  --goo-skeleton-blue: #009ccb;
  --goo-skeleton-orange: #ff6600;
}

@keyframes goo-skeleton-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.goo-skeleton {
  display: block;
  position: relative;
  overflow: hidden;
  color: transparent !important;
  background: linear-gradient(
    100deg,
    var(--goo-skeleton-base) 25%,
    var(--goo-skeleton-highlight) 40%,
    var(--goo-skeleton-base) 55%
  );
  background-size: 220% 100%;
  border-color: var(--goo-skeleton-border) !important;
  animation: goo-skeleton-shimmer 1.35s ease-in-out infinite;
  user-select: none;
}

.goo-skeleton::before,
.goo-skeleton::after {
  visibility: hidden;
}

.goo-skeleton-line {
  height: 0.75rem;
  border-radius: 999px;
}

.goo-skeleton-line.is-title {
  height: 1.25rem;
  width: 70%;
}

.goo-skeleton-line.is-short { width: 42%; }
.goo-skeleton-line.is-medium { width: 68%; }
.goo-skeleton-line.is-long { width: 92%; }

.goo-skeleton-circle {
  border-radius: 50%;
  flex: 0 0 auto;
}

.goo-skeleton-button {
  width: 3rem;
  height: 2rem;
  border-radius: 999px;
  flex: 0 0 auto;
}

.goo-skeleton-stack {
  display: grid;
  gap: 0.625rem;
  width: 100%;
}

.goo-skeleton-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-height: 4.75rem;
  padding: 0.75rem 1rem;
  background: #fff;
  border: 1px solid var(--goo-skeleton-border);
  border-radius: 0.5rem;
}

.goo-skeleton-row .goo-skeleton-circle {
  width: 3.25rem;
  height: 3.25rem;
}

.goo-skeleton-card {
  min-height: 10rem;
  padding: 1rem;
  background: #fff;
  border: 1px solid var(--goo-skeleton-border);
  border-radius: 0.75rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.goo-skeleton-card .goo-skeleton-media {
  width: 100%;
  height: 7rem;
  margin-bottom: 0.875rem;
  border-radius: 0.625rem;
}

.goo-skeleton-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10rem, 1fr));
  gap: 1rem;
}

.goo-skeleton-page {
  display: grid;
  gap: 1.25rem;
  width: 100%;
  max-width: 68.75rem;
  margin: 0 auto;
  padding: 1rem;
}

.goo-skeleton-hero {
  min-height: 11rem;
  padding: 1.5rem;
  background: #fff;
  border: 1px solid var(--goo-skeleton-border);
  border-radius: 0.75rem;
}

.goo-skeleton-accent {
  height: 0.1875rem;
  background: linear-gradient(90deg, var(--goo-skeleton-blue), var(--goo-skeleton-orange));
  border-radius: 999px;
}

.goo-skeleton-image-wrap {
  position: relative;
  overflow: hidden;
  background: transparent;
  border-radius: inherit;
}

.goo-skeleton-image-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(
    100deg,
    var(--goo-skeleton-base) 25%,
    var(--goo-skeleton-highlight) 40%,
    var(--goo-skeleton-base) 55%
  );
  background-size: 220% 100%;
  animation: goo-skeleton-shimmer 1.35s ease-in-out infinite;
  pointer-events: none;
  border-radius: inherit;
}

.goo-skeleton-image-wrap.is-loaded::after {
  display: none;
}

.goo-skeleton-image-wrap img {
  position: relative;
  z-index: 1;
  transition: opacity 0.2s ease;
}

.goo-skeleton-image-wrap:not(.is-loaded) img {
  opacity: 0;
}

.goo-initial-skeleton {
  position: fixed;
  inset: 0;
  z-index: 9998;
  overflow: auto;
  padding-top: 4.5rem;
  background: #f7f8f9;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.18s ease;
}

.goo-initial-skeleton.is-visible {
  opacity: 1;
  visibility: visible;
}

.goo-initial-skeleton.is-leaving {
  opacity: 0;
  pointer-events: none;
}

.goo-skeleton-region {
  min-height: 8rem;
}

.goo-skeleton-error {
  padding: 1rem;
  color: #7a2b1b;
  background: #fff4ef;
  border: 1px solid #ffd0bf;
  border-radius: 0.5rem;
}

[aria-busy="true"] {
  cursor: progress;
}

@media (max-width: 768px) {
  .goo-skeleton-page {
    padding: 0.75rem;
  }

  .goo-skeleton-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
  }

  .goo-skeleton-card {
    min-height: 8rem;
    padding: 0.75rem;
  }

  .goo-skeleton-row {
    min-height: 4.25rem;
    padding: 0.625rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .goo-skeleton,
  .goo-skeleton-image-wrap::after {
    animation: none;
    background: var(--goo-skeleton-base);
  }

  .goo-initial-skeleton {
    transition: none;
  }
}
