/* ============================================================
   Anahata Yoga — main stylesheet
   Mobile-first · optimized for PC + mobile
   ============================================================ */

:root{
	--sage:#6B8E7F;
	--sage-dark:#4F6E62;
	--cream:#F5EFE6;
	--cream-deep:#EDE4D3;
	--terra:#C97B5B;
	--ink:#2A2A2A;
	--muted:#7A7367;
	--line:rgba(42,42,42,.12);
	--serif:'Cormorant Garamond', Georgia, serif;
	--sans:'Inter', system-ui, sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
	font-family:var(--sans);
	font-weight:300;
	color:var(--ink);
	background:var(--cream);
	line-height:1.6;
	font-size:clamp(15px,1.6vw,17px);
	-webkit-font-smoothing:antialiased;
	-moz-osx-font-smoothing:grayscale;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

.wrap{width:100%;max-width:1240px;margin:0 auto;padding:0 1.5rem}
@media(min-width:768px){.wrap{padding:0 2.5rem}}

h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(2.5rem,7vw,5.25rem)}
h2{font-size:clamp(2rem,4.5vw,3.5rem)}
h3{font-size:clamp(1.35rem,2.2vw,1.75rem)}
.eyebrow{
	font-family:var(--sans);
	font-size:.75rem;
	letter-spacing:.22em;
	text-transform:uppercase;
	color:var(--sage-dark);
	font-weight:500;
}

