:root {
  --azul: #1B2D4F;
  --oro: #C9A84C;
  --marfil: #F5F4F0;
  --carbon: #1A1A1A;
  --blanco: #FFFFFF;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

html{scroll-behavior:smooth;font-size:16px;}

body{
  font-family:'Outfit',sans-serif;
  background:var(--marfil);
  color:var(--carbon);
  overflow-x:hidden;
  position:relative;
}

body::before{
  content:'';
  position:fixed;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:0.04;
  pointer-events:none;
  z-index:9999;
}

/* ============ NAVBAR ============ */
#navbar{
  position:fixed;
  top:20px;
  left:50%;
  transform:translateX(-50%);
  z-index:1000;
  width:calc(100% - 40px);
  max-width:1100px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 24px;
  border-radius:60px;
  transition:all 0.4s ease;
  border:1px solid transparent;
}

#navbar.scrolled{
  background:rgba(27,45,79,0.9);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-color:rgba(201,168,76,0.3);
  box-shadow:0 8px 32px rgba(0,0,0,0.2);
}

.nav-logo img{width:250px;height:auto;}

.nav-links{
  display:flex;
  gap:32px;
  list-style:none;
}

.nav-links a{
  color:rgba(255,255,255,0.85);
  text-decoration:none;
  font-family:'Outfit',sans-serif;
  font-size:14px;
  font-weight:500;
  transition:color 0.2s;
}
.nav-links a:hover{color:var(--oro);}

.btn-nav{
  background:var(--oro);
  color:var(--carbon);
  border:none;
  padding:10px 22px;
  border-radius:50px;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  font-size:13px;
  cursor:pointer;
  text-decoration:none;
  transition:all 0.3s ease;
  display:inline-block;
}
.btn-nav:hover{background:#e0c05a;transform:scale(1.04);}

/* ============ HERO ============ */
#hero{
  position:relative;
  height:100dvh;
  min-height:600px;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  padding-bottom:80px;
}

#hero-bg{
  position:absolute;
  inset:0;
  background-image:url('https://raw.githubusercontent.com/webmasteramd/mis-recursos/main/img/fondo-hero.png');
  background-size:cover;
  background-position:center;
  will-change:transform;
}

#hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(27,45,79,0.85) 0%,rgba(10,10,20,0.7) 100%);
}

#hero-content{
  position:relative;
  z-index:2;
  padding-left:80px;
  max-width:760px;
  opacity:0;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(201,168,76,0.6);
  background:rgba(27,45,79,0.4);
  backdrop-filter:blur(8px);
  padding:8px 18px;
  border-radius:50px;
  font-family:'Outfit',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:0.2em;
  color:var(--oro);
  text-transform:uppercase;
  margin-bottom:20px;
  opacity:0;
}

#hero h1{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(48px,6vw,72px);
  line-height:1.1;
  margin-bottom:20px;
  opacity:0;
}

#hero h1 .line1{
  display:block;
  color:#fff;
  font-weight:700;
}
#hero h1 .line2{
  display:block;
  color:var(--oro);
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-weight:600;
}

.hero-slider{
  min-height:36px;
  margin-bottom:36px;
  opacity:0;
}

.slider-item{
  font-family:'Outfit',sans-serif;
  font-size:20px;
  color:rgba(255,255,255,0.85);
  line-height:1.5;
  display:none;
}
.slider-item.active{display:block;}

.hero-ctas{
  display:flex;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
  opacity:0;
}

.btn-primary{
  background:var(--oro);
  color:var(--carbon);
  border:none;
  padding:16px 32px;
  border-radius:50px;
  font-family:'Outfit',sans-serif;
  font-weight:700;
  font-size:15px;
  cursor:pointer;
  text-decoration:none;
  display:inline-block;
  transition:all 0.3s ease;
  position:relative;
  overflow:hidden;
}
.btn-primary::before{
  content:'';
  position:absolute;
  inset:0;
  background:rgba(255,255,255,0.2);
  transform:translateX(-100%);
  transition:transform 0.4s ease;
}
.btn-primary:hover::before{transform:translateX(0);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,0.4);}

