/* input(19,92): run-time error CSS1019: Unexpected token, found ' '
input(19,92): run-time error CSS1019: Unexpected token, found ' '
input(19,92): run-time error CSS1042: Expected function, found ' '
input(19,92): run-time error CSS1062: Expected semicolon or closing curly-brace, found ' '
input(73,98): run-time error CSS1019: Unexpected token, found ' '
input(73,98): run-time error CSS1019: Unexpected token, found ' '
input(73,98): run-time error CSS1042: Expected function, found ' '
input(73,98): run-time error CSS1062: Expected semicolon or closing curly-brace, found ' '
input(88,100): run-time error CSS1019: Unexpected token, found ' '
input(88,100): run-time error CSS1019: Unexpected token, found ' '
input(88,100): run-time error CSS1042: Expected function, found ' '
input(88,100): run-time error CSS1062: Expected semicolon or closing curly-brace, found ' ' */
/* === internal-page.css ===
   Shared layout for internal "scale model" pages (ArchModels).
   Sections: hero, subnav, alternating blocks, examples slider.
   ------------------------------------------------------------ */

/* -----------------------------------------------
   Internal Hero
   ----------------------------------------------- */
.ip-hero { display: flex; flex-direction: column; gap: 2rem; padding-block: 1.5rem 0; }

.ip-hero__image { width: 100%; overflow: hidden; }

.ip-hero__image img { display: block; width: 100%; height: auto; object-fit: cover; }

.ip-hero__body { display: flex; flex-direction: column; gap: 1.25rem; }

.ip-hero__label { margin: 0; font-family: var(--font-heading); font-size: 1rem; font-weight: 500; letter-spacing: -0.03em; text-transform: uppercase; color: var(--color-black); }

.ip-hero__title { margin: 0; font-family: var(--font-heading); font-size: clamp(2rem, 4vw + 0.5rem, 3.875rem); font-weight: 400; line-height: 1.065; letter-spacing: -0.03em; color: var(--color-black); }

.ip-hero__title-light { color: var(--color-gray); }

.ip-hero__intro { display: flex; flex-direction: column; gap: 0.5rem; }

.ip-hero__lead { margin: 0; font-family: var(--font-heading); font-size: 1.125rem; font-weight: 600; line-height: 1.5; letter-spacing: -0.03em; color: var(--color-black); }

.ip-hero__desc { margin: 0; font-family: var(--font-heading); font-size: 1rem; font-weight: 400; line-height: 1.667; letter-spacing: -0.03em; color: var(--color-black); }

.ip-hero__cta { display: inline-flex; align-items: center; justify-content: center; padding: 0.875rem 1.5rem; border: 1px solid var(--color-black); border-radius: 0; background: transparent; font-family: var(--font-nav); font-size: var(--text-body-lg); font-weight: 400; line-height: 1; color: var(--color-black); text-decoration: none; transition: background-color var(--transition-fast), color var(--transition-fast); width: fit-content; }

.ip-hero__cta:hover { background-color: var(--color-black); color: var(--color-white); }

/* -----------------------------------------------
   Subnav
   ----------------------------------------------- */
.subnav { padding-block: 4rem; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }

.subnav::-webkit-scrollbar { display: none; }

.subnav ul { display: flex; align-items: center; gap: 0.5rem; list-style: none; margin: 0; padding: 0; white-space: nowrap; }

.subnav li { flex: 0 0 auto; }

.subnav a { display: inline-block; padding: 0.9375rem 1.5rem; border: 2px solid transparent; border-radius: 5.1875rem; font-family: var(--font-heading); font-size: 1rem; font-weight: 500; line-height: 1; letter-spacing: -0.03em; color: rgba(0, 0, 0, 0.49); text-decoration: none; transition: color var(--transition-fast), border-color var(--transition-fast); }

.subnav a:hover { color: var(--color-black); }

.subnav a.active,
.subnav li.active a { color: var(--color-black); border-color: var(--color-black); padding: 0.9375rem 1.5rem; }

/* -----------------------------------------------
   Hero Divider
   ----------------------------------------------- */
.ip-divider { border: none; border-top: 1px solid var(--color-black); margin: 0; margin-top: 60px; }

/* -----------------------------------------------
   Alternating Content Blocks
   ----------------------------------------------- */
.ip-blocks { display: flex; flex-direction: column; gap: 4rem; padding-block: 2rem 3rem; }

.ip-block { display: flex; flex-direction: column; gap: 2rem; }

.ip-block__image { width: 100%; overflow: hidden; }

.ip-block__image img { display: block; width: 100%; height: auto; object-fit: cover; }

.ip-block__image .lightbox { display: block; cursor: zoom-in; }

.ip-block__text { display: flex; flex-direction: column; gap: 1rem; }

.ip-block__rule { display: block; width: 10rem; height: 4px; background-color: var(--color-black); }

.ip-block__title { margin: 0; font-family: var(--font-heading); font-size: clamp(1.75rem, 2.5vw + 0.5rem, 2.75rem); font-weight: 500; line-height: 1.1; letter-spacing: -0.03em; color: var(--color-black); }

.ip-block__desc { margin: 0; font-family: var(--font-heading); font-size: 1rem; font-weight: 400; line-height: 1.722; letter-spacing: -0.03em; color: var(--color-black); }

/* -----------------------------------------------
   Examples Slider
   ----------------------------------------------- */
.ip-examples { padding: 3rem 0; background-color: var(--color-gray-mid); overflow: hidden; }

.ip-examples__header { display: flex; flex-direction: column; gap: 0.75rem; margin-bottom: 1.5rem; }

.ip-examples__rule { display: block; width: 13.625rem; height: 4px; background-color: var(--color-black); }

.ip-examples__title-row { display: flex; align-items: center; justify-content: space-between; }

