/* ═══════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════ */
.sh-hero {
  padding: var(--hero-y) 0 64px;
  background: var(--midnight);
  position: relative;
  overflow: hidden;
}
.sh-hero::before {
  content: ''; position: absolute; top: -100px; right: -100px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(139,108,247,0.07) 0%, transparent 65%);
  pointer-events: none;
}
.sh-hero__inner {
  display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: center;
}
.sh-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;
}
.sh-hero__h1 {
  font-family: var(--font-heading); font-size: 44px; font-weight: 700;
  line-height: 1.06; color: var(--white); margin-bottom: 18px;
}
.sh-hero__h1 em { font-style: normal; color: var(--lime); }
.sh-hero__sub {
  font-size: 14px; color: rgba(255,255,255,0.48); line-height: 1.78;
  max-width: 440px; margin-bottom: 28px;
}
.sh-hero__ctas { display: flex; gap: 10px; flex-wrap: wrap; }

/* Animation card wrapper */
.sh-hero__anim-wrap {
  background: var(--deep);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-card);
  overflow: hidden;
  position: relative;
}
.sh-hero__anim-bar {
  display: flex; align-items: center; justify-content: space-between;
  background: #060b11; padding: 9px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.sh-hero__anim-dots { display: flex; gap: 5px; }
.sh-hero__anim-dots span { display: block; width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,0.07); }
.sh-hero__anim-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.18); }
#hero-canvas { display: block; width: 100%; height: auto; }

/* Phase bar inside animation card */
.sh-phase-bar {
  display: flex; align-items: center; justify-content: center; gap: 20px;
  padding: 10px 16px;
  background: rgba(6,11,17,0.8);
  border-top: 1px solid rgba(255,255,255,0.06);
}
.sh-phase-item {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 8px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.2); transition: color 0.4s ease;
}
.sh-phase-item.active.lime   { color: var(--lime); }
.sh-phase-item.active.teal   { color: var(--teal); }
.sh-phase-item.active.violet { color: var(--violet); }
.sh-phase-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: rgba(255,255,255,0.12);
  transition: background 0.4s ease, box-shadow 0.4s ease;
}
.sh-phase-item.active.lime   .sh-phase-dot { background: var(--lime);   box-shadow: 0 0 7px rgba(202,255,112,0.6); }
.sh-phase-item.active.teal   .sh-phase-dot { background: var(--teal);   box-shadow: 0 0 7px rgba(0,201,212,0.6); }
.sh-phase-item.active.violet .sh-phase-dot { background: var(--violet); box-shadow: 0 0 7px rgba(139,108,247,0.6); }
.sh-phase-divider { width: 1px; height: 12px; background: rgba(255,255,255,0.07); }

/* ═══════════════════════════════════════════════════
   ROADMAP TO INTELLIGENCE
   ═══════════════════════════════════════════════════ */
.roadmap { background: var(--deep); padding: var(--section-y) 0 calc(var(--section-y) + 16px); }

.roadmap__head { text-align: center; margin-bottom: 56px; }
.roadmap__head .h2 { margin-bottom: 10px; }

/* Timeline */
.roadmap__timeline {
  position: relative; max-width: 860px; margin: 0 auto 56px;
  display: grid; grid-template-columns: 1fr 1fr 1fr;
}

/* Connecting track behind the dots */
.roadmap__track {
  position: absolute; top: 24px; left: calc(33.33% / 2); right: calc(33.33% / 2);
  height: 2px; background: rgba(255,255,255,0.07); z-index: 0;
}
.roadmap__track-fill {
  position: absolute; top: 0; left: 0; width: 50%; height: 100%;
  background: linear-gradient(to right, var(--lime), var(--teal));
}
.roadmap__track-dash {
  position: absolute; top: 0; left: 50%; right: 0; height: 100%;
  background: repeating-linear-gradient(
    to right, rgba(0,201,212,0.4) 0px, rgba(0,201,212,0.4) 6px,
    transparent 6px, transparent 12px
  );
}

/* Animated travelling dot */
@keyframes travel { 0%{ left: 0; } 100%{ left: 100%; } }
.roadmap__traveller {
  position: absolute; top: -3px; width: 8px; height: 8px; border-radius: 50%;
  background: var(--lime); box-shadow: 0 0 12px rgba(202,255,112,0.7);
  animation: travel 5s ease-in-out infinite alternate;
}