.btn-secondary-link{
  color:rgba(255,255,255,0.75);
  text-decoration:none;
  font-family:'Outfit',sans-serif;
  font-size:14px;
  border-bottom:1px solid rgba(255,255,255,0.3);
  padding-bottom:2px;
  transition:all 0.2s;
}
.btn-secondary-link:hover{color:#fff;border-color:#fff;}

/* ============ QUIENES SOMOS ============ */
#quienes{
  background:var(--azul);
  padding:100px 40px;
}

.quienes-inner{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}

.quienes-img-wrap{
  position:relative;
  padding-bottom:16px;
  padding-right:16px;
}

.quienes-img-wrap::after{
  content:'';
  position:absolute;
  bottom:0;
  right:0;
  width:calc(100% - 16px);
  height:calc(100% - 16px);
  border:2px solid var(--oro);
  border-radius:2rem;
  z-index:0;
}

.quienes-img-wrap img{
  width:100%;
  max-width:480px;
  height:380px;
  object-fit:cover;
  border-radius:20px;
  display:block;
  position:relative;
  z-index:1;
}

.quienes-blob{
  clip-path:none;
}

.quienes-text{color:var(--marfil);}

.section-badge{
  display:inline-block;
  font-family:'Outfit',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--oro);
  margin-bottom:16px;
}

.quienes-text h2{
  font-size:clamp(32px,4vw,48px);
  line-height:1.15;
  margin-bottom:12px;
}
.quienes-text h2 em{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--oro);
  font-size:1.1em;
}
.quienes-text h2 span{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  color:#fff;
}

.quienes-text h3{
  font-family:'Outfit',sans-serif;
  font-size:18px;
  font-weight:400;
  color:var(--marfil);
  margin-bottom:20px;
}

.quienes-text p{
  font-family:'Outfit',sans-serif;
  font-size:16px;
  line-height:1.75;
  color:rgba(245,244,240,0.8);
  margin-bottom:32px;
}

.quienes-datos{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
}

.dato-item{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:'Outfit',sans-serif;
  font-size:13px;
  color:var(--marfil);
}
.dato-icon{color:var(--oro);font-size:16px;}

/* ============ FEATURES ============ */
#features{
  background:var(--azul);
  padding:100px 40px;
  border-top:1px solid rgba(201,168,76,0.15);
}

.features-inner{
  max-width:1100px;
  margin:0 auto;
}

.section-head{
  text-align:center;
  margin-bottom:60px;
}

.section-head h2{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:clamp(28px,4vw,44px);
  color:#fff;
  margin-top:12px;
}

.features-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}

.feature-panel{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:1.5rem;
  padding:32px 28px;
  position:relative;
  overflow:hidden;
}

.panel-label{
  font-family:'Outfit',sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--oro);
  margin-bottom:24px;
  display:block;
}

/* Panel 1 - Baraja */
.card-stack{
  position:relative;
  height:160px;
}

.stack-card{
  position:absolute;
  width:100%;
  background:#fff;
  border-radius:1rem;
  padding:16px 20px;
  display:flex;
  align-items:center;
  gap:16px;
  transition:all 0.5s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow:0 4px 20px rgba(0,0,0,0.15);
}

.stack-card.pos-0{
  top:0;z-index:3;transform:translateY(0) scale(1);
}
.stack-card.pos-1{
  top:12px;z-index:2;transform:scale(0.95);opacity:0.7;
}
.stack-card.pos-2{
  top:24px;z-index:1;transform:scale(0.9);opacity:0.45;
}

.stack-icon{
  width:44px;height:44px;
  background:var(--azul);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  font-size:20px;
}

.stack-text{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:14px;
  color:var(--carbon);
}

/* Panel 2 - Online */
.online-content{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.online-indicator{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Outfit',sans-serif;
  font-size:12px;
  color:rgba(245,244,240,0.75);
  background:rgba(255,255,255,0.06);
  padding:6px 14px;
  border-radius:50px;
  width:fit-content;
}

.pulse-dot{
  width:8px;height:8px;
  background:#22c55e;
  border-radius:50%;
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,0.5);}
  50%{box-shadow:0 0 0 6px rgba(34,197,94,0);}
}

