/* ═══════════════════════════════════════
   BOUDOIR LEÓN — CSS ESPECÍFICO DE LANDING
   (extraído del <style> inline de index.php
    para que sea cacheable por el navegador)
═══════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
/* HERO */
#hero{min-height:100svh;background:var(--vino-prof);display:flex;align-items:stretch;overflow:hidden;position:relative}
.hero-left{flex:1;display:flex;flex-direction:column;justify-content:center;padding:8rem 4rem 5rem;position:relative;z-index:2}
.hero-shape{position:absolute;border-radius:50%;pointer-events:none}
.hero-shape-1{top:-100px;left:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(248,180,73,.12) 0%,transparent 70%)}
.hero-shape-2{bottom:0;right:0;width:400px;height:400px;background:radial-gradient(circle,rgba(161,6,54,.2) 0%,transparent 70%)}
.hero-right{width:44%;position:relative;overflow:hidden;flex-shrink:0}
.hero-right::before{content:'';position:absolute;top:0;left:-60px;bottom:0;width:120px;background:var(--vino-prof);clip-path:polygon(100% 0,100% 100%,0 100%,60px 0);z-index:1}
.hero-photo{width:100%;height:100%;object-fit:cover;display:block}
.hero-photo-ph{width:100%;height:100%;min-height:100vh;background:linear-gradient(160deg,var(--vino-osc) 0%,var(--azul) 100%);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.6rem}
.hero-photo-ph span{font-family:var(--serif);font-style:italic;color:rgba(247,240,232,.2);font-size:.9rem}
.hero-photo-ph small{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(248,180,73,.3)}
.hero-tag{display:inline-flex;align-items:center;gap:.8rem;font-size:.63rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ambar);margin-bottom:1.8rem;font-weight:500;opacity:0;animation:fadeUp .8s .2s forwards}
.hero-tag::before{content:'';width:35px;height:1px;background:var(--ambar);display:block}
.hero-h1{font-family:var(--serif);font-size:clamp(2.8rem,5.5vw,5rem);font-weight:700;line-height:1.1;color:var(--crema);margin-bottom:1rem;opacity:0;animation:fadeUp .9s .35s forwards}
.hero-h1 em{font-style:italic;color:var(--ambar);font-weight:400;display:block;font-size:.78em}
.hero-sub{font-family:var(--serif);font-style:italic;font-size:clamp(.95rem,1.7vw,1.15rem);color:rgba(247,240,232,.7);line-height:1.75;max-width:440px;margin-bottom:2.5rem;opacity:0;animation:fadeUp .9s .5s forwards}
.hero-actions{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;opacity:0;animation:fadeUp .9s .65s forwards}
.hero-stats{display:flex;gap:2.5rem;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(247,240,232,.1);opacity:0;animation:fadeUp .9s .8s forwards;flex-wrap:wrap}
.hero-stat strong{display:block;font-family:var(--serif);font-size:1.8rem;color:var(--ambar);font-weight:600;line-height:1}
.hero-stat span{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,240,232,.4)}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
/* EQUIPO */
#equipo{padding:7rem 3rem;background:var(--vino-osc)}
.equipo-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.equipo-texto h2{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,3rem);font-weight:700;line-height:1.2;color:var(--crema);margin-bottom:1.5rem}
.equipo-texto h2 em{font-style:italic;color:var(--ambar)}
.equipo-texto p{font-size:.95rem;line-height:1.85;color:rgba(247,240,232,.72);margin-bottom:1rem}
.equipo-texto p strong{color:var(--ambar);font-weight:600}
.equipo-cards{display:flex;flex-direction:column;gap:1.2rem}
.equipo-card{display:flex;gap:1.2rem;align-items:flex-start;padding:1.5rem;background:rgba(255,255,255,.06);border-left:4px solid var(--ambar)}
.equipo-avatar{width:56px;height:56px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--vino),var(--azul));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.4rem;color:var(--crema);font-weight:700;overflow:hidden}
.equipo-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.equipo-info .rol{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ambar);font-weight:500;margin-bottom:.3rem}
.equipo-info h3{font-family:var(--serif);font-size:1.1rem;color:var(--crema);margin-bottom:.4rem}
.equipo-info p{font-size:.83rem;line-height:1.65;color:rgba(247,240,232,.6)}
/* SERVICIOS */
#servicios{padding:7rem 3rem;background:var(--azul)}
.servicios-header{text-align:center;max-width:600px;margin:0 auto 4rem}
.servicios-header h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:700;color:var(--crema);margin-bottom:.8rem}
.servicios-header h2 em{font-style:italic;color:var(--ambar);font-weight:400}
.servicios-header p{font-family:var(--serif);font-style:italic;color:rgba(247,240,232,.6);font-size:1rem;line-height:1.7}
.servicios-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1150px;margin:0 auto}
.servicio-card{background:rgba(255,255,255,.04);border:1px solid rgba(247,240,232,.1);padding:2.5rem 2rem;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:background .3s,border-color .3s,transform .3s}
.servicio-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--ambar);transform:scaleX(0);transition:transform .35s;transform-origin:left}
.servicio-card:hover{background:rgba(255,255,255,.07);border-color:rgba(248,180,73,.4);transform:translateY(-4px)}
.servicio-card:hover::after{transform:scaleX(1)}
.servicio-card.destacado{background:var(--vino);border-color:var(--vino-claro)}
.servicio-card.destacado:hover{background:var(--vino-claro)}
.serv-badge{position:absolute;top:1.2rem;right:1.2rem;background:var(--ambar);color:var(--azul);font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .65rem;font-weight:600}
.serv-icon{font-size:1.8rem;margin-bottom:1rem;display:block}
.servicio-card h3{font-family:var(--serif);font-size:1.4rem;color:var(--crema);margin-bottom:.7rem;font-weight:600}
.servicio-card p{font-size:.88rem;line-height:1.8;color:rgba(247,240,232,.65);flex:1;margin-bottom:1.2rem}
.serv-incluye{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.serv-incluye span{font-size:.65rem;letter-spacing:.06em;color:rgba(247,240,232,.55)}
.serv-locs{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.2rem}
.serv-loc{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(248,180,73,.35);color:var(--ambar);padding:.2rem .6rem}
.serv-precio{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1rem;margin-top:auto}
.serv-precio strong{font-family:var(--serif);font-size:1.8rem;color:var(--ambar);font-weight:600;line-height:1}
.serv-precio span{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(247,240,232,.45)}
.serv-precio-consulta{font-family:var(--serif);font-style:italic;font-size:.95rem;color:rgba(247,240,232,.5);margin-bottom:1rem;margin-top:auto}
.serv-link{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ambar);font-weight:500;border-bottom:1px solid rgba(248,180,73,.3);padding-bottom:.15rem;transition:border-color .2s}
.serv-link:hover{border-color:var(--ambar)}
/* PORTFOLIO */
#portfolio{padding:7rem 3rem;background:var(--vino)}
.portfolio-header{display:flex;justify-content:space-between;align-items:flex-end;max-width:1200px;margin:0 auto 1.6rem}
.portfolio-header h2{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,3rem);color:var(--crema);font-weight:700}
.portfolio-header h2 em{font-style:italic;color:var(--ambar);font-weight:400}
.portfolio-header a{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ambar);border-bottom:2px solid var(--ambar);padding-bottom:.2rem}
.p-filtros{max-width:1200px;margin:0 auto 1.8rem;display:flex;gap:.6rem;flex-wrap:wrap}
.p-filtro{font-family:var(--sans);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(247,240,232,.55);background:rgba(255,255,255,.05);border:1px solid rgba(247,240,232,.15);padding:.55rem 1.1rem;cursor:pointer;transition:all .25s}
.p-filtro:hover{border-color:rgba(248,180,73,.5);color:var(--crema)}
.p-filtro.active{background:var(--ambar);border-color:var(--ambar);color:var(--azul);font-weight:600}
.portfolio-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.p-item{overflow:hidden;position:relative;cursor:pointer;aspect-ratio:4/5}
.p-item.p-hide{display:none}
.p-ph,.p-vid-wrap{position:relative;width:100%;height:100%;background:linear-gradient(135deg,var(--vino-prof) 0%,var(--azul) 100%);overflow:hidden}
.p-ph img,.p-vid-wrap video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.p-item:hover .p-ph img,.p-item:hover .p-vid-wrap video{transform:scale(1.04)}
.p-ph-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem}
.p-ph-label span{font-family:var(--serif);font-style:italic;color:rgba(247,240,232,.2);font-size:.9rem}
.p-ph-label small{font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(248,180,73,.3)}
.p-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(9,15,56,.85) 0%,transparent 55%);opacity:0;transition:opacity .35s;display:flex;align-items:flex-end;padding:1.2rem}
.p-item:hover .p-overlay{opacity:1}
.p-overlay-txt{font-family:var(--serif);font-style:italic;color:var(--crema);font-size:.9rem}
.p-chip{position:absolute;left:.6rem;bottom:.6rem;font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--crema);background:rgba(9,15,56,.55);padding:.32rem .65rem;z-index:2}
.p-zoom{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);width:46px;height:46px;border-radius:50%;background:rgba(9,15,56,.45);border:1px solid rgba(247,240,232,.4);display:flex;align-items:center;justify-content:center;color:var(--crema);font-size:1.1rem;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;z-index:3}
.p-item:hover .p-zoom{opacity:1;transform:translate(-50%,-50%) scale(1)}
.p-play{position:absolute;top:.6rem;right:.6rem;width:26px;height:26px;border-radius:50%;background:rgba(9,15,56,.6);border:1px solid rgba(247,240,232,.4);display:flex;align-items:center;justify-content:center;color:var(--crema);font-size:.62rem;z-index:3}
.p-item.p-item-cta{background:var(--vino-osc);display:flex;align-items:center;justify-content:center;text-align:center;padding:1.5rem;text-decoration:none;cursor:pointer;aspect-ratio:4/5}
.p-item.p-item-cta:hover{background:var(--vino-claro)}
.p-item-cta-txt{font-family:var(--serif);font-style:italic;color:var(--ambar);font-size:1.05rem;line-height:1.5}
.p-item-cta-txt small{display:block;margin-top:.5rem;font-family:var(--sans);font-style:normal;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(247,240,232,.5)}
.portfolio-cta{text-align:center;margin-top:2.5rem}
/* LIGHTBOX PORTFOLIO */
.bl-lightbox{position:fixed;inset:0;background:rgba(9,15,56,.96);z-index:999;display:none;align-items:center;justify-content:center;padding:2rem}
.bl-lightbox.open{display:flex}
.bl-lightbox-inner{position:relative;max-width:1100px;max-height:90vh;width:100%;display:flex;flex-direction:column;align-items:center}
.bl-lightbox-inner img,.bl-lightbox-inner video{max-width:100%;max-height:78vh;object-fit:contain;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.bl-lightbox-cap{margin-top:1.2rem;font-family:var(--serif);font-style:italic;color:var(--crema);font-size:.95rem;text-align:center}
.bl-close,.bl-prev,.bl-next{position:absolute;background:rgba(255,255,255,.08);border:1px solid rgba(247,240,232,.25);color:var(--crema);cursor:pointer;transition:background .2s,border-color .2s;display:flex;align-items:center;justify-content:center}
.bl-close{top:-3rem;right:0;width:42px;height:42px;font-size:1.3rem;border-radius:50%}
.bl-close:hover,.bl-prev:hover,.bl-next:hover{background:rgba(248,180,73,.18);border-color:rgba(248,180,73,.5)}
.bl-prev,.bl-next{top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;font-size:1.6rem}
.bl-prev{left:-1rem}
.bl-next{right:-1rem}
@media(max-width:700px){.bl-prev{left:.3rem}.bl-next{right:.3rem}.bl-close{top:.6rem;right:.6rem;background:rgba(9,15,56,.6)}}
/* LOCALIZACIONES */
#localizaciones{padding:6rem 3rem;background:var(--azul-med)}
.loc-header{text-align:center;margin-bottom:3rem}
.loc-header h2{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,3rem);color:var(--crema);font-weight:700}
.loc-header h2 em{font-style:italic;color:var(--ambar)}
.loc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:800px;margin:0 auto}
.loc-card{padding:2rem 1.8rem;border:1px solid rgba(247,240,232,.1);background:rgba(255,255,255,.04);text-align:center;transition:background .3s,border-color .3s}
.loc-card:hover{background:rgba(255,255,255,.08);border-color:rgba(248,180,73,.4)}
.loc-icon{font-size:2.2rem;margin-bottom:1rem;display:block}
.loc-card h3{font-family:var(--serif);font-size:1.2rem;color:var(--crema);margin-bottom:.5rem}
.loc-card p{font-size:.85rem;color:rgba(247,240,232,.55);line-height:1.7}
/* PROCESO */
#proceso{padding:7rem 3rem;background:var(--vino-osc)}
.proceso-inner{max-width:900px;margin:0 auto}
.proceso-header{margin-bottom:4rem}
.proceso-header h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);color:var(--crema);font-weight:700}
.proceso-header h2 em{font-style:italic;color:var(--ambar)}
.paso{display:grid;grid-template-columns:70px 1fr;gap:2rem;padding:2rem 0;border-bottom:1px solid rgba(247,240,232,.1)}
.paso:last-child{border-bottom:none}
.paso-num{font-family:var(--serif);font-size:3rem;color:rgba(247,240,232,.12);line-height:1;font-weight:700}
.paso-chip{display:inline-block;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;background:var(--ambar);color:var(--azul);padding:.22rem .65rem;font-weight:600;margin-bottom:.6rem}
.paso-body h3{font-family:var(--serif);font-size:1.25rem;color:var(--crema);margin-bottom:.5rem}
.paso-body p{font-size:.9rem;line-height:1.8;color:rgba(247,240,232,.65)}
/* TESTIMONIOS */
#testimonios{padding:7rem 3rem;background:var(--vino-prof)}
.test-header{text-align:center;margin-bottom:4rem}
.test-header h2{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,3rem);color:var(--crema);font-weight:700}
.test-header h2 em{font-style:italic;color:var(--ambar)}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;margin:0 auto}
.test-card{background:rgba(255,255,255,.06);border:1px solid rgba(247,240,232,.1);padding:2.2rem 2rem;position:relative}
.test-card::before{content:'\201C';font-family:var(--serif);font-size:4.5rem;color:var(--ambar);opacity:.25;position:absolute;top:.8rem;left:1.5rem;line-height:1}
.test-stars{color:var(--ambar);font-size:.8rem;margin-bottom:.8rem;letter-spacing:.06em}
.test-card p{font-family:var(--serif);font-style:italic;font-size:.98rem;line-height:1.75;color:rgba(247,240,232,.85);margin-bottom:1.5rem;position:relative;z-index:1}
.test-author{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ambar);font-weight:500}
/* FAQ */
#faq{padding:7rem 3rem;background:var(--azul)}
.faq-inner{max-width:750px;margin:0 auto}
.faq-header{margin-bottom:3rem}
.faq-header h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);color:var(--crema);font-weight:700}
.faq-header h2 em{font-style:italic;color:var(--ambar)}
.faq-item{border-bottom:1px solid rgba(247,240,232,.12)}
.faq-q{width:100%;background:none;border:none;display:flex;justify-content:space-between;align-items:center;padding:1.4rem 0;font-family:var(--serif);font-size:1.05rem;color:var(--crema);text-align:left;cursor:pointer;transition:color .2s}
.faq-q:hover{color:var(--ambar)}
.faq-icon{font-size:1.3rem;color:var(--ambar);transition:transform .3s;flex-shrink:0;margin-left:1rem}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{font-size:.9rem;line-height:1.85;color:rgba(247,240,232,.65);padding-bottom:1.5rem}
/* RESERVA */
#reserva{padding:7rem 3rem;background:var(--vino-prof)}
.reserva-inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;align-items:start}
.reserva-texto h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);color:var(--crema);font-weight:700;line-height:1.15;margin-bottom:1.2rem}
.reserva-texto h2 em{font-style:italic;color:var(--ambar)}
.reserva-texto p{font-family:var(--serif);font-style:italic;font-size:1rem;color:rgba(247,240,232,.65);line-height:1.75;margin-bottom:2rem}
.garantias{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.garantia{display:flex;gap:.7rem;align-items:center;font-size:.83rem;color:rgba(247,240,232,.65)}
.garantia::before{content:'✓';color:var(--ambar);font-weight:700;flex-shrink:0}
.contacto-directo{padding:1.4rem;background:rgba(255,255,255,.05);border:1px solid rgba(248,180,73,.25)}
.contacto-directo p{font-size:.78rem;color:rgba(247,240,232,.5);margin-bottom:.4rem}
.contacto-directo a{color:var(--ambar);font-weight:500;font-size:.9rem}
.reserva-form{display:flex;flex-direction:column;gap:.9rem}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.f-field{display:flex;flex-direction:column;gap:.35rem}
.f-label{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ambar);font-weight:500}
.f-input,.f-select,.f-textarea{background:rgba(255,255,255,.06);border:1px solid rgba(247,240,232,.15);color:var(--crema);padding:.82rem 1rem;font-family:var(--sans);font-size:.88rem;outline:none;transition:border-color .2s,background .2s;appearance:none;width:100%}
.f-input::placeholder,.f-textarea::placeholder{color:rgba(247,240,232,.22);font-style:italic}
.f-input:focus,.f-select:focus,.f-textarea:focus{border-color:rgba(248,180,73,.6);background:rgba(248,180,73,.05)}
.f-select option{background:var(--azul)}
.f-textarea{min-height:85px;resize:vertical}
.f-btns{display:flex;flex-direction:column;gap:.7rem;margin-top:.4rem}
.btn-submit{background:var(--vino);color:var(--crema);border:none;padding:1.05rem 2rem;font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;font-weight:500;transition:background .25s,transform .2s;width:100%}
.btn-submit:hover{background:var(--vino-claro);transform:translateY(-2px)}
.f-legal{font-size:.65rem;color:rgba(247,240,232,.3);text-align:center;line-height:1.5}
.f-legal a{color:rgba(248,180,73,.6)}
/* MOBILE */
@media(max-width:900px){
#hero{flex-direction:column}
.hero-left{padding:5rem 1.5rem 3rem}
.hero-right{width:100%;height:280px}
.hero-right::before{display:none}
#equipo,#servicios,#portfolio,#localizaciones,#proceso,#testimonios,#faq,#reserva{padding:5rem 1.5rem}
.equipo-grid,.reserva-inner{grid-template-columns:1fr;gap:2.5rem}
.servicios-grid,.test-grid{grid-template-columns:1fr}
.loc-grid{grid-template-columns:1fr}
.portfolio-grid{grid-template-columns:repeat(2,1fr)}
.portfolio-header{flex-direction:column;align-items:flex-start;gap:1rem}
.f-row{grid-template-columns:1fr}
.hero-stats{gap:1.5rem}
.paso{grid-template-columns:50px 1fr}
}

/* ── MÓVIL PEQUEÑO (≤480px) — específico landing ── */
@media(max-width:480px){
  /* Hero */
  .hero-left{padding:4.5rem 1.2rem 2.5rem}
  .hero-right{height:220px}
  .hero-stats{gap:1rem}
  .hero-stat strong{font-size:1.4rem}
  .hero-actions{gap:1rem}
  .hero-actions .btn{padding:.85rem 1.4rem;font-size:.65rem}

  /* Portfolio: 1 columna en pantallas muy pequeñas */
  .portfolio-grid{grid-template-columns:1fr;gap:6px}
  .p-filtros{gap:.4rem}
  .p-filtro{padding:.45rem .8rem;font-size:.6rem}

  /* Secciones */
  #equipo,#servicios,#portfolio,#localizaciones,#proceso,#testimonios,#faq,#reserva{
    padding:4rem 1.2rem
  }

  /* Formulario */
  .btn-submit{padding:.9rem 1.4rem}
  .btn-wa{padding:.75rem 1.2rem;font-size:.63rem}

  /* Servicios */
  .servicio-card{padding:2rem 1.4rem}

  /* Pasos */
  .paso-num{font-size:2.2rem}
}
