/* =====================================================
   CASA CULTIVA v6
   ===================================================== */

:root {
  --cream:      #FBF8F2;
  --cream-2:    #F4EFE4;
  --cream-3:    #EDE5D5;
  --white:      #FFFFFF;

  --green:      #4A7C4E;
  --green-d:    #355438;
  --green-l:    #EBF2E8;
  --green-m:    #C8DEC4;

  --terra:      #C8623F;
  --terra-d:    #A84E2E;
  --terra-l:    #F9EDE7;
  --terra-m:    #EEC4B0;

  --ink:        #252220;
  --ink-2:      #524F4A;
  --ink-3:      #948F89;

  --ff-serif: 'Playfair Display', Georgia, serif;
  --ff-sans:  'Inter', system-ui, sans-serif;

  --nav-h: 72px;
  --ease: cubic-bezier(.4,0,.2,1);
  --r: 16px;
  --r-lg: 24px;
  --r-xl: 32px;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff-sans);font-size:1rem;color:var(--ink);
  background:var(--cream);line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
address{font-style:normal}
input,textarea,select{font:inherit}

/* LAYOUT */
.wrap{width:min(1140px,100% - 2.5rem);margin-inline:auto}
.section{padding-block:clamp(4rem,8vw,7rem)}

/* TYPOGRAPHY */
.heading{
  font-family:var(--ff-serif);
  font-size:clamp(2rem,3.8vw,3.25rem);
  font-weight:500;line-height:1.15;
  letter-spacing:-.02em;color:var(--ink);
}
.heading em{font-style:italic;color:var(--terra)}
.heading--center{text-align:center}

/* CHIP */
.chip{
  display:inline-block;
  padding:.35rem 1rem;border-radius:100px;
  font-size:.72rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;margin-bottom:1.25rem;
}
.chip--green{background:var(--green-l);color:var(--green-d)}
.chip--terra{background:var(--terra-l);color:var(--terra-d)}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.8rem 1.75rem;border-radius:100px;
  font-family:var(--ff-sans);font-size:.875rem;font-weight:500;
  transition:.22s var(--ease);white-space:nowrap;cursor:pointer;
  border:none;
}
.btn--terra{background:var(--terra);color:var(--white)}
.btn--terra:hover{background:var(--terra-d);transform:translateY(-2px);box-shadow:0 8px 24px rgba(200,98,63,.3)}
.btn--green{background:var(--green);color:var(--white)}
.btn--green:hover{background:var(--green-d);transform:translateY(-2px);box-shadow:0 8px 24px rgba(74,124,78,.28)}
.btn--outline{background:transparent;color:var(--green);border:1.5px solid var(--green)}
.btn--outline:hover{background:var(--green);color:var(--white)}
.btn--lg{padding:1rem 2rem;font-size:.9rem}
.btn--full{width:100%;justify-content:center}

