:root {
  --yellow:       #F5C518;
  --yellow-light: #FDE98A;
  --yellow-pale:  #FFFBEA;
  --violet:       rgba(91,71,170,0.92);
  --violet-s:     #5B47AA;
  --violet-dark:  #3b2d8a;
  --violet-deep:  #1f1545;
  --white:        #FFFFFF;
  --offwhite:     #FAFAF7;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden;max-width:100%;}
body{font-family:'Montserrat',sans-serif;background:var(--offwhite);color:#2a1f5a;overflow-x:hidden;max-width:100%;}

/* ── INTRO SCREEN ───────────────────────────── */
#intro-screen {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: linear-gradient(160deg, var(--violet-deep) 0%, var(--violet-dark) 40%, #2d1e6b 70%, #0d0920 100%);
  animation: introBgFade 1.2s ease-in forwards;
  animation-delay: 2.5s;
}
#intro-screen::before {
  content: '';
  position: absolute;
  inset: 0;
  background: #fff;
  z-index: 3;
  opacity: 0;
  pointer-events: none;
  animation: flashExplosion 1.5s ease-out forwards;
  animation-delay: 2.25s;
}
#intro-screen::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 80% 20%, rgba(245,197,24,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 40% 50% at 10% 80%, rgba(91,71,170,0.4) 0%, transparent 55%);
  z-index: 0;
}
.intro-sol {
  position: relative;
  z-index: 2;
  width: 600px;
  height: 600px;
  filter: drop-shadow(0 0 24px rgba(245,197,24,0.25)) drop-shadow(0 0 60px rgba(245,197,24,0.08));
  animation: solSequence 3s forwards;
}

#particles-container {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}
.intro-particle {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 6px;
  height: 6px;
  background: var(--yellow);
  border-radius: 50%;
  box-shadow: 0 0 10px var(--yellow);
  opacity: 0;
}

@keyframes solSequence {
  0% { transform: scale(1); filter: drop-shadow(0 0 24px rgba(245,197,24,0.25)); opacity: 1; animation-timing-function: ease-in-out; }
  30% { transform: scale(1.05); filter: drop-shadow(0 0 35px rgba(245,197,24,0.4)); opacity: 1; animation-timing-function: ease-in-out; }
  60% { transform: scale(1); filter: drop-shadow(0 0 24px rgba(245,197,24,0.25)); opacity: 1; animation-timing-function: ease-in-out; }
  75% { transform: scale(0.85); filter: drop-shadow(0 0 20px rgba(245,197,24,0.8)); opacity: 1; animation-timing-function: cubic-bezier(0.25, 0.46, 0.45, 0.94); }
  100% { transform: scale(15); filter: drop-shadow(0 0 100px rgba(255,255,255,1)); opacity: 0; }
}

@keyframes flashExplosion {
  0% { opacity: 0; background: #fff; }
  15% { opacity: 1; background: #fff; }
  100% { opacity: 0; background: rgba(245,197,24,0); }
}

@keyframes introBgFade {
  0% { opacity: 1; visibility: visible; }
  100% { opacity: 0; visibility: hidden; }
}

@keyframes particleExplode {
  0% {
    transform: translate(0, 0) scale(1);
    opacity: 1;
  }
  100% {
    transform: translate(var(--tx), var(--ty)) scale(0);
    opacity: 0;
  }
}

/* ── NAVBAR ─────────────────────────────── */
#navbar{
  position:fixed;top:0;left:0;width:100%;z-index:200;
  padding:22px 60px;
  display:flex;justify-content:space-between;align-items:center;
  transition:background 0.4s,padding 0.4s;
}
#navbar.scrolled{
  background:rgba(31,21,69,0.97);
  padding:14px 60px;
  box-shadow:0 2px 20px rgba(0,0,0,0.3);
}
#navbar .brand{
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem;font-weight:400;font-style:italic;
  color:var(--yellow);letter-spacing:2px;text-decoration:none;
}
#navbar nav{display:flex;gap:36px;align-items:center}
#navbar nav a{
  color:rgba(255,255,255,0.85);text-decoration:none;
  font-size:0.72rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  transition:color 0.3s;
}
#navbar nav a:hover{color:var(--yellow)}
#navbar nav .cta-nav{
  background:var(--yellow);color:var(--violet-dark)!important;
  padding:9px 22px;border-radius:50px;font-weight:700;
  transition:transform 0.2s,box-shadow 0.2s!important;
}
#navbar nav .cta-nav:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(245,197,24,0.5)}