.ip-examples__title { margin: 0; font-family: var(--font-heading); font-size: clamp(1.5rem, 2.5vw + 0.5rem, 2.75rem); font-weight: 500; letter-spacing: -0.03em; color: var(--color-black); }

.ip-examples__nav { display: flex; gap: 0.3125rem; }

.ip-examples__nav-btn { display: flex; align-items: center; justify-content: center; width: 3.1875rem; height: 3.1875rem; padding: 0; border: none; border-radius: 50%; color: var(--color-white); cursor: pointer; touch-action: manipulation; -webkit-tap-highlight-color: transparent; transition: opacity var(--transition-fast); }

.ip-examples__nav-btn:hover:not(:disabled) { opacity: 0.85; }

.ip-examples__nav-btn--prev { background-color: var(--color-gray); }

.ip-examples__nav-btn--next { background-color: var(--color-primary); }

.ip-examples__nav-btn:disabled { opacity: 0.5; cursor: default; }

.ip-examples__nav-btn svg { width: 0.625rem; height: 1rem; fill: none; stroke: currentColor; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }

.ip-examples__viewport { overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; scrollbar-width: none; cursor: grab; }

.ip-examples__viewport::-webkit-scrollbar { display: none; }

.ip-examples__viewport.is-dragging { cursor: grabbing; user-select: none; }

.ip-examples__track { display: inline-flex; gap: 2rem; min-width: max-content; padding-right: 2rem; }

.ip-examples__card { flex: 0 0 auto; width: 25rem; background-color: var(--color-white); overflow: hidden; }

.ip-examples__card-image { width: 100%; height: 16.5rem; overflow: hidden; }

.ip-examples__card-image img { display: block; width: 100%; height: 100%; object-fit: cover; }

.ip-examples__card-body { padding: 1.25rem 1.5rem 1.75rem; display: flex; flex-direction: column; gap: 0.5625rem; }

.ip-examples__card-title { margin: 0; font-family: var(--font-heading); font-size: clamp(1.5rem, 2vw, 2.25rem); font-weight: 500; letter-spacing: -0.03em; color: var(--color-black); }

.ip-examples__card-desc { margin: 0; font-family: var(--font-heading); font-size: 1rem; font-weight: 400; line-height: 1.9375; letter-spacing: -0.03em; color: var(--color-black); }

/* -----------------------------------------------
   Internal Image Lightbox
   ----------------------------------------------- */
.ip-lightbox-open { overflow: hidden; }

.ip-lightbox { position: fixed; inset: 0; z-index: 1000; }

.ip-lightbox[hidden] { display: none; }

.ip-lightbox__backdrop { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.39); }

.ip-lightbox__dialog { position: relative; display: flex; align-items: center; justify-content: center; width: min(calc(100vw - 2rem), 74.5rem); min-height: calc(100vh - 2rem); margin: 1rem auto; }

