@media screen and (min-width: 1280px) {
  /* Global ~6% shrink so single-block sections (hero, CTA band, phone band)
     fit a typical desktop viewport without cropping mid-title or mid-CTA.
     All rem-based measurements scale proportionally. */
  html {
    font-size: 15px;
  }

  :root {
    /* Bumped contentWidth (rem) to compensate so container ~1275px on cap */
    --contentWidth: min(100% - 8rem, 85rem);
    --headerHeight: 5.6rem;
  }

  br.tablet {
    display: none;
  }
.sectionHeadingContent {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding-top: 11vw!important;
}

  br.desktop {
    display: block;
  }

  /* HEADER */
  .headerMenuButton {
    display: none;
  }

  .headerInner {
    gap: 4.4rem;
    min-height: var(--headerHeight);
    padding-block: 0.9rem;
  }

  .siteLogo {
    width: 6.8rem;
  }

  .headerRightArea {
    position: static;
    inset: auto;
    flex: 1;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0;
    background: transparent;
    transform: none;
    visibility: visible;
    pointer-events: auto;
  }

  .globalNavList {
    flex-direction: row;
    align-items: center;
    gap: 1.75rem;
  }

  .globalNavLink {
    position: relative;
    min-height: auto;
    font-size: 0.9rem;
    font-weight: 700;
  }

  .globalNavLink::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -0.3rem;
    width: 100%;
    height: 0.125rem;
    background: var(--gradientSectionText);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform var(--transitionBase);
  }

  .globalNavLink:hover::after,
  .globalNavLink:focus-visible::after {
    transform: scaleX(1);
  }

  .globalNavLink:hover,
  .globalNavLink:focus-visible {
    color: var(--colorBlue);
  }

  /* Desktop dropdown: floating panel below the trigger */
  .globalNavSubmenu {
    display: block;
    position: absolute;
    top: 100%;
    left: 50%;
    min-width: 12rem;
    max-height: none;
    margin: 0;
    padding: 0.6rem 0;
    background: var(--colorWhite);
    border-radius: 0.9rem;
    box-shadow: 0 1.2rem 2.4rem rgba(55, 67, 82, 0.16);
    opacity: 0;
    visibility: hidden;
    overflow: visible;
    transform: translate(-50%, -0.3rem);
    transition: opacity var(--transitionBase), transform var(--transitionBase), visibility var(--transitionBase);
    z-index: 50;
  }

  .globalNavSubmenu::before {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 0.9rem;
  }

  .globalNavItemHasSubmenu {
    padding-bottom: 0.6rem;
    margin-bottom: -0.6rem;
  }

  .globalNavItemHasSubmenu:hover .globalNavSubmenu,
  .globalNavItemHasSubmenu:focus-within .globalNavSubmenu,
  .globalNavTrigger[aria-expanded="true"] + .globalNavSubmenu {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, 0.5rem);
  }

  .globalNavItemHasSubmenu:hover .globalNavArrow,
  .globalNavItemHasSubmenu:focus-within .globalNavArrow {
    transform: rotate(-135deg) translate(-0.12rem, -0.12rem);
  }

  .globalNavSubmenuItem {
    padding: 0;
  }

  .globalNavSubmenuLink {
    display: block;
    min-height: auto;
    padding: 0.55rem 1.2rem;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--colorTitleDark);
    white-space: nowrap;
    transition: background var(--transitionBase), color var(--transitionBase);
  }

  .globalNavSubmenuLink:hover,
  .globalNavSubmenuLink:focus-visible {
    background: rgba(126, 214, 167, 0.12);
    color: var(--colorBlue);
  }

  .headerContactArea {
    flex-direction: row;
    align-items: center;
    gap: 0.9rem;
  }

  .headerPhoneLink {
    align-items: flex-end;
  }

  .headerPhoneLabel {
    font-size: 0.72rem;
  }

  .headerPhoneNumber {
    font-size: 1.45rem;
    line-height: 1;
  }

  .headerPhoneNote {
    font-size: 0.68rem;
  }

  .headerCtaButton {
    min-width: 11.5rem;
    min-height: 2.6rem;
    padding-inline: 1.35rem;
    font-size: 1.5rem;
    margin-left: 2vw;
  }

  /* HERO SECTION */
  .heroSection {
    /* Section taller (was 32rem) so the stats banner can sit prominently
       at top, products show smaller, and the CTA gets pushed lower. */
    padding-block: 2rem 2.6rem;
    min-height: calc(32rem + 4vw);
  }

  /* Desktop bg is now Group4bg.png (clean wave) — cover-fill the section,
     no specific anchor needed since there's nothing to "expose". */
  .heroBackgroundImage {
    object-fit: cover;
    object-position: center center;
  }

  /* Product layer is the right column of the heroBody grid (59% / 41%). */
  .heroProductLayer {
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
  }
