/* =============================================================
   Pausas Activas — CINEMATIC index
   Full-screen scenes, a scroll-driven pinned intro, filmic wipes.
   Layout/chrome only; primitives come from the DS bundle.
   ============================================================= */

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:auto;}
body{margin:0;font-family:var(--font-body);font-size:16px;line-height:1.65;color:var(--color-text);background:#0B2C2F;-webkit-font-smoothing:antialiased;}
img,svg{display:block;max-width:100%;}
h1,h2,h3,h4{font-family:var(--font-display);margin:0;text-wrap:balance;letter-spacing:-0.02em;}

.container{width:100%;max-width:var(--container-max);margin:0 auto;padding-inline:var(--container-pad);}

/* Deep cinematic teal used for dark scenes */
:root{ --cine-bg:#0B2C2F; --cine-bg-2:#0E3539; }

/* ---------- Scroll progress + scene counter ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(var(--scroll,0));transform-origin:left;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));z-index:120;pointer-events:none;}
.scene-counter{position:fixed;right:24px;bottom:24px;z-index:115;display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.14em;color:rgba(255,255,255,.7);mix-blend-mode:difference;pointer-events:none;}
.scene-counter .cur{color:var(--color-accent);font-size:15px;}
.scene-counter .bar{width:42px;height:2px;background:rgba(255,255,255,.25);position:relative;overflow:hidden;}
.scene-counter .bar::after{content:"";position:absolute;inset:0;background:var(--color-accent);transform:scaleX(var(--scroll,0));transform-origin:left;}
@media(max-width:640px){.scene-counter{display:none;}}

/* ---------- Header (revealed after intro) ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:110;height:68px;display:flex;align-items:center;
  background:rgba(11,44,47,.55);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08);
  transform:translateY(-100%);transition:transform .6s cubic-bezier(.16,1,.3,1);}
.site-header.is-shown{transform:none;}
.header-inner{width:100%;display:flex;align-items:center;gap:24px;}
.brand-logo{height:40px;width:auto;}
.nav-primary{display:none;margin-left:auto;gap:26px;}
@media(min-width:1024px){.nav-primary{display:flex;}}
.nav-primary a{color:rgba(255,255,255,.8);font-weight:500;font-size:14px;text-decoration:none;position:relative;padding:4px 0;}
.nav-primary a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--color-accent);transform:scaleX(0);transform-origin:left;transition:transform .25s cubic-bezier(.16,1,.3,1);}
.nav-primary a:hover{color:#fff;}
.nav-primary a:hover::after{transform:scaleX(1);}
.header-actions{margin-left:auto;}
@media(min-width:1024px){.header-actions{margin-left:0;}}

/* =============================================================
   SCENE 1 — Cinematic intro (scroll-driven, pinned)
   ============================================================= */
.intro-hero{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;overflow:hidden;background:transparent;}
.intro-hero::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(circle at 50% 42%,rgba(14,53,57,.35),transparent 60%),
             linear-gradient(180deg,rgba(0,0,0,.30),transparent 26%,transparent 70%,var(--cine-bg) 99%);}

/* The ring system — FIXED background layer behind every section */
.intro-rings{position:fixed;top:50%;left:50%;width:min(80vmin,760px);aspect-ratio:1;z-index:0;pointer-events:none;
  transform:translate(-50%,-50%) scale(var(--ring-scale,.92));opacity:var(--ring-op,1);}
.intro-rings .r{position:absolute;inset:0;border-radius:50%;}
.intro-rings .r1{border:3px solid rgba(31,110,114,.9);animation:ring-spin 26s linear infinite;}
.intro-rings .r2{inset:11%;border:2px solid rgba(212,165,58,.85);animation:ring-spin 34s linear infinite reverse;}
.intro-rings .r3{inset:24%;border:1px dashed rgba(255,255,255,.18);animation:ring-spin 60s linear infinite;}
.intro-rings .r1::before{content:"";position:absolute;top:-7px;left:50%;width:13px;height:13px;border-radius:50%;background:var(--color-primary);transform:translateX(-50%);box-shadow:0 0 18px 2px rgba(31,110,114,.6);}
.intro-rings .r2::before{content:"";position:absolute;bottom:-6px;left:50%;width:11px;height:11px;border-radius:50%;background:var(--color-accent);transform:translateX(-50%);box-shadow:0 0 18px 2px rgba(212,165,58,.7);}
.intro-logo{width:min(26vmin,210px);filter:drop-shadow(0 10px 40px rgba(0,0,0,.5));}

/* Hero content — static, crossfades out on scroll */
.intro-hero-inner{position:relative;z-index:2;text-align:center;color:#fff;padding-inline:24px;display:flex;flex-direction:column;align-items:center;gap:22px;will-change:opacity,transform;}
.intro-tag{font-family:var(--font-display);font-weight:500;font-size:clamp(12px,1.6vw,16px);letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.66);}
.intro-headline{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,6.4vw,74px);line-height:1.06;letter-spacing:-.02em;color:#fff;max-width:18ch;margin:0;text-wrap:balance;}
.intro-headline .g{color:var(--color-accent);}
.intro-ctas{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:8px;}

.intro-scrollcue{position:absolute;z-index:2;bottom:34px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.6);opacity:var(--cue-op,1);}
.intro-scrollcue span{font-family:var(--font-display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;}
.intro-scrollcue .mouse{width:22px;height:34px;border:2px solid rgba(255,255,255,.5);border-radius:12px;position:relative;}
.intro-scrollcue .mouse::after{content:"";position:absolute;top:6px;left:50%;width:3px;height:7px;border-radius:2px;background:#fff;transform:translateX(-50%);animation:cue-dot 1.6s ease-in-out infinite;}
@keyframes cue-dot{0%{opacity:0;transform:translate(-50%,0);}30%{opacity:1;}100%{opacity:0;transform:translate(-50%,10px);}}

/* =============================================================
   Generic cinematic scenes
   ============================================================= */
.scene{position:relative;z-index:1;padding-block:clamp(80px,14vh,160px);}
.scene--dark{background:var(--cine-bg);color:#fff;}
.scene--dark2{background:var(--cine-bg-2);color:#fff;}
.scene--light{background:#fff;color:var(--color-text);}
.scene--alt{background:var(--color-bg-alt);color:var(--color-text);}
.scene--dark h2,.scene--dark2 h2,.scene--dark h3,.scene--dark2 h3{color:#fff;}
.scene--light h2,.scene--alt h2{color:var(--color-primary-dark);}

.eyebrow-cine{font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--color-accent);display:inline-flex;align-items:center;gap:12px;margin:0 0 22px;}
.eyebrow-cine::before{content:"";width:32px;height:1px;background:var(--color-accent);}
.eyebrow-cine.center{justify-content:center;}
.scene-title{font-size:clamp(30px,5.2vw,60px);line-height:1.06;font-weight:700;margin:0 0 20px;}
.scene-title .g{color:var(--color-accent);}
.scene-lead{font-size:clamp(16px,1.5vw,20px);line-height:1.6;max-width:62ch;margin:0;color:var(--color-text-muted);}
.scene--dark .scene-lead,.scene--dark2 .scene-lead{color:rgba(255,255,255,.72);}
.scene-head{max-width:880px;margin-bottom:clamp(48px,7vh,84px);}
.scene-head.center{margin-inline:auto;text-align:center;}

/* Filmic reveal — fully scroll-scrubbed from JS (opacity/transform/clip set
   inline per frame). These classes are just hidden-by-default + variant markers
   the script reads. JS-driven so it survives any animation-clock quirks. */
.cine{opacity:0;will-change:opacity,transform,clip-path;}
.cine--up,.cine--left,.cine--right{}

/* ---------- Promise scene (big statement) ---------- */
.promise{text-align:center;}
.promise h2{font-size:clamp(32px,6vw,84px);line-height:1.05;font-weight:700;color:#fff;max-width:18ch;margin:0 auto;}
.promise h2 .g{color:var(--color-accent);}
.promise .sub{margin:28px auto 0;max-width:54ch;font-size:clamp(16px,1.6vw,20px);color:rgba(255,255,255,.66);}

/* ---------- Services ---------- */
.services-grid{display:grid;gap:24px;grid-template-columns:1fr;}
@media(min-width:768px){.services-grid{grid-template-columns:repeat(2,1fr);gap:28px;}}

/* ---------- Benefits (huge numbers) ---------- */
.benefits-grid{display:grid;gap:1px;grid-template-columns:1fr;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);overflow:hidden;}
@media(min-width:768px){.benefits-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1024px){.benefits-grid{grid-template-columns:repeat(4,1fr);}}
.benefit-block{padding:40px 32px;background:var(--cine-bg);transition:background-color .4s ease;}
.benefit-block:hover{background:var(--cine-bg-2);}
.benefit-block .figure{font-family:var(--font-display);font-weight:700;font-size:clamp(48px,6vw,72px);line-height:1;color:var(--color-accent);letter-spacing:-.03em;font-variant-numeric:tabular-nums;}
.benefit-block .figure .unit{font-size:.5em;opacity:.7;margin-left:2px;}
.benefit-block h3{margin-top:18px;font-size:18px;font-weight:600;color:#fff;}
.benefit-block p{margin:10px 0 0;font-size:14px;line-height:1.6;color:rgba(255,255,255,.66);}

/* ---------- Method ---------- */
.method-steps{display:grid;gap:24px;grid-template-columns:1fr;}
@media(min-width:1024px){.method-steps{grid-template-columns:repeat(3,1fr);}}
.method-step{position:relative;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:36px 32px;}
.method-step .step-number{position:absolute;top:-18px;left:32px;background:var(--color-primary-dark);color:var(--color-accent);width:44px;height:44px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:16px;box-shadow:var(--shadow-md);}
.method-step .icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-md);background:var(--tint-accent-15);color:var(--color-primary);margin:18px 0 20px;}
.method-step .icon-wrap svg{width:28px;height:28px;}
.method-step h3{font-size:20px;font-weight:600;margin-bottom:8px;color:var(--color-primary-dark);}
.method-step p{color:var(--color-text-muted);font-size:15px;margin:0;}

/* ---------- About / Team ---------- */
.about-grid{display:grid;gap:48px;grid-template-columns:1fr;align-items:start;}
@media(min-width:1024px){.about-grid{grid-template-columns:1fr 1.25fr;gap:80px;}}
.about-copy p{color:var(--color-text-muted);font-size:17px;line-height:1.7;}
.about-stats{margin-top:32px;display:grid;grid-template-columns:repeat(2,1fr);gap:20px 16px;padding-top:32px;border-top:1px solid var(--color-border);}
.team-grid{display:grid;gap:20px;grid-template-columns:repeat(2,1fr);}
.team-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;text-align:center;transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s ease;}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.team-photo{width:92px;height:92px;border-radius:50%;margin:0 auto 16px;background:linear-gradient(135deg,var(--tint-primary-15),var(--tint-accent-15));display:flex;align-items:center;justify-content:center;border:3px solid #fff;box-shadow:0 0 0 1px var(--color-border);font-family:var(--font-display);font-weight:600;color:var(--color-primary-dark);font-size:22px;}
.team-card h4{font-family:var(--font-display);font-size:16px;font-weight:600;margin:0;}
.team-card .role{font-size:13px;color:var(--color-primary);font-weight:500;margin:4px 0;}
.team-card .specialty{font-size:12px;color:var(--color-text-muted);}

/* ---------- Testimonials (dark) ---------- */
.testimonials-grid{display:grid;gap:24px;grid-template-columns:1fr;}
@media(min-width:768px){.testimonials-grid{grid-template-columns:repeat(3,1fr);}}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:820px;margin:0 auto;}

/* ---------- Final CTA ---------- */
.cta-final{text-align:center;}
.cta-final h2{font-size:clamp(32px,5.6vw,72px);line-height:1.05;font-weight:700;margin:0 auto 18px;max-width:18ch;color:#fff;}
.cta-final h2 .g{color:var(--color-accent);}
.cta-final p{font-size:clamp(16px,1.6vw,20px);color:rgba(255,255,255,.7);max-width:52ch;margin:0 auto 40px;}
.cta-ctas{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;}

/* ---------- Footer ---------- */
.site-footer{position:relative;z-index:1;background:#06201F;color:#fff;padding-top:64px;padding-bottom:26px;}
.footer-grid{display:grid;gap:40px;grid-template-columns:1fr;}
@media(min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;}}
.footer-logo-wrap{display:inline-flex;padding:14px 18px;background:#fff;border-radius:var(--radius-lg);}
.footer-logo{height:72px;width:auto;}
.footer-brand p{margin:16px 0 0;color:rgba(255,255,255,.6);font-size:14px;max-width:36ch;}
.footer-col h5{font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--color-accent);margin:0 0 16px;}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.footer-col a{color:rgba(255,255,255,.72);font-size:14px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;}
.footer-col a:hover{color:var(--color-accent);}
.footer-col a svg{width:16px;height:16px;}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:16px 24px;justify-content:space-between;align-items:center;font-size:13px;color:rgba(255,255,255,.5);}

/* ---------- Contact modal ---------- */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;background:rgba(6,32,31,.7);backdrop-filter:blur(10px);overflow-y:auto;}
.modal-card{width:100%;max-width:520px;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:32px;margin:auto;position:relative;opacity:1;animation:pop-soft .4s cubic-bezier(.16,1,.3,1);}
@media(min-width:640px){.modal-card{padding:40px;}}
.modal-close{position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:50%;border:none;background:var(--color-bg-alt);color:var(--color-primary-dark);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease,transform .2s ease;}
.modal-close:hover{background:var(--tint-primary-15);transform:rotate(90deg);}
.modal-close svg{width:18px;height:18px;}
.modal-title{font-family:var(--font-display);font-size:clamp(20px,2.4vw,26px);line-height:1.2;font-weight:700;color:var(--color-primary-dark);margin:0 0 8px;max-width:28ch;}
.modal-sub{font-size:14px;color:var(--color-text-muted);margin:0 0 24px;}
.form-row{display:grid;gap:16px;grid-template-columns:1fr;margin-bottom:16px;}
@media(min-width:520px){.form-row{grid-template-columns:1fr 1fr;}}
.modal-success{text-align:center;padding:16px 8px;}
.success-icon{width:72px;height:72px;border-radius:50%;margin:0 auto 16px;background:var(--tint-accent-20);display:inline-flex;align-items:center;justify-content:center;color:var(--color-accent);opacity:1;animation:pop-soft .45s cubic-bezier(.16,1,.3,1);}
.success-icon svg{width:36px;height:36px;}
.modal-success h3{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--color-primary-dark);margin:0 0 8px;}
.modal-success p{color:var(--color-text-muted);margin:0 0 24px;max-width:36ch;margin-inline:auto;}

@media (prefers-reduced-motion: reduce){
  .cine{opacity:1 !important;transform:none !important;clip-path:none !important;}
  .intro-hero-inner{opacity:1 !important;transform:none !important;}
  .intro-rings{opacity:.45 !important;}
}

/* Base-visible entrance pop (works even where the animation clock is frozen) */
@keyframes pop-soft{from{opacity:.4;transform:scale(.94);}to{opacity:1;transform:none;}}

/* =============================================================
   Multi-page additions (Inicio / Servicios / Nosotros)
   ============================================================= */
.nav-primary a.is-active{color:#fff;}
.nav-primary a.is-active::after{transform:scaleX(1);}

/* Compact hero for inner pages (sits under the fixed header).
   Transparent so the fixed aro (rings) shows behind the page title. */
.page-hero{position:relative;z-index:1;padding-top:160px;padding-bottom:clamp(56px,9vh,104px);
  background:transparent;color:#fff;}
.page-hero::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:-1;
  background:radial-gradient(120% 100% at 80% 0%,rgba(212,165,58,.10),transparent 55%),
             linear-gradient(180deg,rgba(0,0,0,.25),transparent 60%,var(--cine-bg) 100%);}
.page-hero .container{position:relative;z-index:1;}
.page-hero .eyebrow-cine{margin-bottom:18px;}
.page-hero-title{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,5.4vw,64px);line-height:1.05;letter-spacing:-.02em;color:#fff;max-width:20ch;margin:0;text-wrap:balance;}
.page-hero-title .g{color:var(--color-accent);}
.page-hero-lead{margin:20px 0 0;font-size:clamp(16px,1.5vw,20px);line-height:1.6;color:rgba(255,255,255,.72);max-width:60ch;}

/* Centered link row (e.g. "Ver servicios en detalle") */
.section-cta{margin-top:40px;text-align:center;}

/* ---------- Hero quick-nav (entrar a una sección desde el hero) ---------- */
.hero-nav{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:34px;}
.hero-nav a{display:inline-flex;align-items:center;gap:9px;padding:12px 24px;border-radius:var(--radius-full);
  border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.04);color:#fff;text-decoration:none;
  font-family:var(--font-display);font-weight:500;font-size:14px;letter-spacing:.01em;
  transition:color .25s ease,border-color .25s ease,background-color .25s ease,transform .25s cubic-bezier(.16,1,.3,1);}
.hero-nav a::after{content:"\2192";opacity:.55;transition:transform .25s ease,opacity .25s ease;}
.hero-nav a:hover{color:var(--color-accent);border-color:var(--color-accent);background:rgba(212,165,58,.10);transform:translateY(-2px);}
.hero-nav a:hover::after{transform:translateX(4px);opacity:1;}

/* ---------- Smooth page transitions (entrar a otra página con fundido) ---------- */
main{animation:page-in .95s cubic-bezier(.22,1,.36,1) both;}
@keyframes page-in{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
body.is-leaving main{animation:page-out .5s cubic-bezier(.4,0,.2,1) forwards;}
@keyframes page-out{from{opacity:1;transform:none;}to{opacity:0;transform:translateY(-6px);}}
@media (prefers-reduced-motion: reduce){
  main{animation:none;}
  body.is-leaving main{animation:none;}
}
