/*
Theme Name: BFM Propiedades
Theme URI: https://bfmpropiedades.cl
Author: BFM Propiedades SpA
Description: Tema premium BFM Propiedades — Video hero, sunset atmosphere, editorial luxury.
Version: 3.0.0
Text Domain: bfm
*/

/* =========================================================
   VARIABLES
   ========================================================= */
:root {
  --navy:      #0d1f2d;
  --sky:       #7cb9d8;
  --sky-lt:    #b8d9eb;
  --sky-pale:  #d8eaf5;
  --amber:     #e8a838;
  --amber-lt:  #f5c96a;
  --cream:     #faf7f2;
  --fog:       #f5edd8;
  --ink:       #1a2535;
  --ink-2:     #4a5568;
  --ink-3:     #8a96a5;
  --white:     #ffffff;
  --glass:     rgba(255,255,255,0.60);
  --glass-b:   rgba(255,255,255,0.88);
  --ease:      cubic-bezier(0.22,1,0.36,1);
  --nav-h:     80px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  color:var(--ink);line-height:1.6;overflow-x:hidden;
  background:var(--sky-pale);
}
body::before{
  content:'';position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(ellipse 120% 55% at 80% 0%,  #c0ddf0 0%,transparent 52%),
    radial-gradient(ellipse 70%  80% at 100% 100%,#f5e4c0 0%,transparent 58%),
    radial-gradient(ellipse 55%  55% at 0%   80%, #d8eaf5 0%,transparent 52%),
    linear-gradient(170deg,#d8eaf5 0%,#e8e0d0 48%,#f5edd8 100%);
  pointer-events:none;
}
body::after{
  content:'';position:fixed;inset:0;z-index:-1;opacity:.022;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px;pointer-events:none;
}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.container{width:100%;max-width:1240px;margin:0 auto;padding:0 36px}
h1,h2,h3{font-family:'Playfair Display',Georgia,serif;font-weight:700;color:var(--navy);line-height:1.1;letter-spacing:-.02em}
h1{font-size:clamp(2.4rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,3.2vw,2.8rem)}
h3{font-size:clamp(1rem,1.8vw,1.3rem)}
p{color:var(--ink-2);line-height:1.75;font-size:1rem}

.eyebrow{
  font-family:'DM Sans',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--sky);
  display:flex;align-items:center;gap:10px;margin-bottom:12px;
}
.eyebrow::before{content:'';display:inline-block;width:22px;height:1.5px;background:currentColor;flex-shrink:0}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}
.eyebrow.light{color:var(--sky-lt)}
.eyebrow.light::before{background:var(--sky-lt)}

/* =========================================================
   BOTONES
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:600;
  border-radius:999px;padding:13px 28px;border:none;cursor:pointer;
  transition:all .35s var(--ease);position:relative;overflow:hidden;
  text-decoration:none;white-space:nowrap;letter-spacing:.01em;
}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.12);opacity:0;transition:opacity .25s}
.btn:hover::after{opacity:1}
.btn-navy{background:var(--navy);color:#fff;box-shadow:0 4px 20px rgba(13,31,45,.26)}
.btn-navy:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(13,31,45,.3)}
.btn-amber{background:var(--amber);color:var(--navy);font-weight:700;box-shadow:0 5px 22px rgba(232,168,56,.3)}
.btn-amber:hover{transform:translateY(-3px);background:var(--amber-lt);box-shadow:0 14px 36px rgba(232,168,56,.4)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid rgba(13,31,45,.28)}
.btn-outline:hover{background:rgba(13,31,45,.05);transform:translateY(-2px)}
.btn-wa{background:#25d366;color:#fff;font-weight:700;box-shadow:0 5px 20px rgba(37,211,102,.28)}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(37,211,102,.38)}
.btn-lg{padding:16px 36px;font-size:.96rem}
.btn-sm{padding:9px 20px;font-size:.8rem}

/* =========================================================
   NAV
   ========================================================= */
#bfm-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);transition:all .4s var(--ease);
}
#bfm-nav.scrolled{
  background:rgba(210,232,246,.86);
  backdrop-filter:blur(22px) saturate(1.5);
  box-shadow:0 1px 0 rgba(124,185,216,.2),0 6px 28px rgba(13,31,45,.06);
}
.nav-in{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;max-width:1240px;margin:0 auto;padding:0 36px;
}
.nav-logo{display:flex;align-items:center;gap:11px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:1rem;color:#fff;transition:color .3s}
#bfm-nav.scrolled .nav-logo{color:var(--navy)}
.nav-logo img{height:38px;width:auto}
.nav-mark{
  width:38px;height:38px;border-radius:9px;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:.82rem;font-weight:700;color:#fff;
  backdrop-filter:blur(8px);transition:all .3s;
}
#bfm-nav.scrolled .nav-mark{background:var(--navy);border-color:var(--navy)}
.nav-links{display:flex;gap:0}
.nav-links a{
  font-size:.85rem;font-weight:500;color:rgba(255,255,255,.85);
  padding:7px 14px;border-radius:999px;transition:all .2s;
}
#bfm-nav.scrolled .nav-links a{color:var(--ink-2)}
.nav-links a:hover{background:rgba(255,255,255,.14);color:#fff}
#bfm-nav.scrolled .nav-links a:hover{background:rgba(13,31,45,.07);color:var(--navy)}
.nav-right{display:flex;align-items:center;gap:8px}
.nav-btn-ghost{
  font-size:.82rem;font-weight:600;color:rgba(255,255,255,.85);
  padding:8px 18px;border-radius:999px;
  border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(6px);
  transition:all .25s;
}
#bfm-nav.scrolled .nav-btn-ghost{color:var(--navy);border-color:rgba(13,31,45,.25)}
.nav-btn-ghost:hover{background:rgba(255,255,255,.14)}
#bfm-nav.scrolled .nav-btn-ghost:hover{background:rgba(13,31,45,.05)}

.nav-ham{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;
}
.nav-logo-img{
  height:38px;width:auto;display:block;
  /* Sobre el video hero: logo en blanco */
  filter:brightness(0) invert(1);
  transition:filter .4s var(--ease);
}
#bfm-nav.scrolled .nav-logo-img{
  /* Scrolled: logo a color original */
  filter:none;
}
.foot-logo{display:flex;align-items:center}
.foot-logo-img{
  height:36px;width:auto;display:block;
  /* Footer oscuro: logo en blanco */
  filter:brightness(0) invert(1);
  opacity:.85;
  transition:opacity .2s;
}
.foot-logo-img:hover{opacity:1}
#bfm-nav.scrolled .nav-ham span{background:var(--navy)}
.nav-ham.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-ham.open span:nth-child(2){opacity:0}
.nav-ham.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.nav-mob{
  position:fixed;top:var(--nav-h);left:0;right:0;
  background:rgba(210,232,246,.97);backdrop-filter:blur(24px);
  padding:22px 32px 30px;display:flex;flex-direction:column;gap:3px;
  transform:translateY(-110%);opacity:0;
  transition:all .4s var(--ease);pointer-events:none;z-index:999;
  border-bottom:1px solid rgba(124,185,216,.18);
}
.nav-mob.open{transform:translateY(0);opacity:1;pointer-events:auto}
.nav-mob a{font-size:.98rem;font-weight:500;color:var(--navy);padding:12px 16px;border-radius:12px;border-bottom:1px solid rgba(124,185,216,.12)}
.nav-mob a:last-child{border-bottom:none}

/* =========================================================
   HERO — VIDEO PANTALLA COMPLETA
   ========================================================= */
#hero{
  position:relative;
  width:100%;height:100vh;min-height:640px;
  display:flex;align-items:flex-end;
  overflow:hidden;
}

