/* ==========================================================================
   Squarely — Solutions: By Frameworks
   Figma node 437:1321 ("Solutions | By Frameworks")
   Loaded AFTER css/solutions.css (reuses .sol-hero, .sol-breadcrumb, buttons).
   ========================================================================== */

/* ---- Hero: single column (no glass cards / chips) ---- */
.sol-hero--simple { padding: 140px 0 96px; }
.sol-hero--simple .sol-hero__lines { width: 726px; max-width: 44%; opacity: 0.8; }
.sol-hero--simple .sol-hero__inner { display: block; }
.sol-hero--simple .sol-hero__title { max-width: 980px; }
.sol-hero--simple .sol-hero__text { max-width: 905px; margin-bottom: 32px; }

/* ==========================================================================
   Multi-framework mapping
   ========================================================================== */
.fw-map {
  background: var(--white);
  padding: 96px 0 60px;
}
.fw-map__grid {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 40px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 531px;
  gap: 56px;
  align-items: start;
}
.fw-eyebrow {
  margin: 0 0 14px;
  font-size: 20px;
  font-weight: 600;
  color: var(--green-600);
}
.fw-h2 {
  margin: 0 0 18px;
  font-size: 42px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--teal-900);
}
.fw-map__text {
  margin: 0 0 28px;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--teal-900);
  max-width: 950px;
}
.fw-pills {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.fw-pill {
  display: flex;
  align-items: center;
  min-height: 82px;
  padding: 16px 31px;
  background: var(--white);
  border: 1px solid var(--hairline);
  border-radius: 30px;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.35;
  color: var(--green-600);
}
.fw-pill--green  { border-color: #aada91; }
.fw-pill--blue   { border-color: #7ba8d9; }
.fw-pill--purple { border-color: #a68bd9; }
.fw-pill--orange { border-color: #f2a57a; }

.fw-map__media { display: flex; align-items: center; justify-content: center; }
.fw-map__media img { width: 100%; height: auto; }

/* ==========================================================================
   How Squarely helps — five stages
   ========================================================================== */
.fw-stages {
  max-width: var(--container);
  margin: 0 auto;
  padding: 40px 40px 96px;
}
.fw-stages__panel {
  position: relative;
  overflow: hidden;
  border-radius: 50px;
  background: #f8f6f1;
  background-image: radial-gradient(circle at 96% 4%, rgba(83, 188, 125, 0.22) 0%, rgba(83, 188, 125, 0) 46%);
  padding: 80px;
  display: grid;
  grid-template-columns: 569px minmax(0, 1fr);
  column-gap: 132px;
  row-gap: 48px;
  align-items: start;
}
.fw-stages__intro { position: sticky; top: 100px; }
.fw-stages__title {
  margin: 12px 0 18px;
  font-size: 42px;
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: -1.4px;
  color: var(--teal-900);
}
.fw-stages__text {
  margin: 0 0 28px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
  color: #3a5c5a;
}
.fw-stages__text strong { font-weight: 600; }
.fw-explore {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  padding: 14px 22px;
  border-radius: 100px;
  background: linear-gradient(90deg, #125e59 0%, #3fa285 100%);
  color: #fbf8f1;
  font-size: 14px;
  font-weight: 700;
}
.fw-explore svg { width: 14px; height: 14px; }
.fw-explore:hover { filter: brightness(1.06); }

.fw-stages__list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.fw-stage {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  column-gap: 8px;
  align-items: center;
  padding: 22px 30px;
  border-radius: 30px;
  box-shadow: inset 0 0 50px rgba(45, 130, 103, 0.05);
  color: inherit;
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.fw-stage:hover {
  transform: translateY(-3px);
  box-shadow: inset 0 0 50px rgba(45, 130, 103, 0.05), 0 14px 28px rgba(0, 71, 80, 0.12);
}
.fw-stage__label {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 1.6px;
  color: var(--teal-900);
}
.fw-stage__title {
  margin: 0 0 4px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--teal-900);
}
.fw-stage__desc {
  margin: 0;
  font-size: 13px;
  font-weight: 400;
  line-height: 1.4;
  color: #3a5c5a;
}
.fw-stage--plan    { background: var(--white); }
.fw-stage--gather  { background: #cfe2f3; }
.fw-stage--process { background: #e4daf5; }
.fw-stage--report  { background: #ffd9c2; }
.fw-stage--manage  { background: linear-gradient(90deg, #3fa285 0%, #125e59 100%); }
.fw-stage--manage .fw-stage__label { color: #f8f6f1; }
.fw-stage--manage .fw-stage__title,
.fw-stage--manage .fw-stage__desc  { color: var(--white); }

/* ==========================================================================
   CTA — see Squarely on your disclosure scope
   ========================================================================== */
.fw-cta {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 40px 100px;
}
.fw-cta__panel {
  position: relative;
  overflow: hidden;
  border-radius: 50px;
  background: #125e59;
  background-image: radial-gradient(circle at 85% 30%, rgba(45, 130, 103, 0.9) 0%, rgba(45, 130, 103, 0) 55%);
  padding: 80px;
  display: grid;
  grid-template-columns: 1fr 603px;
  gap: 60px;
  align-items: center;
  color: var(--white);
}
.fw-cta__title {
  margin: 0 0 20px;
  font-size: 48px;
  font-weight: 700;
  line-height: 1.2;
  max-width: 724px;
}
.fw-cta__text {
  margin: 0 0 32px;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.5;
  max-width: 697px;
}
.fw-cta__media { display: flex; align-items: center; justify-content: center; }
.fw-cta__media img { height: 300px; width: auto; max-width: 100%; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1100px) {
  .sol-hero--simple { padding: 110px 0 64px; }
  .sol-hero--simple .sol-hero__lines { max-width: 38%; opacity: 0.4; }

  .fw-h2, .fw-stages__title, .fw-cta__title { font-size: 34px; }

  .fw-map__grid { grid-template-columns: 1fr; gap: 40px; }
  .fw-map__media { order: -1; }

  .fw-stages__panel { grid-template-columns: 1fr; column-gap: 0; row-gap: 36px; padding: 56px 48px; }
  .fw-stages__intro { position: static; }

  .fw-cta__panel { grid-template-columns: 1fr; padding: 56px 48px; gap: 32px; }
  .fw-cta__media { justify-content: flex-start; }
  .fw-cta__media img { height: 200px; }
}

@media (max-width: 640px) {
  .sol-hero--simple { padding: 80px 0 48px; }
  .fw-h2, .fw-stages__title, .fw-cta__title { font-size: 28px; }

  .fw-map { padding: 64px 0 48px; }
  .fw-map__grid { padding-inline: 22px; }
  .fw-map__text { font-size: 16px; }
  .fw-pill { font-size: 16px; padding: 16px 22px; }

  .fw-stages { padding: 20px 22px 64px; }
  .fw-stages__panel { padding: 36px 22px; border-radius: 30px; }
  .fw-stage { grid-template-columns: 1fr; row-gap: 10px; padding: 20px 22px; }

  .fw-cta { padding: 0 22px 64px; }
  .fw-cta__panel { padding: 40px 24px; border-radius: 30px; }
  .fw-cta__text { font-size: 16px; }
  .fw-cta__media { display: none; } /* decorative mark — hide on mobile */
}
