/* ============================================================
   OnDestination - Designs & drukwerk page
   Builds on colors_and_type.css + home.css + aanbod.css.
   Reuses .pg-header, .svc-cluster / .svc-card, .bd-list and the
   advies band. Adds: the suite showcase, the print package
   feature and the numbered process.
   ============================================================ */

/* 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;
}

/* Header eyebrow tweak so the deliverable count reads as a kicker */
.pg-header .pg-lead b { color: #F8F5EE; font-weight: 600; }

/* "Vanaf" price anchored to the bottom of every deliverable card.
   Scoped under .svc-card so it beats `.od p { margin: 0 }` (0,1,1)
   and the auto top-margin actually pushes the price to the base. */
.svc-card .svc-price { margin: auto 0 0; padding-top: 18px; display: flex; align-items: baseline; gap: 8px; }
.svc-price .vf {
  font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; font-weight: 700;
  color: rgba(0,0,0,.42);
}
.svc-price b {
  font-family: 'Kardige', sans-serif; font-weight: 400; font-size: 26px; letter-spacing: -.02em;
  color: #3F8A00; line-height: 1;
}
/* When a kick line is present, tighten the gap above the price */
.svc-card .svc-kick + .svc-price { padding-top: 12px; }

/* ============================================================
   SUITE SHOWCASE  -  one visual line across every piece (ink band)
   ============================================================ */
.suite-head { margin-bottom: 44px; }
.suite-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 132px; gap: 14px;
}
.suite-tile {
  position: relative; border: 1px solid rgba(255,255,255,.09); border-radius: 16px;
  overflow: hidden; transition: border-color 260ms cubic-bezier(.22,.61,.36,1), transform 260ms cubic-bezier(.22,.61,.36,1);
}
.suite-tile:hover { border-color: rgba(111,224,0,.42); transform: translateY(-4px); }
.suite-tile .ph { position: absolute; inset: 0; }
.suite-tile .suite-tag {
  position: absolute; left: 14px; bottom: 13px; z-index: 2; display: inline-flex; align-items: center; gap: 8px;
  font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase; font-weight: 700;
  color: #F8F5EE; background: rgba(0,0,0,.46); backdrop-filter: blur(4px);
  padding: 7px 12px; border-radius: 999px;
}
.suite-tile .suite-tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: #6FE000; flex-shrink: 0; }
.suite-tile .suite-fmt {
  position: absolute; top: 13px; right: 14px; z-index: 2; font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 10px; letter-spacing: .1em; color: rgba(255,255,255,.4);
}
/* Spans for editorial rhythm */
.suite-tile.t-tall { grid-row: span 2; }
.suite-tile.t-wide { grid-column: span 2; }
.suite-tile.t-big  { grid-column: span 2; grid-row: span 2; }

/* ============================================================
   PRINT PACKAGE FEATURE  -  the Graphic Design pakket (dark band)
   ============================================================ */
