/* module.css */

/* Full-width wrapper */
.plans-module {
  width: 100%;
  padding: 0;
}

/* Horizontal, wrapping flex container */
.plans-flex {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  justify-content: space-between;
}

/* Card base */
.plan-card {
  background: #fff;
  color: #000;
  border: 1px solid rgba(128, 128, 128, 0.5);
  border-radius: 32px;
  padding: 32px;
  flex: 1 1 calc(25% - 24px);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}

/* Titles & descriptions */
.plan-title {
  margin: 0 0 4px;
  font-size: 1.5rem;
}
.plan-description {
  margin: 4px 0 24px;
  color: #666;
  flex-shrink: 0;
}

/* Price & features spacing */
.plan-price {
  margin: 0 0 16px;
  font-size: 2rem;
  font-weight: bold;
}
.plan-price span {
  font-size: 1rem;
  font-weight: normal;
}

.plan-note {
  margin: 0 0 16px;
  font-size: 0.875rem;
  color: #555;
}

/* Features list */
.plan-features {
  list-style: none;
  padding: 0;
  margin: 0;
  flex-grow: 1;
}
.plan-features li {
  margin-bottom: 8px;
  padding-left: 24px;
  position: relative;
}
.plan-features li::before {
  content: '\2713'; /* Unicode checkmark */
  position: absolute;
  left: 0;
  top: 0;
  font-size: 1rem;
  color: #000;
}

/* Mobile stacking */
@media (max-width: 768px) {
  .plan-card {
    flex: 1 1 100%;
  }
}
```
