/* =========================================================
   LS – Pricing / Pakketten (V3.1 FINAL)
   Markup-aligned • system rhythm • no phantom elements
========================================================= */

.ls-pricing {
  position: relative;
}

/* ---------------------------------------------------------
   Header
--------------------------------------------------------- */

.ls-pricing-header {
  text-align: center;
  max-width: 720px;
  margin-inline: auto;

  display: flex;
  flex-direction: column;
  gap: var(--ls-f5);
}

/* ---------------------------------------------------------
   Grid
--------------------------------------------------------- */

.ls-pricing-grid {
  --gap: clamp(24px, 4vw, 40px);

  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);

  position: relative;
}

/* Accent rail (decoratief, achter cards) */
.ls-pricing-grid::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 4%;
  right: 4%;
  height: 2px;

  background: linear-gradient(
    90deg,
    transparent,
    var(--color-accent-soft),
    transparent
  );

  transform: translateY(-50%);
  pointer-events: none;
}

.ls-pricing > .ls-container {
  display: flex;
  flex-direction: column;
  gap: var(--ls-f7);
}

/* ---------------------------------------------------------
   Card
--------------------------------------------------------- */

.ls-pricing-card {
  position: relative;
  isolation: isolate;

  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,0.06);

  padding: clamp(28px, 4vw, 36px);

  display: flex;
  flex-direction: column;
  gap: var(--ls-f5);

  transition:
    transform .35s cubic-bezier(.2,.8,.2,1),
    box-shadow .35s ease,
    border-color .35s ease;
}

/* Hover */
@media (hover:hover) {
  .ls-pricing-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 28px 64px rgba(10,35,66,.14);
    border-color: rgba(255,107,0,.35);
  }
}

/* ---------------------------------------------------------
   Featured
--------------------------------------------------------- */

.ls-pricing-card.is-featured {
  transform: translateY(-8px);
  border-color: var(--color-accent);

  box-shadow:
    0 32px 72px rgba(10,35,66,.18);

  background:
    linear-gradient(
      180deg,
      rgba(255,107,0,.08),
      rgba(255,107,0,.02)
    ),
    #fff;
}

/* Accent outline */
.ls-pricing-card.is-featured::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 2px solid var(--color-accent);
  opacity: .25;
  pointer-events: none;
}

/* ---------------------------------------------------------
   Card header
--------------------------------------------------------- */

.ls-pricing-card-header {
  display: flex;
  flex-direction: column;
  gap: var(--ls-f3);
}

.ls-pricing-card-header p {
  color: var(--color-muted);
  line-height: 1.55;
}

/* ---------------------------------------------------------
   Price
--------------------------------------------------------- */

.ls-pricing-price {
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text);
}

.ls-pricing-price small {
  font-size: .85em;
  font-weight: 500;
  color: var(--color-muted);
}

.ls-pricing-price_extra {
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.4;
  color: color-mix(in srgb, var(--color-muted) 80%, transparent);
  opacity: 0.9;
  margin-top: 6px;
  display: block;
}
/* ---------------------------------------------------------
   Features
--------------------------------------------------------- */

.ls-pricing-features {
  list-style: none;
  padding: 0;
  margin: 0;

  display: grid;
  gap: 10px;
}

.ls-pricing-features li {
  position: relative;
  padding-left: 22px;
  line-height: 1.55;
  color: var(--color-text);
}

/* Checkmark */
.ls-pricing-features li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .45em;

  width: 10px;
  height: 10px;
  border-radius: 50%;

  background: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-soft);
}

/* ---------------------------------------------------------
   CTA
--------------------------------------------------------- */

.ls-pricing-card .btn {
  margin-top: auto;
}

/* ---------------------------------------------------------
   Reduced motion
--------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {

  .ls-pricing-card {
    transition: none;
  }

}

/* ---------------------------------------------------------
   Mobile
--------------------------------------------------------- */

@media (max-width: 900px) {

  .ls-pricing-grid {
    grid-template-columns: 1fr;
  }

  .ls-pricing-grid::before {
    display: none;
  }

  .ls-pricing-card.is-featured {
    transform: none;
  }

}