:root{
  --tc-teal: #00918A;
  --tc-orange-left: #f4792d;
  --tc-orange-right: #f8951d;
  --accent-orange: var(--tc-orange-left);
  --hero-bg-1: #070b12;
  --hero-bg-2: #0b1526;
  --hero-interior-padding-y: clamp(2.75rem, 5vw, 4.25rem);
  --hero-interior-padding-bottom: clamp(2.25rem, 4.5vw, 3.75rem);
}

.accent{
  color: var(--accent-orange);
}

html, body { height: 100%; }
body{
  margin: 0;
  overflow-x: hidden;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background: #0b1020;
}

.site-hero{
  position: relative;
  z-index: 2;
  overflow: hidden;
  color: #fff;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background:
    radial-gradient(900px 500px at 20% 15%, rgba(0,145,138,.35), transparent 60%),
    radial-gradient(700px 450px at 80% 30%, rgba(244,121,45,.20), transparent 60%),
    linear-gradient(135deg, var(--hero-bg-1), var(--hero-bg-2));
}

/* Interior pages — hero only as tall as content, shared padding */
.site-hero--compact{
  min-height: 0;
}

.site-hero--compact .cap-hero{
  padding: var(--hero-interior-padding-y) 0 var(--hero-interior-padding-bottom);
}

.site-hero--compact .hero-content{
  padding: var(--hero-interior-padding-y) 0 var(--hero-interior-padding-bottom);
}

.site-hero--compact .cap-hero-visual{
  min-height: 0;
}

.site-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(transparent 0 0),
    repeating-linear-gradient(
      135deg,
      rgba(255,255,255,.06) 0px,
      rgba(255,255,255,.06) 1px,
      transparent 1px,
      transparent 14px
    );
  opacity: .30;
  pointer-events: none;
}

.site-hero::before,
.site-hero::after{
  z-index: 0;
}

.site-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,.75), rgba(0,0,0,.10) 60%, rgba(0,0,0,.00));
  pointer-events: none;
}

.navbar-overlay,
.hero-content,
.proof-strip{
  position: relative;
  z-index: 1;
}

.hero-content{
  z-index: 1;
}

/* Site header: secondary utility bar + main nav — must sit above hero content for dropdown clicks */
.site-header-nav{
  position: relative;
  z-index: 200;
  flex-shrink: 0;
}

.navbar-secondary{
  position: relative;
  z-index: 201;
  background: rgba(0, 0, 0, 0.22);
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.navbar-secondary__list{
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 0.35rem 1.35rem;
  list-style: none;
  margin: 0;
  padding: 0.4rem 0;
  width: 100%;
}

.navbar-secondary__item--external{
  margin-left: 0.5rem;
}

.navbar-secondary__link--external{
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.navbar-secondary__link--external .bi{
  font-size: 0.9em;
  opacity: 0.82;
  line-height: 1;
}

.navbar-secondary__link{
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
  padding: 0.15rem 0 0.35rem;
  transition: color 0.18s ease;
}

.navbar-secondary__link:hover,
.navbar-secondary__link:focus{
  color: #fff;
}

.navbar-secondary__link.active{
  color: #fff;
}

.navbar-overlay{
  background: rgba(0,0,0,.10);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
}

.navbar-tc-main.navbar-overlay{
  position: relative;
  z-index: 202;
  background: #343a40;
  backdrop-filter: none;
}

.navbar-tc-main .dropdown-menu{
  z-index: 1200;
  min-width: 13rem;
  padding: 0.45rem 0;
  margin-top: 0.35rem;
  box-shadow: 0 16px 40px -12px rgba(0, 0, 0, 0.55);
}

.navbar-tc-main .dropdown-item{
  padding: 0.6rem 1.15rem;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  text-transform: none;
  line-height: 1.35;
}

.navbar-tc-main .dropdown-item:hover,
.navbar-tc-main .dropdown-item:focus{
  background: rgba(244, 121, 45, 0.18);
  color: #fff;
}

.navbar-tc-main .navbar-nav-tc .nav-link{
  color: #fff;
  font-weight: 700;
  font-size: 0.8125rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.navbar-tc-main .navbar-nav-tc .nav-link:hover,
.navbar-tc-main .navbar-nav-tc .nav-link:focus{
  color: #fff;
}

.navbar-tc-main .navbar-nav-tc .nav-link.active{
  color: #fff;
}

.navbar-tc-main .tc-nav-chevron{
  color: var(--tc-orange-left);
  font-size: 0.7em;
  margin-left: 0.1rem;
}

.navbar-tc-main .dropdown-toggle::after{
  display: none;
}

.navbar .nav-link{
  color: rgba(255,255,255,.85);
}

.navbar .nav-link:hover{
  color: #fff;
}

@media (min-width: 992px){
  .navbar-nav .btn-tc-primary.btn-sm{
    padding: 0.55rem 1.4rem;
    font-size: 1.05rem;
    line-height: 1.45;
  }
}

.brand-mark svg{
  height: 32px;
  width: auto;
  display: block;
}

.btn-tc-primary{
  background: transparent;
  border: 1px solid var(--tc-teal);
  color: #fff;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
}

.btn-tc-primary:hover{
  background: rgba(0,145,138,.12);
  border-color: var(--tc-teal);
  color: #fff;
}

.btn-outline-light{
  background: var(--tc-orange-left);
  border-color: var(--tc-orange-left);
  color: #fff;
}

.btn-outline-light:hover{
  background: #de6d27;
  border-color: #de6d27;
  color: #fff;
}

.btn-process-outline{
  background: transparent;
  border: 2px solid rgba(255,255,255,.7);
  color: #fff;
}

.btn-process-outline:hover{
  background: rgba(255,255,255,.1);
  border-color: #fff;
  color: #fff;
}

.btn-tc-filled{
  background: var(--tc-teal);
  border: 1px solid var(--tc-teal);
  color: #fff;
}

.btn-tc-filled:hover{
  background: #007a74;
  border-color: #007a74;
  color: #fff;
}

.hero-content{
  padding: clamp(6rem, 9.6vw, 8.4rem) 0 clamp(3rem, 4.8vw, 3.6rem);
}

/* Landing hero: same .container max-widths as Bootstrap (aligns with how-utility-incentives-work hero) */
@media (min-width: 576px){
  .hero-content--landing > .container{
    max-width: 540px;
  }
}
@media (min-width: 768px){
  .hero-content--landing > .container{
    max-width: 720px;
  }
}
@media (min-width: 992px){
  .hero-content--landing > .container{
    max-width: 960px;
  }
}
@media (min-width: 1200px){
  .hero-content--landing > .container{
    max-width: 1140px;
  }
}
@media (min-width: 1400px){
  .hero-content--landing > .container{
    max-width: 1320px;
  }
}

/* Landing hero fills the viewport; content vertically centers in remaining space */
.hero-content--landing{
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: clamp(1.5rem, 3vw, 3rem);
  padding-bottom: 0;
}

/* Landing page only: row nudge for PNG alignment */
@media (min-width: 992px){
  .hero-content--landing .hero-content-row{
    margin-bottom: -20px;
  }

  /* Copy / visual split: 40% / 60% */
  .hero-content--landing .hero-content-row .hero-copy{
    flex: 0 0 40%;
    width: 40%;
    max-width: 40%;
  }

  .hero-content--landing .hero-content-row .hero-visual-col{
    flex: 0 0 60%;
    width: 60%;
    max-width: 60%;
  }
}

.hero-copy{
  position: relative;
  z-index: 3;
}

.hero-content--landing .hero-copy{
  transform: translateY(-40px);
}

/* The TC Standard page — wide text banner, no building visual */
.hero-content--tc-standard .hero-copy{
  transform: none;
}

.hero-content--tc-standard .hero-title{
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: clamp(1.55rem, 2.65vw, 2.25rem);
}

.hero-content--tc-standard .hero-question{
  font-size: clamp(1.05rem, 1.85vw, 1.2rem);
  line-height: 1.55;
  color: rgba(255,255,255,.9);
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}

.tc-standard-context{
  background: #f8f7f4;
  border-top: 1px solid rgba(0,0,0,.06);
}

.tc-standard-context-prose{
  margin-left: auto;
  margin-right: auto;
}

.tc-standard-context-lead{
  font-size: 1.0625rem;
  line-height: 1.65;
  color: #1a1a1a;
}

/* Editorial lead-in + drop cap (first sentence only) */
.tc-standard-context-opener{
  display: flow-root;
  font-size: clamp(1.04rem, 1.35vw, 1.14rem);
  font-weight: 500;
  line-height: 1.52;
  letter-spacing: -0.008em;
  color: #161616;
  margin-bottom: 0.75rem;
  padding: 0.25rem 0 0.25rem 0.85rem;
  border-left: 2px solid rgba(0,145,138,.45);
  background: linear-gradient(90deg, rgba(0,145,138,.035), transparent min(100%, 14rem));
}

.tc-standard-context-opener::first-letter{
  float: left;
  font-size: clamp(1.95rem, 4.2vw, 2.4rem);
  line-height: 0.92;
  font-weight: 700;
  padding-right: 0.28rem;
  margin-top: 0.03em;
  color: var(--tc-teal);
}

.tc-standard-context-body{
  font-weight: 400;
  color: rgba(0,0,0,.76);
}

.tc-standard-pillars{
  background: #fff;
  border-top: 1px solid rgba(0,0,0,.06);
}

.tc-pillar-toggle-outer{
  width: 100%;
  max-width: min(100%, 42rem);
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 576px){
  /*
    Outer is the positioning + stacking context. Track stays position:static so the & (absolute)
    is centered on the true seam (50% of outer), not the padded flex track box.
  */
  .tc-pillar-toggle-outer{
    position: relative;
    z-index: 0;
    isolation: isolate;
  }

  .tc-pillar-toggle-track.path-toggle-track{
    position: static;
    align-items: stretch;
    gap: 0;
  }

  /* Segmented control: flat inner edges so the & can straddle the seam */
  .tc-pillar-toggle-track > .tc-pillar-btn:first-child{
    border-radius: 10px 0 0 10px;
  }

  .tc-pillar-toggle-track > .tc-pillar-btn:last-child{
    border-radius: 0 10px 10px 0;
  }

  .tc-pillar-toggle-track > .tc-pillar-btn{
    position: relative;
    z-index: 1;
  }

  .tc-pillar-toggle-outer .tc-pillar-and-wrap{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(calc(-50% - 15px), -50%);
    margin: 0;
    z-index: 30;
  }

  .tc-pillar-btn{
    align-items: center;
    text-align: center;
  }

  .tc-pillar-btn .path-toggle-label{
    text-align: center;
    width: 100%;
  }
}

@media (max-width: 575.98px){
  .tc-pillar-toggle-track > .tc-pillar-btn{
    border-radius: 12px;
  }

  .tc-pillar-and-wrap{
    margin: 0.15rem auto;
  }
}

/* Split teal / orange ampersand between the two pillars */
.tc-pillar-and-wrap{
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  pointer-events: none;
  position: relative;
}

.tc-pillar-and-wrap::before{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  background: #fff;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.06),
    0 2px 10px rgba(0,0,0,.07);
  z-index: 0;
}

.tc-pillar-and{
  position: relative;
  z-index: 1;
  width: 1.85rem;
  height: 2.5rem;
}

.tc-pillar-and__layer{
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  text-align: center;
  font-size: clamp(1.15rem, 2.2vw, 1.5rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
}

.tc-pillar-and__layer--teal{
  color: var(--tc-teal);
  clip-path: polygon(0 0, 50% 0, 50% 100%, 0 100%);
}

.tc-pillar-and__layer--orange{
  color: var(--tc-orange-left);
  clip-path: polygon(50% 0, 100% 0, 100% 100%, 50% 100%);
}

.tc-pillar-panel{
  border-style: solid;
  border-color: rgba(0,0,0,.08);
  background: #fff;
  padding: clamp(1.25rem, 2.2vw, 1.75rem);
}

.tc-pillar-panel[hidden]{
  display: none !important;
}

.tc-pillar-panel-title{
  display: flex;
  align-items: center;
  gap: 0.65rem;
  font-weight: 800;
  font-size: clamp(1.15rem, 2vw, 1.35rem);
  color: #1a1a1a;
  letter-spacing: -0.02em;
  margin-bottom: 1.35rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.tc-pillar-panel-title-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 12px;
  flex-shrink: 0;
  font-size: 1.25rem;
}

.tc-pillar-panel-title-icon--integration{
  background: linear-gradient(135deg, rgba(244,121,45,.18), rgba(248,149,29,.14));
  color: var(--tc-orange-left);
  border: 1px solid rgba(244,121,45,.28);
}

.tc-pillar-panel-title-icon--service{
  background: rgba(0,145,138,.12);
  color: var(--tc-teal);
  border: 1px solid rgba(0,145,138,.28);
}

.tc-pillar-item-list{
  display: flex;
  flex-direction: column;
  gap: 1.35rem;
}

.tc-pillar-item{
  display: flex;
  gap: 0.85rem;
  align-items: flex-start;
}

.tc-pillar-item-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 10px;
  flex-shrink: 0;
  font-size: 1.1rem;
  color: var(--tc-teal);
  background: rgba(0,145,138,.08);
  border: 1px solid rgba(0,145,138,.15);
}

#tc-pillar-panel-integration .tc-pillar-item-icon{
  color: var(--tc-orange-left);
  background: rgba(244,121,45,.08);
  border-color: rgba(244,121,45,.18);
}

.tc-pillar-item-lead{
  font-size: 1rem;
  color: #1a1a1a;
}

.tc-pillar-item .mb-0{
  font-size: 0.98rem;
  line-height: 1.6;
  color: rgba(0,0,0,.72);
}

.tc-pillar-inline-link{
  font-weight: 600;
  color: var(--tc-teal);
  text-decoration: none;
  border-bottom: 1px solid rgba(0,145,138,.35);
}

.tc-pillar-inline-link:hover{
  color: #007a74;
  border-bottom-color: rgba(0,122,116,.55);
}

.tc-standard-prose{
  color: #1a1a1a;
}

.tc-standard-prose p{
  line-height: 1.65;
}

/* Hero CTAs: a bit larger than default .btn; labels stay on one line from sm up */
.hero-content--landing .hero-cta-row .btn{
  padding: 0.7rem 1.55rem;
  font-size: 1.2rem;
  line-height: 1.5;
}

@media (min-width: 576px){
  .hero-content--landing .hero-cta-row{
    flex-wrap: nowrap;
    align-items: center;
  }

  .hero-content--landing .hero-cta-row .btn{
    white-space: nowrap;
  }
}

/* Space below headline; subtitle + CTAs follow */
.hero-content--landing .hero-copy .hero-title{
  margin-bottom: 1.4rem !important;
  font-size: clamp(3.45rem, 5.7vw, 5.25rem);
}
@media (min-width: 576px){
  .hero-content--landing .hero-copy .hero-title{
    margin-bottom: 1.65rem !important;
  }
}

/* Incentives hub hero — matches incentives.tccontrols.com (not main homepage scale) */
.hero-content--incentives-hub.hero-content--landing .hero-copy .hero-title{
  font-size: clamp(1.85rem, 3.05vw, 2.8rem);
  margin-bottom: 2.35rem !important;
}
@media (min-width: 576px){
  .hero-content--incentives-hub.hero-content--landing .hero-copy .hero-title{
    margin-bottom: 3.4rem !important;
  }

  .hero-content--incentives-hub.hero-content--landing #heroTitle2{
    white-space: normal;
  }
}

@media (max-width: 991.98px){
  .hero-content--incentives-hub.hero-content--landing .hero-copy .hero-title{
    font-size: clamp(2.2rem, 6.5vw, 2.65rem);
  }
}

@media (max-width: 575.98px){
  .hero-content--incentives-hub.hero-content--landing .hero-copy .hero-title{
    margin-bottom: 1.85rem !important;
  }
}

.hero-visual{
  position: relative;
  min-height: 874px;
}

.hero-artboard{
  position: absolute;
  right: 50px;
  bottom: 0px;
  width: min(115%, 1175px);
  aspect-ratio: 1536 / 1152;
  z-index: 2;
  overflow: visible;
}

.hero-building,
.particle-scene{
  position: absolute;
  top: 0;
  left: 60px;
  width: 100%;
  height: 100%;
}

/* Same inner offset as .hero-building so SVG circuits align with the PNG */
.particle-scene .circuit-traces,
.particle-scene .circuit-glow,
.particle-scene .hero-target-logo{
  position: absolute;
  top: 0;
  left: 60px;
  width: 100%;
  height: 100%;
}

.hero-building{
  z-index: 2;
  pointer-events: none;
  object-fit: contain;
  object-position: bottom center;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.28));
  /* Soft fade on left + right edges */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 14%,
    black 86%,
    transparent 100%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 30%,
    black 60%,
    transparent 100%
  );
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.particle-scene{
  overflow: visible;
  pointer-events: none;
  z-index: 4;
}

.particle-node{
  position: absolute;
  width: 7.4px;
  height: 7.4px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  opacity: .9;
  box-shadow: 0 0 11px currentColor;
  will-change: left, top, opacity, background-color, transform;
  z-index: 5;
  transition: opacity 0.55s ease;
}

