/* ============================================================
   OnDestination - Aftermovie page
   Builds on colors_and_type.css + home.css + aanbod.css +
   design-drukwerk.css (proc-grid) + fotografie.css (tier styles).
   Adds: the cinematic feature reel, the format showcase
   (16:9 / 9:16 / 1:1) and the pricing block.
   ============================================================ */

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

/* ============================================================
   FEATURE REEL  -  the aftermovie itself (paper band)
   A cinematic 16:9 placeholder with timecode, play button and
   a faux scrubber, so it reads as motion, not a still.
   ============================================================ */
.reel-feature {
  position: relative; aspect-ratio: 16 / 9; border-radius: 22px; overflow: hidden;
  margin-bottom: 22px; box-shadow: 0 40px 90px -50px rgba(0,0,0,.7);
}
.reel-feature.ph::after { font-size: 0; }
.reel-feature .rf-wash {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(ellipse 60% 70% at 50% 42%, rgba(111,224,0,.16), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.35) 0%, transparent 30%, transparent 62%, rgba(0,0,0,.78) 100%);
}
.reel-feature .rf-tc {
  position: absolute; top: 18px; left: 18px; z-index: 3; display: inline-flex; align-items: center; gap: 9px;
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase; font-weight: 400;
  color: #F8F5EE; background: rgba(0,0,0,.42); backdrop-filter: blur(5px);
  padding: 7px 13px; border-radius: 999px;
}
.reel-feature .rf-tc::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%; background: #6FE000;
  box-shadow: 0 0 10px rgba(111,224,0,.9); animation: rfBlink 1.6s steps(1) infinite;
}
@keyframes rfBlink { 0%,55% { opacity: 1; } 56%,100% { opacity: .25; } }
@media (prefers-reduced-motion: reduce) { .reel-feature .rf-tc::before { animation: none; } }

.reel-feature .rf-play {
  position: absolute; inset: 0; margin: auto; z-index: 3;
  width: 92px; height: 92px; border-radius: 50%; border: 0; cursor: pointer;
  display: grid; place-items: center;
  background: rgba(111,224,0,.95); color: #0A0A0A;
  box-shadow: 0 0 0 0 rgba(111,224,0,.5), 0 18px 50px -12px rgba(0,0,0,.6);
  transition: transform 240ms cubic-bezier(.22,.61,.36,1), box-shadow 240ms cubic-bezier(.22,.61,.36,1);
}
.reel-feature .rf-play svg { width: 30px; height: 30px; margin-left: 4px; }
.reel-feature:hover .rf-play { transform: scale(1.06); box-shadow: 0 0 0 14px rgba(111,224,0,.12), 0 18px 50px -12px rgba(0,0,0,.6); }