/* Video */
.hero-vid-wrap{position:absolute;inset:0;z-index:0}
.hero-vid-wrap video{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;will-change:transform;
}
/* Fallback poster para móvil / sin wifi */
.hero-vid-wrap .vid-poster{
  position:absolute;inset:0;
  background:url('https://bfmpropiedades.cl/wp-content/uploads/2026/06/foto-respaldo-para-moviles.png') center/cover no-repeat;
  display:none;z-index:1;
}
.hero-vid-wrap.no-video .vid-poster{display:block}
.hero-vid-wrap.no-video video{display:none}

/* Overlay — oscuro desde abajo, transparente arriba */
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    to top,
    rgba(13,31,45,.88) 0%,
    rgba(13,31,45,.52) 30%,
    rgba(13,31,45,.18) 60%,
    rgba(13,31,45,.04) 100%
  );
}
/* Tinte ámbar sutil en esquina superior */
.hero-overlay::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 65% 50% at 85% 5%,rgba(232,168,56,.14) 0%,transparent 55%);
}

/* Contenido del hero — posicionado abajo */
.hero-body{
  position:relative;z-index:2;
  width:100%;padding-bottom:68px;
}
.hero-body .container{
  display:flex;flex-direction:column;align-items:flex-start;
}

.hero-chip{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(10px);border-radius:999px;
  padding:6px 16px 6px 9px;
  font-family:'DM Sans',sans-serif;font-size:.74rem;font-weight:600;
  color:rgba(255,255,255,.88);
  margin-bottom:22px;
  animation:slideDown .8s var(--ease) both;
}
.hero-chip-dot{
  width:7px;height:7px;border-radius:50%;background:var(--amber);
  animation:blink 2.4s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.6)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.hero-body h1{
  color:#fff;font-weight:800;max-width:680px;margin-bottom:16px;
  animation:slideUp .9s var(--ease) .1s both;
}
.hero-body h1 em{
  font-style:italic;color:var(--amber);position:relative;display:inline-block;
}
.hero-body h1 em::after{
  content:'';position:absolute;bottom:3px;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--amber),var(--sky));border-radius:2px;opacity:.55;
}
.hero-lead{
  font-size:1.08rem;color:rgba(255,255,255,.72);max-width:500px;
  line-height:1.7;margin-bottom:32px;
  animation:slideUp .9s var(--ease) .2s both;
}
.hero-btns{
  display:flex;gap:12px;flex-wrap:wrap;margin-bottom:52px;
  animation:slideUp .9s var(--ease) .28s both;
}
.hero-stats{
  display:flex;gap:40px;flex-wrap:wrap;
  animation:slideUp .9s var(--ease) .38s both;
}
.h-stat .n{
  font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;
  color:#fff;line-height:1;
}
.h-stat .n em{font-style:normal;color:var(--amber)}
.h-stat .l{font-size:.73rem;color:rgba(255,255,255,.5);font-weight:500;margin-top:3px}