.particle-node.is-large{
  width: 8.7px;
  height: 8.7px;
}

.particle-node.is-roamer{
  width: 10.35px;
  height: 10.35px;
  box-shadow: 0 0 16px currentColor;
  opacity: .85;
}

.particle-node.is-overlay{
  z-index: 10;
}

.circuit-traces,
.circuit-glow{
  opacity: 0;
  transition: opacity 1.1s ease;
  pointer-events: none;
  z-index: 3;
  transform: translateY(25px);
}

.circuit-traces svg,
.circuit-glow svg,
.hero-target-logo svg{
  width: 100%;
  height: 100%;
}

.circuit-glow{
  filter: blur(14px);
}

.circuit-traces .trace-outline--rail{
  stroke-dasharray: 22 26;
}

.hero-artboard.is-formed .circuit-traces .trace-outline--rail{
  animation: traceRace 14s linear infinite;
}

.hero-artboard.is-formed .circuit-traces .trace-outline--rail-b{
  animation-delay: -7s;
}

@media (prefers-reduced-motion: reduce){
  .hero-artboard.is-formed .circuit-traces .trace-outline--rail{
    animation: none;
  }
}

.hero-artboard.is-formed .circuit-traces{
  opacity: .32;
}

.hero-artboard.is-formed .circuit-glow{
  opacity: .32;
  filter: blur(22px) drop-shadow(0 0 18px rgba(244,121,45,0.55)) drop-shadow(0 0 36px rgba(248,149,29,0.35));
}

.hero-target-logo{
  opacity: 0;
  pointer-events: none;
  z-index: 1;
  /* Same vertical offset as .circuit-traces / .circuit-glow so #targetPaths match visible tracers */
  transform: translateY(25px);
}

@keyframes traceRace{
  from { stroke-dashoffset: 0; }
  to { stroke-dashoffset: -220; }
}

.hero-kicker{
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.75);
  margin-bottom: 0.75rem;
}

.hero-content--landing .hero-kicker{
  font-size: clamp(0.875rem, 2.85vw, 1.05rem);
  margin-bottom: 0.95rem;
}

@media (min-width: 1200px){
  .hero-content--landing .hero-kicker{
    white-space: nowrap;
  }
}

.hero-title{
  font-weight: 800;
  line-height: 1.05;
  font-size: clamp(2.3rem, 3.8vw, 3.5rem);
}

.hero-title-line{
  display: inline;
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.hero-title-line.is-visible{
  opacity: 1;
  transform: translateX(0);
}

.hero-title-sub{
  font-weight: 700;
  color: var(--tc-orange-left);
}

.hero-content--landing .hero-subtitle{
  font-size: clamp(1.2rem, 1.6vw, 1.4rem);
  line-height: 1.55;
  color: rgba(255,255,255,.82);
  max-width: 42rem;
}

/* Keep stacked headline lines from awkward mid-phrase wraps */
@media (min-width: 576px){
  .hero-content--landing #heroTitle2,
  .hero-content--landing #heroTitle3{
    white-space: nowrap;
  }
}

/* Mobile / tablet: tighter hero bottom padding */
@media (max-width: 991.98px){
  .hero-content--landing{
    padding-bottom: clamp(0.65rem, 2.2vw, 1.1rem);
  }
}

/* ── Section 2 — full-viewport video + stacked copy ── */

.section-2{
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: min(72vh, 700px);
  border-top: 0;
}

.section-2-video-layer{
  position: absolute;
  inset: 0;
  z-index: 0;
}

.section-2-video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  pointer-events: none;
  background: #0a0e12;
}

.section-2-scrim{
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    rgba(8, 14, 22, 0.78) 0%,
    rgba(8, 14, 22, 0.42) 48%,
    rgba(8, 14, 22, 0.62) 100%
  );
  pointer-events: none;
}

.section-2-content{
  position: relative;
  z-index: 1;
  padding-top: clamp(4.5rem, 12vw, 7.5rem);
  padding-bottom: clamp(2rem, 5vw, 3.25rem);
  min-height: min(58vh, 620px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.section-2-lead-col{
  display: flex;
  align-items: center;
}

.section-2-lead-heading{
  color: #fff;
  font-weight: 800;
  line-height: 1.12;
  font-size: clamp(1.2rem, 2.05vw, 1.85rem);
  letter-spacing: -0.02em;
  max-width: none;
}

.section-2-lead-heading .section-2-heading-line{
  display: block;
}

.section-2-lead-heading .section-2-heading-line + .section-2-heading-line{
  margin-top: 0.18rem;
}

@media (min-width: 992px){
  .section-2-lead-heading .section-2-heading-line:first-child{
    white-space: nowrap;
  }
}

@media (min-width: 1200px){
  .section-2-lead-heading .section-2-heading-line:last-child{
    white-space: nowrap;
  }
}

.section-2-lead-heading .fade-in-late{
  display: inline;
  opacity: 0;
  transition: opacity 0.65s ease;
  transition-delay: 0ms;
}

.section-2.section-2--in-view .fade-in-late{
  opacity: 1;
  transition-delay: 0ms;
}

@media (prefers-reduced-motion: reduce){
  .section-2 .fade-in-late{
    opacity: 1;
    transition: none;
  }
}

.section-2-circuit-overlay{
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.section-2-circuit-svg{
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
}

.section-2-fork-glow{
  filter: blur(5px);
  pointer-events: none;
}

.section-2-fork-trace{
  opacity: 0;
  stroke-linecap: round;
}

.section-2-row{
  position: relative;
  z-index: 3;
}

@media (min-width: 992px){
  .section-2-row.section-2-row.row{
    --bs-gutter-x: clamp(2.75rem, 6.5vw, 5.75rem);
  }
}

.section-2-lead-heading .section-2-line2{
  color: var(--tc-orange-left);
  white-space: nowrap;
}

.section-2-lead-heading #section2Later{
  font-weight: 800;
}

.section-2-subpoints-col{
  position: relative;
  display: flex;
  align-items: center;
}

.section-2-subpoints-col > .section-2-subpoints{
  width: 100%;
}

.section-2-subpoints{
  display: flex;
  flex-direction: column;
  gap: clamp(2.85rem, 6.75vw, 4.25rem);
  max-width: 34rem;
}

.section-2-subpoint-inner{
  display: flex;
  gap: 0.85rem;
  align-items: flex-start;
}

.section-2-node-anchor{
  flex: 0 0 11px;
  width: 11px;
  height: 11px;
  margin-top: 0.42rem;
  border-radius: 2px;
  background: #0c121a;
  border: 2px solid #e86f28;
  box-shadow: none;
}

.section-2-subpoint-copy{
  flex: 1 1 auto;
  min-width: 0;
}

.section-2-subpoint-lead{
  color: #fff;
  font-size: clamp(1.05rem, 1.65vw, 1.2rem);
  line-height: 1.35;
}

.section-2-subpoint-lead--nowrap{
  white-space: nowrap;
}

.section-2-subpoint-body{
  color: rgba(255, 255, 255, 0.86);
  font-size: 1.0325rem;
  line-height: 1.55;
}

.section-2-subpoint{
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  transition:
    opacity 0.55s ease,
    transform 0.55s ease;
}

.section-2.section-2--subpoints-in .section-2-subpoint.section-2-subpoint--revealed{
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

@media (prefers-reduced-motion: reduce){
  .section-2.section-2--subpoints-in .section-2-subpoint{
    opacity: 1;
    transform: none;
    transition: none;
  }
}

.section-2-fork-trace.section-2-fork-trace--live{
  animation: section2TraceRace 10s linear infinite;
}

@media (prefers-reduced-motion: reduce){
  .section-2-fork-trace.section-2-fork-trace--live{
    animation: none;
  }
}

@keyframes section2TraceRace{
  from{
    stroke-dashoffset: 0;
  }
  to{
    stroke-dashoffset: -7.1;
  }
}


/* ── BMS incentives hub — proof strip & sticky scroll ── */

.proof-strip{
  padding: 1.1rem 0 1.6rem;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.18);
  backdrop-filter: blur(8px);
}

/* Mobile / tablet: less air between hero CTAs ("See how it works") and proof strip */
@media (max-width: 991.98px){
  .hero-content--landing{
    padding-bottom: clamp(0.65rem, 2.2vw, 1.1rem);
  }

  .proof-strip{
    padding-top: 0.45rem;
  }
}

.proof-strip .proof-item{
  display: flex;
  gap: .8rem;
  align-items: flex-start;
  padding: .9rem 1rem;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  background: rgba(255,255,255,.04);
}

.proof-strip .proof-item i{
  font-size: 1.2rem;
  line-height: 1;
  color: rgba(255,255,255,.9);
  margin-top: .15rem;
}

.proof-strip .proof-title{
  font-weight: 700;
  line-height: 1.1;
  color: #fff;
}

.proof-strip .proof-sub{
  font-size: .95rem;
  color: rgba(255,255,255,.72);
  margin-top: .15rem;
}

/* ── Sticky scroll section (building left, text panels right) ── */
/* Desktop text panels: sized for ~1440×900 and similar; short windows use more of dvh
   so headlines aren’t clipped (avoid clamp min 18rem when 46vh is smaller). */

.sticky-scroll-section{
  position: relative;
  z-index: 1;
  overflow-x: clip;
  background:
    radial-gradient(800px 440px at 22% 40%, rgba(0,145,138,.06), transparent 60%),
    radial-gradient(700px 420px at 76% 30%, rgba(244,121,45,.05), transparent 60%),
    #f8f7f4;
  border-top: 1px solid rgba(0,0,0,.06);
}

@media (min-width: 992px){
  .sticky-scroll-section{
    overflow-x: visible;
    min-height: 220vh;
    display: flex;
    flex-direction: column;
  }

  .sticky-scroll-visual{
    position: sticky;
    top: 0;
    align-self: flex-start;
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    will-change: transform;
  }

  .sticky-text-viewport-wrap{
    position: sticky;
    top: 0;
    align-self: flex-start;
    height: 100vh;
    height: 100dvh;
    display: flex;
    align-items: center;
  }

  .sticky-text-viewport{
    /* Cap at 32rem; on short viewports use up to 85vh so content fits (pairs with JS slide distance). */
    height: min(32rem, 85vh);
    height: min(32rem, 85dvh);
    overflow: hidden;
    width: 100%;
    position: relative;
  }

  .sticky-text-track{
    will-change: transform;
  }

  .sticky-text-track .sticky-copy-block{
    box-sizing: border-box;
    height: min(32rem, 85vh);
    height: min(32rem, 85dvh);
    min-height: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-top: 0;
    padding: 0.75rem 0 1rem;
  }

  @supports (justify-content: safe center){
    .sticky-text-track .sticky-copy-block{
      justify-content: safe center;
    }
  }
}

.sticky-scroll-inner{
  padding-top: 0;
  padding-bottom: 0;
}

@media (min-width: 992px){
  .sticky-scroll-inner{
    padding-bottom: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
  }

  .sticky-scroll-inner > .row{
    flex: 1 1 auto;
  }
}

@media (max-width: 991.98px){
  .sticky-scroll-visual{
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .sticky-copy-block + .sticky-copy-block{
    margin-top: clamp(2rem, 4vw, 3rem);
  }
}

.sticky-scroll-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(0,0,0,.02) 0px,
      rgba(0,0,0,.02) 1px,
      transparent 1px,
      transparent 14px
    );
  opacity: .6;
  pointer-events: none;
}

.sticky-text-col{
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sticky-copy-block{
  max-width: 36rem;
}

.sticky-copy-block h2{
  color: #1a1a1a;
  font-weight: 800;
  line-height: 1.15;
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  letter-spacing: -0.02em;
}

.sticky-copy-block p{
  color: rgba(0,0,0,.70);
  font-size: 1.05rem;
}

/* Sticky panels 2 & 3: ~15% larger type than base .sticky-copy-block */
#panel2 h2,
#panel3 h2{
  font-size: clamp(1.84rem, 2.875vw, 2.53rem);
}

#panel2 p,
#panel3 p{
  font-size: 1.2075rem;
}

#panel2 .pain-list li,
#panel2 .pain-list i{
  font-size: 1.2075rem;
}

#panel2 .scroll-prompt{
  font-size: 1.0925rem;
}

#panel2 .scroll-prompt-arrow{
  font-size: 1.61rem;
}

/* Section 2 / panel 3 — “Learn more” CTA: larger, orange outline + text (matches scroll-prompt / TC orange) */
#panel3 .panel3-cta-btn{
  background: transparent;
  border: 2px solid var(--tc-orange-left);
  color: var(--tc-orange-left);
  font-weight: 700;
  font-size: 1.4375rem;
  padding-left: 1.35rem;
  padding-right: 1.35rem;
  box-shadow: none;
}

#panel3 .panel3-cta-btn:hover,
#panel3 .panel3-cta-btn:focus-visible{
  background: rgba(244,121,45,.1);
  border-color: var(--tc-orange-left);
  color: var(--tc-orange-left);
}

.scroll-prompt{
  display: flex;
  flex-direction: column;
  align-items: left;
  gap: 0.35rem;
  color: rgba(0,0,0,.55);
  font-size: 0.95rem;
  font-weight: 800;
}

.scroll-prompt-arrow{
  font-size: 1.4rem;
  animation: scroll-bounce 1.8s ease-in-out infinite;
}

@keyframes scroll-bounce{
  0%, 100%{ transform: translateY(0); }
  50%{ transform: translateY(6px); }
}

.pain-list li{
  color: rgba(0,0,0,.75);
}

.pain-list i{
  color: var(--tc-orange-left);
}

.pain-list{
  list-style: none;
  padding: 0;
  margin: 1.25rem 0 0;
  display: grid;
  gap: .75rem;
}

.pain-list li{
  display: flex;
  gap: .75rem;
  align-items: flex-start;
  font-size: 1.05rem;
}

.pain-list i{
  margin-top: .15rem;
  font-size: 1.05rem;
  flex: 0 0 auto;
}

.feature-graphic{
  position: relative;
  margin: 0 auto;
  max-width: 480px;
  min-height: 320px;
}

@media (max-width: 991.98px){
  .sticky-scroll-section .feature-graphic{
    margin-top: clamp(1.25rem, 3.5vh, 2.5rem);
  }
}

@media (min-width: 992px){
  .feature-graphic-col{
    align-self: stretch;
    overflow: visible;
  }

  /* Building stays inside the left column (no bleed). Do not use overflow:hidden here — it breaks
     position:sticky on .sticky-scroll-visual, so the graphic would scroll away instead of staying pinned. */
  .feature-graphic-col--contained{
    min-width: 0;
  }

  .feature-graphic.feature-graphic--contained{
    width: 100%;
    max-width: 100%;
    min-height: 540px;
    margin: 0;
  }

  .feature-graphic--contained .feature-graphic-img{
    width: 100%;
    max-width: 100%;
    height: auto;
    object-fit: contain;
    object-position: bottom center;
    margin: 0;
    display: block;
    transform: scale(1.71) translateX(-10%);
    transform-origin: bottom center;
    will-change: filter, transform;
  }

  .feature-graphic.feature-graphic--bleed-left{
    max-width: none;
    width: min(265%, 1460px);
    min-height: 540px;
    margin-top: 0;
    margin-left: max(-68vw, -60rem);
    margin-right: auto;
  }

  .feature-graphic--bleed-left .feature-graphic-img{
    width: 100%;
    max-width: none;
    height: auto;
    object-fit: contain;
    object-position: 65% center;
    margin: 0;
    display: block;
  }
}

.feature-graphic-img{
  position: relative;
  width: 100%;
  max-width: 480px;
  height: auto;
  object-fit: contain;
  object-position: center;
  display: block;
  margin: 0 auto;
  will-change: filter;
}

/* ── BMS incentives hub — case study cards ── */

.case-studies-section{
  position: relative;
  padding: clamp(4rem, 8vw, 6rem) 0;
  background:
    radial-gradient(800px 440px at 22% 40%, rgba(0,145,138,.06), transparent 60%),
    radial-gradient(700px 420px at 76% 30%, rgba(244,121,45,.05), transparent 60%),
    #f8f7f4;
  border-top: 1px solid rgba(0,0,0,.06);
}

.case-studies-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    135deg,
    rgba(0,0,0,.02) 0px,
    rgba(0,0,0,.02) 1px,
    transparent 1px,
    transparent 14px
  );
  opacity: .6;
  pointer-events: none;
}

.case-studies-section .container{
  position: relative;
  z-index: 1;
}

.case-studies-intro{
  max-width: 40rem;
}

.case-studies-section-title{
  font-weight: 800;
  font-size: clamp(1.65rem, 2.6vw, 2.25rem);
  color: #1a1a1a;
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.case-study-card{
  display: block;
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.08);
  border: 1px solid rgba(0,0,0,.06);
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.3s ease;
}

/* No transform on the card: CSS transform on an ancestor breaks Leaflet tile alignment. */
.case-study-card:hover{
  box-shadow: 0 12px 40px rgba(0,0,0,.12);
}

.case-study-card-link{
  display: block;
  text-decoration: none;
  color: inherit;
}