.reel-feature .rf-bar {
  position: absolute; left: 22px; right: 22px; bottom: 20px; z-index: 3;
  display: flex; align-items: center; gap: 14px;
}
.reel-feature .rf-track {
  flex: 1; height: 4px; border-radius: 999px; background: rgba(255,255,255,.22); overflow: hidden;
}
.reel-feature .rf-fill { display: block; width: 38%; height: 100%; background: #6FE000; border-radius: 999px; }
.reel-feature .rf-dur {
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 12px; letter-spacing: .08em; color: #F8F5EE; white-space: nowrap;
}

/* Caption strip under the reel */
.reel-caps {
  display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 58px;
}
.reel-caps span {
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: #6a6862;
  border: 1px solid rgba(0,0,0,.14); border-radius: 999px; padding: 7px 13px;
}

/* ============================================================
   FORMAT SHOWCASE  -  one edit, every channel (ink grain band)
   ============================================================ */
.fmt-head { margin-bottom: 44px; }
.fmt-grid {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 18px; align-items: end;
}
.fmt-card {
  display: flex; flex-direction: column; gap: 18px;
}
.fmt-frame {
  position: relative; border-radius: 16px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
}
.fmt-frame.ph { background: repeating-linear-gradient(135deg, #141414 0 14px, #191919 14px 28px); }
.fmt-frame .ff-badge {
  position: absolute; top: 12px; left: 12px; z-index: 2;
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 10.5px; letter-spacing: .12em; color: #0A0A0A; font-weight: 700;
  background: #6FE000; padding: 5px 10px; border-radius: 999px;
}
.fmt-frame .ff-play {
  position: absolute; inset: 0; margin: auto; z-index: 2;
  width: 48px; height: 48px; border-radius: 50%; display: grid; place-items: center;
  background: rgba(255,255,255,.14); backdrop-filter: blur(4px); color: #F8F5EE;
  border: 1px solid rgba(255,255,255,.25);
}
.fmt-frame .ff-play svg { width: 18px; height: 18px; margin-left: 2px; }
.fmt-16x9 { aspect-ratio: 16 / 9; }
.fmt-9x16 { aspect-ratio: 9 / 16; }
.fmt-1x1  { aspect-ratio: 1 / 1; }
.fmt-meta .fm-ratio {
  font-family: 'Kardige', sans-serif; font-size: 24px; letter-spacing: -.01em;
  color: #F8F5EE; line-height: 1; margin: 0 0 7px;
}
.fmt-meta .fm-use {
  font-size: 13.5px; line-height: 1.5; color: rgba(248,245,238,.6); margin: 0;
}

/* ============================================================
   PRICING  -  the one hard fact (ink band)
   ============================================================ */
.price-card {
  position: relative; display: grid; grid-template-columns: .92fr 1.08fr; gap: 0;
  border-radius: 26px; overflow: hidden; border: 1px solid rgba(111,224,0,.24);
  background:
    radial-gradient(ellipse 100% 90% at 0% 0%, rgba(111,224,0,.12), transparent 60%),
    #121712;
}
.price-left { padding: 48px 44px; border-right: 1px solid rgba(255,255,255,.08); display: flex; flex-direction: column; }
.price-tag {
  display: inline-flex; align-items: baseline; gap: 4px;
  font-family: 'Kardige', sans-serif; color: #F8F5EE; letter-spacing: -.02em; line-height: .92;
}
.price-tag .pt-cur { font-size: 34px; color: #6FE000; }
.price-tag .pt-num { font-size: 76px; color: #6FE000; text-shadow: 0 0 52px rgba(111,224,0,.35); }
.price-unit {
  font-size: 15px; color: rgba(248,245,238,.72); margin: 16px 0 4px; font-weight: 600;
}
.price-vat { font-size: 13px; color: rgba(248,245,238,.42); margin: 0 0 28px; }
.price-note {
  font-size: 14.5px; line-height: 1.6; color: rgba(248,245,238,.6); margin: 0 0 30px; max-width: 38ch;
}
.price-left .price-cta { margin-top: auto; display: flex; flex-wrap: wrap; gap: 12px; }

.price-right { padding: 46px 44px; }
.price-right .pr-label {
  font-size: 11.5px; letter-spacing: .15em; text-transform: uppercase; font-weight: 700;
  color: #6FE000; margin: 0 0 22px;
}
.price-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0; }
.price-list li {
  display: flex; align-items: flex-start; gap: 15px; padding: 16px 0;
  font-size: 15.5px; line-height: 1.45; color: rgba(248,245,238,.86);
  border-top: 1px solid rgba(255,255,255,.08);
}
.price-list li:first-child { border-top: 0; }
.price-list .pk {
  width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center;
  background: #6FE000; color: #0A0A0A; margin-top: 1px;
}
.price-list .pk svg { width: 13px; height: 13px; }
.price-list li b { color: #F8F5EE; font-weight: 700; }
.price-list li span { color: rgba(248,245,238,.55); }

/* Two ways to footage - compact row above the price card */
.src-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 22px;
}
.src-tile {
  display: flex; flex-direction: column; gap: 9px;
  background: #141414; border: 1px solid rgba(255,255,255,.09); border-radius: 18px;
  padding: 26px 28px;
}
.src-tile .st-ico {
  width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center;
  background: rgba(111,224,0,.12); color: #6FE000; margin-bottom: 6px;
}
.src-tile .st-ico svg { width: 20px; height: 20px; }
.src-tile h4 { font-size: 16px; font-weight: 700; color: #F8F5EE; margin: 0; letter-spacing: -.01em; }
.src-tile p { font-size: 14px; line-height: 1.55; color: rgba(248,245,238,.6); margin: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .fmt-grid { grid-template-columns: 1fr 1fr; }
  .fmt-card:first-child { grid-column: span 2; }
  .fmt-card:first-child .fmt-frame { max-width: 620px; }
}
@media (max-width: 860px) {
  .price-card { grid-template-columns: 1fr; }
  .price-left { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.08); }
}
@media (max-width: 640px) {
  .reel-feature .rf-play { width: 72px; height: 72px; }
  .reel-feature .rf-play svg { width: 24px; height: 24px; }
  .fmt-grid { grid-template-columns: 1fr; }
  .fmt-card:first-child { grid-column: span 1; }
  .src-row { grid-template-columns: 1fr; }
  .price-left, .price-right { padding: 34px 28px; }
  .price-tag .pt-num { font-size: 58px; }
}