/* ── HERO ────────────────────────────────── */
#hero{
  position:relative;height:100vh;min-height:600px;
  display:flex;align-items:center;justify-content:flex-start;
  overflow:hidden;
}
#hero .hero-bg{
  position:absolute;inset:0;
  background:linear-gradient(160deg, var(--violet-deep) 0%, var(--violet-dark) 40%, #2d1e6b 70%, #0d0920 100%);
}
#hero .hero-bg::after{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 60% at 80% 20%, rgba(245,197,24,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 40% 50% at 10% 80%, rgba(91,71,170,0.4) 0%, transparent 55%);
}
/* Sol decorativo */
.hero-sol{
  position:absolute;
  right: 10px;top:50%;
  transform:translateY(-50%);
  width:700px;height:700px;
  pointer-events:none;
  z-index:1;
  filter:drop-shadow(0 0 24px rgba(245,197,24,0.25)) drop-shadow(0 0 60px rgba(245,197,24,0.08));
  animation:solGlow 5s ease-in-out infinite alternate;
}
.sol-img{
  width:100%;height:100%;
  object-fit:contain;
}
@keyframes solGlow{
  from{filter:drop-shadow(0 0 24px rgba(245,197,24,0.25)) drop-shadow(0 0 60px rgba(245,197,24,0.08))}
  to{filter:drop-shadow(0 0 38px rgba(245,197,24,0.4)) drop-shadow(0 0 90px rgba(245,197,24,0.15))}
}
@media(max-width:900px){
  .hero-sol{width:300px;height:300px;right:-60px;top:auto;bottom:-40px;transform:none}
}
/* El texto se posiciona para que el conjunto texto+sol quede centrado */
.hero-content{
  position:relative;z-index:2;
  max-width:600px;
  margin-left:max(60px, calc(50vw - 600px));
}
@media(max-width:900px){
  .hero-content{margin-left:20px;margin-right:20px;text-align:center;}
  .hero-eyebrow{justify-content:center;}
  .hero-actions{justify-content:center;}
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:0.72rem;font-weight:600;letter-spacing:4px;text-transform:uppercase;
  color:var(--yellow);margin-bottom:28px;
}
.hero-eyebrow span{display:block;width:40px;height:1px;background:var(--yellow)}
#hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,10vw,6.5rem);
  font-weight:300;line-height:1.08;
  color:#fff;margin-bottom:12px;
}
#hero h1 em{
  font-style:italic;color:var(--yellow);
  display:block;font-weight:300;
}
#hero .hero-sub{
  font-size:0.9rem;font-weight:300;letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,0.55);margin-bottom:48px;
}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}
.btn-primary{
  background:var(--yellow);color:var(--violet-dark);
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:0.78rem;letter-spacing:2px;text-transform:uppercase;
  padding:16px 38px;border-radius:50px;text-decoration:none;
  transition:transform 0.2s,box-shadow 0.2s;
  box-shadow:0 8px 28px rgba(245,197,24,0.35);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(245,197,24,0.5)}
.btn-outline{
  border:1.5px solid rgba(255,255,255,0.3);color:#fff;
  font-family:'Montserrat',sans-serif;font-weight:600;
  font-size:0.78rem;letter-spacing:2px;text-transform:uppercase;
  padding:16px 38px;border-radius:50px;text-decoration:none;
  transition:border-color 0.3s,color 0.3s;
}
.btn-outline:hover{border-color:var(--yellow);color:var(--yellow)}
.hero-scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2;
}
.hero-scroll span{font-size:0.65rem;letter-spacing:3px;color:rgba(255,255,255,0.4);text-transform:uppercase}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,rgba(245,197,24,0.6),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:0.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}