/* =====================================================
   NAV
===================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:999;
  height:var(--nav-h);
  background:transparent;
  transition:background .3s,box-shadow .3s,border-color .3s;
}
.nav.scrolled,.nav.menu-open{
  background:rgba(251,248,242,.97);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--cream-2);
  box-shadow:0 2px 20px rgba(0,0,0,.06);
}

.nav__inner{
  display:flex;align-items:center;gap:2rem;
  height:100%;
  width:min(1140px,100% - 2.5rem);margin-inline:auto;
}

.nav__brand{display:flex;align-items:center;flex-shrink:0}
.nav__logo-img{height:56px;width:auto;object-fit:contain}
.nav__logo--dark{display:none}
.nav.scrolled .nav__logo--white,.nav.menu-open .nav__logo--white{display:none}
.nav.scrolled .nav__logo--dark,.nav.menu-open .nav__logo--dark{display:block}

.nav__links{display:flex;gap:1.75rem;margin-left:auto}
.nav__links a{
  font-size:.84rem;font-weight:400;
  color:rgba(255,255,255,.85);transition:color .2s;
}
.nav__links a:hover{color:var(--white)}
.nav.scrolled .nav__links a,.nav.menu-open .nav__links a{color:var(--ink-2)}
.nav.scrolled .nav__links a:hover,.nav.menu-open .nav__links a:hover{color:var(--green)}

.nav__cta{
  flex-shrink:0;
  padding:.55rem 1.35rem;background:var(--terra);color:var(--white);
  border-radius:100px;font-size:.8rem;font-weight:500;
  transition:.2s;
}
.nav__cta:hover{background:var(--terra-d)}

.nav__burger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:4px;width:28px;height:28px;
  margin-left:auto;flex-shrink:0;
  padding:0;overflow:visible;background:none;border:none;cursor:pointer;
}
.nav__burger span{
  display:block;width:16px;height:2px;
  background:var(--white);border-radius:2px;
  transition:.3s var(--ease);transform-origin:center;
}
.nav.scrolled .nav__burger span,.nav.menu-open .nav__burger span{background:var(--ink)}
.nav__burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav__burger.open span:nth-child(2){transform:translateY(-6px) rotate(-45deg)}

.nav__mobile{
  display:none;
}
.nav__mobile-close{
  display:none;
  align-self:flex-end;
  background:none;border:none;cursor:pointer;
  font-size:1.75rem;line-height:1;color:var(--ink);
  padding:.25rem .5rem;margin-bottom:1rem;
}
.nav__m-link{
  font-family:var(--ff-serif);font-size:2rem;font-weight:400;
  color:var(--ink);padding:.45rem 0;
  border-bottom:1px solid var(--cream-2);
}
.nav__m-link:hover{color:var(--green)}
.nav__mobile .btn{margin-top:1.5rem}

/* =====================================================
   HERO - Overlay
===================================================== */
.hero{
  position:relative;
  min-height:100svh;
  padding-top:var(--nav-h);
  display:flex;align-items:center;justify-content:center;
  background:url('../images/header.jpg') center/cover no-repeat;
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(20,30,20,.78) 0%,rgba(30,41,26,.68) 100%);
  z-index:0;
}
.hero__left{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  padding:clamp(3rem,6vw,5rem) clamp(1.5rem,5vw,3rem);
  width:100%;
}
.hero__left-inner{max-width:760px;width:100%;}
.hero__right{display:none;}

.hero__sup{
  font-size:.7rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.6);
  margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;gap:.75rem;
}
.hero__sup::before{
  content:'';display:block;width:28px;height:1.5px;
  background:var(--terra);border-radius:1px;flex-shrink:0;
}

.hero__title{
  font-family:var(--ff-serif);
  font-size:clamp(2.8rem,5.5vw,5rem);
  font-weight:400;line-height:1.08;letter-spacing:-.025em;
  color:var(--white);margin-bottom:1.5rem;
}
.hero__title em{font-style:italic;color:var(--terra-m)}

.hero__desc{
  font-size:1.05rem;color:rgba(255,255,255,.82);
  line-height:1.85;margin-bottom:2rem;max-width:560px;margin-inline:auto;
}

.hero__btns{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.5rem}
.hero .btn--outline{color:var(--white);border-color:rgba(255,255,255,.5);}
.hero .btn--outline:hover{background:rgba(255,255,255,.15);border-color:var(--white);}

.hero__tag{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.12);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.2);
  padding:.55rem 1.25rem;border-radius:100px;
  font-size:.78rem;color:rgba(255,255,255,.8);font-weight:500;
  white-space:nowrap;
}
.hero__tag svg{color:var(--terra-m);flex-shrink:0}

/* =====================================================
   TICKER
===================================================== */
.ticker{background:var(--terra);padding-block:.8rem;overflow:hidden}
.ticker__track{
  display:flex;gap:1.5rem;white-space:nowrap;
  animation:tick 28s linear infinite;
  font-size:.7rem;font-weight:600;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(255,255,255,.7);
}
.ticker__track .sep{opacity:.4}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker__track{animation:none}}

/* =====================================================
   SOBRE
===================================================== */
.sobre{background:var(--white)}
.sobre__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,6vw,6rem);align-items:center;
}
.sobre__img-col{position:relative}
.sobre__img-main{
  border-radius:var(--r-xl);overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:0 20px 60px rgba(0,0,0,.1);
  background:linear-gradient(135deg,var(--green-m),var(--green-l));
}
.sobre__img-main img{width:100%;height:100%;object-fit:cover}

