/* ═══════════════════════════════════════════════════════
   HERO  (Concept C — selected)
   ═══════════════════════════════════════════════════════ */
.hero {
  padding: var(--section-hero) 0 64px;
  background: var(--midnight);
  position: relative;
  overflow: hidden;
}

/* Subtle background glow */
.hero::before {
  content: '';
  position: absolute;
  top: -80px; right: -120px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(139,108,247,0.07) 0%, transparent 70%);
  pointer-events: none;
}

.hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 52px;
  align-items: center;
}

.hero__tag {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--violet);
  border-left: 2px solid var(--violet);
  padding-left: 10px;
  margin-bottom: 20px;
  display: block;
}

.hero__h1 {
  font-family: var(--font-heading);
  font-size: 48px;
  font-weight: 700;
  line-height: 1.06;
  color: var(--white);
  margin-bottom: 18px;
}

.hero__h1 em { font-style: normal; color: var(--lime); }

.hero__sub {
  font-size: 14px;
  color: rgba(255,255,255,0.48);
  line-height: 1.78;
  max-width: 440px;
  margin-bottom: 28px;
}

.hero__ctas { display: flex; gap: 10px; flex-wrap: wrap; }

/* Platform panel (right column) */
.hero__panel {
  background: var(--deep);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-card);
  overflow: hidden;
}

.hero__panel-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #0d1520;
  padding: 10px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

.hero__panel-dots { display: flex; gap: 5px; }
.hero__panel-dots span { display: block; width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.15); }

.hero__panel-status {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}

.hero__panel-label {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  padding: 14px 18px 10px;
}

.hero__panel-rows { display: flex; flex-direction: column; }

.hero__panel-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  transition: background var(--ease);
}
.hero__panel-row:last-child { border-bottom: none; }
.hero__panel-row:hover { background: rgba(255,255,255,0.03); }

.hero__panel-row-left { display: flex; flex-direction: column; gap: 3px; }
.hero__panel-pillar {
  font-family: var(--font-heading);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.hero__panel-pillar--lime   { color: var(--lime); }
.hero__panel-pillar--teal   { color: var(--teal); }
.hero__panel-pillar--violet { color: var(--violet); }

.hero__panel-desc { font-size: 10px; color: rgba(255,255,255,0.55); line-height: 1.5; }

.hero__panel-row-right {
  flex-shrink: 0;
  text-align: right;
}

.hero__panel-val {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
}
.hero__panel-val--lime   { color: var(--lime); }
.hero__panel-val--teal   { color: var(--teal); }
.hero__panel-val--violet { color: var(--violet); }

.hero__panel-sub-val { font-family: var(--font-mono); font-size: 9px; color: rgba(255,255,255,0.45); margin-top: 2px; }

/* Mini sparkline bars */
.hero__sparkline { display: flex; align-items: flex-end; gap: 2px; height: 24px; }
.hero__sparkline span { display: block; width: 4px; border-radius: 1px; }

.hero__panel-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 18px;
  background: rgba(0,0,0,0.25);
  border-top: 1px solid rgba(255,255,255,0.1);
}

.hero__panel-live {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: 9px;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.06em;
}

.live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--lime);
  animation: pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 0.5; transform: scale(0.9); }
  50%       { opacity: 1;   transform: scale(1.1); }
}

.hero__panel-time {
  font-family: var(--font-mono);
  font-size: 9px;
  color: rgba(255,255,255,0.35);
  letter-spacing: 0.08em;
}


/* ═══════════════════════════════════════════════════════
   STATS BAR
   ═══════════════════════════════════════════════════════ */
.stats {
  background: var(--midnight);
  border-top: 1px solid rgba(255,255,255,0.07);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding: var(--section-compact) 0;
}