/* nav */
.nav{
	position:sticky;top:0;z-index:50;
	-webkit-backdrop-filter:blur(10px);
	backdrop-filter:blur(10px);
	background:rgba(245,239,230,.85);
	border-bottom:1px solid var(--line);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{font-family:var(--serif);font-size:1.5rem;font-weight:500;letter-spacing:.02em}
.brand span{color:var(--terra);font-style:italic}
.nav__links{display:flex;gap:2.5rem;font-size:.875rem;align-items:center}
.nav__links a{position:relative;padding:.25rem 0;transition:color .2s}
.nav__links a:hover{color:var(--sage-dark)}
.nav__links-cta{display:none}
.nav__cta{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;padding:.7rem 1.3rem;border:1px solid var(--ink);border-radius:999px;transition:all .25s}
.nav__cta:hover{background:var(--ink);color:var(--cream)}

/* hamburger button (mobile only) */
.nav__burger{
	display:flex;flex-direction:column;justify-content:center;gap:5px;
	width:40px;height:40px;padding:0;
	background:transparent;border:none;cursor:pointer;
	margin-left:.5rem;z-index:60;position:relative;
}
.nav__burger span{
	display:block;width:24px;height:1.5px;
	background:var(--ink);margin:0 auto;
	transition:transform .3s, opacity .3s;
}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile menu overlay (under 900px) */
@media(max-width:899px){
	.nav__cta{display:none}
	.nav__links{
		position:fixed;left:0;right:0;top:72px;
		height:calc(100vh - 72px);
		height:calc(100dvh - 72px);
		flex-direction:column;justify-content:flex-start;align-items:center;
		gap:1.25rem;
		background:var(--cream);
		padding:3rem 1.5rem 4rem;
		font-family:var(--serif);
		font-size:1.5rem;
		transform:translateX(100%);
		transition:transform .35s cubic-bezier(.22,1,.36,1);
		visibility:hidden;
		overflow-y:auto;
		-webkit-overflow-scrolling:touch;
	}
	.nav__links.is-open{transform:translateX(0);visibility:visible}
	.nav__links a{font-weight:500;color:var(--ink);padding:.35rem 0;line-height:1.2}
	.nav__links a.nav__links-cta,
	a.nav__links-cta{
		display:inline-flex;align-items:center;justify-content:center;
		margin-top:1.25rem;font-family:var(--sans);font-size:.85rem;
		letter-spacing:.08em;text-transform:uppercase;font-weight:500;
		padding:1rem 1.75rem;border-radius:999px;
		background:var(--ink);color:var(--cream)!important;
		min-height:48px;white-space:nowrap;
	}
}
@media(min-width:900px){
	.nav__burger{display:none}
}

/* hero */
.hero{position:relative;padding:3rem 0 4rem}
@media(min-width:900px){.hero{padding:5rem 0 6rem}}
.hero__grid{display:grid;gap:2.5rem;align-items:center}
@media(min-width:900px){.hero__grid{grid-template-columns:1fr 1.1fr;gap:4rem}}
.hero__title{margin:1.25rem 0 1.5rem}
.hero__title em{font-style:italic;color:var(--sage-dark)}
.hero__lead{font-size:clamp(1.05rem,1.6vw,1.2rem);color:var(--muted);max-width:42ch;margin-bottom:2rem}
.hero__ctas{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.btn{
	display:inline-flex;align-items:center;gap:.6rem;
	padding:1rem 1.75rem;border-radius:999px;
	font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;
	font-weight:500;transition:transform .25s, background .25s, color .25s;
}
.btn--primary{background:var(--ink);color:var(--cream)}
.btn--primary:hover{background:var(--sage-dark);transform:translateY(-2px)}
.btn--ghost{color:var(--ink)}
.btn--ghost::after{content:"→";transition:transform .25s}
.btn--ghost:hover::after{transform:translateX(4px)}
.hero__image{
	position:relative;border-radius:8px;overflow:hidden;
	aspect-ratio:4/5;
	box-shadow:0 30px 60px -30px rgba(42,42,42,.3);
}
.hero__image img{width:100%;height:100%;object-fit:cover}
.hero__badge{
	position:absolute;left:-1rem;bottom:1.5rem;
	background:var(--cream);padding:1rem 1.25rem;border-radius:4px;
	font-family:var(--serif);font-style:italic;font-size:1.05rem;
	box-shadow:0 10px 30px -10px rgba(42,42,42,.2);
	max-width:220px;
}
.hero__badge strong{display:block;font-family:var(--sans);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--terra);font-weight:600;margin-bottom:.35rem;font-style:normal}

/* sections */
section{padding:5rem 0}
@media(min-width:900px){section{padding:7rem 0}}
.section__head{max-width:600px;margin-bottom:3.5rem}
.section__head .eyebrow{display:block;margin-bottom:1rem}

/* manifesto */
.manifesto{background:var(--cream-deep)}
.manifesto__grid{display:grid;gap:3rem;align-items:center}
@media(min-width:900px){.manifesto__grid{grid-template-columns:1.4fr 1fr;gap:5rem}}
.manifesto__figure{border-radius:6px;overflow:hidden;aspect-ratio:1;box-shadow:0 20px 50px -25px rgba(42,42,42,.25)}
.manifesto__figure img{width:100%;height:100%;object-fit:cover}
.manifesto__text{
	font-family:var(--serif);
	font-size:clamp(1.5rem,3vw,2.25rem);
	line-height:1.4;
	max-width:880px;
	font-weight:400;
}
.manifesto__text em{font-style:italic;color:var(--sage-dark)}
.manifesto__sig{margin-top:2.5rem;font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}

/* clases */
.classes__grid{display:grid;gap:1.5rem}
@media(min-width:700px){.classes__grid{grid-template-columns:repeat(3,1fr)}}
.class-card{
	background:#fff;border-radius:6px;padding:2.25rem;
	border:1px solid var(--line);
	transition:transform .3s, box-shadow .3s;
	display:flex;flex-direction:column;height:100%;
}
.class-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(42,42,42,.15)}
.class-card__num{font-family:var(--serif);font-style:italic;color:var(--terra);font-size:1.5rem;margin-bottom:1.5rem}
.class-card__title{margin-bottom:.75rem}
.class-card__desc{color:var(--muted);margin-bottom:1.5rem;flex:1}
.class-card__meta{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage-dark);padding-top:1.25rem;border-top:1px solid var(--line)}

/* horarios */
.schedule{background:var(--ink);color:var(--cream)}
.schedule .eyebrow{color:var(--terra)}
.schedule h2{color:var(--cream)}
.schedule__table{
	width:100%;border-collapse:collapse;
	font-size:.92rem;margin-top:1rem;
}
.schedule__table th,.schedule__table td{
	padding:1.1rem .8rem;text-align:left;
	border-bottom:1px solid rgba(245,239,230,.12);
}
.schedule__table th{
	font-family:var(--serif);font-weight:500;
	font-size:1.1rem;color:var(--terra);
	font-style:italic;
}
.schedule__table td:first-child{font-weight:500}
.schedule__table td .tag{
	display:inline-block;font-size:.7rem;letter-spacing:.1em;
	text-transform:uppercase;color:rgba(245,239,230,.6);
	margin-top:.15rem;
}
.schedule__wrap{overflow-x:auto;margin:0 -1.5rem;padding:0 1.5rem;-webkit-overflow-scrolling:touch}
@media(min-width:768px){.schedule__wrap{margin:0;padding:0}}