/* Scroll indicator */
.hero-scroll-hint{
  position:absolute;bottom:28px;right:40px;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  animation:fadeIn 1.2s .8s both;
}
.scroll-text{font-size:.64rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.scroll-bar{width:1px;height:44px;background:rgba(255,255,255,.2);position:relative;overflow:hidden}
.scroll-bar::after{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:rgba(255,255,255,.55);animation:scrollRun 2s ease-in-out infinite}
@keyframes scrollRun{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}

/* =========================================================
   TRUST BAR
   ========================================================= */
.trust-section{padding:0 0 88px}
.trust-wrap{
  background:var(--glass);
  backdrop-filter:blur(22px) saturate(1.4);
  border:1px solid rgba(255,255,255,.7);
  border-radius:28px;
  box-shadow:0 8px 40px rgba(13,31,45,.07);
  padding:32px 52px;
  display:grid;grid-template-columns:repeat(3,1fr);
}
.t-stat{text-align:center;padding:0 28px;position:relative}
.t-stat+.t-stat::before{
  content:'';position:absolute;left:0;top:15%;height:70%;
  width:1px;background:rgba(124,185,216,.28);
}
.t-num{
  font-family:'Playfair Display',serif;font-size:2.8rem;font-weight:800;
  color:var(--navy);line-height:1;margin-bottom:5px;
}
.t-num em{font-style:normal;color:var(--amber)}
.t-lbl{font-size:.8rem;color:var(--ink-3);font-weight:500}

/* =========================================================
   SECCIONES COMUNES
   ========================================================= */
.section{padding:100px 0}
.s-header{margin-bottom:56px}
.s-header.c{text-align:center}
.s-header.c .eyebrow{justify-content:center}
.s-header.c .eyebrow::before{display:none}
.s-header h2{margin-bottom:14px}
.s-header p{font-size:1.02rem;max-width:510px}
.s-header.c p{margin:0 auto}

/* Reveal */
.rv{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.on{opacity:1;transform:none}
.rv-l{opacity:0;transform:translateX(-36px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-l.on{opacity:1;transform:none}
.rv-r{opacity:0;transform:translateX(36px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-r.on{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* Glass card base */
.glass-card{
  background:var(--glass);
  backdrop-filter:blur(16px) saturate(1.3);
  border:1px solid rgba(255,255,255,.64);
  border-radius:28px;
}

/* =========================================================
   SERVICIOS
   ========================================================= */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-card{
  padding:34px 28px 28px;position:relative;overflow:hidden;
  transition:all .4s var(--ease);
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--sky),var(--amber));
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);
}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 22px 54px rgba(13,31,45,.11);background:var(--glass-b)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-num{
  font-family:'Playfair Display',serif;font-size:4.5rem;font-weight:800;
  color:rgba(124,185,216,.13);line-height:1;margin-bottom:-16px;
}
.svc-ico{
  width:50px;height:50px;border-radius:13px;
  background:linear-gradient(135deg,rgba(124,185,216,.2),rgba(124,185,216,.06));
  border:1px solid rgba(124,185,216,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:1.45rem;margin-bottom:15px;
}
.svc-card h3{margin-bottom:9px;font-size:1.15rem}
.svc-card p{font-size:.86rem;margin-bottom:18px}
.tags{display:flex;flex-wrap:wrap;gap:5px}
.tag{
  font-size:.68rem;font-weight:700;letter-spacing:.04em;
  color:#1a6a8e;background:rgba(124,185,216,.13);
  border:1px solid rgba(124,185,216,.2);border-radius:999px;padding:4px 11px;
}

/* =========================================================
   SPLIT SECTIONS (foto + texto)
   ========================================================= */
.split{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;align-items:stretch;overflow:hidden;
}
.split.reverse{direction:rtl}
.split.reverse>*{direction:ltr}
.split-img{
  position:relative;overflow:hidden;min-height:520px;
}
.split-img img{width:100%;height:100%;object-fit:cover;display:block}
.split-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(13,31,45,.05),transparent 60%);
}
.split-body{
  padding:80px 64px;
  display:flex;flex-direction:column;justify-content:center;
  background:rgba(250,247,242,.55);
}
.split-body.dark{
  background:var(--navy);
}
.split-body.dark h2{color:#fff}
.split-body.dark p{color:rgba(255,255,255,.62)}
.split-body.dark .eyebrow{color:var(--sky-lt)}
.split-body.dark .eyebrow::before{background:var(--sky-lt)}
.split-body h2{margin-bottom:18px}
.split-body p{margin-bottom:14px}
.split-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:20px}
.split-tag{
  font-size:.76rem;font-weight:600;
  border-radius:999px;padding:5px 14px;
}
.split-tag.light{background:rgba(124,185,216,.14);color:#1a6a8e;border:1px solid rgba(124,185,216,.25)}
.split-tag.dark-t{background:rgba(124,185,216,.15);color:var(--sky-lt);border:1px solid rgba(124,185,216,.22)}

/* Checkmarks */
.check-list{display:flex;flex-direction:column;gap:11px;margin:20px 0 28px}
.check-row{display:flex;align-items:center;gap:11px;font-size:.88rem;font-weight:500}
.check-row.light-t{color:#fff}
.chk{
  width:26px;height:26px;border-radius:50%;flex-shrink:0;
  background:rgba(124,185,216,.18);border:1px solid rgba(124,185,216,.3);
  display:flex;align-items:center;justify-content:center;
  color:var(--sky);font-size:.8rem;
}
.split-body.dark .chk{background:rgba(124,185,216,.15);color:var(--sky-lt)}

/* =========================================================
   EQUIPO
   ========================================================= */
.team-hero{
  border-radius:28px;overflow:hidden;
  aspect-ratio:16/9;position:relative;
  box-shadow:0 20px 56px rgba(13,31,45,.12);
  margin-bottom:56px;
}
.team-hero img{width:100%;height:100%;object-fit:cover}
.team-hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(13,31,45,.45) 0%,transparent 55%);
}
.team-hero-badge{
  position:absolute;bottom:24px;left:24px;z-index:2;
  background:rgba(13,31,45,.82);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;padding:14px 18px;color:#fff;
}
.team-hero-badge .big{
  font-family:'Playfair Display',serif;font-size:2rem;
  font-weight:800;color:var(--amber);line-height:1;
}
.team-hero-badge p{font-size:.76rem;color:rgba(255,255,255,.55);margin-top:3px}

.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.team-card{border-radius:24px;overflow:hidden;transition:all .4s var(--ease)}
.team-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(13,31,45,.1)}
.team-photo{aspect-ratio:3/4;overflow:hidden;position:relative}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .5s var(--ease)}
.team-card:hover .team-photo img{transform:scale(1.04)}
.team-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(13,31,45,.55) 0%,transparent 50%);
}
.team-info{padding:18px 20px 22px}
.team-role{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--sky);margin-bottom:4px}
.team-info h3{font-size:.98rem;margin-bottom:5px}
.team-info p{font-size:.8rem;line-height:1.55}