.case-study-image{
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.case-study-image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Leaflet: map must fill a sized box; absolute fill + invalidateSize() keeps tiles aligned. */
.case-study-image--map{
  position: relative;
  background: #dfe5e8;
}

.case-study-map-canvas{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

.case-study-image--map .leaflet-container{
  width: 100%;
  height: 100%;
  font-family: inherit;
  background: #dfe5e8;
}

.case-study-marker-icon .case-study-marker-inner{
  display: flex;
  justify-content: center;
}

.case-study-content{
  padding: 1.5rem 1.5rem 1.75rem;
}

.case-study-title{
  font-size: 1.35rem;
  font-weight: 800;
  color: #1a1a1a;
  margin: 0 0 1.25rem;
  letter-spacing: -0.02em;
}

.case-study-facts{
  list-style: none;
  margin: 0 0 1.25rem;
  padding: 0;
}

.case-study-facts li{
  position: relative;
  padding-left: 1rem;
  margin-bottom: 0.85rem;
  border-left: 3px solid var(--tc-teal);
}

.case-study-facts li:last-child{
  margin-bottom: 0;
}

.case-study-fact-label{
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--tc-orange-left);
  margin-bottom: 0.2rem;
}

.case-study-fact-value{
  display: block;
  font-size: 0.95rem;
  color: #2a2a2a;
}

.case-study-cta{
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--tc-teal);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.case-study-card:hover .case-study-cta{
  color: var(--tc-orange-left);
}

@media (max-width: 991.98px){
  .mobile-panel-icon{
    display: flex;
    justify-content: center;
    font-size: 2.25rem;
    color: var(--tc-orange-left);
    margin-bottom: 0.85rem;
  }

  #panel2 .mobile-panel-icon,
  #panel3 .mobile-panel-icon{
    font-size: 2.5875rem;
  }

  .sticky-scroll-inner{
    padding-top: clamp(1.25rem, 3vw, 2rem);
  }

  #panel2 .mobile-panel-icon{
    margin-top: 0.5rem;
    margin-bottom: 1.1rem;
    padding: 0.85rem 0 0.35rem;
  }

  .sticky-scroll-section{
    padding-bottom: clamp(2rem, 5vw, 3.25rem);
  }
}

.process-section{
  position: relative;
  color: #fff;
  padding-top: clamp(3.25rem, 7vw, 5.5rem);
  padding-bottom: clamp(3.25rem, 7vw, 5.5rem);
  background:
    radial-gradient(920px 520px at 16% 22%, rgba(0,145,138,.24), transparent 62%),
    radial-gradient(760px 440px at 86% 30%, rgba(244,121,45,.16), transparent 64%),
    linear-gradient(135deg, #070b12, #0b1526);
  border-top: 1px solid rgba(255,255,255,.08);
}

.process-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    135deg,
    rgba(255,255,255,.05) 0px,
    rgba(255,255,255,.05) 1px,
    transparent 1px,
    transparent 14px
  );
  opacity: .3;
  pointer-events: none;
}

.process-section .container{
  position: relative;
  z-index: 1;
}

.process-intro{
  max-width: 860px;
}

.process-title{
  font-weight: 800;
  line-height: 1.1;
  font-size: clamp(1.9rem, 3.1vw, 2.7rem);
  letter-spacing: -0.02em;
}

.process-subtitle{
  color: rgba(255,255,255,.82);
  font-size: clamp(1rem, 1.7vw, 1.15rem);
}

.process-flow{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 1rem;
}

.process-step{
  position: relative;
  text-align: center;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.process-step-box{
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 100%;
  padding: 1rem 0.75rem 1.1rem;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  transition: background 0.25s ease, border-color 0.25s ease;
  cursor: pointer;
}

.process-step-box:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(244,121,45,.35);
}

.process-step-desc{
  margin: 0.75rem 0 0;
  padding: 0;
  font-size: 0.88rem;
  line-height: 1.4;
  color: rgba(255,255,255,.72);
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.35s ease, opacity 0.3s ease, margin 0.3s ease;
}

.process-step-box:hover .process-step-desc{
  max-height: 320px;
  opacity: 1;
}

.process-step::after{
  content: "";
  position: absolute;
  top: 32px;
  left: calc(50% + 28px);
  width: calc(100% - 56px);
  height: 1px;
  background: linear-gradient(to right, rgba(244,121,45,.55), rgba(248,149,29,.3));
}

.process-step:last-child::after{
  display: none;
}

.process-step-number{
  width: 32px;
  height: 32px;
  margin: 0 auto 0.85rem;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 0.88rem;
  font-weight: 700;
  color: #fff;
  border: 1px solid rgba(244,121,45,.75);
  background: rgba(244,121,45,.18);
  box-shadow: 0 0 0 1px rgba(255,255,255,.05) inset;
}

.process-step-number i{
  font-size: 0.95rem;
  line-height: 1;
}

.process-step-label{
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  width: 100%;
  min-height: 4.5em;
  color: rgba(255,255,255,.88);
  font-size: 0.98rem;
  line-height: 1.35;
}

@media (max-width: 991.98px){
  .process-flow{
    grid-template-columns: 1fr;
    gap: 1.1rem;
  }

  .process-step{
    text-align: left;
  }

  .process-step-box{
    display: grid;
    grid-template-columns: 32px 1fr;
    align-items: start;
    column-gap: 0.8rem;
  }

  .process-step-label{
    display: block;
    min-height: 0;
    flex: none;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .process-step-box .process-step-desc{
    grid-column: 1 / -1;
  }

  .process-step-box .process-step-number{
    margin: 0;
  }

  .process-step::after{
    left: 16px;
    top: calc(100% + 0.35rem);
    width: 1px;
    height: 0.9rem;
    background: linear-gradient(to bottom, rgba(244,121,45,.55), rgba(248,149,29,.3));
  }

  .process-step-number{
    margin: 0;
  }
}

.take-control-intro{
  max-width: min(56rem, 100%);
}

.take-control-intro .process-title{
  font-size: clamp(1.5rem, 2.85vw, 2.35rem);
  line-height: 1.18;
}

.take-control-cards{
  --take-control-accent-rule: rgba(244,121,45,.92);
}

.take-control-card{
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 0;
  padding-top: 1.75rem;
  border: none;
  border-radius: 0;
  background: transparent;
  border-top: 3px solid var(--take-control-accent-rule);
  box-shadow: none;
}

.take-control-card-title{
  margin: 0 0 0.9rem;
  font-weight: 800;
  font-size: clamp(1.05rem, 1.45vw, 1.22rem);
  line-height: 1.28;
  letter-spacing: -0.02em;
  color: #fff;
}

.take-control-card-body{
  margin: 0;
  flex-grow: 1;
  font-size: clamp(0.94rem, 1.05vw, 1.035rem);
  line-height: 1.58;
  color: rgba(255,255,255,.82);
}

.take-control-card-link{
  margin-top: auto;
  padding-top: 1.35rem;
  font-weight: 700;
  font-size: 0.9375rem;
  letter-spacing: 0.01em;
  color: var(--accent-orange);
  text-decoration: none;
  transition: color 0.2s ease, letter-spacing 0.2s ease;
}

.take-control-card-link:hover{
  color: var(--tc-orange-right);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.service-quad-band{
  position: relative;
  padding-top: clamp(1.1rem, 2.35vw, 1.65rem);
  padding-bottom: clamp(1.1rem, 2.35vw, 1.65rem);
  background: #eef0f4;
  color: #1a2231;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.service-quad-band__grid{
  max-width: 48rem;
}

.service-quad-band__grid > .col:nth-child(odd) .service-quad-tile{
  border-right: 1px solid rgba(0, 0, 0, 0.065);
}

.service-quad-band__grid > .col:nth-child(-n + 2) .service-quad-tile{
  border-bottom: 1px solid rgba(0, 0, 0, 0.055);
}

.service-quad-tile{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(0.52rem, 1.6vw, 0.72rem);
  min-height: clamp(6.75rem, 16vw, 9.25rem);
  padding: clamp(1.05rem, 3.5vw, 1.65rem) 0.85rem;
  text-align: center;
  color: inherit;
  text-decoration: none;
  transition:
    transform 0.22s ease,
    color 0.2s ease;
}

.service-quad-tile:hover{
  transform: translateY(-3px);
  color: #1a2231;
}

.service-quad-tile:focus-visible{
  outline: 2px solid var(--accent-orange);
  outline-offset: 2px;
}

.service-quad-tile__icon{
  display: block;
  line-height: 1;
  font-size: clamp(1.28rem, 2.05vw, 1.42rem);
  color: rgba(26, 34, 49, 0.55);
}

.service-quad-tile__icon i{
  display: block;
  line-height: 1;
  font-weight: 400;
}

.service-quad-tile:hover .service-quad-tile__icon{
  color: rgba(26, 34, 49, 0.72);
}

.service-quad-tile__label{
  display: block;
  max-width: 15rem;
  margin-inline: auto;
  font-weight: 600;
  font-size: clamp(0.84rem, 1.22vw, 0.9625rem);
  line-height: 1.25;
  letter-spacing: -0.01em;
  text-wrap: balance;
}

.service-quad-tile:hover .service-quad-tile__label{
  text-decoration: underline;
  text-decoration-color: var(--accent-orange);
  text-decoration-thickness: 2px;
  text-underline-offset: 0.22em;
}

.quote-section{
  position: relative;
  padding: clamp(3.5rem, 7vw, 5rem) 0;
  background:
    radial-gradient(800px 440px at 22% 40%, rgba(0,145,138,.06), transparent 60%),
    radial-gradient(700px 420px at 76% 30%, rgba(244,121,45,.05), transparent 60%),
    #f8f7f4;
  border-top: 1px solid rgba(0,0,0,.06);
}

.quote-section .container{
  position: relative;
  z-index: 1;
}

.testimonial-quote{
  max-width: 720px;
  margin: 0 auto;
  padding: 2rem 2.5rem;
  border-left: 4px solid var(--tc-teal);
  background: rgba(255,255,255,.6);
  border-radius: 0 12px 12px 0;
  box-shadow: 0 2px 16px rgba(0,0,0,.04);
}

.quote-text{
  font-size: 1.25rem;
  line-height: 1.6;
  color: #1a1a1a;
  margin: 0 0 1.25rem;
  font-style: italic;
}

.quote-attribution{
  display: block;
}

.quote-name{
  font-style: normal;
  font-weight: 700;
  font-size: 1rem;
  color: #1a1a1a;
}

.quote-title{
  display: block;
  font-size: 0.9rem;
  color: rgba(0,0,0,.6);
  margin-top: 0.2rem;
}

.proof-section{
  position: relative;
  padding: clamp(3.25rem, 7vw, 5rem) 0 0;
  background:
    radial-gradient(800px 440px at 22% 40%, rgba(0,145,138,.06), transparent 60%),
    radial-gradient(700px 420px at 76% 30%, rgba(244,121,45,.05), transparent 60%),
    #f8f7f4;
  border-top: 1px solid rgba(0,0,0,.06);
}

.proof-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    135deg,
    rgba(0,0,0,.02) 0px,
    rgba(0,0,0,.02) 1px,
    transparent 1px,
    transparent 14px
  );
  opacity: .55;
  pointer-events: none;
}

.proof-section__inner{
  position: relative;
  z-index: 1;
  padding-bottom: clamp(2.25rem, 4vw, 3rem);
}

.proof-section-head{
  max-width: 40rem;
  margin-bottom: clamp(2rem, 4vw, 2.85rem);
}

.proof-section-title{
  font-weight: 800;
  font-size: clamp(1.65rem, 2.6vw, 2.25rem);
  color: #1a1a1a;
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.proof-row + .proof-row{
  margin-top: clamp(2rem, 4.5vw, 3rem);
}

.proof-row{
  overflow: hidden;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 4px 22px rgba(0, 0, 0, 0.065);
  border: 1px solid rgba(0, 0, 0, 0.065);
}

.proof-row__media{
  min-height: clamp(200px, 28vw, 300px);
  padding: 0;
}

@media (min-width: 992px){
  .proof-row__media{
    min-height: clamp(260px, 30vw, 360px);
  }
}

.proof-row__photo{
  width: 100%;
  height: 100%;
  min-height: inherit;
  overflow: hidden;
  background: #d8dde4;
}

.proof-row__photo img{
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  object-position: center;
}

.proof-row__body{
  padding: clamp(1.35rem, 3vw, 2rem);
  min-height: clamp(200px, 28vw, 300px);
}

@media (min-width: 992px){
  .proof-row__body{
    min-height: 0;
  }
}

.proof-card{
  max-width: 28rem;
}

.proof-tag{
  margin: 0 0 0.5rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-orange);
}

.proof-title{
  margin: 0 0 1rem;
  font-size: clamp(1.2rem, 1.85vw, 1.42rem);
  font-weight: 800;
  color: #161c27;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.proof-outcomes{
  margin: 0;
  padding: 0;
  list-style: none;
  color: rgba(22, 28, 39, 0.78);
  font-size: clamp(0.895rem, 1.05vw, 0.98rem);
  line-height: 1.5;
}

.proof-outcomes li{
  position: relative;
  padding-left: 1rem;
  margin-bottom: 0.5rem;
  border-left: 3px solid var(--tc-teal);
}

.proof-outcomes li:last-child{
  margin-bottom: 0;
}

.proof-timing{
  margin: 0.85rem 0 0;
  padding: 0;
  font-size: 0.88rem;
  line-height: 1.45;
  color: rgba(22, 28, 39, 0.62);
  font-style: italic;
}

.proof-link{
  display: inline-block;
  margin-top: 1.1rem;
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--tc-teal);
  text-decoration: none;
}

.proof-link:hover{
  color: var(--accent-orange);
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.also-serving-band{
  position: relative;
  z-index: 1;
  width: 100%;
  padding: clamp(0.72rem, 2vw, 1rem) 0;
  margin-top: 0;
  background: rgba(220, 224, 230, 0.75);
  border-top: 1px solid rgba(0, 0, 0, 0.07);
}

.also-serving-band__content{
  margin: 0;
  text-align: center;
  font-size: clamp(0.78rem, 1.05vw, 0.8625rem);
  line-height: 1.5;
  color: rgba(22, 28, 39, 0.7);
}

.also-serving-band__prefix{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  font-weight: 600;
  color: rgba(22, 28, 39, 0.78);
  margin-right: 0.35rem;
}

.also-serving-band__icon{
  font-size: 1rem;
  color: rgba(244, 121, 45, 0.75);
}

.also-serving-band__sep{
  display: inline-block;
  padding: 0 0.45rem;
  color: rgba(22, 28, 39, 0.35);
}

a.also-serving-sector-link{
  color: var(--accent-orange);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-color: rgba(244, 121, 45, 0.55);
  text-underline-offset: 0.22em;
}

a.also-serving-sector-link:hover{
  color: var(--tc-orange-right);
  text-decoration-color: var(--accent-orange);
}

.contact-section{
  position: relative;
  padding: clamp(3.5rem, 7vw, 5.25rem) 0;
  background:
    radial-gradient(900px 500px at 25% 20%, rgba(0,145,138,.28), transparent 60%),
    radial-gradient(800px 450px at 75% 80%, rgba(244,121,45,.18), transparent 60%),
    linear-gradient(135deg, var(--hero-bg-1), var(--hero-bg-2));
  border-top: 1px solid rgba(255,255,255,.08);
}

.contact-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    135deg,
    rgba(255,255,255,.05) 0px,
    rgba(255,255,255,.05) 1px,
    transparent 1px,
    transparent 14px
  );
  opacity: .25;
  pointer-events: none;
}

.contact-section .container{
  position: relative;
  z-index: 1;
}

.contact-intro{
  max-width: 46rem;
}

.contact-title{
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.12;
  font-size: clamp(1.7rem, 2.7vw, 2.35rem);
  color: #fff;
}

.contact-subtitle{
  color: rgba(255,255,255,.82);
  font-size: clamp(1.02rem, 1.5vw, 1.15rem);
  line-height: 1.6;
}

.faq-section{
  position: relative;
  padding: clamp(4rem, 8vw, 6rem) 0;
  background:
    radial-gradient(800px 440px at 20% 45%, rgba(255,255,255,.18), transparent 55%),
    radial-gradient(700px 400px at 85% 35%, rgba(248,149,29,.35), transparent 55%),
    linear-gradient(165deg, var(--tc-orange-left) 0%, var(--tc-orange-right) 100%);
  border-top: 1px solid rgba(0,0,0,.08);
}

.faq-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    135deg,
    rgba(255,255,255,.04) 0px,
    rgba(255,255,255,.04) 1px,
    transparent 1px,
    transparent 14px
  );
  opacity: .5;
  pointer-events: none;
}

.faq-section .container{
  position: relative;
  z-index: 1;
}

.faq-intro{
  max-width: 640px;
}