.online-title{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:22px;
  color:#fff;
  line-height:1.2;
}
.online-title em{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  color:var(--oro);
}

.online-desc{
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:rgba(245,244,240,0.7);
  line-height:1.65;
}

.online-perks{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:4px;
}

.perk-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:'Outfit',sans-serif;
  font-size:13px;
  color:rgba(245,244,240,0.8);
}

.perk-icon{
  width:24px;height:24px;
  background:rgba(201,168,76,0.15);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;
  flex-shrink:0;
}

/* Panel 3 - Calendario */
.calendar-wrap{
  font-family:'Outfit',sans-serif;
}

.cal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:16px;
}

.cal-month{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:16px;
  color:#fff;
}

.cal-nav{
  background:rgba(255,255,255,0.1);
  border:none;
  color:#fff;
  width:28px;height:28px;
  border-radius:50%;
  cursor:pointer;
  font-size:14px;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s;
}
.cal-nav:hover{background:rgba(201,168,76,0.3);}

.cal-days-header{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  text-align:center;
  font-size:10px;
  color:rgba(245,244,240,0.5);
  letter-spacing:0.05em;
  margin-bottom:8px;
}

.cal-days{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:4px;
}

.cal-day{
  aspect-ratio:1;
  border:none;
  background:transparent;
  color:rgba(245,244,240,0.8);
  font-family:'Outfit',sans-serif;
  font-size:12px;
  border-radius:50%;
  cursor:pointer;
  transition:all 0.2s;
  display:flex;align-items:center;justify-content:center;
}
.cal-day:hover:not(.disabled){background:rgba(201,168,76,0.2);}
.cal-day.selected{background:var(--oro);color:var(--carbon);font-weight:700;}
.cal-day.disabled{color:rgba(245,244,240,0.2);cursor:not-allowed;}
.cal-day.today{border:1px solid rgba(201,168,76,0.5);}

.cal-form{
  margin-top:16px;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.cal-form-row{
  display:flex;
  gap:8px;
}
.cal-form-row .cal-input{
  flex:1;
  min-width:0;
  width:50%;
}

.cal-input{
  flex:1;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:0.75rem;
  padding:10px 14px;
  font-family:'Outfit',sans-serif;
  font-size:13px;
  color:#fff;
  outline:none;
  transition:border-color 0.2s;
}
.cal-input::placeholder{color:rgba(255,255,255,0.35);}
.cal-input:focus{border-color:var(--oro);}

.btn-cal{
  width:100%;
  background:var(--oro);
  color:var(--carbon);
  border:none;
  padding:12px;
  border-radius:0.75rem;
  font-family:'Outfit',sans-serif;
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  transition:all 0.3s;
}
.btn-cal:hover{background:#e0c05a;transform:translateY(-2px);}

.cal-confirm{
  display:none;
  text-align:center;
  padding:12px;
  background:rgba(34,197,94,0.15);
  border:1px solid rgba(34,197,94,0.3);
  border-radius:0.75rem;
  color:#22c55e;
  font-family:'Outfit',sans-serif;
  font-size:13px;
  font-weight:600;
}

/* ============ MANIFIESTO ============ */
#manifiesto{
  background:var(--carbon);
  padding:120px 40px;
}

.manifiesto-inner{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}

.manifiesto-img-wrap{
  position:relative;
  padding-bottom:16px;
  padding-right:16px;
}
.manifiesto-img-wrap::after{
  content:'';
  position:absolute;
  bottom:0;
  right:0;
  width:calc(100% - 16px);
  height:calc(100% - 16px);
  border:2px solid var(--oro);
  border-radius:1.5rem;
  z-index:0;
}
.manifiesto-img-wrap img{
  width:100%;
  max-width:500px;
  height:420px;
  object-fit:cover;
  border-radius:1.5rem;
  position:relative;
  z-index:1;
  display:block;
}

.manifiesto-text{}

.manif-intro{
  font-family:'Outfit',sans-serif;
  font-size:16px;
  color:#9CA3AF;
  margin-bottom:16px;
}

.manif-quote{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:clamp(32px,4vw,46px);
  color:var(--oro);
  line-height:1.2;
  margin-bottom:24px;
}

.manif-desc{
  font-family:'Outfit',sans-serif;
  font-size:15px;
  color:rgba(255,255,255,0.75);
  line-height:1.7;
  margin-bottom:36px;
}

.btn-outline{
  display:inline-block;
  border:1.5px solid rgba(255,255,255,0.7);
  color:#fff;
  padding:13px 28px;
  border-radius:50px;
  font-family:'Outfit',sans-serif;
  font-size:14px;
  font-weight:500;
  text-decoration:none;
  cursor:pointer;
  transition:all 0.3s;
  background:transparent;
}
.btn-outline:hover{background:#fff;color:var(--carbon);}

/* ============ SERVICIOS ============ */
#servicios{
  background:var(--marfil);
  padding:120px 40px;
}

.servicios-inner{
  max-width:1100px;
  margin:0 auto;
}

.servicios-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:60px;
}

