*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--beige:#ede4d9;--beige-light:#f5efe8;--brown:#3d3028;--brown-light:#6b5b4e;--mauve:#c4a08a;--mauve-light:#d4b8a5;--white:#fff;--black:#1a1a1a;--dark:#222;--dark-card:#333;--gold:#b8943e;--font-title:'Bebas Neue',sans-serif;--font-body:'Montserrat',sans-serif;--gap:clamp(1.2rem,4vw,2.5rem);--section-py:clamp(4rem,8vw,7rem)}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font-body);color:var(--brown);background:var(--beige);font-size:clamp(14px,1.1vw,16px);line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-title);font-weight:400;letter-spacing:.12em;line-height:1.1}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
/* NAV */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;display:flex;flex-direction:column}
.nav__bar{background:rgba(30,25,20,.3);backdrop-filter:blur(4px);padding:.6rem 0;transition:background .4s,padding .3s}
.nav.scrolled .nav__bar{background:rgba(30,25,20,.85);backdrop-filter:blur(8px);padding:.45rem 0}
.nav__links{display:flex;align-items:center;justify-content:center;gap:1.1rem;flex-wrap:wrap;max-width:1300px;margin:0 auto;padding:0 var(--gap)}
.nav__link{font-family:var(--font-body);font-size:.8rem;letter-spacing:.15em;font-weight:400;color:var(--white);text-transform:uppercase;opacity:.85;transition:opacity .3s}
.nav__link:hover{opacity:1}
.nav__cta-row{max-width:1050px;width:100%;margin:0 auto;padding:.4rem var(--gap) 0;display:flex;justify-content:flex-end}
.nav__cta{font-family:var(--font-body);font-size:.75rem;letter-spacing:.15em;font-weight:500;color:var(--white);text-transform:uppercase;border:1px solid rgba(255,255,255,.4);padding:.35rem 1.1rem;border-radius:3px;background:rgba(30,25,20,.7);transition:background .3s,border-color .3s}
.nav__cta:hover{background:rgba(255,255,255,.1);border-color:var(--white)}
.nav__sep{color:rgba(255,255,255,.3);font-size:.7rem}
.nav__moblogo,.nav__mobcta{display:none}
.nav__burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:5px;z-index:301}
.nav__burger span{width:24px;height:2px;background:var(--white);transition:transform .3s,opacity .3s}
.nav__burger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav__burger.active span:nth-child(2){opacity:0}
.nav__burger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
/* MOBILE OVERLAY (outside nav, direct child of body) */
.mob-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(30,25,20,.97);z-index:200;flex-direction:column;justify-content:center;align-items:center;gap:1.8rem;padding:2rem}
.mob-overlay.open{display:flex}
.mob-overlay__close{position:absolute;top:1rem;right:1.2rem;background:none;border:none;color:var(--white);font-size:1.4rem;cursor:pointer;padding:.5rem;opacity:.8;transition:opacity .3s}
.mob-overlay__close:hover{opacity:1}
.mob-overlay__link{font-family:var(--font-body);font-size:1.1rem;letter-spacing:.18em;font-weight:400;color:var(--white);text-transform:uppercase;text-decoration:none;transition:opacity .3s}
.mob-overlay__link:hover{opacity:.7}
/* HERO */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;align-items:stretch;overflow:hidden;padding:0 0 clamp(3rem,6vw,5rem)}
.hero__bg{position:absolute;inset:0;background:url('/img/hero.jpg') center/cover no-repeat;filter:brightness(.55)}
.hero__content{position:relative;z-index:2;max-width:1050px;width:100%;margin:0 auto;padding:0 var(--gap)}
.hero__logo{width:clamp(180px,25vw,320px);margin-bottom:1.5rem;opacity:0;animation:fadeUp .8s .3s forwards}
.hero__title{font-size:clamp(1.6rem,3.5vw,2.8rem);color:var(--white);letter-spacing:.2em;opacity:0;animation:fadeUp .8s .6s forwards}
.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;opacity:0;animation:fadeUp .8s 1s forwards}
.hero__scroll svg{width:28px;height:28px;stroke:var(--white);animation:bounce 2s infinite}
/* SECTIONS */
.section{padding:var(--section-py) var(--gap)}
.section__inner{max-width:800px;margin:0 auto}
.section__tag{font-family:var(--font-title);font-size:clamp(1.2rem,2.5vw,1.8rem);letter-spacing:.15em;color:var(--brown)}
.section__title{font-size:clamp(2.2rem,5vw,4rem);margin-bottom:1.5rem}
/* QUIÉNES SOMOS */
.qs{background:var(--beige);padding-bottom:clamp(1.5rem,3vw,2.5rem)}
.qs__header{text-align:right;margin-bottom:1.5rem}
.qs__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(1.5rem,3vw,2.5rem);align-items:start}
.qs__text{font-size:1.05rem;line-height:1.8}
.qs__text p{margin-bottom:1rem}
.qs__img{border-radius:3px;overflow:hidden}
.qs__img img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top}
/* MÁS QUE GIMNASIA */
.mqg{background:var(--beige);padding-top:clamp(1.5rem,3vw,2.5rem)}
.mqg__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(1.5rem,3vw,2.5rem);align-items:start}
.mqg__img{border-radius:3px;overflow:hidden}
.mqg__img img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .6s}
.mqg__img:hover img{transform:scale(1.02)}
.mqg__text{font-size:1.05rem;line-height:1.8}
.mqg__text p{margin-bottom:1rem;color:var(--brown)}
.mqg__text p:last-child{font-style:italic;font-weight:400}
/* EXPLORA */
.explora{background:var(--black);color:var(--white);text-align:center}
.explora .section__tag{color:rgba(255,255,255,.6)}
.explora .section__title{color:var(--white)}
.explora__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.explora__card{display:flex;flex-direction:column;align-items:center;gap:0}
.explora__card-img{width:100%;aspect-ratio:3/4;border-radius:6px;overflow:hidden}
.explora__card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.explora__card:hover .explora__card-img img{transform:scale(1.05)}
.explora__card-label{display:inline-block;margin-top:1rem;padding:.7rem 1.8rem;background:var(--dark-card);border-radius:30px;font-family:var(--font-title);font-size:1.1rem;letter-spacing:.12em;color:var(--white)}
.explora__card-sub{font-size:.85rem;font-weight:500;margin-top:.8rem;color:var(--white)}
.explora__card-btn{display:inline-block;margin-top:.8rem;padding:.5rem 1.5rem;border:1.5px solid rgba(255,255,255,.5);border-radius:30px;font-size:.72rem;letter-spacing:.12em;font-weight:400;color:var(--white);transition:background .3s,border-color .3s}
.explora__card-btn:hover{background:rgba(255,255,255,.1);border-color:var(--white)}
/* PROGRAMAS */
.programas{background:var(--black);color:var(--white)}
.programas .section__tag{color:rgba(255,255,255,.6)}
.programas .section__title{color:var(--white)}
.prog-rows{max-width:800px;margin:0 auto}
.prog-row{display:grid;grid-template-columns:1fr 1fr;overflow:hidden}
.prog-row__img{overflow:hidden;aspect-ratio:1/1}
.prog-row__img img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s}
.prog-row:hover .prog-row__img img{transform:scale(1.03)}
.prog-row__info{display:flex;flex-direction:column;justify-content:center;padding:clamp(1.5rem,3vw,2.5rem);background:rgba(255,255,255,.06)}
.prog-row__name{font-family:var(--font-title);font-size:clamp(1.5rem,3vw,2.2rem);letter-spacing:.12em;color:var(--white)}
.prog-row__age{font-size:.85rem;font-weight:500;font-style:italic;margin-top:.3rem;color:var(--mauve-light)}
.prog-row__desc{font-size:.82rem;margin-top:.8rem;color:rgba(255,255,255,.75);line-height:1.6}
.prog-row:nth-child(even) .prog-row__img{order:2}
.prog-row:nth-child(even) .prog-row__info{order:1}
/* HORARIOS CTA */
.horarios{background:var(--black);text-align:center;padding:var(--section-py) var(--gap)}
.horarios__box{display:inline-block;padding:2rem 4rem;background:var(--dark-card);border-radius:16px;margin-bottom:2rem}
.horarios__box h2{font-size:clamp(2rem,5vw,3.5rem);color:var(--beige);letter-spacing:.15em}
.horarios__btn{display:inline-block;padding:.8rem 2.5rem;border:1.5px solid rgba(255,255,255,.5);border-radius:30px;font-family:var(--font-title);font-size:1.2rem;letter-spacing:.15em;color:var(--white);transition:background .3s,border-color .3s}
.horarios__btn:hover{background:rgba(255,255,255,.1);border-color:var(--white)}
/* PROYECTOS */
.proyectos{background:var(--black);color:var(--white)}
.proyectos .section__tag{color:rgba(255,255,255,.6)}
.proyectos .section__title{color:var(--white)}
.proyectos__divider{width:100%;height:1px;background:rgba(255,255,255,.3);margin-bottom:2rem}
.proy-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.proy-card{display:flex;flex-direction:column;align-items:center;text-align:center}
.proy-card__img{width:100%;aspect-ratio:3/4;border-radius:6px;overflow:hidden}
.proy-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.proy-card:hover .proy-card__img img{transform:scale(1.05)}
.proy-card__label{display:inline-block;margin-top:1rem;padding:.6rem 1.5rem;background:var(--dark-card);border-radius:30px;font-family:var(--font-title);font-size:.95rem;letter-spacing:.1em;color:var(--white)}
.proy-card__desc{font-size:.78rem;color:rgba(255,255,255,.7);margin-top:.8rem;line-height:1.6;max-width:280px}
.proy-card__btn{display:inline-block;margin-top:.8rem;padding:.45rem 1.3rem;border:1.5px solid rgba(255,255,255,.5);border-radius:30px;font-size:.68rem;letter-spacing:.1em;color:var(--white);transition:background .3s}
.proy-card__btn:hover{background:rgba(255,255,255,.1)}
/* ARTÍCULOS */
.articulos{background:var(--black);color:var(--white)}
.articulos .section__tag{color:rgba(255,255,255,.6)}
.articulos .section__title{color:var(--white);margin-bottom:2.5rem}
.art-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.art-sidebar{border-radius:4px;overflow:hidden}
.art-sidebar img{width:100%;aspect-ratio:2/3;object-fit:cover}
.art-list{display:flex;flex-direction:column;gap:0}
.art-item{display:block;padding:1.5rem 0;border-bottom:1px solid rgba(255,255,255,.2);transition:opacity .3s}
.art-item:first-child{padding-top:0}
.art-item:hover{opacity:.8}
.art-item__title{font-family:var(--font-title);font-size:clamp(1.1rem,2vw,1.5rem);letter-spacing:.1em;color:var(--white);margin-bottom:.5rem}
.art-item__excerpt{font-size:.8rem;color:rgba(255,255,255,.65);line-height:1.6}
/* CONTACTO */
.contacto{background:var(--beige);padding-bottom:clamp(1.5rem,3vw,2.5rem)}
.contacto__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,2.5rem);max-width:600px;margin:0 auto}
.contacto__info{display:flex;flex-direction:column;gap:.5rem}
.contacto__info p{font-size:.85rem}
.contacto__logo{width:clamp(140px,18vw,200px)}
.contacto__map{margin-top:1rem;border-radius:6px;overflow:hidden;grid-column:1/-1}
.contacto__map iframe{width:100%;height:250px;border:0}
/* FORMULARIO */
.formulario{background:var(--beige);padding-top:clamp(1.5rem,3vw,2.5rem);padding-bottom:var(--section-py)}
.formulario__inner{max-width:550px;margin:0 auto}
.formulario .section__title{margin-bottom:1.5rem;font-size:clamp(1.6rem,3vw,2.2rem)}
.form-table{display:grid;gap:.5rem}
.form-row{display:grid;grid-template-columns:130px 1fr;align-items:start}
.form-row__label{font-weight:500;font-size:.78rem;padding:.6rem .8rem;background:var(--beige-light);border:1px solid rgba(61,48,40,.1);border-right:0;border-radius:3px 0 0 3px;display:flex;align-items:center;min-height:40px}
.form-row__input{font-family:var(--font-body);font-size:.8rem;padding:.6rem .8rem;border:1px solid rgba(61,48,40,.15);border-radius:0 3px 3px 0;background:var(--white);color:var(--brown);outline:none;transition:border-color .3s;min-height:40px}
.form-row__input:focus{border-color:var(--mauve)}
.form-row__textarea{min-height:90px;resize:vertical}
.form__submit{margin-top:1rem;display:inline-block;font-family:var(--font-body);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:.7rem 2rem;border:1.5px solid var(--brown);color:var(--brown);border-radius:2px;background:transparent;cursor:pointer;transition:background .3s,color .3s}
.form__submit:hover{background:var(--brown);color:var(--white)}
/* WHATSAPP */
.wa-btn{position:fixed;bottom:1.5rem;right:1.5rem;z-index:90;width:52px;height:52px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px rgba(0,0,0,.25);transition:transform .3s,box-shadow .3s}
.wa-btn:hover{transform:scale(1.1);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.wa-btn svg{width:28px;height:28px;fill:var(--white)}
/* FOOTER */
.footer{background:var(--black);color:rgba(255,255,255,.6);text-align:center;padding:2.5rem var(--gap) 1.5rem}
.footer__logo{width:120px;margin:0 auto 1rem;opacity:.7}
.footer__copy{font-size:.7rem;letter-spacing:.05em}
/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.reveal.visible{opacity:1;transform:translateY(0)}
/* RESPONSIVE */
@media(max-width:900px){
.nav{flex-direction:row;align-items:center;justify-content:space-between;padding:.6rem var(--gap);background:rgba(30,25,20,.4);backdrop-filter:blur(4px)}
.nav.scrolled{background:rgba(30,25,20,.85);backdrop-filter:blur(8px)}
.nav__bar,.nav__cta-row{display:none}
.nav__moblogo{display:block;flex:1}
.nav__moblogo img{height:25px;width:auto;opacity:.9;margin-left:20px}
.nav__mobcta{display:block;font-family:var(--font-body);font-size:.65rem;letter-spacing:.12em;font-weight:500;color:var(--white);text-transform:uppercase;border:1px solid rgba(255,255,255,.4);padding:.3rem .8rem;border-radius:3px;background:rgba(30,25,20,.7);white-space:nowrap}
.nav__burger{display:flex}
.nav__burger span{width:20px;height:1.5px}
.hero{height:100vh;min-height:0;max-height:100vh}
.mqg__grid,.qs__grid,.contacto__inner{grid-template-columns:1fr}
.qs__header{text-align:left}
.qs__img{order:-1}
.mqg__text{order:1}
.mqg__img{order:-1}
.explora__cards,.proy-cards{grid-template-columns:1fr}
.prog-row{grid-template-columns:1fr}
.prog-row:nth-child(even) .prog-row__img{order:0}
.prog-row:nth-child(even) .prog-row__info{order:0}
.art-layout{grid-template-columns:1fr}
.art-sidebar{max-width:300px}
.form-row{grid-template-columns:1fr}
.form-row__label{border-right:1px solid rgba(61,48,40,.1);border-radius:3px 3px 0 0;border-bottom:0;min-height:36px}
.form-row__input{border-radius:0 0 3px 3px;min-height:36px}
.horarios__box{padding:1.5rem 2.5rem}
}
/* BLOG LIST */
.blog-hero{background:var(--black);padding:clamp(6rem,12vw,9rem) var(--gap) var(--section-py);text-align:center;color:var(--white)}
.blog-hero h1{font-size:clamp(2.5rem,6vw,4rem);letter-spacing:.15em}
.blog-list{background:var(--beige);padding:var(--section-py) var(--gap)}
.blog-list__inner{max-width:800px;margin:0 auto;display:grid;gap:2rem}
.blog-card{display:grid;grid-template-columns:200px 1fr;gap:1.5rem;align-items:start}
.blog-card__img{aspect-ratio:4/3;border-radius:4px;overflow:hidden}
.blog-card__img img{width:100%;height:100%;object-fit:cover}
.blog-card__title{font-family:var(--font-title);font-size:1.5rem;letter-spacing:.1em;margin-bottom:.3rem}
.blog-card__excerpt{font-size:.82rem;color:var(--brown-light);line-height:1.6}
.blog-card__date{font-size:.7rem;color:var(--mauve);margin-top:.4rem}
/* BLOG SINGLE */
.article-hero{position:relative;min-height:50vh;display:flex;align-items:flex-end;overflow:hidden;padding:var(--section-py) var(--gap)}
.article-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.45)}
.article-hero__content{position:relative;z-index:2;max-width:800px;margin:0 auto;width:100%}
.article-hero h1{font-size:clamp(2rem,5vw,3.5rem);color:var(--white);letter-spacing:.15em}
.article-hero__date{font-size:.8rem;color:rgba(255,255,255,.7);margin-top:.5rem}
.article-body{background:var(--beige);padding:var(--section-py) var(--gap)}
.article-body__inner{max-width:700px;margin:0 auto;font-size:1rem;line-height:1.9}
.article-body__inner p{margin-bottom:1.2rem}
.article-body__inner img{border-radius:4px;margin:1.5rem 0}
/* GALLERY */
.gallery-hero{background:var(--black);padding:clamp(6rem,12vw,9rem) var(--gap) var(--section-py);text-align:center;color:var(--white)}
.gallery-hero h1{font-size:clamp(2.5rem,6vw,4rem);letter-spacing:.15em}
.gallery-list{background:var(--beige);padding:var(--section-py) var(--gap)}
.gallery-list__inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.gallery-thumb{border-radius:6px;overflow:hidden;position:relative}
.gallery-thumb img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s}
.gallery-thumb:hover img{transform:scale(1.05)}
.gallery-thumb__label{position:absolute;bottom:0;left:0;right:0;padding:.8rem 1rem;background:linear-gradient(transparent,rgba(0,0,0,.7));color:var(--white);font-family:var(--font-title);font-size:1.1rem;letter-spacing:.1em}
.photo-grid{background:var(--beige);padding:var(--section-py) var(--gap)}
.photo-grid__inner{max-width:1000px;margin:0 auto;columns:3;column-gap:1rem}
.photo-grid__item{break-inside:avoid;margin-bottom:1rem;border-radius:4px;overflow:hidden}
.photo-grid__item img{width:100%;display:block}
.photo-grid__caption{font-size:.75rem;color:var(--brown-light);padding:.4rem 0}
/* PAGINATION PUBLIC */
.pagination{display:flex;gap:.3rem;justify-content:center;margin-top:2rem}
.pagination a{padding:.4rem .8rem;border:1px solid rgba(61,48,40,.15);border-radius:3px;font-size:.75rem;color:var(--brown-light)}
.pagination a:hover,.pagination a.active{background:var(--brown);color:var(--white);border-color:var(--brown)}
@media(max-width:900px){
.blog-card{grid-template-columns:1fr}
.photo-grid__inner{columns:2}
}
@media(max-width:600px){
.photo-grid__inner{columns:1}
}
