/* ============================================================
   HOMEPAGE — UP YOUR REACH
   Personal-brand-first. Build is one footer link. Tone: editorial, warm, direct.
   ============================================================ */

.page-home { padding-top: 72px; }
.page-home .nav[data-scrolled="true"] { background: rgba(0, 21, 26, 0.85); }

/* ============================ HERO ========================== */
.home-hero {
  min-height: calc(100svh - 72px);
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.home-hero__inner {
  position: relative;
  z-index: var(--z-base);
  padding-block: var(--s-12);
}
.home-hero__content {
  max-width: 1080px;
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
}
.home-hero__h {
  font-size: clamp(3.5rem, 2rem + 8vw, 10rem);
  line-height: 0.92;
  letter-spacing: -0.035em;
}
.home-hero__lede { max-width: 60ch; color: var(--cyan-300); }
.home-hero .cluster { gap: var(--s-3); margin-top: var(--s-3); }

.home-hero__scroll {
  position: absolute;
  bottom: var(--s-6);
  left: 50%;
  transform: translateX(-50%);
  z-index: var(--z-base);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-3);
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--fg-muted-dark);
  transition: color var(--t-base) var(--ease-out);
}
.home-hero__scroll:hover { color: var(--cyan-500); }

/* ============================ LOGOS ========================= */
.logos { padding-block: var(--s-16); }
.logos__lede {
  text-align: center;
  font-size: var(--text-xl);
  margin-bottom: var(--s-12);
  color: var(--charcoal);
}
.logos__marquee {
  position: relative;
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent 0, black 8%, black 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0, black 8%, black 92%, transparent 100%);
}
.logos__track {
  display: flex;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  width: max-content;
  animation: marquee 36s linear infinite;
}
.logos__track:hover { animation-play-state: paused; }
.logos__track li { display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.logos__track img {
  height: clamp(36px, 4vw, 56px);
  width: auto;
  opacity: 0.65;
  filter: grayscale(1) contrast(1.05);
  transition: opacity var(--t-base) var(--ease-out), filter var(--t-base) var(--ease-out);
}
.logos__track img:hover { opacity: 1; filter: grayscale(0); }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .logos__track { animation: none; }
}

/* ============================ STORY ========================= */
.story__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-12);
  align-items: start;
}
@media (min-width: 880px) {
  .story__grid { grid-template-columns: 0.85fr 1fr; gap: var(--s-16); align-items: center; }
}
.story__portrait {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: linear-gradient(160deg, rgba(0,208,255,0.18), rgba(0,21,26,0.9));
  border: 1px solid var(--card-border-on-dark);
}
.story__portrait-frame {
  position: absolute;
  inset: 16px;
  border: 1px dashed rgba(0,208,255,0.45);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
}
.story__portrait-label {
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--cyan-300);
}
.story__caption {
  position: absolute;
  bottom: var(--s-4);
  left: var(--s-4);
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--fg-muted-dark);
  background: rgba(0,21,26,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 6px 10px;
  border-radius: var(--r-sm);
  border: 1px solid var(--card-border-on-dark);
}
.story__copy { display: flex; flex-direction: column; gap: var(--s-5); }
.story__copy .body-lg { color: var(--fg-muted-dark); }
.story__copy .tagline {
  font-size: var(--text-xl);
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule-on-dark);
  margin-top: var(--s-2);
}

/* ============================ RESULTS ========================= */
.results__stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
  margin: var(--s-12) 0;
}
@media (min-width: 880px) {
  .results__stats { grid-template-columns: repeat(3, 1fr); gap: var(--s-8); }
}
.big-stat {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-6) 0;
  border-top: 2px solid var(--charcoal);
}
.big-stat__num {
  font-family: var(--font-sans);
  font-weight: 900;
  font-size: clamp(3rem, 2rem + 4.5vw, 6rem);
  letter-spacing: var(--tracking-display);
  line-height: 1;
  color: var(--charcoal);
}
.big-stat__label {
  font-size: var(--text-sm);
  color: var(--fg-muted-light);
  max-width: 32ch;
}

.results__cases {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
}
@media (min-width: 880px) {
  .results__cases { grid-template-columns: 1fr 1.2fr; align-items: stretch; }
}
.mini-case {
  background: var(--white);
  border: 1px solid var(--rule-on-light);
  border-radius: var(--r-xl);
  padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  transition: transform var(--t-base) var(--ease-out),
              border-color var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out);
}
.mini-case:hover { transform: translateY(-3px); border-color: var(--cyan-500); box-shadow: 0 24px 50px -28px rgba(0,150,200,0.35); }
.mini-case__tag {
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--cyan-700);
  font-weight: 600;
}
.mini-case__h { color: var(--charcoal); font-size: var(--text-xl); }
.mini-case__body { color: var(--fg-muted-light); font-size: var(--text-base); }