.serv-card{
  border-radius:1.5rem;
  padding:40px 32px;
  position:relative;
  overflow:hidden;
  cursor:default;
  transition:all 0.3s ease;
}
.serv-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 40px rgba(0,0,0,0.25);
}

.serv-card.card-1{background:var(--azul);}
.serv-card.card-2{background:#1E3460;}
.serv-card.card-3{background:var(--carbon);}

.serv-num{
  position:absolute;
  top:24px;right:24px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:800;
  font-size:72px;
  color:rgba(255,255,255,0.06);
  line-height:1;
  user-select:none;
}

.serv-icon{
  width:52px;height:52px;
  background:rgba(201,168,76,0.15);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;
  margin-bottom:24px;
}

.serv-card h3{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:22px;
  color:#fff;
  margin-bottom:16px;
}

.serv-card p{
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:rgba(255,255,255,0.7);
  line-height:1.7;
  margin-bottom:28px;
}

.btn-serv{
  color:var(--oro);
  background:none;
  border:none;
  font-family:'Outfit',sans-serif;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  padding:0;
  text-decoration:none;
  transition:all 0.2s;
  display:inline-block;
}
.btn-serv:hover{color:#e0c05a;letter-spacing:0.03em;}

/* ============ CONTADORES ============ */
#contadores{
  background:var(--marfil);
  padding:100px 40px;
}

.contadores-inner{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns:3fr 2fr;
  gap:80px;
  align-items:center;
}

.counters-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

.counter-item{
  padding:0 0 0 4px;
}

.counter-num{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:800;
  font-size:clamp(42px,5vw,64px);
  color:var(--azul);
  line-height:1;
  margin-bottom:8px;
}

.counter-line{
  width:40px;height:3px;
  background:var(--oro);
  margin-bottom:10px;
}

.counter-label{
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:var(--carbon);
}

.counters-cta{
  margin-top:40px;
}

.btn-solid{
  display:inline-block;
  background:var(--azul);
  color:#fff;
  padding:14px 32px;
  border-radius:50px;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  font-size:15px;
  text-decoration:none;
  border:none;
  cursor:pointer;
  transition:all 0.3s;
}
.btn-solid:hover{background:#243d6d;transform:translateY(-2px);}

.contadores-img-wrap{
  position:relative;
  padding-bottom:16px;
  padding-right:16px;
}
.contadores-img-wrap::after{
  content:'';
  position:absolute;
  bottom:0;right:0;
  width:calc(100% - 16px);
  height:calc(100% - 16px);
  border:2px solid var(--oro);
  border-radius:1.5rem;
  z-index:0;
}
.contadores-img-wrap img{
  width:100%;
  height:auto;
  object-fit:cover;
  border-radius:1.5rem;
  display:block;
  position:relative;
  z-index:1;
}

/* ============ TESTIMONIOS ============ */
#testimonios{
  background:var(--azul);
  padding:100px 40px;
}

.testimonios-inner{
  max-width:900px;
  margin:0 auto;
  text-align:center;
}

.testimonios-inner h2{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:clamp(28px,4vw,42px);
  color:#fff;
  margin-top:12px;
  margin-bottom:48px;
}

.test-carousel{
  position:relative;
  min-height:220px;
}

.test-card{
  display:none;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:1.5rem;
  padding:40px;
  text-align:left;
  position:absolute;
  width:100%;
  top:0;
  opacity:0;
  transition:opacity 0.5s ease;
}
.test-card.active{
  display:block;
  opacity:1;
  position:relative;
}

.test-stars{
  color:var(--oro);
  font-size:18px;
  letter-spacing:2px;
  margin-bottom:16px;
}

.test-text{
  font-family:'Outfit',sans-serif;
  font-size:16px;
  color:rgba(245,244,240,0.85);
  line-height:1.7;
  margin-bottom:20px;
  font-style:italic;
}

.test-author{
  display:flex;
  align-items:center;
  gap:12px;
}

.test-avatar{
  width:44px;height:44px;
  border-radius:50%;
  background:var(--oro);
  display:flex;align-items:center;justify-content:center;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:16px;
  color:var(--carbon);
  flex-shrink:0;
}

.test-name{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:15px;
  color:#fff;
}
.test-role{
  font-family:'Outfit',sans-serif;
  font-size:12px;
  color:rgba(245,244,240,0.5);
}

.test-dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:24px;
}
.dot{
  width:8px;height:8px;
  border-radius:50%;
  background:rgba(255,255,255,0.2);
  cursor:pointer;
  transition:all 0.2s;
}
.dot.active{background:var(--oro);width:24px;border-radius:4px;}

