*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --midnight:#0f1520;
  --midnight-2:#1a2235;
  --midnight-3:#232f44;
  --carbon:#2c3a4a;
  --gold:#b8975a;
  --gold-light:#d4b47a;
  --gold-dark:#8a6e3e;
  --cream:#f5f0e8;
  --cream-2:#ede6d6;
  --text-light:#e8e2d6;
  --text-muted:#9aa5b4;
  --white:#ffffff;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans','Helvetica Neue',sans-serif;
}
html{scroll-behavior:smooth;font-size:16px;}
body{background:var(--midnight);color:var(--text-light);font-family:var(--sans);font-weight:300;overflow-x:hidden;}

/* ── NAV ─────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:0.55rem 2.5rem;
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(10,15,28,0.96);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(184,151,90,0.18);
  min-height:72px;
}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;}
.nav-logo-img{
  height:54px;
  width:auto;
  display:block;
  object-fit:contain;
  filter:drop-shadow(0 2px 10px rgba(184,151,90,0.2));
}
.visually-hidden{
  position:absolute!important;height:1px;width:1px;overflow:hidden;
  clip:rect(1px,1px,1px,1px);white-space:nowrap;border:0;padding:0;margin:-1px;
}
.nav-links{display:flex;gap:2.5rem;list-style:none;}
.nav-links a{font-family:var(--sans);font-size:0.78rem;font-weight:400;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;transition:color 0.3s;}
.nav-links a:hover{color:var(--gold);}
.nav-cta{font-family:var(--sans);font-size:0.75rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:0.6rem 1.4rem;border:1px solid var(--gold);color:var(--gold);background:transparent;cursor:pointer;text-decoration:none;transition:all 0.3s;white-space:nowrap;}
.nav-cta:hover{background:var(--gold);color:var(--midnight);}

/* ── HERO ────────────────────────────────────────── */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:7rem 2.5rem 4rem;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%, rgba(184,151,90,0.06) 0%, transparent 60%), radial-gradient(ellipse at 20% 80%, rgba(26,34,53,0.8) 0%, transparent 50%);}
.hero-line-v{position:absolute;left:8%;top:0;bottom:0;width:1px;background:linear-gradient(to bottom, transparent, rgba(184,151,90,0.3) 30%, rgba(184,151,90,0.3) 70%, transparent);}
.hero-inner{max-width:1200px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.hero-badge{display:inline-flex;align-items:center;gap:0.6rem;padding:0.5rem 1.2rem;border:1px solid rgba(184,151,90,0.35);margin-bottom:2rem;}
.hero-badge-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;}
.hero-badge-text{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);font-weight:500;}
.hero-title{font-family:var(--serif);font-size:clamp(2.8rem,5vw,4.2rem);font-weight:300;line-height:1.12;color:var(--cream);margin-bottom:1.5rem;}
.hero-title em{font-style:italic;color:var(--gold);}
.hero-subtitle{font-size:1rem;line-height:1.8;color:var(--text-muted);max-width:480px;margin-bottom:2.5rem;font-weight:300;}
.hero-actions{display:flex;gap:1.2rem;flex-wrap:wrap;}
.btn-primary{display:inline-block;padding:1rem 2.2rem;background:var(--gold);color:var(--midnight);font-family:var(--sans);font-size:0.78rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;text-decoration:none;border:none;cursor:pointer;transition:all 0.3s;}
.btn-primary:hover{background:var(--gold-light);}
.btn-secondary{display:inline-block;padding:1rem 2.2rem;border:1px solid rgba(184,151,90,0.4);color:var(--text-light);font-family:var(--sans);font-size:0.78rem;font-weight:400;letter-spacing:0.12em;text-transform:uppercase;text-decoration:none;cursor:pointer;transition:all 0.3s;background:transparent;}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold);}
.hero-visual{display:flex;justify-content:center;align-items:center;}
.hero-emblem{width:280px;height:280px;border:1px solid rgba(184,151,90,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;background:transparent}
.hero-emblem::before{content:'';position:absolute;inset:12px;border:1px solid rgba(184,151,90,0.12);border-radius:50%;}
.hero-emblem::after{content:'';position:absolute;inset:24px;border:1px solid rgba(184,151,90,0.07);border-radius:50%;}
.hero-icon-wrap{width:calc(100% - 48px);height:calc(100% - 48px);display:flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden}

.hero-logo-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}