.sobre__text .heading{margin-block:.25rem 1.5rem}
.sobre__text p{color:var(--ink-2);line-height:1.85;margin-bottom:1rem}
.sobre__text p:last-of-type{margin-bottom:1.75rem}

.sobre__nums{
  display:flex;gap:2rem;padding:1.5rem 0;
  border-top:1px solid var(--cream-2);border-bottom:1px solid var(--cream-2);
  margin-bottom:2rem;flex-wrap:wrap;
}
.sobre__num strong{
  display:block;font-family:var(--ff-serif);
  font-size:2.25rem;font-weight:400;color:var(--green);line-height:1;
}
.sobre__num span{font-size:.8rem;color:var(--ink-3);margin-top:.2rem;display:block}

/* =====================================================
   VALORES
===================================================== */
.valores{background:var(--cream-2)}
.valores__header{
  text-align:center;max-width:600px;
  margin:0 auto clamp(2.5rem,4vw,4rem);
}
.valores__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;
}
.vcard{
  background:var(--white);border-radius:var(--r-lg);
  padding:2rem 1.75rem;
  border:1px solid transparent;
  transition:.25s var(--ease);
}
.vcard:hover{
  border-color:var(--green-m);
  transform:translateY(-3px);
  box-shadow:0 10px 35px rgba(74,124,78,.1);
}
.vcard__icon{
  width:44px;height:44px;border-radius:12px;
  background:var(--green-l);color:var(--green);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;transition:.25s;
}
.vcard:hover .vcard__icon{background:var(--green);color:var(--white)}
.vcard h3{
  font-family:var(--ff-serif);font-size:1.2rem;font-weight:500;
  margin-bottom:.5rem;color:var(--ink);
}
.vcard p{font-size:.875rem;color:var(--ink-2);line-height:1.75}

/* =====================================================
   PARA QUEM
===================================================== */
.paraquem{background:var(--white)}
.paraquem__header{
  text-align:center;max-width:580px;
  margin:0 auto clamp(2.5rem,4vw,4rem);
}
.paraquem__cards{
  display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;
}
.pcard{
  border-radius:var(--r-xl);padding:2.75rem;
  display:flex;flex-direction:column;
}
.pcard--pro{background:var(--green);box-shadow:0 16px 50px rgba(74,124,78,.25)}
.pcard--pac{background:var(--white);border:1.5px solid var(--cream-3);box-shadow:0 8px 30px rgba(0,0,0,.05)}

.pcard__tag{
  font-size:.7rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;margin-bottom:1.25rem;
}
.pcard--pro .pcard__tag{color:rgba(255,255,255,.5)}
.pcard--pac .pcard__tag{color:var(--ink-3)}

.pcard h3{
  font-family:var(--ff-serif);font-size:1.75rem;font-weight:500;
  line-height:1.2;margin-bottom:1rem;
}
.pcard--pro h3{color:var(--white)}
.pcard--pac h3{color:var(--ink)}

.pcard > p{font-size:.9rem;line-height:1.8;margin-bottom:1.5rem;flex:1}
.pcard--pro > p{color:rgba(255,255,255,.7)}
.pcard--pac > p{color:var(--ink-2)}

.pcard ul{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.pcard ul li{display:flex;align-items:center;gap:.6rem;font-size:.875rem}
.pcard--pro ul li{color:rgba(255,255,255,.8)}
.pcard--pro ul li svg{color:rgba(255,255,255,.5);flex-shrink:0}
.pcard--pac ul li{color:var(--ink-2)}
.pcard--pac ul li svg{color:var(--green);flex-shrink:0}

/* =====================================================
   ESPACOS - bento editorial
===================================================== */
.espacos{background:var(--cream-2)}
.espacos__header{margin-bottom:clamp(2rem,4vw,3rem)}
.espacos__header .heading{margin-block:.25rem 1rem}
.espacos__lead{font-size:1rem;color:var(--ink-2);max-width:560px;line-height:1.8}

.espacos__gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-bottom:2.5rem;
  align-items:start;
}
.gal-item{
  border-radius:var(--r-lg);
  overflow:hidden;
  background:var(--green-m);
  position:relative;
}
.gal-item img{
  width:100%;height:auto;display:block;
  transition:transform .6s var(--ease);
}
.gal-item::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(37,34,32,0);
  transition:background .35s;
  pointer-events:none;
}
.gal-item:hover img{transform:scale(1.05)}
.gal-item:hover::after{background:rgba(37,34,32,.08)}