/* ============ TIPOS CONSULTA ============ */
#tipos{
  background:var(--carbon);
  padding:120px 40px;
}

.tipos-inner{
  max-width:1100px;
  margin:0 auto;
}

.tipos-inner .section-head h2{color:#fff;}

.tipos-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr 1fr;
  gap:20px;
  margin-top:60px;
  align-items:center;
}

.tipo-card{
  background:#2A2A2A;
  border-radius:1.5rem;
  padding:36px 28px;
  cursor:default;
  transition:all 0.3s ease;
  position:relative;
  border:1px solid rgba(255,255,255,0.05);
}
.tipo-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 32px rgba(0,0,0,0.3);
  border-color:rgba(255,255,255,0.1);
}

.tipo-card.destacada{
  background:var(--azul);
  border:1px solid rgba(201,168,76,0.4);
  padding-top:56px;
}

.tipo-badge{
  position:absolute;
  top:-16px;
  left:50%;
  transform:translateX(-50%);
  background:var(--oro);
  color:var(--carbon);
  font-family:'Outfit',sans-serif;
  font-weight:700;
  font-size:11px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  padding:6px 18px;
  border-radius:50px;
  white-space:nowrap;
}

.tipo-title{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:22px;
  color:#fff;
  margin-bottom:14px;
}
.tipo-card.destacada .tipo-title{font-size:26px;}

.tipo-desc{
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:rgba(255,255,255,0.65);
  line-height:1.65;
  margin-bottom:28px;
}
.tipo-card.destacada .tipo-desc{color:rgba(255,255,255,0.8);}

.btn-tipo-outline{
  width:100%;
  border:1.5px solid rgba(255,255,255,0.35);
  background:transparent;
  color:#fff;
  padding:13px;
  border-radius:1rem;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  transition:all 0.3s;
}
.btn-tipo-outline:hover{background:rgba(255,255,255,0.1);}

.btn-tipo-solid{
  width:100%;
  border:none;
  background:var(--oro);
  color:var(--carbon);
  padding:14px;
  border-radius:1rem;
  font-family:'Outfit',sans-serif;
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  transition:all 0.3s;
}
.btn-tipo-solid:hover{background:#e0c05a;transform:translateY(-2px);}

/* ============ FORMULARIO ============ */
#formulario{
  background:var(--marfil);
  padding:120px 40px;
}

.formulario-inner{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}

#cubo-canvas-wrap{
  height:500px;
  border-radius:2rem;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  background:radial-gradient(ellipse at center,rgba(27,45,79,0.08) 0%,transparent 70%);
}

#cubo-canvas{width:100%;height:100%;}

.form-head{
  margin-bottom:36px;
}
.form-head h2{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:clamp(28px,3.5vw,40px);
  color:var(--azul);
  line-height:1.2;
  margin-top:12px;
  margin-bottom:10px;
}
.form-head p{
  font-family:'Outfit',sans-serif;
  font-size:15px;
  color:#6B7280;
  line-height:1.6;
}

