/* ============================================
   IEFYX HOMEPAGE SECTIONS
   ============================================ */

/* ---- Trusted By / Logo strip ---- */
.logos {
  padding: var(--space-10) 0;
  border-top: 1px solid var(--color-glass-border);
  border-bottom: 1px solid var(--color-glass-border);
}

.logos__label {
  text-align: center;
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  margin-bottom: var(--space-8);
}

.logos__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  flex-wrap: wrap;
}

.logos__item {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-text-faint);
  opacity: 0.55;
  transition: var(--transition-fast);
  letter-spacing: -0.01em;
}

.logos__item:hover {
  opacity: 1;
  color: var(--color-text-muted);
}

/* ---- Platform Overview ---- */
.overview {
  position: relative;
}

.overview__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.overview__content .eyebrow { margin-bottom: var(--space-4); }
.overview__content h2 { margin-bottom: var(--space-5); }
.overview__content p { margin-bottom: var(--space-6); font-size: var(--fs-body-lg); }

.overview__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.overview__list-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.overview__check {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(124, 92, 255, 0.15);
  color: var(--color-primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}

.overview__check svg { width: 12px; height: 12px; }

.overview__list-item strong {
  color: var(--color-text);
  display: block;
  margin-bottom: 2px;
  font-size: var(--fs-body-sm);
}

.overview__list-item span {
  font-size: var(--fs-body-sm);
  color: var(--color-text-muted);
}

/* ---- Dashboard mockup card ---- */
.dash-card {
  position: relative;
  border-radius: var(--radius-2xl);
  padding: var(--space-5);
  overflow: hidden;
}

.dash-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-5);
}

.dash-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-body);
  font-weight: 600;
}

.dash-card__tabs {
  display: flex;
  gap: var(--space-2);
}

.dash-card__tab {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-glass-border);
}

.dash-card__tab.is-active {
  background: var(--color-primary);
}

.dash-card__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--color-glass-border);
  margin-bottom: var(--space-3);
}

.dash-card__row-left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.dash-card__severity {
  width: 8px;
  height: 32px;
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

.dash-card__severity--critical { background: var(--color-danger); }
.dash-card__severity--high { background: var(--color-warning); }
.dash-card__severity--medium { background: var(--color-cyan); }
.dash-card__severity--resolved { background: var(--color-success); }

.dash-card__row-title {
  font-size: var(--fs-body-sm);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 2px;
}

.dash-card__row-sub {
  font-size: 0.75rem;
  color: var(--color-text-faint);
  font-family: var(--font-mono);
}

.dash-card__badge {
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.25rem 0.6rem;
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
}

.dash-card__badge--critical { background: rgba(248, 113, 113, 0.12); color: var(--color-danger); }
.dash-card__badge--high { background: rgba(251, 191, 36, 0.12); color: var(--color-warning); }
.dash-card__badge--medium { background: rgba(34, 211, 238, 0.12); color: var(--color-cyan); }
.dash-card__badge--resolved { background: rgba(52, 211, 153, 0.12); color: var(--color-success); }

.dash-card__chart {
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-glass-border);
}

.dash-card__chart-bars {
  display: flex;
  align-items: flex-end;
  gap: var(--space-2);
  height: 80px;
}

.dash-card__bar {
  flex: 1;
  border-radius: var(--radius-sm) var(--radius-sm) 2px 2px;
  background: var(--gradient-primary);
  opacity: 0.85;
}

/* ---- Why ieFyx ---- */
.why {
  background: var(--color-bg-elevated);
  border-top: 1px solid var(--color-glass-border);
  border-bottom: 1px solid var(--color-glass-border);
}

.feature-card {
  padding: var(--space-6);
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: var(--transition-base);
}

.feature-card:hover {
  background: var(--color-glass-hover);
  transform: translateY(-4px);
  border-color: rgba(255, 255, 255, 0.14);
}

.feature-card__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: rgba(124, 92, 255, 0.12);
  color: var(--color-primary-light);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-5);
}

.feature-card__icon svg { width: 22px; height: 22px; }

.feature-card h4 {
  margin-bottom: var(--space-3);
  font-size: 1.15rem;
}

.feature-card p {
  font-size: var(--fs-body-sm);
  line-height: var(--lh-relaxed);
}

/* ---- Key Capabilities (tabs) ---- */
.capabilities__tabs {
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--space-10);
}