.espacos__cta{text-align:center}

/* =====================================================
   EQUIPE
===================================================== */
.equipe{background:var(--white)}
.equipe__header{
  text-align:center;max-width:580px;
  margin:0 auto clamp(2rem,4vw,3rem);
}
.equipe__foto{
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:0 16px 60px rgba(0,0,0,.1);
  background:var(--green-l);
}
.equipe__foto img{
  width:100%;height:auto;object-fit:cover;
  display:block;
}

/* =====================================================
   GALERIA - expandir / lightbox
===================================================== */
.gal-extra{display:none}
.gal-extra.show{display:block}
.gal-item{cursor:pointer}
.gal-expand{text-align:center;margin-bottom:2.5rem}
.gal-expand .btn{display:inline-flex;align-items:center;gap:.5rem}
.gal-expand .btn svg{transition:transform .3s}
.gal-expand .btn.expanded svg{transform:rotate(180deg)}

/* =====================================================
   LIGHTBOX
===================================================== */
.lightbox{
  position:fixed;inset:0;z-index:9000;
  background:rgba(20,18,16,.94);
  display:none;align-items:center;justify-content:center;
}
.lightbox.open{display:flex}
.lb__img-wrap{
  max-width:min(90vw,900px);max-height:90vh;
  display:flex;align-items:center;justify-content:center;
}
.lb__img{
  max-width:100%;max-height:90vh;
  object-fit:contain;border-radius:var(--r);
  box-shadow:0 24px 80px rgba(0,0,0,.5);
}
.lb__close{
  position:fixed;top:1.25rem;right:1.5rem;
  font-size:2rem;line-height:1;color:#fff;
  background:rgba(255,255,255,.12);border:none;
  width:44px;height:44px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.lb__close:hover{background:rgba(255,255,255,.25)}
.lb__nav{
  position:fixed;top:50%;transform:translateY(-50%);
  font-size:2.5rem;line-height:1;color:#fff;
  background:rgba(255,255,255,.1);border:none;
  width:52px;height:52px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.lb__nav:hover{background:rgba(255,255,255,.25)}
.lb__prev{left:1rem}
.lb__next{right:1rem}
.lb__counter{
  position:fixed;bottom:1.25rem;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.7);font-size:.85rem;font-family:var(--ff-sans);
  background:rgba(0,0,0,.4);padding:.25rem .75rem;border-radius:999px;
}

/* =====================================================
   CONHEÇA A CASA - Carrossel
===================================================== */
.conheca{background:var(--cream-2)}
.conheca__header{text-align:center;margin-bottom:2.5rem}
.conheca__header .heading{margin-block:.25rem .5rem}

/* foto grid */
.conheca__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-bottom:3rem;
}
.conheca__item{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4;cursor:pointer}
.conheca__item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease)}
.conheca__item:hover img{transform:scale(1.04)}
.conheca__legend{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(20,30,20,.8) 0%,transparent 100%);
  color:var(--white);
  font-family:var(--ff-serif);font-size:.9rem;line-height:1.3;
  padding:2.5rem .85rem .85rem;
}
@media(max-width:768px){
  .conheca__grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .conheca__grid{grid-template-columns:1fr}
}

.carousel{position:relative;border-radius:var(--r-xl);overflow:hidden;user-select:none}
.carousel__track{display:flex;transition:transform .45s var(--ease)}
.carousel__slide{min-width:100%;position:relative;flex-shrink:0;aspect-ratio:16/9}
.carousel__slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.carousel__caption{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(20,30,20,.82) 0%,rgba(20,30,20,.3) 60%,transparent 100%);
  color:var(--white);
  padding:3.5rem 2rem 1.75rem;
  font-family:var(--ff-serif);font-size:1.35rem;line-height:1.35;
}