/* ── STATS ───────────────────────────────────────── */
.stats-bar{background:var(--midnight-2);border-top:1px solid rgba(184,151,90,0.12);border-bottom:1px solid rgba(184,151,90,0.12);padding:2.5rem;}
.stats-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center;}
.stat-item{display:flex;flex-direction:column;align-items:center;justify-content:center;}
.stat-num{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2.6rem);font-weight:300;color:var(--gold);line-height:1.1;text-align:center;}
.stat-label{font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);margin-top:0.4rem;}

/* ── SECTIONS COMMON ─────────────────────────────── */
section{padding:6rem 2.5rem;}
.section-inner{max-width:1200px;margin:0 auto;}
.section-label{font-size:0.7rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;display:flex;align-items:center;gap:0.8rem;}
.section-label::before{content:'';width:24px;height:1px;background:var(--gold);}
.section-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:300;color:var(--cream);line-height:1.2;margin-bottom:1.5rem;}
.section-sub{font-size:0.95rem;color:var(--text-muted);line-height:1.8;max-width:600px;}

/* ── EQUIPO ──────────────────────────────────────── */
.equipo{background:var(--midnight);}

.team-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2.5rem;
  margin-top:4rem;
  align-items:start;
}

.team-card{
  background:var(--midnight-2);
  border:1px solid rgba(184,151,90,0.15);
  overflow:hidden;
  position:relative;
  display:flex;
  flex-direction:column;
  transition:border-color 0.4s, box-shadow 0.4s;
}
.team-card:hover{
  border-color:rgba(184,151,90,0.4);
  box-shadow:0 12px 40px rgba(0,0,0,0.35);
}

/* Foto principal — retrato vertical elegante */
.team-photo-wrap{
  width:100%;
  aspect-ratio:3/4;
  overflow:hidden;
  position:relative;
  flex-shrink:0;
}
.team-photo-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 15%;
  display:block;
  transition:transform 0.7s ease;
}
.team-card:hover .team-photo-wrap img{transform:scale(1.04);}

/* Degradado sobre la foto — nombre y rol */
.team-photo-overlay{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:2.5rem 2rem 1.8rem;
  background:linear-gradient(to top,
    rgba(10,15,28,0.98) 0%,
    rgba(10,15,28,0.75) 45%,
    transparent 100%
  );
}
.team-name{
  font-family:var(--serif);
  font-size:1.6rem;
  font-weight:400;
  color:var(--cream);
  line-height:1.15;
  margin-bottom:0.4rem;
}
.team-role{
  font-size:0.68rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
}

/* Línea dorada inferior */
.team-card::after{
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;
  height:2px;
  background:linear-gradient(to right, transparent 0%, var(--gold) 50%, transparent 100%);
  opacity:0.55;
}

/* Bio */
.team-bio{
  padding:2rem 2rem 2.2rem;
  display:flex;
  flex-direction:column;
  gap:0.85rem;
}
.team-bio p{
  font-size:0.83rem;
  line-height:1.85;
  color:var(--text-muted);
}

/* ── SERVICIOS ───────────────────────────────────── */
.servicios{background:var(--midnight-2);}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem;}
.service-card{padding:2rem;border:1px solid rgba(184,151,90,0.12);background:var(--midnight);position:relative;overflow:hidden;cursor:default;transition:all 0.4s;}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transition:transform 0.4s;transform-origin:left;}
.service-card:hover{border-color:rgba(184,151,90,0.35);transform:translateY(-4px);}
.service-card:hover::after{transform:scaleX(1);}
.service-icon{width:44px;height:44px;margin-bottom:1.5rem;color:var(--gold);}
.service-name{font-family:var(--serif);font-size:1.3rem;font-weight:400;color:var(--cream);margin-bottom:0.75rem;}
.service-desc{font-size:0.82rem;color:var(--text-muted);line-height:1.8;}
.service-num{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--serif);font-size:2.5rem;font-weight:300;color:rgba(184,151,90,0.08);line-height:1;}

