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,
.hero-editorial-media {
  animation: none !important;
  opacity: 1 !important;
}

.hero-editorial-media {
  background-image:
    linear-gradient(90deg, rgba(16, 23, 20, .58), rgba(16, 23, 20, .18) 44%, rgba(0, 0, 0, 0) 68%),
    url("reformas/hero-rsb.jpg") !important;
  background-position: center 48% !important;
  background-size: cover !important;
}

.hero-editorial-media img {
  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;
}

.webgl-frame {
  background: transparent !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;
}

.back-home-link {
  width: fit-content !important;
  max-width: 100% !important;
  background: rgba(255, 253, 248, .92) !important;
  box-shadow: 0 12px 30px rgba(24, 32, 29, .08) !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: 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;
  }
}

@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;
  }
}

@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-header h2 {
  color: #fff;
  max-width: 760px;
  overflow-wrap: anywhere;
}

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

.rsb-contact-trust .icon-chip {
  color: var(--color-copper);
  font-size: .78rem;
  font-weight: 900;
}

.rsb-contact-trust .trust-card {
  min-width: 0;
}

.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,
.rsb-contact-trust .grid-4,
.rsb-contact-trust .trust-card {
  max-width: calc(100vw - 24px) !important;
}

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

.contact-card,
.rsb-contact-trust .trust-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;
}

.rsb-sate-grid {
  display: grid;
  grid-template-columns: minmax(280px, .48fr) minmax(420px, .72fr);
  align-items: center;
  gap: clamp(28px, 5vw, 68px);
}

.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: 16 / 10;
  background: var(--color-soft);
  box-shadow: 0 24px 70px rgba(24, 32, 29, .22);
  min-height: 340px;
  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-img {
  height: 100%;
  inset: 0;
  object-fit: cover;
  position: absolute;
  width: 100%;
}

.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: 16 / 11;
    min-height: 0;
    width: 100%;
  }

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

@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;
  }
}

@media (max-width: 720px) {
  .rsb-contact-trust {
    padding: 58px 0 calc(76px + env(safe-area-inset-bottom)) !important;
  }

  .rsb-contact-trust .section-header h2 {
    font-size: clamp(1.85rem, 8.4vw, 2.45rem);
    line-height: 1.02;
  }

  .rsb-contact-trust .trust-card p {
    overflow-wrap: anywhere;
  }

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

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

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

  .contact-card h2,
  .contact-card p,
  .rsb-contact-trust .trust-card h3,
  .rsb-contact-trust .trust-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;
  }
}

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(255, 253, 248, .28) !important;
  border-color: rgba(24, 32, 29, .13) !important;
  box-shadow: 0 12px 34px rgba(24, 32, 29, .13), inset 0 1px rgba(255, 255, 255, .56) !important;
  text-shadow: none !important;
}

html.rsb-more-services-page .site-header .desktop-nav a:hover,
html.rsb-more-services-page .site-header .desktop-nav a:focus-visible,
html.rsb-more-services-page .site-header .phone-link:hover,
html.rsb-more-services-page .site-header .phone-link:focus-visible,
html.rsb-more-services-page .site-header .mobile-menu-button:hover,
html.rsb-more-services-page .site-header .mobile-menu-button:focus-visible {
  color: #18201d !important;
  background: rgba(255, 253, 248, .5) !important;
  border-color: rgba(166, 95, 63, .32) !important;
  box-shadow: 0 16px 42px rgba(24, 32, 29, .18), inset 0 1px rgba(255, 255, 255, .68) !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;
  background: rgba(7, 13, 11, .68) !important;
  border: 1px solid rgba(255, 255, 255, .14) !important;
  border-radius: 6px !important;
  bottom: auto !important;
  color: rgba(255, 255, 255, .9) !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: 118px;
  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;
}

@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;
  }
}

