/* ==================== SECOND BITE · CUSTOM CSS ==================== */

:root {
  --ink:   #0a0d10;
  --coal:  #11161b;
  --steel: #1a2128;
  --mist:  #b9c2cc;
  --ember: #ff6b1a;
  --flame: #ff8a3d;
  --glow:  #ffb56b;
  --leaf:  #7ec37a;
  --cream: #f4ede2;
}

html { scroll-behavior: smooth; }
body { font-feature-settings: "ss01","cv11"; }

/* ========== NAV STATES ========== */
#site-header.scrolled {
  background: rgba(10,13,16,0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

/* ========== HERO BACKGROUND ========== */
.hero-bg {
  background:
    radial-gradient(ellipse 80% 60% at 20% 0%, rgba(255,107,26,.14), transparent 70%),
    radial-gradient(ellipse 60% 50% at 90% 20%, rgba(255,181,107,.10), transparent 70%),
    linear-gradient(180deg, #0a0d10 0%, #0c1115 60%, #0a0d10 100%);
}
.hero-grid {
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at 50% 20%, #000 30%, transparent 85%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 20%, #000 30%, transparent 85%);
}

/* ========== TEXT GRADIENT ========== */
.text-gradient {
  background: linear-gradient(100deg, #ff6b1a 0%, #ffb56b 60%, #f4ede2 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ========== MARQUEE ========== */
.marquee {
  animation: marquee 40s linear infinite;
  width: max-content;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ========== GENERIC CARD ========== */
.card {
  position: relative;
  padding: 1.75rem;
  border-radius: 1.25rem;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .4s ease, border-color .4s ease, background .4s ease;
}
.card:hover {
  transform: translateY(-4px);
  border-color: rgba(255,107,26,.4);
  background: linear-gradient(180deg, rgba(255,107,26,.06), rgba(255,255,255,.02));
}
.card-ico {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 12px;
  background: rgba(255,107,26,.12);
  color: var(--ember);
  margin-bottom: 1rem;
}
.card-title {
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--cream);
  margin-bottom: .5rem;
}
.card-body {
  color: var(--mist);
  font-size: .95rem;
  line-height: 1.6;
}

/* ========== PROCESS FLOW ========== */
.process-flow .step {
  position: relative;
  padding: 2rem 1.5rem;
  background: rgba(10,13,16,.75);
  transition: background .3s ease;
}
.process-flow .step:hover { background: rgba(255,107,26,.06); }
.step-num {
  font-family: "Space Grotesk", sans-serif;
  font-size: .7rem;
  letter-spacing: .25em;
  color: var(--ember);
  margin-bottom: 1rem;
}
.step-ico {
  width: 34px; height: 34px;
  color: var(--cream);
  margin-bottom: 1rem;
  opacity: .9;
}
.step-title {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--cream);
  margin-bottom: .5rem;
}
.step-desc {
  font-size: .85rem;
  color: var(--mist);
  line-height: 1.55;
}

.heat-pulse {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 120px; height: 6px;
  background: linear-gradient(90deg, transparent, var(--ember), transparent);
  filter: blur(2px);
  animation: heat-flow 4s linear infinite;
}
@keyframes heat-flow {
  0%   { transform: translate(0,-50%); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translate(calc(100vw),-50%); opacity: 0; }
}

/* ========== SPEC TILES ========== */
.spec {
  padding: 2rem;
  border-radius: 1.25rem;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
}

/* ========== LAYER PANEL ========== */
.layer {
  display: flex; align-items: center; gap: .75rem;
}
.layer-tag {
  display: inline-flex; align-items:center; justify-content:center;
  width: 28px; height: 28px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 8px;
  font-family: "Space Grotesk", sans-serif;
  font-size: .7rem;
  color: var(--mist);
  flex-shrink: 0;
}
.layer-body { flex: 1; }
.layer-title {
  font-size: .75rem;
  color: var(--cream);
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: .35rem;
}
.bar {
  height: 10px; border-radius: 999px;
  position: relative; overflow: hidden;
  background: rgba(255,255,255,.05);
}
.bar::after {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit;
  transform-origin: left;
  animation: bar-load 1.4s cubic-bezier(.2,.8,.2,1) .2s both;
}
.bar.ember::after  { background: linear-gradient(90deg, #ff6b1a, #ff8a3d); width: 100%; }
.bar.flame::after  { background: linear-gradient(90deg, #ff8a3d, #ffb56b); width: 78%; }
.bar.cream::after  { background: linear-gradient(90deg, #ffb56b, #f4ede2); width: 60%; }
.bar.leaf::after   { background: linear-gradient(90deg, #7ec37a, #f4ede2); width: 45%; }
.bar.glow::after   { background: linear-gradient(90deg, #ffb56b, #ff6b1a); width: 88%; }
@keyframes bar-load { from { transform: scaleX(0); } to { transform: scaleX(1); } }

/* ========== IMPACT PILLARS ========== */
.pillar {
  padding: 2rem 1.5rem;
  border-radius: 1.25rem;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,0));
  border: 1px solid rgba(255,255,255,.08);
  transition: all .35s ease;
}
.pillar:hover {
  border-color: rgba(255,107,26,.35);
  transform: translateY(-4px);
}
.pillar-num {
  font-family: "Space Grotesk", sans-serif;
  color: var(--ember);
  font-size: .72rem;
  letter-spacing: .3em;
  margin-bottom: 1.25rem;
}
.pillar-title {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--cream);
  margin-bottom: .5rem;
}
.pillar-body {
  color: var(--mist);
  font-size: .85rem;
  line-height: 1.55;
}

/* ========== AGENDA CARDS (richer pillar variant) ========== */
.agenda {
  position: relative;
  border-radius: 1.25rem;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease;
  display: flex;
  flex-direction: column;
}
.agenda:hover {
  transform: translateY(-6px);
  border-color: rgba(255,107,26,.4);
  box-shadow: 0 20px 40px -20px rgba(0,0,0,.6);
}
.agenda-scene {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.agenda-scene svg {
  width: 100%;
  height: 100%;
  display: block;
  transition: transform .9s ease;
}
.agenda:hover .agenda-scene svg {
  transform: scale(1.04);
}
.agenda-tag {
  position: absolute;
  bottom: .55rem;
  left: .6rem;
  right: .6rem;
  font-family: "Inter", sans-serif;
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  padding: .35rem .55rem;
  border-radius: .4rem;
  text-align: center;
  border: 1px solid rgba(255,255,255,.15);
}
.agenda-body {
  padding: 1.1rem 1.1rem 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.agenda-num {
  font-family: "Space Grotesk", sans-serif;
  color: var(--ember);
  font-size: .68rem;
  letter-spacing: .3em;
  margin-bottom: .55rem;
}
.agenda-title {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 1rem;
  color: var(--cream);
  margin-bottom: .4rem;
  line-height: 1.2;
}
.agenda-text {
  color: var(--mist);
  font-size: .8rem;
  line-height: 1.55;
}

/* Color accents per agenda */
.agenda-green:hover  { border-color: rgba(58,168,108,.55); }
.agenda-blue:hover   { border-color: rgba(255,204,0,.55); }
.agenda-amber:hover  { border-color: rgba(255,204,0,.55); }
.agenda-sdg12:hover  { border-color: rgba(211,151,40,.7); }
.agenda-sdg7:hover   { border-color: rgba(252,195,11,.7); }

/* Tag color variations */
.agenda-green .agenda-tag  { background: rgba(0,51,153,.85); border-color: rgba(255,204,0,.35); }
.agenda-blue .agenda-tag   { background: rgba(0,51,153,.85); border-color: rgba(255,204,0,.4); }
.agenda-amber .agenda-tag  { background: rgba(0,51,153,.85); border-color: rgba(255,204,0,.4); }
.agenda-sdg12 .agenda-tag  { background: rgba(118,84,21,.9); border-color: rgba(255,255,255,.25); }
.agenda-sdg7 .agenda-tag   { background: rgba(170,128,8,.9); border-color: rgba(255,255,255,.3); }

/* SVG animations */
@keyframes agendaSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes agendaSpinReverse {
  from { transform: rotate(360deg); }
  to   { transform: rotate(0deg); }
}
@keyframes agendaPulse {
  0%, 100% { opacity: .55; }
  50%      { opacity: 1; }
}
@keyframes agendaBob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}
@keyframes agendaShimmer {
  0%, 100% { filter: drop-shadow(0 0 0 rgba(255,204,0,0)); }
  50%      { filter: drop-shadow(0 0 6px rgba(255,204,0,.55)); }
}

.agenda-stars-rotate {
  transform-box: fill-box;
  transform-origin: center;
  animation: agendaSpin 60s linear infinite;
}
.agenda-loop-rotate {
  transform-box: fill-box;
  transform-origin: center;
  animation: agendaSpin 18s linear infinite;
}
.agenda-shield-stars {
  transform-box: fill-box;
  transform-origin: center;
  animation: agendaSpin 80s linear infinite;
}
.agenda-shield-shimmer {
  animation: agendaShimmer 4.5s ease-in-out infinite;
}
.agenda-particles circle {
  animation: agendaPulse 3s ease-in-out infinite;
}
.agenda-particles circle:nth-child(2) { animation-delay: .4s; }
.agenda-particles circle:nth-child(3) { animation-delay: .9s; }
.agenda-particles circle:nth-child(4) { animation-delay: 1.4s; }
.agenda-particles circle:nth-child(5) { animation-delay: 1.9s; }
.agenda-particles circle:nth-child(6) { animation-delay: 2.4s; }
.agenda-sdg12-loop {
  transform-box: fill-box;
  transform-origin: center;
  animation: agendaBob 3.2s ease-in-out infinite;
}
.agenda-fruits g {
  transform-box: fill-box;
  transform-origin: center;
  animation: agendaBob 3.6s ease-in-out infinite;
}
.agenda-fruits g:nth-child(2) { animation-delay: 1.2s; }
.agenda-sun-rotate {
  transform-box: fill-box;
  transform-origin: center;
  animation: agendaSpin 22s linear infinite;
}
.agenda-turbine-blades {
  transform-box: fill-box;
  transform-origin: center;
  animation: agendaSpin 4s linear infinite;
}
.agenda-trees g {
  transform-box: fill-box;
  transform-origin: bottom center;
  animation: agendaBob 5s ease-in-out infinite;
}
.agenda-trees g:nth-child(2) { animation-delay: .6s; }
.agenda-trees g:nth-child(3) { animation-delay: 1.2s; }
.agenda-trees g:nth-child(4) { animation-delay: 1.8s; }

@media (prefers-reduced-motion: reduce) {
  .agenda-stars-rotate,
  .agenda-loop-rotate,
  .agenda-shield-stars,
  .agenda-shield-shimmer,
  .agenda-particles circle,
  .agenda-sdg12-loop,
  .agenda-fruits g,
  .agenda-sun-rotate,
  .agenda-turbine-blades,
  .agenda-trees g,
  .agenda-kenburns {
    animation: none !important;
  }
}

/* ============ Photo-backed agenda cards ============ */
.agenda-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.agenda-kenburns {
  animation: agendaKenBurns 22s ease-in-out infinite alternate;
  transform-origin: 50% 50%;
  will-change: transform;
}
@keyframes agendaKenBurns {
  0%   { transform: scale(1.06) translate(0, 0); }
  100% { transform: scale(1.20) translate(-2.5%, -1.5%); }
}
.agenda-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.agenda-overlay-green  { background: linear-gradient(180deg, rgba(0,40,90,.20) 0%, rgba(0,30,80,.55) 65%, rgba(0,20,55,.92) 100%); }
.agenda-overlay-blue   { background: linear-gradient(180deg, rgba(0,40,120,.30) 0%, rgba(0,30,90,.60) 65%, rgba(0,15,50,.92) 100%); }
.agenda-overlay-amber  { background: linear-gradient(180deg, rgba(0,30,90,.30) 0%, rgba(0,40,110,.55) 65%, rgba(10,20,45,.92) 100%); }
.agenda-overlay-sdg12  { background: linear-gradient(180deg, rgba(170,128,8,.25) 0%, rgba(118,84,21,.65) 65%, rgba(45,28,5,.92) 100%); }
.agenda-overlay-sdg7   { background: linear-gradient(180deg, rgba(252,195,11,.20) 0%, rgba(190,140,8,.55) 65%, rgba(85,55,5,.92) 100%); }

/* Fallback solid-colour backgrounds in case the photo fails to load */
.scene-bg-green  { background: #1f5836; }
.scene-bg-blue   { background: #0d2a66; }
.scene-bg-amber  { background: #0d2a66; }
.scene-bg-sdg12  { background: #765415; }
.scene-bg-sdg7   { background: #aa8008; }

.agenda:hover .agenda-photo { transform: scale(1.08); }

/* ============ Industry Interest cards ============ */
.industry-card {
  position: relative;
  padding: 1.4rem 1.4rem 1.5rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  display: flex;
  flex-direction: column;
  gap: .55rem;
  transition: transform .35s ease, border-color .35s ease;
}
.industry-card:hover {
  transform: translateY(-4px);
  border-color: rgba(255,107,26,.3);
}
.industry-card.industry-confirmed {
  border-color: rgba(255,107,26,.45);
  background: linear-gradient(180deg, rgba(255,107,26,.08), rgba(255,107,26,0));
}
.industry-mark {
  width: 2.4rem;
  height: 2.4rem;
  border-radius: .65rem;
  background: rgba(255,107,26,.18);
  color: var(--ember);
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .35rem;
}
.industry-confirmed .industry-mark {
  background: var(--ember);
  color: var(--ink);
}
.industry-status {
  font-family: "Inter", sans-serif;
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mist);
}
.industry-confirmed .industry-status { color: var(--ember); }
.industry-name {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 1.25rem;
  color: var(--cream);
  line-height: 1.1;
}
.industry-text {
  color: var(--mist);
  font-size: .82rem;
  line-height: 1.55;
}

/* Slim institutional endorsement chip */
.endorsement-mark-sm {
  display: inline-flex;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: .4rem;
  background: var(--ember);
  color: var(--ink);
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: .85rem;
  align-items: center;
  justify-content: center;
}

.impact-stat {
  padding: 1.75rem;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(10,13,16,.5);
}
.impact-stat .v {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: 2.25rem;
  color: var(--cream);
  line-height: 1.05;
}
.impact-stat .l {
  margin-top: .6rem;
  font-size: .8rem;
  color: var(--mist);
  text-transform: uppercase;
  letter-spacing: .15em;
  line-height: 1.5;
}

/* ========== MILESTONES ========== */
.milestone {
  padding: 1.75rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01));
  display: flex; flex-direction: column; gap: .75rem;
  transition: transform .35s ease, border-color .35s ease;
}
.milestone:hover {
  transform: translateY(-4px);
  border-color: rgba(255,107,26,.35);
}
.mile-label {
  display: inline-flex; align-self: flex-start;
  padding: .3rem .7rem;
  border-radius: 999px;
  background: rgba(255,107,26,.12);
  color: var(--ember);
  font-size: .65rem;
  letter-spacing: .25em;
  text-transform: uppercase;
}
.mile-title {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: 1.4rem;
  color: var(--cream);
}
.mile-body { color: var(--mist); line-height: 1.6; font-size: .95rem; }
.mile-foot {
  margin-top: auto;
  font-size: .75rem;
  color: var(--mist);
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: .85rem;
  text-transform: uppercase;
  letter-spacing: .15em;
}

/* ========== ROADMAP ========== */
.road {
  position: relative;
  padding: 2rem 1.5rem;
  background: rgba(10,13,16,.6);
  transition: background .3s ease;
}
.road:hover { background: rgba(255,107,26,.06); }
.road-num {
  font-family: "Space Grotesk", sans-serif;
  color: var(--ember);
  font-size: .7rem;
  letter-spacing: .3em;
  margin-bottom: 1.25rem;
}
.road-title {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--cream);
  margin-bottom: .5rem;
}
.road-desc { font-size: .85rem; color: var(--mist); line-height: 1.55; }

/* ========== PEOPLE ========== */
.person {
  display: flex; gap: 1.5rem; align-items: flex-start;
  padding: 2rem;
  border-radius: 1.5rem;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.08);
}
.person-avatar {
  flex-shrink: 0;
  width: 72px; height: 72px;
  border-radius: 999px;
  display: inline-flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, var(--ember), var(--glow));
  color: var(--ink);
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: .05em;
}
.person-avatar.outline {
  background: transparent;
  border: 1px dashed rgba(255,107,26,.5);
  color: var(--ember);
}

/* ========== CONTACT ========== */
.contact-card {
  display: block;
  padding: 1.75rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(10,13,16,.6);
  transition: all .3s ease;
}
.contact-card:hover {
  border-color: rgba(255,107,26,.45);
  background: rgba(255,107,26,.05);
  transform: translateY(-2px);
}
.form-input {
  width: 100%;
  padding: 1rem 1.25rem;
  border-radius: .9rem;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(10,13,16,.7);
  color: var(--cream);
  font-family: inherit;
  font-size: .95rem;
  transition: border-color .2s ease, background .2s ease;
}
.form-input::placeholder { color: rgba(185,194,204,.5); }
.form-input:focus {
  outline: none;
  border-color: var(--ember);
  background: rgba(10,13,16,.9);
}

/* ========== REVEAL ON SCROLL ========== */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1);
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* ========== SELECTION ========== */
::selection {
  background: var(--ember);
  color: var(--ink);
}

/* ========== SCROLLBAR ========== */
html { scrollbar-width: thin; scrollbar-color: var(--ember) var(--ink); }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--ink); }
::-webkit-scrollbar-thumb { background: var(--steel); border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: var(--ember); }

/* ========== RESPONSIVE TWEAKS ========== */
@media (max-width: 767px) {
  .process-flow { border-radius: 1.5rem; }
  .process-flow .step { border-bottom: 1px solid rgba(255,255,255,.06); }
  .process-flow .step:last-child { border-bottom: none; }
  .person { flex-direction: column; }
}

/* ========== TEAMMATE CARDS ========== */
.teammate {
  padding: 2rem;
  border-radius: 1.5rem;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .35s ease, border-color .35s ease, background .35s ease;
}
.teammate:hover { transform: translateY(-4px); }
.teammate.accent-ember:hover {
  border-color: rgba(255,107,26,.45);
  background: linear-gradient(180deg, rgba(255,107,26,.05), rgba(255,255,255,.02));
}
.teammate.accent-blue:hover {
  border-color: rgba(56,189,248,.45);
  background: linear-gradient(180deg, rgba(56,189,248,.05), rgba(255,255,255,.02));
}
.teammate-head {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  margin-bottom: 1.5rem;
}
.teammate-photo {
  flex-shrink: 0;
  width: 84px; height: 84px;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid rgba(255,107,26,.35);
  background: linear-gradient(135deg, var(--ember), var(--glow));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 700;
  font-size: 1.75rem;
  letter-spacing: .04em;
}
.teammate.accent-blue .teammate-photo {
  border-color: rgba(56,189,248,.45);
  background: linear-gradient(135deg, #38bdf8, #7dd3fc);
}
.teammate-initials { color: var(--ink); }
.teammate-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .55rem;
  color: var(--mist);
  font-size: .92rem;
  line-height: 1.55;
}
.teammate-list li { display: flex; gap: .6rem; }
.teammate-list li::before {
  content: "◆";
  color: var(--ember);
  flex-shrink: 0;
}
.teammate-list.list-blue li::before { color: #38bdf8; }

/* ========== PHASE CARDS (ROADMAP) ========== */
.phase {
  position: relative;
  padding: 2rem 1.75rem;
  border-radius: 1.5rem;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .35s ease, border-color .35s ease;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.phase:hover {
  transform: translateY(-4px);
  border-color: rgba(255,107,26,.35);
}
.phase.phase-active {
  border-color: rgba(255,107,26,.5);
  background: linear-gradient(180deg, rgba(255,107,26,.08), rgba(255,255,255,.02));
  box-shadow: 0 20px 60px -30px rgba(255,107,26,.55);
}
.phase-top {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.phase-badge {
  flex-shrink: 0;
  width: 54px; height: 54px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--ink);
}
.phase-badge-ember { background: linear-gradient(135deg, var(--ember), var(--glow)); }
.phase-badge-teal  { background: linear-gradient(135deg, #5eead4, #14b8a6); color: #052e2b; }
.phase-badge-blue  { background: linear-gradient(135deg, #7dd3fc, #38bdf8); color: #0c2a3c; }
.phase-tag {
  font-family: "Space Grotesk", Inter, sans-serif;
  font-size: .7rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--mist);
}
.phase-name {
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 700;
  font-size: 1.4rem;
  color: var(--cream);
  margin-top: .15rem;
}
.phase-sub {
  color: var(--mist);
  font-size: .9rem;
  border-top: 1px solid rgba(255,255,255,.07);
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: .8rem 0;
}
.phase-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .55rem;
  color: var(--mist);
  font-size: .92rem;
  line-height: 1.55;
}
.phase-list li { display: flex; gap: .6rem; }
.phase-list li::before {
  content: "◆";
  color: var(--ember);
  flex-shrink: 0;
}

/* ========== VALUE / ROI ========== */
.value {
  position: relative;
  padding: 2rem 1.75rem;
  border-radius: 1.5rem;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .35s ease, border-color .35s ease, background .35s ease;
  display: flex;
  flex-direction: column;
  gap: .85rem;
}
.value:hover {
  transform: translateY(-4px);
  border-color: rgba(255,107,26,.4);
}
.value.value-ember {
  border-color: rgba(255,107,26,.4);
  background: linear-gradient(180deg, rgba(255,107,26,.08), rgba(255,255,255,.02));
  box-shadow: 0 20px 60px -30px rgba(255,107,26,.55);
}
.value-tag {
  color: var(--ember);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.value-big {
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 800;
  font-size: 5rem;
  line-height: .95;
  color: var(--cream);
  margin: .4rem 0 .25rem;
  letter-spacing: -.02em;
}
@media (min-width: 768px) {
  .value-big { font-size: 6rem; }
}
.value-sub {
  color: var(--mist);
  font-size: .92rem;
  letter-spacing: .02em;
  line-height: 1.4;
}
.value-list {
  list-style: none;
  padding: 0;
  margin: .5rem 0 0;
  display: flex;
  flex-direction: column;
  gap: .55rem;
  color: var(--mist);
  font-size: .9rem;
  line-height: 1.55;
}
.value-list li { display: flex; gap: .6rem; }
.value-list li::before {
  content: "◆";
  color: var(--ember);
  flex-shrink: 0;
}

.value-cell {
  padding: 1.5rem 1.25rem;
  background: rgba(10,13,16,.7);
}
.value-cell-v {
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 700;
  font-size: 2.1rem;
  line-height: 1;
  color: var(--cream);
}
.value-cell-l {
  margin-top: .55rem;
  font-size: .72rem;
  color: var(--mist);
  letter-spacing: .15em;
  text-transform: uppercase;
  line-height: 1.5;
}

.value-pane {
  padding: 1.75rem 1.5rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.value-line {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding: .55rem 0;
  border-bottom: 1px dashed rgba(255,255,255,.08);
  color: var(--mist);
  font-size: .88rem;
  line-height: 1.4;
}
.value-line:last-child { border-bottom: 0; }
.value-line > span:last-child {
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 600;
  white-space: nowrap;
}
.value-line-total {
  margin-top: .25rem;
  padding-top: .85rem;
  border-top: 1px solid rgba(255,107,26,.35);
  border-bottom: 0;
  color: var(--cream);
  font-weight: 600;
  font-size: .95rem;
}
.value-line-total > span:last-child {
  color: var(--ember);
  font-size: 1.05rem;
}

/* ========== MARKETS ========== */
.market {
  position: relative;
  padding: 2rem 1.75rem;
  border-radius: 1.5rem;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .35s ease, border-color .35s ease, background .35s ease;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.market:hover {
  transform: translateY(-4px);
  border-color: rgba(255,107,26,.4);
}
.market.market-ember {
  border-color: rgba(255,107,26,.4);
  background: linear-gradient(180deg, rgba(255,107,26,.08), rgba(255,255,255,.02));
  box-shadow: 0 20px 60px -30px rgba(255,107,26,.55);
}
.market-num {
  font-family: "Space Grotesk", Inter, sans-serif;
  color: var(--ember);
  font-size: .7rem;
  letter-spacing: .3em;
}
.market-tag {
  color: var(--cream);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 600;
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.market-val {
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 700;
  font-size: 2.75rem;
  line-height: 1;
  background: linear-gradient(100deg, #ff6b1a 0%, #ffb56b 70%, #f4ede2 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin: .15rem 0 .1rem;
}
.market-sub {
  color: var(--mist);
  font-size: .78rem;
  letter-spacing: .04em;
}
.market-body {
  color: var(--mist);
  font-size: .92rem;
  line-height: 1.6;
}
.market-list {
  list-style: none;
  padding: 0;
  margin: .5rem 0 0;
  display: flex;
  flex-direction: column;
  gap: .45rem;
  color: var(--mist);
  font-size: .86rem;
  line-height: 1.5;
}
.market-list li { display: flex; gap: .6rem; }
.market-list li::before {
  content: "◆";
  color: var(--ember);
  flex-shrink: 0;
}
.market-note {
  padding: 1.25rem 1.25rem;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(10,13,16,.5);
}

/* ========== HERO ANIMATED LOOP ========== */
.hero-loop {
  filter: drop-shadow(0 30px 80px rgba(255,107,26,.15));
}
.hero-ring-rotate {
  animation: hero-spin 22s linear infinite;
  transform-box: fill-box;
}
.hero-ring-rotate-rev {
  animation: hero-spin 32s linear infinite reverse;
  transform-box: fill-box;
}
@keyframes hero-spin {
  to { transform: rotate(360deg); }
}
.hero-sun {
  animation: hero-sun-pulse 4s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}
@keyframes hero-sun-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.06); opacity: .92; }
}
.hero-led {
  animation: hero-led-blink 1.4s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}
@keyframes hero-led-blink {
  0%, 100% { opacity: 1; }
  50%      { opacity: .25; }
}
.hero-heatwave {
  animation: hero-heatwave 2s ease-in-out infinite;
}
@keyframes hero-heatwave {
  0%, 100% { transform: translateX(0); opacity: .8; }
  50%      { transform: translateX(2px); opacity: 1; }
}
.hero-node {
  transition: transform .35s ease;
  cursor: default;
}
.hero-node:hover { transform: translateY(-2px); }

.hero-loop-badge {
  position: absolute;
  padding: .55rem .9rem;
  border-radius: 14px;
  background: rgba(10,13,16,.85);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,138,61,.35);
  box-shadow: 0 12px 30px -12px rgba(255,107,26,.4);
  animation: hero-badge-float 5s ease-in-out infinite;
}
.hero-loop-badge-1 { top: 8%;  left: -4%;  animation-delay: 0s; }
.hero-loop-badge-2 { top: 38%; right: -8%; animation-delay: 1.5s; }
.hero-loop-badge-3 { bottom: 12%; left: 4%; animation-delay: 3s; }
@keyframes hero-badge-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

/* ========== SYSTEM DIAGRAM (TECHNOLOGY) ========== */
.system-diagram {
  box-shadow: 0 30px 80px -40px rgba(255,107,26,.35);
}
.sys-station {
  transition: opacity .3s ease, transform .3s ease;
  transform-box: fill-box;
}
.sys-station:hover {
  filter: drop-shadow(0 0 12px rgba(255,138,61,.5));
}
.sys-sun-rotate {
  animation: hero-spin 18s linear infinite;
}
.sys-rays {
  animation: sys-rays-flicker 1.6s ease-in-out infinite;
}
@keyframes sys-rays-flicker {
  0%, 100% { opacity: .5; }
  50%      { opacity: .85; }
}
.sys-led {
  animation: hero-led-blink 1.6s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}
.sys-recup-dot-r {
  animation: sys-flow-r 1.4s linear infinite;
}
.sys-recup-dot-l {
  animation: sys-flow-l 1.4s linear infinite;
}
@keyframes sys-flow-r {
  from { transform: translateX(-12px); opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  to   { transform: translateX(112px); opacity: 0; }
}
@keyframes sys-flow-l {
  from { transform: translateX(12px); opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  to   { transform: translateX(-112px); opacity: 0; }
}
.sys-steam-line {
  animation: sys-steam 2.8s ease-in-out infinite;
  opacity: 0;
}
@keyframes sys-steam {
  0%   { opacity: 0; transform: translateY(0); }
  20%  { opacity: .8; }
  80%  { opacity: .4; }
  100% { opacity: 0; transform: translateY(-22px); }
}
.sys-bar {
  animation: sys-bar-shimmer 4s ease-in-out infinite;
}
@keyframes sys-bar-shimmer {
  0%, 100% { opacity: .55; }
  50%      { opacity: .85; }
}

/* ========== COMPARISON TABLE ========== */
.compare-table {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 1.5rem;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01));
}
.compare-head, .compare-row {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1fr;
  gap: 1px;
  background: rgba(255,255,255,.06);
}
.compare-row {
  border-top: 1px solid rgba(255,255,255,.06);
  transition: background .3s ease;
}
.compare-row:hover { background: rgba(255,107,26,.04); }
.compare-cell {
  padding: 1.5rem 1.6rem;
  background: rgba(10,13,16,.7);
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.compare-cell-label {
  flex-direction: row;
  align-items: flex-start;
  gap: 1rem;
  background: rgba(10,13,16,.85);
}
.compare-row-num {
  flex-shrink: 0;
  font-family: "Space Grotesk", sans-serif;
  color: var(--ember);
  font-size: .65rem;
  letter-spacing: .3em;
  width: 26px; height: 26px;
  border: 1px solid rgba(255,107,26,.4);
  border-radius: 6px;
  display: inline-flex;
  align-items: center; justify-content: center;
}
.compare-row-title {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 600;
  color: var(--cream);
  font-size: 1rem;
}
.compare-row-sub {
  color: var(--mist);
  font-size: .78rem;
  margin-top: .25rem;
}
.compare-col-trad { background: rgba(255,255,255,.015); }
.compare-col-us {
  background: linear-gradient(180deg, rgba(255,107,26,.06), rgba(255,107,26,.02));
  border-left: 1px solid rgba(255,107,26,.18);
}
.compare-bad {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  color: #ff6b6b;
  font-size: 1.2rem;
}
.compare-good {
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
  color: var(--leaf);
  font-size: 1.2rem;
}
.compare-detail {
  color: var(--mist);
  font-size: .82rem;
  line-height: 1.55;
}
@media (max-width: 767px) {
  .compare-head, .compare-row {
    grid-template-columns: 1fr;
  }
  .compare-cell { padding: 1.1rem 1.3rem; }
  .compare-cell-label { background: rgba(255,107,26,.08); }
}

/* ========== INTERACTIVE CARBON CALCULATOR ========== */
.calc {
  border: 1px solid rgba(255,107,26,.25);
  border-radius: 1.5rem;
  background:
    radial-gradient(ellipse 80% 60% at 80% 0%, rgba(255,107,26,.08), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  box-shadow: 0 30px 80px -40px rgba(255,107,26,.4);
  overflow: hidden;
}
.calc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: rgba(255,255,255,.06);
}
.calc-input, .calc-output {
  padding: 2.5rem 2rem;
  background: rgba(10,13,16,.7);
  display: flex;
  flex-direction: column;
  gap: .9rem;
}
@media (max-width: 900px) {
  .calc-grid { grid-template-columns: 1fr; }
}
.calc-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(to right,
    var(--ember) 0%, var(--ember) var(--calc-fill, 50%),
    rgba(255,255,255,.1) var(--calc-fill, 50%), rgba(255,255,255,.1) 100%);
  outline: none;
  cursor: pointer;
}
.calc-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 22px; height: 22px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--flame), var(--ember));
  border: 3px solid var(--ink);
  box-shadow: 0 4px 12px rgba(255,107,26,.5), 0 0 0 2px rgba(255,138,61,.4);
  cursor: grab;
  transition: transform .15s ease;
}
.calc-slider::-webkit-slider-thumb:active { transform: scale(1.15); cursor: grabbing; }
.calc-slider::-moz-range-thumb {
  width: 22px; height: 22px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--flame), var(--ember));
  border: 3px solid var(--ink);
  box-shadow: 0 4px 12px rgba(255,107,26,.5);
  cursor: grab;
}
.calc-presets {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: 1.25rem;
}
.calc-preset {
  font-family: "Space Grotesk", sans-serif;
  font-size: .78rem;
  letter-spacing: .04em;
  padding: .55rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: var(--mist);
  cursor: pointer;
  transition: all .25s ease;
}
.calc-preset:hover {
  border-color: rgba(255,107,26,.4);
  color: var(--cream);
  background: rgba(255,107,26,.06);
}
.calc-preset.active {
  border-color: var(--ember);
  color: var(--ink);
  background: var(--ember);
  font-weight: 600;
}
.calc-out-card {
  padding: 1.25rem 1.4rem;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  transition: border-color .25s ease, transform .25s ease;
}
.calc-out-card:hover { border-color: rgba(255,107,26,.3); transform: translateY(-2px); }
.calc-out-primary {
  border-color: rgba(255,107,26,.45);
  background: linear-gradient(180deg, rgba(255,107,26,.1), rgba(255,107,26,.02));
  padding: 1.75rem;
}

/* ========== ENDORSEMENT CARD ========== */
.endorsement-card {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  padding: 1.5rem 1.75rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(255,107,26,.35);
  background: linear-gradient(180deg, rgba(255,107,26,.06), rgba(255,255,255,.02));
  max-width: 540px;
}
.endorsement-mark {
  flex-shrink: 0;
  width: 56px; height: 56px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--ember), var(--glow));
  color: var(--ink);
  font-family: "Space Grotesk", Inter, sans-serif;
  font-weight: 800;
  font-size: 1.6rem;
  letter-spacing: .02em;
}

/* ========== REDUCED MOTION ========== */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
}
