/* ============================================================
   SANTORI · LANDING PAGE
   Sistema: Biblia de Diagramación V2.0
   ============================================================ */
:root{
  --navy:#1E3359;
  --slate:#565C81;
  --sand:#C7B7AA;
  --champagne:#E3D7C5;
  --ivory:#FDFBF7;
  --gold:#FCEFCE;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--ivory);
  font-family:'Inter',sans-serif;
  color:var(--slate);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{cursor:pointer;}
:focus-visible{outline:2px solid var(--navy);outline-offset:3px;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important;transition-duration:0.01ms !important;}
}

/* ---------- utilidades de sección ---------- */
.eyebrow{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:11px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--sand);
}
.divider-thin{width:56px;height:1px;background:var(--champagne);margin:22px 0;}
.divider-thin.on-navy{background:rgba(253,251,247,.22);}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;background-color:var(--ivory);
  position:relative;overflow:hidden;
  padding:64px 20px 80px 20px;
}
.hero-photo{
  position:absolute;inset:0;z-index:0;
  background-image: url("../../img/home/hero.jpg");
  background-size:cover;background-position:center 30%;
  opacity:.30;
  filter:saturate(.85) brightness(1.08);
}
.hero::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(253,251,247,.78) 0%, rgba(253,251,247,.92) 40%, var(--ivory) 82%);
}
.hero-content{
  position:relative;z-index:1;max-width:800px;
  display:flex;flex-direction:column;align-items:center;gap:0;
}
.hero-logo{
  height: auto;
  width: 400px;
  display: block;
  margin-bottom: 150px;
}
.hero-h1{
  font-family:'Cinzel',serif;font-weight:400;
  font-size:clamp(32px,5vw,54px);color:var(--navy);
  line-height:1.3;margin-bottom:24px;letter-spacing:-0.01em;
}
.hero-support{
  font-family:'Montserrat',sans-serif;font-weight:500;
  font-size:clamp(9.5px,1.9vw,13px);color:var(--slate);
  letter-spacing:.24em;text-transform:uppercase;
  margin-bottom:36px;line-height:1.6;
  white-space:nowrap;
}
@media (max-width:420px){
  .hero-support{letter-spacing:.14em;font-size:9px;}
}
.hero-divider{width:48px;height:1px;background:var(--champagne);margin-bottom:36px;}
.hero-cta{
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:13px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--ivory);
  text-decoration:none;padding:16px 40px;border:1px solid var(--navy);
  background:var(--navy);transition:all .4s ease;cursor:pointer;
}
.hero-cta:hover{background:transparent;color:var(--navy);}

/* ============================================================
   PROMESA
   ============================================================ */
.santuario-promesa{
  padding:100px 0;background-color:var(--ivory);
  position:relative;overflow:hidden;
}
.santuario-promesa::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
}
.promesa-grid{
  max-width:1200px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:1fr;gap:50px;align-items:center;
  position:relative;z-index:1;
}
@media (min-width:860px){ .promesa-grid{grid-template-columns:1fr 1fr;gap:80px;} }
.promesa-foto{width:100%;overflow:hidden;background:var(--champagne);}
.promesa-foto img{width:100%;height:540px;object-fit:cover;object-position:center top;border-radius:0;display:block;}
.promesa-foto .ph{
  height:540px;display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--slate);
}
.promesa-texto{display:flex;flex-direction:column;justify-content:center;}
.promesa-h2{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;
  letter-spacing:.34em;text-transform:uppercase;color:var(--sand);
  margin-bottom:28px;line-height:1.6;
}
.promesa-relato{font-family:'Inter',sans-serif;font-size:15px;color:var(--slate);line-height:1.9;}
.promesa-relato p{margin-bottom:22px;}
.promesa-relato p:last-child{margin-bottom:0;}
.promesa-relato strong{font-weight:600;color:var(--navy);}
.promesa-firma{margin-top:40px;display:flex;flex-direction:column;align-items:flex-end;}
.promesa-firma .firma-texto{font-family:'Meow Script',cursive;font-size:38px;color:var(--navy);line-height:1;}
.promesa-firma .firma-rol{
  font-family:'Montserrat',sans-serif;font-size:9px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--sand);margin-top:6px;
}

/* ── SECCIÓN 3: EL SANTUARIO ── */
.santuario-studio {
    padding: 100px 0;
    background-color: var(--ivory);
    position: relative;
}

.santuario-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 40px;
}

