/* solutions.css (page-specific) */

.nav-list a.is-current{ color: var(--color-text-main); }
.nav-list a.is-current::after{ transform: scaleX(1); }

/* small utility */
.flow > * + *{ margin-top: 0.9rem; }

.sol-hero{ padding-top: 50px; }
.sol-hero-card{ padding: clamp(1.6rem, 3vw, 2.4rem); }

.sol-hero__grid{
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(0, 0.88fr);
  gap: clamp(1rem, 2.4vw, 1.6rem);
  align-items: start;
}

.sol-hero__title{
  margin: 0;
  font-size: clamp(2rem, 2.2rem + 0.5vw, 2.75rem);
  letter-spacing: -0.03em;
}

.sol-hero__lead{
  margin: 0;
  color: var(--color-text-soft);
  font-size: var(--text-lg);
  line-height: 1.7;
  max-width: 76ch;
}

.sol-hero__bullets{
  margin: 0;
  padding-left: 1.1rem;
  color: var(--color-text-soft);
  line-height: 1.7;
}
.sol-hero__bullets li{ margin: 0.35rem 0; }

.sol-hero__ctas{
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

/* TOC */
.sol-toc{
  padding: 1.25rem;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-subtle);
  position: sticky;
  top: calc(var(--stack-top) - 10px);
  max-height: calc(100vh - var(--stack-top) - 28px);
  overflow: auto;
}

.sol-toc__title{
  margin: 0 0 0.6rem;
  font-size: var(--text-lg);
}

.sol-toc__nav{
  display: grid;
  gap: 10px;
  margin-top: 0.6rem;
}

.sol-toc__nav a{
  text-decoration: none;
  color: var(--color-text-soft);
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.65);
  box-shadow: var(--shadow-subtle);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: transform .15s ease, border-color .15s ease, color .15s ease, background .15s ease;
}

.sol-toc__nav a::after{ content: "→"; opacity: .45; }

.sol-toc__nav a:hover{
  transform: translateY(-1px);
  color: var(--color-text-main);
  border-color: rgba(94,203,255,.35);
}

.sol-toc__nav a.is-active{
  color: var(--color-text-main);
  border-color: rgba(162,117,255,.30);
  background: linear-gradient(135deg, rgba(94,203,255,.16), rgba(162,117,255,.12));
}

.sol-toc__chips{
  margin-top: 0.9rem;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

/* headings */
.sol-head{ margin-bottom: 1rem; }
.sol-h2{ margin: 0.55rem 0 0.5rem; letter-spacing: -0.02em; }
.sol-lead{ margin: 0; max-width: 86ch; color: var(--color-text-soft); line-height: 1.7; }

/* solution panels */
.sol-section{ margin-top: 1rem; }
.sol-panel{ padding: clamp(1.2rem, 2.2vw, 1.6rem); }

.sol-panel__head{
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 0.9rem;
}

.sol-icon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(15,23,42,.12);
  background: linear-gradient(135deg, rgba(94,203,255,.18), rgba(162,117,255,.12));
  box-shadow: 0 10px 22px rgba(15,23,42,.10);
  flex: 0 0 auto;
}

.sol-who{
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.6;
  font-size: var(--text-sm);
}

.sol-panel__grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.42fr);
  gap: 14px;
  align-items: start;
}

.sol-mini{
  margin: 0;
  padding-left: 1.1rem;
  color: var(--color-text-soft);
  line-height: 1.65;
  font-size: var(--text-sm);
}
.sol-mini li{ margin: 0.25rem 0; }

.sol-foot{
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.7;
  font-size: var(--text-sm);
}

/* outcomes aside */
.sol-outcomes{
  border-radius: var(--radius-xl);
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: var(--shadow-subtle);
  padding: 14px;
}

.sol-outcomes h4{
  margin: 0 0 0.5rem 0;
  font-size: var(--text-base);
}

.sol-outcomes__list{
  margin: 0;
  padding-left: 1.1rem;
  color: var(--color-text-soft);
  font-size: var(--text-sm);
  line-height: 1.65;
}
.sol-outcomes__list li{ margin: 0.25rem 0; }

/* split block in dept section */
.sol-split{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.sol-h4{
  margin: 0 0 0.4rem 0;
  font-size: var(--text-base);
}

/* fit check */
.sol-fit{ padding: clamp(1.4rem, 2.6vw, 2.1rem); }
.sol-check{
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
  display: grid;
  gap: 0.7rem;
  color: var(--color-text-soft);
  line-height: 1.6;
}
.sol-check__dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: .35rem;
  background: linear-gradient(90deg, var(--color-accent-blue), var(--color-accent-soft-blue));
  box-shadow: 0 0 14px rgba(159,179,255,.25);
  flex: 0 0 auto;
  display: inline-block;
  margin-right: 10px;
}

.sol-mini,
.sol-outcomes__list{
  line-height: 1.75;
}

.sol-mini li,
.sol-outcomes__list li{
  margin: 0.4rem 0;
}

.sol-who,
.sol-foot{
  line-height: 1.75;
}

.visual-card{ padding: 14px; box-shadow: var(--shadow-subtle); }
.visual-img{
  width: 100%;
  height: auto;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.75);
  display: block;
}
.visual-caption{
  margin: 0.75rem 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.6;
}

/* ===== Curtain-reveal band (image stays fixed; section reveals it) ===== */
.reveal-band{
  position: relative;
  height: clamp(260px, 44vw, 460px);
  margin-top: -24px;      /* tuck under hero */
  z-index: 0;
}

/* Fixed “poster” aligned to your container width */
.reveal-band__media{
  position: fixed;
  left: 50%;
  top: calc(var(--stack-top) + 12px);
  width: min(1120px, calc(100% - 2.75rem));
  height: clamp(260px, 44vw, 460px);

  transform: translateX(-50%) scale(0.985);
  border-radius: var(--radius-xl);
  /* border: 1px solid rgba(15,23,42,.10);
  box-shadow: var(--shadow-subtle); */
  border: none;
box-shadow: none;
  overflow: hidden;
  pointer-events: none;

  /* background:
    radial-gradient(circle at 15% 20%, rgba(94,203,255,.22), transparent 45%),
    radial-gradient(circle at 80% 30%, rgba(162,117,255,.18), transparent 48%),
    var(--band-image) center / cover no-repeat; */
    background-image: var(--band-image);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain; /* ✅ fits entire image */
      

  opacity: 0;
  clip-path: inset(100% 0 0 0 round var(--radius-xl)); /* starts hidden */
  transition: opacity 200ms ease, transform 260ms ease;
}

/* show only while band is in play */
.reveal-band.is-active .reveal-band__media{
  opacity: 1;
}

/* sections should sit above the band */
.section{ position: relative; z-index: 1; }

/* Force icon sizing (overrides earlier rules) */
.sol-panel .sol-icon{
    width: 52px !important;
    height: 52px !important;
    border-radius: 18px !important;
    font-size: 20px; /* for emoji icons */
  }  
  
/* responsive */
@media (max-width: 960px){
  .sol-hero__grid{ grid-template-columns: 1fr; }
  .sol-toc{ position: relative; top: auto; max-height: none; }
  .sol-panel__grid{ grid-template-columns: 1fr; }
  .sol-split{ grid-template-columns: 1fr; }
}