/* Timeline step */
.roadmap__step { display: flex; flex-direction: column; align-items: center; gap: 16px; position: relative; z-index: 1; padding: 0 16px; }

.roadmap__step-circle {
  width: 48px; height: 48px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  border: 2px solid; flex-shrink: 0;
  background: var(--deep);
}
.roadmap__step--lime .roadmap__step-circle   { color: var(--lime);   border-color: var(--lime);   background: rgba(202,255,112,0.07); }
.roadmap__step--teal .roadmap__step-circle   { color: var(--teal);   border-color: var(--teal);   background: rgba(0,201,212,0.07); }
.roadmap__step--violet .roadmap__step-circle { color: var(--violet); border-color: var(--violet); background: rgba(139,108,247,0.07); }

.roadmap__step-content { text-align: center; }

.roadmap__step-period {
  font-family: var(--font-mono); font-size: 8px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.22); margin-bottom: 6px; display: block;
}
.roadmap__step--lime .roadmap__step-period   { color: rgba(202,255,112,0.5); }
.roadmap__step--teal .roadmap__step-period   { color: rgba(0,201,212,0.5); }
.roadmap__step--violet .roadmap__step-period { color: rgba(139,108,247,0.5); }

.roadmap__step-title { font-family: var(--font-heading); font-size: 14px; font-weight: 700; color: var(--white); margin-bottom: 6px; }
.roadmap__step-body  { font-size: 11px; color: rgba(255,255,255,0.4); line-height: 1.6; }

/* PoC + Subscription cards */
.roadmap__cards { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 860px; margin: 0 auto; }

.roadmap-card {
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-card); padding: 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.roadmap-card--lime   { border-left: 3px solid var(--lime);   }
.roadmap-card--teal   { border-left: 3px solid var(--teal);   }

.roadmap-card__badge {
  font-family: var(--font-mono); font-size: 8px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  padding: 3px 9px; border-radius: var(--radius-btn); align-self: flex-start;
}
.roadmap-card--lime .roadmap-card__badge { color: var(--lime); border: 1px solid rgba(202,255,112,0.3); background: rgba(202,255,112,0.06); }
.roadmap-card--teal .roadmap-card__badge { color: var(--teal); border: 1px solid rgba(0,201,212,0.3); background: rgba(0,201,212,0.06); }

.roadmap-card__title { font-family: var(--font-heading); font-size: 18px; font-weight: 700; color: var(--white); }
.roadmap-card__body  { font-size: 13px; color: rgba(255,255,255,0.48); line-height: 1.7; }

.roadmap-card__period {
  font-family: var(--font-mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding-top: 12px; border-top: 1px solid rgba(255,255,255,0.07);
  margin-top: auto;
}
.roadmap-card--lime .roadmap-card__period { color: rgba(202,255,112,0.5); }
.roadmap-card--teal .roadmap-card__period { color: rgba(0,201,212,0.5); }

/* ═══════════════════════════════════════════════════
   PILLAR SECTIONS — shared
   ═══════════════════════════════════════════════════ */
.pillar { padding: var(--section-y) 0; position: relative; overflow: hidden; }
.pillar--predict   { background: var(--midnight); }
.pillar--aggregate { background: var(--deep); }
.pillar--execute   { background: var(--midnight); }

.pillar__grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 56px; align-items: start;
}
.pillar__grid--reverse { direction: rtl; }
.pillar__grid--reverse > * { direction: ltr; }

.pillar__label {
  font-family: var(--font-mono); font-size: 8px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
}
.pillar__label::before { content: ''; display: block; width: 20px; height: 1px; }
.pillar--predict   .pillar__label { color: var(--lime);   }
.pillar--aggregate .pillar__label { color: var(--teal);   }
.pillar--execute   .pillar__label { color: var(--violet); }
.pillar--predict   .pillar__label::before { background: var(--lime); }
.pillar--aggregate .pillar__label::before { background: var(--teal); }
.pillar--execute   .pillar__label::before { background: var(--violet); }

.pillar__h2 { font-family: var(--font-heading); font-size: 34px; font-weight: 700; line-height: 1.1; color: var(--white); margin-bottom: 14px; }
.pillar__h2 em { font-style: normal; }
.pillar--predict   .pillar__h2 em { color: var(--lime); }
.pillar--aggregate .pillar__h2 em { color: var(--teal); }
.pillar--execute   .pillar__h2 em { color: var(--violet); }

