/* ===================== PLATFORM CAPABILITIES — folder cards ===================== */
.caps {
  position: relative;
  padding: clamp(70px, 8vw, 120px) clamp(20px, 4vw, 60px);
  background: #ffffff;
  overflow: hidden;
}

/* ---------- Heading ---------- */
.caps-head {
  position: relative;
  text-align: center;
  max-width: 1080px;
  margin: 0 auto clamp(44px, 5.5vw, 78px);
}
.caps-eyebrow {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  color: #2f6bd8;
  margin-bottom: 14px;
}
.caps-title {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: clamp(1.8rem, 3.5vw, 2.7rem);
  line-height: 1.12;
  letter-spacing: -0.015em;
  color: #16202f;
}
.caps-title .grad {
  background: linear-gradient(100deg, #4aa0ff 0%, #2f6bd8 60%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.caps-sub {
  margin: 16px auto 0;
  max-width: 640px;
  font-size: clamp(1rem, 1.3vw, 1.18rem);
  font-weight: 300;
  line-height: 1.6;
  color: #6b7689;
}

/* ---------- Grid / rail ---------- */
.caps-rail { position: relative; }
.caps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(26px, 2.6vw, 40px);
  max-width: 1180px;
  margin: 0 auto;
}
.caps-mnav { display: none; }

/* ---------- Folder card (compact) ---------- */
.cap {
  position: relative;
  height: clamp(186px, 21vw, 202px);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.cap:hover,
.cap:focus-within,
.cap.is-open { transform: translateY(-5px); outline: none; }

/* folder tab — rounded, merges into the body like a real folder */
.cap-tab {
  position: absolute;
  top: 0;
  left: 14px;
  width: 46%;
  height: 24px;
  border-radius: 12px 14px 0 0;
  background: linear-gradient(180deg, #3a78dd, #2f6bd8);
  z-index: 0;
}
/* folder body — overflow visible so the paper can rise out of the top */
.cap-body {
  position: absolute;
  top: 14px;
  left: 0; right: 0; bottom: 0;
  border-radius: 16px;
  background: linear-gradient(165deg, #2f6bd8 0%, #4aa0ff 100%);
  box-shadow: 0 12px 24px rgba(47, 107, 216, 0.22);
  overflow: visible;
  z-index: 1;
}

/* the document that slides out of the folder */
.cap-doc {
  position: absolute;
  top: 13px;
  left: 15px;
  right: 15px;
  /* bottom anchored well above the folder base so the pushed-down paper never
     leaks out below the pocket (it stays tucked behind it) */
  bottom: 30%;
  padding: 13px 14px;
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 10px 18px rgba(30, 55, 110, 0.18);
  transform: translateY(40px);
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 1;
}
.cap-doc::before,
.cap-doc::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;
  background: #fbfbfc;
  z-index: -1;
}
.cap-doc::before { transform: translate(6px, -6px) rotate(2deg); opacity: 0.6; }
.cap-doc::after  { transform: translate(-5px, -3px) rotate(-2.2deg); opacity: 0.4; }

.cap-desc {
  font-size: 0.86rem;
  font-weight: 500;
  line-height: 1.48;
  color: #3f4a5e;
  opacity: 0;
  transform: translateY(5px);
  transition: opacity 0.38s ease 0.06s, transform 0.38s ease 0.06s;
}
.cap:hover .cap-doc,
.cap:focus-within .cap-doc,
.cap.is-open .cap-doc { transform: translateY(-24px); }
.cap:hover .cap-desc,
.cap:focus-within .cap-desc,
.cap.is-open .cap-desc { opacity: 1; transform: translateY(0); }

/* frosted folder pocket (front) */
.cap-pocket {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 56%;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 13px 15px 14px;
  background: linear-gradient(180deg, #4a90ee 0%, #2f6bd8 100%);
  border-top: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: 14px 14px 16px 16px;
  box-shadow: 0 -6px 14px rgba(47, 107, 216, 0.28);
}
.cap-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.cap-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cap-title {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 0.96rem;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: #ffffff;
  text-shadow: 0 1px 4px rgba(20, 50, 110, 0.3);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cap-sub {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.85);
}
.cap-info {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.18);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.3);
}
.cap-info svg { width: 16px; height: 16px; }
.cap-foot {
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.78);
}

/* ---------- Reveal on scroll ---------- */
.caps .reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1), transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.caps .reveal.in-view { opacity: 1; transform: translateY(0); }
.cap.in-view { transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); }

/* ---------- Desktop breakpoints ---------- */
@media (max-width: 1000px) and (min-width: 761px) {
  .caps-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ---------- Phone: horizontal swipe carousel ---------- */
@media (max-width: 760px) {
  .caps-rail {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none;
    padding: 8px calc((100% - min(78%, 290px)) / 2) 10px;
  }
  .caps-rail::-webkit-scrollbar { display: none; }

  .caps-grid {
    display: flex;
    gap: 14px;
    max-width: none;
  }
  .cap {
    flex: 0 0 min(78%, 290px);
    scroll-snap-align: center;
    height: 208px;
    transform-origin: center center;
    will-change: transform, opacity;
  }
  /* coverflow scale/opacity are driven per-frame by JS — no transition so the
     cards track the finger 1:1 (same as the Industries carousel) */
  .caps .reveal,
  .cap.in-view { transition: none; }

  .caps-mnav { display: flex; justify-content: center; margin-top: 20px; }
  .caps-dots { display: flex; gap: 7px; }
  .cap-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    border: none;
    padding: 0;
    background: rgba(47, 107, 216, 0.28);
    cursor: pointer;
    transition: width 0.3s ease, background 0.3s ease;
  }
  .cap-dot.active { width: 22px; border-radius: 5px; background: #2f6bd8; }
}

@media (prefers-reduced-motion: reduce) {
  .caps .reveal { transition: none; opacity: 1; transform: none; }
  .cap, .cap-doc, .cap-desc { transition: none; }
}

/* ===================== Dark theme ===================== */
[data-theme="dark"] .caps { background: var(--d-base); }
[data-theme="dark"] .caps-title { color: var(--d-t1); }
[data-theme="dark"] .caps-sub { color: var(--d-t2); }
[data-theme="dark"] .cap-body { box-shadow: 0 14px 28px rgba(0, 0, 0, 0.45); }
[data-theme="dark"] .cap-doc { background: #f3f4f7; }
[data-theme="dark"] .cap-doc::before,
[data-theme="dark"] .cap-doc::after { background: #e7e9ee; }
[data-theme="dark"] .cap-dot { background: rgba(120, 160, 255, 0.32); }
[data-theme="dark"] .cap-dot.active { background: #5b9bf5; }
