.cavinx-flip-card {
  --cavinx-flip-height: 380px;
  --cavinx-flip-accent: #9773bc;
  --cavinx-flip-radius: 18px;
  --cavinx-flip-border: rgba(255, 255, 255, 0.2);
  --cavinx-flip-shadow: 0 18px 34px rgba(6, 10, 22, 0.35);
  --cavinx-flip-back-top: rgba(21, 25, 41, 0.9);
  --cavinx-flip-back-mid: rgba(14, 18, 30, 0.92);
  --cavinx-flip-back-low: rgba(10, 13, 24, 0.94);

  position: relative;
  width: 100%;
  max-width: 360px;
  perspective: 1200px;
}

.cavinx-flip-card__inner {
  position: relative;
  width: 100%;
  height: var(--cavinx-flip-height);
  transition: transform .6s cubic-bezier(.2, .72, .2, 1);
  transform-style: preserve-3d;
  border-radius: var(--cavinx-flip-radius);
  box-shadow: var(--cavinx-flip-shadow);
}

.cavinx-flip-card.is-flipped .cavinx-flip-card__inner {
  transform: rotateY(180deg);
}

.cavinx-flip-card__face {
  position: absolute;
  inset: 0;
  border-radius: var(--cavinx-flip-radius);
  overflow: hidden;
  border: 1px solid var(--cavinx-flip-border);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.cavinx-flip-card__face--front {
  background: #0d1121;
}

.cavinx-flip-card__face--front img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cavinx-flip-card__overlay {
  position: absolute;
  inset: auto 0 0 0;
  padding: 16px;
  background: linear-gradient(to top, rgba(8, 11, 21, 0.82), rgba(8, 11, 21, 0));
}

.cavinx-flip-card__title {
  margin: 0;
  color: #fff;
  font-size: clamp(20px, 2vw, 24px);
  font-weight: 800;
  line-height: 1.2;
}

.cavinx-flip-card__face--back {
  transform: rotateY(180deg);
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: linear-gradient(
    to bottom,
    var(--cavinx-flip-back-top) 0%,
    var(--cavinx-flip-back-mid) 52%,
    var(--cavinx-flip-back-low) 100%
  );
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.cavinx-flip-card__text {
  color: #e6ebf6;
  font-size: 15px;
  line-height: 1.5;
}

.cavinx-flip-card__text p {
  margin: 0 0 10px;
}

.cavinx-flip-card__text p:last-child {
  margin-bottom: 0;
}

.cavinx-flip-card__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--cavinx-flip-accent) 58%, #ffffff 42%);
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--cavinx-flip-accent) 44%, #ffffff 56%) 0%,
    color-mix(in srgb, var(--cavinx-flip-accent) 70%, #000000 30%) 100%
  );
  color: #fff;
  font-weight: 700;
  text-decoration: none;
}

.cavinx-flip-card__close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  background: rgba(11, 16, 30, 0.68);
  color: #fff;
  cursor: pointer;
}

.cavinx-flip-card__toggle {
  display: none;
}

@media (hover: hover) and (pointer: fine) {
  .cavinx-flip-card:hover .cavinx-flip-card__inner,
  .cavinx-flip-card:focus-within .cavinx-flip-card__inner {
    transform: rotateY(180deg);
  }
}

@media (hover: none), (pointer: coarse), (max-width: 1024px) {
  .cavinx-flip-card__toggle {
    display: inline-flex;
    margin-top: 10px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    min-height: 36px;
    padding: 6px 12px;
    background: rgba(16, 20, 34, 0.7);
    color: #e8edf7;
    font-weight: 700;
  }
}

.cavinx-community-cards {
  --cavinx-community-cols: 5;
  display: grid;
  grid-template-columns: repeat(var(--cavinx-community-cols), minmax(0, 1fr));
  gap: 18px;
}

.cavinx-community-cards .cavinx-flip-card {
  max-width: none;
}

.cavinx-community-cards__empty {
  color: #d6dbe8;
  font-weight: 600;
  padding: 14px;
  border: 1px dashed rgba(255, 255, 255, 0.24);
  border-radius: 12px;
  background: rgba(16, 20, 34, 0.5);
}

@media (max-width: 1024px) {
  .cavinx-community-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }
}

@media (max-width: 767px) {
  .cavinx-community-cards {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}