.pillar__body { font-size: 14px; color: rgba(255,255,255,0.5); line-height: 1.78; margin-bottom: 28px; }

/* Feature list */
.pillar__features { display: flex; flex-direction: column; gap: 0; }

.pillar__feature {
  display: flex; gap: 14px; padding: 18px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.pillar__feature:last-child { border-bottom: none; }

.pillar__feature-icon {
  width: 36px; height: 36px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 2px;
}
.pillar--predict   .pillar__feature-icon { background: rgba(202,255,112,0.09); color: var(--lime); }
.pillar--aggregate .pillar__feature-icon { background: rgba(0,201,212,0.09);   color: var(--teal); }
.pillar--execute   .pillar__feature-icon { background: rgba(139,108,247,0.09); color: var(--violet); }

.pillar__feature-name { font-family: var(--font-heading); font-size: 13px; font-weight: 700; color: var(--white); margin-bottom: 4px; }
.pillar__feature-desc { font-size: 12px; color: rgba(255,255,255,0.4); line-height: 1.6; }

/* "What you receive" callout strip */
.pillar__strip {
  margin-top: 56px; padding: 16px 24px;
  background: var(--surface); border-radius: 8px;
  border-left: 3px solid;
}
.pillar--predict   .pillar__strip { border-color: var(--lime); }
.pillar--aggregate .pillar__strip { border-color: var(--teal); }
.pillar--execute   .pillar__strip { border-color: var(--violet); }

.pillar__strip-label {
  font-family: var(--font-mono); font-size: 8px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.25); margin-bottom: 8px; display: block;
}
.pillar__strip-text {
  font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.04em; line-height: 1.8;
  color: rgba(255,255,255,0.55);
}
.pillar--predict   .pillar__strip-text { color: rgba(202,255,112,0.65); }
.pillar--aggregate .pillar__strip-text { color: rgba(0,201,212,0.65); }
.pillar--execute   .pillar__strip-text { color: rgba(139,108,247,0.65); }

/* ── PREDICT dashboard card ── */
.dash-card {
  background: var(--deep); border-radius: var(--radius-card);
  border: 1px solid rgba(255,255,255,0.07); overflow: hidden;
}
.pillar--predict   .dash-card { border-top: 2px solid var(--lime); }
.pillar--aggregate .dash-card { border-top: 2px solid var(--teal); }
.pillar--execute   .dash-card { border-top: 2px solid var(--violet); }

.dash-card__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 18px; background: rgba(0,0,0,0.2);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.dash-card__title-row { display: flex; align-items: center; gap: 8px; }
.dash-card__title { font-family: var(--font-mono); font-size: 9px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.35); }
.dash-card__live { display: flex; align-items: center; gap: 5px; font-family: var(--font-mono); font-size: 8px; color: rgba(255,255,255,0.25); }
.live-dot { width: 6px; height: 6px; border-radius: 50%; animation: pulse-dot 2s ease-in-out infinite; }
.live-dot--lime   { background: var(--lime); }
.live-dot--teal   { background: var(--teal); }
.live-dot--violet { background: var(--violet); }
@keyframes pulse-dot { 0%,100%{opacity:0.5;transform:scale(0.9);}50%{opacity:1;transform:scale(1.1);} }

.dash-card__body { padding: 20px 18px; display: flex; flex-direction: column; gap: 16px; }

/* Big metric */
.dash-metric { display: flex; flex-direction: column; gap: 4px; }
.dash-metric__label { font-family: var(--font-mono); font-size: 8px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.3); }
.dash-metric__val { font-family: var(--font-heading); font-size: 40px; font-weight: 700; line-height: 1; color: var(--white); display: flex; align-items: baseline; gap: 8px; }
.dash-metric__unit { font-family: var(--font-mono); font-size: 13px; font-weight: 600; }
.dash-metric--lime .dash-metric__unit   { color: var(--lime); }
.dash-metric--teal .dash-metric__unit   { color: var(--teal); }
.dash-metric--violet .dash-metric__unit { color: var(--violet); }
.dash-metric__badge { font-family: var(--font-mono); font-size: 9px; font-weight: 600; padding: 2px 8px; border-radius: 100px; margin-left: auto; }
.dash-metric--lime   .dash-metric__badge { color: var(--lime);   background: rgba(202,255,112,0.1); }
.dash-metric--teal   .dash-metric__badge { color: var(--teal);   background: rgba(0,201,212,0.1); }
.dash-metric--violet .dash-metric__badge { color: var(--violet); background: rgba(139,108,247,0.1); }

