/* ==========================================================================
   RADOP — Business / Contract page
   Editorial luxury · glassmorphism · sharp edges · slow motion
   Scoped under .rdp-biz to avoid touching the rest of the theme.
   ========================================================================== */

.rdp-biz {
  --rdp-canvas: #f8f8f8;
  --rdp-surface: #ffffff;
  --rdp-ink: #000000;
  --rdp-ink-soft: #333333;
  --rdp-grey: #c1c1c1;
  --rdp-gold: #af9a75;
  --rdp-gold-lt: #f1d39f;
  --rdp-peach: #ffbc7d;

  --rdp-font: "Ysabeau Office", "Helvetica Neue", Helvetica, Arial, sans-serif;

  /* fluid type scale */
  --rdp-display: clamp(3rem, 9vw, 9.5rem);
  --rdp-h1: clamp(2.4rem, 6vw, 5.5rem);
  --rdp-h2: clamp(1.9rem, 3.6vw, 3.1rem);
  --rdp-h3: clamp(1.3rem, 2vw, 1.7rem);
  --rdp-body: clamp(1rem, 1.15vw, 1.18rem);

  --rdp-ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --rdp-slow: 1s;

  font-family: var(--rdp-font);
  color: var(--rdp-ink);
  background: var(--rdp-canvas);
  font-weight: 300;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

.rdp-biz *,
.rdp-biz *::before,
.rdp-biz *::after { box-sizing: border-box; border-radius: 0 !important; }

.rdp-biz img { display: block; max-width: 100%; }

.rdp-wrap { width: min(1280px, 92vw); margin-inline: auto; }
.rdp-wrap--narrow { width: min(900px, 90vw); margin-inline: auto; }

/* ---- Bidirectional reveal: fade IN on enter, fade OUT on leave ---------- */
.rdp-rise {
  opacity: 0;
  transform: translateY(42px);
  transition: opacity .95s var(--rdp-ease), transform .95s var(--rdp-ease);
  will-change: opacity, transform;
}
.rdp-rise.is-in { opacity: 1; transform: none; }
.rdp-rise[data-delay="1"] { transition-delay: .09s; }
.rdp-rise[data-delay="2"] { transition-delay: .18s; }
.rdp-rise[data-delay="3"] { transition-delay: .27s; }
.rdp-rise[data-delay="4"] { transition-delay: .36s; }
/* faster exit than entry feels more responsive (MD motion) */
.rdp-rise:not(.is-in) { transition-duration: .6s; transition-delay: 0s; }
/* When GSAP is active it owns motion — kill the CSS transition to avoid double-animating. */
.rdp-js .rdp-rise { transition: none !important; }

/* ==========================================================================
   HERO
   ========================================================================== */
.rdp-hero {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  overflow: visible;            /* let the card cluster spill into the section below */
  color: #fff;
  background: #0c0b0a;
  z-index: 2;                   /* keep the spilling cards above the next section */
}
/* Background/scrim layers clip here so only the cards escape the hero. */
.rdp-hero__media { position: absolute; inset: 0; overflow: hidden; z-index: 0; }
/* Parallax layer holder. GSAP drives the transform on .rdp-hero__bg. */
.rdp-hero__bg {
  position: absolute; inset: -20%; z-index: 0;
  will-change: transform;
}
/* Crossfading photo slideshow. */
.rdp-hero__slides { position: absolute; inset: 0; }
.rdp-hero__slide {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0;
  transition: opacity 1.8s var(--rdp-ease);
}
.rdp-hero__slide.is-active { opacity: 1; }
/* Warm mesh tint over the photos + slow drift (its own transform, no GSAP collision). */
.rdp-hero__mesh {
  position: absolute; inset: -10%; mix-blend-mode: multiply; opacity: .9;
  background:
    radial-gradient(42% 50% at 22% 30%, rgba(175,154,117,.40) 0%, rgba(175,154,117,0) 60%),
    radial-gradient(38% 46% at 78% 28%, rgba(255,188,125,.26) 0%, rgba(255,188,125,0) 62%),
    radial-gradient(50% 55% at 68% 78%, rgba(241,211,159,.30) 0%, rgba(241,211,159,0) 60%),
    radial-gradient(60% 60% at 28% 80%, rgba(20,16,12,.55) 0%, rgba(20,16,12,0) 62%);
  will-change: transform;
  animation: rdp-mesh 26s ease-in-out infinite alternate;
}
@keyframes rdp-mesh {
  0%   { transform: translate3d(-3%, -2%, 0) scale(1.05) rotate(0deg); }
  50%  { transform: translate3d(3%, 2%, 0) scale(1.12) rotate(1.5deg); }
  100% { transform: translate3d(-2%, 3%, 0) scale(1.06) rotate(-1deg); }
}
/* fine grain overlay for editorial texture */
.rdp-hero__grain {
  position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .06;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.rdp-hero__scrim {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(8,7,6,.28) 0%, rgba(8,7,6,.42) 55%, rgba(8,7,6,.66) 100%);
}
.rdp-hero__inner { position: relative; z-index: 2; padding: 16vh 0 13vh; width: 100%; }
.rdp-hero__inner .rdp-wrap { padding-inline: clamp(.5rem, 2vw, 2rem); }
.rdp-eyebrow {
  font-size: .78rem; letter-spacing: .42em; text-transform: uppercase;
  font-weight: 400; color: var(--rdp-gold-lt); margin: 0 0 1.6rem;
}
.rdp-hero__title {
  font-size: var(--rdp-h1); font-weight: 200; line-height: 1.02;
  letter-spacing: .01em; text-transform: uppercase; margin: 0 0 1.4rem; max-width: 16ch;
  color: #ffffff;
}
.rdp-hero__title .rdp-line__in { color: #ffffff; }
.rdp-hero__title em { font-style: normal; color: var(--rdp-gold-lt); }

/* --- SplitText line reveal (each line rises out of an overflow mask) --- */
.rdp-split .rdp-line { display: block; overflow: hidden; }
.rdp-split .rdp-line__in { display: inline-block; will-change: transform; }
/* GSAP owns the hidden start state via gsap.set() — no CSS transform here
   (a CSS transform would compound with GSAP's and leave the line clipped).
   Flash-proof: hide the hero text block until JS marks it ready, but if JS
   never runs (no-GSAP fallback) it stays visible because .rdp-js is absent. */
.rdp-js .rdp-hero__inner { visibility: hidden; }
.rdp-js .rdp-hero__inner.rdp-hero-ready { visibility: visible; }
.rdp-hero__lead { font-size: clamp(1.05rem, 1.5vw, 1.35rem); font-weight: 300; max-width: 46ch; color: #f0f0f0; margin: 0 0 2.6rem; }

/* --- Floating hero card cluster (bottom-right) -------------------------
   Two-card stack. All sizing in vw so it scales with the viewport and stays
   pinned to the right edge on every screen (no fixed-px cap that drifts in). */
.rdp-cards {
  position: absolute; right: 3vw; bottom: -7vh;
  width: 34vw; height: 46vw;
  max-height: 88vh;
  z-index: 3; pointer-events: none;
}
.rdp-card {
  position: absolute; margin: 0; overflow: hidden;
  background: #1a1410;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.65);
  outline: 1px solid rgba(255,255,255,.10); outline-offset: -1px;
  will-change: transform;
}
/* Inner wrapper carries the idle float; .rdp-card carries JS mouse-parallax —
   two elements so the transforms never collide. */
.rdp-card__in { display: block; width: 100%; height: 100%; will-change: transform; }
.rdp-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* Three staggered, overlapping cards at different depths/sizes.
   Stacked low so the cluster mass sits at the bottom-right and spills down. */
/* Two-card stack: front card hugs the right edge, second sits behind-left. */
.rdp-card--1 { width: 21vw; aspect-ratio: 3/4; right: 0;     bottom: 0;    z-index: 3; }
.rdp-card--2 { width: 18vw; aspect-ratio: 3/4; right: 15vw;  bottom: 14%;  z-index: 2; }
.rdp-card--3 { display: none; }
/* Idle float — each on its own slow loop, staggered so they don't sync. */
.rdp-card--1 .rdp-card__in { animation: rdp-float1 9s ease-in-out infinite; }
.rdp-card--2 .rdp-card__in { animation: rdp-float2 11s ease-in-out infinite; }
.rdp-card--3 .rdp-card__in { animation: rdp-float3 13s ease-in-out infinite; }
@keyframes rdp-float1 { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-14px) rotate(-.6deg); } }
@keyframes rdp-float2 { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-20px) rotate(.8deg); } }
@keyframes rdp-float3 { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-10px) rotate(-1deg); } }