.stats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.stats__item {
  padding: 20px 32px;
  border-right: 1px solid rgba(255,255,255,0.07);
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.stats__item:first-child { padding-left: 0; }
.stats__item:last-child  { border-right: none; }

.stats__num {
  font-family: var(--font-heading);
  font-size: 36px;
  font-weight: 700;
  color: var(--lime);
  line-height: 1;
}

.stats__label {
  font-family: var(--font-heading);
  font-size: 11px;
  font-weight: 700;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.stats__desc {
  font-size: 11px;
  color: rgba(255,255,255,0.28);
  line-height: 1.5;
}


/* ═══════════════════════════════════════════════════════
   BRAND SENTENCE / PULL QUOTE
   ═══════════════════════════════════════════════════════ */
.quote-section {
  background: var(--deep);
  padding: 36px 0 40px;
  position: relative;
  overflow: hidden;
}

.quote-section::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(202,255,112,0.04) 0%, transparent 60%);
  pointer-events: none;
}

.quote__inner { max-width: 860px; }

.quote__mark {
  font-family: var(--font-heading);
  font-size: 64px;
  font-weight: 700;
  color: var(--lime);
  opacity: 0.3;
  line-height: 1;
  margin-bottom: 16px;
  display: block;
}

.quote__label {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--lime);
  margin-bottom: 20px;
  display: block;
}

.quote__text {
  font-family: var(--font-heading);
  font-size: 26px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--white);
}

.quote__text em { font-style: normal; color: var(--lime); }


/* ═══════════════════════════════════════════════════════
   BEFORE / AFTER
   ═══════════════════════════════════════════════════════ */
.compare { background: var(--midnight); padding: var(--section-pad-y) 0; }

.compare__head { text-align: center; margin-bottom: 44px; }

.compare__grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0;
  align-items: stretch;
}

.compare__card {
  border-radius: var(--radius-card);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.compare__card--before {
  background: var(--deep);
  border: 1.5px solid rgba(255,80,80,0.3);
}

.compare__card--after {
  background: var(--deep);
  border: 1px solid rgba(202,255,112,0.15);
}

.compare__card-label {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 8px;
}
.compare__card-label--before { color: rgba(255,80,80,0.7); }
.compare__card-label--after  { color: rgba(202,255,112,0.7); }

.compare__card-label::before {
  content: '';
  display: block;
  width: 6px; height: 6px;
  border-radius: 50%;
  animation: pulse-dot 2s infinite;
}
.compare__card--before .compare__card-label::before { background: rgba(255,80,80,0.8); }
.compare__card--after  .compare__card-label::before { background: var(--lime); }

.compare__points { display: flex; flex-direction: column; gap: 8px; }
.compare__point {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  line-height: 1.5;
}
.compare__point--no  { color: rgba(255,120,120,0.7); }
.compare__point--yes { color: rgba(202,255,112,0.8); }
.compare__point-icon { font-size: 14px; font-weight: 700; flex-shrink: 0; width: 16px; text-align: center; }

/* Arrow between cards */
.compare__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
  padding-top: 100px;
}

/* ═══════════════════════════════════════════════════════
   AI INTELLIGENCE ENGINE  (three pillars)
   ═══════════════════════════════════════════════════════ */
.pillars { background: var(--deep); padding: var(--section-pad-y) 0; }

.pillars__head { text-align: center; margin-bottom: 48px; }

.pillars__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.pillar-card {
  background: var(--midnight);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-card);
  padding: 28px 24px 24px;
  display: flex;
  flex-direction: column;
  gap: 0;
  transition: transform 200ms ease, box-shadow 200ms ease;
  position: relative;
  overflow: hidden;
}
.pillar-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,0.35); }

/* Colour-coded top border — confirmed fix */
.pillar-card--predict  { border-top: 2px solid var(--lime);   }
.pillar-card--aggregate{ border-top: 2px solid var(--teal);   }
.pillar-card--execute  { border-top: 2px solid var(--violet); }

/* Subtle corner glow per pillar */
.pillar-card--predict::before  { content:''; position:absolute; top:0; right:0; width:120px; height:120px; background: radial-gradient(circle at top right, rgba(202,255,112,0.06), transparent 70%); pointer-events:none; }
.pillar-card--aggregate::before{ content:''; position:absolute; top:0; right:0; width:120px; height:120px; background: radial-gradient(circle at top right, rgba(0,201,212,0.06),    transparent 70%); pointer-events:none; }
.pillar-card--execute::before  { content:''; position:absolute; top:0; right:0; width:120px; height:120px; background: radial-gradient(circle at top right, rgba(139,108,247,0.07),  transparent 70%); pointer-events:none; }