/* Confidence bar */
.dash-bar { height: 4px; background: rgba(255,255,255,0.07); border-radius: 2px; overflow: hidden; }
.dash-bar__fill { height: 100%; border-radius: 2px; transition: width 1s ease; }
.dash-bar__fill--lime   { background: var(--lime); }
.dash-bar__fill--teal   { background: var(--teal); }
.dash-bar__fill--violet { background: var(--violet); }

/* Mini tiles */
.dash-tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.dash-tile { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); border-radius: 8px; padding: 12px; }
.dash-tile__label { font-family: var(--font-mono); font-size: 8px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.28); margin-bottom: 4px; display: block; }
.dash-tile__val { font-family: var(--font-mono); font-size: 18px; font-weight: 600; color: var(--white); }

/* Heatmap visual (CSS-generated) */
.dash-heatmap {
  border-radius: 8px; overflow: hidden; position: relative;
  height: 100px; min-height: 100px;
  background: linear-gradient(135deg,
    rgba(202,255,112,0.04) 0%,
    rgba(251,146,60,0.08) 30%,
    rgba(202,255,112,0.12) 55%,
    rgba(251,146,60,0.06) 75%,
    rgba(202,255,112,0.04) 100%
  );
  border: 1px solid rgba(255,255,255,0.06);
}
/* Field row pattern */
.dash-heatmap::before {
  content: '';
  position: absolute; inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent 0px, transparent 6px,
    rgba(202,255,112,0.05) 6px, rgba(202,255,112,0.05) 7px
  );
}
.dash-heatmap__overlay {
  position: absolute; inset: 0; padding: 10px 12px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.dash-heatmap__coords { font-family: var(--font-mono); font-size: 8px; color: rgba(255,255,255,0.4); letter-spacing: 0.08em; }
.dash-heatmap__alert { display: flex; align-items: center; gap: 5px; }
.dash-heatmap__alert-line { display: block; width: 10px; height: 1px; background: var(--lime); }
.dash-heatmap__alert-text { font-family: var(--font-mono); font-size: 8px; color: var(--lime); letter-spacing: 0.1em; text-transform: uppercase; }

/* Harvest countdown badge */
.dash-countdown {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; border-radius: 8px;
  background: rgba(251,146,60,0.06); border: 1px solid rgba(251,146,60,0.2);
}
.dash-countdown__label { font-family: var(--font-mono); font-size: 9px; color: rgba(255,255,255,0.4); letter-spacing: 0.1em; text-transform: uppercase; }
.dash-countdown__val { font-family: var(--font-heading); font-size: 12px; font-weight: 700; color: #FB923C; }

/* ── AGGREGATE dashboard cards ── */
.agg-cards { display: flex; flex-direction: column; gap: 12px; }

.agg-card {
  background: var(--midnight); border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-card); overflow: hidden;
  border-top: 2px solid var(--teal);
}

.agg-card__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 18px; background: rgba(0,0,0,0.15);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

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

.agg-card__body { padding: 16px 18px; display: flex; flex-direction: column; gap: 10px; }

.risk-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 12px;
}
.risk-row:last-child { border-bottom: none; }
.risk-row__zone { color: rgba(255,255,255,0.55); }
.risk-row__status { font-family: var(--font-mono); font-size: 9px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; }
.risk-row__status--stable  { color: var(--lime); }
.risk-row__status--alert   { color: #FB923C; }
.risk-row__status--harvest { color: var(--teal); }

.agg-card__action {
  margin: 0 18px 14px; padding: 10px 14px; border-radius: 8px;
  background: rgba(202,255,112,0.05); border: 1px solid rgba(202,255,112,0.15);
  display: flex; align-items: center; justify-content: space-between;
}
.agg-card__action-text { font-size: 11px; color: rgba(255,255,255,0.5); }
.agg-card__action-badge { font-family: var(--font-mono); font-size: 9px; font-weight: 700; color: var(--lime); }

/* Trace log */
.trace-log {
  background: rgba(0,0,0,0.3); border-radius: 6px; padding: 12px 14px;
  font-family: var(--font-mono); font-size: 10px;
  display: flex; flex-direction: column; gap: 5px;
}
.trace-row { display: flex; gap: 12px; }
.trace-key { color: var(--teal); min-width: 44px; }
.trace-val { color: rgba(255,255,255,0.6); }
.trace-verified {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 8px; margin-top: 4px;
  border-top: 1px solid rgba(255,255,255,0.07);
  font-size: 9px; font-weight: 700; color: var(--teal);
}

/* ── EXECUTE section ── */
.exec__left { display: flex; flex-direction: column; gap: 24px; }

.line-callout {
  background: rgba(139,108,247,0.05);
  border: 1px solid rgba(139,108,247,0.15);
  border-radius: var(--radius-card); padding: 20px;
  display: flex; gap: 16px; align-items: flex-start;
}
.line-callout__icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: rgba(139,108,247,0.1); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: var(--violet);
}
.line-callout__label { font-family: var(--font-mono); font-size: 8px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.25); display: block; margin-bottom: 4px; }
.line-callout__title { font-family: var(--font-heading); font-size: 13px; font-weight: 700; color: var(--white); margin-bottom: 4px; }
.line-callout__body { font-size: 12px; color: rgba(255,255,255,0.42); line-height: 1.6; }

