/* ============================================
   RAMBLA STUDIO — Custom Overrides v4.0
   Cinematic editorial homepage
   ============================================ */

/* ---- KEYFRAMES ---- */
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-33.333%)}}
@keyframes orb{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.12);opacity:1}}
@keyframes spinSlow{to{transform:rotate(360deg)}}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.12}50%{transform:scale(1.06);opacity:.22}}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes sweep{to{left:150%}}
@keyframes countUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes lineGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes textReveal{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 20px rgba(45,212,191,.08)}50%{box-shadow:0 0 50px rgba(45,212,191,.18)}}

/* ---- GLOBALS ---- */
body{cursor:default!important;overflow-x:hidden!important}
html{scroll-behavior:smooth}

/* Kill all noise/grain overlays */
.noise,.rambla-noise,.grain-overlay{display:none!important}
.grain-overlay::before{display:none!important}
div[style*="noiseFilter"],div[style*="feTurbulence"],div[style*="fractalNoise"]{display:none!important}

/* Scroll progress */
.rambla-scroll-progress{position:fixed;top:0;left:0;height:2px;z-index:200;background:linear-gradient(90deg,#2DD4BF,#818cf8);width:0%;pointer-events:none;transition:width .1s linear}

/* ---- HIDE React elements ---- */
nav.fixed{display:none!important}
footer[class*="relative w-full"]{display:none!important}
section[code-path*="Team.tsx"],section[code-path*="Services.tsx"],section[code-path*="Contact.tsx"]{display:none!important}
#root section#team,#root section#services,#root section#contact{display:none!important}
section[code-path*="RamblaExtreme"],[code-path*="RamblaExtreme"]{display:none!important}
section[code-path*="Manifesto.tsx"]{display:none!important}
section[code-path*="SocialProof.tsx"]{display:none!important}
section[code-path*="App.tsx:79"]{display:none!important}

/* ---- UNIFIED NAV ---- */
nav.rambla-nav{position:fixed!important;top:0;left:0;right:0;z-index:100!important;backdrop-filter:blur(24px) saturate(1.6)!important;-webkit-backdrop-filter:blur(24px) saturate(1.6)!important;background:rgba(5,5,5,.55)!important;border-bottom:1px solid rgba(255,255,255,.04)!important;display:flex!important}
nav.rambla-nav .nav-inner{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:4.5rem;width:100%}
nav.rambla-nav .nav-logo{display:flex;align-items:center;gap:.65rem;text-decoration:none}
nav.rambla-nav .nav-logo img{height:32px;width:auto;object-fit:contain}
nav.rambla-nav .nav-links{display:flex;align-items:center;gap:1.8rem}
nav.rambla-nav .nav-links a{font-family:'Unbounded',sans-serif;font-size:.68rem;color:rgba(255,255,255,.4);text-decoration:none;text-transform:uppercase;letter-spacing:.1em;font-weight:600;transition:color .3s}
nav.rambla-nav .nav-links a:hover{color:#fff}
nav.rambla-nav .nav-links a.active{color:#2DD4BF}
nav.rambla-nav .nav-links a.extreme{color:#f87171}
nav.rambla-nav .nav-links a.extreme:hover{color:#fca5a5}

/* Hamburger button */
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:.5rem;z-index:110;position:relative}
.nav-hamburger span{display:block;width:22px;height:2px;background:#fff;margin:5px 0;transition:all .3s cubic-bezier(.25,.46,.45,.94);border-radius:2px}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:translateX(-10px)}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav overlay */
.nav-mobile-overlay{position:fixed;inset:0;z-index:105;background:rgba(5,5,5,.97);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity .4s cubic-bezier(.25,.46,.45,.94)}
.nav-mobile-overlay.open{opacity:1;pointer-events:all}
.nav-mobile-overlay a{font-family:'Unbounded',sans-serif;font-size:clamp(1.4rem,4vw,2rem);font-weight:700;color:rgba(255,255,255,.6);text-decoration:none;text-transform:uppercase;letter-spacing:.08em;transition:color .3s,transform .3s;transform:translateY(10px);opacity:0}
.nav-mobile-overlay.open a{transform:translateY(0);opacity:1}
.nav-mobile-overlay.open a:nth-child(1){transition-delay:.05s}
.nav-mobile-overlay.open a:nth-child(2){transition-delay:.1s}
.nav-mobile-overlay.open a:nth-child(3){transition-delay:.15s}
.nav-mobile-overlay.open a:nth-child(4){transition-delay:.2s}
.nav-mobile-overlay.open a:nth-child(5){transition-delay:.25s}
.nav-mobile-overlay a:hover{color:#fff;transform:scale(1.05)}
.nav-mobile-overlay a.active{color:#2DD4BF}
.nav-mobile-overlay a.extreme{color:#f87171}
.nav-mobile-overlay a.extreme:hover{color:#fca5a5}
.nav-mobile-logo{margin-bottom:2rem}
.nav-mobile-logo img{height:40px;width:auto}

@media(max-width:768px){
  nav.rambla-nav .nav-links{display:none!important}
  .nav-hamburger{display:block!important}
  nav.rambla-nav .nav-logo img{content:url('./assets/loghi/png/RamblaGradient02/RamblaGradient02_esteso.png');height:28px}
}

/* ---- HERO (React - keep) ---- */
section[code-path*="Hero.tsx"]{min-height:100vh!important;min-height:100dvh!important;overflow:visible!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:flex-end!important;padding-bottom:9rem!important}
div[code-path*="Hero.tsx:76"]{overflow:visible!important;padding:0 0 .1rem!important;margin:0 auto .2rem!important;max-width:min(100%,740px)!important}
section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:76"] img{max-height:clamp(38px,7.5vw,58px)!important;width:auto!important;height:auto!important;object-fit:contain!important}
div[code-path*="Hero.tsx:71"]{overflow:visible!important;max-width:100vw!important;width:100%!important;padding-left:1rem!important;padding-right:1rem!important;box-sizing:border-box!important}
/* Hero wordmark sopra "We Play Serious": RAMBLA black (peso) + STUDIO extralight — tutto bianco puro */
section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:76"] span.font-black,
section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:76"] span.font-extralight{
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  text-shadow:none!important;
  filter:none!important;
  font-family:'Unbounded',sans-serif!important;
  letter-spacing:-.02em!important;
}
section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:76"] span.font-black{font-weight:900!important}
section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:76"] span.font-extralight{font-weight:200!important}
section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:76"] .font-unbounded{font-size:clamp(1.32rem,4.65vw,2.1rem)!important;line-height:1!important}
div[code-path*="Hero.tsx:120"]{display:none!important}

/* ---- HOME HERO VIDEO & IMMERSIVE ---- */
section[code-path*="Hero.tsx"]{position:relative!important;overflow:hidden!important}
.home-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.4;filter:brightness(.75) contrast(1.1);transition:opacity .8s ease,filter .8s ease}
.home-hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(to bottom,rgba(5,5,5,.2) 0%,rgba(5,5,5,.05) 40%,rgba(5,5,5,.1) 70%,#050505 100%);transition:background .8s ease}
section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:71"]{position:relative!important;z-index:10!important;transition:all .9s cubic-bezier(.25,.46,.45,.94)!important}

/* Grid overlay above video */
section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:140"]{z-index:2!important;opacity:.02!important}

.home-hero-tagline{font-family:'Unbounded',sans-serif;font-size:clamp(1.2rem,3.5vw,2.5rem);font-weight:800;letter-spacing:-.02em;color:#fff;margin-top:.15rem;margin-bottom:.2rem;opacity:0;animation:fadeUp .8s ease-out .3s forwards;transition:opacity .5s,transform .5s,height .5s,margin .5s;line-height:1.1}

.home-hero-play{position:relative;z-index:10;display:inline-flex;align-items:center;gap:.75rem;margin:1rem auto 0;cursor:pointer;border:none;padding:.5rem 1.2rem;border-radius:9999px;border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:rgba(255,255,255,.04);transition:all .4s cubic-bezier(.25,.46,.45,.94);opacity:0;animation:fadeUp .8s ease-out .85s forwards}
.home-hero-play:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.3);transform:scale(1.05)}
.home-hero-play .play-icon{width:36px;height:36px;border-radius:50%;background:rgba(45,212,191,.12);border:1px solid rgba(45,212,191,.25);display:flex;align-items:center;justify-content:center;transition:all .3s}
.home-hero-play:hover .play-icon{background:rgba(45,212,191,.25);border-color:rgba(45,212,191,.45)}
.home-hero-play .play-icon svg{width:14px;height:14px;fill:#2DD4BF;margin-left:2px}
.home-hero-play .play-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.5);font-weight:500;font-family:'Space Grotesk',sans-serif;transition:color .3s}
.home-hero-play:hover .play-label{color:rgba(255,255,255,.8)}

/* Immersive state */
section[code-path*="Hero.tsx"].home-immersive .home-hero-scrim{background:linear-gradient(to bottom,rgba(5,5,5,.05) 0%,rgba(5,5,5,0) 40%,rgba(5,5,5,.15) 80%,#050505 100%)}
section[code-path*="Hero.tsx"].home-immersive .home-hero-video{opacity:1;filter:brightness(.95) contrast(1.05)}
section[code-path*="Hero.tsx"].home-immersive div[code-path*="Hero.tsx:71"]{transform:translateY(8vh) scale(.6)!important;opacity:.9!important;pointer-events:none;text-align:center!important;filter:drop-shadow(0 8px 30px rgba(0,0,0,.6))}
section[code-path*="Hero.tsx"].home-immersive div[code-path*="Hero.tsx:76"] span.font-black,
section[code-path*="Hero.tsx"].home-immersive div[code-path*="Hero.tsx:76"] span.font-extralight{
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  text-shadow:none!important;
  background:none!important;
  -webkit-background-clip:unset!important;
  background-clip:unset!important;
}
/* Hide gradient line + its container permanently */
div[code-path*="Hero.tsx:116"]{display:none!important}
div[code-path*="Hero.tsx:114"]{display:none!important}

section[code-path*="Hero.tsx"].home-immersive .home-hero-tagline{opacity:0!important;height:0;margin:0;overflow:hidden;transition:opacity .4s,height .4s,margin .4s}
section[code-path*="Hero.tsx"].home-immersive .home-hero-play{opacity:0!important;pointer-events:none;transition:opacity .3s}
section[code-path*="Hero.tsx"].home-immersive div[code-path*="Hero.tsx:120"]{opacity:0!important;pointer-events:none;transition:opacity .3s}
section[code-path*="Hero.tsx"].home-immersive p[code-path*="Hero.tsx"]{opacity:0!important;visibility:hidden;height:0;margin:0;overflow:hidden}

/* Reduce subtitle spacing, increase size */
section[code-path*="Hero.tsx"] p[code-path*="Hero.tsx"]{font-size:clamp(.9rem,1.4vw,1.1rem)!important;margin-top:0!important;margin-bottom:0!important;padding:0!important;opacity:.55!important;line-height:1.4!important}
section[code-path*="Hero.tsx"] div.mt-12{margin-top:.6rem!important}
section[code-path*="Hero.tsx"] div.mt-6{margin-top:.4rem!important}
section[code-path*="Hero.tsx"] div.mt-8{margin-top:.4rem!important}

.home-hero-controls{position:absolute;bottom:5rem;left:50%;transform:translateX(-50%);z-index:20;display:flex;align-items:center;gap:1rem;opacity:0;pointer-events:none;transition:all .5s cubic-bezier(.25,.46,.45,.94) .4s}
section[code-path*="Hero.tsx"].home-immersive .home-hero-controls{opacity:1;pointer-events:all}
.home-hero-close,.home-hero-sound{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.2rem;border:1px solid rgba(255,255,255,.12);border-radius:9999px;background:rgba(5,5,5,.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);cursor:pointer;transition:all .3s}
.home-hero-close svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2}
.home-hero-close span,.home-hero-sound span{font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;color:rgba(255,255,255,.6);font-weight:500;font-family:'Space Grotesk',sans-serif}
.home-hero-close:hover,.home-hero-sound:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25)}
.home-hero-close:hover span,.home-hero-sound:hover span{color:#fff}
.home-hero-sound svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}

.home-hero-video-fade{opacity:.25!important;transition:opacity .4s ease}

/* ---- CLIENT LOGO CAROUSEL (inside hero) ---- */
@keyframes logoScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.r-logos{position:absolute;bottom:2rem;left:0;right:0;z-index:12;padding:1.5rem 0;overflow:hidden;transition:opacity .5s}
.r-logos-label{text-align:center;font-size:.55rem;text-transform:uppercase;letter-spacing:.35em;color:rgba(255,255,255,.25);font-weight:600;font-family:'Space Grotesk',sans-serif;margin-bottom:1rem}
.r-logos-track{display:flex;align-items:center;width:max-content;gap:3.5rem;animation:logoScroll 35s linear infinite}
.r-logos-track:hover{animation-play-state:paused}
.r-logos-item{flex-shrink:0;height:45px;width:auto;opacity:.5;filter:brightness(0) invert(1);transition:all .4s ease}
.r-logos-item:hover{opacity:.85}
section[code-path*="Hero.tsx"].home-immersive .r-logos{opacity:0;pointer-events:none}

/* ---- MARQUEE (hidden) ---- */
.rambla-marquee-wrap{display:none!important}

/* ---- CINEMATIC VIDEO HERO (single bg video, height = video aspect) ---- */
.r-vhero{position:relative;width:100%;height:auto;overflow:hidden;z-index:5;background:#050505;line-height:0}
.r-vhero-bg{position:relative;width:100%;height:auto;vertical-align:top;display:block;object-fit:contain}
.r-vhero-overlay{position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(5,5,5,.75) 0%,rgba(5,5,5,.35) 55%,rgba(5,5,5,.15) 100%)}
.r-vhero-content{position:absolute;inset:0;z-index:3;display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem;pointer-events:none}
@keyframes rVheroLineIn{0%{opacity:0;transform:translateY(22px) scale(.985);filter:blur(6px)}100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}
@keyframes rVheroLineInReduced{0%{opacity:0}100%{opacity:1}}
.r-vhero-copy{display:flex;flex-direction:column;align-items:center;gap:clamp(.75rem,2vw,1.25rem);max-width:min(36rem,100%)}
.r-vhero-copy .r-vhero-title-line,
.r-vhero-copy h2 em.r-vhero-title-accent,
.r-vhero-copy .r-vhero-tagline span.r-vhero-tagline-line{opacity:0;transform:translateY(22px) scale(.985);filter:blur(6px)}
.r-vhero.r-reveal.shown .r-vhero-copy .r-vhero-title-line{animation:rVheroLineIn .88s cubic-bezier(.23,1,.32,1) .85s forwards}
.r-vhero.r-reveal.shown .r-vhero-copy h2 em.r-vhero-title-accent{animation:rVheroLineIn .88s cubic-bezier(.23,1,.32,1) 1.08s forwards}
.r-vhero.r-reveal.shown .r-vhero-copy .r-vhero-tagline span.r-vhero-tagline-line:nth-of-type(1){animation:rVheroLineIn .82s cubic-bezier(.23,1,.32,1) 1.32s forwards}
.r-vhero.r-reveal.shown .r-vhero-copy .r-vhero-tagline span.r-vhero-tagline-line:nth-of-type(2){animation:rVheroLineIn .82s cubic-bezier(.23,1,.32,1) 1.55s forwards}
.r-vhero-title-line{display:inline-block;white-space:nowrap;color:#fff}
.r-vhero-content h2{font-family:'Unbounded',sans-serif;font-size:clamp(1.8rem,5.5vw,5rem);font-weight:900;letter-spacing:-.03em;line-height:1.12;margin:0;text-shadow:0 4px 40px rgba(0,0,0,.6)}
.r-vhero-content h2 em.r-vhero-title-accent{font-style:normal;background:linear-gradient(135deg,#2DD4BF,#818cf8);-webkit-background-clip:text;background-clip:text;color:transparent}
.r-vhero-tagline{font-family:'Space Grotesk',sans-serif;font-size:clamp(.78rem,1.75vw,.95rem);font-weight:500;color:rgba(255,255,255,.72);line-height:1.38;letter-spacing:.015em;margin:0;max-width:min(32rem,92vw);text-shadow:0 2px 28px rgba(0,0,0,.65)}
.r-vhero-tagline-line{display:block}
/* seconda riga più vicina alla prima (niente <br> tra i block per evitare riga fantasma) */
.r-vhero-tagline .r-vhero-tagline-line+.r-vhero-tagline-line{margin-top:-.2rem!important}
.r-vhero-tag-yes{font-weight:700;color:#5eead4;text-shadow:0 0 24px rgba(45,212,191,.35)}
.r-vhero-tag-no{font-weight:700;color:#fca5a5;text-shadow:0 0 24px rgba(248,113,113,.3)}
@media (prefers-reduced-motion:reduce){
  .r-vhero-copy .r-vhero-title-line,
  .r-vhero-copy h2 em.r-vhero-title-accent,
  .r-vhero-copy .r-vhero-tagline span.r-vhero-tagline-line{transform:none;filter:none}
  .r-vhero.r-reveal.shown .r-vhero-copy .r-vhero-title-line,
  .r-vhero.r-reveal.shown .r-vhero-copy h2 em.r-vhero-title-accent,
  .r-vhero.r-reveal.shown .r-vhero-copy .r-vhero-tagline span.r-vhero-tagline-line{animation-name:rVheroLineInReduced;animation-duration:.28s;animation-timing-function:ease-out}
  .r-vhero.r-reveal.shown .r-vhero-copy .r-vhero-title-line{animation-delay:.05s}
  .r-vhero.r-reveal.shown .r-vhero-copy h2 em.r-vhero-title-accent{animation-delay:.12s}
  .r-vhero.r-reveal.shown .r-vhero-copy .r-vhero-tagline span.r-vhero-tagline-line:nth-of-type(1){animation-delay:.18s}
  .r-vhero.r-reveal.shown .r-vhero-copy .r-vhero-tagline span.r-vhero-tagline-line:nth-of-type(2){animation-delay:.24s}
}

/* ---- SPLIT STATEMENT ---- */
.r-split{position:relative;z-index:5;display:grid;grid-template-columns:1fr 1fr;min-height:80vh;overflow:hidden}
.r-split-left{display:flex;align-items:center;padding:6rem 4rem 6rem 6rem;position:relative}
.r-split-left::after{content:'';position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.04) 30%,rgba(255,255,255,.04) 70%,transparent)}
.r-split-text{max-width:500px}
.r-split-label{font-size:.6rem;color:#2DD4BF;text-transform:uppercase;letter-spacing:.35em;margin-bottom:1.5rem;display:block}
.r-split-title{font-family:'Unbounded',sans-serif;font-size:clamp(2rem,3.5vw,3.2rem);font-weight:800;color:#fff;line-height:1.15;letter-spacing:-.02em;margin-bottom:1.5rem}
.r-split-title em{font-style:normal;background:linear-gradient(135deg,#2DD4BF,#818cf8);-webkit-background-clip:text;background-clip:text;color:transparent}
.r-split-body{font-size:.9rem;color:rgba(255,255,255,.4);line-height:1.75;margin-bottom:2rem}
.r-split-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.r-split-tag{padding:.3rem .7rem;border-radius:9999px;font-size:.6rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.35);border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);transition:all .3s}
.r-split-tag:hover{border-color:rgba(45,212,191,.2);color:rgba(255,255,255,.6)}
.r-split-right{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#080810}
.r-split-right video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.3;filter:brightness(.5)}
.r-split-right-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;position:relative;z-index:2}
.r-split-right-ph svg{width:3rem;height:3rem;color:rgba(255,255,255,.06)}
.r-split-right-ph span{font-size:.5rem;color:rgba(255,255,255,.08);text-transform:uppercase;letter-spacing:.15em}
.r-split-orb{position:absolute;border-radius:50%;pointer-events:none}
.r-split-orb.a{top:-15%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(45,212,191,.05),transparent 70%);animation:orb 14s ease-in-out infinite}
.r-split-orb.b{bottom:-20%;right:-15%;width:600px;height:600px;background:radial-gradient(circle,rgba(129,140,248,.04),transparent 70%);animation:orb 11s ease-in-out infinite 4s}

/* ---- SERVICES GRID ---- */
.r-svc{position:relative;z-index:5;max-width:1400px;margin:0 auto;padding:7rem 2rem}
.r-svc-header{text-align:center;margin-bottom:4rem}
.r-svc-label{font-size:.58rem;color:#2DD4BF;text-transform:uppercase;letter-spacing:.4em;margin-bottom:.8rem}
.r-svc-title{font-family:'Unbounded',sans-serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:.6rem}
.r-svc-sub{font-size:.88rem;color:rgba(255,255,255,.35);max-width:480px;margin:0 auto;line-height:1.65}
.r-svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.r-svc-card{position:relative;padding:2rem 1.5rem;border-radius:1rem;border:1px solid rgba(255,255,255,.04);background:rgba(255,255,255,.012);overflow:hidden;transition:all .5s cubic-bezier(.23,1,.32,1);cursor:default}
.r-svc-card:hover{border-color:color-mix(in srgb,var(--sc) 22%,transparent);transform:translateY(-5px);box-shadow:0 25px 70px rgba(0,0,0,.35),0 0 35px color-mix(in srgb,var(--sc) 6%,transparent)}
.r-svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--sc),var(--sc2));transform:scaleX(0);transform-origin:left;transition:transform .6s cubic-bezier(.23,1,.32,1)}
.r-svc-card:hover::before{transform:scaleX(1)}
.r-svc-icon{width:42px;height:42px;border-radius:.7rem;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;background:color-mix(in srgb,var(--sc) 7%,transparent);border:1px solid color-mix(in srgb,var(--sc) 10%,transparent);transition:all .4s}
.r-svc-card:hover .r-svc-icon{transform:scale(1.06);background:color-mix(in srgb,var(--sc) 12%,transparent)}
.r-svc-icon svg{width:18px;height:18px;color:var(--sc)}
.r-svc-name{font-family:'Unbounded',sans-serif;font-size:.85rem;font-weight:800;color:#fff;margin-bottom:.3rem}
.r-svc-desc{font-size:.72rem;color:rgba(255,255,255,.35);line-height:1.55}
.r-svc-cta{text-align:center;margin-top:2.5rem}
.r-svc-cta a{display:inline-flex;align-items:center;gap:.55rem;font-family:'Unbounded',sans-serif;font-size:.68rem;font-weight:700;color:#2DD4BF;text-decoration:none;text-transform:uppercase;letter-spacing:.1em;padding:.7rem 1.8rem;border-radius:9999px;border:1px solid rgba(45,212,191,.18);background:rgba(45,212,191,.03);transition:all .4s cubic-bezier(.23,1,.32,1)}
.r-svc-cta a:hover{background:rgba(45,212,191,.08);border-color:rgba(45,212,191,.35);transform:translateY(-2px);box-shadow:0 12px 35px rgba(45,212,191,.08)}
.r-svc-cta a svg{width:13px;height:13px}

/* ---- STATS COUNTER ---- */
.r-stats{position:relative;z-index:5;padding:6rem 2rem;overflow:hidden}
.r-stats-orb{position:absolute;top:50%;left:50%;width:800px;height:800px;border-radius:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(45,212,191,.03),transparent 65%);pointer-events:none;animation:orb 12s ease-in-out infinite}
.r-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;max-width:1100px;margin:0 auto;position:relative;z-index:2}
.r-stats-item{text-align:center}
.r-stats-num{font-family:'Unbounded',sans-serif;font-size:clamp(2.5rem,5vw,4rem);font-weight:900;color:#fff;letter-spacing:-.03em;line-height:1}
.r-stats-num span{background:linear-gradient(135deg,#2DD4BF,#818cf8);-webkit-background-clip:text;background-clip:text;color:transparent}
.r-stats-label{font-size:.65rem;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.15em;margin-top:.6rem}

/* ---- FULL-WIDTH VIDEO QUOTE ---- */
.r-fwvid{position:relative;width:100%;aspect-ratio:21/9;overflow:hidden;z-index:5;background:#060608}
.r-fwvid video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.3;filter:brightness(.45) contrast(1.1)}
.r-fwvid-overlay{position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;background:rgba(5,5,5,.25)}
.r-fwvid-text{font-family:'Unbounded',sans-serif;font-size:clamp(1.2rem,3.8vw,3rem);font-weight:900;letter-spacing:-.02em;color:#fff;text-align:center;opacity:.85;max-width:900px;padding:0 2rem;line-height:1.2}
.r-fwvid-text em{font-style:normal;background:linear-gradient(135deg,#2DD4BF,#818cf8);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- CTA ---- */
.r-cta{position:relative;text-align:center;padding:9rem 2rem;overflow:hidden;z-index:5}
.r-cta-orb{position:absolute;top:50%;left:50%;width:700px;height:700px;border-radius:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(45,212,191,.04),transparent 65%);pointer-events:none;animation:orb 10s ease-in-out infinite}
.r-cta-deco{position:absolute;top:20%;left:10%;width:200px;height:200px;border-radius:50%;border:1px solid rgba(129,140,248,.04);animation:spinSlow 50s linear infinite;pointer-events:none}
.r-cta-content{position:relative;z-index:10}
.r-cta-title{font-family:'Unbounded',sans-serif;font-size:clamp(2rem,4.5vw,3.5rem);font-weight:800;color:#fff;margin-bottom:.8rem;letter-spacing:-.02em}
.r-cta-sub{font-family:'Space Grotesk',sans-serif;font-size:.95rem;color:rgba(255,255,255,.35);margin-bottom:2.5rem;max-width:430px;margin-left:auto;margin-right:auto;line-height:1.65}
.r-cta-btn{display:inline-flex;align-items:center;gap:.7rem;padding:1rem 2.4rem;border-radius:9999px;font-family:'Unbounded',sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff;background:linear-gradient(135deg,rgba(45,212,191,.1),rgba(129,140,248,.08));border:1px solid rgba(45,212,191,.25);text-decoration:none;transition:all .4s cubic-bezier(.23,1,.32,1);backdrop-filter:blur(8px)}
.r-cta-btn:hover{background:linear-gradient(135deg,rgba(45,212,191,.18),rgba(129,140,248,.15));border-color:rgba(45,212,191,.45);transform:translateY(-3px) scale(1.02);box-shadow:0 20px 60px rgba(45,212,191,.1)}
.r-cta-btn svg{width:1rem;height:1rem;color:#2DD4BF}

/* ---- DIVIDER ---- */
.r-divider{position:relative;width:100%;height:1px;overflow:visible;z-index:5;margin:1rem 0}
.r-divider-line{position:absolute;top:0;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,rgba(45,212,191,.15) 25%,rgba(129,140,248,.15) 50%,rgba(139,92,246,.15) 75%,transparent)}
.r-divider-dot{position:absolute;top:-3px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:#2DD4BF;box-shadow:0 0 12px rgba(45,212,191,.35);opacity:.7}

/* ---- SCROLL REVEAL ---- */
.r-reveal{opacity:0;transform:translateY(45px);transition:opacity .9s cubic-bezier(.23,1,.32,1),transform .9s cubic-bezier(.23,1,.32,1)}
.r-reveal.shown{opacity:1!important;transform:translateY(0)!important}

/* ---- CUSTOM FOOTER ---- */
.rambla-footer{position:relative;z-index:10;border-top:1px solid rgba(255,255,255,.04);background:linear-gradient(to top,rgba(0,0,0,.5),rgba(5,5,5,.95));padding:2.5rem 2rem 0}
.rambla-footer-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:start}
.rambla-footer-brand{display:flex;flex-direction:column;gap:.75rem}
.rambla-footer-logo{display:flex;align-items:center;gap:.65rem;text-decoration:none}
.rambla-footer-logo img{height:32px;width:auto;object-fit:contain}
.rambla-footer-tagline{font-size:.78rem;color:rgba(255,255,255,.35);line-height:1.65;max-width:360px}
.rambla-footer-company{font-size:.68rem;color:rgba(255,255,255,.22);line-height:1.7;margin-top:.25rem}
.rambla-footer-right{display:flex;flex-direction:column;align-items:flex-end;gap:1rem}
.rambla-footer-right h4{font-family:'Unbounded',sans-serif;font-size:.6rem;font-weight:700;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.15em;margin-bottom:.25rem;text-align:right}
.rambla-footer-right ul{list-style:none;display:flex;flex-direction:column;gap:.4rem;align-items:flex-end}
.rambla-footer-right ul li a{font-size:.75rem;color:rgba(255,255,255,.35);text-decoration:none;transition:color .3s}
.rambla-footer-right ul li a:hover{color:#fff}
.rambla-footer-social{display:flex;gap:.5rem}
.rambla-footer-social a{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);text-decoration:none;transition:all .3s}
.rambla-footer-social a:hover{color:#fff;background:rgba(45,212,191,.08);border-color:rgba(45,212,191,.25)}
.rambla-footer-social svg{width:14px;height:14px}
.rambla-footer-bottom{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0;margin-top:2rem;border-top:1px solid rgba(255,255,255,.04)}
.rambla-footer-copy{font-size:.62rem;color:rgba(255,255,255,.18)}
.rambla-footer-legal{display:flex;gap:1.5rem}
.rambla-footer-legal a{font-size:.6rem;color:rgba(255,255,255,.18);text-decoration:none;transition:color .3s}
.rambla-footer-legal a:hover{color:rgba(255,255,255,.5)}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){
  .r-svc-grid{grid-template-columns:repeat(2,1fr)}
  .r-split{grid-template-columns:1fr;min-height:auto}
  .r-split-left{padding:4rem 2rem}
  .r-split-left::after{display:none}
  .r-split-right{min-height:50vh}
  .r-stats-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem}
}
@media(max-width:768px){
  nav.rambla-nav .nav-links{gap:.9rem}
  nav.rambla-nav .nav-links a{font-size:.65rem}
  section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:76"] .font-unbounded{font-size:clamp(1.22rem,5.35vw,1.72rem)!important}
  div[code-path*="Hero.tsx:120"]{display:none!important}
  section[code-path*="Hero.tsx"].home-immersive div[code-path*="Hero.tsx:71"]{transform:translateY(8vh) scale(.6)}
  .home-hero-controls{bottom:3rem}
  .home-hero-tagline{font-size:clamp(1rem,3.5vw,1.8rem)}
  .r-logos-item{height:35px}
  .r-logos-track{gap:2.5rem}
  .r-logos{bottom:1.5rem}
  .r-svc-grid{grid-template-columns:1fr}
  .r-svc{padding:5rem 1.5rem}
  .r-split-left{padding:3rem 1.5rem}
  .r-split-right{min-height:40vh}
  .r-fwvid{aspect-ratio:16/9}
  .r-stats-grid{grid-template-columns:repeat(2,1fr);gap:2rem}
  .r-cta{padding:6rem 1.5rem}
  .rambla-footer-inner{grid-template-columns:1fr;gap:1.5rem}
  .rambla-footer-right{align-items:flex-start}
  .rambla-footer-right h4{text-align:left}
  .rambla-footer-right ul{align-items:flex-start}
  .rambla-footer-bottom{flex-direction:column;gap:.75rem;text-align:center}
  .rambla-footer{padding:2rem 1.5rem 0}
}
@media(max-width:480px){
  nav.rambla-nav .nav-links{gap:.5rem}
  nav.rambla-nav .nav-links a{font-size:.55rem;letter-spacing:.06em}
  nav.rambla-nav .nav-inner{padding:0 1rem}
  .home-hero-tagline{font-size:clamp(.85rem,3vw,1.4rem)}
  .home-hero-play{padding:.5rem 1rem}
  .home-hero-play .play-label{font-size:.55rem}
  .home-hero-controls{bottom:2rem;gap:.6rem}
  .r-logos-item{height:28px}
  .r-logos-track{gap:2rem}
  .r-logos{bottom:1rem;padding:1rem 0}
  .r-logos-label{font-size:.5rem;margin-bottom:.75rem}
  .r-stats-grid{grid-template-columns:1fr}
  .r-svc{padding:3.5rem 1rem}
  .r-cta{padding:5rem 1rem}
  .rambla-footer{padding:1.5rem 1rem 0}
  .rambla-footer-legal{gap:.75rem;flex-wrap:wrap;justify-content:center}
}
@media(min-width:1440px){
  section[code-path*="Hero.tsx"] div[code-path*="Hero.tsx:76"] .font-unbounded{font-size:clamp(1.48rem,2.65vw,2.2rem)!important}
}

/* Scrollbar */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#050505}
::-webkit-scrollbar-thumb{background:rgba(45,212,191,.12);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(45,212,191,.25)}
::selection{background:rgba(45,212,191,.2);color:#fff}