.capabilities__tab {
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-full);
  font-size: var(--fs-body-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  background: var(--color-glass);
  border: 1px solid var(--color-glass-border);
  transition: var(--transition-fast);
}

.capabilities__tab.is-active {
  color: #fff;
  background: var(--gradient-primary);
  border-color: transparent;
  box-shadow: var(--shadow-glow);
}

.capabilities__panel {
  display: none;
}

.capabilities__panel.is-active {
  display: grid;
}

.capabilities__panel {
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  align-items: center;
}

.capabilities__panel-content h3 {
  margin-bottom: var(--space-4);
}

.capabilities__panel-content p {
  margin-bottom: var(--space-6);
  font-size: var(--fs-body-lg);
}

.capabilities__feature-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.capabilities__feature-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--fs-body-sm);
  color: var(--color-text);
}

.capabilities__feature-item .dot-icon {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(163, 230, 53, 0.12);
  color: var(--color-lime);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.capabilities__feature-item .dot-icon svg { width: 11px; height: 11px; }

@media (max-width: 992px) {
  .capabilities__panel { grid-template-columns: 1fr; }
  .capabilities__panel-visual { order: -1; }
}

/* ---- Security Testing Lifecycle ---- */
.lifecycle__track {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-4);
  position: relative;
}

.lifecycle__track::before {
  content: '';
  position: absolute;
  top: 28px;
  left: 4%;
  right: 4%;
  height: 1px;
  background: var(--color-glass-border);
  z-index: 0;
}

.lifecycle__step {
  position: relative;
  z-index: 1;
  text-align: center;
}

.lifecycle__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-4);
  color: var(--color-primary-light);
  transition: var(--transition-base);
}

.lifecycle__step:hover .lifecycle__icon {
  background: var(--gradient-primary);
  color: #fff;
  box-shadow: var(--shadow-glow);
  transform: scale(1.08);
}

.lifecycle__icon svg { width: 22px; height: 22px; }

.lifecycle__step h4 {
  font-size: var(--fs-body);
  margin-bottom: var(--space-2);
}

.lifecycle__step p {
  font-size: 0.8125rem;
  line-height: var(--lh-snug);
}

@media (max-width: 992px) {
  .lifecycle__track {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8) var(--space-4);
  }
  .lifecycle__track::before { display: none; }
}

@media (max-width: 560px) {
  .lifecycle__track { grid-template-columns: 1fr; }
}

/* ---- AI-Powered Section ---- */
.ai-section {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  padding: var(--space-12);
  background: linear-gradient(135deg, rgba(124, 92, 255, 0.12) 0%, rgba(15, 20, 36, 0.6) 60%);
  border: 1px solid var(--color-glass-border);
}

.ai-section__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
  position: relative;
  z-index: 1;
}

.ai-section h2 { margin-bottom: var(--space-5); }
.ai-section p { font-size: var(--fs-body-lg); margin-bottom: var(--space-6); }

.ai-feature-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.ai-feature {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
}

.ai-feature__icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  background: rgba(34, 211, 238, 0.12);
  color: var(--color-cyan);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-3);
}

.ai-feature__icon svg { width: 16px; height: 16px; }

.ai-feature h4 {
  font-size: var(--fs-body);
  margin-bottom: var(--space-2);
}

.ai-feature p {
  font-size: 0.8125rem;
  margin-bottom: 0;
}

@media (max-width: 992px) {
  .ai-section { padding: var(--space-8) var(--space-5); }
  .ai-section__layout { grid-template-columns: 1fr; }
  .ai-feature-grid { order: -1; margin-bottom: var(--space-6); }
}

@media (max-width: 560px) {
  .ai-feature-grid { grid-template-columns: 1fr; }
}

/* ---- Vulnerability Mgmt / Exposure Mgmt / Compliance — split rows ---- */
.split-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.split-row.reverse .split-row__visual { order: 2; }

.split-row__content .eyebrow { margin-bottom: var(--space-4); }
.split-row__content h2 { margin-bottom: var(--space-5); }
.split-row__content p { font-size: var(--fs-body-lg); margin-bottom: var(--space-6); }

.split-row__stats {
  display: flex;
  gap: var(--space-8);
  margin-top: var(--space-6);
  flex-wrap: wrap;
}