/* ── PILARES ─────────────────────────────────────── */
.pilares{background:var(--midnight);}
.pilares-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:4rem;border:1px solid rgba(184,151,90,0.12);}
.pilar{padding:3rem 2.5rem;border-right:1px solid rgba(184,151,90,0.12);position:relative;}
.pilar:last-child{border-right:none;}
.pilar-num{font-family:var(--serif);font-size:5rem;font-weight:300;color:rgba(184,151,90,0.1);line-height:1;margin-bottom:1rem;}
.pilar-icon{margin-bottom:1.5rem;color:var(--gold);}
.pilar-title{font-family:var(--serif);font-size:1.5rem;font-weight:400;color:var(--cream);margin-bottom:1rem;}
.pilar-text{font-size:0.85rem;color:var(--text-muted);line-height:1.9;}

/* ── CONTACTO ────────────────────────────────────── */
.contacto{background:var(--midnight-2);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:4rem;align-items:start;}
.contact-info h3{font-family:var(--serif);font-size:1.8rem;font-weight:300;color:var(--cream);margin-bottom:1.5rem;}
.contact-info p{font-size:0.9rem;color:var(--text-muted);line-height:1.8;margin-bottom:1.2rem;}
.contact-detail{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;}
.contact-detail svg{color:var(--gold);flex-shrink:0;}
.contact-detail span{font-size:0.88rem;color:var(--text-muted);}

/* ── FOOTER ──────────────────────────────────────── */
footer{background:var(--midnight);border-top:1px solid rgba(184,151,90,0.15);padding:3rem 2.5rem;}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem;}
.footer-brand{font-family:var(--serif);font-size:1.1rem;color:var(--cream);}
.footer-brand span{color:var(--gold);}
.footer-links{display:flex;gap:2rem;}
.footer-links a{font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;transition:color 0.3s;}
.footer-links a:hover{color:var(--gold);}
.footer-copy{font-size:0.72rem;color:var(--text-muted);letter-spacing:0.05em;}

/* ── WHATSAPP FLOAT ──────────────────────────────── */
.wa-float{position:fixed;bottom:2rem;right:2rem;z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:0.75rem;}
.wa-label{background:var(--midnight-2);border:1px solid rgba(184,151,90,0.25);padding:0.5rem 1rem;font-size:0.72rem;color:var(--text-muted);white-space:nowrap;opacity:0;transform:translateX(8px);transition:all 0.3s;}
.wa-float:hover .wa-label{opacity:1;transform:translateX(0);}
.wa-btn{width:54px;height:54px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,0.3);transition:transform 0.3s;text-decoration:none;}
.wa-btn:hover{transform:scale(1.08);}

/* ── DIVIDER ─────────────────────────────────────── */
.divider{width:60px;height:1px;background:var(--gold);margin:2rem 0;opacity:0.5;}

/* ── TALLY IFRAME ────────────────────────────────── */
.tally-wrap{width:100%;background:transparent;overflow:hidden;padding:0;}
.tally-wrap iframe{display:block;width:100%;min-height:891px;border:none;}

/* ── ANIMATIONS ──────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity 0.7s ease, transform 0.7s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}

/* ── RESPONSIVE ──────────────────────────────────── */
@media(max-width:900px){
  nav{padding:0.55rem 1.5rem;}
  .nav-logo-img{height:44px;}
  .hero-inner{grid-template-columns:1fr;gap:3rem;}
  .hero-visual{display:none;}
  .stats-inner{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr;max-width:500px;margin-left:auto;margin-right:auto;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .pilares-grid{grid-template-columns:1fr;}
  .pilar{border-right:none;border-bottom:1px solid rgba(184,151,90,0.12);}
  .contact-grid{grid-template-columns:1fr;}
  .nav-links{display:none;}
}
@media(max-width:600px){
  section{padding:4rem 1.5rem;}
  .services-grid{grid-template-columns:1fr;}
  .hero{padding:7rem 1.5rem 4rem;}
  .team-name{font-size:1.35rem;}
}