.pillar-card__tag {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 14px;
  display: block;
}
.pillar-card--predict  .pillar-card__tag { color: var(--lime); }
.pillar-card--aggregate .pillar-card__tag { color: var(--teal); }
.pillar-card--execute  .pillar-card__tag { color: var(--violet); }

.pillar-card__icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
  flex-shrink: 0;
}
.pillar-card--predict  .pillar-card__icon { background: rgba(202,255,112,0.1); color: var(--lime); }
.pillar-card--aggregate .pillar-card__icon { background: rgba(0,201,212,0.1);   color: var(--teal); }
.pillar-card--execute  .pillar-card__icon { background: rgba(139,108,247,0.1); color: var(--violet); }

.pillar-card__title {
  font-family: var(--font-heading);
  font-size: 18px;
  font-weight: 700;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 10px;
}

.pillar-card__body {
  font-size: 13px;
  color: rgba(255,255,255,0.48);
  line-height: 1.7;
  flex: 1;
  margin-bottom: 20px;
}

.pillar-card__status {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 8px 12px;
  border-radius: 6px;
  margin-bottom: 16px;
}
.pillar-card--predict  .pillar-card__status { background: rgba(202,255,112,0.06); color: rgba(202,255,112,0.7); }
.pillar-card--aggregate .pillar-card__status { background: rgba(0,201,212,0.06);   color: rgba(0,201,212,0.7); }
.pillar-card--execute  .pillar-card__status { background: rgba(139,108,247,0.06); color: rgba(139,108,247,0.7); }

.pillar-card__modules {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 14px;
}

.pillar-card__module {
  font-size: 11px;
  color: rgba(255,255,255,0.3);
  padding: 5px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  display: flex; align-items: center; gap: 7px;
}
.pillar-card__module:last-child { border-bottom: none; }
.pillar-card__module::before { content: ''; display: block; width: 4px; height: 4px; border-radius: 50%; background: currentColor; opacity: 0.5; flex-shrink: 0; }


/* ═══════════════════════════════════════════════════════
   EXECUTE — STAKEHOLDER GRID
   ═══════════════════════════════════════════════════════ */
.stakeholders { background: var(--midnight); padding: var(--section-pad-y) 0; }

.stakeholders__head { margin-bottom: 36px; }

.stakeholders__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}

.stakeholder-card {
  background: var(--deep);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-card);
  padding: 20px 16px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  transition: transform var(--ease), border-color var(--ease);
}
.stakeholder-card:hover { transform: translateY(-3px); border-color: rgba(255,255,255,0.14); }

.stakeholder-card__icon {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}

.stakeholder-card__name {
  font-family: var(--font-heading);
  font-size: 12px;
  font-weight: 700;
  color: var(--white);
}

.stakeholder-card__desc {
  font-size: 10px;
  color: rgba(255,255,255,0.38);
  line-height: 1.6;
}

.stakeholder-card__badge {
  font-family: var(--font-mono);
  font-size: 8px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: var(--radius-tag);
}


/* ═══════════════════════════════════════════════════════
   SUCCESS STORIES (preview cards)
   ═══════════════════════════════════════════════════════ */
.stories { background: var(--midnight); padding: var(--section-pad-y) 0; }

.stories__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 28px;
  gap: 24px;
}

.stories__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.story-card {
  background: var(--deep);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-card);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color var(--ease), transform var(--ease);
}
.story-card:hover { border-color: rgba(255,255,255,0.14); transform: translateY(-2px); }
.story-card:focus-within { border-color: rgba(202,255,112,0.25); }

.story-card__partner {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.25);
}

.story-card__title {
  font-family: var(--font-heading);
  font-size: 15px;
  font-weight: 700;
  color: var(--white);
  line-height: 1.3;
}