.carousel__btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.88);backdrop-filter:blur(6px);
  border:none;cursor:pointer;
  width:44px;height:44px;border-radius:50%;
  font-size:1.4rem;line-height:1;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:.2s;box-shadow:0 2px 12px rgba(0,0,0,.15);
}
.carousel__btn:hover{background:var(--white)}
.carousel__prev{left:1rem}
.carousel__next{right:1rem}

.carousel__dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.25rem}
.carousel__dot{
  width:8px;height:8px;border-radius:100px;
  background:var(--cream-3);cursor:pointer;
  transition:background .25s,width .25s;border:none;padding:0;
}
.carousel__dot.active{background:var(--terra);width:24px}

.conheca__cta{
  text-align:center;
  margin-top:3rem;padding-top:3rem;
  border-top:1px solid var(--cream-3);
}
.conheca__cta-title{
  font-family:var(--ff-serif);
  font-size:clamp(1.75rem,3vw,2.25rem);
  font-weight:400;color:var(--ink);
  margin-bottom:.75rem;
}
.conheca__cta-title em{font-style:italic;color:var(--terra)}
.conheca__cta p{color:var(--ink-2);margin-bottom:1.75rem;font-size:1rem;line-height:1.7}

/* =====================================================
   INSTAGRAM - split: texto esquerda, fotos direita
===================================================== */
.instagram{background:var(--cream-2);padding-block:0;overflow:hidden}
.insta__grid{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:480px;
  max-width:1200px;margin:0 auto;
  gap:clamp(2rem,5vw,4rem);
  padding:clamp(3rem,6vw,5rem) clamp(1.5rem,5vw,4rem);
}
.insta__texto{
  display:flex;flex-direction:column;justify-content:center;
}
.insta__texto .heading{margin-block:.25rem 1rem}
.insta__texto p{color:var(--ink-2);line-height:1.85;margin-bottom:2rem;max-width:380px}
.insta__fotos{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:8px;align-content:start;
}
.insta__foto{
  aspect-ratio:1;overflow:hidden;
  background:var(--green-m);display:block;
}
.insta__foto img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);display:block}
.insta__foto:hover img{transform:scale(1.07)}

/* =====================================================
   COMUNIDADE - sticky esquerda
===================================================== */
.comunidade{background:var(--white)}
.comunidade__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,6vw,6rem);
  align-items:start;
}
.comunidade__grid--reversed .comunidade__beneficios{order:1}
.comunidade__grid--reversed .comunidade__sticky{order:2}
.comunidade__sticky{
  position:sticky;
  top:calc(var(--nav-h) + 2rem);
}
.comunidade__text .heading{margin-block:.25rem 1.25rem}
.comunidade__text p{color:var(--ink-2);line-height:1.85;margin-bottom:2rem}

.comunidade__beneficios{display:flex;flex-direction:column}
.beneficio{
  display:flex;align-items:flex-start;gap:1.25rem;
  padding:1.5rem 0;
  border-bottom:1px solid var(--cream-2);
}
.beneficio:last-child{border-bottom:none}
.beneficio__n{
  font-family:var(--ff-serif);font-size:1.5rem;font-weight:400;
  color:var(--terra-m);line-height:1;flex-shrink:0;
  width:36px;text-align:center;transition:color .25s;
}
.beneficio:hover .beneficio__n{color:var(--terra)}
.beneficio h4{
  font-family:var(--ff-serif);font-size:1.1rem;font-weight:500;
  margin-bottom:.3rem;color:var(--ink);
}
.beneficio p{font-size:.875rem;color:var(--ink-2);line-height:1.75}

/* =====================================================
   CONTATO
===================================================== */
.contato{background:var(--cream-2)}
.contato__header{
  text-align:center;max-width:560px;
  margin:0 auto clamp(2.5rem,4vw,4rem);
}
.contato__header .heading{margin-block:.25rem .75rem}
.contato__header p{font-size:1rem;color:var(--ink-2);line-height:1.8}

