/* ===== Ideias Verdes — Grazy ===== */
@font-face{
  font-family:"Chinese Rocks";
  src:url("fonts/chinese-rocks.otf") format("opentype");
  font-weight:400;
  font-display:swap;
}
:root{
  --verde-escuro:#1B5E2E;
  --verde-escuro-2:#14492280;
  --verde:#2F8B3C;
  --verde-medio:#54A85A;
  --lima:#8DC63F;
  --lima-2:#A7CE3A;
  --lima-claro:#C6E089;
  --creme:#F4F8EC;
  --branco:#ffffff;
  --texto:#1d3322;
  --texto-suave:#4c6450;
  --sombra:0 14px 40px rgba(20,73,34,.14);
  --sombra-sm:0 6px 18px rgba(20,73,34,.10);
  --radius:22px;
  --radius-sm:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Poppins",system-ui,sans-serif;
  color:var(--texto);
  background:var(--creme);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.font-stencil{font-family:"Chinese Rocks",sans-serif;letter-spacing:.5px;text-transform:uppercase}
.font-script{font-family:"Pacifico",cursive;text-transform:none}

.container{width:min(1180px,92vw);margin-inline:auto}
.section{padding:88px 0}
.section-tight{padding:60px 0}

.eyebrow{
  font-family:"Chinese Rocks",sans-serif;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--verde);
  font-size:.82rem;
  margin-bottom:10px;
}
.title{
  font-family:"Chinese Rocks",sans-serif;
  text-transform:uppercase;
  color:var(--verde-escuro);
  line-height:1.05;
  font-size:clamp(1.9rem,4.5vw,3rem);
  letter-spacing:.5px;
}
.title .accent{
  font-family:"Pacifico",cursive;
  text-transform:none;
  color:var(--lima);
  display:inline-block;
  letter-spacing:0;
}
.subtitle{color:var(--texto-suave);max-width:620px;margin-top:14px;font-size:1.05rem}
.center{text-align:center}
.center .subtitle{margin-inline:auto}