.story-card__body {
  font-size: 12px;
  color: rgba(255,255,255,0.42);
  line-height: 1.65;
  flex: 1;
}

.story-card__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.story-card__tag {
  font-family: var(--font-mono);
  font-size: 8px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--teal);
  background: rgba(0,201,212,0.07);
  border: 1px solid rgba(0,201,212,0.15);
  border-radius: 100px;
  padding: 3px 8px;
}


/* ═══════════════════════════════════════════════════════
   GLOBAL DATA MAP
   ═══════════════════════════════════════════════════════ */
.map-section{position:relative;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 40px 48px;overflow:hidden;}
.map-header{text-align:center;margin-bottom:36px;position:relative;z-index:10;}
.map-tag{font-family:var(--font-heading);font-size:10px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--lime);margin-bottom:14px;}
.map-title{font-family:var(--font-heading);font-size:42px;font-weight:700;line-height:1.1;margin-bottom:12px;}
.map-title em{font-style:normal;color:var(--lime);}
.map-subtitle{font-size:15px;color:rgba(255,255,255,0.45);max-width:560px;margin:0 auto;line-height:1.7;}
.map-canvas-wrap{position:relative;width:100%;max-width:1200px;aspect-ratio:2.4/1;margin:0 auto 16px;}
.map-canvas-wrap canvas{width:100%;height:100%;display:block;}
.timeline-wrap{width:100%;max-width:1200px;margin:0 auto 32px;position:relative;z-index:10;}
.timeline-track{position:relative;height:48px;cursor:pointer;user-select:none;}
.timeline-bg{position:absolute;top:20px;left:0;right:0;height:6px;background:rgba(255,255,255,0.04);border-radius:3px;overflow:hidden;}
.timeline-filled{height:100%;border-radius:3px;background:linear-gradient(90deg,rgba(139,108,247,0.5) 0%,rgba(0,201,212,0.5) 45%,rgba(0,201,212,0.5) 60%,rgba(202,255,112,0.6) 85%,rgba(202,255,112,0.6) 100%);width:0%;transition:width 2.5s cubic-bezier(0.22,1,0.36,1);}
.timeline-future{position:absolute;top:20px;right:0;height:6px;width:13%;background:repeating-linear-gradient(90deg,rgba(202,255,112,0.12) 0px,rgba(202,255,112,0.12) 4px,transparent 4px,transparent 8px);border-radius:0 3px 3px 0;}
.timeline-head{position:absolute;top:12px;width:14px;height:22px;background:var(--lime);border-radius:4px;left:0%;transition:left 2.5s cubic-bezier(0.22,1,0.36,1);box-shadow:0 0 12px rgba(202,255,112,0.4);display:flex;align-items:center;justify-content:center;}
.timeline-head::after{content:'';width:2px;height:8px;background:var(--midnight);border-radius:1px;}
.timeline-markers{position:absolute;top:0;left:0;right:0;height:48px;}
.timeline-marker{position:absolute;top:0;display:flex;flex-direction:column;align-items:center;}
.timeline-marker .tick{width:1px;height:8px;background:rgba(255,255,255,0.12);margin-bottom:2px;}
.timeline-marker .yr{font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,0.4);}
.timeline-marker.now .yr{color:var(--lime);font-weight:600;font-size:10px;}
.timeline-marker.now .tick{background:var(--lime);height:10px;}
.timeline-marker.future .yr{color:rgba(202,255,112,0.25);}
.timeline-marker.future .tick{background:rgba(202,255,112,0.1);}
.timeline-milestone{position:absolute;top:19px;width:8px;height:8px;border-radius:50%;background:var(--teal);border:2px solid var(--midnight);}
.timeline-milestone .tip{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:8px;color:rgba(255,255,255,0.35);white-space:nowrap;opacity:0;transition:opacity 0.2s;pointer-events:none;}
.timeline-track:hover .timeline-milestone .tip{opacity:1;}
.timeline-labels{display:flex;justify-content:space-between;margin-top:4px;padding:0 2px;}
.timeline-caption{font-family:var(--font-mono);font-size:10px;color:rgba(255,255,255,0.25);}
.timeline-caption span{color:var(--teal);}
.timeline-future-label{font-family:var(--font-mono);font-size:10px;color:rgba(202,255,112,0.3);}
.counters{display:flex;gap:56px;justify-content:center;flex-wrap:wrap;position:relative;z-index:10;}
.counter-item{text-align:center;min-width:160px;}
.counter-value{font-family:var(--font-heading);font-size:44px;font-weight:700;letter-spacing:-1px;color:var(--lime);}
.counter-label{font-family:var(--font-heading);font-size:11px;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:1.8px;margin-top:4px;}
.counter-sub{font-size:11px;color:rgba(255,255,255,0.22);margin-top:2px;font-family:var(--font-mono);}
.data-legend{display:flex;gap:28px;justify-content:center;margin-top:28px;position:relative;z-index:10;}
.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:rgba(255,255,255,0.4);font-family:var(--font-mono);}
.legend-dot{width:8px;height:8px;border-radius:2px;}