@media (max-width: 900px) { .rdp-cards { display: none; } }

.rdp-cta {
  display: inline-flex; align-items: center; gap: .9rem;
  padding: 1.15rem 2.6rem; font-family: var(--rdp-font);
  font-size: .82rem; letter-spacing: .22em; text-transform: uppercase; font-weight: 400;
  background: #fff; color: #000; border: 0; cursor: pointer; text-decoration: none;
  transition: background var(--rdp-slow) var(--rdp-ease), color var(--rdp-slow) var(--rdp-ease);
}
.rdp-cta:hover,
.rdp-cta:focus-visible { background: var(--rdp-gold); color: #1a1206 !important; }
.rdp-cta:focus-visible { outline: 2px solid var(--rdp-gold-lt); outline-offset: 3px; }
.rdp-cta--dark { background: #000; color: #fff; }
.rdp-cta--dark:hover,
.rdp-cta--dark:focus-visible { background: var(--rdp-gold); color: #1a1206 !important; }
.rdp-cta__arrow { width: 26px; height: 1px; background: currentColor; position: relative; transition: width var(--rdp-slow) var(--rdp-ease); }
.rdp-cta:hover .rdp-cta__arrow { width: 40px; }

/* Vertical scroll cue, pinned to the right edge (editorial). */
.rdp-scroll {
  position: absolute; right: clamp(1.2rem, 2.5vw, 2.6rem); bottom: clamp(2rem, 6vh, 5rem);
  z-index: 4; display: flex; flex-direction: column; align-items: center; gap: 1rem;
  font-size: .7rem; letter-spacing: .42em; text-transform: uppercase; color: rgba(255,255,255,.72);
}
.rdp-scroll span { writing-mode: vertical-rl; text-orientation: mixed; }
/* thin animated line beneath the word */
.rdp-scroll::after {
  content: ""; width: 1px; height: 64px; background: rgba(255,255,255,.45);
  transform-origin: top; animation: rdp-scrollline 2.4s ease-in-out infinite;
}
@keyframes rdp-scrollline {
  0%   { transform: scaleY(0); opacity: 0; }
  40%  { transform: scaleY(1); opacity: 1; }
  100% { transform: scaleY(1); opacity: 0; }
}

/* ==========================================================================
   STATS — black band, oversized figures
   ========================================================================== */
.rdp-stats { background: #000; color: #fff; padding: clamp(3.5rem, 7vw, 6rem) 0; }
.rdp-stats__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.rdp-stat { text-align: center; position: relative; }
.rdp-stat:not(:last-child)::after { content: ""; position: absolute; right: -1rem; top: 18%; bottom: 18%; width: 1px; background: rgba(255,255,255,.16); }
.rdp-stat__num { font-size: clamp(3.2rem, 6vw, 5.4rem); font-weight: 200; line-height: 1; color: var(--rdp-gold-lt); font-variant-numeric: tabular-nums; }
.rdp-stat__label { margin-top: .9rem; font-size: .72rem; letter-spacing: .26em; text-transform: uppercase; color: #cfcfcf; }

/* ==========================================================================
   INTRO — editorial two-column with vertical label
   ========================================================================== */
.rdp-intro { position: relative; overflow: hidden; background: var(--rdp-canvas); padding: clamp(5rem, 12vw, 10rem) 0; }
.rdp-intro > .rdp-wrap { position: relative; z-index: 1; }

/* Constantly-flowing warm mesh — soft drifting blobs, very subtle so text
   contrast is never affected. */
.rdp-intro__mesh { position: absolute; inset: -10%; z-index: 0; pointer-events: none; filter: blur(60px); opacity: .55; }
.rdp-blob { position: absolute; display: block; border-radius: 50% !important; will-change: transform; mix-blend-mode: multiply; }
.rdp-blob--1 {
  width: 48vw; height: 48vw; top: -6%; left: -8%;
  background: radial-gradient(circle at 50% 50%, rgba(175,154,117,.50) 0%, rgba(175,154,117,0) 70%);
  animation: rdp-drift1 24s ease-in-out infinite alternate;
}
.rdp-blob--2 {
  width: 42vw; height: 42vw; top: 20%; right: -10%;
  background: radial-gradient(circle at 50% 50%, rgba(255,188,125,.42) 0%, rgba(255,188,125,0) 70%);
  animation: rdp-drift2 30s ease-in-out infinite alternate;
}
.rdp-blob--3 {
  width: 40vw; height: 40vw; bottom: -14%; left: 26%;
  background: radial-gradient(circle at 50% 50%, rgba(241,211,159,.50) 0%, rgba(241,211,159,0) 70%);
  animation: rdp-drift3 27s ease-in-out infinite alternate;
}
@keyframes rdp-drift1 { 0% { transform: translate(0,0) scale(1); } 50% { transform: translate(8vw,5vh) scale(1.15); } 100% { transform: translate(3vw,-4vh) scale(1.05); } }
@keyframes rdp-drift2 { 0% { transform: translate(0,0) scale(1.05); } 50% { transform: translate(-7vw,6vh) scale(1); } 100% { transform: translate(-3vw,-5vh) scale(1.18); } }
@keyframes rdp-drift3 { 0% { transform: translate(0,0) scale(1); } 50% { transform: translate(-6vw,-6vh) scale(1.12); } 100% { transform: translate(5vw,3vh) scale(1); } }

/* --- Architectural draft layer: blueprint grid + drafting marks ------- */
.rdp-intro__draft { position: absolute; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
/* Fine + coarse graph-paper grid, slowly drifting.
   Line color driven by --rdp-grid-rgb so sections can invert it on dark bg. */
.rdp-grid,
.rdp-process::before, .rdp-projects::before, .rdp-brands::before,
.rdp-stats::before, .rdp-contact::before,
.rdp-sectors::after,
.rdp-hero::after {
  --rdp-grid-rgb: 120,120,120;
  content: ""; position: absolute; inset: -80px; z-index: 0; opacity: .5; pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(var(--rdp-grid-rgb),.10) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(var(--rdp-grid-rgb),.10) 1px, transparent 1px),
    linear-gradient(to right, rgba(var(--rdp-grid-rgb),.16) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(var(--rdp-grid-rgb),.16) 1px, transparent 1px);
  background-size: 40px 40px, 40px 40px, 200px 200px, 200px 200px;
  will-change: transform;
  animation: rdp-gridshift 40s linear infinite;
}
@keyframes rdp-gridshift { from { transform: translate(0,0); } to { transform: translate(40px,40px); } }

/* Apply the grid to plain-background sections via ::before (no extra markup).
   Each needs position+overflow and content above the grid. */
.rdp-process, .rdp-projects, .rdp-brands, .rdp-stats, .rdp-contact { position: relative; overflow: hidden; }
.rdp-process > *, .rdp-projects > *, .rdp-brands > *, .rdp-stats > *, .rdp-contact > * { position: relative; z-index: 1; }
/* Dark sections: invert grid to light lines, lower opacity so it stays subtle. */
.rdp-stats::before, .rdp-contact::before { --rdp-grid-rgb: 235,235,235; opacity: .5; }
/* Sectors has an image bg — overlay the inverted grid above the scrim, below content. */
.rdp-sectors::after { z-index: 1; --rdp-grid-rgb: 245,245,245; opacity: .22; }
/* Hero — inverted grid above the media, below content & cards.
   inset:-80px gives drift overscan; clip-path:inset(80px) trims the spill back to
   the hero's own box (the hero is overflow:visible so the cards can escape). */
.rdp-hero::after { z-index: 1; --rdp-grid-rgb: 245,245,245; opacity: .20; clip-path: inset(80px); }


/* Drafting marks — thin grey, sharp, floating. */
.rdp-mark { position: absolute; display: block; will-change: transform; opacity: .55; }
.rdp-mark--cross { width: 34px; height: 34px; }
.rdp-mark--cross::before, .rdp-mark--cross::after { content: ""; position: absolute; background: rgba(110,110,110,.45); }
.rdp-mark--cross::before { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-.5px); }
.rdp-mark--cross::after  { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-.5px); }
.rdp-mark--square { width: 46px; height: 46px; border: 1px solid rgba(110,110,110,.40); }
.rdp-mark--reg { width: 40px; height: 40px; border: 1px solid rgba(110,110,110,.40); }
.rdp-mark--reg::before { content: ""; position: absolute; inset: -8px; border: 1px solid rgba(110,110,110,.22); }
.rdp-mark--reg::after  { content: ""; position: absolute; left: 50%; top: 50%; width: 7px; height: 7px; background: rgba(175,154,117,.5); transform: translate(-50%,-50%); }

.rdp-mark--a { top: 14%; left: 12%; animation: rdp-mfloat-a 22s ease-in-out infinite; }
.rdp-mark--b { top: 24%; right: 16%; animation: rdp-mfloat-b 26s ease-in-out infinite; }
.rdp-mark--c { bottom: 18%; left: 30%; animation: rdp-mfloat-c 30s ease-in-out infinite; }
.rdp-mark--d { bottom: 26%; right: 28%; animation: rdp-mfloat-a 28s ease-in-out infinite reverse; }
.rdp-mark--e { top: 50%; left: 6%; animation: rdp-mfloat-b 24s ease-in-out infinite; }
@keyframes rdp-mfloat-a { 0%,100% { transform: translate(0,0) rotate(0); } 50% { transform: translate(16px,-22px) rotate(2deg); } }
@keyframes rdp-mfloat-b { 0%,100% { transform: translate(0,0); } 50% { transform: translate(-20px,14px); } }
@keyframes rdp-mfloat-c { 0%,100% { transform: translate(0,0) rotate(0); } 50% { transform: translate(12px,18px) rotate(-3deg); } }
.rdp-intro__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(2rem, 6vw, 6rem); align-items: start; }
.rdp-vlabel { writing-mode: vertical-rl; transform: rotate(180deg); font-size: .74rem; letter-spacing: .5em; text-transform: uppercase; color: var(--rdp-grey); }
.rdp-intro__left { display: flex; gap: clamp(1rem, 3vw, 2.4rem); }
.rdp-intro__display { font-size: var(--rdp-display); font-weight: 200; line-height: .9; color: var(--rdp-gold); letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.rdp-intro__display .rdp-count { display: inline-block; }
.rdp-intro__display .rdp-count::after { content: "+"; }
.rdp-intro__display small { display: block; font-size: .9rem; letter-spacing: .24em; text-transform: uppercase; color: var(--rdp-ink-soft); margin-top: 1rem; font-weight: 400; }
.rdp-prose p { font-size: var(--rdp-body); line-height: 1.85; margin: 0 0 1.4rem; max-width: 62ch; color: var(--rdp-ink-soft); }
.rdp-prose p:first-child { font-size: clamp(1.2rem, 1.8vw, 1.6rem); line-height: 1.6; color: var(--rdp-ink); font-weight: 300; }
.rdp-prose strong { font-weight: 500; color: var(--rdp-ink); }

/* ==========================================================================
   PROCESS — numbered editorial steps
   ========================================================================== */
.rdp-process { background: var(--rdp-canvas); padding: clamp(5rem, 11vw, 9rem) 0; }
.rdp-sec-head { text-align: center; margin-bottom: clamp(3rem, 6vw, 5rem); }
.rdp-sec-head .rdp-eyebrow { color: var(--rdp-gold); }
.rdp-sec-title { font-size: var(--rdp-h2); font-weight: 200; text-transform: uppercase; letter-spacing: .02em; margin: .4rem 0 0; }
.rdp-sec-note { margin: 1rem auto 0; max-width: 52ch; font-size: .95rem; font-weight: 300; color: var(--rdp-ink-soft); }
.rdp-sectors .rdp-sec-note { color: #d8d8d8; }
.rdp-steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; border-top: 1px solid #e6e6e6; }
.rdp-step { padding: 2.4rem 1.6rem; border-right: 1px solid #e6e6e6; transition: background var(--rdp-slow) var(--rdp-ease); }
.rdp-step:last-child { border-right: 0; }
.rdp-step:hover { background: var(--rdp-canvas); }
.rdp-step__n { font-size: 1rem; color: var(--rdp-grey); letter-spacing: .1em; font-variant-numeric: tabular-nums; }
.rdp-step__t { margin-top: 1.4rem; font-size: var(--rdp-h3); font-weight: 300; line-height: 1.25; }
.rdp-step__d { margin-top: .7rem; font-size: .95rem; color: var(--rdp-ink-soft); line-height: 1.6; }

/* ==========================================================================
   SECTORS — glass cards over parallax image
   ========================================================================== */
.rdp-sectors { position: relative; overflow: hidden; color: #fff; padding: clamp(5rem, 12vw, 10rem) 0; background: #111; }
/* Overscan must exceed the parallax travel (yPercent) or black shows through on scroll. */
.rdp-sectors__bg { position: absolute; inset: -22% 0; z-index: 0; background-size: cover; background-position: center 38%; will-change: transform; }
.rdp-sectors__scrim { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(8,7,6,.62) 0%, rgba(8,7,6,.50) 45%, rgba(8,7,6,.68) 100%); }
.rdp-sectors__inner { position: relative; z-index: 2; }
.rdp-sectors__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem; margin-top: clamp(2.5rem, 5vw, 4rem); }
.rdp-glass {
  background: rgba(255,255,255,.08);
  -webkit-backdrop-filter: blur(12px) saturate(120%);
  backdrop-filter: blur(12px) saturate(120%);
  border: 1px solid rgba(255,255,255,.14);
  padding: clamp(2rem, 3vw, 3rem);
  transition: background var(--rdp-slow) var(--rdp-ease), transform var(--rdp-slow) var(--rdp-ease);
}
.rdp-glass:hover { background: rgba(255,255,255,.13); transform: translateY(-6px); }
.rdp-glass__t { font-size: var(--rdp-h3); font-weight: 300; margin: 0 0 1rem; }
.rdp-glass__d { font-size: .98rem; color: #e9e9e9; line-height: 1.7; margin: 0; }
.rdp-glass__line { width: 38px; height: 1px; background: var(--rdp-gold-lt); margin-bottom: 1.6rem; }

/* ==========================================================================
   PROJECTS — credentials grid, oversized numerals
   ========================================================================== */
.rdp-projects { background: var(--rdp-canvas); padding: clamp(5rem, 12vw, 10rem) 0; }
.rdp-projects__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.6rem, 3vw, 3rem); margin-top: clamp(2.5rem, 5vw, 4rem); }
.rdp-proj { border-top: 1px solid #ddd; padding-top: 1.6rem; }
.rdp-proj__n { font-size: clamp(3rem, 5vw, 4.6rem); font-weight: 200; line-height: 1; color: var(--rdp-gold); font-variant-numeric: tabular-nums; }
.rdp-proj__t { margin-top: 1rem; font-size: 1.18rem; font-weight: 400; }
.rdp-proj__m { margin-top: .35rem; font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--rdp-grey); }

/* ==========================================================================
   BRANDS — marquee of houses
   ========================================================================== */
.rdp-brands { background: var(--rdp-canvas); padding: clamp(4rem, 9vw, 7rem) 0; overflow: hidden; }
.rdp-brands__rail { margin-top: clamp(2rem, 4vw, 3rem); display: flex; gap: 3.4rem; width: max-content; animation: rdp-marquee 42s linear infinite; }
.rdp-brands:hover .rdp-brands__rail { animation-play-state: paused; }
.rdp-brand { font-size: clamp(1.3rem, 2.4vw, 2.1rem); font-weight: 300; letter-spacing: .04em; color: var(--rdp-ink); white-space: nowrap; opacity: .55; transition: opacity var(--rdp-slow) var(--rdp-ease); }
.rdp-brand:hover { opacity: 1; }
@keyframes rdp-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ==========================================================================
   CONTACT — black close
   ========================================================================== */
.rdp-contact { background: #000; color: #fff; padding: clamp(5rem, 12vw, 10rem) 0; text-align: center; }
.rdp-contact__title { font-size: var(--rdp-h2); font-weight: 200; text-transform: uppercase; letter-spacing: .03em; margin: 0 0 1.2rem; }
.rdp-contact__lead { font-size: clamp(1.05rem, 1.4vw, 1.28rem); color: #dcdcdc; max-width: 56ch; margin: 0 auto 3rem; line-height: 1.7; }
.rdp-contact__phones { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: clamp(.6rem, 2vw, 1.6rem); }
.rdp-contact__phone { display: inline-block; font-size: clamp(1.9rem, 3.8vw, 3.2rem); font-weight: 200; color: var(--rdp-gold-lt); letter-spacing: .04em; text-decoration: none; transition: color var(--rdp-slow) var(--rdp-ease); }
.rdp-contact__phone:hover { color: #fff; }
.rdp-contact__phsep { font-size: clamp(1.5rem, 3vw, 2.4rem); color: var(--rdp-grey); font-weight: 200; }
@media (max-width: 560px) { .rdp-contact__phsep { display: none; } }
.rdp-contact__addr { margin: 1.4rem 0 2.8rem; font-size: .76rem; letter-spacing: .2em; text-transform: uppercase; color: var(--rdp-grey); }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
  .rdp-steps { grid-template-columns: repeat(2, 1fr); }
  .rdp-step { border-bottom: 1px solid #e6e6e6; }
  .rdp-step:nth-child(2n) { border-right: 0; }
  .rdp-projects__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .rdp-intro__grid { grid-template-columns: 1fr; }
  .rdp-vlabel { writing-mode: horizontal-tb; transform: none; }
  .rdp-stats__grid { grid-template-columns: 1fr; gap: 2.6rem; }
  .rdp-stat:not(:last-child)::after { display: none; }
  .rdp-sectors__grid { grid-template-columns: 1fr; }
  .rdp-steps { grid-template-columns: 1fr; }
  .rdp-step { border-right: 0; }
  .rdp-projects__grid { grid-template-columns: 1fr 1fr; }
  .rdp-hero { background-attachment: scroll; }
}

/* ==========================================================================
   REDUCED MOTION — kill all motion, keep content visible
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
  .rdp-biz .rdp-rise { opacity: 1 !important; transform: none !important; transition: none !important; }
  .rdp-hero__bg, .rdp-sectors__bg, .rdp-hero__bg::before { transform: none !important; animation: none !important; }
  .rdp-brands__rail { animation: none !important; transform: none !important; flex-wrap: wrap; justify-content: center; }
  .rdp-scroll::after { animation: none !important; transform: scaleY(1) !important; opacity: .45 !important; }
  .rdp-blob { animation: none !important; }
  .rdp-grid, .rdp-mark { animation: none !important; }
  .rdp-biz * { transition-duration: .01ms !important; animation-duration: .01ms !important; }
}
