/* Who We Are */
.who { border-top: 1px solid var(--ic-rule); max-width: 1200px; }
.who-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.who-text .section-label { margin-bottom: 16px; }
.who-text h2 { margin-bottom: 28px; }
.who-text .lead { margin-bottom: 22px; max-width: none; }
.who-text .lead:last-child { margin-bottom: 0; }
.who-image {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--ic-rule);
}
.who-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(10,10,10,0.6) 100%);
  pointer-events: none;
  z-index: 1;
}
.who-image::after {
  content: '';
  position: absolute;
  top: -40px; right: -40px;
  width: 280px; height: 280px;
  background: radial-gradient(circle, rgba(0,255,136,0.18) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.who-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  position: relative; z-index: 0;
  object-position: 35% center;
}
@media (max-width: 900px) {
  .who-grid { grid-template-columns: 1fr; gap: 32px; }
  .who-image { aspect-ratio: 16 / 10; }
}

/* Case Study IICY */
.case-iicy {
  margin: 43px 0 0;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 50px;
  align-items: center;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.005));
  border: 1px solid var(--ic-rule);
  padding: 43px;
  border-radius: 6px;
  position: relative;
  overflow: hidden;
}
.case-iicy::before {
  content: '';
  position: absolute;
  top: -100px; left: -100px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(0,255,136,0.2) 0%, transparent 60%);
  z-index: 0;
  pointer-events: none;
}
.case-iicy::after {
  content: '';
  position: absolute;
  bottom: -100px; right: -100px;
  width: 350px; height: 350px;
  background: radial-gradient(circle, rgba(61,139,255,0.15) 0%, transparent 60%);
  z-index: 0;
  pointer-events: none;
}
.case-iicy-photo {
  position: relative;
  z-index: 1;
  width: 240px; height: 240px;
  margin: 0 auto;
}
.case-iicy-photo::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(0,255,136,0.35) 0%, transparent 50%);
  border-radius: 50%;
  z-index: -1;
}
.case-iicy-photo img {
  width: 100%; height: 100%;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(0,255,136,0.3);
  box-shadow: 0 0 40px rgba(0,255,136,0.2);
}
.case-iicy-content { position: relative; z-index: 1; }
.case-iicy-label {
  font-size: 11px;
  color: var(--ic-green);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 700;
  margin: 0 0 8px;
}
.case-iicy-name {
  font-size: 48px;
  line-height: 1;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  margin: 0 0 8px;
}
.case-iicy-period {
  font-size: 13px;
  color: var(--ic-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  margin: 0 0 32px;
}
.case-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.case-metric {
  border-top: 1px solid var(--ic-rule);
  padding-top: 14px;
}
.case-metric-value {
  font-size: 32px;
  font-weight: 900;
  line-height: 1;
  color: var(--ic-green);
  letter-spacing: -0.03em;
  margin: 0 0 6px;
  text-shadow: 0 0 24px rgba(0,255,136,0.3);
}
.case-metric-label {
  font-size: 11px;
  color: var(--ic-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
}
.case-outcome {
  margin: 32px 0 0;
  padding-top: 24px;
  border-top: 1px solid var(--ic-rule);
  font-size: 15px;
  line-height: 1.5;
}
@media (max-width: 900px) {
  .case-iicy { grid-template-columns: 1fr; gap: 32px; padding: 32px; }
  .case-iicy::before, .case-iicy::after { display: none; }
  .case-iicy-photo { width: 180px; height: 180px; }
  .case-iicy-name { font-size: 36px; }
  .case-metric-value { font-size: 26px; }
}
@media (max-width: 640px) {
  .case-metrics { grid-template-columns: 1fr; }
  .case-iicy-name { font-size: 30px; }
  .case-metric-value { font-size: 24px; }
}

/* Proof Strip */
.proof {
  padding: 80px 28px;
  position: relative;
  z-index: 2;
  background: var(--ic-bg);
  border-top: 1px solid var(--ic-rule);
  border-bottom: 1px solid var(--ic-rule);
}
.proof-inner { max-width: 1300px; margin: 0 auto; }
.proof-header { text-align: center; margin: 0 0 48px; }
.proof-header h3 {
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  margin: 0;
}
.proof-header h3 .accent { color: var(--ic-green); }
.proof-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}
.proof-card.mobile-only { display: none; }
.proof-card {
  background: var(--ic-bg-soft);
  border: 1px solid var(--ic-rule);
  border-radius: 6px;
  overflow: hidden;
  transition: transform 0.3s ease, border-color 0.3s ease;
}
.proof-card:hover {
  transform: translateY(-4px);
  border-color: rgba(0,255,136,0.3);
}
.proof-card-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #000;
}
.proof-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.proof-card-caption {
  padding: 14px 16px;
  border-top: 1px solid var(--ic-rule);
}
.proof-card-value {
  font-size: 16px;
  font-weight: 800;
  color: var(--ic-green);
  letter-spacing: -0.01em;
  margin: 0 0 4px;
  text-shadow: 0 0 16px rgba(0,255,136,0.2);
}
.proof-card-label {
  font-size: 10px;
  color: var(--ic-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
}
@media (max-width: 900px) {
  .proof-grid { grid-template-columns: repeat(2, 1fr); }
  .proof-card.mobile-only { display: block; }
}
@media (max-width: 640px) {
  .proof-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
}

/* Team Brief */
.team-brief {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  margin: 50px 0 0;
}
.team-card { text-align: center; position: relative; }
.team-photo {
  width: 160px; height: 160px;
  margin: 0 auto 20px;
  position: relative;
}
.team-photo::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 240px; height: 240px;
  background: radial-gradient(circle, rgba(0,255,136,0.24) 0%, transparent 60%);
  border-radius: 50%;
  z-index: -1;
}
.team-photo img {
  width: 100%; height: 100%;
  object-fit: contain;
  filter: brightness(1.15);
}
.team-name {
  font-size: 20px;
  font-weight: 800;
  margin: 0 0 6px;
  letter-spacing: -0.02em;
}
.team-role {
  font-size: 11px;
  color: var(--ic-green);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  margin: 0 0 14px;
}
.team-bio {
  font-size: 13px;
  color: var(--ic-muted);
  line-height: 1.55;
}
@media (max-width: 900px) {
  .team-brief { grid-template-columns: 1fr; }
}