.split-row__stat-value {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.split-row__stat-label {
  font-size: var(--fs-caption);
  color: var(--color-text-faint);
  font-family: var(--font-mono);
  margin-top: 4px;
}

@media (max-width: 992px) {
  .split-row { grid-template-columns: 1fr; }
  .split-row.reverse .split-row__visual { order: -1; }
}

/* ---- Visual: severity matrix card ---- */
.matrix-card {
  padding: var(--space-6);
  border-radius: var(--radius-2xl);
}

.matrix-card__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
  margin-top: var(--space-5);
}

.matrix-card__cell {
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  font-weight: 600;
  color: var(--color-text-faint);
  border: 1px solid var(--color-glass-border);
}

.matrix-card__cell.lvl-1 { background: rgba(52, 211, 153, 0.08); }
.matrix-card__cell.lvl-2 { background: rgba(34, 211, 238, 0.1); color: var(--color-cyan); }
.matrix-card__cell.lvl-3 { background: rgba(251, 191, 36, 0.12); color: var(--color-warning); }
.matrix-card__cell.lvl-4 { background: rgba(248, 113, 113, 0.16); color: var(--color-danger); }

/* ---- Visual: exposure map card ---- */
.exposure-card {
  padding: var(--space-6);
  border-radius: var(--radius-2xl);
  position: relative;
}

.exposure-card__map {
  position: relative;
  height: 260px;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(124,92,255,0.06), transparent);
  border: 1px solid var(--color-glass-border);
  margin-top: var(--space-5);
  overflow: hidden;
}

.exposure-card__map::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 24px 24px;
}

.exposure-node {
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  z-index: 1;
}

.exposure-node::after {
  content: '';
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  border: 1px solid currentColor;
  opacity: 0.3;
}

.exposure-node--1 { top: 20%; left: 15%; background: var(--color-danger); color: var(--color-danger); box-shadow: 0 0 12px var(--color-danger); }
.exposure-node--2 { top: 55%; left: 60%; background: var(--color-warning); color: var(--color-warning); box-shadow: 0 0 12px var(--color-warning); }
.exposure-node--3 { top: 35%; left: 75%; background: var(--color-cyan); color: var(--color-cyan); box-shadow: 0 0 12px var(--color-cyan); }
.exposure-node--4 { top: 70%; left: 25%; background: var(--color-success); color: var(--color-success); box-shadow: 0 0 12px var(--color-success); }
.exposure-node--5 { top: 12%; left: 50%; background: var(--color-primary-light); color: var(--color-primary-light); box-shadow: 0 0 12px var(--color-primary-light); }

/* ---- Visual: compliance checklist card ---- */
.compliance-card {
  padding: var(--space-6);
  border-radius: var(--radius-2xl);
}

.compliance-card__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-glass-border);
}

.compliance-card__item:last-child { border-bottom: none; }

.compliance-card__item-left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.compliance-card__logo {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  background: var(--color-glass);
  border: 1px solid var(--color-glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--color-primary-light);
}

.compliance-card__name {
  font-size: var(--fs-body-sm);
  font-weight: 600;
}

.compliance-card__sub {
  font-size: 0.75rem;
  color: var(--color-text-faint);
}

.compliance-card__status {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-caption);
  font-family: var(--font-mono);
  color: var(--color-success);
}

.compliance-card__status svg { width: 14px; height: 14px; }

/* ---- Customer Success Stories ---- */
.stories__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.story-card {
  padding: var(--space-6);
  border-radius: var(--radius-xl);
  display: flex;
  flex-direction: column;
}

.story-card__industry {
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary-light);
  margin-bottom: var(--space-4);
}

.story-card__quote {
  font-size: var(--fs-body);
  color: var(--color-text);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-6);
  flex-grow: 1;
}

.story-card__results {
  display: flex;
  gap: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-glass-border);
}

.story-card__result-value {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-text);
}

.story-card__result-label {
  font-size: 0.7rem;
  color: var(--color-text-faint);
  font-family: var(--font-mono);
  margin-top: 2px;
}

@media (max-width: 992px) {
  .stories__grid { grid-template-columns: 1fr; }
}

/* ---- Industry Statistics (counters) ---- */
.stats-band {
  border-radius: var(--radius-2xl);
  border: 1px solid var(--color-glass-border);
  padding: var(--space-10);
  position: relative;
  overflow: hidden;
}

.stats-band__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8);
  position: relative;
  z-index: 1;
}

.stat-counter {
  text-align: center;
}

