:root{
  --gold:#D4AF37;
  --gold-2:#E7C766;
  --bg:#0B0A0F;
  --bg-2:#15131C;
  --text:#F4F1EA;
  --muted:#C5BBA3;
  --accent:#845EC2;
  --shadow:0 10px 30px rgba(0,0,0,.45);
  --radius:18px;
  --max:1120px;
  --hero-img:url('/img/2espectacularmaestras.png');
}

html,body{height:100%}
body{
  margin:0;
  color:var(--text);
  background:
    radial-gradient(80vw 60vh at 50% -10%, rgba(212,175,55,.12), transparent 60%),
    radial-gradient(50vw 40vh at 10% 20%, rgba(132,94,194,.06), transparent 60%),
    var(--bg);
  font-family:Lato,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Helvetica Neue',Arial,sans-serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.container{width:min(100% - 2rem,var(--max));margin-inline:auto}
.grid{display:grid;gap:1.2rem}

/* Botones */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;font-weight:700;text-decoration:none;border:1px solid transparent;border-radius:999px;padding:.9rem 1.2rem;box-shadow:var(--shadow)}
.btn:focus-visible{outline:3px solid var(--gold-2);outline-offset:3px}
.btn-primary{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#1a1206;border-color:rgba(0,0,0,.12)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-ghost{background:transparent;border-color:rgba(212,175,55,.35);color:var(--gold-2)}
.btn-ghost:hover{background:rgba(212,175,55,.08)}

.pill{display:inline-block;padding:.35rem .75rem;border-radius:999px;border:1px solid rgba(212,175,55,.35);color:var(--gold-2);font-weight:600;letter-spacing:.3px}
.k{color:var(--gold)}
.muted{color:var(--muted)}

/* Header */
header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(1.1) blur(6px);background:linear-gradient(180deg,rgba(11,10,15,.9),rgba(11,10,15,.65));border-bottom:1px solid rgba(212,175,55,.12)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.8rem 0}
.brand{display:flex;align-items:center;gap:.8rem}
.logo{width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--gold-2),var(--gold));box-shadow:0 0 0 2px rgba(212,175,55,.2),0 6px 24px rgba(212,175,55,.25)}
.brand h1{font-family:'Playfair Display',serif;font-size:1.15rem;margin:0}
.call-now{display:flex;align-items:center;gap:.6rem}
.call-now small{letter-spacing:.4px}

/* Hero */
.hero{position:relative;isolation:isolate;overflow:hidden}
.hero::before{
  content:"";
  position:absolute;inset:-10% -20% auto -20%;height:120%;
  background:radial-gradient(50% 40% at 50% 0%,rgba(212,175,55,.22),transparent 60%);
  z-index:-1;pointer-events:none
}
.hero .inner{display:grid;gap:1.6rem;padding:clamp(2rem,4vw + 1rem,4rem) 0}
.eyebrow{font-size:.9rem}
.hero h2{font-family:'Playfair Display',serif;font-weight:700;font-size:clamp(1.8rem,2.2rem + 1vw,3rem);line-height:1.15;margin:0}
.hero p{font-size:1.05rem;margin:.2rem 0 0}
.cta-group{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.8rem}

/* HERO visual con control de encuadre */
.hero-visual{
  aspect-ratio:4 / 3;
  border-radius:var(--radius);
  border:1px solid rgba(212,175,55,.2);
  box-shadow:0 14px 40px rgba(0,0,0,.55);

  /* Capas: 2 velos + imagen */
  background-image:
    radial-gradient(60% 60% at 40% 40%, rgba(212,175,55,.12), transparent 60%),
    linear-gradient(135deg, rgba(132,94,194,.2), transparent 40%),
    var(--hero-img);
  background-repeat:no-repeat,no-repeat,no-repeat;
  background-size:100% 100%,100% 100%,cover;
  background-position:center,center,center var(--hero-y, 25%);
}

