html.rsb-skip-intro .brand-intro {
  display: none !important;
}

.brand-intro-inner strong {
  font-size: 0 !important;
}

.brand-intro-inner strong::after {
  content: "RSB Reformas";
  display: block;
  color: #fffdf8;
  font-family: var(--font-serif), Georgia, serif;
  font-size: clamp(2.35rem, 5vw, 4.9rem);
  font-weight: 900;
  letter-spacing: 0;
  line-height: .92;
}

.brand-loader svg {
  display: none !important;
}

.brand-loader::before {
  content: "";
  width: 38px;
  height: 38px;
  display: block;
  border: 3px solid rgba(242, 210, 190, .95);
  border-top-color: transparent;
  border-left-color: #a65f3f;
  transform: rotate(45deg);
  box-shadow: 12px 12px 0 -8px rgba(255, 253, 248, .85);
}

.hero-copy {
  animation: none !important;
  opacity: 1 !important;
}

.site-header,
.site-header.is-page,
.site-header.is-scrolled,
.site-header.menu-open {
  min-height: 76px !important;
  color: #fff !important;
  background: transparent !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.site-header .desktop-nav a,
.site-header.is-page .desktop-nav a,
.site-header.is-scrolled .desktop-nav a,
.site-header.menu-open .desktop-nav a,
.site-header .phone-link,
.site-header.is-page .phone-link,
.site-header.is-scrolled .phone-link,
.site-header.menu-open .phone-link,
.site-header .mobile-menu-button,
.site-header.is-page .mobile-menu-button,
.site-header.is-scrolled .mobile-menu-button,
.site-header.menu-open .mobile-menu-button {
  color: #fff !important;
  background: rgba(255, 255, 255, .1) !important;
  border-color: rgba(255, 255, 255, .2) !important;
}

.site-header .desktop-nav a:hover,
.site-header .phone-link:hover {
  background: rgba(255, 255, 255, .18) !important;
  border-color: rgba(242, 210, 190, .55) !important;
}

.site-header .mobile-nav,
.site-header.is-page .mobile-nav,
.site-header.is-scrolled .mobile-nav,
.site-header.menu-open .mobile-nav {
  color: var(--color-ink) !important;
  background: rgba(255, 253, 248, .98) !important;
  border-color: rgba(24, 32, 29, .18) !important;
  z-index: 80 !important;
}

.site-header .mobile-nav a,
.site-header.is-page .mobile-nav a,
.site-header.is-scrolled .mobile-nav a,
.site-header.menu-open .mobile-nav a {
  color: var(--color-ink) !important;
  background: transparent !important;
  border-color: rgba(24, 32, 29, .12) !important;
}

.site-header .mobile-nav a:hover,
.site-header .mobile-nav a:focus-visible {
  color: var(--color-copper) !important;
  background: rgba(166, 95, 63, .09) !important;
}

.editorial-hero {
  padding-top: 0 !important;
  min-height: 100dvh !important;
  margin-top: -1px !important;
}

.editorial-hero .hero-content {
  min-height: 100dvh !important;
  padding-top: clamp(112px, 13vh, 150px) !important;
  padding-bottom: clamp(36px, 5vh, 64px) !important;
  align-content: start !important;
}

.editorial-hero .hero-copy {
  margin-top: 0 !important;
}

.editorial-hero h1 {
  max-width: 980px !important;
  font-size: clamp(3.35rem, 4.55vw, 5.25rem) !important;
  line-height: .92 !important;
}

.more-services-hero {
  min-height: auto !important;
  padding: 18px 0 42px !important;
}

.more-services-hero-inner {
  display: grid !important;
  gap: 22px !important;
}

.more-services-topbar {
  margin: 0 !important;
  position: relative !important;
  z-index: 3 !important;
}
.more-services-magazine-layout {
  align-items: start !important;
  gap: clamp(22px, 3vw, 42px) !important;
  transform: none !important;
  margin-bottom: 0 !important;
}

.more-services-hero h1 {
  max-width: 820px !important;
  font-size: clamp(2.5rem, 3.82vw, 4.25rem) !important;
  line-height: .89 !important;
}

.more-services-hero p:not(.eyebrow) {
  margin-top: 14px !important;
  font-size: clamp(1rem, 1.18vw, 1.12rem) !important;
  line-height: 1.45 !important;
}

.more-services-actions {
  margin-top: 20px !important;
}

.magazine-photo-left {
  min-height: clamp(270px, 35vh, 405px) !important;
}

@media (max-width: 380px) {
  .editorial-hero h1 {
    width: min(100%, 20rem) !important;
    font-size: clamp(1.88rem, 8.45vw, 2.08rem) !important;
    line-height: 1.05 !important;
  }

  .editorial-hero .hero-description {
    width: min(100%, 20rem) !important;
  }
}

.rsb-contact-trust {
  background: linear-gradient(135deg, #101714, #18201d 58%, #070a09);
  color: #fff;
  padding-top: 72px !important;
  overflow: hidden;
}

.rsb-contact-trust .container {
  width: min(1180px, 100% - 24px);
}

.rsb-contact-trust .section-lead {
  color: rgba(255, 255, 255, .72);
}
.contact-card,
.step-card {
  min-width: 0;
}

.contact-page *,
.contact-page *::before,
.contact-page *::after {
  box-sizing: border-box;
}

.contact-page {
  overflow-x: hidden;
  max-width: 100vw;
}

.contact-header,
.contact-hero,
.contact-steps,
.contact-card,
.rsb-contact-trust,
.rsb-contact-trust .container {
  max-width: calc(100vw - 24px) !important;
}

.contact-header,
.contact-hero,
.contact-steps,
.rsb-contact-trust .container {
  width: calc(100vw - 24px) !important;
}

.contact-card {
  width: 100% !important;
}

.contact-hero h1,
.contact-lead,
.contact-card h2,
.contact-card p,
.rsb-contact-trust h2,
.rsb-contact-trust p,
.rsb-contact-trust h3 {
  max-width: 100% !important;
  overflow-wrap: anywhere;
}

.contact-card p,
.contact-card a,
.step-card span {
  overflow-wrap: anywhere;
}

.rsb-sate-section {
  background: var(--color-paper);
  padding: clamp(76px, 8vw, 118px) 0;
}

/* Home: bring SATE closer to work-examples */
html:not(.rsb-more-services-page) .work-examples-section {
  padding-bottom: clamp(32px, 3.5vw, 44px);
}
html:not(.rsb-more-services-page) .rsb-sate-section {
  padding-top: clamp(32px, 3.5vw, 44px);
  padding-bottom: clamp(36px, 4vw, 52px);
}

/* Button standalone block after SATE on home */
.rsb-sate-section + .work-more-cta {
  background: var(--color-paper);
  padding: clamp(40px, 4.5vw, 60px) clamp(16px, 5vw, 24px);
  margin-top: 0;
}

.rsb-sate-grid {
  display: grid;
  grid-template-columns: minmax(0, .78fr) minmax(300px, .62fr);
  align-items: center;
  gap: clamp(24px, 4vw, 58px);
}

.rsb-sate-copy h2,
.rsb-before-after-copy h2 {
  color: var(--color-ink);
  font-family: "Nippo", var(--font-sans), Arial, sans-serif;
  font-size: clamp(2rem, 4.4vw, 4rem);
  font-weight: 700;
  letter-spacing: -.035em;
  line-height: 1;
  margin: 0;
  text-wrap: balance;
}

.rsb-sate-copy p,
.rsb-before-after-copy p {
  color: var(--color-muted);
  font-size: clamp(1rem, 1.2vw, 1.12rem);
  line-height: 1.62;
  margin: 18px 0 0;
  max-width: 620px;
}

.rsb-sate-copy ul {
  display: grid;
  gap: 10px;
  margin: 24px 0 0;
}

.rsb-sate-copy li {
  color: var(--color-ink);
  border-left: 3px solid rgba(166, 95, 63, .42);
  padding-left: 14px;
  font-weight: 750;
  line-height: 1.45;
}

.rsb-sate-carousel {
  aspect-ratio: 4 / 3;
  background: var(--color-soft);
  box-shadow: 0 20px 54px rgba(24, 32, 29, .12);
  min-height: 0;
  overflow: hidden;
  position: relative;
}

.rsb-sate-carousel img {
  height: 100%;
  inset: 0;
  object-fit: cover;
  opacity: 0;
  position: absolute;
  transition: opacity .65s ease, transform 4.2s ease;
  width: 100%;
}

.rsb-sate-carousel img.is-active {
  opacity: 1;
  transform: scale(1.025);
}

.rsb-sate-controls {
  bottom: 16px;
  display: flex;
  gap: 8px;
  left: 16px;
  position: absolute;
  z-index: 2;
}

.rsb-sate-controls button {
  background: rgba(255, 253, 248, .62);
  border: 1px solid rgba(255, 255, 255, .55);
  border-radius: 999px;
  height: 10px;
  padding: 0;
  width: 34px;
}

.rsb-sate-controls button.is-active {
  background: #fffdf8;
}

.more-service-editorial-card:has(.rsb-construction-inline),
.rsb-exterior-construction-card {
  align-items: start;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: clamp(28px, 5vw, 82px);
}

.more-service-editorial-card:has(.rsb-construction-inline) > .more-service-editorial-image,
.rsb-exterior-construction-card > .more-service-editorial-image {
  display: none !important;
}

.rsb-construction-inline {
  align-self: start;
  justify-self: end;
  margin-top: 0;
  max-width: 560px;
}

.rsb-before-after-section {
  background: linear-gradient(135deg, #101714, #18201d 58%, #070a09);
  color: #fff;
  padding: clamp(76px, 8vw, 118px) 0 calc(clamp(88px, 8vw, 128px) + env(safe-area-inset-bottom));
}

.rsb-before-after-grid {
  display: grid;
  grid-template-columns: minmax(360px, .36fr) minmax(880px, 1.14fr);
  align-items: center;
  gap: clamp(28px, 3.2vw, 58px);
  max-width: min(1680px, calc(100vw - 96px));
  width: min(1680px, calc(100vw - 96px));
}

.rsb-before-after-copy h2,
.rsb-before-after-copy p {
  color: #fff;
}

.rsb-before-after-copy p {
  color: rgba(255, 255, 255, .76);
}

.rsb-ba-frame {
  aspect-ratio: 16 / 9;
  background: #0d1311;
  box-shadow: 0 28px 86px rgba(0, 0, 0, .38);
  cursor: ew-resize;
  min-height: clamp(460px, 34vw, 640px);
  overflow: hidden;
  position: relative;
  touch-action: none;
  user-select: none;
  width: min(100%, 1180px);
}
.rsb-ba-layer {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  inset: 0;
  position: absolute;
}

.rsb-ba-layer-after {
  background-image: var(--ba-after);
}

.rsb-ba-layer-before {
  background-image: var(--ba-before);
}

.rsb-ba-before-wrap {
  clip-path: inset(0 calc(100% - var(--split, 52%)) 0 0);
  inset: 0;
  overflow: hidden;
  position: absolute;
}

.rsb-ba-before-wrap::after {
  background: #fffdf8;
  content: "";
  height: 100%;
  left: var(--split, 52%);
  position: absolute;
  top: 0;
  transform: translateX(-1px);
  width: 2px;
}

.rsb-ba-range {
  appearance: none;
  background: transparent;
  cursor: ew-resize;
  height: 100%;
  inset: 0;
  opacity: 0;
  position: absolute;
  touch-action: none;
  width: 100%;
  z-index: 4;
}

.rsb-ba-range::-webkit-slider-thumb {
  appearance: none;
  background: #fffdf8;
  border: 3px solid var(--color-copper);
  border-radius: 999px;
  box-shadow: 0 8px 22px rgba(0, 0, 0, .32);
  height: 34px;
  width: 34px;
}

.rsb-ba-handle {
  animation: rsb-ba-pulse 1.9s ease-in-out infinite;
  background: #fffdf8;
  border: 3px solid var(--color-copper);
  border-radius: 999px;
  box-shadow: 0 8px 22px rgba(0, 0, 0, .32);
  height: 38px;
  left: var(--split, 52%);
  pointer-events: none;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 38px;
  z-index: 5;
}

.rsb-ba-frame .rsb-ba-handle {
  display: none !important;
}

@keyframes rsb-ba-pulse {
  0%, 100% {
    box-shadow: 0 8px 22px rgba(0, 0, 0, .32), 0 0 0 0 rgba(166, 95, 63, .24);
  }
  50% {
    box-shadow: 0 8px 22px rgba(0, 0, 0, .32), 0 0 0 10px rgba(166, 95, 63, 0);
  }
}

.rsb-ba-handle::before {
  background: #fffdf8;
  content: "";
  height: 999px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 2px;
}

.rsb-ba-label {
  background: rgba(16, 23, 20, .86);
  border: 1px solid rgba(255, 255, 255, .28);
  border-radius: 999px;
  bottom: 16px;
  color: #fff;
  font-size: .84rem;
  font-weight: 900;
  padding: 8px 12px;
  position: absolute;
  z-index: 3;
}

.rsb-ba-label-before {
  left: 16px;
}

.rsb-ba-label-after {
  right: 16px;
}

@media (max-width: 1280px) {
  .rsb-before-after-grid {
    grid-template-columns: 1fr;
    max-width: min(1120px, calc(100vw - 48px));
    width: min(1120px, calc(100vw - 48px));
  }

  .rsb-ba-frame {
    width: 100%;
  }
}

@media (max-width: 900px) {
  .rsb-sate-grid,
  .rsb-before-after-grid {
    grid-template-columns: 1fr;
  }

  .rsb-sate-carousel,
  .rsb-ba-frame {
    aspect-ratio: 4 / 3;
    min-height: 0;
    width: 100%;
  }

  .rsb-construction-inline {
    justify-self: start;
  }
}

html.rsb-more-services-page .site-header .desktop-nav a,
html.rsb-more-services-page .site-header.is-page .desktop-nav a,
html.rsb-more-services-page .site-header.is-scrolled .desktop-nav a,
html.rsb-more-services-page .site-header.menu-open .desktop-nav a,
html.rsb-more-services-page .site-header .phone-link,
html.rsb-more-services-page .site-header.is-page .phone-link,
html.rsb-more-services-page .site-header.is-scrolled .phone-link,
html.rsb-more-services-page .site-header.menu-open .phone-link,
html.rsb-more-services-page .site-header .mobile-menu-button,
html.rsb-more-services-page .site-header.is-page .mobile-menu-button,
html.rsb-more-services-page .site-header.is-scrolled .mobile-menu-button,
html.rsb-more-services-page .site-header.menu-open .mobile-menu-button {
  color: #18201d !important;
  background: rgba(16, 23, 20, .06) !important;
  border-color: rgba(24, 32, 29, .13) !important;
  text-shadow: none !important;
}

html.rsb-more-services-page .more-services-editorial-section {
  padding-bottom: clamp(16px, 2.4vw, 28px) !important;
}

/* Home hero carousel: full-section imagery with synchronized sales copy. */
.editorial-hero.rsb-hero-carousel-ready {
  isolation: isolate !important;
  min-height: 100dvh !important;
  overflow: hidden !important;
  position: relative !important;
}

.rsb-home-hero-carousel {
  background: #0a100e;
  inset: 0;
  overflow: hidden;
  position: absolute;
  z-index: 0;
}

.rsb-home-hero-carousel::after {
  background:
    linear-gradient(90deg, rgba(5, 10, 9, .9) 0%, rgba(5, 10, 9, .68) 38%, rgba(5, 10, 9, .16) 70%, rgba(5, 10, 9, .04) 100%),
    linear-gradient(180deg, rgba(5, 10, 9, .28), transparent 30%, rgba(5, 10, 9, .28));
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 3;
}

.rsb-home-hero-slide {
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: center center;
  opacity: 0;
  position: absolute;
  transform: translate3d(6%, 0, 0) scale(1.035);
  transition:
    opacity 1.05s cubic-bezier(.22, .72, .2, 1),
    transform 1.2s cubic-bezier(.22, .72, .2, 1);
  visibility: hidden;
  width: 100%;
  will-change: opacity, transform;
  z-index: 1;
}

.rsb-home-hero-slide.is-active {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  visibility: visible;
  z-index: 2;
}

.rsb-home-hero-slide.is-leaving {
  opacity: 0;
  transform: translate3d(-4%, 0, 0) scale(1.02);
  visibility: visible;
  z-index: 1;
}

.editorial-hero.rsb-hero-carousel-ready .hero-content {
  align-content: center !important;
  align-items: start !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-height: 100dvh !important;
  padding: clamp(120px, 14vh, 164px) 0 clamp(72px, 8vh, 96px) !important;
  position: relative !important;
  width: min(100% - 96px, 1680px) !important;
  z-index: 4 !important;
}

.editorial-hero.rsb-hero-carousel-ready .hero-copy {
  margin: 0 !important;
  max-width: min(840px, 62vw) !important;
}

.editorial-hero.rsb-hero-carousel-ready .hero-copy .eyebrow {
  color: #efb58f !important;
  text-shadow: 0 2px 18px rgba(0, 0, 0, .42);
}

.editorial-hero.rsb-hero-carousel-ready h1 {
  color: #fff !important;
  font-size: clamp(3.4rem, 5.1vw, 6.1rem) !important;
  line-height: .9 !important;
  max-width: 840px !important;
  text-shadow: 0 4px 30px rgba(0, 0, 0, .38);
}

.editorial-hero.rsb-hero-carousel-ready .hero-description {
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  align-items: center !important;
  background: rgba(7, 13, 11, .68) !important;
  border: none !important;
  border-radius: 6px !important;
  bottom: auto !important;
  color: rgba(255, 255, 255, .9) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  text-align: center !important;
  font-size: clamp(1rem, 1.24vw, 1.2rem) !important;
  left: auto !important;
  line-height: 1.55 !important;
  margin: clamp(22px, 3vh, 32px) 0 0 !important;
  max-width: 680px !important;
  min-height: 165px;
  padding: 18px 20px !important;
  position: relative !important;
  transition: opacity .28s ease, transform .28s ease !important;
}

.editorial-hero.rsb-hero-carousel-ready .hero-description.is-changing {
  opacity: 0 !important;
  transform: translate3d(-14px, 0, 0) !important;
}

.editorial-hero.rsb-hero-carousel-ready .hero-actions {
  bottom: auto !important;
  left: auto !important;
  margin: 18px 0 0 !important;
  position: relative !important;
}

.editorial-hero.rsb-hero-carousel-ready .hero-actions a {
  box-shadow: 0 16px 38px rgba(0, 0, 0, .22);
}

.editorial-hero.rsb-hero-carousel-ready .hero-proof {
  display: none !important;
}

.rsb-home-hero-controls {
  align-items: center;
  display: flex;
  gap: 8px;
  margin-top: 18px;
  order: 5;
}

.rsb-home-hero-controls button {
  background: transparent;
  border: 0;
  cursor: pointer;
  height: 24px;
  padding: 9px 0;
  width: 42px;
}

.rsb-home-hero-controls button span {
  background: rgba(255, 255, 255, .34);
  display: block;
  height: 2px;
  transition: background .25s ease, transform .25s ease;
  width: 100%;
}

.rsb-home-hero-controls button.is-active span {
  background: #efb58f;
  transform: scaleY(2);
}

.rsb-home-hero-controls button:focus-visible {
  outline: 2px solid #efb58f;
  outline-offset: 3px;
}

/* Lighter glass surfaces so photography remains visible underneath. */
.editorial-hero.rsb-hero-carousel-ready .hero-description {
  background: rgba(7, 13, 11, .34) !important;
  border-color: transparent !important;
  box-shadow: 0 16px 42px rgba(0, 0, 0, .16) !important;
  backdrop-filter: blur(8px) saturate(112%) !important;
  -webkit-backdrop-filter: blur(8px) saturate(112%) !important;
  text-shadow: 0 2px 10px rgba(0, 0, 0, .62);
}
html.rsb-more-services-page .more-services-topbar,
html.rsb-more-services-page .more-services-hero .more-services-actions {
  display: none !important;
}

html.rsb-more-services-page .more-services-hero-inner {
  gap: 0 !important;
}

html.rsb-more-services-page .rsb-sate-section {
  padding-top: clamp(22px, 3vw, 34px) !important;
  scroll-margin-top: 96px;
}

html.rsb-more-services-page .more-services-editorial-list > .rsb-exterior-construction-card {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  align-items: start !important;
  column-gap: clamp(42px, 5vw, 82px) !important;
  row-gap: 28px !important;
}

html.rsb-more-services-page .more-services-editorial-list > .rsb-exterior-construction-card > .more-service-editorial-copy,
html.rsb-more-services-page .more-services-editorial-list > .rsb-exterior-construction-card > .rsb-construction-inline {
  min-width: 0 !important;
}

html.rsb-more-services-page .more-services-editorial-list > .rsb-exterior-construction-card > .rsb-construction-inline {
  justify-self: end !important;
  max-width: 560px !important;
}

html.rsb-more-services-page .rsb-slide-text {
  opacity: 0;
  transform: translate3d(0, 22px, 0);
  transition:
    opacity .72s cubic-bezier(.2, .7, .2, 1) var(--rsb-slide-delay, 0ms),
    transform .72s cubic-bezier(.2, .7, .2, 1) var(--rsb-slide-delay, 0ms);
  will-change: opacity, transform;
}

html.rsb-more-services-page .rsb-slide-text.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

html.rsb-more-services-page .more-services-hero .rsb-slide-text {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

.cinematic-process {
  border-top: 0 !important;
  border-bottom: 0 !important;
}

.cinematic-process {
  margin-top: -1px !important;
  background-color: #101714 !important;
  box-shadow: 0 -2px 0 #101714 !important;
}

body.contact-page .contact-header,
body.contact-page .contact-shell,
body.contact-page .contact-steps,
body.contact-page .rsb-contact-trust .contact-shell {
  width: min(100% - 48px, 1680px) !important;
  max-width: 1680px !important;
}

body.contact-page .contact-header {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  background: transparent !important;
  color: #fff !important;
  border-bottom: 0 !important;
}

body.contact-page .contact-nav a,
body.contact-page .contact-phone {
  color: #fff !important;
  background: rgba(255, 255, 255, .08) !important;
  border-color: rgba(255, 255, 255, .28) !important;
  box-shadow: 0 18px 42px rgba(0, 0, 0, .18) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

body.contact-page .contact-hero {
  width: 100% !important;
  max-width: none !important;
  min-height: 100svh !important;
  margin-inline: 0 !important;
  display: flex !important;
  align-items: center !important;
  padding: clamp(98px, 8vw, 118px) clamp(24px, 5vw, 84px) clamp(38px, 4vw, 56px) !important;
  background:
    linear-gradient(90deg, rgba(7, 13, 11, .95) 0%, rgba(7, 13, 11, .84) 38%, rgba(7, 13, 11, .38) 68%, rgba(7, 13, 11, .08) 100%),
    url("reformas/contacto-visita.png") 62% center / cover no-repeat !important;
  border-bottom: 1px solid rgba(16, 23, 20, .12) !important;
}

body.contact-page .contact-copy {
  width: min(760px, 100%) !important;
}

body.contact-page .contact-hero h1 {
  color: #fff !important;
  max-width: 690px !important;
  font-size: clamp(2.8rem, 4.15vw, 4.8rem) !important;
  letter-spacing: 0 !important;
  line-height: .94 !important;
}

body.contact-page .contact-lead {
  color: rgba(255, 255, 255, .82) !important;
  margin-top: 16px !important;
  font-size: clamp(1rem, 1.08vw, 1.12rem) !important;
  line-height: 1.5 !important;
}

body.contact-page .contact-card {
  color: #fff !important;
  background: rgba(7, 13, 11, .36) !important;
  border-color: rgba(255, 255, 255, .22) !important;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .24) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}

body.contact-page .contact-card p {
  color: rgba(255, 255, 255, .78) !important;
}

body.contact-page .contact-card {
  margin-top: 18px !important;
  padding: clamp(16px, 1.8vw, 22px) !important;
}

body.contact-page .contact-card-top {
  grid-template-columns: minmax(150px, 210px) minmax(0, 1fr) !important;
  gap: 16px !important;
}

body.contact-page .contact-card h2 {
  font-size: clamp(1.65rem, 2vw, 2.2rem) !important;
}

body.contact-page .contact-buttons {
  gap: 10px !important;
  margin-top: 16px !important;
}

body.contact-page .contact-buttons a {
  min-height: 52px !important;
}

body.contact-page .contact-proof-lines {
  gap: 10px !important;
  margin-top: 16px !important;
}

body.contact-page .contact-proof-lines p {
  min-height: 68px !important;
  padding: 12px 16px !important;
}

body.contact-page .contact-buttons a {
  color: #fff !important;
  background: rgba(255, 255, 255, .08) !important;
  border-color: rgba(255, 255, 255, .24) !important;
}

body.contact-page .contact-buttons a:first-child {
  color: #101714 !important;
  background: rgba(255, 253, 248, .94) !important;
  border-color: rgba(255, 255, 255, .5) !important;
}

body.contact-page main {
  padding-top: 0 !important;
}

body.contact-page .contact-card,
body.contact-page .step-card {
  border-radius: 8px !important;
}

body.contact-page .rsb-contact-trust {
  background: #101714 !important;
  color: #fff !important;
  padding: clamp(64px, 8vw, 104px) 0 calc(clamp(74px, 8vw, 116px) + env(safe-area-inset-bottom)) !important;
}

body.contact-page .rsb-contact-trust .contact-section-head {
  display: grid !important;
  grid-template-columns: minmax(0, .54fr) minmax(0, .46fr) !important;
  gap: clamp(24px, 4vw, 56px) !important;
  align-items: end !important;
  margin-bottom: 28px !important;
}

body.contact-page .rsb-contact-trust h2,
body.contact-page .rsb-contact-trust .contact-section-kicker {
  color: #fff !important;
}

body.contact-page .rsb-contact-trust .section-lead {
  color: rgba(255, 255, 255, .72) !important;
}

/* Bath: same aspect-ratio as kitchen (4/3 landscape) */
.work-example-bath .work-example-media {
  aspect-ratio: 4 / 3 !important;
  min-height: 0 !important;
  max-height: none !important;
  width: 100% !important;
  justify-self: auto !important;
}

/* Tablet: recorta aire muerto del hero y del proceso horizontal. */

@media (min-width: 761px) and (max-width: 1024px) {
  .cinematic-process {
    height: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
  }
}
/* Stable process carousel: one state source for autoplay, arrows and dots. */
.cinematic-process.rsb-stable-process {
  background: radial-gradient(circle at 76% 30%, rgba(50, 74, 95, .17), transparent 36%), linear-gradient(135deg, #101714, #07100d);
  height: auto !important;
  min-height: 100dvh;
  overflow: hidden;
  position: relative;
}

.cinematic-process.rsb-stable-process > :not(.rsb-process-carousel) {
  display: none !important;
}

.rsb-process-carousel {
  color: #fff;
  min-height: 100dvh;
  overflow: visible;
  position: relative;
}

.rsb-process-inner {
  align-items: center;
  display: grid;
  gap: clamp(42px, 7vw, 110px);
  grid-template-columns: minmax(340px, .72fr) minmax(520px, 1.2fr);
  margin-inline: auto;
  min-height: 100dvh;
  padding: clamp(110px, 12vh, 148px) 6vw clamp(84px, 9vh, 112px);
  width: min(100%, 1720px);
}

.rsb-process-copy {
  position: relative;
  z-index: 2;
}

.rsb-process-copy > .eyebrow, .rsb-process-heading > .eyebrow {
  color: #efb58f;
}

.rsb-process-copy > h2, .rsb-process-heading > h2 {
  font-family: "Nippo", var(--font-sans), Arial, sans-serif;
  font-size: clamp(2.9rem, 4.2vw, 5rem);
  font-weight: 700;
  letter-spacing: 0;
  line-height: .96;
  margin: 0;
  max-width: 690px;
  text-wrap: balance;
}

.rsb-process-card {
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background: rgba(7, 13, 11, .62);
  border: 1px solid rgba(255, 255, 255, .17);
  border-radius: 8px;
  margin-top: 30px;
  min-height: 272px;
  padding: 28px 30px;
  transition: opacity .16s ease, transform .22s ease;
}

.rsb-process-eyebrow {
  color: #efb58f;
  display: block;
  font-size: .82rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.rsb-process-card h3 {
  font-family: var(--font-serif), Georgia, serif;
  font-size: clamp(2.5rem, 3.7vw, 4rem);
  line-height: .98;
  margin: 18px 0 0;
  max-width: 620px;
}

.rsb-process-card > p {
  color: rgba(255, 255, 255, .78);
  font-size: clamp(1rem, 1.2vw, 1.14rem);
  line-height: 1.55;
  margin: 16px 0 0;
  max-width: 620px;
}

.rsb-process-cta {
  align-items: center;
  background: #fff;
  border-radius: 6px;
  color: #18201d;
  display: inline-flex;
  font-weight: 900;
  gap: 10px;
  margin-top: 20px;
  min-height: 46px;
  padding: 0 18px;
}

.rsb-process-cta[hidden] {
  display: none;
}

.rsb-process-progress {
  background: rgba(255, 255, 255, .22);
  height: 7px;
  margin-top: 30px;
  max-width: 620px;
  overflow: hidden;
}

.rsb-process-progress span {
  background: #f1c8ae;
  display: block;
  height: 100%;
  transform: scaleX(.2);
  transform-origin: left center;
  transition: transform .32s ease;
  width: 100%;
}

.rsb-process-visual {
  aspect-ratio: 16 / 10;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 8px;
  box-shadow: 0 34px 100px rgba(0, 0, 0, .38);
  overflow: hidden;
  position: relative;
  transition: opacity .16s ease, transform .28s cubic-bezier(.22, .8, .22, 1);
}

.rsb-process-visual::after {
  background: linear-gradient(90deg, rgba(7, 13, 11, .16), transparent 52%);
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
}

.rsb-process-visual img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.rsb-process-carousel.is-changing .rsb-process-card,
.rsb-process-carousel.is-changing .rsb-process-visual {
  opacity: .18;
}

.rsb-process-carousel.is-forward.is-changing .rsb-process-visual {
  transform: translate3d(18px, 0, 0) scale(.992);
}

.rsb-process-carousel.is-backward.is-changing .rsb-process-visual {
  transform: translate3d(-18px, 0, 0) scale(.992);
}

.rsb-process-arrow {
  align-items: center;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  background: rgba(10, 17, 14, .62);
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 999px;
  color: #fff;
  display: flex;
  font-family: Arial, sans-serif;
  font-size: 2.1rem;
  height: 56px;
  justify-content: center;
  line-height: 1;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  z-index: 4;
}

.rsb-process-arrow.is-previous {
  left: 22px;
}

.rsb-process-arrow.is-next {
  right: 22px;
}

.rsb-process-arrow:hover,
.rsb-process-arrow:focus-visible {
  background: rgba(255, 255, 255, .14);
  border-color: rgba(241, 200, 174, .72);
}

.rsb-process-dots {
  bottom: 28px;
  display: flex;
  gap: 8px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  z-index: 4;
}

.rsb-process-dots button {
  background: transparent;
  border: 0;
  height: 26px;
  padding: 11px 0;
  width: 44px;
}

.rsb-process-dots button span {
  background: rgba(255, 255, 255, .28);
  display: block;
  height: 2px;
  transition: background .2s ease, transform .2s ease;
}

.rsb-process-dots button.is-active span {
  background: #f1c8ae;
  transform: scaleY(2);
}

/* Process composition refined from the Figma reference. */
.cinematic-process.rsb-stable-process {
  min-height: 760px;
  scroll-margin-top: 72px;
}

.cinematic-process.rsb-stable-process .rsb-process-carousel {
  min-height: 760px;
}

.cinematic-process.rsb-stable-process .rsb-process-inner {
  gap: clamp(48px, 5vw, 76px);
  grid-template-columns: minmax(360px, 500px) minmax(480px, 610px);
  min-height: 760px;
  padding: 104px clamp(54px, 6vw, 92px) 78px;
  width: min(100%, 1320px);
}

.cinematic-process.rsb-stable-process .rsb-process-copy > h2, .rsb-process-heading > h2 {
  font-size: clamp(2.2rem, 3.2vw, 3.8rem);
  max-width: 540px;
}

.cinematic-process.rsb-stable-process .rsb-process-card {
  margin-top: 24px;
  min-height: 230px;
  padding: 24px 26px;
}

.cinematic-process.rsb-stable-process .rsb-process-card h3 {
  font-size: clamp(2.25rem, 3vw, 3.25rem);
  margin-top: 14px;
}

.cinematic-process.rsb-stable-process .rsb-process-card > p {
  font-size: 1rem;
  margin-top: 13px;
}

.cinematic-process.rsb-stable-process .rsb-process-progress {
  height: 5px;
  margin-top: 24px;
}

.cinematic-process.rsb-stable-process .rsb-process-visual {
  aspect-ratio: 16 / 10;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  min-width: 0;
  overflow: visible;
  position: relative;
}

.cinematic-process.rsb-stable-process .rsb-process-visual::after {
  display: none;
}

.cinematic-process.rsb-stable-process .rsb-process-photo {
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 7px;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .34);
  inset: 0;
  margin: 0;
  overflow: hidden;
  position: absolute;
  transform-origin: center;
  transition: opacity .32s ease, transform .58s cubic-bezier(.22, .8, .22, 1);
}

.cinematic-process.rsb-stable-process .rsb-process-photo img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.cinematic-process.rsb-stable-process .rsb-process-photo-1 {
  transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
  z-index: 4;
}

.cinematic-process.rsb-stable-process .rsb-process-photo-2 {
  transform: translate3d(20px, -14px, 0) rotate(2.2deg) scale(.975);
  z-index: 3;
}

.cinematic-process.rsb-stable-process .rsb-process-photo-3 {
  transform: translate3d(38px, -26px, 0) rotate(4deg) scale(.95);
  z-index: 2;
}

.cinematic-process.rsb-stable-process .rsb-process-photo-4 {
  transform: translate3d(54px, -36px, 0) rotate(5.5deg) scale(.925);
  z-index: 1;
}

.cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-inner {
  grid-template-columns: minmax(0, 650px);
  justify-content: center;
}

.cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-copy {
  width: 100%;
}

.cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-visual {
  display: none;
}

.cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-card {
  background: linear-gradient(145deg, rgba(241, 200, 174, .12), rgba(7, 13, 11, .68));
  min-height: 260px;
}

/* Natural card-dealing motion: fixed photos move between depth slots. */
.cinematic-process.rsb-stable-process .rsb-process-photo {
  backface-visibility: hidden;
  transform-origin: 48% 52%;
  transition:
    transform 1250ms cubic-bezier(.42, 0, .18, 1),
    opacity 1250ms cubic-bezier(.42, 0, .18, 1),
    box-shadow 1250ms cubic-bezier(.42, 0, .18, 1),
    filter 1250ms cubic-bezier(.42, 0, .18, 1);
  transition-delay: 0ms !important;
  will-change: transform, opacity;
}

.cinematic-process.rsb-stable-process .rsb-process-photo[data-slot="0"] {
  filter: brightness(1) saturate(1);
  opacity: 1;
  transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
  z-index: 4;
}

.cinematic-process.rsb-stable-process .rsb-process-photo[data-slot="1"] {
  filter: brightness(.88) saturate(.9);
  opacity: .5;
  transform: translate3d(20px, -14px, 0) rotate(2.2deg) scale(.975);
  z-index: 3;
}

.cinematic-process.rsb-stable-process .rsb-process-photo[data-slot="2"] {
  filter: brightness(.76) saturate(.82);
  opacity: .28;
  transform: translate3d(38px, -26px, 0) rotate(4deg) scale(.95);
  z-index: 2;
}

.cinematic-process.rsb-stable-process .rsb-process-photo[data-slot="3"] {
  filter: brightness(.68) saturate(.76);
  opacity: .14;
  transform: translate3d(54px, -36px, 0) rotate(5.5deg) scale(.925);
  z-index: 1;
}

.cinematic-process.rsb-stable-process .rsb-process-photo.is-exiting-forward {
  filter: brightness(.96) saturate(.96);
  opacity: 0;
  transform: translate3d(-42px, 14px, 0) rotate(-2.4deg) scale(.988);
  transition:
    transform 1250ms cubic-bezier(.42, 0, .18, 1),
    opacity 1250ms cubic-bezier(.42, 0, .18, 1),
    filter 1250ms cubic-bezier(.42, 0, .18, 1);
  z-index: 6;
}

.cinematic-process.rsb-stable-process .rsb-process-photo.is-entering-backward {
  z-index: 6;
}

.cinematic-process.rsb-stable-process .rsb-process-photo.is-resetting {
  opacity: 0 !important;
  transition: none !important;
}

.cinematic-process.rsb-stable-process .rsb-process-carousel.is-changing .rsb-process-visual {
  opacity: 1;
  transform: none;
}

.cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-visual {
  display: block;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  transform: translate3d(36px, 8px, 0) scale(.965);
  transition:
    opacity 780ms cubic-bezier(.2, .65, .24, 1),
    transform 1080ms cubic-bezier(.2, .72, .22, 1);
}

.cinematic-process.rsb-stable-process .rsb-process-carousel:not(.is-final) .rsb-process-visual {
  opacity: 1;
  transition:
    opacity 880ms cubic-bezier(.2, .65, .24, 1),
    transform 1180ms cubic-bezier(.2, .72, .22, 1);
}

/* Fix 1: hero carousel controls (3 dashes) always visible in viewport */
.editorial-hero.rsb-hero-carousel-ready .hero-content {
  padding-top: clamp(80px, 10vh, 120px) !important;
  padding-bottom: clamp(32px, 4vh, 56px) !important;
}

.editorial-hero.rsb-hero-carousel-ready .hero-description {
  min-height: 88px !important;
}

/* ===== RSB UI PATCHES v3 2026-06-12 ===== */

/* Overflow fix: prevent horizontal scroll */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw !important;
}

/* Hide obra real badge (removed from JS; hide any remnant) */
/* Bigger process arrows (rsb-carousel) */
.rsb-process-arrow {
  height: 66px !important;
  width: 66px !important;
  background: rgba(10, 17, 14, .78) !important;
  border: 1.5px solid rgba(255, 255, 255, .36) !important;
  box-shadow: 0 4px 18px rgba(0,0,0,.32) !important;
}
.rsb-process-arrow:hover,
.rsb-process-arrow:focus-visible {
  background: rgba(10, 17, 14, .92) !important;
  border-color: rgba(241, 200, 174, .86) !important;
}
.rsb-process-arrow.is-previous { left: 18px !important; }
.rsb-process-arrow.is-next    { right: 18px !important; }

/* Play/Pause button (rsb-carousel) */
.rsb-process-playpause {
  align-items: center;
  background: rgba(10, 17, 14, .62);
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 999px;
  bottom: 28px;
  color: rgba(255, 255, 255, .82);
  cursor: pointer;
  display: flex;
  height: 40px;
  justify-content: center;
  left: 50%;
  position: absolute;
  transform: translateX(calc(-50% + 56px));
  transition: background .18s ease, border-color .18s ease;
  width: 40px;
  z-index: 5;
}
.rsb-process-playpause:hover,
.rsb-process-playpause:focus-visible {
  background: rgba(10, 17, 14, .9);
  border-color: rgba(241, 200, 174, .72);
  color: #fff;
}
/* Gestión integral: center cards vertically within section */
.turnkey-strip {
  padding-top: clamp(48px, 6vh, 72px) !important;
  padding-bottom: clamp(48px, 6vh, 72px) !important;
}
.turnkey-grid {
  align-items: center !important;
}

/* Contacto: card-top now has only h2 — remove 2-col grid */
.contact-card-top {
  grid-template-columns: 1fr !important;
}

/* Contacto: proof-lines inside card — reset outer margin/width */
.contact-card .contact-proof-lines {
  width: 100% !important;
  margin-top: 14px !important;
}

/* Contacto: rsb-contact-trust with no cards — minimal padding */
.rsb-contact-trust .contact-shell {
  padding-top: 0 !important;
  padding-bottom: clamp(24px, 4vw, 48px) !important;
}


/* ─── Process nav: grid sibling of .rsb-process-visual inside .rsb-process-inner ─── */
.rsb-process-nav {
  align-self: start;
  display: flex;
  align-items: center;
  justify-content: space-between;
  grid-column: 2;
  padding: 10px 20px;
  pointer-events: none;
  z-index: 6;
}
.rsb-process-nav > * {
  pointer-events: auto;
}
.rsb-process-nav .rsb-process-arrow {
  position: static !important;
  top: auto !important;
  transform: none !important;
}
.rsb-process-nav .rsb-process-playpause {
  position: static !important;
  bottom: auto !important;
  left: auto !important;
  transform: none !important;
}
/* Dots hidden (progress bar in copy replaces them) */
.rsb-process-nav .rsb-process-dots {
  display: none !important;
}
/* Tablet + mobile: single-column grid, reorder rows: visual=1, nav=2, copy=3 */

/* ─── Hero CTA buttons: hide on mobile (sticky bar covers them) ─── */

/* ─── Logo: prevent GPU compositing blur on mobile (caused by backdrop-filter on hero) ─── */

/* ─── Process section: override late-cascade min-height on mobile ─── */


/* ─── SATE eyebrow: same warm colour as kitchen/bath ─── */
.rsb-sate-copy .eyebrow {
  color: #efb58f !important;
}

/* ══════════════════════════════════════════════════════════════════
   MOBILE-FIRST RESPONSIVE SYSTEM — 320 px → 760 px
   All measurements fluid: clamp() · svh · vw · % · rem
   ══════════════════════════════════════════════════════════════════ */

/* ── 1. Global: stop horizontal overflow, safe box-sizing ── */

/* ── 2. Sticky CTA bar: safe area for notch / home-indicator ── */

/* ── 3. Hero section ── */

/* ── 4. Process section: fluid, fits any screen height ── */

/* ── 5. Work examples: fluid images, safe copy size ── */

/* ── 6. SATE section fluid ── */

/* ── 7. Extra-small screens ≤ 390 px ── */
@media (max-width: 390px) {
  .rsb-process-heading h2,
  .rsb-process-copy > h2, .rsb-process-heading > h2 {
    font-size: clamp(1.35rem, 9vw, 1.65rem) !important;
  }
  .rsb-process-visual {
    max-height: clamp(155px, 34svh, 230px) !important;
  }
  .rsb-process-card h3 {
    font-size: clamp(1.2rem, 8.5vw, 1.5rem) !important;
  }
  .work-example-copy h2,
  .rsb-sate-copy h2 {
    font-size: clamp(1.3rem, 8.5vw, 1.75rem) !important;
  }
  .editorial-hero.rsb-hero-carousel-ready h1 {
    font-size: clamp(1.9rem, 11vw, 2.6rem) !important;
  }
}

/* ── 8. Landscape mobile: redistribute vertical space ── */
@media (max-width: 760px) and (orientation: landscape) and (max-height: 500px) {
  .rsb-process-inner {
    padding: 28px clamp(12px, 4vw, 20px) 16px !important;
    gap: 8px !important;
  }
  .rsb-process-visual {
    max-height: 52svh !important;
  }
  .rsb-process-heading h2,
  .rsb-process-copy > h2, .rsb-process-heading > h2 {
    font-size: clamp(1.1rem, 5.5vw, 1.5rem) !important;
  }
  .rsb-process-card h3 {
    font-size: clamp(1rem, 5vw, 1.35rem) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   PROCESO HORIZONTAL — LAYOUT MÓVIL DEFINITIVO
   Debe estar al final para ganar la cascada contra todo lo anterior
   ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════
   PROCESO HORIZONTAL — LAYOUT DESKTOP DEFINITIVO (≥ 761 px)
   Sin este bloque el auto-placement de grid pone copy en col 2
   y visual en col 1 — al revés de la referencia.
   ═══════════════════════════════════════════════════════════════ */
@media (min-width: 761px) {

  /* Grid 3 filas: col1=[heading/card/—], col2=[foto centrada (filas1-2)/flechas] */
  .cinematic-process.rsb-stable-process .rsb-process-inner {
    gap: 16px clamp(48px, 5vw, 76px);
    grid-template-columns: minmax(300px, 38%) 1fr;
    grid-template-rows: auto auto auto;
    align-items: start;
    padding: 56px clamp(54px, 6vw, 92px) 24px;
  }

  /* Col izquierda fila 1: eyebrow + h2 */
  .cinematic-process.rsb-stable-process .rsb-process-heading {
    grid-column: 1;
    grid-row: 1;
    align-self: start;
  }

  /* Col derecha filas 1-2: foto centrada verticalmente */
  .cinematic-process.rsb-stable-process .rsb-process-visual {
    grid-column: 2 !important;
    grid-row: 1 / span 2 !important;
    align-self: center !important;
    aspect-ratio: 16 / 10 !important;
    width: 100% !important;
  }

  /* Col izquierda fila 2: tarjeta pegada al heading */
  .cinematic-process.rsb-stable-process .rsb-process-copy {
    grid-column: 1;
    grid-row: 2;
    align-self: start;
  }

  /* Col derecha fila 3: flechas ← → pegadas justo bajo la foto */
  .cinematic-process.rsb-stable-process .rsb-process-nav {
    grid-column: 2 !important;
    grid-row: 3 !important;
    align-self: start !important;
    justify-content: space-between !important;
    gap: 0 !important;
    padding: 0 !important;
    margin-top: -107px !important;
  }

  /* Tarjeta sin margen extra arriba — ya tiene row-gap de 16px */
  .cinematic-process.rsb-stable-process .rsb-process-card {
    margin-top: 0 !important;
    min-height: 180px;
  }

  /* Botones: más pequeños y sin contorno */
  .cinematic-process.rsb-stable-process .rsb-process-nav .rsb-process-arrow,
  .cinematic-process.rsb-stable-process .rsb-process-nav .rsb-process-playpause {
    height: 44px !important;
    width: 44px !important;
    border: none !important;
    box-shadow: none !important;
  }

  /* Slide 5 final: mantener grid 2-col — la foto se desvanece donde está, sin salto de layout */
  .cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-inner {
    grid-template-columns: minmax(300px, 38%) 1fr !important;
    justify-content: unset !important;
  }
  .cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-visual {
    display: block !important;
    opacity: 0 !important;
    pointer-events: none !important;
    position: relative !important;
    transform: none !important;
    transition: opacity 600ms ease !important;
  }
}

/* ─── MOBILE: Work examples — orden texto/imagen (bloque único autoritativo)
   El CSS principal (≤1024px) fuerza bath copy:order:2 / media:order:1.
   Estas reglas al final del archivo ganan en cascada.
   ─────────────────────────────────────────────────────────────────────── */

/* ─── MOBILE: Espaciado compacto work-examples → SATE
   Especificidad mayor que padding-block anteriores para ganar en cascada.
   ─────────────────────────────────────────────────────────────────────── */

/* ─── Scroll-hide header — mobile/tablet ───────────────────────────────── */
.site-header {
  transition: transform 0.28s cubic-bezier(.4, 0, .2, 1) !important;
}
.site-header.rsb-header-hidden {
  transform: translateY(-100%) !important;
  pointer-events: none !important;
}
.site-header.menu-open.rsb-header-hidden {
  transform: none !important;
  pointer-events: auto !important;
}

@media (max-width: 1100px) {
  html.rsb-more-services-page .more-service-editorial-card:has(.rsb-construction-inline),
  html.rsb-more-services-page .rsb-exterior-construction-card {
    grid-template-columns: 1fr !important;
    gap: clamp(22px, 5vw, 34px) !important;
  }

  html.rsb-more-services-page .rsb-construction-inline {
    justify-self: start !important;
    max-width: min(100%, 620px) !important;
  }

  html.rsb-more-services-page .more-services-editorial-list > .rsb-exterior-construction-card {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: clamp(24px, 5vw, 36px) !important;
  }

  html.rsb-more-services-page .more-services-editorial-list > .rsb-exterior-construction-card > .rsb-construction-inline {
    justify-self: start !important;
    max-width: min(100%, 680px) !important;
  }
}

@media (max-width: 1024px) {
  .site-header,
  .site-header.is-page,
  .site-header.is-scrolled,
  .site-header.menu-open {
    min-height: 72px !important;
  }

  .more-services-hero {
    padding: 16px 0 34px !important;
  }

  .more-services-magazine-layout {
    grid-template-columns: 1fr !important;
    transform: none !important;
    margin-bottom: 0 !important;
  }

  .magazine-photo-left {
    min-height: 270px !important;
  }

  .rsb-process-inner {
    gap: 28px;
    grid-template-columns: 1fr;
    padding: 92px 24px 92px;
    width: min(100%, 780px);
  }

  .rsb-process-copy > h2, .rsb-process-heading > h2 {
    font-size: clamp(2.5rem, 7vw, 4rem);
  }

  .rsb-process-card {
    min-height: 226px;
  }

  .rsb-process-visual {
    aspect-ratio: 16 / 9;
    grid-row: 1;
  }

  .rsb-process-arrow {
    bottom: 24px;
    top: auto;
    transform: none;
  }

  .rsb-process-arrow.is-previous {
    left: 24px;
  }

  .rsb-process-arrow.is-next {
    right: 24px;
  }

  .cinematic-process.rsb-stable-process,
  .cinematic-process.rsb-stable-process .rsb-process-carousel {
    min-height: auto;
  }

  .cinematic-process.rsb-stable-process .rsb-process-inner {
    gap: 34px;
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 92px 24px 106px;
    width: min(100%, 760px);
  }

  .cinematic-process.rsb-stable-process .rsb-process-visual {
    grid-row: 1;
    margin-inline: auto;
    width: min(88%, 580px);
  }

  .cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-inner {
    min-height: 620px;
  }

  .rsb-process-nav {
    grid-column: auto !important;
    grid-row: 2 !important;
    justify-content: center !important;
    gap: 16px !important;
    padding: 14px 20px !important;
  }
  .rsb-process-copy {
    grid-row: 3 !important;
  }
}

@media (min-width: 761px) and (max-width: 1280px) {
  .editorial-hero.rsb-hero-carousel-ready,
  .editorial-hero.rsb-hero-carousel-ready .hero-content {
    min-height: 100dvh !important;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-content {
    padding: 100px 0 44px !important;
    width: min(100% - 48px, 980px) !important;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-copy {
    max-width: min(720px, 76vw) !important;
  }

  .editorial-hero.rsb-hero-carousel-ready h1 {
    font-size: clamp(3rem, 6.2vw, 4.8rem) !important;
    max-width: 720px !important;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-description {
    max-width: 620px !important;
    min-height: 165px;
    align-items: center !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    text-align: center !important;
  }

  .editorial-hero,
  .editorial-hero .hero-content {
    min-height: auto !important;
  }

  .editorial-hero .hero-content {
    padding-top: clamp(78px, 8vw, 104px) !important;
    padding-bottom: clamp(34px, 4vw, 52px) !important;
    gap: clamp(16px, 2.4vw, 26px) !important;
  }

  .editorial-hero .hero-description {
    margin-top: 12px !important;
  }

  .editorial-hero .hero-actions {
    margin-top: 12px !important;
  }
}

@media (max-width: 760px) {
  /* Hero: auto height so it fits content, no empty space below */
  .editorial-hero,
  .editorial-hero.rsb-hero-carousel-ready,
  .editorial-hero.rsb-hero-carousel-ready .hero-content {
    min-height: auto !important;
  }

  .rsb-home-hero-carousel::after {
    background:
      linear-gradient(180deg, rgba(5, 10, 9, .52) 0%, rgba(5, 10, 9, .5) 35%, rgba(5, 10, 9, .84) 100%),
      linear-gradient(90deg, rgba(5, 10, 9, .72), rgba(5, 10, 9, .12));
  }

  .rsb-home-hero-slide {
    object-position: 68% center;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-content {
    justify-content: flex-start !important;
    padding: 76px 0 48px !important;
    width: min(100% - 24px, 520px) !important;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-copy {
    max-width: 100% !important;
    width: 100% !important;
  }

  .editorial-hero.rsb-hero-carousel-ready h1 {
    font-size: clamp(2.18rem, 10.2vw, 3.15rem) !important;
    line-height: .96 !important;
    max-width: 22rem !important;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-description {
    align-items: center !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    text-align: center !important;
    font-size: .94rem !important;
    line-height: 1.46 !important;
    margin-top: 16px !important;
    max-width: 100% !important;
    min-height: 200px;
    padding: 14px 15px !important;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-actions {
    flex-direction: row !important;
    gap: 10px !important;
    margin-top: 14px !important;
    width: 100%;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-actions a {
    flex: 1 1 0;
    min-width: 0;
    padding-inline: 12px !important;
  }

  .rsb-home-hero-controls {
    margin-top: 12px;
  }

  .rsb-home-hero-controls button {
    width: 36px;
  }

  .cinematic-process.rsb-stable-process,
  .rsb-process-carousel,
  .rsb-process-inner {
    min-height: auto;
  }

  .rsb-process-inner {
    gap: 12px;
    grid-template-columns: 1fr !important;
    min-height: 0 !important;
    padding: 48px 12px 36px;
    width: 100% !important;
  }

  .rsb-process-heading h2,
  .rsb-process-copy > h2, .rsb-process-heading > h2 {
    font-size: clamp(1.8rem, 8vw, 2.4rem) !important;
    line-height: 1.04 !important;
  }

  .rsb-process-card {
    margin-top: 0;
    min-height: 0;
    padding: 16px;
  }

  .rsb-process-card h3 {
    font-size: clamp(1.7rem, 7.5vw, 2.2rem);
    margin-top: 8px;
  }

  .rsb-process-card > p {
    font-size: .9rem;
    line-height: 1.46;
  }

  .rsb-process-progress {
    margin-top: 14px;
  }

  .rsb-process-visual {
    aspect-ratio: 4 / 3;
  }

  .rsb-process-arrow {
    bottom: 36px;
    height: 46px;
    width: 46px;
  }

  .rsb-process-dots {
    bottom: 44px;
    gap: 5px;
  }

  .rsb-process-dots button {
    width: 30px;
  }

.rsb-process-heading {
    grid-row: 1 !important;
    grid-column: 1 !important;
  }

  .rsb-process-visual {
    grid-row: 2 !important;
    grid-column: 1 !important;
    overflow: hidden !important;
    width: 100% !important;
  }

  /* Nav overlaid at the bottom of the image */
  .rsb-process-nav {
    grid-row: 2 !important;
    grid-column: 1 !important;
    align-self: end !important;
    justify-content: center !important;
    gap: 20px !important;
    padding: 0 16px 14px !important;
    z-index: 8 !important;
  }

  .rsb-process-copy {
    grid-row: 3 !important;
    grid-column: 1 !important;
  }

  .rsb-process-card {
    border: none !important;
    box-shadow: none !important;
  }

  .rsb-process-progress {
    display: none !important;
  }

  /* Bottom gradient so buttons are readable against the photo */
  .rsb-process-visual::after {
    background:
      linear-gradient(180deg, transparent 52%, rgba(7, 13, 11, .62) 100%),
      linear-gradient(90deg, rgba(7, 13, 11, .12), transparent 52%) !important;
  }

  /* Semi-transparent circle buttons over image */
  .rsb-process-nav .rsb-process-arrow,
  .rsb-process-nav .rsb-process-playpause {
    background: rgba(10, 17, 14, .52) !important;
    border: 1px solid rgba(255, 255, 255, .28) !important;
    backdrop-filter: blur(6px) !important;
    -webkit-backdrop-filter: blur(6px) !important;
    box-shadow: none !important;
    color: #fff !important;
    height: 46px !important;
    width: 46px !important;
  }

  .cinematic-process.rsb-stable-process .rsb-process-inner {
    gap: 24px;
    padding: 82px 12px 104px;
  }

  .cinematic-process.rsb-stable-process .rsb-process-visual {
    aspect-ratio: 4 / 3;
    width: calc(100% - 38px);
  }

  .cinematic-process.rsb-stable-process .rsb-process-photo-2 {
    transform: translate3d(10px, -8px, 0) rotate(1.6deg) scale(.98);
  }

  .cinematic-process.rsb-stable-process .rsb-process-photo-3 {
    transform: translate3d(19px, -15px, 0) rotate(3deg) scale(.96);
  }

  .cinematic-process.rsb-stable-process .rsb-process-photo-4 {
    transform: translate3d(27px, -21px, 0) rotate(4.2deg) scale(.94);
  }

  .cinematic-process.rsb-stable-process .rsb-process-copy > h2, .rsb-process-heading > h2 {
    font-size: clamp(1.95rem, 8.3vw, 2.5rem);
  }

  .cinematic-process.rsb-stable-process .rsb-process-card {
    min-height: 210px;
    padding: 17px;
  }

  .cinematic-process.rsb-stable-process .rsb-process-card h3 {
    font-size: clamp(1.8rem, 8vw, 2.35rem);
  }

  .cinematic-process.rsb-stable-process .rsb-process-carousel.is-final .rsb-process-inner {
    min-height: 570px;
  }

  .cinematic-process.rsb-stable-process .rsb-process-photo[data-slot="1"] {
    transform: translate3d(10px, -8px, 0) rotate(1.6deg) scale(.98);
  }

  .cinematic-process.rsb-stable-process .rsb-process-photo[data-slot="2"] {
    transform: translate3d(19px, -15px, 0) rotate(3deg) scale(.96);
  }

  .cinematic-process.rsb-stable-process .rsb-process-photo[data-slot="3"] {
    transform: translate3d(27px, -21px, 0) rotate(4.2deg) scale(.94);
  }

  .cinematic-process.rsb-stable-process .rsb-process-photo.is-exiting-forward {
    transform: translate3d(-28px, 10px, 0) rotate(-1.8deg) scale(.99);
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-content {
    padding-bottom: calc(32px + env(safe-area-inset-bottom)) !important;
  }

  .editorial-hero.rsb-hero-carousel-ready .hero-description {
    line-height: 1.42 !important;
  }

  .rsb-home-hero-controls {
    margin-top: 8px !important;
  }

  .editorial-hero .hero-actions {
    display: none !important;
  }

  .brand-logo {
    filter: drop-shadow(0 1px 3px rgba(0, 0, 0, .55)) !important;
    image-rendering: -webkit-optimize-contrast;
  }

  .cinematic-process.rsb-stable-process,
  .cinematic-process.rsb-stable-process .rsb-process-carousel,
  .cinematic-process.rsb-stable-process .rsb-process-inner {
    min-height: 0 !important;
    overflow: visible !important;
  }

  html, body {
    overflow-x: hidden;
    max-width: 100%;
  }
  img, video, iframe {
    max-width: 100%;
  }

  .sticky-cta {
    padding-bottom: max(10px, env(safe-area-inset-bottom, 0px)) !important;
    padding-left:  max(12px, env(safe-area-inset-left,   0px)) !important;
    padding-right: max(12px, env(safe-area-inset-right,  0px)) !important;
  }

  .editorial-hero.rsb-hero-carousel-ready {
    min-height: 100svh !important;
    min-height: 100dvh !important;
  }

  /* Description box: no forced tall min-height on small screens */
  .editorial-hero.rsb-hero-carousel-ready .hero-description {
    min-height: clamp(120px, 24svh, 200px) !important;
    font-size: clamp(.84rem, 3.8vw, .95rem) !important;
    padding: 12px 14px !important;
  }

  /* Hero content: push content away from header & sticky bar */
  .editorial-hero.rsb-hero-carousel-ready .hero-content {
    padding-top: clamp(68px, 12svh, 96px) !important;
    padding-bottom: clamp(72px, 14svh, 100px) !important;
  }

  /* Carousel dots */
  .rsb-home-hero-controls {
    margin-top: clamp(8px, 1.5svh, 14px) !important;
  }

  .rsb-process-inner {
    padding: clamp(44px, 9svh, 68px) clamp(12px, 4vw, 20px)
             clamp(20px, 4svh, 36px) !important;
    gap: clamp(8px, 1.8svh, 14px) !important;
    width: 100% !important;
  }

  /* Section heading */
  .rsb-process-heading .eyebrow {
    font-size: clamp(.7rem, 3vw, .85rem) !important;
  }
  .rsb-process-heading h2,
  .rsb-process-copy > h2, .rsb-process-heading > h2 {
    font-size: clamp(1.55rem, 7vw, 2.05rem) !important;
    line-height: 1.06 !important;
    margin: 0 0 clamp(2px, .6svh, 6px) !important;
  }

  /* Image: cap height so heading + image + card all fit */
  .rsb-process-visual {
    aspect-ratio: 4 / 3 !important;
    max-height: clamp(180px, 36svh, 280px) !important;
    width: 100% !important;
    border-radius: 8px !important;
    overflow: hidden !important;
  }
  .rsb-process-visual figure,
  .rsb-process-visual img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  /* Nav controls */
  .rsb-process-nav {
    gap: clamp(12px, 3.5vw, 22px) !important;
    padding: 0 12px clamp(8px, 1.4svh, 14px) !important;
  }
  .rsb-process-nav .rsb-process-arrow,
  .rsb-process-nav .rsb-process-playpause {
    height: clamp(36px, 7vw, 46px) !important;
    width:  clamp(36px, 7vw, 46px) !important;
  }

  /* Step description card */
  .rsb-process-card {
    padding: clamp(10px, 2svh, 16px) clamp(12px, 3.5vw, 18px) !important;
    min-height: 0 !important;
    border-radius: 8px !important;
  }
  .rsb-process-eyebrow {
    font-size: clamp(.7rem, 3vw, .82rem) !important;
  }
  .rsb-process-card h3 {
    font-size: clamp(1.3rem, 6.5vw, 1.85rem) !important;
    line-height: 1.1 !important;
    margin: clamp(4px, .8svh, 8px) 0 clamp(4px, .8svh, 8px) !important;
  }
  .rsb-process-card > p {
    font-size: clamp(.82rem, 3.6vw, .93rem) !important;
    line-height: 1.44 !important;
    margin: 0 !important;
  }
  .rsb-process-cta {
    margin-top: clamp(10px, 2svh, 16px) !important;
    font-size: clamp(.84rem, 3.6vw, .93rem) !important;
  }

  .work-examples-section {
    padding-block: clamp(32px, 6svh, 56px) !important;
  }

  .work-example {
    grid-template-columns: 1fr !important;
    gap: clamp(10px, 2.2svh, 18px) !important;
  }

  .work-example-media {
    aspect-ratio: 4 / 3 !important;
    max-height: clamp(200px, 44svh, 340px) !important;
    width: 100% !important;
    overflow: hidden !important;
  }

  .work-example-copy .eyebrow {
    font-size: clamp(.72rem, 3.2vw, .86rem) !important;
  }
  .work-example-copy h2 {
    font-size: clamp(1.5rem, 7vw, 2.1rem) !important;
    line-height: 1.08 !important;
  }
  .work-example-copy > p {
    font-size: clamp(.84rem, 3.8vw, .95rem) !important;
    line-height: 1.5 !important;
  }

  /* Tighter gap between sections */
  .work-example + .work-example {
    margin-top: clamp(24px, 4svh, 40px) !important;
  }

  .rsb-sate-section {
    padding-block: clamp(28px, 5svh, 48px) !important;
  }
  .rsb-sate-grid {
    grid-template-columns: 1fr !important;
    gap: clamp(12px, 2.5svh, 20px) !important;
  }
  .rsb-sate-carousel {
    max-height: clamp(200px, 44svh, 340px) !important;
    width: 100% !important;
  }
  .rsb-sate-copy h2 {
    font-size: clamp(1.5rem, 7vw, 2.1rem) !important;
    line-height: 1.08 !important;
  }
  .rsb-sate-copy p {
    font-size: clamp(.84rem, 3.8vw, .95rem) !important;
  }


  /* 1. Grid de 1 columna — anula el 2-col del desktop y el 1024px block */
  .rsb-process-inner {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto !important;
    min-height: 0 !important;
    gap: 14px !important;
    padding: 32px 16px 24px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* 2. Orden de filas */
  .rsb-process-heading {
    grid-row: 1 !important;
    grid-column: 1 !important;
  }

  .rsb-process-visual {
    grid-row: 2 !important;
    grid-column: 1 !important;
    aspect-ratio: 4 / 3 !important;
    max-height: none !important;
    border-radius: 14px !important;
    overflow: hidden !important;
    width: 100% !important;
    position: relative !important;
  }

  /* Nav en la misma celda que el visual → se superpone encima */
  .rsb-process-nav {
    grid-row: 2 !important;
    grid-column: 1 !important;
    align-self: end !important;
    justify-content: center !important;
    gap: clamp(18px, 4.5vw, 28px) !important;
    padding: 0 16px clamp(16px, 3svh, 24px) !important;
    z-index: 8 !important;
  }

  .rsb-process-copy {
    grid-row: 3 !important;
    grid-column: 1 !important;
  }

  /* 3. Gradiente inferior para legibilidad de botones */
  .rsb-process-visual::after {
    display: block !important;
    background: linear-gradient(to top, rgba(7, 13, 11, .70) 0%, transparent 52%) !important;
  }

  /* 4. Botones: círculos semitransparentes, tamaño igual */
  .rsb-process-nav .rsb-process-arrow,
  .rsb-process-nav .rsb-process-playpause {
    background: rgba(10, 17, 14, .56) !important;
    border: 1px solid rgba(255, 255, 255, .32) !important;
    backdrop-filter: blur(6px) !important;
    -webkit-backdrop-filter: blur(6px) !important;
    border-radius: 50% !important;
    color: #fff !important;
    height: clamp(44px, 10.5vw, 54px) !important;
    width: clamp(44px, 10.5vw, 54px) !important;
    position: static !important;
    top: auto !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    box-shadow: none !important;
  }

  /* 5. Tarjeta: con borde sutil y esquinas redondeadas */
  .rsb-process-card {
    border: 1px solid rgba(255, 255, 255, .12) !important;
    border-radius: 12px !important;
    box-shadow: none !important;
    padding: clamp(14px, 3svh, 20px) clamp(14px, 4vw, 20px) !important;
  }

  /* 6. Barra de progreso: visible */
  .rsb-process-progress {
    display: block !important;
    height: 3px !important;
    margin-top: 14px !important;
  }

  /* 7. Título h2: más grande, como en la referencia */
  .rsb-process-heading > h2 {
    font-size: clamp(2.1rem, 9.5vw, 3rem) !important;
    line-height: 1.03 !important;
    margin-bottom: 0 !important;
  }

  .work-example-kitchen .work-example-copy { order: -1 !important; }
  .work-example-bath .work-example-copy    { order: -1 !important; }
  .rsb-sate-copy                           { order: -1 !important; }

  html:not(.rsb-more-services-page) .work-examples-section {
    padding-bottom: clamp(8px, 1.5svh, 14px) !important;
  }
  html:not(.rsb-more-services-page) .rsb-sate-section {
    padding-top: clamp(8px, 1.5svh, 14px) !important;
  }
}

@media (max-width: 720px) {
  .site-header,
  .site-header.is-page,
  .site-header.is-scrolled,
  .site-header.menu-open {
    min-height: 66px !important;
  }

  .editorial-hero .hero-content {
    padding-top: 86px !important;
  }

  .editorial-hero .hero-copy {
    width: 100% !important;
    max-width: 100% !important;
  }

  .editorial-hero h1 {
    width: min(100%, 21rem) !important;
    max-width: 100% !important;
    font-size: clamp(2rem, 8.6vw, 2.4rem) !important;
    line-height: 1.04 !important;
    text-wrap: balance;
    white-space: normal !important;
    overflow-wrap: normal;
  }

  .editorial-hero h1 span {
    display: block !important;
    max-width: 100% !important;
    white-space: normal !important;
  }

  .editorial-hero .hero-description {
    width: min(100%, 21rem) !important;
    max-width: 100% !important;
    font-size: 1rem !important;
    line-height: 1.5 !important;
  }

  .more-services-hero h1 {
    font-size: clamp(2.25rem, 10vw, 3.25rem) !important;
  }

  .rsb-contact-trust {
    padding: 58px 0 calc(76px + env(safe-area-inset-bottom)) !important;
  }
  .contact-header,
  .contact-hero,
  .contact-steps,
  .rsb-contact-trust .container {
    width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
  }

  .contact-card {
    width: 100% !important;
    max-width: calc(100vw - 32px) !important;
  }

  .contact-hero h1,
  .contact-lead,
  .rsb-contact-trust .section-lead {
    max-width: min(100%, 20.5rem) !important;
    white-space: normal !important;
  }

  .contact-card h2,
  .contact-card p {
    max-width: min(100%, 18rem) !important;
    white-space: normal !important;
  }

  .rsb-sate-section {
    padding: 64px 0;
  }

  .rsb-sate-carousel {
    aspect-ratio: 1.22 / 1;
  }

  .rsb-before-after-section {
    padding: 64px 0 calc(104px + env(safe-area-inset-bottom));
  }

  .rsb-sate-copy h2,
  .rsb-before-after-copy h2 {
    font-size: clamp(2rem, 9vw, 2.75rem);
  }

  .rsb-ba-frame {
    aspect-ratio: 1 / 1.08;
    border: 1px solid rgba(255, 255, 255, .18);
  }

  .rsb-ba-handle {
    height: 44px;
    width: 44px;
  }

  .rsb-ba-label {
    bottom: 12px;
    font-size: .78rem;
    padding: 7px 10px;
  }
}

@media (max-width: 640px) {
  .more-services-hero,
  .more-services-hero-inner,
  .more-services-magazine-layout,
  .more-services-hero-copy {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: clip !important;
  }

  .more-services-hero-copy {
    box-sizing: border-box !important;
    padding-right: 12px !important;
  }

  .more-services-hero-copy h1 {
    max-width: calc(100vw - 36px) !important;
    overflow-wrap: break-word !important;
  }

  .more-services-hero-copy > p:not(.eyebrow) {
    display: block !important;
    width: calc(100vw - 72px) !important;
    max-width: calc(100vw - 72px) !important;
    overflow-wrap: break-word !important;
  }

  html.rsb-more-services-page .more-services-hero,
  html.rsb-more-services-page .more-services-hero-inner,
  html.rsb-more-services-page .more-services-magazine-layout,
  html.rsb-more-services-page .more-services-hero-copy {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: clip !important;
  }

  html.rsb-more-services-page .more-services-hero-copy {
    box-sizing: border-box !important;
    padding-right: 12px !important;
  }

  html.rsb-more-services-page .more-services-hero-copy h1,
  html.rsb-more-services-page .more-services-hero-copy > p:not(.eyebrow) {
    max-width: calc(100vw - 36px) !important;
    overflow-wrap: break-word !important;
  }

  html.rsb-more-services-page .more-services-hero-copy > p:not(.eyebrow) {
    display: block !important;
    width: calc(100vw - 72px) !important;
    max-width: calc(100vw - 72px) !important;
  }

  html.rsb-more-services-page .more-services-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    max-width: 100% !important;
  }

  html.rsb-more-services-page .more-services-actions > a {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.contact-page .contact-header,
  body.contact-page .contact-shell,
  body.contact-page .contact-steps,
  body.contact-page .rsb-contact-trust .contact-shell {
    width: min(100% - 24px, 1680px) !important;
    max-width: calc(100vw - 24px) !important;
  }

  body.contact-page .contact-hero {
    width: 100% !important;
    max-width: none !important;
    min-height: 100svh !important;
    align-items: flex-start !important;
    padding: 82px 12px 28px !important;
    background:
      linear-gradient(180deg, rgba(7, 13, 11, .72) 0%, rgba(7, 13, 11, .54) 34%, rgba(7, 13, 11, .88) 100%),
      url("reformas/contacto-visita.png") 69% center / cover no-repeat !important;
  }

  body.contact-page .contact-copy,
  body.contact-page .contact-proof-lines,
  body.contact-page .contact-card {
    width: calc(100vw - 48px) !important;
    max-width: 360px !important;
    min-width: 0 !important;
  }
  body.contact-page .contact-copy {
    max-width: calc(100vw - 24px) !important;
  }

  body.contact-page .contact-hero h1 {
    font-size: clamp(2rem, 9.6vw, 2.65rem) !important;
    line-height: .98 !important;
  }

  body.contact-page .contact-lead {
    margin-top: 12px !important;
    font-size: .94rem !important;
    line-height: 1.42 !important;
  }

  body.contact-page .contact-card {
    margin-top: 14px !important;
    padding: 14px !important;
  }

  body.contact-page .contact-card-top {
    display: block !important;
  }

  body.contact-page .contact-card-top p {
    display: none !important;
  }

  body.contact-page .contact-card h2 {
    font-size: 1.55rem !important;
  }

  body.contact-page .contact-buttons {
    gap: 8px !important;
    margin-top: 12px !important;
  }

  body.contact-page .contact-buttons a {
    min-height: 46px !important;
  }

  body.contact-page .contact-proof-lines {
    margin-top: 12px !important;
  }

  body.contact-page .contact-proof-lines p,
  body.contact-page .contact-card p,
  body.contact-page .contact-buttons a {
    overflow-wrap: anywhere !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  html.rsb-more-services-page .rsb-slide-text {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  .cinematic-process.rsb-stable-process .rsb-process-photo,
  .cinematic-process.rsb-stable-process .rsb-process-visual {
    transition-duration: .01ms !important;
  }
}

/* Contact page: dark trust section covers full viewport width including scrollbar gap */
html:has(body.contact-page) {
  background-color: #101714;
}

/* ── Brick Loader (reuses .brand-intro) ─────────────────────────── */
html[data-rsb-brick] .brand-intro,
html[data-rsb-brick] .brand-intro.is-gone {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #0d1311 !important;
  inset: 0 !important;
  position: fixed !important;
  z-index: 9999 !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transition: opacity 0.42s ease !important;
}
html[data-rsb-brick].rsb-skip-intro .brand-intro {
  display: flex !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
html[data-rsb-brick] .brand-intro-inner {
  position: relative !important;
}
html[data-rsb-brick] .brand-intro-inner strong,
html[data-rsb-brick] .brand-intro-inner strong::after,
html[data-rsb-brick] .brand-intro-inner p {
  display: none !important;
}
html[data-rsb-brick] .brand-loader {
  all: unset !important;
  display: block !important;
  width: 206px !important;
  height: 134px !important;
}
html[data-rsb-brick] .brand-loader svg {
  display: none !important;
}
html[data-rsb-brick] .brand-loader span {
  display: none !important;
}
html[data-rsb-brick] .brand-loader::before {
  content: "" !important;
  display: block !important;
  width: 206px !important;
  height: 134px !important;
  border: none !important;
  box-shadow: none !important;
  transform: none !important;
  border-radius: 0 !important;
  background: url("data:image/svg+xml;charset=utf-8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 206 134'><rect x='35' y='0' width='64' height='40' rx='8' fill='transparent' stroke='%23444' stroke-width='2'><animate attributeName='fill' values='transparent;%23c06535' begin='0.4s' dur='0.22s' fill='freeze'/><animate attributeName='stroke' values='%23444;%238a3e1c' begin='0.4s' dur='0.22s' fill='freeze'/></rect><rect x='106' y='0' width='64' height='40' rx='8' fill='transparent' stroke='%23444' stroke-width='2'><animate attributeName='fill' values='transparent;%23c06535' begin='0.4s' dur='0.22s' fill='freeze'/><animate attributeName='stroke' values='%23444;%238a3e1c' begin='0.4s' dur='0.22s' fill='freeze'/></rect><rect x='0' y='47' width='64' height='40' rx='8' fill='transparent' stroke='%23444' stroke-width='2'><animate attributeName='fill' values='transparent;%23c06535' begin='0.7s' dur='0.22s' fill='freeze'/><animate attributeName='stroke' values='%23444;%238a3e1c' begin='0.7s' dur='0.22s' fill='freeze'/></rect><rect x='71' y='47' width='64' height='40' rx='8' fill='transparent' stroke='%23444' stroke-width='2'><animate attributeName='fill' values='transparent;%23c06535' begin='0.7s' dur='0.22s' fill='freeze'/><animate attributeName='stroke' values='%23444;%238a3e1c' begin='0.7s' dur='0.22s' fill='freeze'/></rect><rect x='142' y='47' width='64' height='40' rx='8' fill='transparent' stroke='%23444' stroke-width='2'><animate attributeName='fill' values='transparent;%23c06535' begin='1.0s' dur='0.22s' fill='freeze'/><animate attributeName='stroke' values='%23444;%238a3e1c' begin='1.0s' dur='0.22s' fill='freeze'/></rect><rect x='35' y='94' width='64' height='40' rx='8' fill='transparent' stroke='%23444' stroke-width='2'><animate attributeName='fill' values='transparent;%23c06535' begin='1.0s' dur='0.22s' fill='freeze'/><animate attributeName='stroke' values='%23444;%238a3e1c' begin='1.0s' dur='0.22s' fill='freeze'/></rect><rect x='106' y='94' width='64' height='40' rx='8' fill='transparent' stroke='%23444' stroke-width='2'><animate attributeName='fill' values='transparent;%23c06535' begin='1.3s' dur='0.22s' fill='freeze'/><animate attributeName='stroke' values='%23444;%238a3e1c' begin='1.3s' dur='0.22s' fill='freeze'/></rect></svg>") no-repeat center / contain !important;
}
@media (max-width: 480px) {
  html[data-rsb-brick] .brand-loader {
    width: 148px !important;
    height: 96px !important;
  }
  html[data-rsb-brick] .brand-loader::before {
    width: 148px !important;
    height: 96px !important;
  }
}