@media (max-width: 760px) {
  .editorial-hero.rsb-hero-carousel-ready,
  .editorial-hero.rsb-hero-carousel-ready .hero-content {
    min-height: 100dvh !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-end !important;
    padding: 100px 0 calc(96px + env(safe-area-inset-bottom)) !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 {
    font-size: .94rem !important;
    line-height: 1.46 !important;
    margin-top: 16px !important;
    max-width: 100% !important;
    min-height: 132px;
    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;
  }
}

/* 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: rgba(255, 255, 255, .22) !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);
}

.work-image-controls {
  background: rgba(16, 23, 20, .48) !important;
  border: 0 !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, .16) !important;
  backdrop-filter: blur(8px) saturate(112%) !important;
  -webkit-backdrop-filter: blur(8px) saturate(112%) !important;
  text-shadow: 0 1px 8px rgba(0, 0, 0, .68);
}

.work-image-controls button {
  border: 0 !important;
  transition: background .18s ease, color .18s ease;
}

.work-image-controls button:hover,
.work-image-controls button:focus-visible {
  background: rgba(255, 255, 255, .14) !important;
}

.rsb-project-real-badge {
  position: absolute;
  z-index: 3;
  top: 18px;
  left: 0;
  display: grid;
  place-items: center;
  width: 30px;
  min-height: 108px;
  padding: 12px 0;
  background: var(--color-copper);
  color: #111714;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  box-shadow: 8px 10px 24px rgba(0, 0, 0, .16);
  pointer-events: none;
}

.rsb-project-real-badge[hidden] {
  display: none !important;
}

@media (max-width: 760px) {
  .editorial-hero.rsb-hero-carousel-ready .hero-description {
    background: rgba(7, 13, 11, .4) !important;
  }

  .work-image-controls {
    background: rgba(16, 23, 20, .52) !important;
  }

  .rsb-project-real-badge {
    top: 12px;
    width: 26px;
    min-height: 94px;
    font-size: 10px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .rsb-home-hero-slide,
  .editorial-hero.rsb-hero-carousel-ready .hero-description {
    transition: opacity .01ms linear !important;
    transform: none !important;
  }
}

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;
}

@media (max-width: 1100px) {
  html.rsb-more-services-page .site-header,
  html.rsb-more-services-page .site-header.is-page,
  html.rsb-more-services-page .site-header.is-scrolled,
  html.rsb-more-services-page .site-header.menu-open {
    background: linear-gradient(180deg, rgba(255, 253, 248, .99), rgba(255, 253, 248, .94)) !important;
    box-shadow: 0 12px 32px rgba(24, 32, 29, .08) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
  }
}

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;
}

@media (max-width: 1100px) {
  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;
  }
}

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;
}

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

@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;
  }
}

.cinematic-process,
.cinematic-sticky {
  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 .contact-card,
body.contact-page .step-card,
body.contact-page .contact-trust-card {
  border-radius: 8px !important;
}

.rsb-process-step-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  width: fit-content !important;
  min-height: 44px !important;
  margin-top: 18px !important;
  padding: 0 18px !important;
  border-radius: 6px !important;
  background: #f7f4ed !important;
  color: #101714 !important;
  font-family: var(--font-sans), Arial, sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24) !important;
}

.rsb-process-step-cta:hover {
  background: #d9824b !important;
  color: #fff !important;
}

@media (max-width: 760px) {
  .cinematic-mobile-heading h2 {
    font-size: clamp(1.72rem, 7.2vw, 2.12rem) !important;
    line-height: 1.04 !important;
    max-width: 360px !important;
  }

  .cinematic-mobile-panel.is-final {
    min-height: 390px !important;
  }

  .cinematic-mobile-panel.is-final .cinematic-mobile-panel-copy {
    min-height: 0 !important;
    padding: 18px !important;
  }
}

@media (min-width: 1025px) {
  .cinematic-layout {
    grid-template-columns: minmax(320px, 0.7fr) minmax(500px, 1fr) !important;
    align-items: center !important;
    align-content: center !important;
    gap: clamp(28px, 3vw, 54px) !important;
    width: min(100% - 96px, 1320px) !important;
    min-height: 86dvh !important;
    margin-inline: auto !important;
    padding: 88px 0 68px !important;
  }

  .cinematic-copy {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    z-index: 8 !important;
    width: 100% !important;
    max-width: 460px !important;
  }

  .cinematic-copy h2 {
    max-width: 460px !important;
    font-size: clamp(2.35rem, 3.25vw, 3.75rem) !important;
    line-height: 0.98 !important;
  }

  .cinematic-step {
    max-width: 460px !important;
    padding: 22px 24px !important;
  }

  .cinematic-progress {
    width: min(460px, 100%) !important;
  }

  .cinematic-progress span {
    width: 100% !important;
    transform-origin: left center !important;
  }

  .cinematic-visuals {
    position: relative !important;
    z-index: 2 !important;
    width: 100% !important;
    min-height: clamp(330px, 34vw, 470px) !important;
    transform: none !important;
  }

  .cinematic-photo-stack {
    width: min(100%, 720px) !important;
    height: clamp(300px, 31vw, 430px) !important;
    margin-inline: auto !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .cinematic-photo-card {
    display: block !important;
    visibility: visible !important;
  }

  .cinematic-arrows {
    z-index: 30 !important;
  }

  .cinematic-process.rsb-process-final .cinematic-layout {
    grid-template-columns: 1fr !important;
    place-items: center !important;
    width: min(100% - 96px, 920px) !important;
    min-height: 76dvh !important;
    padding: 88px 0 72px !important;
  }

  .cinematic-process.rsb-process-final .cinematic-visuals {
    display: none !important;
  }

  .cinematic-process.rsb-process-final .cinematic-copy {
    max-width: 640px !important;
    width: min(100%, 640px) !important;
    margin-inline: auto !important;
  }

  .cinematic-process.rsb-process-final .cinematic-copy > .eyebrow,
  .cinematic-process.rsb-process-final .cinematic-copy > h2 {
    display: none !important;
  }

  .cinematic-process.rsb-process-final .cinematic-step {
    max-width: 640px !important;
    min-height: 0 !important;
    padding: clamp(28px, 3vw, 42px) !important;
  }

  .cinematic-process.rsb-process-final .cinematic-step h3 {
    font-size: clamp(2.2rem, 4.5vw, 4rem) !important;
  }

  .cinematic-process.rsb-process-final .cinematic-progress {
    width: min(640px, 100%) !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;
}

body.contact-page .contact-trust-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

body.contact-page .contact-trust-card {
  width: 100% !important;
  min-height: 0 !important;
  color: #101714 !important;
  background: #fffdf8 !important;
}

@media (max-width: 980px) {
  body.contact-page .rsb-contact-trust .contact-section-head {
    grid-template-columns: 1fr !important;
  }

  body.contact-page .contact-trust-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  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;
  }
}

/* Home: escala profesional de la imagen de baño. */
.work-example-bath {
  grid-template-columns: minmax(280px, 0.58fr) minmax(0, 0.88fr) !important;
  align-items: center !important;
  gap: clamp(36px, 5vw, 78px) !important;
}

.work-example-bath .work-example-media {
  width: min(100%, 680px) !important;
  max-height: 540px !important;
  min-height: 0 !important;
  aspect-ratio: 4 / 3 !important;
  justify-self: end !important;
}

.work-example-bath .work-example-media img {
  object-fit: cover !important;
  object-position: center center !important;
}

@media (min-width: 1281px) {
  .work-example-bath .work-example-media {
    width: min(100%, 700px) !important;
    max-height: 560px !important;
  }
}

@media (min-width: 901px) and (max-width: 1280px) {
  .work-example-bath {
    grid-template-columns: minmax(250px, 0.66fr) minmax(0, 0.94fr) !important;
    gap: clamp(28px, 4vw, 54px) !important;
  }

  .work-example-bath .work-example-media {
    width: min(100%, 560px) !important;
    max-height: 440px !important;
  }
}

@media (max-width: 900px) {
  .work-example-bath {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }

  .work-example-bath .work-example-copy {
    max-width: 680px !important;
  }

  .work-example-bath .work-example-media {
    width: 100% !important;
    max-height: none !important;
    aspect-ratio: 4 / 3 !important;
    justify-self: stretch !important;
  }
}

/* Tablet: recorta aire muerto del hero y del proceso horizontal. */
@media (min-width: 761px) and (max-width: 1280px) {
  .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-editorial-media {
    height: clamp(270px, 34vw, 360px) !important;
    margin-top: clamp(10px, 1.6vw, 18px) !important;
  }

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

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

@media (min-width: 761px) and (max-width: 1024px) {
  .cinematic-process {
    height: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
  }

  .cinematic-sticky {
    position: relative !important;
    top: auto !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .cinematic-layout {
    min-height: 0 !important;
    align-content: start !important;
    align-items: start !important;
    padding: clamp(34px, 5vw, 52px) 0 clamp(38px, 5vw, 58px) !important;
    gap: 0 !important;
  }

  .cinematic-visuals {
    order: 1 !important;
    min-height: clamp(285px, 42vw, 390px) !important;
  }

  .cinematic-photo-stack {
    width: min(90%, 680px) !important;
    height: clamp(270px, 38vw, 360px) !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .cinematic-photo-card {
    display: block !important;
    visibility: visible !important;
    transition: opacity 520ms ease, transform 620ms cubic-bezier(.22, .8, .22, 1) !important;
  }

  .cinematic-final-card,
  .cinematic-final-bg {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .cinematic-arrows {
    z-index: 40 !important;
    pointer-events: none !important;
  }

  .cinematic-arrows button {
    position: relative !important;
    z-index: 41 !important;
    pointer-events: auto !important;
    touch-action: manipulation !important;
  }

  .cinematic-copy {
    position: relative !important;
    z-index: 5 !important;
    order: 2 !important;
    left: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: min(100%, 580px) !important;
    margin: clamp(-42px, -4vw, -24px) auto 0 !important;
  }

  .cinematic-copy h2 {
    max-width: 100% !important;
    font-size: clamp(1.9rem, 4.6vw, 2.75rem) !important;
  }

  .cinematic-step {
    max-width: 100% !important;
    min-height: 0 !important;
    margin-top: 14px !important;
  }

  .cinematic-progress {
    width: 100% !important;
  }

  .cinematic-progress span {
    width: 100% !important;
    transform-origin: left center !important;
  }

  .cinematic-process.rsb-process-final .cinematic-layout {
    place-items: center !important;
    padding: clamp(44px, 7vw, 72px) 0 !important;
  }

  .cinematic-process.rsb-process-final .cinematic-visuals {
    display: none !important;
  }

  .cinematic-process.rsb-process-final .cinematic-copy {
    order: 1 !important;
    width: min(100%, 620px) !important;
    margin: 0 auto !important;
  }

  .cinematic-process.rsb-process-final .cinematic-copy > .eyebrow,
  .cinematic-process.rsb-process-final .cinematic-copy > h2 {
    display: none !important;
  }

  .cinematic-process.rsb-process-final .cinematic-step {
    max-width: 620px !important;
    padding: clamp(24px, 4vw, 36px) !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;
  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 {
  color: #efb58f;
}

.rsb-process-copy > 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);
}

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

  .rsb-process-copy > 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;
  }
}

@media (max-width: 760px) {
  .cinematic-process.rsb-stable-process,
  .rsb-process-carousel,
  .rsb-process-inner {
    min-height: auto;
  }

  .rsb-process-inner {
    gap: 18px;
    padding: 82px 12px 104px;
  }

  .rsb-process-copy > h2 {
    font-size: clamp(2rem, 9vw, 2.7rem);
  }

  .rsb-process-card {
    margin-top: 18px;
    min-height: 240px;
    padding: 18px;
  }

  .rsb-process-card h3 {
    font-size: clamp(2rem, 9vw, 2.8rem);
    margin-top: 12px;
  }

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

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

  .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;
  }
}

/* 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 {
  font-size: clamp(2.6rem, 3.5vw, 3.7rem);
  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 {
  opacity: 1;
  transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
  z-index: 4;
}

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

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

.cinematic-process.rsb-stable-process .rsb-process-photo-4 {
  opacity: .14;
  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;
}

@media (max-width: 1024px) {
  .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;
  }
}

@media (max-width: 760px) {
  .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 {
    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;
  }
}

/* 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);
}

@media (max-width: 760px) {
  .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);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cinematic-process.rsb-stable-process .rsb-process-photo,
  .cinematic-process.rsb-stable-process .rsb-process-visual {
    transition-duration: .01ms !important;
  }
}