/* instructoras */
.team__grid{display:grid;gap:2rem;margin-top:1rem}
@media(min-width:700px){.team__grid{grid-template-columns:repeat(2,1fr);gap:3rem}}
.teacher{display:grid;grid-template-columns:120px 1fr;gap:1.5rem;align-items:start}
@media(min-width:500px){.teacher{grid-template-columns:160px 1fr;gap:2rem}}
.teacher__photo{
	aspect-ratio:1;border-radius:50%;overflow:hidden;
	background:var(--cream-deep);
}
.teacher__photo img{width:100%;height:100%;object-fit:cover}
.teacher__photo--placeholder{
	background:var(--terra);
	display:flex;align-items:center;justify-content:center;
	font-family:var(--serif);font-size:2.5rem;color:var(--cream);font-style:italic;
}
.teacher__name{font-family:var(--serif);font-size:1.4rem;margin-bottom:.25rem}
.teacher__role{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--terra);margin-bottom:.85rem}
.teacher__bio{color:var(--muted);font-size:.92rem}

/* community banner */
.community{padding:0;position:relative}
.community__image{position:relative;height:clamp(360px,55vh,560px);overflow:hidden}
.community__image img{width:100%;height:100%;object-fit:cover}
.community__overlay{
	position:absolute;inset:0;
	display:flex;flex-direction:column;justify-content:flex-end;
	padding:2.5rem 1.5rem;
	background:linear-gradient(to top,rgba(42,42,42,.65) 0%,rgba(42,42,42,.15) 50%,transparent 100%);
	color:var(--cream);
}
@media(min-width:768px){.community__overlay{padding:3.5rem 4rem}}
.community__overlay .eyebrow{color:var(--cream-deep);margin-bottom:.75rem}
.community__text{font-family:var(--serif);font-size:clamp(1.5rem,3.5vw,2.5rem);max-width:600px;line-height:1.2;font-style:italic}

/* testimonios */
.testimonials{background:var(--sage);color:var(--cream)}
.testimonials .eyebrow{color:var(--cream-deep);opacity:.8}
.testimonials h2{color:var(--cream)}
.t-grid{display:grid;gap:2rem;margin-top:1rem}
@media(min-width:768px){.t-grid{grid-template-columns:repeat(3,1fr)}}
.t-card{padding:.5rem 0}
.t-card__text{
	font-family:var(--serif);font-style:italic;
	font-size:1.2rem;line-height:1.55;margin-bottom:1.5rem;
}
.t-card__text::before{content:"“";font-size:3rem;line-height:.5;display:inline-block;vertical-align:-.3em;margin-right:.15em;color:var(--cream-deep);opacity:.5}
.t-card__name{font-size:.85rem;letter-spacing:.1em;font-weight:500}
.t-card__meta{font-size:.75rem;opacity:.7;margin-top:.2rem}

/* cta final */
.final{
	background:var(--cream-deep);
	text-align:center;
	position:relative;overflow:hidden;
}
.final__inner{max-width:680px;margin:0 auto;position:relative;z-index:2}
.final h2{margin:1rem 0 1.25rem}
.final p{color:var(--muted);font-size:1.1rem;margin-bottom:2.5rem;max-width:520px;margin-left:auto;margin-right:auto}

/* footer */
.footer{background:var(--ink);color:rgba(245,239,230,.7);padding:4rem 0 2rem;font-size:.88rem}
.footer__grid{display:grid;gap:2.5rem;margin-bottom:3rem}
@media(min-width:700px){.footer__grid{grid-template-columns:1.5fr 1fr 1fr;gap:4rem}}
.footer .brand{color:var(--cream);font-size:1.75rem;margin-bottom:1rem;display:inline-block}
.footer h4{font-family:var(--sans);font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);margin-bottom:1.25rem;font-weight:600}
.footer ul{list-style:none}
.footer li{margin-bottom:.6rem}
.footer a:hover{color:var(--cream)}
.footer__bottom{padding-top:2rem;border-top:1px solid rgba(245,239,230,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.8rem;opacity:.6}

/* reveal anim */
@media(prefers-reduced-motion:no-preference){
	.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
	.reveal.in{opacity:1;transform:none}
}

/* WP admin bar fix */
.admin-bar .nav{top:32px}
@media(max-width:782px){.admin-bar .nav{top:46px}}