@media(max-width:768px){
  .map-section{padding:48px 16px;}
  .map-title{font-size:28px;}
  .map-subtitle{font-size:13px;max-width:100%;}
  .map-canvas-wrap{aspect-ratio:1.4/1;margin-bottom:12px;}
  .counters{gap:24px;}
  .counter-item{min-width:100px;}
  .counter-value{font-size:32px;}
  .counter-label{font-size:9px;letter-spacing:1px;}
  .counter-sub{font-size:9px;}
  .data-legend{gap:14px;flex-wrap:wrap;}
  .legend-item{font-size:9px;}
  .timeline-labels{flex-direction:column;gap:4px;align-items:flex-start;}
  .timeline-future-label{align-self:flex-end;}
  .timeline-marker .yr{font-size:7px;}
}
@media(max-width:480px){
  .map-section{padding:32px 12px;}
  .map-tag{font-size:9px;margin-bottom:10px;}
  .map-title{font-size:24px;}
  .map-subtitle{font-size:12px;}
  .map-canvas-wrap{aspect-ratio:1.2/1;}
  .counters{gap:16px;}
  .counter-value{font-size:26px;}
  .counter-label{font-size:8px;}
  .data-legend{gap:10px;}
  .legend-item{font-size:8px;}
  .timeline-caption{font-size:8px;}
  .timeline-future-label{font-size:8px;}
}


/* ═══════════════════════════════════════════════════════
   CLIENT SHOWCASE
   ═══════════════════════════════════════════════════════ */
.clients {
  background: var(--midnight);
  padding: 48px 0;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.clients__tag {
  font-family: var(--font-heading);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--lime);
  text-align: center;
  margin-bottom: 10px;
}
.clients__title {
  font-family: var(--font-heading);
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  color: rgba(255,255,255,0.8);
  margin-bottom: 40px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.3;
}
.clients__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
  max-width: 1000px;
  margin: 0 auto;
}
.client-card {
  background: var(--deep);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 90px;
  transition: border-color 0.2s, background 0.2s;
}
.client-card:hover {
  border-color: rgba(202,255,112,0.15);
  background: rgba(13,21,32,0.8);
}
.client-card__logo-wrap {
  height: 40px;
  display: flex;
  align-items: center;
  margin-bottom: 10px;
}
.client-card__logo {
  max-height: 36px;
  max-width: 140px;
  filter: brightness(0) invert(1);
  opacity: 0.55;
  transition: opacity 0.2s;
  object-fit: contain;
}
.client-card:hover .client-card__logo { opacity: 0.85; }
/* Per-logo size adjustments */
.client-card__logo--unilever { max-height: 28px; }
.client-card__logo--nri-naro { max-height: 24px; }
.client-card__logo--sapporo { max-height: 42px; max-width: 160px; }
.client-card__geo {
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: rgba(255,255,255,0.25);
}
.client-card__flag {
  width: 16px;
  height: 11px;
  border-radius: 1px;
}