/* =========================================================
   PROCESO PASOS
   ========================================================= */
.steps-wrap{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.steps-list{display:flex;flex-direction:column}
.step-row{
  display:grid;grid-template-columns:50px 1fr;gap:16px;
  padding:24px 0;border-bottom:1px solid rgba(124,185,216,.13);
  cursor:pointer;transition:all .3s var(--ease);
}
.step-row:last-child{border-bottom:none}
.step-n{
  width:44px;height:44px;border-radius:11px;flex-shrink:0;margin-top:2px;
  background:rgba(124,185,216,.11);border:1px solid rgba(124,185,216,.22);
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:.9rem;font-weight:800;color:var(--navy);
  transition:all .3s var(--ease);
}
.step-row.active .step-n{background:var(--amber);border-color:var(--amber);box-shadow:0 5px 18px rgba(232,168,56,.3)}
.step-row h3{font-size:1rem;margin-bottom:5px}
.step-row p{font-size:.85rem;line-height:1.6}
.step-panels{position:relative}
.s-panel{
  display:none;border-radius:28px;overflow:hidden;
  aspect-ratio:4/5;box-shadow:0 22px 58px rgba(13,31,45,.13);
  background:linear-gradient(135deg,var(--sky-pale),var(--fog));
}
.s-panel.active{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px}
.s-panel img{width:100%;height:100%;object-fit:cover}
.s-panel-ico{font-size:4.5rem;opacity:.45}
.s-panel-lbl{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--navy)}