.exec__stat {
  font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.08em; color: rgba(139,108,247,0.7);
  padding: 10px 14px; border-radius: 8px;
  background: rgba(139,108,247,0.05); border: 1px solid rgba(139,108,247,0.12);
}

/* Machine queue card */
.machine-card {
  background: var(--deep); border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--radius-card); overflow: hidden; border-top: 2px solid var(--violet);
  margin-bottom: 16px;
}
.machine-card__header { display: flex; align-items: center; justify-content: space-between; padding: 12px 18px; background: rgba(0,0,0,0.2); border-bottom: 1px solid rgba(255,255,255,0.06); }
.machine-card__title  { font-family: var(--font-mono); font-size: 9px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.35); }
.machine-card__lops   { font-family: var(--font-mono); font-size: 8px; padding: 3px 8px; border-radius: 100px; color: var(--violet); background: rgba(139,108,247,0.08); border: 1px solid rgba(139,108,247,0.2); }
.machine-card__body   { padding: 16px 18px; display: flex; flex-direction: column; gap: 12px; }

.machine-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; border-radius: 8px;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.05);
}
.machine-row--active { border-right: 3px solid var(--violet); background: rgba(139,108,247,0.04); }

.machine-row__icon { flex-shrink: 0; color: var(--violet); opacity: 0.7; }
.machine-row__icon--dim { color: rgba(255,255,255,0.2); }

.machine-row__info { flex: 1; min-width: 0; }
.machine-row__name { font-size: 12px; font-weight: 600; color: var(--white); margin-bottom: 6px; display: flex; align-items: center; justify-content: space-between; }
.machine-row__route { font-family: var(--font-mono); font-size: 9px; color: var(--violet); }
.machine-row__route--dim { color: rgba(255,255,255,0.25); }

.machine-row__bar { height: 3px; background: rgba(255,255,255,0.07); border-radius: 2px; overflow: hidden; }
.machine-row__bar-fill { height: 100%; border-radius: 2px; }
.machine-row__bar-fill--violet { background: var(--violet); }
.machine-row__bar-fill--dim    { background: rgba(255,255,255,0.1); width: 0%; }

.machine-row__pct { font-family: var(--font-mono); font-size: 9px; color: rgba(255,255,255,0.3); flex-shrink: 0; }

.machine-card__note { padding: 0 18px 14px; font-family: var(--font-mono); font-size: 9px; color: rgba(139,108,247,0.45); letter-spacing: 0.06em; }

/* Stakeholder mini grid (Execute) */
.stakeholder-mini-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }

.stakeholder-mini {
  background: var(--deep); border: 1px solid rgba(255,255,255,0.07);
  border-radius: 10px; padding: 12px 8px;
  text-align: center; display: flex; flex-direction: column;
  align-items: center; gap: 6px;
  transition: border-color var(--ease);
}
.stakeholder-mini:hover { border-color: rgba(255,255,255,0.14); }

.stakeholder-mini__icon {
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.stakeholder-mini__name { font-family: var(--font-heading); font-size: 10px; font-weight: 700; color: var(--white); }
.stakeholder-mini__badge { font-family: var(--font-mono); font-size: 7px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 6px; border-radius: 100px; }

/* ═══════════════════════════════════════════════════
   CTA BOX  (_cta-global)
   ═══════════════════════════════════════════════════ */
.cta-section { background: var(--midnight); padding: var(--section-y) 0 80px; }
.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: 30px; font-weight: 700; line-height: 1.15; color: var(--white); margin-bottom: 12px; position: relative; }
.cta-box__sub { font-size: 13px; color: rgba(255,255,255,0.42); margin-bottom: 28px; position: relative; line-height: 1.6; }
.cta-box .btn-primary { font-size: 13px; padding: 12px 28px; position: relative; margin: 0 auto; }