/* Imagen secundaria (tarjeta) con control de encuadre */
.section-visual{
  width:min(100%,820px);
  aspect-ratio:4 / 6;                 /* más alto para enseñar arriba/abajo */
  border-radius:var(--radius);
  margin:1rem auto 0;
  box-shadow:0 14px 40px rgba(0,0,0,.55);
  border:1px solid rgba(212,175,55,.20);

  background-image:
    radial-gradient(60% 60% at 40% 40%, rgba(212,175,55,.10), transparent 60%),
    linear-gradient(135deg, rgba(132,94,194,.18), transparent 40%),
    url('/img/1maestrasola.png');
  background-repeat:no-repeat,no-repeat,no-repeat;
  background-size:100% 100%,100% 100%,cover;
  background-position:center,center,center var(--hero-y, 25%);
}

/* Barra fija móvil */
main{padding-bottom:calc(env(safe-area-inset-bottom,0px) + 96px)}
.bar{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + 12px);left:50%;transform:translateX(-50%);z-index:60;width:min(92%,520px)}
.bar .btn{width:100%;padding:1rem 1.2rem}

/* Separador */
.divider{--c:rgba(212,175,55,.28);position:relative;height:1px;background:linear-gradient(90deg,transparent,var(--c),transparent);margin:2.2rem 0}
.divider::after{content:"✦ ✧ ✦";position:absolute;inset:auto 0 -0.85rem 0;text-align:center;color:var(--gold-2);font-family:'Playfair Display',serif;font-size:.95rem;letter-spacing:.2rem}

/* Tipografía y paneles */
section{padding:clamp(1.5rem,3vw + 1rem,3rem) 0}
h3{font-family:'Playfair Display',serif;font-size:clamp(1.25rem,1rem + 1vw,1.6rem);margin:.4rem 0 0}
p{margin:.6rem 0}
.panel{background:linear-gradient(180deg,rgba(212,175,55,.08),rgba(212,175,55,.02));border:1px solid rgba(212,175,55,.18);border-radius:var(--radius);padding:1.2rem 1rem;box-shadow:var(--shadow)}

.steps{display:grid;gap:1rem;grid-template-columns:1fr}
.step{display:grid;gap:.4rem;padding:1rem;border:1px dashed rgba(212,175,55,.25);border-radius:14px;background:rgba(21,19,28,.5)}
.step strong{color:var(--gold-2)}
.closing{font-style:italic;color:var(--muted)}

footer{padding:2rem 0;color:var(--muted)}
footer a{color:var(--gold-2)}

/* Desktop layout */
@media (min-width:800px){
  .hero .inner{grid-template-columns:1.2fr .8fr;align-items:center}
  .hero-visual{aspect-ratio:4 / 3}
  .steps{grid-template-columns:repeat(3,1fr)}
}

/* Mobile tweaks: más alto y encuadre superior */
@media (max-width:600px){
  .hero-visual{
    aspect-ratio:2 / 3;
    --hero-y: 6%;                /* sube el encuadre del HERO */
  }
  .section-visual{
    aspect-ratio:3 / 4;
    --hero-y: 8%;                /* sube el encuadre de la secundaria */
  }
}

/* Accesibilidad/movimiento */
@media (prefers-reduced-motion:no-preference){
  .btn-primary{transition:transform .18s ease,filter .18s ease}
  .btn-primary:hover{transform:translateY(-1px)}
}

/* Animación reveal */
.reveal{opacity:0;transform:translateY(14px) scale(0.98);will-change:opacity,transform;transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
}


/* Ajuste de encuadre solo en escritorio (imagen del HERO) */
@media (min-width: 801px){
  .hero-visual{
    --hero-y: 45%;  /* Baja el encuadre para mostrar más parte inferior */
  }
}


/* HERO más vertical SOLO en escritorio grande */
@media (min-width: 1100px){
  .hero-visual{
    aspect-ratio: 2 / 3;  /* más alto → se ve más arriba y abajo */
    --hero-y: 10%;        /* encuadre un poco hacia arriba (ajusta 6–15%) */
  }
}

/* Si ya tenías esta regla, cámbiala o elimínala para que no empuje hacia abajo */
@media (min-width: 801px){
  .hero-visual{
    --hero-y: 10%;        /* en lugar de 45% */
  }
}



/* Animación suave de entrada para la imagen del HERO */
.hero-visual{
  opacity: 0;
  transform: scale(1.06);
  transition:
    opacity 1.2s ease-out,
    transform 1.8s ease-out;
}

.hero-visual.in{
  opacity: 1;
  transform: scale(1);
}