.sectionHeadingContent{
  padding-top: 5rem;
}
  .heroProductImage {
    display: block;
    width: 100%;
    max-width: 30rem;
    height: auto;
    filter: drop-shadow(0 1.6rem 2.4rem rgba(55, 67, 82, 0.18));
  }

  .heroContent {
    display: flex;
    flex-direction: column;
    /* More breathing room between stats / body / cta */
    gap: 2.6rem;
    min-height: 28rem;
    justify-content: flex-start;
  }

  /* Bigger banner-style pill stretching across the top-right */
  .heroStatsCard {
    align-self: flex-end;
    gap: 1rem 2rem;
    padding: 1rem 2rem;
    border-radius: 1.4rem;
    margin-right: 11rem;
    margin-bottom: 2rem;
    /* padding-top: 2rem; */
  }

  .heroStatsText {
    font-size: 1.6rem;
    line-height: 1.2;
  }

  .heroStatsText strong {
    font-size: 1.25em;
  }

  .heroBody {
    flex: 1;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 3rem;
    min-height: 0;
  }

  .heroCopyArea {
    flex: 0 1 36rem;
    max-width: 36rem;
    padding-top: 0;
    margin-left: 0;
  }

  .heroProductLayer {
    flex: 0 1 26rem;
    max-width: 26rem;
  }

  .heroTitle {
    gap: 0.7em;
    margin-bottom: 1.2rem;
  }

  .heroTitleLine {
    font-size: 3rem;
    line-height: 1;
    letter-spacing: -0.03em;
  }

  .heroDescription {
    font-size: 0.95rem;
    line-height: 1.7;
  }

  .heroCaution {
    margin-top: 0.55rem;
    font-size: 0.78rem;
    line-height: 1.55;
  }

  .heroVisualArea {
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 0.7rem;
    padding-top: 0;
    min-height: 26rem;
  }

  .heroMachineImageSmall {
    width: 11rem;
  }

  .heroMachineImageLarge {
    width: 16.8rem;
  }

  .heroCtaButton {
    align-self: center;
    width: 100%;
    max-width: 56rem;
    margin-top: 3.2rem;
    margin-bottom: 0.6rem;
    min-height: 4rem;
    padding: 0.7rem 1.4rem 0.6rem;
    border-radius: 1.2rem;
  }

  .heroCtaMain {
    font-size: 1.5rem;
    line-height: 1.2;
  }

  .heroCtaArrow {
    font-size: 1rem;
  }

  .heroCtaSub {
    font-size: 0.88rem;
    line-height: 1.45;
  }

  /* PROBLEM SECTION */
  .problemSection {
    padding-block: 3rem 4rem;
  }

  /* Global: bigger yellow label on desktop */
  .sectionHeadingWrap {
    padding-top: 9rem;
    margin-bottom: 2rem;
  }

  .sectionLabelWrap {
    width: 24rem;
    height: 9rem;
  }

  .sectionLabelBoxFront {
    top: 0;
    left: 0;
    width: 18rem;
    height: 7rem;
  }

  .sectionLabelBoxBack {
    top: 2rem;
    left: 3.2rem;
    width: 19rem;
    height: 7rem;
  }

  .sectionLabelText {
    font-size: 2.5rem;
  }

  .sectionTitle {
    font-size: 1.7rem;
    line-height: 1.3;
  }

  .problemIntro {
    margin-bottom: 2rem;
  }

  .problemIntroText {
    font-size: 0.98rem;
    line-height: 1.8;
  }

  .problemCardGrid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.2rem;
  }

  .problemCard {
    min-height: 16rem;
    padding: 1.4rem 1.25rem 1.5rem;
    border-radius: 1.6rem;
  }

  .problemCardNumber {
    font-size: 3rem;
  }

  .problemCardTitle {
    font-size: 1.2rem;
    margin-bottom: 0.7rem;
  }

  .problemCardText {
    font-size: 0.9rem;
    line-height: 1.7;
  }

  /* SOLUTION SECTION */
  .solutionSection {
    padding-block: 3.5rem 4.5rem;
  }

#gtnex .sectionHeadingWrapSolution {
  --solutionHeadingOffset: clamp(14rem, 17vw, 18rem);
  padding-top: 2rem;
  margin-bottom: 2.4rem;
  align-items: flex-start;
  text-align: left;
}

#gtnex .sectionLabelWrapSolution {
  position: absolute;
  top: 0;
  left: 0;
}

#gtnex .sectionHeadingContent {
  padding-top: 0 !important;
}