.mini-case--with-img {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
}
@media (min-width: 600px) {
  .mini-case--with-img { grid-template-columns: 1fr auto; align-items: start; }
}
.mini-case__shot {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  align-items: center;
  grid-column: 1 / -1;
}
@media (min-width: 600px) {
  .mini-case__shot { grid-column: 2; grid-row: 1 / span 4; align-self: stretch; max-width: 200px; }
}
.mini-case__shot img {
  width: 100%;
  max-width: 200px;
  border-radius: var(--r-md);
  border: 1px solid var(--rule-on-light);
  aspect-ratio: 9/16;
  object-fit: cover;
  object-position: top;
}
.mini-case__shot-label {
  font-size: var(--text-xs);
  color: var(--fg-muted-light);
  text-align: center;
}

/* ============================ BUILDING ========================= */
.building__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
  margin-top: var(--s-8);
}
@media (min-width: 880px) {
  .building__grid { grid-template-columns: 1.3fr 1fr 1fr; align-items: stretch; }
}
.build-card {
  background: var(--card-on-dark);
  border: 1px solid var(--card-border-on-dark);
  border-radius: var(--r-xl);
  padding: var(--s-8);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  transition: transform var(--t-base) var(--ease-out),
              border-color var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out);
}
.build-card:hover {
  transform: translateY(-3px);
  border-color: rgba(0,208,255,0.4);
  box-shadow: var(--glow-cyan-sm);
}
.build-card--feature {
  border-color: var(--cyan-500);
  background: linear-gradient(160deg, rgba(0,208,255,0.10), rgba(0,208,255,0.02));
}
.build-card__tag {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  font-weight: 500;
  background: rgba(0,208,255,0.12);
  color: var(--cyan-300);
  border: 1px solid var(--card-border-on-dark);
}
.build-card__tag--coming {
  background: rgba(255,47,0,0.10);
  color: var(--signal-red);
  border-color: rgba(255,47,0,0.35);
}
.build-card__h { font-size: clamp(1.5rem, 1.2rem + 1.4vw, 2.25rem); margin-top: var(--s-2); }
.build-card__body { color: var(--fg-muted-dark); font-size: var(--text-base); }
.build-card .arrow-link { margin-top: auto; padding-top: var(--s-4); }

/* ============================ NEWSLETTER ========================= */
.news__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-10);
  align-items: start;
}
@media (min-width: 880px) {
  .news__inner { grid-template-columns: 0.9fr 1fr; gap: var(--s-16); align-items: center; }
}
.news__copy { display: flex; flex-direction: column; gap: var(--s-4); }
.news__copy .body-lg { color: var(--fg-muted-light); }

.news__form {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.news__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
}
@media (min-width: 600px) {
  .news__row { grid-template-columns: 1fr 1fr; }
  .news__row > :nth-child(2) { grid-column: 2; }
  .news__row > :nth-child(3) { grid-column: 1 / -1; }
}
.news__field {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.news__field span {
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--charcoal);
  font-weight: 500;
}
.news__field span em {
  font-style: normal;
  text-transform: none;
  letter-spacing: 0;
  color: var(--fg-muted-light);
  font-weight: 400;
  margin-left: 4px;
}
.news__field input {
  padding: var(--s-3) var(--s-4);
  background: var(--white);
  border: 1px solid var(--rule-on-light);
  border-radius: var(--r-md);
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: var(--text-base);
  color: var(--charcoal);
  transition: border-color var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.news__field input:focus { outline: none; border-color: var(--cyan-500); box-shadow: 0 0 0 3px rgba(0,208,255,0.18); }
.news__field input::placeholder { color: rgba(26,26,26,0.35); }
.news__submit { align-self: flex-start; margin-top: var(--s-2); }
.news__success {
  margin: var(--s-3) 0 0;
  padding: var(--s-3) var(--s-4);
  background: rgba(0, 208, 255, 0.10);
  border: 1px solid var(--cyan-500);
  border-radius: var(--r-md);
  color: var(--cyan-700);
  font-size: var(--text-sm);
  font-weight: 600;
}
.news__error {
  margin: var(--s-3) 0 0;
  padding: var(--s-3) var(--s-4);
  background: rgba(255, 47, 0, 0.06);
  border: 1px solid rgba(255, 47, 0, 0.4);
  border-radius: var(--r-md);
  color: var(--signal-red);
  font-size: var(--text-sm);
}
.news__error a { color: inherit; text-decoration: underline; }
.news__terms {
  font-size: var(--text-xs);
  color: var(--fg-muted-light);
  margin-top: var(--s-2);
}

/* ============================ COACHING ========================= */
.coaching { text-align: center; }
.coaching__inner { display: flex; flex-direction: column; align-items: center; gap: var(--s-6); }
.coaching__h { font-size: clamp(3rem, 2rem + 5vw, 7rem); }
.coaching__body { max-width: 60ch; color: var(--fg-muted-dark); }
.coaching__small {
  margin-top: var(--s-8);
  padding-top: var(--s-6);
  border-top: 1px solid var(--rule-on-dark);
  font-size: var(--text-sm);
  color: var(--fg-muted-dark);
  max-width: 60ch;
}
.coaching__small a { color: var(--cyan-500); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 4px; }

/* ============================ FOOTER · BUILD LINK ON HOME ===== */
.footer__build-link {
  font-size: var(--text-xs);
  color: var(--cyan-500);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  transition: color var(--t-base) var(--ease-out);
}
.footer__build-link:hover { color: var(--cyan-300); }