.form-main{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.form-row{
  display:flex;
  gap:16px;
}

.form-group{
  display:flex;
  flex-direction:column;
  gap:6px;
  flex:1;
}

.form-group label{
  font-family:'Outfit',sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--oro);
}

.form-group input,
.form-group select,
.form-group textarea{
  background:#fff;
  border:1.5px solid #E5E7EB;
  border-radius:0.75rem;
  padding:13px 16px;
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:var(--carbon);
  outline:none;
  transition:border-color 0.2s;
  width:100%;
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:#9CA3AF;}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{border-color:var(--oro);}
.form-group textarea{min-height:120px;resize:vertical;}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;}

.btn-cta-full{
  width:100%;
  background:var(--oro);
  color:var(--carbon);
  border:none;
  padding:17px;
  border-radius:2rem;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:16px;
  cursor:pointer;
  transition:all 0.3s;
  position:relative;
  overflow:hidden;
}
.btn-cta-full::before{
  content:'';
  position:absolute;
  inset:0;
  background:rgba(255,255,255,0.2);
  transform:translateX(-100%);
  transition:transform 0.4s ease;
}
.btn-cta-full:hover::before{transform:translateX(0);}
.btn-cta-full:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,0.4);}

.form-legal{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:'Outfit',sans-serif;
  font-size:12px;
  color:#9CA3AF;
  margin-top:4px;
}

.form-success{
  display:none;
  text-align:center;
  padding:20px;
  background:rgba(34,197,94,0.1);
  border:1px solid rgba(34,197,94,0.3);
  border-radius:1rem;
  color:#22c55e;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  font-size:15px;
}

/* ============ FOOTER ============ */
#footer{
  background:var(--marfil);
  padding:80px 40px 32px;
  border-top:1px solid rgba(201,168,76,0.2);
  border-radius:40px 40px 0 0;
}

.footer-inner{
  max-width:1100px;
  margin:0 auto;
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:60px;
  margin-bottom:60px;
}

.footer-logo img{
  width:400px;
  height:auto;
  margin-bottom:16px;
}

.footer-tagline{
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:var(--carbon);
  line-height:1.65;
  max-width:280px;
}

.footer-col h4{
  font-family:'Outfit',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--oro);
  margin-bottom:20px;
}

.footer-links{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.footer-links a{
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:var(--carbon);
  text-decoration:none;
  transition:color 0.2s;
}
.footer-links a:hover{color:var(--oro);}

.footer-contact-item{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:var(--carbon);
  margin-bottom:10px;
  text-decoration:none;
}
.footer-contact-item:hover{color:var(--oro);}

.disponible-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:#F0FDF4;
  border-radius:50px;
  padding:6px 14px;
  font-family:'Outfit',sans-serif;
  font-size:12px;
  color:var(--carbon);
  margin-top:8px;
  text-decoration:none;
  border:1px solid transparent;
  cursor:pointer;
  transition:all 0.25s ease;
}
.disponible-pill:hover{
  background:#dcfce7;
  border-color:rgba(34,197,94,0.4);
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(34,197,94,0.15);
  color:var(--carbon);
}

.footer-bottom{
  border-top:1px solid rgba(201,168,76,0.2);
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
}

.footer-copy{
  font-family:'Outfit',sans-serif;
  font-size:12px;
  color:rgba(26,26,26,0.55);
}

.footer-legal{
  display:flex;
  gap:20px;
}
.footer-legal a{
  font-family:'Outfit',sans-serif;
  font-size:12px;
  color:rgba(26,26,26,0.55);
  text-decoration:none;
  transition:color 0.2s;
}
.footer-legal a:hover{color:var(--oro);}