#gtnex .sectionHeadingContentSolution {
  width: min(56rem, calc(100% - var(--solutionHeadingOffset)));
  margin-left: var(--solutionHeadingOffset);
  padding-top: 1.5rem !important;
  padding-left: 0;
}

  #gtnex .sectionHeadingWrapSolution .sectionTitle {
    font-size: 1.75rem;
    line-height: 1.3;
  }

  .solutionLeadText {
    font-size: 0.92rem;
    line-height: 1.7;
  }

  .solutionArticleList {
    gap: 2.6rem;
  }

  .solutionArticle {
    position: relative;
    display: flex;
    gap: 0;
    align-content: center;
    flex-direction: row;
    align-items: center;
  }

  .solutionArticleReversed {
    flex-direction: row-reverse;
  }

  .solutionArticleMedia {
    position: relative;
    flex: 0 0 50%;
    max-width: 50%;
  }

  .solutionArticleImage {
    width: 100%;
    height: auto;
  }

  .solutionArticleBody {
    position: relative;
    flex: 0 0 53%;
    max-width: 53%;
    margin-left: -3%;
    margin-top: 0;
  }

  .solutionArticleReversed .solutionArticleBody {
    margin-left: 0;
    margin-right: -3%;
  }

  .solutionArticleTextBox {
    min-height: 0;
    padding: 3.75rem 3.8rem 3.8rem;
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(0.7rem);
    box-shadow: 0 1rem 2.4rem rgba(55, 67, 82, 0.1);
    border-radius: 0.4rem;
  }

  .solutionArticleTitle {
    margin-bottom: 0.9rem;
    font-size: 1.5rem;
    line-height: 1.5;
    font-weight: 600;
  }

  .solutionArticleTag {
    margin-bottom: 1rem;
    padding: 0.28rem 0.7rem;
    font-size: 0.82rem;
  }

  .solutionArticleText {
    font-size: 0.95rem;
    line-height: 1.7;
  }

  /* SOLUTION badge circles — sit at image/textbox boundary, ~19% down */
  .solutionArticleBadge {
    position: absolute;
    top: 15%;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 6rem;
    height: 6rem;
    right: -3rem;
    transform: translateY(-50%);
    border-radius: 50%;
    background: var(--gradientNumber);
    color: var(--colorWhite);
    font-family: var(--fontMincho);
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.02em;
    box-shadow:
      0 0.8rem 1.8rem rgba(72, 106, 130, 0.3),
      inset 0 0.0625rem 0 rgba(255, 255, 255, 0.4);
    background: linear-gradient(180deg, #486A82 0%, rgba(126, 214, 167, 0.95) 50%, #374352 100%);
    filter: drop-shadow(0 6px 16px rgba(55, 67, 82, 0.30));
  }

  .solutionArticleReversed .solutionArticleBadge {
    right: auto;
    left: -3rem;
  }

  /* VOICE SECTION */
  .voiceSection {
    padding-block: 3.8rem 4.8rem;
  }
  .sectionHeadingWrapVoice {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.8rem;
  }
  .sectionHeadingWrapVoice .sectionTitle {
    font-size: 2rem;
    line-height: 1.2;
  }

  .voiceCardGrid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
  }

  .voiceCard {
    padding: 1.8rem 1.6rem 1.6rem;
    border-radius: 2.4rem;
    min-height: 23rem;
  }

  .voiceCardNumber {
    font-size: 4.4rem;
    line-height: 1;
    margin-bottom: 0.3rem;
  }

  .voiceCardTitle {
    font-size: 1.3rem;
    margin-bottom: 0.8rem;
  }

  .voiceCardText {
    font-size: 0.95rem;
    line-height: 1.7;
  }

  .voiceCardAttribution {
    margin-top: 1.4rem;
    font-size: 0.95rem;
  }

  /* LINEUP */
  .lineupSection {
    padding-block: 4.2rem 5.4rem;
  }

  .sectionHeadingWrapLineup {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 3rem;
  }
  .sectionHeadingWrapLineup .sectionTitle {
    font-size: 2rem;
    line-height: 1.2;
  }

  .lineupCardGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2.2rem;
  }

  .lineupCard {
    padding: 2rem 2rem 2.2rem;
    border-radius: 2.4rem;
  }

  .lineupCardImageWrap {
    /* Center-align so both products share the same vertical anchor */
    align-items: center;
    min-height: 24rem;
    padding: 1.6rem 0 1.6rem;
  }

  /* Both images use the same display box so they align + appear equal in
     visual prominence. The squarer With 15 product fills width more,
     the tall With 5 fills height — but their bounding boxes are identical. */
  .lineupCardImage,
  .lineupCardImageLarge {
    width: auto;
    max-width: 90%;
    max-height: 21rem;
    object-fit: contain;
  }

  .lineupCardName {
    font-size: 2.6rem;
  }

  .lineupCardTag {
    font-size: 0.88rem;
    padding: 0.4rem 1rem;
  }

  .lineupCardPriceRow {
    gap: 1rem 2rem;
  }

  .lineupCardPriceItem {
    min-width: 11rem;
  }

  .lineupCardPriceValue {
    font-size: 2.2rem;
  }

  .lineupCardPriceValueSmall {
    font-size: 1.8rem;
  }

  .lineupCardPriceLabel {
    font-size: 0.88rem;
  }

  .lineupCardSpecRow {
    grid-template-columns: 10rem 1fr;
    padding-block: 0.35rem;
  }

  .lineupCardSpecLabel,
  .lineupCardSpecValue {
    font-size: 0.88rem;
  }

  /* FAQ */
  .faqSection {
    padding-block: 4rem 5.2rem;
  }

  .sectionHeadingWrapFaq {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.8rem;
  }
  .sectionHeadingWrapFaq .sectionTitle {
    font-size: 2rem;
  }

  .faqList {
    max-width: 56rem;
    margin-inline: auto;
    gap: 1rem;
  }

  .faqQuestion {
    padding: 1.15rem 1.6rem;
    font-size: 0.98rem;
  }

  .faqAnswerInner {
    padding: 0 1.6rem 1.4rem 1.6rem;
  }

  .faqQuestion[aria-expanded="true"] + .faqAnswer .faqAnswerInner {
    padding-top: 1.15rem;
  }

  .faqAnswerText {
    font-size: 0.92rem;
  }

  /* AREA */
  .areaSection {
    padding-block: 4rem 5rem;
  }

  .sectionHeadingWrapArea {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2rem;
  }
  .sectionHeadingWrapArea .sectionTitle {
    font-size: 2.1rem;
  }

  .areaGroup {
    margin-bottom: 1.6rem;
  }

  .areaGroupTitle {
    font-size: 1rem;
    margin-bottom: 0.9rem;
  }

  .areaPillList {
    gap: 0.6rem 0.9rem;
  }

  .areaPill {
    padding: 0.5rem 1.3rem;
    font-size: 0.9rem;
  }

  .areaNote {
    font-size: 0.85rem;
    margin-top: 1.5rem;
  }

  /* BLOG */
  .blogSection {
    padding-block: 4rem 5rem;
  }

  .sectionHeadingWrapBlog {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.4rem;
  }
  .sectionHeadingWrapBlog .sectionTitle {
    font-size: 2rem;
  }

  .blogList {
    gap: 1.1rem;
  }

  .blogItemLink {
    grid-template-columns: 10rem 1fr auto;
    gap: 1.8rem;
    padding: 1.2rem 1.6rem;
  }

  .blogItemTitle {
    font-size: 1.08rem;
  }

  .blogItemExcerpt {
    font-size: 0.85rem;
  }

  /* CTA BAND */
  .ctaBand {
    padding-block: 3.6rem 4rem;
  }

  .ctaBandTitle {
    font-size: 2.4rem;
  }

  .ctaBandLead {
    font-size: 1rem;
  }

  .ctaBandPrimary {
    padding: 1.15rem 3rem;
    font-size: 1.15rem;
  }

  .ctaBandPhoneNumber {
    font-size: 2.8rem;
  }

  /* RELATED */
  .relatedSection {
    padding-block: 4.2rem 5.2rem;
  }

  .sectionHeadingWrapRelated {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.4rem;
  }
  .sectionHeadingWrapRelated .sectionTitle {
    font-size: 2rem;
  }

  .relatedCardGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2.4rem;
  }

  .relatedCardImageWrap {
    aspect-ratio: 16 / 9;
  }

  .relatedCardBody {
    padding: 1.6rem 1.8rem 1.8rem;
  }

  .relatedCardTitle {
    font-size: 1.5rem;
  }

  /* FOOTER */
  .siteFooter {
    padding-block: 3rem 2rem;
  }

  .siteFooterInner {
    gap: 1.6rem;
  }

  .siteFooterNavList {
    gap: 0.6rem 2.8rem;
  }

  .siteFooterLink {
    font-size: 0.85rem;
  }

  /* CATCHER PAGE — DESKTOP */
  .catcherHero {
    padding-block: 2rem 2.6rem;
    min-height: 32rem;
  }

  .catcherHeroContent {
    gap: 1.2rem;
    min-height: 26rem;
    justify-content: center;
  }

  .catcherHeroStats {
    align-self: flex-end;
    gap: 1.4rem 1.8rem;
    padding: 0.8rem 1.4rem;
    margin-right: 1.5rem;
  }

  .catcherHeroStatValue {
    font-size: 1.8rem;
  }

  .catcherHeroBody {
    flex: 1;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 3rem;
    min-height: 0;
  }

  .catcherHeroCopy {
    flex: 0 1 36rem;
    max-width: 36rem;
  }

  .catcherHeroVisual {
    flex: 0 1 26rem;
    max-width: 26rem;
  }

  .catcherHeroTitleLine {
    font-size: 3.5rem;
    line-height: 1.05;
  }

  .catcherHeroDescription {
    font-size: 0.95rem;
    line-height: 1.7;
  }

  .catcherHeroCaution {
    font-size: 0.8rem;
  }

  .catcherHeroProduct {
    max-width: 100%;
    width: 30rem;
  }

  .catcherHeroCta {
    align-self: center;
    width: 100%;
    max-width: 72rem;
    margin-top: 1.6rem;
    margin-bottom: 0.6rem;
    min-height: 4rem;
    padding: 0.7rem 1.2rem 0.6rem;
    border-radius: 1.2rem;
  }

  .catcherHeroCtaMain {
    font-size: 1.5rem;
    line-height: 1.2;
  }

  .catcherHeroCtaSub {
    font-size: 0.88rem;
  }

  .catcherSolution {
    padding-block: 3.5rem 4.5rem;
  }

  .catcherSolutionCard {
    grid-template-columns: 6rem 1fr 18rem;
    gap: 1.5rem 2rem;
    padding: 1.6rem 2rem;
  }

  .catcherSolutionNumber {
    width: 5rem;
    height: 5rem;
    font-size: 2.1rem;
  }

  .catcherSolutionTitle {
    font-size: 1.5rem;
  }

  .catcherLineup {
    padding-block: 3.5rem 4.5rem;
  }

  .catcherLineupCard {
    grid-template-columns: 44% 1fr;
    gap: 2.4rem;
    padding: 2.2rem 2.4rem;
    border-radius: 2rem;
    max-width: 66rem;
    margin-inline: auto;
  }

  .catcherLineupName {
    font-size: 2.4rem;
  }

  .catcherLineupPriceValue {
    font-size: 2rem;
  }

  .catcherUsage {
    padding-block: 3.5rem 4.5rem;
  }

  .sectionHeadingWrapCatcherUsage {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.4rem;
  }
  .sectionHeadingWrapCatcherUsage .sectionTitle {
    font-size: 2rem;
  }

  .catcherUsageList {
    max-width: 64rem;
    margin-inline: auto;
  }

  .catcherFlow {
    padding-block: 3.5rem 4.5rem;
  }

  .sectionHeadingWrapCatcherFlow {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.6rem;
  }
  .sectionHeadingWrapCatcherFlow .sectionTitle {
    font-size: 2rem;
  }

  .catcherFlowList {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 2rem;
    max-width: 64rem;
    margin-inline: auto;
  }

  .catcherFlowStep {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    text-align: center;
    padding: 2rem 1.6rem 2rem;
  }

  .catcherFlowStepLabel,
  .catcherFlowStepNumber,
  .catcherFlowStepTitle,
  .catcherFlowStepText {
    grid-column: 1 / 2;
    text-align: center;
  }

  .catcherFlowStepLabel {
    grid-row: 1 / 2;
    justify-self: center;
    align-self: auto;
  }

  .catcherFlowStepNumber {
    grid-row: 2 / 3;
    font-size: 3.4rem;
    justify-self: center;
    align-self: auto;
  }

  .catcherFlowStepTitle {
    grid-row: 3 / 4;
    font-size: 1.2rem;
    margin-top: 0.4rem;
    align-self: auto;
  }

  .catcherFlowStepText {
    grid-row: 4 / 5;
    font-size: 0.9rem;
    line-height: 1.7;
    margin-top: 0.6rem;
  }

  .catcherFlowStep[data-reveal]:nth-child(2).isRevealed { transition-delay: 0.08s; }
  .catcherFlowStep[data-reveal]:nth-child(3).isRevealed { transition-delay: 0.16s; }

  /* Chevron arrows between flow steps (desktop layout, horizontal row) */
  .catcherFlowStep:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -1.4rem;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0.6rem 0 0.6rem 0.85rem;
    border-color: transparent transparent transparent #ff8a5b;
    pointer-events: none;
  }

  .catcherPage .problemSection .sectionTitle {
    font-size: 1.75rem;
  }

  /* ============================================================ */
  /* INDEX FLOW — DESKTOP (5 cards horizontal with chevrons)      */
  /* ============================================================ */
  .indexFlow {
    padding-block: 3.5rem 4.5rem;
  }

  .indexFlowLead {
    font-size: 1.05rem;
    margin-top: 0.8rem;
  }

  .indexFlowList {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.1rem;
    margin-top: 2.2rem;
  }

  .indexFlowStep {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto auto;
    text-align: center;
    padding: 2.2rem 1.1rem 1.6rem;
  }

  .indexFlowStepLabel,
  .indexFlowStepNumber,
  .indexFlowStepTitle,
  .indexFlowStepText {
    grid-column: 1 / 2;
    text-align: center;
  }

  .indexFlowStepLabel {
    grid-row: 1 / 2;
    justify-self: center;
    align-self: auto;
    font-size: 0.7rem;
  }

  .indexFlowStepNumber {
    position: relative;
    grid-row: 2 / 3;
    font-size: 3rem;
    justify-self: center;
    align-self: auto;
    padding-bottom: 0.7rem;
  }

  /* Gold divider line under the number */
  .indexFlowStepNumber::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 2.6rem;
    height: 0.125rem;
    background: #d6c17e;
    pointer-events: none;
  }

  .indexFlowStepTitle {
    grid-row: 3 / 4;
    font-size: 1rem;
    margin-top: 0.5rem;
    align-self: auto;
  }

  .indexFlowStepText {
    grid-row: 4 / 5;
    font-size: 0.82rem;
    line-height: 1.7;
    margin-top: 0.5rem;
  }

  .indexFlowStep[data-reveal]:nth-child(2).isRevealed { transition-delay: 0.06s; }
  .indexFlowStep[data-reveal]:nth-child(3).isRevealed { transition-delay: 0.12s; }
  .indexFlowStep[data-reveal]:nth-child(4).isRevealed { transition-delay: 0.18s; }
  .indexFlowStep[data-reveal]:nth-child(5).isRevealed { transition-delay: 0.24s; }

  /* Chevron arrows between flow steps */
  .indexFlowStep:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -0.85rem;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0.55rem 0 0.55rem 0.78rem;
    border-color: transparent transparent transparent #486a82;
    pointer-events: none;
    z-index: 2;
  }

  /* GT-NEX PAGE — DESKTOP */
  .gtnexHero {
    padding-block: 2rem 2.6rem;
    min-height: 32rem;
  }

  .gtnexHeroContent {
    gap: 1.2rem;
    min-height: 26rem;
    justify-content: center;
  }

  .gtnexHeroStats {
    align-self: flex-end;
    gap: 1.4rem 1.8rem;
    padding: 0.8rem 1.4rem;
    margin-right: 1.5rem;
  }

  .gtnexHeroStatValue {
    font-size: 2rem;
  }

  .gtnexHeroBody {
    flex: 1;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 3rem;
    min-height: 0;
  }

  .gtnexHeroCopy {
    flex: 0 1 36rem;
    max-width: 36rem;
  }

  .gtnexHeroVisual {
    flex: 0 1 26rem;
    max-width: 26rem;
  }

  .gtnexHeroTitleLine {
    font-size: 3.2rem;
    line-height: 1.2;
  }

  .gtnexHeroDescription {
    font-size: 0.95rem;
    line-height: 1.7;
  }

  .gtnexHeroCaution {
    font-size: 0.8rem;
  }

  .gtnexHeroProduct {
    max-width: 100%;
    width: 30rem;
  }

  .gtnexHeroCta {
    align-self: center;
    width: 100%;
    max-width: 72rem;
    margin-top: 1.6rem;
    margin-bottom: 0.6rem;
    min-height: 4rem;
    padding: 0.7rem 1.2rem 0.6rem;
    border-radius: 1.2rem;
  }

  .gtnexHeroCtaMain {
    font-size: 1.4rem;
    line-height: 1.2;
  }

  .gtnexHeroCtaSub {
    font-size: 0.88rem;
  }

  /* SOLUTION */
  .gtnexSolution {
    padding-block: 3.5rem 4.5rem;
  }

  .sectionHeadingWrapGtnexSolution {
    margin-bottom: 2.4rem;
  }

  .sectionHeadingWrapGtnexSolution .sectionTitle {
    font-size: 1.85rem;
    line-height: 1.3;
  }

  .gtnexSolutionGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.6rem;
  }

  .gtnexSolutionCard {
    padding: 2rem 2rem 2rem;
    border-radius: 0.8rem;
    grid-template-columns: 5rem 1fr;
    gap: 0.4rem 1.4rem;
  }

  .gtnexSolutionNumber {
    font-size: 3.8rem;
  }

  .gtnexSolutionTitle {
    font-size: 1.4rem;
  }

  .gtnexSolutionText {
    font-size: 0.95rem;
  }

  /* COST */
  .gtnexCost {
    padding-block: 3.5rem 4.5rem;
  }

  .sectionHeadingWrapGtnexCost {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.4rem;
  }
  .sectionHeadingWrapGtnexCost .sectionTitle {
    font-size: 1.9rem;
  }

  .gtnexCostTable {
    min-width: 0;
  }

  .gtnexCostTable thead th,
  .gtnexCostTable tbody th,
  .gtnexCostTable tbody td {
    padding: 1.2rem 1.6rem;
  }

  .gtnexCostBreakdown {
    padding: 1.8rem 2rem 2rem;
    max-width: 60rem;
    margin-inline: auto;
  }

  /* LINEUP */
  .gtnexLineup {
    padding-block: 3.5rem 4.5rem;
  }

  .sectionHeadingWrapGtnexLineup {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.4rem;
  }
  .sectionHeadingWrapGtnexLineup .sectionTitle {
    font-size: 1.9rem;
  }

  .gtnexLineupCard {
    grid-template-columns: 42% 1fr;
    gap: 2.4rem;
    padding: 2.2rem 2.4rem;
    max-width: 66rem;
    margin-inline: auto;
    border-radius: 1.8rem;
  }

  .gtnexLineupImage {
    max-height: 20rem;
  }

  .gtnexLineupHeading {
    font-size: 1.45rem;
  }

  .gtnexLineupSpecPrice {
    font-size: 1.6rem;
  }

  /* FLOW */
  .gtnexFlow {
    padding-block: 3.5rem 4.5rem;
  }

  .sectionHeadingWrapGtnexFlow {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 2.6rem;
  }
  .sectionHeadingWrapGtnexFlow .sectionTitle {
    font-size: 1.9rem;
  }

  .gtnexFlowList {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.1rem;
  }

  .gtnexFlowStep {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    text-align: center;
    padding: 1.4rem 1.2rem;
  }

  .gtnexFlowStepLabel,
  .gtnexFlowStepNumber,
  .gtnexFlowStepTitle,
  .gtnexFlowStepText {
    grid-column: 1 / 2;
    text-align: center;
  }

  .gtnexFlowStepLabel {
    grid-row: 1 / 2;
    justify-self: center;
    align-self: auto;
  }

  .gtnexFlowStepNumber {
    grid-row: 2 / 3;
    font-size: 3rem;
    justify-self: center;
    align-self: auto;
  }

  .gtnexFlowStepTitle {
    grid-row: 3 / 4;
    font-size: 1.15rem;
    margin-top: 0.3rem;
    align-self: auto;
  }

  .gtnexFlowStepText {
    grid-row: 4 / 5;
    font-size: 0.88rem;
    line-height: 1.55;
  }

  .gtnexFlowStep[data-reveal]:nth-child(2).isRevealed { transition-delay: 0.08s; }
  .gtnexFlowStep[data-reveal]:nth-child(3).isRevealed { transition-delay: 0.16s; }
  .gtnexFlowStep[data-reveal]:nth-child(4).isRevealed { transition-delay: 0.24s; }

  /* Chevron arrows between flow steps (desktop layout, horizontal row) */
  .gtnexFlowStep:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -0.85rem;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0.55rem 0 0.55rem 0.78rem;
    border-color: transparent transparent transparent #8b2635;
    pointer-events: none;
  }

  /* PROBLEM heading — gtnex */
  .gtnexPage .problemSection .sectionTitle {
    font-size: 1.7rem;
  }

  /* PRICING PAGE — DESKTOP */
  .pricingHero {
    padding-block: 2rem 2.4rem;
  }

  .pricingHeroTitle {
    margin-top: 1.2rem;
    font-size: 3.2rem;
  }

  .pricingHeroLead {
    font-size: 1rem;
    margin-top: 1rem;
  }

  .pricingSection {
    padding-block: 3.2rem 4.2rem;
  }

  .pricingSectionEyebrow {
    font-size: 0.9rem;
  }

  .pricingSectionTitle {
    font-size: 2.3rem;
    margin-bottom: 0.6rem;
  }

  .pricingSectionLead {
    font-size: 0.95rem;
    margin-bottom: 2rem;
  }

  .pricingBlock {
    margin-bottom: 2.8rem;
  }

  .pricingBlockTitle {
    font-size: 1.35rem;
    margin-bottom: 1rem;
  }

  .pricingCallout {
    font-size: 1.1rem;
    margin: 2.4rem 0 1.8rem;
  }

  .pricingTable {
    min-width: 0;
    font-size: 0.92rem;
  }

  .pricingTable thead th {
    padding: 1rem 1.2rem;
    font-size: 0.85rem;
  }

  .pricingTable tbody th,
  .pricingTable tbody td {
    padding: 1rem 1.2rem;
  }

  .pricingAmount {
    font-size: 1.02rem;
  }

  .pricingAmountTotal {
    font-size: 1.15rem;
  }

  .pricingTable tbody tr.pricingSubtotal th {
    font-size: 1rem;
  }

  .pricingTable tbody tr.pricingSubtotal .pricingAmountTotal {
    font-size: 1.35rem;
  }

  .pricingIndustryTable tbody th.pricingIndustryName {
    font-size: 1rem;
    padding: 1.2rem 1rem;
    min-width: 8rem;
  }

  .pricingIndustryTable td.pricingIndustryTotal {
    font-size: 1.55rem;
    padding: 1.2rem 1rem;
    min-width: 8rem;
  }

  /* ABOUT PAGE — DESKTOP */
  .aboutHero {
    padding-block: 2.2rem 3rem;
    min-height: 22rem;
    display: flex;
    align-items: center;
  }

  .aboutHeroInner {
    width: 100%;
    gap: 0.8rem;
  }

  .aboutHeroTitle {
    font-size: 2.8rem;
    margin-top: 1.2rem;
  }

  .aboutHeroOrnament::before,
  .aboutHeroOrnament::after {
    width: 4rem;
  }

  .aboutHeroLead {
    font-size: 0.95rem;
    max-width: 44rem;
    margin-top: 0.6rem;
  }

  .aboutSection {
    padding-block: 4.4rem 5rem;
  }

  .aboutSectionHeading {
    gap: 0.5rem;
    margin-bottom: 2.4rem;
  }

  .aboutSectionEyebrow {
    font-size: 0.85rem;
  }

  .aboutSectionTitle {
    font-size: 2.1rem;
  }

  .aboutSectionLead {
    font-size: 0.95rem;
    margin-top: 0.3rem;
  }

  .aboutInfoTable {
    max-width: 60rem;
    margin-inline: auto;
  }

  .aboutInfoRow {
    grid-template-columns: 12rem 1fr;
    gap: 0.4rem 2.4rem;
    padding-block: 1.2rem;
  }

  .aboutInfoLabel {
    font-size: 0.95rem;
  }

  .aboutInfoValue {
    font-size: 1rem;
  }

  .aboutProductGrid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.8rem;
  }

  .aboutProductBody {
    padding: 1.4rem 1.5rem 1.6rem;
  }

  .aboutProductTitle {
    font-size: 1.35rem;
  }

  .aboutProductText {
    font-size: 0.92rem;
  }

  /* SERVICE AREA — DESKTOP */
  .serviceAreaSection {
    padding-block: 3.4rem 4.6rem;
  }

  .serviceAreaSection .areaGroupTitle {
    font-size: 1.45rem;
    margin-bottom: 1.4rem;
  }

  .serviceAreaSection .areaPill {
    font-size: 1rem;
    padding: 0.6rem 1.5rem;
  }

  .areaPillMore {
    font-size: 1rem;
    padding: 0.6rem 0.6rem;
  }

  .areaNoteBox {
    margin-top: 3rem;
    padding: 1.4rem 1.8rem 1.6rem;
  }

  .areaNoteBoxLabel {
    font-size: 0.78rem;
  }

  .areaNoteBoxText {
    font-size: 0.9rem;
  }

  /* NEWS ARTICLE — DESKTOP */
  .newsArticleHero {
    padding-block: 3rem 3.4rem;
    min-height: 24rem;
    display: flex;
    align-items: center;
  }

  .newsArticleHeroInner {
    width: 100%;
    gap: 0.8rem;
  }

  .newsArticleTitle {
    font-size: 2.4rem;
    margin-top: 0.8rem;
  }

  .newsArticleOrnament::before,
  .newsArticleOrnament::after {
    width: 4rem;
  }

  .newsArticleLead {
    font-size: 1rem;
    max-width: 50rem;
  }

  .newsArticleBody {
    padding-block: 3.4rem 4rem;
  }

  .newsArticleBodyInner {
    max-width: 60rem;
    margin-inline: auto;
  }

  .newsArticleIntro {
    font-size: 1.05rem;
  }

  .newsArticleParagraph {
    font-size: 1rem;
  }

  .newsArticleSectionTitle {
    font-size: 1.5rem;
  }

  .newsArticleSection {
    margin-top: 3rem;
  }

  .newsArticleList li {
    font-size: 1rem;
  }

  .newsArticleFooter {
    margin-top: 3.2rem;
  }

  /* NEWS LIST — DESKTOP */
  .newsListHero {
    padding-block: 2.8rem 3rem;
    min-height: 22rem;
    display: flex;
    align-items: center;
  }

  .newsListHeroInner {
    width: 100%;
    gap: 0.6rem;
  }

  .newsListHeroEyebrow {
    font-size: 0.92rem;
  }

  .newsListHeroTitle {
    font-size: 2.8rem;
    margin-top: 0.6rem;
  }

  .newsListHeroLead {
    font-size: 1rem;
    max-width: 50rem;
  }

  .newsListSection {
    padding-block: 3.2rem 4rem;
  }

  .newsFilterTabs {
    gap: 0.8rem;
    margin-bottom: 2.4rem;
  }

  .newsFilterTab {
    padding: 0.7rem 1.6rem;
    font-size: 0.95rem;
  }

  /* FAQ PAGE — DESKTOP */
  .faqPageSection {
    padding-block: 4rem 5rem;
  }

  .faqGroup {
    margin-bottom: 3.2rem;
  }

  .faqGroupTitle {
    font-size: 1.65rem;
    margin-bottom: 1.4rem;
    gap: 1.2rem;
  }

  .faqGroupTitleBar {
    width: 3rem;
  }

  /* CONTACT PAGE — DESKTOP */
  .contactProductSection {
    padding-block: 3.4rem 3.8rem;
  }

  .contactSectionHeading {
    margin-bottom: 2.4rem;
  }

  .contactSectionEyebrow {
    font-size: 0.85rem;
  }

  .contactSectionTitle {
    font-size: 2rem;
  }

  .contactSectionLead {
    font-size: 0.95rem;
  }

  .contactProductGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.8rem;
    max-width: 70rem;
    margin-inline: auto;
  }

  .contactProductCard {
    padding: 1.8rem 1.8rem 2rem;
  }

  .contactProductCardWide {
    grid-column: 1 / -1;
  }

  .contactProductCardWide .contactProductCardWideBody {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
  }

  .contactProductCardWide .contactProductCardWideBody > div {
    flex: 1;
  }

  .contactProductCardWide .contactProductCardButton {
    flex-shrink: 0;
    align-self: center;
  }

  .contactProductCardName {
    font-size: 1.85rem;
  }

  .contactFormSection {
    padding-block: 3.4rem 4rem;
  }

  .contactForm {
    max-width: 64rem;
    padding: 2.6rem 2.6rem 2.8rem;
  }

  .contactFormGrid {
    gap: 1.5rem 2rem;
  }

  .contactFieldInput {
    padding: 0.95rem 1.1rem;
    font-size: 1rem;
  }

  .contactFormSubmit {
    padding: 1.1rem 3rem;
    font-size: 1.1rem;
  }

  .contactPhoneBand {
    padding-block: 3rem 3.4rem;
  }

  .contactPhoneTitle {
    font-size: 2rem;
  }

  .contactPhoneNumber {
    font-size: 3.4rem;
  }

  /* TRIAL / APPLICATION FORM PAGES — DESKTOP */
  .trialHero {
    padding-block: 2.4rem 3rem;
    min-height: 20rem;
    display: flex;
    align-items: center;
  }

  .trialHeroInner {
    width: 100%;
    gap: 0.8rem;
  }

  .trialHeroBadge {
    font-size: 0.95rem;
    padding: 0.55rem 1.6rem;
  }

  .trialHeroTitle {
    font-size: 2.6rem;
    margin-top: 0.8rem;
  }

  .trialFormSection {
    padding-block: 3.4rem 4rem;
  }

  .trialFormHeading {
    gap: 0.5rem;
    margin-bottom: 2.4rem;
  }

  .trialFormEyebrow {
    font-size: 0.85rem;
  }

  .trialFormTitle {
    font-size: 2rem;
  }

  .trialFormLead {
    font-size: 0.95rem;
    margin-top: 0.4rem;
  }

  /* PRIVACY PAGE — DESKTOP */
  .policySection {
    padding-block: 3.4rem 4.2rem;
  }

  .policyIntro {
    padding: 1.8rem 2rem;
    font-size: 1rem;
    margin-bottom: 2.6rem;
  }

  .policyList {
    gap: 1.2rem;
  }

  .policyItem {
    padding: 1.8rem 2rem 2rem;
  }

  .policyItemNumber {
    width: 2.8rem;
    height: 2.8rem;
    font-size: 1.05rem;
    margin-bottom: 0.8rem;
  }

  .policyItemTitle {
    font-size: 1.35rem;
    padding-bottom: 0.85rem;
    margin-bottom: 0.85rem;
  }

  .policyItemText {
    font-size: 0.95rem;
  }

  .policyBulletList li {
    font-size: 0.95rem;
  }

  .policyContactCard {
    padding: 1.4rem 1.6rem;
  }

  .policyContactRow {
    grid-template-columns: 9rem 1fr;
    gap: 0.2rem 1.4rem;
  }

  .policyContactRow dt {
    font-size: 0.85rem;
  }

  .policyContactRow dd {
    font-size: 0.95rem;
  }

  .policyEffective {
    margin-top: 2.6rem;
    padding: 1.4rem 1.4rem;
  }

  .policyEffectiveLabel {
    font-size: 0.85rem;
  }

  .policyEffectiveDate {
    font-size: 1.05rem;
  }
}