.contato__grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2rem,4vw,4rem);align-items:start;
}

.form-card{
  background:var(--white);border-radius:var(--r-xl);
  padding:2.5rem 2.25rem;
  box-shadow:0 8px 40px rgba(0,0,0,.06);
}
.form-card h3{font-family:var(--ff-serif);font-size:1.65rem;font-weight:500;margin-bottom:.3rem}
.form-card__sub{font-size:.875rem;color:var(--ink-3);margin-bottom:1.75rem}

.fg{margin-bottom:1.2rem}
.fl{
  display:block;font-size:.72rem;font-weight:600;
  letter-spacing:.07em;text-transform:uppercase;
  color:var(--ink);margin-bottom:.35rem;
}
.fl span{color:var(--terra)}
.fi{
  width:100%;padding:.75rem 1rem;
  border:1.5px solid var(--cream-3);border-radius:var(--r);
  font-size:.9rem;color:var(--ink);background:var(--cream);
  outline:none;appearance:none;
  transition:border-color .2s,box-shadow .2s;
}
.fi::placeholder{color:var(--ink-3)}
.fi:focus{border-color:var(--green);background:var(--white);box-shadow:0 0 0 3px rgba(74,124,78,.1)}
.fi.err{border-color:#C0392B;box-shadow:0 0 0 3px rgba(192,57,43,.08)}
.form-textarea{resize:vertical;min-height:100px}
.fe{font-size:.74rem;color:#C0392B;display:block;margin-top:.25rem;min-height:1rem}
.form-privacy{font-size:.74rem;color:var(--ink-3);text-align:center;margin-top:.75rem}

.info-card{
  background:var(--white);border-radius:var(--r-xl);
  padding:2.25rem;
  box-shadow:0 8px 40px rgba(0,0,0,.06);
  margin-bottom:1.25rem;
}
.info-card h3{font-family:var(--ff-serif);font-size:1.65rem;font-weight:500;margin-bottom:1.5rem}
.info-item{
  display:flex;align-items:flex-start;gap:1rem;
  padding:.9rem 0;border-bottom:1px solid var(--cream-2);
}
.info-item:last-child{border-bottom:none}
.info-item--link{transition:.2s;cursor:pointer}
.info-item--link:hover .info-icon{background:var(--green-m)}
.info-icon{
  width:40px;height:40px;border-radius:10px;
  background:var(--cream-2);color:var(--ink-2);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:.2s;
}
.info-icon--green{background:var(--green-l);color:var(--green)}
.info-item strong{display:block;font-size:.8rem;font-weight:600;margin-bottom:.2rem}
.info-item span{font-size:.875rem;color:var(--ink-2);line-height:1.6}

.mapa-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.07)}
.mapa-wrap iframe{display:block}
.mapa-foot{
  background:var(--white);padding:.9rem 1.25rem;
  font-size:.8rem;color:var(--ink-2);
  display:flex;align-items:center;gap:.5rem;
  border-top:1px solid var(--cream-2);
}
.mapa-foot svg{color:var(--terra);flex-shrink:0}

/* =====================================================
   FOOTER
===================================================== */
.footer{background:var(--ink);padding-block:4.5rem 1.75rem}
.footer__grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;padding-bottom:3rem;
  border-bottom:1px solid rgba(255,255,255,.07);
  margin-bottom:2rem;
}
.footer__logo-img-wrap{display:block;margin-bottom:1.25rem}
.footer__logo-img{
  height:60px;width:auto;object-fit:contain;
  opacity:.9;
}
.footer__brand p{font-size:.875rem;color:rgba(255,255,255,.45);line-height:1.75;margin-bottom:1.25rem}
.footer__wa{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.84rem;color:rgba(255,255,255,.5);transition:.2s;
}
.footer__wa:hover{color:var(--white)}