.faq-title{
  font-weight: 800;
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.faq-subtitle{
  font-size: 1.05rem;
  color: rgba(255,255,255,.88);
}

.faq-list{
  max-width: 720px;
  margin: 0 auto;
}

.faq-item{
  border-bottom: 1px solid rgba(255,255,255,.2);
}

.faq-item:first-child{
  border-top: 1px solid rgba(255,255,255,.2);
}

.faq-question{
  padding: 1.25rem 2.5rem 1.25rem 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
  cursor: pointer;
  list-style: none;
  position: relative;
  transition: color 0.2s ease;
}

.faq-question::-webkit-details-marker,
.faq-question::marker{
  display: none;
}

.faq-question::after{
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  width: 10px;
  height: 10px;
  border-right: 2px solid rgba(255,255,255,.9);
  border-bottom: 2px solid rgba(255,255,255,.9);
  transform: translateY(-50%) rotate(45deg);
  transition: transform 0.25s ease;
}

.faq-item[open] .faq-question::after{
  transform: translateY(-50%) rotate(-135deg);
}

.faq-question:hover{
  color: #1a1a1a;
}

.faq-answer{
  padding: 0 0 1.25rem 0;
}

.faq-answer p{
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
  color: rgba(255,255,255,.9);
}

@media (max-width: 767.98px){
  .faq-question{
    padding: 1.25rem 2.75rem 1.25rem 1rem;
  }

  .faq-answer{
    padding: 0 1rem 1.25rem 1rem;
  }
}

.calculator-section{
  position: relative;
  padding: clamp(4rem, 8vw, 6rem) 0;
  background:
    radial-gradient(800px 440px at 22% 40%, rgba(0,145,138,.06), transparent 60%),
    radial-gradient(700px 420px at 76% 30%, rgba(244,121,45,.05), transparent 60%),
    #f8f7f4;
  border-top: 1px solid rgba(0,0,0,.06);
}

.calculator-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    135deg,
    rgba(0,0,0,.02) 0px,
    rgba(0,0,0,.02) 1px,
    transparent 1px,
    transparent 14px
  );
  opacity: .6;
  pointer-events: none;
}

.calculator-section .container{
  position: relative;
  z-index: 1;
}

.calculator-intro{
  max-width: 680px;
}

.calculator-title{
  font-weight: 800;
  font-size: clamp(1.6rem, 2.5vw, 2.2rem);
  color: #1a1a1a;
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.calculator-subtitle{
  font-size: 1.05rem;
  color: rgba(0,0,0,.7);
}

.calculator-terminal{
  max-width: 640px;
  margin: 0 auto;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.15), 0 0 0 1px rgba(0,0,0,.06);
}

.terminal-header{
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 1.25rem;
  background: #0b1526;
  border-bottom: 1px solid rgba(0,145,138,.25);
}

.terminal-dots{
  display: flex;
  gap: 0.4rem;
}

.terminal-dot{
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
}

.terminal-dot:nth-child(1){ background: rgba(255,95,86,.9); }
.terminal-dot:nth-child(2){ background: rgba(255,189,46,.9); }
.terminal-dot:nth-child(3){ background: rgba(39,201,63,.9); }

.terminal-title{
  font-size: 0.8rem;
  font-weight: 600;
  color: rgba(255,255,255,.5);
  letter-spacing: 0.02em;
}

.terminal-body{
  padding: 1.5rem 1.5rem 1.75rem;
  background: #0a0f1a;
  font-family: "SF Mono", "Monaco", "Inconsolata", "Fira Mono", "Consolas", monospace;
  font-size: 0.9rem;
  line-height: 1.7;
}

.terminal-inputs{
  margin-bottom: 1.25rem;
}

.terminal-row{
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem;
  margin-bottom: 0.5rem;
}

.terminal-row:last-of-type{
  margin-bottom: 0;
}

.terminal-prompt{
  color: var(--tc-teal);
  font-weight: 600;
}

.terminal-label{
  color: rgba(255,255,255,.75);
}

.terminal-equals{
  color: rgba(255,255,255,.4);
}

.terminal-value{
  color: var(--tc-orange-left);
}

.terminal-command .terminal-cmd{
  color: var(--tc-teal);
}

.terminal-output{
  padding-top: 1rem;
  border-top: 1px solid rgba(0,145,138,.2);
}

.terminal-output-line{
  margin-bottom: 0.4rem;
}

.terminal-output-line:last-child{
  margin-bottom: 0;
}

.output-label{
  color: rgba(255,255,255,.6);
}

.output-arrow{
  color: var(--tc-teal);
  margin: 0 0.35rem;
}

.output-value{
  color: var(--tc-orange-left);
  font-weight: 600;
}

.output-note{
  margin-top: 0.75rem;
  font-size: 0.8rem;
  color: rgba(255,255,255,.35);
}

.cta-section{
  position: relative;
  padding: clamp(4.5rem, 10vw, 7rem) 0;
  color: #fff;
  background:
    radial-gradient(900px 500px at 25% 50%, rgba(0,145,138,.28), transparent 60%),
    radial-gradient(800px 450px at 75% 50%, rgba(244,121,45,.18), transparent 60%),
    linear-gradient(135deg, var(--hero-bg-1), var(--hero-bg-2));
  border-top: 1px solid rgba(255,255,255,.08);
}

.cta-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    135deg,
    rgba(255,255,255,.05) 0px,
    rgba(255,255,255,.05) 1px,
    transparent 1px,
    transparent 14px
  );
  opacity: .25;
  pointer-events: none;
}

.cta-section .container{
  position: relative;
  z-index: 1;
}

.cta-content{
  max-width: 580px;
}