/* ============ WHATSAPP ============ */
#wa-btn{
  position:fixed;
  bottom:32px;
  right:32px;
  z-index:990;
  width:60px;height:60px;
  background:#25D366;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,0.4);
  cursor:pointer;
  text-decoration:none;
  animation:waPulse 2.5s ease-in-out infinite;
  transition:transform 0.2s;
}
#wa-btn:hover{transform:scale(1.1);}
@keyframes waPulse{
  0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.4);}
  50%{box-shadow:0 4px 40px rgba(37,211,102,0.7);}
}
.wa-tooltip{
  position:absolute;
  right:72px;
  background:var(--carbon);
  color:#fff;
  font-family:'Outfit',sans-serif;
  font-size:12px;
  padding:6px 12px;
  border-radius:6px;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.2s;
}
#wa-btn:hover .wa-tooltip{opacity:1;}

/* ============ POPUP ============ */
#exit-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.6);
  backdrop-filter:blur(6px);
  z-index:2000;
  display:none;
  align-items:center;
  justify-content:center;
}
#exit-overlay.active{display:flex;}

#exit-popup{
  background:#fff;
  border-radius:2rem;
  padding:48px 40px;
  max-width:480px;
  width:90%;
  position:relative;
  text-align:center;
  transform:scale(0.8);
  opacity:0;
  transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
#exit-overlay.active #exit-popup{
  transform:scale(1);
  opacity:1;
}

#exit-close{
  position:absolute;
  top:20px;right:20px;
  width:36px;height:36px;
  border:none;
  background:#F3F4F6;
  border-radius:50%;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;
  color:#6B7280;
  transition:all 0.2s;
}
#exit-close:hover{background:#E5E7EB;color:var(--carbon);}

.exit-badge{
  display:inline-block;
  background:rgba(201,168,76,0.15);
  color:var(--oro);
  font-family:'Outfit',sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:0.15em;
  text-transform:uppercase;
  padding:6px 14px;
  border-radius:50px;
  margin-bottom:16px;
}

#exit-popup h3{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:26px;
  color:var(--carbon);
  margin-bottom:10px;
}
#exit-popup p{
  font-family:'Outfit',sans-serif;
  font-size:15px;
  color:#6B7280;
  margin-bottom:28px;
}

.exit-form{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.exit-input{
  width:100%;
  border:1.5px solid #E5E7EB;
  border-radius:0.75rem;
  padding:14px 16px;
  font-family:'Outfit',sans-serif;
  font-size:14px;
  color:var(--carbon);
  outline:none;
  transition:border-color 0.2s;
}
.exit-input:focus{border-color:var(--oro);}
.btn-exit{
  width:100%;
  background:var(--oro);
  color:var(--carbon);
  border:none;
  padding:15px;
  border-radius:0.75rem;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;
  font-size:15px;
  cursor:pointer;
  transition:all 0.3s;
}
.btn-exit:hover{background:#e0c05a;}

.exit-success{
  display:none;
  padding:16px;
  background:rgba(34,197,94,0.1);
  border:1px solid rgba(34,197,94,0.3);
  border-radius:0.75rem;
  color:#22c55e;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  font-size:15px;
}

/* ============ RESPONSIVE ============ */
@media (max-width:900px){
  .nav-links{display:none;}
  .quienes-inner,.manifiesto-inner,.formulario-inner,.contadores-inner{grid-template-columns:1fr;gap:40px;}
  .servicios-grid,.features-grid,.tipos-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;gap:40px;}
  #hero-content{padding-left:24px;padding-right:24px;}
  #cubo-canvas-wrap{display:none;}
  .formulario-inner{grid-template-columns:1fr;}
  .manifiesto-img-wrap img{height:280px;}
  .contadores-img-wrap{display:none;}
  .tipos-grid{grid-template-columns:1fr;}
  .tipo-card.destacada{padding-top:56px;}
}

@media (max-width:600px){
  .form-row{flex-direction:column;}
  .footer-bottom{flex-direction:column;text-align:center;}
  #wa-btn{bottom:20px;right:20px;}
}

/* Noise texture on dark sections */
.noise-bg::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:0.04;
  pointer-events:none;
  z-index:0;
}
.noise-bg > *{position:relative;z-index:1;}

/* Accessibility */
:focus-visible{outline:2px solid var(--oro);outline-offset:2px;}

/* Scroll animate classes */
.gsap-fade-up{opacity:0;transform:translateY(30px);}
.gsap-fade-in{opacity:0;}
.gsap-slide-left{opacity:0;transform:translateX(-80px);}