/* ═══════════════════════════════════════════════════
   FOOTER  (_footer-global)
   ═══════════════════════════════════════════════════ */
.footer { background: var(--deep); border-top: 1px solid rgba(255,255,255,0.07); }
.footer__main { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 32px; padding: 56px var(--container-pad) 48px; max-width: var(--container-max); margin: 0 auto; }
.footer__logo { display: inline-flex; align-items: center; text-decoration: none; margin-bottom: 10px; }
.footer__logo-l { font-family: var(--font-heading); font-size: 16px; font-weight: 700; letter-spacing: 0.06em; color: var(--white); line-height: 1; }
.footer__logo-f { font-family: var(--font-heading); font-size: 16px; font-weight: 700; letter-spacing: 0.06em; color: var(--lime); line-height: 1; }
.footer__tagline { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.28); margin-bottom: 20px; line-height: 1.6; }
.footer__offices { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
.footer__office { display: flex; align-items: flex-start; gap: 8px; }
.footer__office-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--lime); flex-shrink: 0; margin-top: 6px; }
.footer__office-dot--teal { background: var(--teal); }
.footer__office-text { font-size: 11px; color: rgba(255,255,255,0.35); line-height: 1.6; }
.footer__office-sub { font-size: 10px; color: rgba(255,255,255,0.18); }
.footer__social { display: flex; align-items: center; gap: 8px; }
.footer__social-btn { display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 8px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); color: rgba(255,255,255,0.32); text-decoration: none; transition: color var(--ease), background var(--ease), border-color var(--ease); }
.footer__social-btn:hover { color: var(--lime); background: rgba(202,255,112,0.06); border-color: rgba(202,255,112,0.2); }
.footer__col-title { font-family: var(--font-heading); font-size: 10px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.28); margin-bottom: 20px; }
.footer__links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer__link { font-size: 13px; color: rgba(255,255,255,0.48); transition: color var(--ease); }
.footer__link:hover { color: rgba(255,255,255,0.9); }
.footer__link--lime { color: var(--lime); font-weight: 600; }
.footer__bottom { border-top: 1px solid rgba(255,255,255,0.07); max-width: var(--container-max); margin: 0 auto; padding: 20px var(--container-pad); display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.footer__copy { font-size: 11px; color: rgba(255,255,255,0.2); }
.footer__legal { display: flex; align-items: center; gap: 20px; }
.footer__legal-link { font-size: 11px; color: rgba(255,255,255,0.2); transition: color var(--ease); }
.footer__legal-link:hover { color: rgba(255,255,255,0.55); }
.footer__build { font-family: var(--font-mono); font-size: 10px; color: rgba(255,255,255,0.1); letter-spacing: 0.08em; }

/* ═══════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .nav__links, .nav__lang, .nav__actions .btn-primary { display: none; }
  .nav__hamburger { display: flex; }
  .sh-hero__inner, .pillar__grid { grid-template-columns: 1fr; }
  .pillar__grid--reverse { direction: ltr; }
  .roadmap__timeline { grid-template-columns: 1fr; gap: 32px; }
  .roadmap__track { display: none; }
  .roadmap__cards { grid-template-columns: 1fr; }
  .stakeholder-mini-grid { grid-template-columns: repeat(3, 1fr); }
  .footer__main { grid-template-columns: 1fr 1fr; }
  .sh-hero__anim-wrap { max-height: 340px; overflow: hidden; }
}
@media (max-width: 767px) {
  :root { --container-pad: 20px; }
  .sh-hero__h1 { font-size: 32px; }
  .pillar__h2 { font-size: 26px; }
  .roadmap__cards { grid-template-columns: 1fr; }
  .stakeholder-mini-grid { grid-template-columns: repeat(2, 1fr); }
  .footer__main { grid-template-columns: 1fr 1fr; padding: 40px 20px 32px; gap: 32px 20px; }
  .footer__bottom { flex-direction: column; align-items: flex-start; padding: 16px 20px; gap: 10px; }
  .cta-box { padding: 40px 24px; }
}