/* ===========================
   06. CAPACIDADES
=========================== */
#capacidades { background: var(--gray-light); padding: 120px 0; }
.cap-header { margin-bottom: 56px; }
.cap-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { .cap-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 500px) { .cap-grid { grid-template-columns: 1fr; } }
.cap-card {
  --cap-tilt-x: 0deg;
  --cap-tilt-y: 0deg;
  --cap-spot-x: 50%;
  --cap-spot-y: 50%;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02) 32%, rgba(255,255,255,0.04) 100%),
    linear-gradient(135deg, rgba(107,31,184,0.96) 0%, rgba(79,20,141,0.98) 42%, rgba(170,63,54,0.98) 74%, rgba(255,107,26,0.98) 100%);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 24px;
  padding: 32px 28px;
  min-height: 372px;
  position: relative;
  overflow: hidden;
  transform: perspective(1200px) rotateX(var(--cap-tilt-x)) rotateY(var(--cap-tilt-y)) scale3d(1, 1, 1);
  transform-style: preserve-3d;
  box-shadow:
    0 16px 40px rgba(42,14,95,0.18),
    0 0 0 1px rgba(255,255,255,0.03) inset;
  transition: transform 0.2s ease-out, box-shadow 0.3s var(--ease-out), border-color 0.3s var(--ease-out);
}
.cap-card:hover {
  border-color: rgba(255,255,255,0.24);
  box-shadow:
    0 26px 56px rgba(42,14,95,0.24),
    0 18px 40px rgba(255,107,26,0.14),
    0 0 0 1px rgba(255,255,255,0.04) inset;
}
.cap-card::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at var(--cap-spot-x) var(--cap-spot-y), rgba(255,255,255,0.16) 0%, rgba(255,255,255,0.06) 14%, transparent 38%),
    linear-gradient(135deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.03) 34%, transparent 60%, rgba(255,255,255,0.08) 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.cap-card::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at bottom left, rgba(255,255,255,0.18), transparent 52%),
    url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.18'/%3E%3C/svg%3E");
  mix-blend-mode: soft-light;
  opacity: 0.34;
}
.cap-card:hover::before {
  opacity: 1;
}
.cap-card > * {
  position: relative;
  z-index: 1;
  transform: translateZ(24px);
}
.cap-card-icon {
  width: 54px; height: 54px;
  background:
    radial-gradient(circle at 30% 24%, rgba(255,255,255,0.34), transparent 36%),
    linear-gradient(225deg, rgba(31,14,53,0.9) 0%, rgba(16,10,31,0.94) 100%);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  margin-bottom: 18px;
  box-shadow:
    0 10px 24px rgba(0,0,0,0.2),
    inset 0 1px 0 rgba(255,255,255,0.18),
    inset 0 -1px 0 rgba(0,0,0,0.28);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.cap-card:hover .cap-card-icon {
  transform: translateY(-4px) translateZ(36px);
  box-shadow:
    0 14px 32px rgba(0,0,0,0.26),
    0 0 22px rgba(255,107,26,0.2),
    inset 0 1px 0 rgba(255,255,255,0.24),
    inset 0 -1px 0 rgba(0,0,0,0.28);
}
.cap-card h3 {
  font-size: 16px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 10px;
  line-height: 1.25;
  text-shadow: 0 1px 6px rgba(0,0,0,0.18);
}
.cap-card p {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.86);
}
@media (prefers-reduced-motion: reduce) {
  .cap-card {
    transform: none;
    transition: none;
  }
  .cap-card:hover {
    transform: none;
  }
}