/* =========================================================
   TESTIMONIOS
   ========================================================= */
.testi-layout{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.testi-head h2{margin-bottom:14px}
.testi-head p{margin-bottom:26px}
.testi-cards{display:flex;flex-direction:column;gap:13px}
.t-card{
  border-radius:20px;padding:22px 24px;
  transition:all .3s var(--ease);cursor:pointer;
}
.t-card.feat{
  background:var(--navy);border-color:var(--navy);
  box-shadow:0 18px 48px rgba(13,31,45,.16);transform:scale(1.02);
}
.t-stars{color:var(--amber);font-size:.82rem;letter-spacing:2px;margin-bottom:9px}
.t-card.feat .t-stars{color:var(--amber-lt)}
.t-quote{font-size:.88rem;line-height:1.65;font-style:italic;margin-bottom:13px}
.t-card.feat .t-quote{color:rgba(255,255,255,.85)}
.t-who{display:flex;align-items:center;gap:9px}
.t-ava{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--sky-pale),var(--sky-lt));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.76rem;color:var(--navy);
}
.t-card.feat .t-ava{background:rgba(124,185,216,.22);color:#fff}
.t-name{font-size:.84rem;font-weight:600;color:var(--navy)}
.t-card.feat .t-name{color:rgba(255,255,255,.9)}
.t-role{font-size:.73rem;color:var(--ink-3)}
.t-card.feat .t-role{color:rgba(255,255,255,.42)}

/* =========================================================
   FAQ
   ========================================================= */
.faq-wrap{display:grid;grid-template-columns:1fr 1.5fr;gap:72px;align-items:start}
.faq-side{position:sticky;top:calc(var(--nav-h) + 28px)}
.faq-side h2{margin-bottom:14px}
.faq-side p{margin-bottom:26px}
.faq-list{display:flex;flex-direction:column;gap:9px}
.faq-item{
  border-radius:16px;overflow:hidden;transition:all .3s var(--ease);
}
.faq-item.open{background:var(--glass-b);box-shadow:0 8px 30px rgba(13,31,45,.07)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:19px 20px;cursor:pointer;gap:12px;
}
.faq-qt{font-weight:600;font-size:.93rem;color:var(--navy);line-height:1.4}
.faq-ic{
  width:26px;height:26px;border-radius:50%;flex-shrink:0;
  background:rgba(124,185,216,.14);
  display:flex;align-items:center;justify-content:center;
  color:var(--sky);font-size:1.25rem;font-weight:300;line-height:1;
  transition:all .3s var(--ease);
}
.faq-item.open .faq-ic{background:var(--navy);color:#fff;transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;padding:0 20px;
  transition:max-height .4s var(--ease),padding .3s;
  font-size:.88rem;color:var(--ink-2);line-height:1.7;
}
.faq-item.open .faq-a{max-height:260px;padding:0 20px 18px}

/* =========================================================
   CTA FINAL OSCURO
   ========================================================= */
.cta-dark{
  background:var(--navy);border-radius:36px;
  padding:76px 80px;position:relative;overflow:hidden;
  display:grid;grid-template-columns:1fr auto;gap:52px;align-items:center;
}
.cta-dark::before{
  content:'';position:absolute;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,185,216,.12) 0%,transparent 70%);
  top:-180px;right:-60px;pointer-events:none;
}
.cta-dark::after{
  content:'';position:absolute;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,168,56,.1) 0%,transparent 70%);
  bottom:-80px;left:60px;pointer-events:none;
}
.cta-txt{position:relative;z-index:1}
.cta-txt h2{color:#fff;margin-bottom:12px}
.cta-txt p{color:rgba(255,255,255,.58);max-width:440px}
.cta-acts{
  display:flex;flex-direction:column;gap:11px;
  position:relative;z-index:1;flex-shrink:0;
}

/* =========================================================
   FOOTER
   ========================================================= */
#bfm-footer{background:var(--navy);padding:68px 0 0}
.foot-grid{
  display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;
  gap:44px;padding-bottom:52px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.foot-brand p{font-size:.82rem;color:rgba(255,255,255,.38);line-height:1.7;max-width:220px;margin-top:13px}
.foot-logo{display:flex;align-items:center;gap:10px;color:#fff;font-family:'DM Sans',sans-serif;font-weight:700;font-size:.98rem}
.foot-mark{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:.78rem;font-weight:700;color:#fff}
.foot-col h4{font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);margin-bottom:16px}
.foot-col a{display:block;font-size:.82rem;color:rgba(255,255,255,.42);margin-bottom:8px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-ci{display:flex;align-items:flex-start;gap:7px;font-size:.82rem;color:rgba(255,255,255,.42);margin-bottom:10px;line-height:1.5}
.foot-bottom{
  padding:18px 0;display:flex;justify-content:space-between;align-items:center;
  font-size:.74rem;color:rgba(255,255,255,.2);
}

/* =========================================================
   WA FLOTANTE
   ========================================================= */
#wa-btn{
  position:fixed;bottom:26px;right:26px;z-index:999;
  width:56px;height:56px;border-radius:50%;
  background:#25d366;display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;box-shadow:0 6px 26px rgba(37,211,102,.42);
  transition:all .3s var(--ease);
}
#wa-btn:hover{transform:scale(1.11);box-shadow:0 11px 34px rgba(37,211,102,.52)}

/* =========================================================
   PÁGINAS INTERNAS — HERO BANNER CON FOTO
   ========================================================= */
.page-hero{
  position:relative;height:60vh;min-height:420px;
  display:flex;align-items:center;overflow:hidden;
}
.page-hero-bg{position:absolute;inset:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right,rgba(13,31,45,.78) 0%,rgba(13,31,45,.35) 60%,rgba(13,31,45,.1) 100%);
}
.page-hero-content{position:relative;z-index:1}
.page-hero-content .eyebrow{color:var(--sky-lt)}
.page-hero-content .eyebrow::before{background:var(--sky-lt)}
.page-hero-content h1{color:#fff;margin-bottom:14px}
.page-hero-content p{color:rgba(255,255,255,.68);max-width:520px;font-size:1.05rem}

/* =========================================================
   FORMULARIO CONTACTO
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:start}
.bfm-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-field{display:flex;flex-direction:column;gap:5px}
.form-field label{font-size:.8rem;font-weight:600;color:var(--navy)}
.form-field input,
.form-field select,
.form-field textarea{
  border:1.5px solid rgba(124,185,216,.4);border-radius:12px;
  padding:12px 15px;font-size:.9rem;font-family:'DM Sans',sans-serif;
  background:rgba(255,255,255,.7);color:var(--ink);
  transition:border-color .2s,background .2s;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;border-color:var(--sky);background:rgba(255,255,255,.95);
}
.form-field textarea{resize:vertical;min-height:120px}
.contact-info{display:flex;flex-direction:column;gap:14px}
.contact-card{
  padding:24px;border-radius:20px;
}
.ci-row{display:flex;align-items:flex-start;gap:11px;font-size:.88rem;color:var(--ink-2);margin-bottom:12px;line-height:1.55}
.ci-ico{font-size:1.1rem;flex-shrink:0;margin-top:1px}

/* =========================================================
   PLACEHOLDER IMAGEN
   ========================================================= */
.img-ph{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--sky-pale),var(--fog));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;color:var(--ink-3);font-size:.76rem;font-weight:500;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1024px){
  .split{grid-template-columns:1fr}
  .split-body{padding:56px 40px}
  .steps-wrap,.testi-layout,.faq-wrap,.cta-dark,.contact-grid{grid-template-columns:1fr}
  .cta-dark{padding:52px 44px}
  .s-panel-vis{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .svc-grid,.team-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  :root{--nav-h:68px}
  .section{padding:68px 0}
  .container{padding:0 20px}
  #hero{height:100svh}
  .hero-stats{gap:22px}
  .h-stat .n{font-size:1.7rem}
  .hero-scroll-hint{display:none}
  .nav-links,.nav-right{display:none}
  .nav-ham{display:flex}
  .trust-wrap{padding:22px 18px;grid-template-columns:1fr;gap:18px;border-radius:20px}
  .t-stat+.t-stat::before{display:none}
  .svc-grid,.team-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:26px}
  .foot-bottom{flex-direction:column;gap:5px}
  .cta-dark{padding:38px 26px;border-radius:26px}
  .faq-side{position:static}
  .testi-layout{gap:36px}
  .form-row{grid-template-columns:1fr}
  .page-hero{height:50vh}
}