.ip-lightbox__frame { position: relative; width: 100%; margin: 0; border: 3px solid var(--color-white); background: #191a15; overflow: hidden; box-shadow: 0 1.5rem 3rem rgba(0, 0, 0, 0.2); }

.ip-lightbox__image { display: block; width: 100%; max-height: calc(100vh - 5rem); background: #191a15; object-fit: contain; transition: opacity 180ms ease; opacity: 1; }

.ip-lightbox__caption { position: absolute; right: 0; bottom: 0; left: 0; margin: 0; padding: 0.875rem 1rem 1rem; background: linear-gradient(to top, rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0)); font-family: var(--font-heading); font-size: 0.9375rem; line-height: 1.5; letter-spacing: -0.03em; color: var(--color-white); transition: opacity 180ms ease; opacity: 1; }

.ip-lightbox.is-fading-out .ip-lightbox__image,
.ip-lightbox.is-fading-out .ip-lightbox__caption { opacity: 0; }

.ip-lightbox.is-fading-in .ip-lightbox__image,
.ip-lightbox.is-fading-in .ip-lightbox__caption { opacity: 1; }

.ip-lightbox__close { position: absolute; top: -3px; right: -3px; z-index: 2; display: flex; align-items: center; justify-content: center; width: 2.5625rem; height: 2.5625rem; padding: 0; border: 0; background: var(--color-white); color: var(--color-black); cursor: pointer; }

.ip-lightbox__close span { position: absolute; width: 1.125rem; height: 0.125rem; background: currentColor; }

.ip-lightbox__close span:first-child { transform: rotate(45deg); }

.ip-lightbox__close span:last-child { transform: rotate(-45deg); }

.ip-lightbox__nav { position: absolute; top: 50%; z-index: 2; display: flex; align-items: center; justify-content: center; width: 2.75rem; height: 2.75rem; padding: 0; border: 1px solid var(--color-white); border-radius: 50%; color: var(--color-white); cursor: pointer; transform: translateY(-50%); }

.ip-lightbox__nav--prev { left: 0.375rem; background: rgba(125, 125, 125, 0.85); }

.ip-lightbox__nav--next { right: 0.375rem; background: var(--color-primary); }

.ip-lightbox__nav span { display: block; width: 0.75rem; height: 0.75rem; border-top: 2px solid currentColor; border-right: 2px solid currentColor; }

.ip-lightbox__nav--prev span { margin-left: 0.25rem; transform: rotate(-135deg); }

.ip-lightbox__nav--next span { margin-right: 0.25rem; transform: rotate(45deg); }

/* -----------------------------------------------
   Tablet (768px+)
   ----------------------------------------------- */
@media (min-width: 768px) {
    .ip-hero { gap: 1.5rem; padding-block: 1.5rem 2rem; }

    .ip-hero__label { font-size: 1.125rem; }

    .ip-hero__title { font-size: clamp(2.25rem, 3.5vw, 3.875rem); }

    .ip-hero__lead { font-size: 1.125rem; line-height: 1.5; }

    .ip-hero__desc { font-size: 1.0625rem; line-height: 1.667; }

    .subnav { padding-block: 4rem; }

    .subnav ul { gap: 0.75rem; }

    .ip-blocks { gap: 3rem; padding-block: 2rem 3rem; }

    .ip-block { gap: 1.5rem; }

    .ip-block__desc { font-size: 1.0625rem; line-height: 1.722; }

    .ip-examples { padding: 4rem 0; }

    .ip-examples__track { gap: 2rem; }

    .ip-examples__card { width: 28rem; }

    .ip-examples__card-image { height: 20rem; }

    .ip-examples__card-body { padding: 1.5rem 2rem 2rem; }

    .ip-lightbox__dialog { width: min(calc(100vw - 4rem), 74.5rem); min-height: calc(100vh - 4rem); margin: 2rem auto; }

    .ip-lightbox__image { max-height: calc(100vh - 8rem); }

    .ip-lightbox__caption { padding: 1rem 1.5rem 1.25rem; font-size: 1rem; }

    .ip-lightbox__close { width: 2.5625rem; height: 2.5625rem; }

    .ip-lightbox__nav { width: 3.5rem; height: 3.5rem; }

    .ip-lightbox__nav--prev { left: 0.5rem; }

    .ip-lightbox__nav--next { right: 0.5rem; }
}

/* -----------------------------------------------
   Desktop (992px+)
   ----------------------------------------------- */
@media (min-width: 992px) {
    .ip-hero { flex-direction: row; align-items: center; gap: 4rem; padding-block: 2rem 2.5rem; }

    .ip-hero__image { flex: 0 0 46.15%; max-width: 46.15%; }

    .ip-hero__body { flex: 1 1 0; }

    .ip-hero__label { font-size: 1.5rem; }

    .ip-hero__title { font-size: 3.875rem; line-height: 1.065; }

    .ip-hero__lead { font-size: 1.25rem; line-height: 1.5; }

    .ip-hero__desc { font-size: var(--text-body-lg); line-height: 1.667; }

    .subnav ul { gap: 0; justify-content: space-between; }

    .subnav a { font-size: 1.5rem; padding: 1.0625rem 1.5rem; }

    .subnav a.active,
    .subnav li.active a { padding: 1.0625rem 1.5rem; }

    .ip-blocks { gap: 6.9375rem; padding-block: 3rem 5rem; }

    .ip-block { flex-direction: row; align-items: center; gap: 7.5rem; }

    .ip-block--reverse { flex-direction: row-reverse; }

    .ip-block__image { flex: 0 0 46.15%; max-width: 46.15%; }

    .ip-block__text { flex: 1 1 0; }

    .ip-block__title { font-size: 2.75rem; }

    .ip-block__desc { font-size: var(--text-body-lg); line-height: 1.722; }

    .ip-examples { padding: 4.5rem 0; }

    .ip-examples__header { margin-bottom: 2rem; }

    .ip-examples__card { width: 41.25rem; }

    .ip-examples__card-image { height: 26.5rem; }

    .ip-examples__card-body { padding: 1.75rem 2.75rem 2.25rem; }

    .ip-examples__card-title { font-size: 2.25rem; }
}

/* -----------------------------------------------
   Wide desktop (1440px+)
   ----------------------------------------------- */
@media (min-width: 1440px) {
    .ip-hero__image { flex: 0 0 886px; max-width: 886px; }

    .ip-block__image { flex: 0 0 886px; max-width: 886px; }

    .ip-block { gap: 7.5rem; }
}

/* -----------------------------------------------
   About Page
   ----------------------------------------------- */
.about-page { color: var(--color-black); }

.about-page__hero { padding-top: 0.25rem; }

.about-page__hero-image { background-color: #191a15; }

.about-page__hero-image img { width: 100%; height: 100%; min-height: 20rem; object-fit: cover; }

.about-page__hero-body { gap: 1.3125rem; }

.about-page__hero-body .ip-hero__label { font-size: 1.125rem; line-height: 1.3; }

.about-page__hero-body .ip-hero__title { font-size: clamp(2.125rem, 4vw, 3.875rem); font-weight: 500; line-height: 1.06; }

.about-page__hero-body .ip-hero__intro { max-width: 42rem; }

.about-page__hero-body .ip-hero__lead,
.about-page__hero-body .ip-hero__desc { letter-spacing: -0.03em; }

.about-page__hero-body .ip-hero__cta { min-height: 3.75rem; padding: 1.125rem 2rem; border-width: 2px; border-radius: 0.375rem; font-size: 1.125rem; }

.about-page__text-link { color: inherit; font-weight: 700; text-decoration: none; }

.about-page__text-link:hover,
.about-page__text-link:focus-visible { color: inherit; text-decoration: underline; text-underline-offset: 0.12em; }

.about-page__story { padding-top: 4rem; padding-bottom: 4rem; }

.about-page__story-block { gap: 2rem; }

.about-page__story-image { background-color: #191a15; }

.about-page__story-image img { width: 100%; height: 100%; min-height: 16rem; object-fit: cover; }

.about-page__story-text { gap: 1.5rem; }

.about-page__owner { padding-top: 4rem; padding-bottom: 4rem; }

.about-page__owner-inner { display: flex; flex-direction: column; gap: 2rem; background-color: #191a15; padding-top: 2rem; padding-right: 1.5rem; padding-bottom: 2rem; padding-left: 1.5rem; }

.about-page__owner-image { overflow: hidden; }

.about-page__owner-image img { display: block; width: 100%; height: 100%; object-fit: cover; }

.about-page__owner-text { display: flex; flex-direction: column; gap: 1rem; color: var(--color-white); }

.about-page__owner-rule { display: block; width: 10rem; height: 4px; background-color: var(--color-white); }

.about-page__owner-title { margin: 0; font-family: var(--font-heading); font-size: clamp(2rem, 3vw, 2.75rem); font-weight: 500; line-height: 1.08; letter-spacing: -0.03em; }

.about-page__owner-desc { margin: 0; font-family: var(--font-heading); font-size: 1rem; font-weight: 400; line-height: 1.722; letter-spacing: -0.03em; }

.about-page__clients .clients { padding-top: 0; padding-bottom: 0; }

.about-page__clients .clients__heading { margin-bottom: 1rem; font-size: clamp(2rem, 3vw, 2.75rem); line-height: 1.12; }

.about-page__clients .clients__rule { display: none; }

.about-page .faq-section { padding-top: 1.5rem; }

.about-page .faq-section__intro { font-weight: 500; }

@media (min-width: 768px) {
    .about-page__hero { padding-top: 2.25rem; padding-bottom: 2.5rem; }

    .about-page__story { padding-top: 4.5rem; padding-bottom: 4.5rem; }

    .about-page__story-block { gap: 3rem; }

    .about-page__owner-inner { flex-direction: row; align-items: center; gap: 3rem; padding-top: 3rem; padding-right: 2rem; padding-bottom: 3rem; padding-left: 2rem; }

    .about-page__owner-image { flex: 0 0 50%; max-width: 50%; }

    .about-page__owner-text { flex: 1 1 0; }

    .about-page .faq-section { padding-top: 2.5rem; }
}

@media (min-width: 768px) and (max-width: 991px) {
    .scale-page--hundred.has-ip-divider .ip-blocks { padding-top: 30px; }
    .ip-divider { margin-top: 5px; }
}

@media (min-width: 992px) {
    .about-page__hero { gap: 7.5rem; padding-top: 2.25rem; padding-bottom: 4.25rem; }

    .about-page__hero-body { max-width: 44.125rem; }

    .about-page__story { padding-top: 4.3125rem; padding-bottom: 5rem; }

    .about-page__story-block { gap: 7.5rem; }

    .about-page__owner-inner { gap: 6.4375rem; padding-top: 0; padding-right: 0; padding-bottom: 0; padding-left: 0; min-height: 44.875rem; }

    .about-page__owner-image { flex: 0 0 49.36%; max-width: 49.36%; align-self: stretch; }

    .about-page__owner-title { font-size: 2.75rem; line-height: 1.23; }

    .about-page__owner-desc { font-size: 1.125rem; }

    .about-page__clients .clients { padding-top: 0rem; padding-bottom: 2rem; }

    .about-page__clients .clients__heading { margin-bottom: 1.5625rem; }

    .about-page .faq-section { padding-top: 0.25rem; }
}

/* -----------------------------------------------
   Shared internal page styles
   (.scale-page--hundred is the shared class used on ALL arch model,
   service, and other internal pages — not just the 1:100 scale page)
   ----------------------------------------------- */
.scale-page--hundred { color: var(--color-black); }

.scale-page--hundred .ip-hero { padding-block: 0.25rem 0; gap: 2rem; }

.scale-page--hundred .ip-hero__image { background-color: #191a15; }

.scale-page--hundred .ip-hero__image img { width: 100%; height: 100%; min-height: 20rem; object-fit: cover; }

.scale-page--hundred .ip-hero__body { gap: 1.3125rem; }

.scale-page--hundred .ip-hero__label { font-size: 1.125rem; font-weight: 400; line-height: 44px; letter-spacing: -0.54px; color: var(--color-primary); }

.scale-page--hundred .ip-hero__title { font-size: clamp(2.125rem, 4vw, 3rem); font-weight: 500; line-height: 1.06; letter-spacing: -0.03em; }

.scale-page--hundred .ip-hero__title-light { color: rgba(0, 0, 0, 0.58); font-size: 1.5rem; display: block; margin-top: 5px; }

.scale-page--hundred .ip-hero__intro { gap: 0.5rem; max-width: 42rem; }

.scale-page--hundred .ip-hero__lead { font-size: 1.125rem; font-weight: 600; line-height: 1.5; letter-spacing: -0.03em; }

.scale-page--hundred .ip-hero__desc { font-size: 1rem; line-height: 1.667; letter-spacing: -0.03em; }

.scale-page--hundred .ip-hero__cta { min-height: 3.75rem; padding: 1.125rem 2rem; border-width: 2px; border-radius: 0.375rem; font-size: 1.125rem; line-height: 1; }

.scale-page--hundred .ip-blocks { gap: 4rem; padding-block: 1rem 3rem; }

.scale-page--hundred .ip-block { gap: 2rem; }

.scale-page--hundred .ip-block__image { background-color: #191a15; }

.scale-page--hundred .ip-block__image img { width: 100%; height: 100%; min-height: 16rem; object-fit: cover; }

.scale-page--hundred .ip-block__text { gap: 1rem; }

.scale-page--hundred .ip-block__rule { width: 10rem; }

.scale-page--hundred .ip-block__title { font-size: clamp(2rem, 3vw, 2.75rem); font-weight: 500; line-height: 1.05; letter-spacing: -0.03em; }

.scale-page--hundred .ip-block__desc { font-size: 1rem; line-height: 1.72; letter-spacing: -0.03em; }

.scale-page--hundred .ip-examples { padding: 3.75rem 0 4rem; background-color: #efefef; }

.scale-page--hundred .ip-examples__inner.container { padding-left: 1rem; padding-right: 0; }

.scale-page--hundred .ip-examples__viewport { width: calc(100vw - 1rem); max-width: none; }

.scale-page--hundred .ip-examples__header { gap: 0.75rem; margin-bottom: 1.5rem; padding-right: 1rem; }

.scale-page--hundred .ip-examples__rule { width: 13.625rem; }

.scale-page--hundred .ip-examples__title { max-width: 45.875rem; font-size: clamp(2rem, 3vw, 2.75rem); line-height: 1.12; letter-spacing: -0.03em; }

.scale-page--hundred .ip-examples__nav { gap: 0.31875rem; }

.scale-page--hundred .ip-examples__nav-btn { width: 3.1875rem; height: 3.1875rem; }

.scale-page--hundred .ip-examples__track { gap: 1.5rem; padding-right: 1rem; }

.scale-page--hundred .ip-examples__card { width: min(41.25rem, calc(100vw - 2.5rem)); }

.scale-page--hundred .ip-examples__card-image { height: auto; aspect-ratio: 662 / 425; }

.scale-page--hundred .ip-examples__card-body { min-height: 14rem; padding: 1.5rem 1.5rem 1.75rem; gap: 0.5625rem; }

.scale-page--hundred .ip-examples__card-title { font-size: 1.75rem; line-height: 1.1; }

.scale-page--hundred .ip-examples__card-desc { font-size: 0.9375rem; line-height: 1.7; }

.scale-page--hundred .faq-section.container { padding-top: 3rem; padding-bottom: 3rem; }

.scale-page--hundred .faq-section__header { gap: 0.75rem; max-width: 50.8125rem; }

.scale-page--hundred .faq-section__header .section-heading__rule { width: 13.8125rem; }

.scale-page--hundred .faq-section__title { font-size: clamp(2rem, 3vw, 2.75rem); line-height: 1.18; letter-spacing: -0.03em; }

.scale-page--hundred .faq-section__intro { max-width: 54rem; margin-top: 2rem; font-size: 1rem; line-height: 1.55; letter-spacing: -0.03em; }

.scale-page--hundred .faq-section__list { max-width: none; margin-top: 2.5rem; }

.scale-page--hundred .faq-section__question { padding: 1.125rem 0; }

.scale-page--hundred .faq-section__question-text { font-size: 1.125rem; font-weight: 400; line-height: 1.35; letter-spacing: -0.03em; }

.scale-page--hundred .faq-section__icon { width: 1.1875rem; height: 0.625rem; }

.scale-page--hundred .faq-section__answer p { max-width: 58rem; font-size: 1rem; line-height: 1.75; }

.scale-page--hundred .faq-section__cta { margin-top: 2.5rem; }

.scale-page--hundred .faq-section__button { min-height: 3.75rem; padding: 1.125rem 2rem; border-radius: 0.375rem; font-size: 1.125rem; }

.scale-page--hundred .image-strip-section { background-color: #f7f7f7; }

.scale-page--hundred .image-strip-section__inner.container { padding-top: 3.875rem; padding-bottom: 3.75rem; }

.scale-page--hundred .image-strip-section__header { gap: 0.75rem; max-width: 47.6875rem; }

.scale-page--hundred .image-strip-section__rule { width: 13.8125rem; }

.scale-page--hundred .image-strip-section__title { font-size: clamp(2rem, 3vw, 2.75rem); line-height: 1.18; letter-spacing: -0.03em; }

.scale-page--hundred .image-strip-section__track { gap: 1rem; }

.scale-page--hundred .image-strip-section__item { width: 20rem; height: auto; aspect-ratio: 542 / 312; }

.scale-page--hundred .image-strip-section__cta { margin-top: 1.75rem; }

.scale-page--hundred .image-strip-section__button { min-height: 3.75rem; padding: 1.125rem 2rem; border-radius: 0.375rem; }

@media (min-width: 768px) {
    /* Override scale-page base padding-block: 0.25rem 0 and gap: 4rem on blocks */
    .scale-page--hundred .ip-hero { padding-block: 1.25rem 1.5rem; gap: 1.5rem; }

    .scale-page--hundred .ip-blocks { gap: 3rem; padding-block: 2rem 3rem; }

    .scale-page--hundred .ip-examples__inner.container { padding-left: 1rem; }

    .scale-page--hundred .ip-examples__viewport { width: calc(100vw - 1rem); max-width: none; }

    .scale-page--hundred .ip-examples__track { gap: 2rem; }

    .scale-page--hundred .ip-examples__card-image { height: auto; aspect-ratio: 662 / 425; }

    .scale-page--hundred .ip-examples__card-body { min-height: 15rem; padding: 1.75rem 2rem 2rem; }

    .scale-page--hundred .ip-examples__card-title { font-size: 2rem; }

    .scale-page--hundred .faq-section.container { padding-top: 4rem; padding-bottom: 4rem; }

    .scale-page--hundred .faq-section__intro { font-size: 1.125rem; line-height: 1.55; }

    .scale-page--hundred .faq-section__question-text { font-size: 1.375rem; }

    .scale-page--hundred .image-strip-section__inner.container { padding-top: 2rem; padding-bottom: 2rem; }

    .scale-page--hundred .image-strip-section__item { width: 26rem; height: auto; aspect-ratio: 542 / 312; }
}

@media (min-width: 992px) {
    .scale-page--hundred .ip-hero { gap: 4.5rem; padding-top: 0; padding-bottom: 0; }

    .scale-page--hundred .ip-hero__image { flex: 0 0 49.44%; max-width: 49.44%; }

    .scale-page--hundred .ip-hero__image { aspect-ratio: 886 / 618; }

    .scale-page--hundred .ip-hero__body { max-width: 44.125rem; }

    .scale-page--hundred .ip-hero__label { font-size: 1.125rem; line-height: 44px; letter-spacing: -0.54px; font-weight: 400; }

    .scale-page--hundred .ip-hero__title { font-size: 3rem; letter-spacing: -0.03em; }

    .scale-page--hundred .ip-hero__lead { font-size: 1.25rem; line-height: 1.5; }

    .scale-page--hundred .ip-hero__desc { font-size: 1.125rem; line-height: 1.667; }

    .scale-page--hundred .ip-blocks { gap: 6.9375rem; padding-block: 0 5rem; }
    .scale-page--hundred.has-ip-divider .ip-blocks { padding-top: 60px; }

    .scale-page--hundred .ip-block { align-items: center; gap: 7.5rem; }

    .scale-page--hundred .ip-block__image { flex: 0 0 49.44%; max-width: 49.44%; }

    .scale-page--hundred .ip-block__image { aspect-ratio: 886 / 524; }

    .scale-page--hundred .ip-block__text { flex: 0 1 41.5%; gap: 1rem; }

    .scale-page--hundred .ip-block__title { font-size: 2.75rem; line-height: 1.04; }

    .scale-page--hundred .ip-block__desc { font-size: 1.125rem; line-height: 1.72; }

    .scale-page--hundred .ip-examples { padding: 5.625rem 0 5rem; }

    .scale-page--hundred .ip-examples__inner.container { padding-left: 4rem; }

    .scale-page--hundred .ip-examples__viewport { width: calc(100vw - 4rem); max-width: none; }

    .scale-page--hundred .ip-examples__header { margin-bottom: 2rem; padding-right: 4rem; }

    .scale-page--hundred .ip-examples__track { gap: 2rem; padding-right: 4rem; }

    .scale-page--hundred .ip-examples__card { width: 41.25rem; }

    .scale-page--hundred .ip-examples__card-image { height: 26.5rem; }

    .scale-page--hundred .ip-examples__card-body { min-height: 17.9375rem; padding: 1.75rem 2.75rem 2.6875rem; }

    .scale-page--hundred .ip-examples__card-title { font-size: 2.25rem; line-height: 1.28; }

    .scale-page--hundred .ip-examples__card-desc { font-size: 1rem; line-height: 1.9375; }

    .scale-page--hundred .faq-section.container { padding-top: 6rem; padding-bottom: 6rem; }

    .scale-page--hundred .faq-section__header { max-width: 50.8125rem; }

    .scale-page--hundred .faq-section__title { font-size: 2.75rem; line-height: 1.23; }

    .scale-page--hundred .faq-section__intro { max-width: 54rem; margin-top: 1.875rem; font-size: 1.125rem; line-height: 1.56; }

    .scale-page--hundred .faq-section__list { margin-top: 3.9375rem; }

    .scale-page--hundred .faq-section__question { padding: 1.5rem 0 1.625rem; }

    .scale-page--hundred .faq-section__question-text { font-size: 1.5rem; line-height: 1.17; }

    .scale-page--hundred .faq-section__answer p { font-size: 1.125rem; }

    .scale-page--hundred .faq-section__cta { margin-top: 3.9375rem; }

    .scale-page--hundred .image-strip-section__inner.container { padding-top: 3.875rem; padding-bottom: 3.8125rem; }

    .scale-page--hundred .image-strip-section__header { max-width: 47.6875rem; }

    .scale-page--hundred .image-strip-section__title { font-size: 2.75rem; line-height: 1.23; }

    .scale-page--hundred .image-strip-section__track { gap: 1.5rem; }

    .scale-page--hundred .image-strip-section__item { width: 33.6875rem; height: auto; aspect-ratio: 542 / 312; }

    .scale-page--hundred .image-strip-section__cta { margin-top: 1.75rem; display: flex; justify-content: center; }

    .scale-page--hundred .image-strip-section__button { background-color: #ca161e; border-color: rgba(0, 0, 0, 0.22); color: var(--color-white); }
}

/* -----------------------------------------------
   Mid-desktop (992px–1229px) tightening
   ----------------------------------------------- */
@media (min-width: 992px) and (max-width: 1229px) {
    .scale-page--hundred .ip-examples__inner.container { padding-left: 1rem; padding-right: 1rem; }

    .scale-page--hundred .ip-examples__header { padding-right: 0; }

    .scale-page--hundred .ip-examples__viewport { width: calc(100vw - 2rem); max-width: none; overflow-x: auto; overflow-y: hidden; }

    .scale-page--hundred .ip-examples__track { gap: 1.25rem; padding-right: 0.5rem; }

    .scale-page--hundred .ip-examples__card { width: calc((100vw - 4.5rem) / 3); }

    .scale-page--hundred .ip-examples__card-image { height: clamp(11.5rem, 20vw, 15rem); }

    .scale-page--hundred .ip-examples__card-body { min-height: 0; padding: 1.25rem 1.25rem 1.5rem; }

    .scale-page--hundred .ip-examples__card-title { font-size: 1.5rem; line-height: 1.2; }

    .scale-page--hundred .ip-examples__card-desc { font-size: 0.9375rem; line-height: 1.6; }

    .arch-page.scale-page--hundred .ip-hero { gap: 2.5rem; align-items: center; padding-bottom: 2.5rem; }

    .arch-page.scale-page--hundred .ip-hero__title { font-size: 2.75rem; }

    .arch-page.scale-page--hundred .ip-hero__lead { font-size: 1.125rem; }

    .arch-page.scale-page--hundred .ip-hero__desc { font-size: 1rem; line-height: 1.65; }

    .arch-page.scale-page--hundred .ip-blocks { gap: 3.5rem; padding-block: 1.5rem 4rem; }

    .arch-page.scale-page--hundred .ip-block { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); align-items: center; gap: 2.25rem; }

    .arch-page.scale-page--hundred .ip-block--reverse .ip-block__image { order: 2; }

    .arch-page.scale-page--hundred .ip-block--reverse .ip-block__text { order: 1; }

    .arch-page.scale-page--hundred .ip-block__image,
    .arch-page.scale-page--hundred .ip-block__text { max-width: none; }

    .arch-page.scale-page--hundred .ip-block__title { font-size: 2.125rem; line-height: 1.08; }

    .arch-page.scale-page--hundred .ip-block__desc { font-size: 1rem; line-height: 1.65; }

    .arch-page.scale-page--hundred .ip-block--dual-image { display: flex; flex-direction: column; align-items: stretch; gap: 1.5rem; }

    .arch-page.scale-page--hundred .ip-block--dual-image .ip-block__images { display: flex; gap: 1.25rem; width: 100%; }

    .arch-page.scale-page--hundred .ip-block--dual-image .ip-block__images .ip-block__image,
    .arch-page.scale-page--hundred .ip-block--dual-image .ip-block__text { flex: none; width: 100%; max-width: none; }

    .arch-page.scale-page--hundred .ip-block--dual-image .ip-block__images .ip-block__image { flex: 1 1 0; }

    .arch-page.scale-page--hundred .ip-examples { padding: 4.5rem 0 4rem; }

    .arch-page.scale-page--hundred .ip-examples__inner.container { padding-left: 1rem; padding-right: 1rem; }

    .arch-page.scale-page--hundred .ip-examples__header { padding-right: 0; }

    .arch-page.scale-page--hundred .ip-examples__viewport { width: calc(100vw - 2rem); max-width: none; overflow-x: auto; overflow-y: hidden; }

    .arch-page.scale-page--hundred .ip-examples__track { gap: 1.25rem; padding-right: 0.5rem; }

    .arch-page.scale-page--hundred .ip-examples__card { width: calc((100vw - 4.5rem) / 3); }

    .arch-page.scale-page--hundred .ip-examples__card-image { height: clamp(11.5rem, 20vw, 15rem); }

    .arch-page.scale-page--hundred .ip-examples__card-body { min-height: 0; padding: 1.25rem 1.25rem 1.5rem; }

    .arch-page.scale-page--hundred .ip-examples__card-title { font-size: 1.5rem; line-height: 1.2; }

    .arch-page.scale-page--hundred .ip-examples__card-desc { font-size: 0.9375rem; line-height: 1.6; }

    .service-page--exhibition.scale-page--hundred .ip-blocks { gap: 4.5rem; }

    .service-page--exhibition.scale-page--hundred .ip-block { align-items: center; gap: 4rem; }

    .service-page--exhibition.scale-page--hundred .ip-block__text { flex: 1 1 0; }

    .service-page--exhibition.scale-page--hundred .ip-block__title { font-size: 2.375rem; line-height: 1.08; }

    .service-page--exhibition.scale-page--hundred .ip-block__desc { font-size: 1rem; line-height: 1.65; }

    .service-page--product.scale-page--hundred .ip-hero { gap: 3rem; padding-bottom: 2rem; }

    .service-page--product.scale-page--hundred .ip-blocks { gap: 3rem; padding-block: 1.5rem 4rem; }

    .service-page--product.scale-page--hundred .ip-block { gap: 2rem; }

    .service-page--product.scale-page--hundred .ip-block--dual-image { gap: 1.25rem; }

    .service-page--product.scale-page--hundred .ip-block--dual-image .ip-block__images { gap: 1rem; }

    .service-page--product.scale-page--hundred .ip-block__title { font-size: 2.125rem; line-height: 1.08; }

    .service-page--product.scale-page--hundred .ip-block__desc { font-size: 1rem; line-height: 1.65; }

    .service-page--fibreglass.scale-page--hundred .ip-hero { gap: 3rem; padding-bottom: 2rem; }

    .service-page--fibreglass.scale-page--hundred .ip-blocks { gap: 4rem; padding-block: 1.5rem 4rem; }

    .service-page--fibreglass.scale-page--hundred .ip-block { gap: 3rem; }

    .service-page--fibreglass.scale-page--hundred .ip-block--dual-image { gap: 1.25rem; }

    .service-page--fibreglass.scale-page--hundred .ip-block--dual-image .ip-block__images { gap: 1rem; }

    .service-page--fibreglass.scale-page--hundred .ip-block--dual-image .ip-block__images .ip-block__image { aspect-ratio: 660 / 424; }

    .service-page--fibreglass.scale-page--hundred .ip-block__title { font-size: 2.25rem; line-height: 1.08; }

    .service-page--fibreglass.scale-page--hundred .ip-block__desc { font-size: 1rem; line-height: 1.65; }
}

/* -----------------------------------------------
   Wide desktop (1230px–1439px) stepping
   ----------------------------------------------- */
@media (min-width: 1230px) and (max-width: 1439px) {
    .scale-page--hundred .ip-hero { gap: 3.5rem; }

    .scale-page--hundred .ip-blocks { gap: 5rem; }

    .scale-page--hundred .ip-block { gap: 5.5rem; }

    .scale-page--hundred .ip-block__text { flex: 1 1 0; }
}

@media (min-width: 1440px) {
    .scale-page--hundred .ip-hero { gap: 6.875rem; }

    .scale-page--hundred .ip-hero__image { flex: 0 0 55.375rem; max-width: 55.375rem; }

    .scale-page--hundred .ip-block__image { flex: 0 0 55.375rem; max-width: 55.375rem; }

    .scale-page--hundred .ip-block__text { flex-basis: 41.5rem; max-width: 41.5rem; }
}

.service-page .ip-blocks { padding-top: 110px; }

.faq-page .ip-hero { padding-bottom: 2rem; }

.faq-page .ip-hero__body { max-width: 52rem; }

.faq-page .faq-section { padding-top: 0; }

@media (min-width: 992px) {
    .faq-page .ip-hero { padding-bottom: 3rem; }
}

/* -----------------------------------------------
   Tablet (768px–1099px) overrides
   ----------------------------------------------- */
@media (min-width: 768px) and (max-width: 1099px) {
    /* Subnav overflows at this width range due to body overflow-x: clip */
    .subnav { display: none; }
}

/* -----------------------------------------------
   Mobile (max 767px) overrides
   ----------------------------------------------- */
@media (max-width: 767px) {
    /* === Hero === */
    .ip-hero,
    .scale-page--hundred .ip-hero { padding-block: 1rem 1.5rem; gap: 1.5rem; }

    .ip-hero__body,
    .scale-page--hundred .ip-hero__body { gap: 1rem; }

    .ip-hero__label,
    .scale-page--hundred .ip-hero__label { font-size: 0.875rem; padding-left: 0; }

    .ip-hero__title,
    .scale-page--hundred .ip-hero__title { font-size: 1.875rem; line-height: 1.1; }

    .ip-hero__lead,
    .scale-page--hundred .ip-hero__lead { font-size: 1rem; }

    .ip-hero__desc,
    .scale-page--hundred .ip-hero__desc { font-size: 0.9375rem; line-height: 1.6; }

    .ip-hero__cta { width: 100%; }

    /* === Content Blocks === */
    .ip-blocks,
    .scale-page--hundred .ip-blocks { gap: 2.5rem; padding-block: 1.5rem 2rem; }

    .service-page .ip-blocks { padding-top: 1.5rem; }

    .ip-block,
    .scale-page--hundred .ip-block { gap: 1.25rem; }

    .ip-block__rule,
    .scale-page--hundred .ip-block__rule { width: 3rem; }

    .ip-block__title,
    .scale-page--hundred .ip-block__title { font-size: 1.5rem; line-height: 1.15; }

    .ip-block__desc,
    .scale-page--hundred .ip-block__desc { font-size: 0.9375rem; }

    /* === Images — no min-height, let natural aspect ratio scale === */
    .about-page__hero-image img,
    .about-page__story-image img,
    .scale-page--hundred .ip-hero__image img,
    .scale-page--hundred .ip-block__image img { min-height: 0; }

    /* === ip-examples — reduce vertical padding, remove card-body min-height === */
    .ip-examples,
    .scale-page--hundred .ip-examples { padding-block: 2rem 2.5rem; }

    .scale-page--hundred .ip-examples__title { font-size: 1.25rem; }

    .scale-page--hundred .ip-examples__card-body { min-height: 0; }

    /* === image-strip-section — remove double-stacked inner padding === */
    .scale-page--hundred .image-strip-section__inner.container { padding-top: 0; padding-bottom: 0; }

    /* === Subnav — hidden on mobile === */
    .subnav { display: none; }

    .ip-divider { margin-top: 0; }
}

/* -----------------------------------------------
   Dual-image block modifier
   Two images side by side, shared text beneath
   ----------------------------------------------- */
.ip-block--dual-image .ip-block__images { display: flex; flex-direction: column; gap: 1rem; width: 100%; }

@media (min-width: 600px) {
    .ip-block--dual-image .ip-block__images { flex-direction: row; gap: 1.5rem; }

    .ip-block--dual-image .ip-block__images .ip-block__image { flex: 1 1 0; max-width: none; }
}

@media (min-width: 992px) {
    .ip-block--dual-image,
    .scale-page--hundred .ip-block--dual-image { flex-direction: column; align-items: stretch; gap: 2rem; }

    .ip-block--dual-image .ip-block__images,
    .scale-page--hundred .ip-block--dual-image .ip-block__images { flex-direction: row; gap: 2rem; }

    .ip-block--dual-image .ip-block__images .ip-block__image,
    .scale-page--hundred .ip-block--dual-image .ip-block__images .ip-block__image { flex: 1 1 0; max-width: none; aspect-ratio: 660 / 424; }

    .ip-block--dual-image .ip-block__text,
    .scale-page--hundred .ip-block--dual-image .ip-block__text { flex: none; width: 100%; max-width: none; }
}

@media (min-width: 1440px) {
    .ip-block--dual-image .ip-block__images .ip-block__image,
    .scale-page--hundred .ip-block--dual-image .ip-block__images .ip-block__image { flex: 1 1 0; max-width: none; }
}

@media (min-width: 992px) {
    .service-page--fibreglass .ip-block--dual-image .ip-block__images .ip-block__image { aspect-ratio: 886 / 524; }
}

/* -----------------------------------------------
   Riverbed block modifier
   Two image rows, each with paired text columns
   ----------------------------------------------- */
.ip-block--riverbed .ip-block__riverbed-text-grid { display: flex; flex-direction: column; gap: 1rem; width: 100%; }

.ip-block--riverbed .ip-block__riverbed-text-col { flex: 1 1 0; }

@media (min-width: 600px) {
    .ip-block--riverbed .ip-block__riverbed-text-grid { flex-direction: row; gap: 1.5rem; }
}

@media (min-width: 992px) {
    .ip-block--riverbed .ip-block__riverbed-text-grid,
    .scale-page--hundred .ip-block--riverbed .ip-block__riverbed-text-grid { gap: 2rem; }
}

.ip-block--riverbed .ip-block__riverbed-pairs { display: grid; grid-template-columns: 1fr; gap: 1rem; width: 100%; }

.ip-block--riverbed .ip-block__riverbed-pair { display: flex; flex-direction: column; gap: 1rem; }

@media (min-width: 992px) {
    .ip-block--riverbed .ip-block__riverbed-pairs,
    .scale-page--hundred .ip-block--riverbed .ip-block__riverbed-pairs { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2rem; }
}