/* ===== Botões ===== */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:"Chinese Rocks",sans-serif;
  text-transform:uppercase;letter-spacing:.6px;font-size:.92rem;
  padding:14px 26px;border-radius:50px;border:none;cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  line-height:1;
}
.btn:hover{transform:translateY(-3px)}
.btn-lima{background:var(--lima);color:var(--verde-escuro);box-shadow:0 10px 24px rgba(141,198,63,.4)}
.btn-lima:hover{background:var(--lima-2)}
.btn-escuro{background:var(--verde-escuro);color:#fff;box-shadow:0 10px 24px rgba(27,94,46,.3)}
.btn-escuro:hover{background:#16502a}
.btn-ghost{background:transparent;border:2px solid var(--verde-escuro);color:var(--verde-escuro);padding:12px 24px}
.btn-ghost:hover{background:var(--verde-escuro);color:#fff}
.btn-wa{background:#25D366;color:#fff;box-shadow:0 10px 24px rgba(37,211,102,.35)}
.btn-sm{padding:10px 18px;font-size:.8rem}

/* ===== Header ===== */
header.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(244,248,236,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(27,94,46,.10);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0;gap:18px}
.nav-logo{display:flex;align-items:center}
.nav-logo img{width:60px;height:60px;border-radius:50%;transition:transform .2s}
.nav-logo img:hover{transform:rotate(-4deg) scale(1.05)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{
  font-weight:600;font-size:.95rem;color:var(--verde-escuro);
  position:relative;padding:6px 2px;transition:color .18s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:3px;width:0;
  background:linear-gradient(90deg,var(--lima),var(--verde-medio));
  border-radius:3px;transition:width .28s ease;
}
.nav-links a:hover{color:var(--verde)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--verde-escuro)}

/* ===== Hero ===== */
.hero{
  position:relative;color:#fff;overflow:hidden;
  min-height:88vh;display:flex;align-items:center;
  background:linear-gradient(120deg,rgba(8,38,18,.90),rgba(15,62,30,.60)),
             url("assets/fundo.jpg") center/cover no-repeat;
}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,28,13,.95),rgba(8,38,18,.35) 55%,transparent)}
/* elementos de marca */
.hero-squiggle{position:absolute;top:18%;left:6%;width:130px;color:var(--lima);opacity:.85;z-index:2}
.hero-leaf{position:absolute;bottom:-30px;right:8%;width:340px;color:rgba(141,198,63,.16);z-index:1;transform:rotate(12deg)}
.hero-inner{position:relative;z-index:3;padding:90px 0;max-width:680px}
.hero .badge{
  display:inline-flex;gap:10px;align-items:center;
  background:rgba(141,198,63,.18);border:1px solid rgba(141,198,63,.55);
  color:var(--lima-claro);padding:9px 20px;border-radius:50px;
  font-size:.82rem;letter-spacing:1px;text-transform:uppercase;font-weight:700;margin-bottom:22px;
}
.hero .badge::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--lima);box-shadow:0 0 0 4px rgba(141,198,63,.3)}
.hero h1{
  font-family:"Chinese Rocks",sans-serif;text-transform:uppercase;
  font-size:clamp(2.2rem,6vw,4rem);line-height:1.02;letter-spacing:1px;
  text-shadow:0 4px 24px rgba(0,0,0,.4);
}
.hero h1 .lima{color:var(--lima)}
.hero p.lead{font-size:1.15rem;margin:20px 0 30px;max-width:520px;color:#eef6e3}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
/* selo comemorativo (carimbo de vidro) */
.hero-seal{
  position:absolute;z-index:3;right:6%;top:48%;transform:translateY(-50%) rotate(-6deg);
  width:170px;height:170px;border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  background:rgba(7,33,15,.34);backdrop-filter:blur(7px);
  border:2px solid rgba(141,198,63,.75);
  box-shadow:0 14px 40px rgba(0,0,0,.4), inset 0 0 0 7px rgba(255,255,255,.07);
  color:#fff;
}
.hero-seal .n{font-family:"Chinese Rocks",sans-serif;font-size:3.4rem;line-height:.8;color:var(--lima)}
.hero-seal .a{font-family:"Chinese Rocks",sans-serif;font-size:1.05rem;letter-spacing:5px;text-transform:uppercase;color:#fff;margin-top:-2px}
.hero-seal .c{font-size:.66rem;letter-spacing:.4px;color:#d7ecc6;max-width:118px;line-height:1.3;margin-top:7px;padding-top:7px;border-top:1px solid rgba(255,255,255,.25)}
@media(max-width:980px){.hero-seal{display:none}.hero-leaf{opacity:.1}}

/* ===== Serviços ===== */
.servicos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:42px}
.servico{
  background:#fff;border-radius:var(--radius);padding:30px 26px;
  box-shadow:var(--sombra-sm);border:1px solid rgba(27,94,46,.07);
  transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;
}
.servico::before{content:"";position:absolute;top:0;left:0;width:6px;height:100%;background:var(--lima);transform:scaleY(0);transform-origin:top;transition:transform .25s}
.servico:hover{transform:translateY(-6px);box-shadow:var(--sombra)}
.servico:hover::before{transform:scaleY(1)}
.servico .ico{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,#eef6e3,#d6ecc4);margin-bottom:18px;color:var(--verde);transition:background .25s,color .25s}
.servico .ico svg{width:30px;height:30px}
.servico:hover .ico{background:linear-gradient(135deg,var(--verde-escuro),var(--verde));color:#fff}
.servico h3{font-family:"Chinese Rocks",sans-serif;text-transform:uppercase;color:var(--verde-escuro);font-size:1.15rem;letter-spacing:.5px;margin-bottom:8px}
.servico p{color:var(--texto-suave);font-size:.95rem}

/* ===== Sobre ===== */
.sobre{background:#fff}
.sobre-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:54px;align-items:center}
.sobre-foto{position:relative}
.sobre-foto .sobre-pic{border-radius:var(--radius);box-shadow:var(--sombra);width:100%;object-fit:cover;aspect-ratio:4/5}
.sobre-foto .sobre-logo{
  position:absolute;top:-34px;left:-34px;width:188px;height:188px;border-radius:50%;
  background:transparent;aspect-ratio:auto;z-index:2;
  animation:logo-float 5s ease-in-out infinite, logo-glow 3.4s ease-in-out infinite;
}
@keyframes logo-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes logo-glow{
  0%,100%{box-shadow:0 16px 40px rgba(20,73,34,.42), 0 0 0 4px rgba(141,198,63,.4)}
  50%{box-shadow:0 22px 50px rgba(20,73,34,.5), 0 0 0 14px rgba(141,198,63,.05)}
}
@media(max-width:680px){.sobre-foto .sobre-logo{width:132px;height:132px;top:-22px;left:-22px}}
.sobre-foto .selo{
  position:absolute;bottom:-22px;right:-12px;background:var(--verde-escuro);color:#fff;
  border-radius:18px;padding:16px 20px;box-shadow:var(--sombra);max-width:210px;z-index:2;
}
.sobre-foto .selo strong{font-family:"Chinese Rocks",sans-serif;display:block;font-size:1.6rem;color:var(--lima)}
.sobre-foto .selo span{font-size:.8rem;color:#dff0d2}
.sobre-text h2 .accent{display:block}
.sobre-text p{margin-top:16px;color:var(--texto-suave)}
.sobre-stats{display:flex;gap:28px;margin-top:26px;flex-wrap:wrap}
.sobre-stats .st strong{font-family:"Chinese Rocks",sans-serif;font-size:1.8rem;color:var(--verde)}
.sobre-stats .st span{display:block;font-size:.82rem;color:var(--texto-suave)}

/* ===== Portfólio ===== */
.filtros{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:34px 0 38px}
.filtro{
  font-family:"Chinese Rocks",sans-serif;text-transform:uppercase;font-size:.78rem;letter-spacing:.5px;
  padding:9px 18px;border-radius:50px;border:2px solid rgba(27,94,46,.18);background:#fff;color:var(--verde-escuro);
  cursor:pointer;transition:all .15s;
}
.filtro:hover{border-color:var(--lima)}
.filtro.ativo{background:var(--verde-escuro);color:#fff;border-color:var(--verde-escuro)}
.portfolio-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.card-prod{
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--sombra-sm);
  display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;border:1px solid rgba(27,94,46,.06);
}
.card-prod:hover{transform:translateY(-6px);box-shadow:var(--sombra)}
.card-prod .thumb{aspect-ratio:3/4;background:var(--lima-claro);position:relative;overflow:hidden}
.card-prod .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card-prod:hover .thumb img{transform:scale(1.06)}
.card-prod .thumb .ph{width:100%;height:100%;display:grid;place-items:center;background:linear-gradient(135deg,var(--lima-claro),var(--lima));color:rgba(255,255,255,.92)}
.card-prod .thumb .ph svg{width:46px;height:46px}
.card-prod .tag{position:absolute;top:12px;left:12px;background:rgba(27,94,46,.92);color:#fff;font-size:.68rem;text-transform:uppercase;letter-spacing:1px;padding:5px 12px;border-radius:50px;font-weight:600}
.card-prod .body{padding:15px 14px;display:flex;flex-direction:column;gap:6px;flex:1}
.card-prod h3{font-family:"Chinese Rocks",sans-serif;text-transform:uppercase;color:var(--verde-escuro);font-size:.98rem;letter-spacing:.3px;line-height:1.1}
.card-prod p{color:var(--texto-suave);font-size:.8rem;flex:1;line-height:1.35}
.card-prod .preco{font-family:"Chinese Rocks",sans-serif;color:var(--verde);font-size:1.05rem}
.card-prod .preco.promo{display:flex;flex-direction:column;line-height:1.05;gap:1px}
.card-prod .preco.promo .de{font-family:"Poppins",sans-serif;font-size:.74rem;font-weight:500;color:#9aab9d;text-decoration:line-through}
.card-prod .preco.promo .por{font-family:"Chinese Rocks",sans-serif;font-size:1.15rem;color:#E0552E}
.card-prod .promo-badge{position:absolute;top:12px;right:12px;background:#E0552E;color:#fff;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:5px 11px;border-radius:50px;box-shadow:0 4px 12px rgba(224,85,46,.4)}
.card-prod .tag{font-size:.62rem;padding:4px 9px}
.card-prod .btn{margin-top:6px;width:100%;justify-content:center;padding:11px 14px;font-size:.78rem}
.empty-msg{grid-column:1/-1;text-align:center;color:var(--texto-suave);padding:40px}

/* ===== Planos / Assinatura ===== */
.planos{background:linear-gradient(135deg,var(--verde-escuro),#0f3a1d);color:#fff}
.planos .title{color:#fff}
.planos .title .accent{color:var(--lima)}
.planos .subtitle{color:#cfe6c2}
.planos-grid{display:grid;grid-template-columns:1fr 1.25fr 1fr;gap:22px;margin-top:54px;align-items:center}
.plano{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);
  padding:32px 26px;text-align:center;backdrop-filter:blur(4px);transition:transform .2s,border-color .2s,box-shadow .2s;position:relative;
}
.plano:hover{transform:translateY(-6px);border-color:var(--lima)}
.plano.destaque{
  background:linear-gradient(160deg,rgba(141,198,63,.28),rgba(141,198,63,.1));
  border:2px solid var(--lima);transform:scale(1.08);
  box-shadow:0 24px 60px rgba(0,0,0,.4);z-index:2;padding:42px 30px;
}
.plano.destaque:hover{transform:scale(1.08) translateY(-6px)}
.plano.destaque h3{font-size:1.7rem;color:#fff}
.plano.destaque .preco{font-size:3rem}
.plano .pop{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--lima);color:var(--verde-escuro);font-family:"Chinese Rocks";font-size:.8rem;padding:6px 18px;border-radius:50px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 6px 16px rgba(0,0,0,.3);white-space:nowrap}
.plano h3{font-family:"Chinese Rocks",sans-serif;text-transform:uppercase;color:var(--lima-claro);font-size:1.3rem;margin-bottom:6px}
.plano .preco{font-family:"Chinese Rocks",sans-serif;font-size:2.4rem;color:#fff;line-height:1}
.plano .preco small{font-size:.9rem;color:#bcd9ad;font-family:"Poppins"}
.plano ul{list-style:none;margin:18px 0;text-align:left;display:flex;flex-direction:column;gap:10px}
.plano ul li{font-size:.92rem;color:#dff0d2;display:flex;gap:9px;align-items:flex-start}
.plano ul li::before{content:"";flex:none;width:17px;height:17px;margin-top:2px;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%238DC63F" d="M11 20A7 7 0 0 1 9.8 6.1C15.5 5 17 4.48 19 2c1 2 2 4.18 2 8 0 5.5-4.78 10-10 10Z"/></svg>') no-repeat center/contain}
.plano .btn{width:100%;justify-content:center}
.planos-nota{margin-top:26px;text-align:center;color:#bcd9ad;font-size:.85rem}

/* ===== Agenda ===== */
.agenda{background:var(--creme)}
.agenda-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:42px}
.evento{
  background:#fff;border-radius:var(--radius-sm);box-shadow:var(--sombra-sm);overflow:hidden;
  display:flex;border-left:6px solid var(--lima);transition:transform .2s,box-shadow .2s;
}
.evento:hover{transform:translateY(-4px);box-shadow:var(--sombra)}
.evento .data{
  background:var(--verde-escuro);color:#fff;padding:18px 16px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;min-width:84px;text-align:center;
}
.evento .data .dia{font-family:"Chinese Rocks";font-size:1.9rem;line-height:1}
.evento .data .mes{font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--lima-claro)}
.evento .info{padding:16px 18px;flex:1}
.evento .info .tipo{display:inline-block;background:var(--lima-claro);color:var(--verde-escuro);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:3px 10px;border-radius:50px;margin-bottom:6px}
.evento .info h3{font-family:"Chinese Rocks";text-transform:uppercase;color:var(--verde-escuro);font-size:1rem;letter-spacing:.3px}
.evento .info p{color:var(--texto-suave);font-size:.86rem;margin-top:3px}
.evento .info .end{font-size:.8rem;color:var(--verde);margin-top:4px}

/* ===== Instagram ===== */
.insta{background:#fff}
.insta-wrap{display:flex;justify-content:center;margin-top:42px}
.insta-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;
  max-width:560px;width:100%;padding:46px 34px;border-radius:24px;color:#fff;text-decoration:none;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#1B5E2E,#2F8B3C);box-shadow:var(--sombra);
  transition:transform .2s;
}
.insta-card::before{content:"";position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(141,198,63,.25),transparent 70%)}
.insta-card:hover{transform:translateY(-5px)}
.insta-card>*{position:relative;z-index:1}
.insta-card .ic-logo img{width:92px;height:92px;border-radius:50%;box-shadow:0 10px 24px rgba(0,0,0,.3)}
.insta-card .ic-ig{width:38px;height:38px;color:var(--lima-claro)}
.insta-card h3{font-family:"Chinese Rocks",sans-serif;font-size:1.5rem;letter-spacing:.5px}
.insta-card p{font-size:.95rem;color:#dff0d2;max-width:300px}
.insta-card .btn{margin-top:10px;pointer-events:none}

/* ===== CTA final ===== */
.cta-final{
  background:linear-gradient(135deg,var(--lima),var(--verde-medio));
  border-radius:var(--radius);padding:56px;text-align:center;color:var(--verde-escuro);
  box-shadow:var(--sombra);
}
.cta-final h2{font-family:"Chinese Rocks";text-transform:uppercase;font-size:clamp(1.6rem,4vw,2.6rem);color:var(--verde-escuro)}
.cta-final p{max-width:560px;margin:14px auto 26px;color:#13441f}
.cta-final .hero-actions{justify-content:center}

/* ===== Footer ===== */
footer.foot{background:var(--verde-escuro);color:#cfe6c2;padding:60px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.foot-logo{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.foot-logo img{width:64px;height:64px;border-radius:50%}
.foot h4{font-family:"Chinese Rocks";text-transform:uppercase;color:#fff;font-size:1rem;letter-spacing:.5px;margin-bottom:14px}
.foot a,.foot p{color:#cfe6c2;font-size:.92rem;display:block;margin-bottom:8px;transition:color .15s}
.foot a:hover{color:var(--lima)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:20px;text-align:center;font-size:.82rem;color:#9cc28a}
.foot-bottom a{color:var(--lima-claro)}

/* ===== WhatsApp flutuante ===== */
.wa-float{position:fixed;bottom:22px;right:22px;z-index:60;background:#25D366;color:#fff;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 30px rgba(37,211,102,.5);transition:transform .2s}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:32px;height:32px}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ===== Responsivo ===== */
@media(max-width:1100px){ .portfolio-grid{grid-template-columns:repeat(4,1fr)} }
@media(max-width:900px){ .portfolio-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:920px){
  .servicos-grid{grid-template-columns:repeat(2,1fr)}
  .planos-grid{grid-template-columns:1fr;max-width:440px;margin-inline:auto}
  .plano.destaque{transform:none;order:-1}
  .plano.destaque:hover{transform:translateY(-6px)}
  .sobre-grid{grid-template-columns:1fr;gap:60px}
  .sobre-foto{max-width:420px;margin-inline:auto}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .section{padding:60px 0}
  .nav-links{display:none}
  .nav-toggle{display:block}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--creme);padding:20px;gap:16px;box-shadow:var(--sombra)}
  .servicos-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .foot-grid{grid-template-columns:1fr}
  .cta-final{padding:38px 22px}
  .hero{min-height:auto}
}