.cta-title{
  font-weight: 800;
  font-size: clamp(1.6rem, 2.6vw, 2.25rem);
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.cta-subtitle{
  font-size: 1.1rem;
  color: rgba(255,255,255,.88);
  line-height: 1.5;
}

/* How utility incentives work — prescriptive vs custom path toggle */
.incentive-path-module{
  background: #f8f7f4;
  border-top: 1px solid rgba(0,0,0,.06);
}

.incentive-path-module-title{
  font-weight: 800;
  font-size: clamp(1.35rem, 2.2vw, 1.75rem);
  color: #1a1a1a;
  letter-spacing: -0.02em;
  margin-bottom: 1.25rem;
}

.path-toggle-track{
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-width: 640px;
}

@media (min-width: 576px){
  .path-toggle-track{
    flex-direction: row;
    gap: 0;
    border-radius: 14px;
    padding: 4px;
    background: rgba(0,0,0,.06);
    border: 1px solid rgba(0,0,0,.08);
  }
}

.path-toggle-btn{
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  padding: 1rem 1.15rem;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 12px;
  background: #fff;
  color: #1a1a1a;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

@media (min-width: 576px){
  .path-toggle-btn{
    border: none;
    border-radius: 10px;
    background: transparent;
  }

  .path-toggle-btn.is-active{
    background: #fff;
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
  }
}

.path-toggle-btn:hover{
  border-color: rgba(244,121,45,.45);
}

.path-toggle-btn:focus-visible{
  outline: 2px solid var(--tc-teal);
  outline-offset: 2px;
}

.path-toggle-btn.is-active{
  border-color: var(--tc-teal);
  box-shadow: 0 0 0 1px rgba(0,145,138,.25);
}

.path-toggle-label{
  font-weight: 700;
  font-size: 1.05rem;
  line-height: 1.25;
}

.path-toggle-hint{
  font-size: 0.85rem;
  color: rgba(0,0,0,.55);
  margin-top: 0.25rem;
}

.path-toggle-btn.is-active .path-toggle-hint{
  color: rgba(0,0,0,.65);
}

.path-panel{
  min-height: 8rem;
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px dashed rgba(0,0,0,.12);
  background: rgba(255,255,255,.7);
}

.path-panel[hidden]{
  display: none !important;
}

.path-panel--prescriptive{
  border-style: solid;
  border-color: rgba(0,0,0,.08);
  background: #fff;
  padding: clamp(1rem, 2vw, 1.75rem);
}

/* Small inline text CTA at bottom of each path tab panel (how-utility-incentives-work) */
.path-section-cta{
  padding-top: 1.25rem;
  border-top: 1px solid rgba(0,0,0,.08);
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgba(0,0,0,.58);
}

.path-section-cta a{
  font-weight: 600;
  color: var(--tc-teal);
  text-decoration: none;
}

.path-section-cta a:hover{
  color: var(--tc-orange-left);
  text-decoration: underline;
}

.prescriptive-tablist{
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 1.5rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(0,0,0,.1);
}

.prescriptive-tab{
  border: 1px solid transparent;
  background: rgba(0,0,0,.04);
  color: #1a1a1a;
  font-weight: 600;
  font-size: 0.92rem;
  padding: 0.55rem 0.9rem;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.prescriptive-tab:hover{
  background: rgba(0,145,138,.1);
}

.prescriptive-tab.is-active{
  background: #fff;
  border-color: var(--tc-teal);
  color: #0a5c57;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.prescriptive-tab:focus-visible{
  outline: 2px solid var(--tc-teal);
  outline-offset: 2px;
}

.prescriptive-tabpanel{
  animation: prescriptiveFade 0.25s ease;
}

@keyframes prescriptiveFade{
  from { opacity: 0.6; }
  to { opacity: 1; }
}

.prescriptive-section-title{
  font-weight: 800;
  font-size: clamp(1.15rem, 1.8vw, 1.35rem);
  color: #1a1a1a;
  margin-bottom: 1rem;
  letter-spacing: -0.02em;
}

.prescriptive-lead{
  font-size: 1rem;
  line-height: 1.65;
  color: rgba(0,0,0,.78);
  margin-bottom: 1.25rem;
}

.prescriptive-block--spaced{
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(0,0,0,.1);
}

.prescriptive-subheading{
  font-weight: 800;
  font-size: 1rem;
  color: #1a1a1a;
  margin-bottom: 0.75rem;
  letter-spacing: -0.02em;
}

.prescriptive-steps{
  margin: 0;
  padding-left: 1.35rem;
  display: grid;
  gap: 1.35rem;
  color: rgba(0,0,0,.78);
  line-height: 1.65;
}

.prescriptive-steps li{
  padding-left: 0.35rem;
}

.prescriptive-steps li::marker{
  font-weight: 800;
  color: var(--tc-teal);
}

.prescriptive-step-title{
  display: block;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 0.4rem;
}

.prescriptive-steps p{
  margin: 0;
  font-size: 1rem;
}

.prescriptive-table{
  margin-bottom: 0;
  font-size: 0.95rem;
  border: 1px solid rgba(0,0,0,.1);
  border-radius: 8px;
  overflow: hidden;
}

.prescriptive-table thead{
  background: #e8e6e2;
}

.prescriptive-table thead th{
  font-weight: 700;
  color: #1a1a1a;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid rgba(0,0,0,.12);
}

.prescriptive-table tbody td{
  padding: 0.7rem 1rem;
  border-color: rgba(0,0,0,.08);
  vertical-align: top;
}

.prescriptive-list{
  margin: 0 0 1.25rem;
  padding-left: 1.25rem;
  line-height: 1.6;
  color: rgba(0,0,0,.78);
}

.prescriptive-list li{
  margin-bottom: 0.5rem;
}

.prescriptive-negative-heading{
  margin-top: 1.5rem;
  margin-bottom: 0.85rem;
  font-size: 1rem;
  color: #1a1a1a;
}

.prescriptive-aside-note{
  font-size: 0.95rem;
  font-style: italic;
  color: rgba(0,0,0,.65);
  line-height: 1.55;
}

a.path-jump-link{
  color: var(--tc-teal);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

a.path-jump-link:hover{
  color: var(--tc-orange-left);
}

.prescriptive-callout{
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  margin-top: 1.75rem;
  padding: 1.1rem 1.15rem;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.1);
  background: #f0eeeb;
}

.prescriptive-callout-icon{
  font-size: 1.5rem;
  color: rgba(0,0,0,.45);
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.prescriptive-callout a{
  color: var(--tc-teal);
  font-weight: 600;
}

.prescriptive-callout a:hover{
  color: var(--tc-orange-left);
}

/* ── Assessment page ── */

.assessment-page{
  background:
    radial-gradient(900px 500px at 25% 20%, rgba(0,145,138,.28), transparent 60%),
    radial-gradient(800px 450px at 75% 80%, rgba(244,121,45,.18), transparent 60%),
    linear-gradient(135deg, var(--hero-bg-1), var(--hero-bg-2));
  min-height: 100vh;
}

.assessment-hero{
  position: relative;
  padding: clamp(3.5rem, 7vw, 5.5rem) 0 clamp(2.5rem, 5vw, 3.5rem);
  color: #fff;
  text-align: center;
}

.assessment-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    135deg,
    rgba(255,255,255,.05) 0px,
    rgba(255,255,255,.05) 1px,
    transparent 1px,
    transparent 14px
  );
  opacity: .25;
  pointer-events: none;
}

.assessment-hero .container{
  position: relative;
  z-index: 1;
}

.assessment-kicker{
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--tc-orange-left);
  margin-bottom: 0.75rem;
}

.assessment-hero-title{
  font-weight: 800;
  line-height: 1.1;
  font-size: clamp(1.6rem, 2.8vw, 2.35rem);
  letter-spacing: -0.02em;
}

.assessment-hero-subtitle{
  font-size: 1.1rem;
  color: rgba(255,255,255,.82);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.55;
}

.assessment-form-section{
  position: relative;
  padding: clamp(2rem, 4vw, 3.5rem) 0 clamp(4rem, 8vw, 6rem);
}

.assessment-form-section .container{
  position: relative;
  z-index: 1;
}

.assessment-form{
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.assessment-form-group{
  padding: clamp(1.25rem, 2.5vw, 2rem);
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(8px);
}

.assessment-form-group-title{
  font-weight: 700;
  font-size: 1.1rem;
  color: #fff;
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.assessment-form-group-title i{
  color: var(--tc-orange-left);
  font-size: 1.15rem;
}

.assessment-label{
  display: block;
  font-size: 0.88rem;
  font-weight: 600;
  color: rgba(255,255,255,.85);
  margin-bottom: 0.4rem;
}

.assessment-optional{
  font-weight: 400;
  color: rgba(255,255,255,.45);
}

.assessment-input{
  display: block;
  width: 100%;
  padding: 0.7rem 0.9rem;
  font-size: 0.95rem;
  line-height: 1.5;
  color: #fff;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
  appearance: none;
}

.assessment-input::placeholder{
  color: rgba(255,255,255,.35);
}

.assessment-input:focus{
  outline: none;
  border-color: var(--tc-teal);
  background: rgba(255,255,255,.10);
  box-shadow: 0 0 0 3px rgba(0,145,138,.25);
}

select.assessment-input{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(255,255,255,0.6)' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.9rem center;
  padding-right: 2.5rem;
}

select.assessment-input option{
  background: #0b1526;
  color: #fff;
}

textarea.assessment-input{
  resize: vertical;
  min-height: 100px;
}

.assessment-form-submit{
  text-align: center;
}

.btn-assessment-submit{
  background: var(--tc-orange-left);
  border: none;
  color: #fff;
  font-weight: 700;
  font-size: 1.05rem;
  padding: 0.9rem 2rem;
  border-radius: 10px;
  transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.btn-assessment-submit:hover{
  background: #de6d27;
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(244,121,45,.35);
}

.btn-assessment-submit:active{
  transform: translateY(0);
}

.assessment-disclaimer{
  margin-top: 0.85rem;
  font-size: 0.82rem;
  color: rgba(255,255,255,.45);
  line-height: 1.5;
}

.assessment-disclaimer a{
  color: var(--tc-teal);
  font-weight: 600;
  text-decoration: none;
}

.assessment-disclaimer a:hover{
  color: var(--tc-orange-left);
  text-decoration: underline;
}

/* Light sections (paper / off-white) — form was authored for dark assessment page */
.cap-section--paper .assessment-form-group,
.cap-section--light .assessment-form-group{
  background: #f8f7f4;
  border: 1px solid rgba(0, 0, 0, 0.08);
  backdrop-filter: none;
}

.cap-section--paper .assessment-form-group-title,
.cap-section--light .assessment-form-group-title{
  color: #131820;
}

.cap-section--paper .assessment-label,
.cap-section--light .assessment-label{
  color: #2a3340;
}

.cap-section--paper .assessment-optional,
.cap-section--light .assessment-optional{
  color: rgba(19, 24, 32, 0.5);
}

.cap-section--paper .assessment-input,
.cap-section--light .assessment-input{
  color: #131820;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.15);
}

.cap-section--paper .assessment-input::placeholder,
.cap-section--light .assessment-input::placeholder{
  color: rgba(19, 24, 32, 0.4);
}

.cap-section--paper .assessment-input:focus,
.cap-section--light .assessment-input:focus{
  background: #fff;
  border-color: var(--tc-teal);
  box-shadow: 0 0 0 3px rgba(0, 145, 138, 0.15);
}

.cap-section--paper select.assessment-input,
.cap-section--light select.assessment-input{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(19,24,32,0.55)' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

.cap-section--paper select.assessment-input option,
.cap-section--light select.assessment-input option{
  background: #fff;
  color: #131820;
}

.cap-section--paper .assessment-disclaimer,
.cap-section--light .assessment-disclaimer{
  color: rgba(19, 24, 32, 0.65);
}

.assessment-sidebar{
  position: sticky;
  top: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.assessment-sidebar-card{
  padding: 1.5rem;
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(8px);
}

.assessment-sidebar-title{
  font-weight: 800;
  font-size: 1.1rem;
  color: #fff;
  margin-bottom: 1.25rem;
  letter-spacing: -0.02em;
}

.assessment-next-steps{
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.assessment-next-steps li{
  display: flex;
  gap: 0.85rem;
  align-items: flex-start;
}

.assessment-step-num{
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 0.8rem;
  font-weight: 700;
  color: #fff;
  border: 1px solid rgba(244,121,45,.75);
  background: rgba(244,121,45,.18);
  margin-top: 0.1rem;
}

.assessment-next-steps strong{
  display: block;
  font-size: 0.95rem;
  color: #fff;
  margin-bottom: 0.25rem;
}

.assessment-next-steps p{
  font-size: 0.88rem;
  color: rgba(255,255,255,.68);
  line-height: 1.5;
  margin: 0;
}

.assessment-sidebar-card--trust{
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.assessment-trust-item{
  display: flex;
  align-items: center;
  gap: 0.65rem;
  font-size: 0.9rem;
  color: rgba(255,255,255,.85);
}

.assessment-trust-item i{
  font-size: 1.05rem;
  color: var(--tc-teal);
  flex-shrink: 0;
}

@media (max-width: 991.98px){
  .assessment-sidebar{
    position: static;
  }
}

/* ── Mobile improvements (< 992px) ── */

@media (max-width: 991.98px){

  .navbar-secondary__list{
    justify-content: flex-end;
    padding: 0.5rem 0;
  }

  /* 1. Hero title: bigger */
  .hero-title{
    font-size: clamp(2.75rem, 8vw, 3.3rem);
  }

  /* 2. Section 2 spacing on small screens */
  .section-2-content{
    padding-top: clamp(2.25rem, 5vw, 3rem);
    padding-bottom: clamp(1.75rem, 4vw, 2.5rem);
    min-height: 0;
  }

  .section-2{
    padding-bottom: clamp(2rem, 5vw, 3.25rem);
  }

  /* 3. Mobile nav drawer */
  .navbar-collapse{
    border-top: 1px solid rgba(255,255,255,.1);
    margin-top: 0.75rem;
    padding-top: 0.5rem;
    padding-bottom: 0.75rem;
  }

  .navbar-nav .nav-item{
    border-bottom: 1px solid rgba(255,255,255,.07);
  }

  .navbar-nav .nav-item:last-child{
    border-bottom: none;
  }

  .navbar-nav .nav-link{
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    font-size: 1rem;
  }

  .navbar-nav .btn-tc-primary{
    display: block;
    width: 100%;
    text-align: center;
    margin-top: 1.1rem;
    padding: 0.85rem 1rem;
  }

  /* 6. Sticky tab headers on how-utility-incentives-work page */
  .prescriptive-tablist{
    position: sticky;
    top: 0;
    z-index: 20;
    background: #fff;
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
    margin-left: calc(-1 * clamp(1rem, 2vw, 1.75rem));
    margin-right: calc(-1 * clamp(1rem, 2vw, 1.75rem));
    padding-left: clamp(1rem, 2vw, 1.75rem);
    padding-right: clamp(1rem, 2vw, 1.75rem);
    border-bottom: 1px solid rgba(0,0,0,.09);
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    margin-bottom: 1.25rem;
  }
}

/* 7. Assessment page: mobile "What Happens Next" toggle */

.assessment-next-toggle{
  border-radius: 12px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.14);
  overflow: hidden;
}

.assessment-next-toggle-btn{
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.9rem 1.1rem;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.assessment-next-toggle-btn::-webkit-details-marker,
.assessment-next-toggle-btn::marker{
  display: none;
}

.assessment-next-toggle-btn i:first-child{
  font-size: 1.1rem;
  color: var(--tc-teal);
}

.assessment-next-chevron{
  margin-left: auto;
  font-size: 0.85rem;
  transition: transform 0.25s ease;
}

.assessment-next-toggle[open] .assessment-next-chevron{
  transform: rotate(-180deg);
}

.assessment-next-toggle-body{
  padding: 0.25rem 1.1rem 1.1rem;
}

/* Mobile toggle: step numbers above each headline (not beside) */
.assessment-next-toggle-body .assessment-next-steps li{
  flex-direction: column;
  align-items: center;
  gap: 0.55rem;
}

.assessment-next-toggle-body .assessment-step-num{
  margin-top: 0;
}

.assessment-next-toggle-body .assessment-next-steps li > div{
  width: 100%;
  text-align: left;
}

@media (max-width: 575.98px){
  .brand-mark svg{ height: 28px; }
  .btn-lg{ padding: .8rem 1rem; }

  /* Narrow phones: more space between hero headline and CTAs */
  .hero-copy .hero-title{
    margin-bottom: 1.85rem !important;
  }

  .hero-copy > .d-flex.gap-3{
    margin-top: 0.35rem;
  }
}

/* ==========================================================================
   Shared components (BMS site v1)
   --------------------------------------------------------------------------
   Used by: our-approach/, the-tc-system/, jci-247-service/

   Canonical site-wide form pattern:
     - Markup lives in free-assessment/index.html and is copy-pasted into
       any page that takes a lead.
     - Class names: .assessment-form, .assessment-form-group,
       .assessment-form-group-title, .assessment-label, .assessment-input,
       .assessment-form-submit, .btn-assessment-submit.
     - Facility Type dropdown options are page-specific (BMS pages drop
       "Cultivation").
     - Do NOT redesign forms per page. Add new fields to the canonical
       pattern, not as one-off forms.
   ========================================================================== */

/* ── Capability hero (two-column copy/visual hero used on the three v1
       capability pages: Our Approach, The TC System, JCI 24/7 Service) ── */

.cap-hero{
  position: relative;
  z-index: 2;
  padding: clamp(2.5rem, 6vw, 5rem) 0 clamp(2.5rem, 6vw, 4.5rem);
}

.cap-hero-row{
  align-items: center;
}

.cap-hero-copy{
  position: relative;
  z-index: 3;
  color: #fff;
}

.cap-hero-kicker{
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
  margin: 0 0 0.75rem;
}

.cap-hero-title{
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.015em;
  font-size: clamp(2.1rem, 4.2vw, 3.5rem);
  color: #fff;
  margin: 0 0 1.1rem;
}

/* Our Approach — keep “Build Process” on its own line at all widths */
.cap-hero-title--design-build .cap-hero-title__line{
  display: block;
}

.cap-hero-subtitle{
  font-size: clamp(1.05rem, 1.6vw, 1.22rem);
  line-height: 1.55;
  color: rgba(255,255,255,.85);
  max-width: 36rem;
  margin: 0 0 1.75rem;
}

.cap-hero-visual{
  position: relative;
  min-height: clamp(280px, 38vw, 460px);
}

/* Who We Serve — static home hero artboard (right column, no animation) */
.cap-hero--who-serve .cap-hero-visual{
  min-height: clamp(320px, 42vw, 520px);
}

.cap-hero--who-serve .hero-visual--cap{
  min-height: clamp(300px, 40vw, 480px);
}

.cap-hero--who-serve .hero-artboard{
  right: 0;
  width: min(108%, 900px);
}

.hero-artboard--static.is-formed .circuit-traces,
.hero-artboard--static.is-formed .circuit-glow{
  opacity: .32;
}

.hero-artboard--static.is-formed .circuit-glow{
  filter: blur(22px) drop-shadow(0 0 18px rgba(244,121,45,0.55)) drop-shadow(0 0 36px rgba(248,149,29,0.35));
}

.hero-artboard--static .trace-outline--rail{
  animation: none;
}

/* TC System — static artboard with alive node pulse (jitter + color shift) */
.cap-hero--tc-system .cap-hero-visual{
  min-height: clamp(320px, 42vw, 520px);
}

.cap-hero--tc-system .hero-visual--cap{
  min-height: clamp(300px, 40vw, 480px);
}

.cap-hero--tc-system .hero-artboard{
  right: 0;
  width: min(108%, 900px);
}

/* TC System — diagram section meets bottom of hero artboard (desktop) */
@media (min-width: 992px){
  .site-hero--compact .cap-hero--tc-system{
    padding-bottom: 0;
  }

  .cap-section--diagram{
    padding-top: 0;
  }

  .cap-section--diagram .cap-section__head{
    margin-top: clamp(1.5rem, 3vw, 2.25rem);
  }
}

.hero-artboard--alive .particle-node{
  transition: none;
  animation: heroNodeAliveBreath 4.6s ease-in-out infinite;
}

.hero-artboard--alive .particle-node:nth-child(4n+1){
  animation-delay: 0s;
}

.hero-artboard--alive .particle-node:nth-child(4n+2){
  animation-delay: -1.15s;
}

.hero-artboard--alive .particle-node:nth-child(4n+3){
  animation-delay: -2.3s;
}

.hero-artboard--alive .particle-node:nth-child(4n){
  animation-delay: -3.45s;
}

@keyframes heroNodeAliveBreath{
  0%, 100%{
    transform: translate(-50%, -50%) scale(1);
    opacity: .88;
    box-shadow:
      0 0 9px var(--node-color, currentColor),
      0 0 18px color-mix(in srgb, var(--node-color, currentColor) 42%, transparent);
    filter: brightness(1) saturate(1);
    background-color: var(--node-color, currentColor);
  }
  50%{
    transform: translate(-50%, -50%) scale(1.035);
    opacity: .94;
    box-shadow:
      0 0 11px var(--node-color, currentColor),
      0 0 24px color-mix(in srgb, var(--node-color, currentColor) 58%, transparent);
    filter: brightness(1.06) saturate(1.04);
    background-color: color-mix(in srgb, var(--node-color, currentColor) 88%, #f8a85c 12%);
  }
}

@media (prefers-reduced-motion: reduce){
  .hero-artboard--alive .particle-node{
    animation: none;
  }
}

.hero-align-marker{
  pointer-events: none;
}

.cap-hero-visual--clip{
  overflow: hidden;
  border-radius: 14px;
}

/* About Us — light office-window hero */
.site-hero.site-hero--about-light{
  color: #1a2332;
  background: #e8eef5;
}

/* Disable the default dark hero texture + left-to-right shade on About Us */
.site-hero.site-hero--about-light::before,
.site-hero.site-hero--about-light::after{
  display: none;
}

.site-hero--about-light .navbar-secondary{
  background: rgba(255, 255, 255, 0.55);
  border-bottom: 1px solid rgba(26, 35, 50, 0.08);
  backdrop-filter: blur(6px);
}

.site-hero--about-light .navbar-secondary__link{
  color: rgba(26, 35, 50, 0.72);
}

.site-hero--about-light .navbar-secondary__link:hover,
.site-hero--about-light .navbar-secondary__link:focus{
  color: #1a2332;
}

.site-hero--about-light .navbar-secondary__link.active{
  color: #1a2332;
}

.site-hero--about-light .navbar-secondary__link--external .bi{
  opacity: 0.7;
}

.site-hero--about-light .navbar-tc-main.navbar-overlay{
  background: rgba(255, 255, 255, 0.78);
  border-bottom: 1px solid rgba(26, 35, 50, 0.1);
  backdrop-filter: blur(8px);
}

.site-hero--about-light .navbar-tc-main .navbar-nav-tc .nav-link{
  color: rgba(26, 35, 50, 0.86);
}

.site-hero--about-light .navbar-tc-main .navbar-nav-tc .nav-link:hover,
.site-hero--about-light .navbar-tc-main .navbar-nav-tc .nav-link:focus{
  color: #1a2332;
}

.site-hero--about-light .navbar-tc-main .navbar-nav-tc .nav-link.active{
  color: #1a2332;
}

.site-hero--about-light .navbar-tc-main .tc-nav-chevron{
  color: var(--tc-orange-left);
}

.site-hero--about-light .navbar-tc-main .dropdown-menu{
  background: #fff;
  border-color: rgba(26, 35, 50, 0.12);
}

.site-hero--about-light .navbar-tc-main .dropdown-item{
  color: #1a2332;
}

.site-hero--about-light .navbar-tc-main .dropdown-item:hover,
.site-hero--about-light .navbar-tc-main .dropdown-item:focus{
  color: #1a2332;
  background: rgba(0, 145, 138, 0.1);
}

.site-hero--about-light .navbar-tc-main .dropdown-item.active{
  color: #1a2332;
  background: transparent;
}

.site-hero--about-light .brand-mark svg path[fill="#fff"]{
  fill: #1a2332;
}

.site-hero--about-light .navbar-toggler{
  border-color: rgba(26, 35, 50, 0.22);
}

.site-hero--about-light .navbar-toggler-icon{
  filter: invert(1) brightness(0.15);
}

.site-hero--about-light .cap-hero-copy{
  color: #1a2332;
}

.site-hero--about-light .cap-hero-title{
  color: #1a2332;
}

.site-hero--about-light .cap-hero-subtitle{
  color: rgba(26, 35, 50, 0.78);
}

.cap-hero--about{
  position: relative;
  overflow: hidden;
}

.site-hero--compact .cap-hero.cap-hero--about{
  padding-bottom: 0;
}

.cap-hero--about .container{
  position: relative;
  z-index: 2;
}

/* Always two columns — copy left, team photo right (never stack) */
.cap-hero--about .cap-hero-row{
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
}

.cap-hero--about .cap-hero-row > .col-lg-6{
  flex: 0 0 50%;
  max-width: 50%;
  width: 50%;
  min-width: 0;
}

.cap-hero--about .cap-hero-copy{
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-bottom: clamp(1.25rem, 3vw, 2.5rem);
}

.cap-hero--about .cap-hero-row > .col-lg-6:last-child{
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
}

.cap-hero-visual--about-team{
  position: relative;
  flex: 1 1 auto;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  width: 100%;
  max-width: 100%;
  min-height: clamp(220px, 32vw, 460px);
  margin-bottom: 0;
  overflow: hidden;
}

.cap-hero-visual--about-team::before{
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 72%;
  background: radial-gradient(ellipse at center bottom, rgba(255, 252, 245, 0.95) 0%, rgba(255, 252, 245, 0) 68%);
  z-index: 0;
}

.cap-hero-team-photo{
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  object-fit: contain;
  object-position: bottom center;
}

.about-hero-backdrop{
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 95% 85% at 92% 8%, rgba(255, 232, 190, 0.72) 0%, transparent 58%),
    radial-gradient(ellipse 70% 60% at 78% 55%, rgba(255, 255, 255, 0.92) 0%, transparent 62%),
    linear-gradient(112deg, #d5dee9 0%, #edf1f6 34%, #faf6ef 68%, #dde8f4 100%);
}

.about-hero-backdrop::before{
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    90deg,
    rgba(255,255,255,0) 0,
    rgba(255,255,255,0) calc(clamp(58px, 6.5vw, 82px) - 3px),
    rgba(255,255,255,0.72) calc(clamp(58px, 6.5vw, 82px) - 3px),
    rgba(255,255,255,0.72) clamp(58px, 6.5vw, 82px)
  );
  opacity: 0.55;
}

.about-hero-backdrop::after{
  content: "";
  position: absolute;
  top: -8%;
  right: -4%;
  width: min(58%, 520px);
  height: 115%;
  background: linear-gradient(
    168deg,
    rgba(255, 248, 225, 0.95) 0%,
    rgba(255, 255, 255, 0.55) 38%,
    rgba(255, 255, 255, 0) 72%
  );
  transform: skewX(-10deg);
  filter: blur(10px);
}

@media (max-width: 991.98px){
  .about-hero-backdrop::after{
    width: 75%;
    right: -12%;
  }

  .cap-hero--about .cap-hero-title{
    font-size: clamp(1.65rem, 4.5vw, 2.35rem);
  }

  .cap-hero--about .cap-hero-subtitle{
    font-size: clamp(0.92rem, 2.2vw, 1.05rem);
  }
}

/* Work With Us — full-bleed hero video (16:9 section height) */
.site-hero.site-hero--work-with-us-header{
  min-height: 0;
  background: #070b12;
}

.site-hero--compact .cap-hero.cap-hero--work-with-us{
  padding: 0;
}

.cap-hero--work-with-us{
  position: relative;
  width: 100%;
  /* 1400×696 target frame — flush under nav at full width */
  aspect-ratio: 1400 / 696;
  overflow: hidden;
  isolation: isolate;
}

.cap-hero--work-with-us .cap-hero-video-layer{
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

/* Full-bleed cover: top under menu, bottom at container (no clip-path gap) */
.cap-hero--work-with-us .cap-hero-video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  pointer-events: none;
  background: #0a0e12;
}

.cap-hero--work-with-us .cap-hero-video-scrim{
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    rgba(7, 11, 18, 0.82) 0%,
    rgba(7, 11, 18, 0.48) 42%,
    rgba(7, 11, 18, 0.22) 68%,
    rgba(7, 11, 18, 0.35) 100%
  );
  pointer-events: none;
}

.cap-hero--work-with-us .container{
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  align-items: center;
  padding: clamp(1.25rem, 3.5vw, 2.5rem) clamp(1rem, 3vw, 2rem);
}

.cap-hero--work-with-us .cap-hero-copy{
  max-width: min(36rem, 92%);
}

.cap-hero--work-with-us .cap-hero-subtitle{
  margin-bottom: 1.35rem;
}

.cap-hero--work-with-us .cap-hero-cta-row .btn{
  font-weight: 600;
  padding: 0.65rem 1.4rem;
  border-radius: 6px;
}

@media (max-width: 767.98px){
  .cap-hero--work-with-us .cap-hero-copy{
    max-width: 100%;
  }

  .cap-hero--work-with-us .cap-hero-title{
    font-size: clamp(1.85rem, 7vw, 2.5rem);
  }

  .cap-hero--work-with-us .cap-hero-cta-row .btn{
    width: 100%;
    text-align: center;
  }
}

/* Our Approach — process body (headline + numbered steps) */
.cap-section:has(#process-body-heading) > .container{
  max-width: 44rem;
}

/* ── Numbered process sections (Our Approach body) ── */

.numbered-section-list{
  counter-reset: numbered-step;
  display: flex;
  flex-direction: column;
  gap: clamp(1.75rem, 3vw, 2.75rem);
  list-style: none;
  padding: 0;
  margin: 0;
}

.numbered-section{
  counter-increment: numbered-step;
  display: grid;
  grid-template-columns: minmax(3.25rem, auto) 1fr;
  gap: clamp(1rem, 2vw, 1.65rem);
  align-items: start;
}

.numbered-section::before{
  content: counter(numbered-step, decimal-leading-zero);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, "Cascadia Mono", "Roboto Mono", Consolas, monospace;
  font-size: clamp(1.4rem, 2.4vw, 1.85rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--accent-orange);
  line-height: 1.05;
  padding-top: 0.18rem;
}

.numbered-section-title{
  font-size: clamp(1.15rem, 1.9vw, 1.45rem);
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #131820;
  margin: 0 0 0.45rem;
  line-height: 1.2;
}

.numbered-section-body{
  font-size: clamp(0.98rem, 1.1vw, 1.06rem);
  line-height: 1.6;
  color: rgba(20, 26, 36, 0.78);
  margin: 0;
  max-width: 38rem;
}

/* On dark backgrounds, lift the body and titles */
.cap-section--dark .numbered-section-title{ color: #fff; }
.cap-section--dark .numbered-section-body{ color: rgba(255,255,255,.8); }

/* ── Contact Panel (right column on JCI 24/7 Service hero; reusable
       elsewhere as a sticky / footer block) ── */

.contact-panel{
  display: flex;
  flex-direction: column;
  background: rgba(8, 14, 22, 0.72);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  backdrop-filter: blur(12px);
  overflow: hidden;
  color: #fff;
  box-shadow: 0 24px 60px -32px rgba(0,0,0,.55);
}

.contact-panel__tier{
  padding: clamp(1.05rem, 1.8vw, 1.4rem) clamp(1.15rem, 2vw, 1.55rem);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.contact-panel__tier:last-child{ border-bottom: 0; }

.contact-panel__label{
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  margin: 0 0 0.5rem;
}

/* Tier 1 — Emergency */
.contact-panel__tier--emergency{
  background:
    linear-gradient(135deg, rgba(244,121,45,.18), rgba(248,149,29,.08) 60%, transparent),
    rgba(8, 14, 22, 0.5);
}

.contact-panel__emergency-row{
  display: flex;
  align-items: center;
  gap: 0.85rem;
  text-decoration: none;
  color: #fff;
}

.contact-panel__emergency-row:hover,
.contact-panel__emergency-row:focus-visible{
  color: #fff;
  text-decoration: none;
}

.contact-panel__emergency-row:hover .contact-panel__emergency-number{
  color: var(--tc-orange-right);
}

.contact-panel__emergency-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: rgba(244,121,45,.18);
  color: var(--tc-orange-left);
  font-size: 1.1rem;
}

.contact-panel__emergency-text{
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  line-height: 1.25;
}

.contact-panel__emergency-prompt{
  font-size: 0.92rem;
  color: rgba(255,255,255,.75);
}

.contact-panel__emergency-number{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, "Cascadia Mono", "Roboto Mono", Consolas, monospace;
  font-size: clamp(1.45rem, 2vw, 1.75rem);
  font-weight: 700;
  letter-spacing: -0.005em;
  color: #fff;
  transition: color 0.18s ease;
}

/* Tier 2 — Standard service request (primary CTA) */
.contact-panel__tier--service{
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.contact-panel__cta-prompt{
  font-size: 0.95rem;
  color: rgba(255,255,255,.78);
  line-height: 1.45;
  margin: 0;
}

.contact-panel__cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  width: 100%;
  padding: 0.85rem 1.25rem;
  background: var(--accent-orange);
  border: 1px solid var(--accent-orange);
  color: #fff;
  font-weight: 700;
  font-size: 1.0625rem;
  letter-spacing: 0.005em;
  border-radius: 10px;
  text-decoration: none;
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.contact-panel__cta:hover,
.contact-panel__cta:focus-visible{
  background: #de6d27;
  border-color: #de6d27;
  color: #fff;
  text-decoration: none;
}

/* Tier 3 — Async (email) */
.contact-panel__async{
  font-size: 0.95rem;
  color: rgba(255,255,255,.72);
  line-height: 1.5;
  margin: 0;
}

.contact-panel__async a{
  color: var(--tc-teal);
  text-decoration: none;
  border-bottom: 1px solid rgba(0,145,138,.4);
  transition: color 0.18s ease, border-color 0.18s ease;
}

.contact-panel__async a:hover{
  color: var(--tc-orange-right);
  border-bottom-color: rgba(248,149,29,.5);
}

.contact-panel__async--below-cta{
  text-align: center;
  margin-top: 0.15rem;
  font-size: 0.9rem;
}

/* ── In-page FAQ block (short subset of /faq) ── */

.faq-block{
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  max-width: 56rem;
  margin: 0 auto;
}

.faq-block__title{
  font-size: clamp(1.25rem, 2vw, 1.55rem);
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #131820;
  margin: 0 0 0.4rem;
}

.faq-block__item{
  border: 1px solid rgba(20, 26, 36, 0.12);
  border-radius: 10px;
  background: #fff;
  overflow: hidden;
}

.faq-block__item[open]{
  border-color: rgba(244,121,45,.45);
  box-shadow: 0 6px 18px -10px rgba(20, 26, 36, 0.18);
}

.faq-block__question{
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 1rem 1.15rem;
  cursor: pointer;
  list-style: none;
  font-weight: 700;
  font-size: 1rem;
  color: #131820;
  user-select: none;
}

.faq-block__question::-webkit-details-marker{ display: none; }
.faq-block__question::marker{ display: none; }

.faq-block__chevron{
  margin-left: auto;
  font-size: 0.85rem;
  color: var(--accent-orange);
  transition: transform 0.2s ease;
}

.faq-block__item[open] .faq-block__chevron{
  transform: rotate(-180deg);
}

.faq-block__answer{
  padding: 0 1.15rem 1.05rem;
  font-size: 0.96rem;
  line-height: 1.6;
  color: rgba(20, 26, 36, 0.78);
}

.faq-block__answer p{ margin: 0; }
.faq-block__answer p + p{ margin-top: 0.65rem; }

.faq-block__more{
  display: inline-block;
  margin-top: 0.85rem;
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--tc-teal);
  text-decoration: none;
  transition: color 0.18s ease;
}

.faq-block__more:hover{
  color: var(--accent-orange);
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.cap-section--dark .faq-block__title{ color: #fff; }
.cap-section--dark .faq-block__item{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.12);
}
.cap-section--dark .faq-block__question{ color: #fff; }
.cap-section--dark .faq-block__answer{ color: rgba(255,255,255,.78); }

/* ── Cross-links block (plain typographic link list at bottom of page) ── */

.cross-links{
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: clamp(1.5rem, 3vw, 2.25rem) 0 0;
  border-top: 1px solid rgba(20, 26, 36, 0.1);
  max-width: 56rem;
  margin: 0 auto;
}

.cross-links__label{
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(20, 26, 36, 0.55);
  margin: 0 0 0.15rem;
}

.cross-links__item{
  display: inline-flex;
  align-items: baseline;
  gap: 0.35rem;
  font-size: 1.05rem;
  font-weight: 600;
  color: #131820;
  text-decoration: none;
  transition: color 0.18s ease;
}

.cross-links__item:hover{
  color: var(--accent-orange);
}

.cross-links__item-arrow{
  display: inline-block;
  transition: transform 0.18s ease;
}

.cross-links__item:hover .cross-links__item-arrow{
  transform: translateX(2px);
}

.cross-links__item-detail{
  display: block;
  font-size: 0.92rem;
  font-weight: 400;
  color: rgba(20, 26, 36, 0.6);
  margin-top: 0.12rem;
}

.cap-section--dark .cross-links{ border-top-color: rgba(255,255,255,.12); }
.cap-section--dark .cross-links__label{ color: rgba(255,255,255,.6); }
.cap-section--dark .cross-links__item{ color: #fff; }
.cap-section--dark .cross-links__item-detail{ color: rgba(255,255,255,.65); }

/* ── Routing module (TC System "pick your path" — two equal-weight cards) ── */

.routing-module{
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2.5vw, 1.75rem);
  max-width: 56rem;
  margin: 0 auto;
}

@media (min-width: 768px){
  .routing-module{
    grid-template-columns: 1fr 1fr;
  }
}

.routing-module__path{
  display: flex;
  flex-direction: column;
  padding: clamp(1.25rem, 2.5vw, 1.85rem) clamp(1.35rem, 2.5vw, 2rem);
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(20, 26, 36, 0.1);
  box-shadow: 0 14px 40px -28px rgba(20, 26, 36, 0.4);
  transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.routing-module__path:hover{
  border-color: rgba(244, 121, 45, 0.55);
  transform: translateY(-2px);
  box-shadow: 0 20px 50px -28px rgba(20, 26, 36, 0.5);
}

.routing-module__tag{
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-orange);
  margin: 0 0 0.55rem;
}

.routing-module__title{
  font-size: clamp(1.15rem, 1.85vw, 1.35rem);
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #131820;
  margin: 0 0 0.55rem;
  line-height: 1.2;
}

.routing-module__body{
  font-size: 0.98rem;
  line-height: 1.55;
  color: rgba(20, 26, 36, 0.78);
  margin: 0 0 1.15rem;
  flex-grow: 1;
}

.routing-module__cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  align-self: flex-start;
  padding: 0.65rem 1.15rem;
  background: var(--accent-orange);
  border: 1px solid var(--accent-orange);
  color: #fff;
  font-weight: 700;
  font-size: 0.98rem;
  border-radius: 8px;
  text-decoration: none;
  transition: background 0.18s ease, border-color 0.18s ease;
}

.routing-module__cta:hover,
.routing-module__cta:focus-visible{
  background: #de6d27;
  border-color: #de6d27;
  color: #fff;
  text-decoration: none;
}

.cap-section--dark .routing-module__path{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.12);
  box-shadow: none;
}
.cap-section--dark .routing-module__path:hover{
  border-color: rgba(244,121,45,.55);
  background: rgba(255,255,255,.06);
}
.cap-section--dark .routing-module__title{ color: #fff; }
.cap-section--dark .routing-module__body{ color: rgba(255,255,255,.78); }

.partner-logo--jci{
  display: block;
  height: clamp(3.25rem, 8vw, 5rem);
  width: auto;
  margin-top: 0.5rem;
}

/* ── Building diagram (TC System Body 1 — 5 capability labels around a
       central building, hover lights up label + connecting line) ── */

.building-diagram{
  position: relative;
  margin: 0 auto;
  max-width: 1080px;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.building-diagram__svg{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

.building-diagram__line{
  fill: none;
  stroke: rgba(244, 121, 45, 0.22);
  stroke-width: 2.25;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 0.4 6.5;
  transition: stroke 0.25s ease, stroke-width 0.25s ease;
}

.building-diagram__line.is-lit{
  stroke: var(--accent-orange);
  stroke-width: 2.75;
  filter: drop-shadow(0 0 8px rgba(244,121,45,.45));
}

.building-diagram__remote-link{
  fill: none;
  stroke: rgba(244, 121, 45, 0.18);
  stroke-width: 2.25;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 0.4 6.5;
  opacity: 0;
  transition: opacity 0.35s ease, stroke 0.25s ease, stroke-width 0.25s ease;
}

.building-diagram--remote-focus .building-diagram__remote-link{
  opacity: 1;
  stroke: var(--accent-orange);
  stroke-width: 2.75;
  filter: drop-shadow(0 0 10px rgba(244,121,45,.5));
}

.building-diagram--remote-focus .building-diagram__line[data-cap="remote"]{
  opacity: 0;
}

.building-diagram__remote-node{
  position: absolute;
  top: 16%;
  left: 56%;
  right: auto;
  z-index: 4;
  max-width: 24%;
  opacity: 0;
  transform: translateX(-50%) scale(0.88) translateY(8px);
  transition:
    opacity 0.4s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
}

.building-diagram--remote-focus .building-diagram__remote-node{
  opacity: 1;
  transform: translateX(-50%) scale(1) translateY(0);
}

.building-diagram__antenna{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  color: var(--accent-orange);
}

.building-diagram__antenna-icon{
  display: block;
  width: clamp(2rem, 3.5vw, 2.65rem);
  height: auto;
  filter: drop-shadow(0 0 12px rgba(244,121,45,.35));
}

.building-diagram__antenna-pulse{
  animation: building-diagram-antenna-pulse 2s ease-in-out infinite;
}

.building-diagram__antenna-ring{
  animation: building-diagram-antenna-ring 2.4s ease-out infinite;
  transform-origin: 24px 22px;
}

@keyframes building-diagram-antenna-pulse{
  0%, 100%{ opacity: 1; }
  50%{ opacity: 0.55; }
}

@keyframes building-diagram-antenna-ring{
  0%{ opacity: 0.5; transform: scale(0.85); }
  70%{ opacity: 0; transform: scale(1.35); }
  100%{ opacity: 0; transform: scale(1.35); }
}

.building-diagram__antenna-label{
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  white-space: nowrap;
}

@media (prefers-reduced-motion: reduce){
  .building-diagram__remote-node,
  .building-diagram__remote-link,
  .building-diagram__center{
    transition: none;
  }
  .building-diagram__antenna-pulse,
  .building-diagram__antenna-ring{
    animation: none;
  }
}

.building-diagram__center{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: clamp(200px, 30vw, 360px);
  height: clamp(260px, 38vw, 440px);
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    width 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    height 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    top 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    left 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.building-diagram--remote-focus .building-diagram__center{
  left: 47%;
  top: 54%;
  width: clamp(150px, 22vw, 280px);
  height: clamp(190px, 28vw, 360px);
}

.building-diagram__viewer{
  position: relative;
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

.building-diagram__viewer .building-diagram__model-viewer,
.building-diagram__viewer model-viewer{
  background-color: transparent !important;
}

.building-diagram__model-viewer{
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  --poster-color: transparent;
}

.building-diagram__viewer-loading{
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 1rem;
  pointer-events: none;
  color: rgba(255,255,255,.42);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
  pointer-events: none;
}

.building-diagram__viewer-loading--error{
  color: rgba(255, 180, 140, 0.75);
  font-size: 0.72rem;
}

.building-diagram__viewer-placeholder{
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 1.25rem;
  color: rgba(255,255,255,.5);
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  text-align: center;
  text-transform: uppercase;
  pointer-events: none;
}

.building-diagram__viewer.is-model-ready .building-diagram__viewer-canvas{
  opacity: 1;
}


.building-diagram__placeholder{
  width: 100%;
  height: 100%;
  border: 2px solid rgba(244,121,45,.55);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(244,121,45,.05), rgba(0,145,138,.05) 50%, transparent),
    rgba(15, 22, 33, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.6);
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  padding: 1rem;
}

.building-diagram__placeholder i{
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  color: rgba(244,121,45,.7);
  display: block;
  margin-bottom: 0.45rem;
}

.building-diagram__label{
  position: absolute;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  padding: 0;
  margin: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  color: rgba(255,255,255,.78);
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  overflow: visible;
  transition: transform 0.22s ease;
  user-select: none;
}

.building-diagram__label-pill{
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.55rem 0.95rem;
  background: rgba(11, 16, 24, 0.85);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  transition:
    color 0.22s ease,
    background 0.22s ease,
    border-color 0.22s ease,
    box-shadow 0.22s ease;
}

.building-diagram__label-stack{
  display: flex;
  flex-direction: column;
  align-items: inherit;
  overflow: hidden;
  max-height: 2.85rem;
  transition: max-height 0.38s cubic-bezier(0.22, 1, 0.36, 1);
}

.building-diagram__label[data-pos="right-upper"] .building-diagram__label-stack,
.building-diagram__label[data-pos="right-lower"] .building-diagram__label-stack{
  align-items: flex-end;
}

.building-diagram__label[data-pos="left-upper"] .building-diagram__label-stack,
.building-diagram__label[data-pos="left-lower"] .building-diagram__label-stack{
  align-items: flex-start;
}

.building-diagram__label-detail{
  display: block;
  max-width: 13.5rem;
  padding: 0.55rem 0.85rem 0.65rem;
  margin-top: -0.15rem;
  font-size: 0.72rem;
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: 0.01em;
  color: rgba(255,255,255,.82);
  text-align: center;
  background: rgba(11, 16, 24, 0.92);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  box-shadow: 0 10px 24px -12px rgba(0,0,0,.55);
  opacity: 0;
  transform: translateY(-100%);
  transition:
    opacity 0.28s ease,
    transform 0.38s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
}

.building-diagram__label:hover .building-diagram__label-stack,
.building-diagram__label:focus-visible .building-diagram__label-stack,
.building-diagram__label.is-lit .building-diagram__label-stack{
  max-height: 12rem;
}

.building-diagram__label:hover .building-diagram__label-detail,
.building-diagram__label:focus-visible .building-diagram__label-detail,
.building-diagram__label.is-lit .building-diagram__label-detail{
  opacity: 1;
  transform: translateY(0);
}

.building-diagram__label-icon{
  font-size: 1.05rem;
  color: var(--tc-teal);
  transition: color 0.22s ease;
}

.building-diagram__label:hover,
.building-diagram__label:focus-visible,
.building-diagram__label.is-lit{
  z-index: 5;
  color: #fff;
  transform: translateY(-1px);
  outline: none;
}

.building-diagram__label:hover .building-diagram__label-pill,
.building-diagram__label:focus-visible .building-diagram__label-pill,
.building-diagram__label.is-lit .building-diagram__label-pill{
  color: #fff;
  background: rgba(244,121,45,.18);
  border-color: rgba(244,121,45,.7);
  box-shadow: 0 0 0 1px rgba(244,121,45,.25), 0 12px 28px -16px rgba(0,0,0,.6);
}

.building-diagram__label:hover .building-diagram__label-icon,
.building-diagram__label:focus-visible .building-diagram__label-icon,
.building-diagram__label.is-lit .building-diagram__label-icon{
  color: var(--accent-orange);
}

.building-diagram__label[data-pos="right-upper"],
.building-diagram__label[data-pos="right-lower"]{
  align-items: flex-end;
}

.building-diagram__label[data-pos="right-upper"] .building-diagram__label-detail,
.building-diagram__label[data-pos="right-lower"] .building-diagram__label-detail{
  text-align: right;
}

.building-diagram__label[data-pos="left-upper"],
.building-diagram__label[data-pos="left-lower"]{
  align-items: flex-start;
}

.building-diagram__label[data-pos="left-upper"] .building-diagram__label-detail,
.building-diagram__label[data-pos="left-lower"] .building-diagram__label-detail{
  text-align: left;
}

@media (prefers-reduced-motion: reduce){
  .building-diagram__label-detail,
  .building-diagram__label-stack{
    transition: none;
  }
  .building-diagram__label:hover .building-diagram__label-detail,
  .building-diagram__label:focus-visible .building-diagram__label-detail,
  .building-diagram__label.is-lit .building-diagram__label-detail{
    transform: none;
  }
}

/* Anchor positions for 5 labels around the building */
.building-diagram__label[data-pos="top"]{ left: 50%; top: 6%; transform: translate(-50%, 0); }
.building-diagram__label[data-pos="top"]:hover,
.building-diagram__label[data-pos="top"]:focus-visible,
.building-diagram__label[data-pos="top"].is-lit{ transform: translate(-50%, -3px); }

.building-diagram__label[data-pos="right-upper"]{ right: 4%; top: 30%; }
.building-diagram__label[data-pos="right-lower"]{ right: 4%; bottom: 22%; }
.building-diagram__label[data-pos="left-upper"]{ left: 4%; top: 30%; }
.building-diagram__label[data-pos="left-lower"]{ left: 4%; bottom: 22%; }

@media (max-width: 767.98px){
  .building-diagram{
    aspect-ratio: 3 / 4;
  }
  .building-diagram__label{
    font-size: 0.85rem;
  }
  .building-diagram__label-pill{
    padding: 0.45rem 0.75rem;
  }
  .building-diagram__label-detail{
    max-width: 11rem;
    font-size: 0.68rem;
  }
  .building-diagram__label[data-pos="top"]{ top: 2%; }
  .building-diagram__label[data-pos="right-upper"]{ right: 2%; top: 22%; }
  .building-diagram__label[data-pos="right-lower"]{ right: 2%; bottom: 26%; }
  .building-diagram__label[data-pos="left-upper"]{ left: 2%; top: 22%; }
  .building-diagram__label[data-pos="left-lower"]{ left: 2%; bottom: 26%; }
  .building-diagram__center{
    width: 58%;
    height: clamp(220px, 52vw, 320px);
  }
  .building-diagram--remote-focus .building-diagram__center{
    left: 50%;
    top: 56%;
    width: 46%;
    height: clamp(170px, 38vw, 250px);
  }
  .building-diagram__remote-node{
    top: 10%;
    right: 16%;
    max-width: 32%;
  }
}

/* ── Gunpowder ignition (Our Approach hero — left-to-right circuit
       trace lighting up four steps in sequence) ── */

.gunpowder-ignition{
  position: relative;
  width: 100%;
  height: 100%;
  min-height: clamp(280px, 38vw, 420px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.gunpowder-ignition__track{
  position: relative;
  width: 100%;
  padding: clamp(1rem, 2vw, 1.5rem) 0;
}

.gunpowder-ignition__svg{
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.gunpowder-ignition__trace-base{
  fill: none;
  stroke: rgba(255,255,255,.14);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.gunpowder-ignition__trace-lit{
  fill: none;
  stroke: var(--accent-orange);
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 1 1;
  stroke-dashoffset: 1;
  opacity: 0;
  filter: drop-shadow(0 0 6px rgba(244,121,45,.55));
  transition: stroke-dashoffset 1.1s cubic-bezier(0.45, 0, 0.2, 1), opacity 0.22s ease;
}

.gunpowder-ignition.is-running .gunpowder-ignition__trace-lit,
.gunpowder-ignition.is-complete .gunpowder-ignition__trace-lit{
  opacity: 1;
}

.gunpowder-ignition__steps{
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.5rem, 1vw, 1rem);
}

.gunpowder-step{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.55rem;
  padding: 0.5rem 0.25rem;
  background: transparent;
  border: 0;
  cursor: default;
  font-family: inherit;
  color: inherit;
}

/* Interactive variant: clickable pacing */
.gunpowder-ignition--interactive .gunpowder-step{
  cursor: pointer;
}

.gunpowder-ignition--interactive .gunpowder-step:hover .gunpowder-step__node,
.gunpowder-ignition--interactive .gunpowder-step:focus-visible .gunpowder-step__node{
  border-color: rgba(244,121,45,.7);
  box-shadow: 0 0 0 4px rgba(244,121,45,.15);
}

.gunpowder-step__node{
  position: relative;
  z-index: 1;
  width: clamp(46px, 6vw, 64px);
  height: clamp(46px, 6vw, 64px);
  border-radius: 50%;
  background: #0f1621;
  border: 2px solid rgba(255,255,255,.18);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.55);
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  transition:
    border-color 0.4s ease,
    color 0.4s ease,
    background 0.4s ease,
    transform 0.4s ease,
    box-shadow 0.4s ease;
}

.gunpowder-step__title{
  font-size: clamp(0.82rem, 1.2vw, 0.95rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  transition: color 0.4s ease;
  line-height: 1.2;
  margin: 0;
}

.gunpowder-step.is-lit .gunpowder-step__node{
  border-color: var(--accent-orange);
  background: #1c2430;
  color: var(--accent-orange);
  transform: scale(1.06);
  box-shadow: 0 0 0 4px rgba(244,121,45,.12), 0 0 24px -4px rgba(244,121,45,.55);
}

.gunpowder-step.is-lit .gunpowder-step__title{
  color: #fff;
}

@media (prefers-reduced-motion: reduce){
  .gunpowder-ignition__trace-lit{ transition: none; }
  .gunpowder-step__node{ transition: none; }
  .gunpowder-step__title{ transition: none; }
}

/* ── Spec-sheet block (used for "What 24/7 service means at TC" and the
       FX BAS technology section) ── */

.spec-sheet{
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2vw, 1.5rem);
  background: #fff;
  border: 1px solid rgba(20, 26, 36, 0.1);
  border-radius: 14px;
  padding: clamp(1.5rem, 3vw, 2.25rem) clamp(1.35rem, 2.5vw, 2rem);
  box-shadow: 0 14px 50px -32px rgba(20, 26, 36, 0.35);
}

.spec-sheet__row{
  display: grid;
  grid-template-columns: minmax(11rem, 16rem) 1fr;
  gap: clamp(0.75rem, 2vw, 1.5rem);
  padding-bottom: clamp(0.85rem, 1.5vw, 1.15rem);
  border-bottom: 1px solid rgba(20, 26, 36, 0.08);
}

.spec-sheet__row:last-child{
  padding-bottom: 0;
  border-bottom: 0;
}

@media (max-width: 767.98px){
  .spec-sheet__row{
    grid-template-columns: 1fr;
    gap: 0.35rem;
  }
}

.spec-sheet__label{
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(20, 26, 36, 0.55);
  margin: 0;
  padding-top: 0.18rem;
}

.spec-sheet__value{
  font-size: 1rem;
  line-height: 1.55;
  color: #131820;
  margin: 0;
}

.spec-sheet__value--placeholder{
  color: rgba(20, 26, 36, 0.5);
  font-style: italic;
}

.spec-sheet__value--mono{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, "Cascadia Mono", "Roboto Mono", Consolas, monospace;
  font-weight: 600;
  color: #131820;
}

.spec-sheet__placeholder-flag{
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0 0 1rem;
  padding: 0.55rem 0.85rem;
  background: rgba(244, 121, 45, 0.1);
  border: 1px solid rgba(244, 121, 45, 0.32);
  border-radius: 8px;
  color: rgba(20, 26, 36, 0.85);
  font-size: 0.85rem;
  font-weight: 600;
}

.spec-sheet__placeholder-flag i{
  color: var(--accent-orange);
}

/* ── Draft / placeholder notice (corner badge, expands on hover) ── */

.draft-notice{
  position: absolute;
  top: clamp(0.85rem, 2vw, 1.35rem);
  right: clamp(0.85rem, 2vw, 1.35rem);
  z-index: 8;
}

.draft-notice__trigger{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.65rem;
  height: 1.65rem;
  border: 0;
  border-radius: 999px;
  background: rgba(244, 121, 45, 0.12);
  color: var(--accent-orange);
  font-size: 0.72rem;
  line-height: 1;
  cursor: help;
  opacity: 0.42;
  transition: opacity 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.draft-notice:hover .draft-notice__trigger,
.draft-notice:focus-within .draft-notice__trigger{
  opacity: 1;
  background: rgba(244, 121, 45, 0.22);
  transform: scale(1.05);
}

.draft-notice__panel{
  position: absolute;
  top: calc(100% + 0.35rem);
  right: 0;
  width: max-content;
  max-width: min(19rem, calc(100vw - 2.5rem));
  padding: 0.6rem 0.8rem;
  background: #fff;
  border: 1px solid rgba(244, 121, 45, 0.32);
  border-radius: 8px;
  box-shadow: 0 10px 28px -14px rgba(20, 26, 36, 0.45);
  font-size: 0.76rem;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(20, 26, 36, 0.82);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
  pointer-events: none;
}

.draft-notice:hover .draft-notice__panel,
.draft-notice:focus-within .draft-notice__panel{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.cap-section--dark .draft-notice__panel{
  background: rgba(8, 14, 22, 0.96);
  color: rgba(255, 255, 255, 0.86);
  border-color: rgba(244, 121, 45, 0.38);
  box-shadow: 0 12px 32px -12px rgba(0, 0, 0, 0.65);
}

/* ── Service pillars (JCI 24/7 page) ── */

.service-pillars{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.15rem, 2.2vw, 1.65rem);
  max-width: 56rem;
  margin: 0 auto;
}

@media (max-width: 767.98px){
  .service-pillars{
    grid-template-columns: 1fr;
  }
}

.service-pillar{
  background: #fff;
  border: 1px solid rgba(20, 26, 36, 0.1);
  border-top: 3px solid var(--accent-orange);
  border-radius: 14px;
  padding: clamp(1.25rem, 2.2vw, 1.65rem);
  box-shadow: 0 12px 44px -30px rgba(20, 26, 36, 0.35);
}

.service-pillar__title{
  font-size: 1.02rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  line-height: 1.25;
  color: #131820;
  margin: 0 0 0.6rem;
}

.service-pillar__body{
  font-size: 0.96rem;
  line-height: 1.6;
  color: rgba(20, 26, 36, 0.78);
  margin: 0;
}

/* ── Testimonial column (JCI page — 3 plain attributed quotes, marked
       PLACEHOLDER for v1) ── */

.testimonial-column{
  display: flex;
  flex-direction: column;
  gap: clamp(1.25rem, 2vw, 1.85rem);
  max-width: 56rem;
  margin: 0 auto;
}

.testimonial-quote-block{
  border-left: 3px solid var(--accent-orange);
  padding: 0.5rem 0 0.5rem clamp(1rem, 2vw, 1.5rem);
}

.testimonial-quote-block__quote{
  font-size: clamp(1.02rem, 1.4vw, 1.15rem);
  line-height: 1.6;
  color: #131820;
  font-style: italic;
  margin: 0 0 0.65rem;
}

.testimonial-quote-block__attribution{
  font-size: 0.92rem;
  color: rgba(20, 26, 36, 0.65);
  font-style: normal;
}

.testimonial-quote-block__attribution strong{
  color: #131820;
  font-weight: 700;
  font-style: normal;
}

.cap-section--dark .testimonial-quote-block__quote{ color: #fff; }
.cap-section--dark .testimonial-quote-block__attribution{ color: rgba(255,255,255,.68); }
.cap-section--dark .testimonial-quote-block__attribution strong{ color: #fff; }

.testimonial-column__placeholder-flag{
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0 0 0.5rem;
  padding: 0.45rem 0.75rem;
  background: rgba(244, 121, 45, 0.1);
  border: 1px solid rgba(244, 121, 45, 0.3);
  border-radius: 8px;
  color: rgba(20, 26, 36, 0.85);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  align-self: flex-start;
}

.testimonial-column__placeholder-flag i{
  color: var(--accent-orange);
}

.cap-section--dark .testimonial-column__placeholder-flag{
  background: rgba(244, 121, 45, 0.12);
  color: rgba(255,255,255,.85);
}

/* ── Capability section wrappers (consistent vertical rhythm and
       light/dark backgrounds across pages) ── */

.cap-section{
  position: relative;
  padding: clamp(2.75rem, 6vw, 5rem) 0;
}

.cap-section--light{ background: #f8f7f4; color: #131820; }
.cap-section--paper{ background: #fff; color: #131820; }
.cap-section--dark{
  background: var(--hero-bg-1);
  color: #fff;
  background-image:
    radial-gradient(900px 500px at 20% 15%, rgba(0,145,138,.18), transparent 60%),
    radial-gradient(700px 450px at 80% 30%, rgba(244,121,45,.12), transparent 60%),
    linear-gradient(135deg, var(--hero-bg-1), var(--hero-bg-2));
}

.cap-section__head{
  max-width: 56rem;
  margin: 0 auto clamp(1.5rem, 3vw, 2.5rem);
  text-align: center;
}

.cap-section__eyebrow{
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-orange);
  margin: 0 0 0.5rem;
}

.cap-section__title{
  font-size: clamp(1.5rem, 2.85vw, 2.1rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.18;
  margin: 0 0 0.6rem;
}

.cap-section__lede{
  font-size: clamp(1rem, 1.3vw, 1.1rem);
  line-height: 1.6;
  color: rgba(20, 26, 36, 0.72);
  margin: 0 auto;
  max-width: 42rem;
}

.cap-section--dark .cap-section__lede{ color: rgba(255,255,255,.78); }
.cap-section--dark .cap-section__title{ color: #fff; }

/* ==========================================================================
   V2 pages — FAQ, About, Service Agreement, Contact, Who We Serve,
   Work With Us, Blog, TC System hero v2
   ========================================================================== */

/* Legal / Service Agreement */
.legal-document{
  max-width: 46rem;
  margin: 0 auto;
  padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(4rem, 8vw, 6rem);
  color: #131820;
}
.legal-document h1{
  font-size: clamp(1.75rem, 3vw, 2.35rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 1.75rem;
}
.legal-document h2{
  font-size: 1.05rem;
  font-weight: 800;
  margin: 1.75rem 0 0.65rem;
  letter-spacing: -0.01em;
}
.legal-document p,
.legal-document li{
  font-size: 1rem;
  line-height: 1.65;
  color: rgba(20, 26, 36, 0.88);
}
.legal-document ul{
  padding-left: 1.25rem;
  margin: 0 0 0.75rem;
}

/* About Us leadership */
.about-leadership-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: clamp(1.25rem, 2.5vw, 2rem);
  max-width: 56rem;
  margin: 0 auto;
}
.about-leader{
  text-align: center;
}
.about-leader__photo{
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: 0.65rem;
  background: rgba(20, 26, 36, 0.06);
}
.about-leader__name{
  font-weight: 700;
  font-size: 0.95rem;
  margin: 0 0 0.15rem;
}
.about-leader__title{
  font-size: 0.82rem;
  color: rgba(20, 26, 36, 0.62);
  margin: 0;
  line-height: 1.35;
}
.about-values-list{
  max-width: 46rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.about-value-item h3{
  font-size: 1.05rem;
  font-weight: 800;
  margin: 0 0 0.35rem;
}
.about-value-item p{
  margin: 0;
  line-height: 1.6;
  color: rgba(20, 26, 36, 0.78);
}

/* Contact page */
.contact-page-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 4vw, 3rem);
}
@media (min-width: 992px){
  .contact-page-grid{
    grid-template-columns: minmax(280px, 1fr) minmax(320px, 1.1fr);
    align-items: start;
  }
}
.contact-info-block{
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.contact-info-block address{
  font-style: normal;
  line-height: 1.6;
  color: rgba(20, 26, 36, 0.85);
}
.contact-map{
  width: 100%;
  aspect-ratio: 16 / 10;
  border: 0;
  border-radius: 12px;
  background: rgba(20, 26, 36, 0.06);
}

/* Who We Serve */
.who-we-serve-nav{
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(248, 247, 244, 0.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(20, 26, 36, 0.08);
  padding: 0.65rem 0;
}
.who-we-serve-nav__list{
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  list-style: none;
  margin: 0;
  padding: 0;
  justify-content: center;
}
.who-we-serve-nav__link{
  font-size: 0.88rem;
  font-weight: 600;
  color: rgba(20, 26, 36, 0.62);
  text-decoration: none;
  padding: 0.35rem 0.15rem;
  border-bottom: 2px solid transparent;
  transition: color 0.18s ease, border-color 0.18s ease;
}
.who-we-serve-nav__link:hover,
.who-we-serve-nav__link.is-active{
  color: var(--accent-orange);
  border-bottom-color: var(--accent-orange);
}
.who-segment{
  scroll-margin-top: 4.5rem;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(1rem, 2.5vw, 2rem);
  padding: clamp(2rem, 4vw, 3rem) 0;
  border-bottom: 1px solid rgba(20, 26, 36, 0.08);
}
.who-segment__icon{
  width: clamp(48px, 6vw, 64px);
  height: clamp(48px, 6vw, 64px);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.65rem;
  color: var(--tc-teal);
  border: 1px solid rgba(20, 26, 36, 0.12);
  border-radius: 12px;
  flex-shrink: 0;
}
.who-segment__body h2{
  font-size: clamp(1.35rem, 2.2vw, 1.75rem);
  font-weight: 800;
  margin: 0 0 0.65rem;
}
.who-segment__lede{
  line-height: 1.6;
  color: rgba(20, 26, 36, 0.78);
  margin: 0 0 1.25rem;
  max-width: 42rem;
}
.who-case-card{
  background: #fff;
  border: 1px solid rgba(20, 26, 36, 0.1);
  border-radius: 12px;
  padding: 1.25rem 1.35rem;
  max-width: 42rem;
  box-shadow: 0 12px 40px -28px rgba(20, 26, 36, 0.35);
}
.who-case-card__tag{
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-orange);
  margin: 0 0 0.4rem;
}
.who-case-card__title{
  font-weight: 700;
  margin: 0 0 0.5rem;
}
.who-case-card p{
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(20, 26, 36, 0.78);
}
.who-segment--cea .who-case-card{
  border-style: dashed;
  background: rgba(248, 247, 244, 0.6);
}
.who-segment-index{
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1.25rem;
  justify-content: center;
  padding: 1.5rem 0 0;
}
.who-segment-index a{
  color: var(--tc-teal);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.95rem;
}
.who-segment-index a:hover{ color: var(--accent-orange); }

@media (max-width: 767.98px){
  .who-segment{ grid-template-columns: 1fr; }
  .who-segment__icon{ width: 48px; height: 48px; font-size: 1.35rem; }
}

/* Work With Us */
.work-cards{
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2vw, 1.5rem);
  max-width: 56rem;
  margin: 0 auto;
}
@media (min-width: 768px){
  .work-cards{ grid-template-columns: repeat(3, 1fr); }
}
.work-card{
  display: flex;
  flex-direction: column;
  padding: clamp(1.35rem, 2.5vw, 1.75rem);
  background: #fff;
  border: 1px solid rgba(20, 26, 36, 0.1);
  border-radius: 14px;
  min-height: 100%;
}
.work-card__num{
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--accent-orange);
  margin: 0 0 0.5rem;
}
.work-card__title{
  font-size: 1.1rem;
  font-weight: 800;
  margin: 0 0 0.65rem;
}
.work-card__body{
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(20, 26, 36, 0.78);
  margin: 0 0 0.85rem;
  flex-grow: 1;
}
.work-card__quote{
  font-size: 0.88rem;
  font-style: italic;
  line-height: 1.5;
  color: rgba(20, 26, 36, 0.65);
  border-left: 2px solid var(--accent-orange);
  padding-left: 0.85rem;
  margin: 0;
}
.work-card--placeholder{
  /* Third card slot — draft note lives in section corner badge */
}
.work-jobs-list{
  max-width: 46rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.work-job-row{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(20, 26, 36, 0.08);
}
.work-job-row__title{
  font-weight: 700;
  margin: 0;
}
.work-job-row__meta{
  font-size: 0.88rem;
  color: rgba(20, 26, 36, 0.55);
  margin: 0.15rem 0 0;
}
.work-job-row__apply{
  font-weight: 600;
  color: var(--accent-orange);
  text-decoration: none;
  white-space: nowrap;
}
.work-quote-strip{
  max-width: 46rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

/* Blog */
.blog-filters{
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  margin-bottom: 1.75rem;
}
.blog-filter-btn{
  border: 1px solid rgba(20, 26, 36, 0.14);
  background: #fff;
  border-radius: 999px;
  padding: 0.4rem 0.9rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(20, 26, 36, 0.72);
  cursor: pointer;
  transition: border-color 0.18s ease, color 0.18s ease, background 0.18s ease;
}
.blog-filter-btn.is-active,
.blog-filter-btn:hover{
  border-color: var(--accent-orange);
  color: var(--accent-orange);
  background: rgba(244, 121, 45, 0.06);
}
.blog-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  max-width: 56rem;
  margin: 0 auto;
}
@media (min-width: 768px){
  .blog-grid{ grid-template-columns: repeat(2, 1fr); }
}
.blog-card{
  display: flex;
  flex-direction: column;
  padding: 1.25rem 1.35rem;
  background: #fff;
  border: 1px solid rgba(20, 26, 36, 0.1);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.18s ease, transform 0.18s ease;
  min-height: 100%;
}
.blog-card:hover{
  border-color: rgba(244, 121, 45, 0.45);
  transform: translateY(-2px);
  color: inherit;
}
.blog-card__category{
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-orange);
  margin: 0 0 0.45rem;
}
.blog-card__title{
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.3;
  margin: 0 0 0.5rem;
}
.blog-card__excerpt{
  font-size: 0.92rem;
  line-height: 1.5;
  color: rgba(20, 26, 36, 0.68);
  margin: 0 0 0.75rem;
  flex-grow: 1;
}
.blog-card__date{
  font-size: 0.82rem;
  color: rgba(20, 26, 36, 0.48);
}
.blog-post{
  max-width: 42rem;
  margin: 0 auto;
  padding: clamp(2rem, 4vw, 3rem) 0 4rem;
}
.blog-post__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
  font-size: 0.85rem;
  color: rgba(20, 26, 36, 0.55);
  margin-bottom: 1.25rem;
}
.blog-post__title{
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: 800;
  line-height: 1.15;
  margin: 0 0 1.25rem;
}
.blog-post__body{
  line-height: 1.7;
  color: rgba(20, 26, 36, 0.88);
}
.blog-post__body p{ margin: 0 0 1rem; }

/* TC System hero v2 — buildings slide past badge */
.buildings-slide-hero{
  position: relative;
  width: 100%;
  height: 100%;
  min-height: clamp(280px, 38vw, 420px);
  overflow: hidden;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(15,22,33,.95), rgba(8,14,22,.98));
}
.buildings-slide-hero__track{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  gap: clamp(2rem, 8vw, 5rem);
  padding-bottom: 12%;
  animation: buildingsSlide 28s linear infinite;
  will-change: transform;
}
.buildings-slide-hero__building{
  flex: 0 0 auto;
  width: clamp(120px, 22vw, 200px);
  opacity: 0.55;
  filter: grayscale(1) brightness(0.85);
  transition: filter 0.6s ease, opacity 0.6s ease;
}
.buildings-slide-hero__building.is-treated{
  opacity: 0.95;
  filter: grayscale(0) brightness(1) drop-shadow(0 0 12px rgba(244,121,45,.35));
}
.buildings-slide-hero__badge{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
  width: clamp(100px, 18vw, 160px);
  pointer-events: none;
}
.buildings-slide-hero__badge img{
  width: 100%;
  height: auto;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,.45));
}
@keyframes buildingsSlide{
  0%{ transform: translateX(40%); }
  100%{ transform: translateX(-120%); }
}
@media (prefers-reduced-motion: reduce){
  .buildings-slide-hero__track{ animation: none; justify-content: center; padding-bottom: 0; align-items: center; }
  .buildings-slide-hero__building{ opacity: 0.7; }
}

/* CMS admin */
.cms-admin{
  min-height: 100vh;
  background: #f4f3ef;
  padding: 2rem 0 4rem;
}
.cms-admin__panel{
  background: #fff;
  border: 1px solid rgba(20, 26, 36, 0.1);
  border-radius: 12px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.cms-admin textarea{
  width: 100%;
  min-height: 200px;
  font-family: ui-monospace, monospace;
  font-size: 0.85rem;
}

/* ── Visually plan revisions (Notion) ── */

/* Global nav — turquoise laser underline (hover + active, left-to-right) */
:root{
  --nav-trace-duration: 0.42s;
  --nav-trace-ease: cubic-bezier(0.45, 0, 0.2, 1);
}

.navbar-tc-main .navbar-nav-tc .nav-link,
.navbar-secondary__link,
.navbar-tc-main .dropdown-item{
  position: relative;
}

.navbar-tc-main .navbar-nav-tc .nav-link.active,
.navbar-secondary__link.active,
.navbar-tc-main .dropdown-item.active,
.navbar-tc-main .dropdown-item:active{
  background-color: transparent !important;
}

.navbar-tc-main .navbar-nav-tc .nav-link.active{
  color: #fff !important;
}

.navbar-tc-main .navbar-nav-tc .nav-link::after,
.navbar-secondary__link::after,
.navbar-tc-main .dropdown-item::after{
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2.5px;
  background: var(--tc-teal);
  border-radius: 1px;
  transform: scaleX(0);
  transform-origin: left center;
  opacity: 0;
  transition:
    transform var(--nav-trace-duration) var(--nav-trace-ease),
    opacity 0.1s ease;
  filter: drop-shadow(0 0 6px rgba(0, 145, 138, 0.55));
  pointer-events: none;
}

.navbar-tc-main .dropdown-item::after{
  left: 1.15rem;
  width: calc(100% - 2.3rem);
}

.navbar-tc-main .navbar-nav-tc .nav-link:hover::after,
.navbar-tc-main .navbar-nav-tc .nav-link:focus-visible::after,
.navbar-secondary__link:hover::after,
.navbar-secondary__link:focus-visible::after,
.navbar-tc-main .dropdown-item:hover::after,
.navbar-tc-main .dropdown-item:focus-visible::after,
.navbar-tc-main .navbar-nav-tc .nav-link.active::after,
.navbar-secondary__link.active::after,
.navbar-tc-main .dropdown-item.active::after,
.navbar-tc-main .dropdown-item:active::after{
  transform: scaleX(1);
  opacity: 1;
}

.navbar-tc-main .dropdown-item.active,
.navbar-tc-main .dropdown-item:active{
  color: #fff !important;
  box-shadow: none;
}

@starting-style{
  .navbar-tc-main .navbar-nav-tc .nav-link.active::after,
  .navbar-secondary__link.active::after,
  .navbar-tc-main .dropdown-item.active::after{
    transform: scaleX(0);
    opacity: 0.7;
  }
}

@media (prefers-reduced-motion: reduce){
  .navbar-tc-main .navbar-nav-tc .nav-link::after,
  .navbar-secondary__link::after,
  .navbar-tc-main .dropdown-item::after{
    transition: none;
  }

  .navbar-tc-main .navbar-nav-tc .nav-link:hover::after,
  .navbar-tc-main .navbar-nav-tc .nav-link:focus-visible::after,
  .navbar-secondary__link:hover::after,
  .navbar-secondary__link:focus-visible::after,
  .navbar-tc-main .dropdown-item:hover::after,
  .navbar-tc-main .dropdown-item:focus-visible::after,
  .navbar-tc-main .navbar-nav-tc .nav-link.active::after,
  .navbar-secondary__link.active::after,
  .navbar-tc-main .dropdown-item.active::after,
  .navbar-tc-main .dropdown-item:active::after{
    transform: scaleX(1);
    opacity: 1;
  }
}

.site-hero--about-light .navbar-tc-main .navbar-nav-tc .nav-link.active{
  color: #1a2332 !important;
}

.site-hero--about-light .navbar-tc-main .dropdown-item.active,
.site-hero--about-light .navbar-tc-main .dropdown-item:active{
  color: #1a2332 !important;
  background-color: transparent !important;
}

/* Brand switcher */
.nav-brand-switcher{
  position: relative;
}

.navbar-brand-text{
  display: none !important;
}

.nav-brand-switcher__menu{
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 0;
  min-width: 14rem;
  padding: 0.35rem 0;
  background: #1a222c;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  box-shadow: 0 16px 40px -12px rgba(0, 0, 0, 0.55);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
  z-index: 1300;
}

.nav-brand-switcher:hover .nav-brand-switcher__menu,
.nav-brand-switcher:focus-within .nav-brand-switcher__menu{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-brand-switcher__item{
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0.85rem;
  color: #fff;
  text-decoration: none;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.nav-brand-switcher__item:hover,
.nav-brand-switcher__item:focus-visible{
  background: rgba(0, 145, 138, 0.16);
  color: #fff;
}

.nav-brand-switcher__mark--group{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--tc-orange-left), var(--tc-orange-right));
  font-size: 0.72rem;
  font-weight: 800;
}

.nav-brand-switcher__mark .brand-mark svg{
  width: auto;
  height: 1.65rem;
}

/* Home — hero shift up, lighter overlay */
.site-hero.site-hero--landing{
  overflow: visible;
}

.site-hero.site-hero--landing::after{
  opacity: 0.42;
}

.hero-content--landing{
  padding-top: clamp(0.35rem, 1.2vw, 1rem);
}

@media (min-width: 992px) and (max-height: 900px){
  .hero-content--landing .hero-content-row{
    margin-top: -1.25rem;
    margin-bottom: -2.5rem;
  }

  .hero-visual{
    min-height: 760px;
  }
}

/* BMS Incentives hub — desktop shift, mobile kicker padding */
@media (min-width: 992px) and (max-width: 1480px){
  .hero-content--incentives-hub.hero-content--landing{
    padding-top: clamp(0.25rem, 0.8vw, 0.75rem);
  }

  .hero-content--incentives-hub .hero-content-row{
    transform: translateY(-1.75rem);
  }
}

@media (max-width: 767.98px){
  .hero-content--incentives-hub .hero-kicker{
    padding-top: 2.75rem;
  }
}

/* JCI — intro width, phone, title breaks, form selects */
.cap-section__head--stack-left{
  text-align: left;
  margin-left: 0;
  margin-right: 0;
}

.cap-section__head--stack-left .cap-section__lede{
  margin-left: 0;
  margin-right: 0;
  max-width: none;
}

.cap-hero-title--jci-lines{
  line-height: 1.05;
}

.contact-panel__tier--emergency .contact-panel__label{
  margin-bottom: 0.35rem;
}

.contact-panel__tier--service .contact-panel__label{
  margin-bottom: 0.5rem;
}

.contact-panel__emergency-number{
  white-space: nowrap;
  letter-spacing: 0.01em;
}

.assessment-form-group--building{
  margin-top: 1.75rem;
}

select.assessment-input{
  line-height: 1.5;
  min-height: 2.75rem;
}

select.assessment-input:invalid{
  color: rgba(19, 24, 32, 0.45);
}

.cap-section--paper select.assessment-input:invalid,
.cap-section--light select.assessment-input:invalid{
  color: rgba(19, 24, 32, 0.45);
}

select.assessment-input option[disabled]{
  color: rgba(19, 24, 32, 0.45);
}

/* About — leadership grid min 2 per row, bottom CTAs */
.about-leadership-grid{
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (min-width: 768px){
  .about-leadership-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.about-bottom-ctas{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}

/* Service Agreement — readable text */
.site-hero--nav-only::before,
.site-hero--nav-only::after{
  display: none;
}

.page-legal main{
  background: #f8f7f4;
  color: #131820;
}

.page-legal .legal-document{
  color: #131820;
}

.page-legal .legal-document h1,
.page-legal .legal-document h2{
  color: #131820;
}
