/* ============================================================
   OnDestination - Decoratie & Styling page
   Builds on colors_and_type.css + home.css + aanbod.css +
   design-drukwerk.css + fotografie.css.
   Reuses .pg-header, .band-kicker / .disc-grid, the .tier-split
   in-house vs. partners explainer, .compose-d / .bd-list, the
   .proc-grid process and the advies band.
   Adds only: the kant-en-klare package tiers and the maatwerk
   strip that closes the package band.
   ============================================================ */

/* Active nav item (mirrors aanbod.css) */
.nav .ni-link.is-current { color: #F8F5EE; }
.nav .ni-link.is-current::after {
  content: ""; display: block; height: 2px; background: #6FE000;
  border-radius: 2px; margin-top: 3px;
}

/* Band-head <em> accents (matches the per-component rules across the site) */
.band.paper .band-head h2 em,
.band.paper .match-head h3 em { font-style: normal; color: #3F8A00; }
.band.ink .band-head h2 em,
.band.dark .band-head h2 em {
  font-style: normal; color: #6FE000; text-shadow: 0 0 44px rgba(111,224,0,.32);
}

/* ============================================================
   KANT-EN-KLARE PAKKETTEN  -  three pricing tiers (paper band)
   White cards, dark featured card pops on the beige.
   ============================================================ */
.pkg-tiers {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; align-items: stretch;
}
.tier {
  position: relative; display: flex; flex-direction: column;
  background: #fff; border: 1px solid rgba(0,0,0,.09); border-radius: 22px;
  padding: 36px 32px 32px;
  transition: transform 260ms cubic-bezier(.22,.61,.36,1), box-shadow 260ms cubic-bezier(.22,.61,.36,1), border-color 260ms;
}
.tier:hover { transform: translateY(-5px); box-shadow: 0 26px 56px -30px rgba(0,0,0,.45); border-color: rgba(0,0,0,.18); }

/* Featured middle tier */
.tier.is-feat {
  background:
    radial-gradient(ellipse 120% 70% at 50% 0%, rgba(111,224,0,.12), transparent 60%),
    #0A0A0A;
  border-color: #0A0A0A; box-shadow: 0 30px 60px -30px rgba(0,0,0,.55);
}
.tier.is-feat:hover { border-color: rgba(111,224,0,.45); }
.tier-badge {
  position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
  background: #6FE000; color: #000; font-size: 11px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase; padding: 7px 16px; border-radius: 999px;
  white-space: nowrap; box-shadow: 0 0 30px rgba(111,224,0,.4);
}

.tier-name {
  font-family: 'Kardige', sans-serif; font-weight: 400; font-size: 31px; letter-spacing: -.02em;
  line-height: 1; color: #0A0A0A; margin: 0 0 6px;
}
.tier.is-feat .tier-name { color: #F8F5EE; }
.tier-tagline { font-size: 13.5px; line-height: 1.5; color: #6a6a66; margin: 0 0 24px; }
.tier.is-feat .tier-tagline { color: rgba(248,245,238,.55); }

.tier-price {
  display: flex; align-items: baseline; gap: 9px; flex-wrap: wrap;
  padding-bottom: 22px; margin-bottom: 22px; border-bottom: 1px solid rgba(0,0,0,.1);
}
.tier.is-feat .tier-price { border-bottom-color: rgba(255,255,255,.12); }
.tier-price .vf {
  font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; font-weight: 700;
  color: rgba(0,0,0,.42); width: 100%;
}
.tier.is-feat .tier-price .vf { color: #6FE000; }
.tier-price .amt {
  font-family: 'Kardige', sans-serif; font-weight: 400; font-size: 46px; letter-spacing: -.025em;
  line-height: 1; color: #0A0A0A;
}
.tier.is-feat .tier-price .amt { color: #F8F5EE; }
.tier-price .per { font-size: 13px; color: rgba(0,0,0,.5); }
.tier.is-feat .tier-price .per { color: rgba(248,245,238,.5); }

.tier-incl { list-style: none; margin: 0 0 28px; padding: 0; display: grid; gap: 13px; }
.tier-incl li {
  display: flex; align-items: flex-start; gap: 12px; font-size: 14.5px; line-height: 1.45; color: #45433f;
}
.tier.is-feat .tier-incl li { color: rgba(248,245,238,.82); }
.tier-incl .tk {
  width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0; margin-top: 1px;
  display: grid; place-items: center; background: rgba(0,0,0,.06); color: #0A0A0A;
}
.tier.is-feat .tier-incl .tk { background: #6FE000; color: #0A0A0A; }
.tier-incl .tk svg { width: 12px; height: 12px; }
.tier-incl li.muted { color: rgba(0,0,0,.36); }
.tier.is-feat .tier-incl li.muted { color: rgba(248,245,238,.4); }
.tier-incl li.muted .tk { background: transparent; border: 1.5px solid rgba(0,0,0,.16); color: rgba(0,0,0,.3); }
.tier.is-feat .tier-incl li.muted .tk { border-color: rgba(255,255,255,.18); color: rgba(255,255,255,.3); }

.tier-foot { margin-top: auto; }
.tier-foot .btn { width: 100%; justify-content: center; }
.tier-adapt {
  display: flex; align-items: center; gap: 8px; justify-content: center;
  font-size: 12px; color: rgba(0,0,0,.5); margin: 14px 0 0;
}
.tier.is-feat .tier-adapt { color: rgba(248,245,238,.55); }
.tier-adapt svg { width: 13px; height: 13px; flex-shrink: 0; color: #3F8A00; }
.tier.is-feat .tier-adapt svg { color: #6FE000; }

.od p.pkg-disclaimer {
  font-size: 12.5px; line-height: 1.6; color: rgba(0,0,0,.42);
  margin-top: 30px; margin-bottom: 0; margin-left: auto; margin-right: auto;
  text-align: center; max-width: 60ch; text-wrap: balance;
}

/* ============================================================
   PAKKETTEN VERGELIJKEN  -  collapsible comparison table
   Mirrors the Verjaardag-page compare layout (.vj-compare-*).
   ============================================================ */
.vj-compare-wrap { margin-top: 44px; padding-top: 30px; border-top: 1px solid rgba(0,0,0,.12); }
.vj-compare-btn {
  display: inline-flex; align-items: center; gap: 10px; background: none;
  border: 1.5px solid rgba(0,0,0,.18); color: #3a3a36;
  font-family: 'Luxe Uno', sans-serif; font-size: 13.5px; font-weight: 700; letter-spacing: .02em;
  padding: 11px 22px; border-radius: 999px; cursor: pointer;
  transition: all 220ms cubic-bezier(.22,.61,.36,1);
}
.vj-compare-btn:hover { border-color: rgba(0,0,0,.34); color: #0A0A0A; }
.vj-compare-btn.is-open { background: #0A0A0A; border-color: #0A0A0A; color: #F8F5EE; }
.vj-compare-btn svg { transition: transform 300ms cubic-bezier(.22,.61,.36,1); flex-shrink: 0; }
.vj-compare-btn.is-open svg { transform: rotate(180deg); }

.vj-compare-panel { width: 100%; max-height: 0; overflow: hidden; transition: max-height 560ms cubic-bezier(.22,.61,.36,1); }
.vj-compare-inner { padding-top: 36px; padding-bottom: 4px; }

.vj-compare-table { width: 100%; border-collapse: collapse; min-width: 560px; }
.vj-compare-table thead th { padding: 0 18px 18px; text-align: left; vertical-align: bottom; border-bottom: 1.5px solid rgba(0,0,0,.1); }
.vj-compare-table thead th:first-child {
  font-family: 'Luxe Uno', sans-serif; font-size: 10px; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; color: #8a8a86;
}
.vj-compare-table .th-name {
  font-family: 'Kardige', sans-serif; font-size: 24px; font-weight: 400; letter-spacing: -.02em;
  color: #0A0A0A; display: block; margin-bottom: 3px;
}
.vj-compare-table .th-price { font-size: 13px; color: #8a8a86; display: block; }
.vj-compare-table thead th.is-feat-col { background: rgba(0,0,0,.03); border-top: 2px solid #6FE000; }
.vj-compare-table thead th.is-feat-col .th-price { color: #3F8A00; font-weight: 600; }

.vj-compare-table tbody td {
  padding: 11px 18px; font-size: 13.5px; color: #3a3a36;
  border-bottom: 1px solid rgba(0,0,0,.06); vertical-align: middle; line-height: 1.4;
}
.vj-compare-table tbody td:first-child { font-size: 13px; color: #6a6a66; width: 34%; }
.vj-compare-table tbody td.is-feat-col { background: rgba(0,0,0,.025); }
.vj-compare-table tbody tr:last-child td { border-bottom: 0; }
.vj-compare-table tbody tr:hover td { background: rgba(0,0,0,.02); }
.vj-compare-table tbody tr:hover td.is-feat-col { background: rgba(0,0,0,.045); }

.vj-cat-row td {
  padding: 22px 18px 6px !important; font-size: 10px !important; letter-spacing: .18em !important;
  text-transform: uppercase !important; font-weight: 700 !important; color: #3F8A00 !important;
  border-bottom: 0 !important; background: transparent !important;
}
.vj-cat-row:first-child td { padding-top: 12px !important; }

.vj-yes { color: #3F8A00; font-weight: 700; font-size: 15px; }
.vj-no  { color: rgba(0,0,0,.2); font-size: 15px; }
.vj-val { font-weight: 700; color: #0A0A0A; }

/* Mobile package tabs */
.vj-compare-tabs { display: none; gap: 6px; margin-bottom: 20px; }
.vj-ctab {
  flex: 1; appearance: none; background: rgba(0,0,0,.07); border: 1.5px solid rgba(0,0,0,.12);
  border-radius: 999px; font-family: 'Luxe Uno', sans-serif; font-size: 13px; font-weight: 700;
  color: #5a5a56; padding: 9px 12px; cursor: pointer; white-space: nowrap; text-align: center;
  transition: all 200ms cubic-bezier(.22,.61,.36,1);
}
.vj-ctab:hover { border-color: rgba(0,0,0,.3); color: #0A0A0A; }
.vj-ctab.is-active { background: #0A0A0A; border-color: #0A0A0A; color: #F8F5EE; }
.vj-ctab.is-feat.is-active { border-color: #6FE000; box-shadow: 0 0 0 1px #6FE000; }

@media (max-width: 640px) {
  .vj-compare-table .th-name { font-size: 18px; }
  .vj-compare-tabs { display: flex; }
  .vj-compare-table { min-width: unset; }
  .vj-compare-table thead th:nth-child(3),
  .vj-compare-table thead th:nth-child(4),
  .vj-compare-table tbody td:nth-child(3),
  .vj-compare-table tbody td:nth-child(4) { display: none; }
  .vj-compare-table.show-signature thead th:nth-child(2),
  .vj-compare-table.show-signature tbody td:nth-child(2) { display: none; }
  .vj-compare-table.show-signature thead th:nth-child(3),
  .vj-compare-table.show-signature tbody td:nth-child(3) { display: table-cell; }
  .vj-compare-table.show-statement thead th:nth-child(2),
  .vj-compare-table.show-statement tbody td:nth-child(2) { display: none; }
  .vj-compare-table.show-statement thead th:nth-child(4),
  .vj-compare-table.show-statement tbody td:nth-child(4) { display: table-cell; }
}

/* ============================================================
   MAATWERK STRIP  -  fully custom, closes the maatwerk band (dark)
   Reuses .compose-d / .bd-list from aanbod.css; only the dual CTA
   row needs its own rule.
   ============================================================ */
.maat-actions { display: flex; gap: 14px; flex-wrap: wrap; }
@media (max-width: 540px) {
  .maat-actions { width: 100%; }
  .maat-actions .btn { flex: 1 1 auto; justify-content: center; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .pkg-tiers { grid-template-columns: 1fr; gap: 20px; max-width: 460px; margin: 0 auto; }
  .tier.is-feat { order: -1; }
}
@media (max-width: 640px) {
  .tier { padding: 30px 26px 28px; }
  .tier-price .amt { font-size: 40px; }
}