.pkg { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }
.pkg-copy h2 { font-size: clamp(34px, 4.4vw, 58px); line-height: 1.04; margin: 0 0 20px; color: #F8F5EE; }
.pkg-copy h2 em { font-style: normal; color: #6FE000; text-shadow: 0 0 44px rgba(111,224,0,.35); }
.pkg-copy > p { font-size: 17px; line-height: 1.65; color: rgba(248,245,238,.66); margin: 0 0 28px; max-width: 46ch; }
.pkg-price { display: flex; align-items: baseline; gap: 12px; margin: 0 0 26px; }
.pkg-price .amt { font-family: 'Kardige', sans-serif; font-size: 52px; line-height: 1; color: #F8F5EE; letter-spacing: -.02em; }
.pkg-price .vat { font-size: 13px; letter-spacing: .06em; color: rgba(248,245,238,.5); }
.pkg-actions { display: flex; gap: 14px; flex-wrap: wrap; margin: 0 0 18px; }
.pkg-note { font-size: 13px; color: rgba(248,245,238,.42); margin: 0; }

.pkg-card {
  background: #141414; border: 1px solid rgba(255,255,255,.1); border-radius: 22px; padding: 32px 30px;
}
.pkg-card .pkg-card-label {
  font-size: 11.5px; letter-spacing: .15em; text-transform: uppercase; font-weight: 700;
  color: #3F8A00; margin: 0 0 22px; display: flex; align-items: center; gap: 11px;
}
.pkg-card .pkg-card-label::before { content: ""; width: 26px; height: 1.5px; background: #3F8A00; }
.pkg-incl { display: grid; gap: 12px; margin: 0; }
.pkg-incl-row { display: flex; align-items: flex-start; gap: 14px; }
.pkg-incl-row .tick {
  width: 26px; height: 26px; border-radius: 50%; background: #6FE000; flex-shrink: 0;
  display: grid; place-items: center; margin-top: 1px;
}
.pkg-incl-row .tick svg { width: 14px; height: 14px; }
.pkg-incl-row b { display: block; font-size: 16px; font-weight: 700; color: #F8F5EE; margin-bottom: 2px; }
.pkg-incl-row span { font-size: 13.5px; line-height: 1.5; color: rgba(248,245,238,.52); }

/* ============================================================
   PROCESS  -  zo werkt het (paper band)
   ============================================================ */
.proc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.proc-step {
  position: relative; background: #fff; border: 1px solid rgba(0,0,0,.07); border-radius: 18px;
  padding: 30px 26px 28px; display: flex; flex-direction: column;
}
.proc-step .pn {
  font-family: 'Kardige', sans-serif; font-size: 18px; color: #3F8A00; line-height: 1;
  letter-spacing: -.02em; margin-bottom: 22px; display: inline-flex; align-items: center; gap: 10px;
}
.proc-step .pn::after { content: ""; flex: 1; height: 1px; background: rgba(0,0,0,.1); }
.proc-step h3 {
  font-family: 'Kardige', sans-serif; font-weight: 400; font-size: 23px; letter-spacing: -.01em;
  line-height: 1.1; color: #0A0A0A; margin: 0 0 10px;
}
.proc-step p { font-size: 14px; line-height: 1.55; color: #5a5a56; margin: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .proc-grid { grid-template-columns: repeat(2, 1fr); }
  /* 2 koloms i.p.v. 3: de brede/grote tegels (span 2) sluiten zo naadloos
     aan tot één blok i.p.v. een rafelige 3-koloms layout met gaten. */
  .suite-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  /* Stack the package vertically and lift the "Inbegrepen" card above
     the CTA. display:contents promotes the copy's children into the
     same flex flow so we can interleave the card with `order`. */
  .pkg { display: flex; flex-direction: column; gap: 0; }
  .pkg-copy { display: contents; }
  .pkg-copy .eye { order: 0; }
  .pkg-copy h2 { order: 1; }
  .pkg-copy > p:not(.eye):not(.pkg-note) { order: 2; }
  .pkg-price { order: 3; margin-bottom: 24px; }
  .pkg-card { order: 4; margin-bottom: 26px; }
  .pkg-actions { order: 5; }
  .pkg-note { order: 6; }
}
@media (max-width: 640px) {
  .proc-grid { grid-template-columns: 1fr; }
  .suite-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 120px; }
  .suite-tile.t-big { grid-column: span 2; }
  .suite-tile.t-wide { grid-column: span 2; }
  .pkg-price .amt { font-size: 42px; }

  /* Keep the three header stats on one row on phones (numbers aligned,
     labels wrap underneath). Overrides aanbod.css flex-wrap: wrap. */
  .pg-header .pg-stats { flex-wrap: nowrap; gap: 0; }
  .pg-header .pg-stat {
    flex: 1 1 0; min-width: 0; padding-right: 14px; margin-right: 14px;
  }
  .pg-header .pg-stat-num { font-size: 30px; }
  .pg-header .pg-stat-label { font-size: 9.5px; letter-spacing: .08em; }
}
@media (max-width: 380px) {
  .pg-header .pg-stat { padding-right: 10px; margin-right: 10px; }
  .pg-header .pg-stat-num { font-size: 25px; }
  .pg-header .pg-stat-label { font-size: 8.5px; letter-spacing: .06em; }
}