.studio-header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto 60px auto;
}

.santori-studio-logo {
    width: 250px;
    margin: 0 auto 40px;
}

.studio-h2 {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.34em;
    text-transform: uppercase;
    color: var(--sand);
    margin-bottom: 20px;
}

.studio-intro {
    font-family: 'Cinzel', serif;
    font-size: clamp(24px, 3.5vw, 36px);
    color: var(--navy);
    line-height: 1.4;
}

.studio-main-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 50px;
    align-items: center;
    margin-bottom: 80px;
}

@media (min-width: 860px) {
  .studio-main-grid {
    grid-template-columns: 1fr 1.2fr;
    gap: 80px;
  }
}

.studio-principal-foto {
    width:100%;
    overflow:hidden;
    background:var(--champagne);
}

.studio-principal-foto img {
    width: 100%;
    height: 580px;
    object-fit: cover;
    object-position: center;
    border-radius: 0px;
    display: block;
}

.studio-principal-foto .ph {
    height:580px;display:flex;
    align-items:center;
    justify-content:center;
    font-family:'Montserrat',sans-serif;
    font-size:10px;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:var(--slate);
    text-align:center;
    padding:0 30px;
}

.studio-experiencias {
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.experiencia-item {
    border-bottom: 1px solid var(--champagne);
    padding-bottom: 30px;
}

.experiencia-item:last-child {
border-bottom: none;
padding-bottom: 0;
}

.experiencia-titulo {
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--navy);
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 15px;
}

.experiencia-titulo span {
    font-family: 'Meow Script', cursive;
    font-size: 28px;
    color: var(--sand);
    text-transform: none;
    letter-spacing: 0;
}

.experiencia-texto {
    font-family: 'Inter', sans-serif;
    font-size: 14.5px;
    color: var(--slate);
    line-height: 1.8;
}

/* ── GALERÍA DE INVITADAS: NUESTRO ARTE ── */
.studio-galeria-seccion {
    margin-top: 100px;
    border-top: 1px solid var(--champagne);
    padding-top: 80px;
}

.galeria-frase {
    text-align: center;
    font-family: 'Cinzel', serif;
    font-size: clamp(20px, 2.5vw, 28px);
    color: var(--navy);
    margin-bottom: 48px;
    font-style: italic;
}

.galeria-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}

@media (min-width: 768px) {
  .galeria-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }
}

.galeria-item {
    overflow: hidden;
    position: relative;
    background: var(--champagne);
}

.galeria-item img {
    width: 100%;
    height: 380px;
    object-fit: cover;
    object-position: center;
    border-radius: 0px;
    transition: transform 0.6s ease;
    display: block;
}
.galeria-item .ph{
    height:380px;display:flex;align-items:center;justify-content:center;
    font-family:'Montserrat',sans-serif;font-size:9px;letter-spacing:.16em;
    text-transform:uppercase;color:var(--slate);text-align:center;padding:0 16px;
}

.galeria-item:hover img {
    transform: scale(1.04);
}

.studio-cta-wrapper {
    text-align: center;
    margin-top: 60px;
}

.studio-cta {
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--ivory);
    text-decoration: none;
    padding: 18px 44px;
    background: var(--navy);
    border: 1px solid var(--navy);
    transition: all 0.4s ease;
    display: inline-block;
    cursor: pointer;
}

.studio-cta:hover {
    background: transparent;
    color: var(--navy);
}

/* ── SECCIÓN 4: SANTORI BEAUTY ACADEMY (ATEMPORAL) ── */
.beauty-academy {
    padding: 100px 0;
    background-color: var(--navy);
    position: relative;
}

.academy-container {
    max-width:1200px;
    margin:0 auto;
    padding:0 40px;
    
}

/* Bloque Superior · Misión + Sello AURA */

.academy-top {
    display:grid;
    grid-template-columns:1fr;
    gap:56px;
    align-items:center;
    margin-bottom:100px;
}

@media (min-width:900px) {
  .academy-top {
      grid-template-columns:1fr 1fr;
      gap:80px;
  }
}

.academy-header {
    text-align: center;
}

.santori-academy-logo {
    width: 300px;
    margin: 0 auto 30px;
}

.academy-h2 {
    font-family:'Montserrat',sans-serif;
    font-weight:700;
    font-size:11px;
    letter-spacing:.3em;
    text-transform:uppercase;
    color:var(--sand);
    margin-bottom:22px;
}