@media (max-width: 768px) {
  .clients { padding: 48px 0; }
  .clients__title { font-size: 20px; padding: 0 16px; }
  .clients__grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; padding: 0 16px; }
  .client-card { padding: 16px; }
  .client-card__logo { max-height: 26px; }
}


/* ═══════════════════════════════════════════════════════
   CTA BOX  (_cta-global)
   ═══════════════════════════════════════════════════════ */
.cta-section { background: var(--midnight); padding: var(--section-pad-y) 0 64px; }

.cta-box {
  max-width: 680px;
  margin: 0 auto;
  background: var(--deep);
  border: 1px solid rgba(202,255,112,0.15);
  border-radius: 16px;
  padding: 56px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cta-box::before {
  content: '';
  position: absolute; top: -60px; left: 50%;
  transform: translateX(-50%);
  width: 300px; height: 200px;
  background: radial-gradient(circle, rgba(202,255,112,0.06) 0%, transparent 70%);
  pointer-events: none;
}

.cta-box__headline {
  font-family: var(--font-heading);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.15;
  color: var(--white);
  margin-bottom: 14px;
  position: relative;
}

.cta-box__sub {
  font-size: 14px;
  color: rgba(255,255,255,0.42);
  margin-bottom: 28px;
  position: relative;
}

.cta-box .btn-primary {
  font-size: 13px;
  padding: 12px 28px;
  position: relative;
}


/* ═══════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════ */
@keyframes flow-dash {
  0%   { stroke-dashoffset: 20; }
  100% { stroke-dashoffset: 0; }
}
.flow-path { animation: flow-dash 1.5s linear infinite; }

@keyframes rotate-orbit {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.rotate-orbit { animation: rotate-orbit 12s linear infinite; transform-origin: center; }


/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .hero__inner { grid-template-columns: 1fr; }
  .hero__panel { display: none; }
  .hero__h1 { font-size: 38px; }

  .pillars__grid { grid-template-columns: 1fr; }
  .stakeholders__grid { grid-template-columns: repeat(3, 1fr); }
  .stories__grid { grid-template-columns: repeat(2, 1fr); }
  .compare__grid { grid-template-columns: 1fr; gap: 16px; }
  .compare__arrow { padding: 0; transform: rotate(90deg); }
  .stats__grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═══════════════════════════════════════════════════════
   FAQ SECTION
   ═══════════════════════════════════════════════════════ */
.faq-section {
  padding: 80px 0;
  background: var(--midnight);
}
.faq__head { margin-bottom: 48px; }
.faq__grid {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.faq__item {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 8px;
  overflow: hidden;
}
.faq__item[open] { background: rgba(255,255,255,0.05); }
.faq__q {
  padding: 20px 24px;
  font-family: var(--font-head, 'Space Grotesk', system-ui, sans-serif);
  font-size: 17px;
  font-weight: 600;
  color: rgba(255,255,255,0.92);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.faq__q::-webkit-details-marker { display: none; }
.faq__q::after {
  content: '+';
  font-size: 20px;
  color: var(--lime);
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.faq__item[open] .faq__q::after {
  content: '−';
}
.faq__a {
  padding: 0 24px 20px;
}
.faq__a p {
  font-size: 15px;
  line-height: 1.7;
  color: rgba(255,255,255,0.65);
  margin: 0;
}

@media (max-width: 767px) {
  :root { --container-pad: 20px; }
  .hero__h1 { font-size: 32px; }
  .h2 { font-size: 26px; }
  .stats__num { font-size: 28px; }
  .stakeholders__grid { grid-template-columns: repeat(2, 1fr); }
  .stories__grid { grid-template-columns: 1fr; }
  .stories__head { flex-direction: column; align-items: flex-start; }
  .cta-box { padding: 40px 28px; }
  .cta-box__headline { font-size: 26px; }
  .faq-section { padding: 56px 0; }
  .faq__q { font-size: 15px; padding: 16px 20px; }
  .faq__a { padding: 0 20px 16px; }
}