/* ── SECTIONS GENERAL ────────────────────── */
section{padding:110px 60px}
@media(max-width:768px){
  section{padding:70px 24px}
  #navbar{padding:15px 20px; flex-direction:column; gap:12px;}
  #navbar.scrolled{padding:10px 20px;}
  #navbar nav{flex-wrap:wrap; justify-content:center; gap:12px;}
  #navbar nav a{font-size:0.65rem;}
}
.section-label{
  font-size:0.68rem;font-weight:700;letter-spacing:4px;text-transform:uppercase;
  color:var(--violet-s);margin-bottom:14px;display:flex;align-items:center;gap:10px;
}
.section-label::before{content:'';display:block;width:30px;height:1px;background:var(--violet-s)}
h2.h-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3.2rem);font-weight:400;
  color:var(--violet-dark);line-height:1.2;margin-bottom:24px;
}
h2.h-title em{font-style:italic;color:var(--violet-s)}

/* ── SOBRE MÍ ────────────────────────────── */
#sobre{background:#fff;padding-top:120px}
.sobre-wrap{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
@media(max-width:860px){.sobre-wrap{grid-template-columns:1fr;gap:48px}}
.sobre-text p{
  font-size:1.02rem;font-weight:300;line-height:1.95;
  color:#5a4f7a;margin-bottom:18px;
}
.sobre-text .firma{
  font-family:'Cormorant Garamond',serif;font-size:1.6rem;
  font-style:italic;color:var(--violet-s);margin-top:30px;
}
/* Photo stack */
.photo-stack{position:relative;height:500px}
.photo-frame{
  position:absolute;border-radius:18px;overflow:hidden;
  background:linear-gradient(135deg,var(--violet-dark),var(--violet-s));
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;color:rgba(255,255,255,0.15);
  box-shadow:0 20px 60px rgba(91,71,170,0.25);
}
.photo-frame.main{
  width:75%;height:420px;top:0;left:0;
  background-image:url('img/FOTO PARA SOBRE MI.jpeg');background-size:cover;background-position:center;
}
.photo-frame.accent{
  width:55%;height:260px;bottom:0;right:0;
  background:linear-gradient(135deg,var(--yellow-light),var(--yellow));
  font-size:3.5rem;
}
.photo-badge{
  position:absolute;top:30px;right:0;
  background:var(--violet-deep);color:var(--yellow);
  font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;
  padding:12px 20px;border-radius:12px 0 0 12px;
  box-shadow:0 4px 16px rgba(0,0,0,0.3);
}

/* ── SERVICIOS ────────────────────────────── */
#servicios{background:var(--offwhite)}
.servicios-header{max-width:1200px;margin:0 auto 60px}
.servicios-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2px;
}
.srv-card{
  background:#fff;padding:52px 40px;
  border-top:3px solid transparent;
  transition:border-color 0.3s,transform 0.3s,box-shadow 0.3s;
  cursor:pointer;
}
.srv-card:hover{border-color:var(--yellow);transform:translateY(-6px);box-shadow:0 16px 48px rgba(91,71,170,0.12)}
.srv-num{
  font-family:'Cormorant Garamond',serif;font-size:3.5rem;
  font-weight:300;color:var(--yellow-light);line-height:1;margin-bottom:20px;
}
.srv-icon{font-size:2rem;margin-bottom:16px;display:block}
.srv-card h3{
  font-family:'Cormorant Garamond',serif;font-size:1.55rem;
  font-weight:600;color:var(--violet-dark);margin-bottom:14px;
}
.srv-card p{font-size:0.92rem;font-weight:300;line-height:1.8;color:#6b5b9e;margin-bottom:15px}
.btn-more{
  background:none;border:none;color:var(--violet-s);font-weight:600;
  text-transform:uppercase;font-size:0.8rem;letter-spacing:1px;
  cursor:pointer;padding:0;border-bottom:1px solid var(--violet-s);
}
.btn-more:hover{color:var(--violet-dark);border-color:var(--violet-dark)}

/* Modal Styles */
.modal{
  display:none;position:fixed;z-index:1000;left:0;top:0;
  width:100%;height:100%;background:rgba(31,21,69,0.7);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  align-items:center;justify-content:center;
  animation: modalBgFadeIn 0.4s ease forwards;
}
.modal-content{
  background:#fff;border-radius:24px;
  max-width:650px;width:90%;position:relative;
  box-shadow:0 24px 60px rgba(31,21,69,0.4);
  overflow: hidden;
  animation: modalContentPop 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}
.modal-cover {
  width: 100%;
  height: 250px;
  background-size: cover;
  background-position: center;
  border-bottom: 6px solid var(--yellow);
}
.modal-text {
  padding: 40px 50px 50px;
}
@media(max-width:600px){
  .modal-text { padding: 30px 24px 40px; }
  .modal-cover { height: 180px; }
}
@keyframes modalBgFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes modalContentPop {
  from { opacity: 0; transform: translateY(40px) scale(0.95); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.close-modal{
  position:absolute;top:20px;right:20px;width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;line-height:1;border-radius:50%;
  background:var(--offwhite);cursor:pointer;color:var(--violet-s);
  transition:all 0.3s ease;
  z-index: 10;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.close-modal:hover{background:var(--violet-s);color:#fff;transform:rotate(90deg);}
.modal-content h3{
  font-family:'Cormorant Garamond',serif;font-size:2.4rem;
  color:var(--violet-dark);margin-bottom:20px;line-height:1.2;
}
.modal-content p{
  font-size:1.05rem;font-weight:300;line-height:1.85;color:#5a4f7a;
}


/* ── GALERÍA ──────────────────────────────── */
#galeria{background:var(--violet-deep);padding:110px 0}
.galeria-header{max-width:1200px;margin:0 auto 60px;padding:0 60px}
.galeria-header .section-label{color:var(--yellow)}
.galeria-header h2.h-title{color:#fff}
.galeria-header h2.h-title em{color:var(--yellow)}
.gallery-grid{
  max-width:1200px;margin:0 auto;padding:0 60px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:280px 280px;
  gap:12px;
}
@media(max-width:768px){
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:250px;padding:0 24px}
  .gal-item.big{grid-row:auto}
  .galeria-header{padding:0 24px}
}
.gal-item{
  border-radius:14px;overflow:hidden;
  background:linear-gradient(135deg,var(--violet-s),var(--violet-dark));
  display:flex;align-items:center;justify-content:center;
  font-size:3rem;color:rgba(255,255,255,0.15);
  position:relative;cursor:pointer;
  transition:transform 0.3s;
}
.gal-item:hover{transform:scale(1.02)}
.gal-item:hover .gal-overlay{opacity:1}
.gal-item.foto1{background-image:url('img/Galeria 1.jpg');background-size:cover;background-position:center;font-size:0}
.gal-item.foto2{background-image:url('img/Galeria 2.jpeg');background-size:cover;background-position:center;font-size:0}
.gal-item.foto3{background-image:url('img/Galeria 3.jpeg');background-size:cover;background-position:center;font-size:0}
.gal-item.foto4{background-image:url('img/Galeria 4.jpeg');background-size:cover;background-position:center;font-size:0}
.gal-item.foto5{background-image:url('img/Galeria 5.jpeg');background-size:cover;background-position:center;font-size:0}
.gal-item.big{grid-row:1/3}
.gal-overlay{
  position:absolute;inset:0;
  background:rgba(91,71,170,0.75);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity 0.3s;
  font-size:1rem;font-weight:600;color:#fff;letter-spacing:2px;text-transform:uppercase;
}
.gallery-cta{
  max-width:1200px;margin:40px auto 0;padding:0 60px;text-align:right;
}
@media(max-width:768px){.gallery-cta{padding:0 24px;text-align:center}}
.gallery-cta a{
  font-size:0.78rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--yellow);text-decoration:none;border-bottom:1px solid rgba(245,197,24,0.3);
  padding-bottom:4px;transition:border-color 0.3s;
}
.gallery-cta a:hover{border-color:var(--yellow)}

/* ── VIDEO ────────────────────────────────── */
#video{background:#fff;padding:110px 60px}
.video-wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:center}
@media(max-width:860px){.video-wrap{grid-template-columns:1fr;gap:48px}}
.video-text p{font-size:1.02rem;font-weight:300;line-height:1.9;color:#5a4f7a;margin-bottom:18px}
.video-player{
  position:relative;border-radius:20px;overflow:hidden;
  max-width: 400px; margin: 0 auto;
  background:linear-gradient(135deg,var(--violet-dark),var(--violet-deep));
  box-shadow:0 24px 70px rgba(91,71,170,0.3);
}
.video-player video{
  width:100%; height:auto; border-radius:20px; display:block;
}

/* ── PROCESO ──────────────────────────────── */
#proceso{background:var(--yellow-pale);padding:110px 60px}
.proceso-wrap{max-width:900px;margin:0 auto}
.steps{margin-top:60px;display:flex;flex-direction:column;gap:0}
.step{
  display:grid;grid-template-columns:80px 1fr;gap:30px;
  align-items:start;padding:36px 0;
  border-bottom:1px solid rgba(91,71,170,0.1);
}
@media(max-width:600px){
  .step{grid-template-columns:1fr;text-align:center;gap:15px;}
  .step-num{margin:0 auto;}
}
.step:last-child{border-bottom:none}
.step-num{
  font-family:'Cormorant Garamond',serif;
  font-size:3rem;font-weight:300;color:var(--violet-s);opacity:0.35;line-height:1;
}
.step h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;color:var(--violet-dark);margin-bottom:10px;
}
.step p{font-size:0.95rem;font-weight:300;line-height:1.8;color:#5a4f7a}

/* ── TESTIMONIOS ─────────────────────────── */
#testimonios{background:var(--offwhite);padding:110px 60px}
.test-header{max-width:1200px;margin:0 auto 60px}
.test-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%, 280px),1fr));gap:24px;
}
.test-card{
  background:#fff;border-radius:20px;padding:44px;
  border-bottom:4px solid var(--yellow);
  box-shadow:0 4px 24px rgba(91,71,170,0.07);
  transition:transform 0.3s,box-shadow 0.3s;
}
.test-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(91,71,170,0.14)}
.stars{color:var(--yellow);font-size:1rem;letter-spacing:2px;margin-bottom:20px}
.test-card blockquote{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:1.18rem;line-height:1.7;color:#4a3f7a;margin-bottom:28px;
}
.test-author{display:flex;align-items:center;gap:14px}
.test-avatar{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--yellow),var(--yellow-light));
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.test-name{font-weight:700;font-size:0.9rem;color:var(--violet-dark)}
.test-role{font-size:0.78rem;color:#9b8ec4;font-weight:300}

/* ── CONTACTO ────────────────────────────── */
#contacto{
  background:linear-gradient(150deg,var(--violet-deep) 0%,var(--violet-dark) 50%,#2d1e6b 100%);
  padding:110px 60px;position:relative;overflow:hidden;
}
#contacto::before{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,197,24,0.08),transparent 70%);
  right:-200px;top:50%;transform:translateY(-50%);
}
.contacto-wrap{max-width:700px;margin:0 auto;text-align:center;position:relative;z-index:1}
.contacto-wrap .section-label{justify-content:center;color:var(--yellow)}
.contacto-wrap .section-label::before{background:var(--yellow)}
.contacto-wrap h2.h-title{color:#fff;margin-bottom:16px}
.contacto-wrap h2.h-title em{color:var(--yellow)}
.contacto-wrap p{
  font-size:1rem;font-weight:300;line-height:1.85;
  color:rgba(255,255,255,0.65);margin-bottom:50px;
}
.contact-btns{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}
.social-link{
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;transition:transform 0.2s,opacity 0.2s;
  text-decoration:none;
}
.social-link:hover{transform:scale(1.1);opacity:0.8}
.social-link svg{width:40px;height:40px}
.contact-divider{
  margin:60px auto 0;max-width:300px;
  border:none;border-top:1px solid rgba(255,255,255,0.1);
}
.contact-info{margin-top:40px;display:flex;flex-wrap:wrap;gap:30px;justify-content:center}
.ci{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,0.5);font-size:0.85rem}
.ci strong{color:rgba(255,255,255,0.85);font-weight:400}

/* ── FOOTER ──────────────────────────────── */
footer{
  background:var(--violet-deep);
  padding:32px 60px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
@media(max-width: 768px){
  footer{justify-content:center;text-align:center;flex-direction:column;padding:32px 24px;}
}
footer .ft-brand{
  font-family:'Cormorant Garamond',serif;
  font-size:1.15rem;font-style:italic;color:var(--yellow);
}
footer p{font-size:0.78rem;color:rgba(255,255,255,0.35);letter-spacing:0.5px}

/* ── FADE IN ──────────────────────────────── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 0.8s ease,transform 0.8s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-36px);transition:opacity 0.8s ease,transform 0.8s ease}
.reveal-left.visible{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(36px);transition:opacity 0.8s ease,transform 0.8s ease}
.reveal-right.visible{opacity:1;transform:none}