.footer__nav{display:flex;flex-direction:column;gap:.6rem}
.footer__nav h4{
  font-size:.68rem;font-weight:600;letter-spacing:.13em;
  text-transform:uppercase;color:rgba(255,255,255,.28);
  margin-bottom:.4rem;
}
.footer__nav a,.footer__nav address{
  font-size:.875rem;color:rgba(255,255,255,.45);
  line-height:1.7;transition:.2s;
}
.footer__nav a:hover{color:var(--white)}

.footer__bottom{
  display:flex;justify-content:space-between;
  align-items:center;gap:1rem;flex-wrap:wrap;
}
.footer__bottom p{font-size:.78rem;color:rgba(255,255,255,.28)}
.footer__bottom a{color:rgba(255,255,255,.38);transition:.2s}
.footer__bottom a:hover{color:var(--white)}

/* WA float */
.wa-float{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:90;
  width:52px;height:52px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--white);box-shadow:0 4px 18px rgba(37,211,102,.4);
  transition:.25s;
}
.wa-float:hover{transform:scale(1.1);box-shadow:0 8px 28px rgba(37,211,102,.5)}

/* =====================================================
   REVEAL ANIMATIONS
===================================================== */
[data-reveal]{
  opacity:0;
  transition:opacity .65s var(--ease),transform .65s var(--ease);
}
[data-reveal="up"]{transform:translateY(28px)}
[data-reveal="left"]{transform:translateX(-28px)}
[data-reveal="right"]{transform:translateX(28px)}
[data-reveal].visible{opacity:1;transform:none}
[data-delay="0"]{transition-delay:0s}
[data-delay="100"]{transition-delay:.1s}
[data-delay="200"]{transition-delay:.2s}
[data-delay="300"]{transition-delay:.3s}
[data-delay="400"]{transition-delay:.4s}
[data-delay="500"]{transition-delay:.5s}

/* =====================================================
   RESPONSIVE
===================================================== */
@media(max-width:1024px){
  .footer__grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  .footer__brand{grid-column:1/-1}
  .espacos__gallery{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:860px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__mobile{
    display:flex;flex-direction:column;
    position:fixed;top:0;left:0;width:100%;height:100vh;
    background:var(--white);
    padding:calc(var(--nav-h) + 2rem) 1.5rem 2.5rem;
    transform:translateX(100%);
    transition:transform .35s var(--ease);
    z-index:998;overflow-y:auto;
  }
  .nav__mobile.open{transform:translateX(0)}
  .nav__mobile-close{display:block}

  /* hero overlay mobile */
  .hero{min-height:100svh}
  .hero__left{padding:2.5rem 1.5rem}
  .hero__left-inner{max-width:100%}
  .hero__btns{margin-bottom:2rem}

  .sobre__grid{grid-template-columns:1fr;gap:3rem}
  .valores__grid{grid-template-columns:repeat(2,1fr)}
  .paraquem__cards{grid-template-columns:1fr;gap:1.25rem}

  .espacos__gallery{grid-template-columns:repeat(3,1fr)}

  .insta__grid{grid-template-columns:1fr;gap:2rem;padding:3rem 1.5rem}
  .insta__texto p{max-width:100%}

  /* comunidade: desliga sticky no mobile */
  .comunidade__grid{grid-template-columns:1fr;gap:2.5rem}
  .comunidade__sticky{position:static;top:auto}

  .contato__grid{grid-template-columns:1fr;gap:2rem}
  .footer__grid{grid-template-columns:1fr 1fr;gap:2rem}
}

@media(max-width:600px){
  :root{--nav-h:64px}

  .hero__title{font-size:clamp(2.4rem,9vw,3rem)}
  .hero__btns{flex-direction:column}
  .hero__btns .btn{justify-content:center;width:100%}
  .hero__stats{gap:1rem}

  .valores__grid{grid-template-columns:1fr}
  .pcard{padding:2rem 1.5rem}
  .form-card{padding:1.75rem 1.5rem}

  .espacos__gallery{grid-template-columns:1fr}

  .insta__fotos{grid-template-columns:repeat(2,1fr)}

  .footer__grid{grid-template-columns:1fr;gap:2rem}
  .footer__bottom{flex-direction:column;text-align:center}
}

@media(prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none}
  .ticker__track{animation:none}
  *{transition-duration:.01ms!important}
}