.stat-counter__value {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4vw, 3.25rem);
  font-weight: 700;
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  line-height: 1;
  margin-bottom: var(--space-2);
}

.stat-counter__label {
  font-size: var(--fs-body-sm);
  color: var(--color-text-muted);
}

@media (max-width: 992px) {
  .stats-band__grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-8) var(--space-4); }
}

@media (max-width: 560px) {
  .stats-band { padding: var(--space-8) var(--space-5); }
  .stats-band__grid { grid-template-columns: 1fr; }
}

/* ---- Testimonials (swiper) ---- */
.testimonials__swiper {
  overflow: hidden;
  margin: 0 calc(var(--space-6) * -1);
  padding: 0 var(--space-6);
}

.testimonial-card {
  padding: var(--space-8);
  border-radius: var(--radius-xl);
  height: 100%;
  display: flex;
  flex-direction: column;
}

.testimonial-card__stars {
  display: flex;
  gap: 4px;
  color: var(--color-warning);
  margin-bottom: var(--space-5);
}

.testimonial-card__stars svg { width: 16px; height: 16px; }

.testimonial-card__quote {
  font-size: var(--fs-body-lg);
  color: var(--color-text);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-6);
  flex-grow: 1;
}

.testimonial-card__author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.testimonial-card__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--gradient-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}

.testimonial-card__name {
  font-size: var(--fs-body-sm);
  font-weight: 600;
  color: var(--color-text);
}

.testimonial-card__role {
  font-size: 0.8125rem;
  color: var(--color-text-faint);
}

.swiper-pagination {
  position: relative;
  margin-top: var(--space-8);
  text-align: center;
}

.swiper-pagination .swiper-pagination-bullet {
  background: var(--color-glass-border);
  opacity: 1;
  width: 8px;
  height: 8px;
}

.swiper-pagination .swiper-pagination-bullet-active {
  background: var(--color-primary);
  width: 24px;
  border-radius: var(--radius-full);
}

/* ---- Integrations ---- */
.integrations__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-4);
  }
.integrations__grid img {
  filter: brightness(0) invert(1);
  width: 75%;
}
.integration-tile {
  aspect-ratio: 1;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--fs-caption);
  font-weight: 600;
  color: var(--color-text-muted);
  transition: var(--transition-base);
  text-align: center;
  padding: var(--space-3);
}

.integration-tile:hover {
  color: var(--color-text);
  border-color: var(--color-primary);
  transform: translateY(-3px);
  box-shadow: var(--shadow-glow);
}

@media (max-width: 992px) {
  .integrations__grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 560px) {
  .integrations__grid { grid-template-columns: repeat(2, 1fr); }
}

/* ---- Awards ---- */
.awards__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

.award-card {
  padding: var(--space-6);
  border-radius: var(--radius-xl);
  text-align: center;
}

.award-card__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(251, 191, 36, 0.1);
  color: var(--color-warning);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-4);
}

.award-card__icon svg { width: 24px; height: 24px; }

.award-card h4 {
  font-size: var(--fs-body);
  margin-bottom: var(--space-2);
}

.award-card p {
  font-size: 0.8125rem;
  margin-bottom: 0;
}

@media (max-width: 992px) {
  .awards__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
  .awards__grid { grid-template-columns: 1fr; }
}

/* ---- CTA Section ---- */
.cta-band {
  position: relative;
  border-radius: var(--radius-2xl);
  padding: var(--space-12);
  text-align: center;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(124, 92, 255, 0.18) 0%, rgba(34, 211, 238, 0.06) 100%);
  border: 1px solid var(--color-glass-border);
}

.cta-band__content {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin: 0 auto;
}

.cta-band h2 {
  margin-bottom: var(--space-4);
}

.cta-band p {
  font-size: var(--fs-body-lg);
  margin-bottom: var(--space-8);
}

.cta-band__actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

.cta-band__glow {
  position: absolute;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(124, 92, 255, 0.35), transparent 70%);
  border-radius: 50%;
  top: -50%;
  left: 50%;
  transform: translateX(-50%);
  filter: blur(40px);
  z-index: 0;
}

@media (max-width: 768px) {
  .cta-band { padding: var(--space-8) var(--space-5); }
}

/* ---- Generic responsive grid overrides for homepage ---- */
@media (max-width: 992px) {
  .overview__layout { grid-template-columns: 1fr; gap: var(--space-8); }
  .overview__visual { order: -1; }
}