.academy-title {
    font-family:'Cinzel',serif;
    font-weight:500;
    font-size:clamp(26px,3.6vw,38px);
    color: var(--ivory);
    line-height:1.35;
    margin-bottom:26px;
}

.academy-text {
    font-family:'Inter',sans-serif;
    font-size:15px;
    color: var(--ivory);
    line-height:1.9;
    max-width:460px;
}

/* Tile · Sello de Calidad AURA */
.aura-seal{
    border: 1px solid var(--champagne);
    padding: 56px 44px;
    text-align: center;
    position: relative;
}
.aura-seal-mark{
    width:52px;
    height:52px;
    border:1px solid var(--gold);
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    margin:0 auto 26px;
    font-family:'Cinzel',serif;
    font-weight:600;
    font-size:16px;
    color:var(--gold);
    letter-spacing:.04em;
}

.aura-seal-title{
    font-family:'Montserrat',sans-serif;
    font-weight:700;
    font-size:14px;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:var(--navy);
    margin-bottom:20px;
}
.aura-seal-text{
    font-family:'Inter',sans-serif;
    font-size:14px;
    color:var(--ivory);
    line-height:1.85;
}

/* Bloque Inferior · Los 3 Beneficios */
.academy-beneficios-head{text-align:center;margin-bottom:48px;}
.academy-beneficios-head .academy-h2{margin-bottom:0;}

.beneficios-grid{
  display:grid;grid-template-columns:1fr;gap:1px;
  background:rgba(30,51,89,.10);
}

@media (min-width:760px) {
    
    .beneficios-grid {
        grid-template-columns:repeat(3,1fr);
        
    } 

}

.beneficio-item {
    padding: 40px 32px;
    text-align: center;
    
}

.beneficio-num{
  font-family:'Cinzel',serif;font-weight:600;font-size:13px;color:var(--sand);
  display:block;margin-bottom:16px;letter-spacing:.06em;
}
.beneficio-item h4{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:12.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--navy);
  margin-bottom:14px;line-height:1.5;
}
.beneficio-item p{
    font-family:'Inter',sans-serif;
    font-size:13.5px;
    line-height:1.8;
    color:var(--ivory);
}

.academy-cta-wrap {
    text-align:center;
    margin-top:60px;
    
}

.academy-cta {
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:13px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--navy);
  text-decoration:none;
  padding:18px 44px;
  background:var(--ivory);
  border:1px solid var(--ivory);
  transition:all .4s ease;
  display:inline-block;
  cursor:pointer;
}

.academy-cta:hover {
    background:transparent;
    color:var(--ivory);
}

/* ── BLOQUE DE CIERRE: EL REFUGIO ── */
.santuario-cierre {
    background:var(--ivory);
}

.cierre-frame {
    margin:0 auto;
    position:relative;
    overflow:hidden;
    padding:88px 48px;
    text-align:center;
}
.cierre-frame::before{
  content:'';position:absolute;top:-110px;left:-110px;width:300px;height:300px;
  background:radial-gradient(circle,var(--gold) 0%,transparent 70%);opacity:.10;pointer-events:none;
}
.cierre-eyebrow{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;color:var(--sand);
  margin-bottom:22px;position:relative;z-index:1;
}

.cierre-title {
    font-family:'Cinzel',serif;
    font-weight:500;
    font-size:clamp(26px,4vw,38px);
    color:var(--navy);
    line-height:1.35;
    margin-bottom:28px;
    position:relative;
    z-index:1;
}

.cierre-msg{
    font-family:'Inter',sans-serif;
    font-size:15px;
    color:rgba(253,251,247,.72);
    line-height:1.9;
    max-width:520px;
    color:var(--navy);
    margin:0 auto 40px;
    position:relative;
    z-index:1;
}

.cierre-cta{
    font-family:'Montserrat',sans-serif;
    font-weight:600;
    font-size:13px;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:var(--ivory);
    text-decoration:none;
    padding:17px 40px;
    background:var(--navy);
    border:1px solid var(--navy);
    transition:all .4s ease;
    display:inline-block;
    cursor:pointer;
    position:relative;
    z-index:1;
}

.cierre-cta:hover {
    background:transparent;
    color:var(--navy);
}
.cierre-firma {
    display:block;
    margin-top:34px;
    position:relative;
    z-index:1;
    font-family:'Meow Script',cursive;
    font-size:20px;
    color:var(--slate);
    opacity:.8;
}