/* =================================================================
   PACOTE BOHO — Itens + Floral Essencial · Indaiá Eventos
   Estética: editorial luxuoso · boho chique
   -----------------------------------------------------------------
   ESTILO/LAYOUT do site. As CORES e FONTES ficam em css/theme.css
   (carregado antes deste arquivo). Para mudar o tema, edite lá.
   ================================================================= */

/* ----------------- base ----------------- */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden; }
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  animation:pageIn .6s var(--ease) both;   /* fade suave ao abrir a página */
}
@keyframes pageIn{ from{ opacity:0; } to{ opacity:1; } }
img{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--bege); color:var(--brown-deep); }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,56px); }

.ic{ width:1em; height:1em; fill:none; stroke:currentColor; flex:0 0 auto; }

/* grão / textura de papel (desligado no celular: blend-mode fullscreen pesa no scroll) */
@media (max-width:600px){ .grain{ display:none; } }
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.05; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.skip-link{
  position:fixed; top:-60px; left:16px; z-index:200;
  background:var(--brown-deep); color:var(--cream); padding:10px 18px; border-radius:0 0 8px 8px;
  transition:top .25s var(--ease);
}
.skip-link:focus{ top:0; }

/* ----------------- tipografia utilitária ----------------- */
.eyebrow{
  font-family:var(--sans); font-weight:500;
  font-size:.74rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--taupe); margin:0 0 1.1rem;
  display:inline-flex; align-items:center; gap:.9em;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--gold); opacity:.7; }
.eyebrow--light{ color:rgba(255,255,255,.86); }
.eyebrow--light::before{ background:rgba(255,255,255,.7); }

.section{ position:relative; z-index:2; padding-block:clamp(64px,9vw,128px); }
.section__head{ max-width:640px; margin-bottom:clamp(36px,5vw,64px); }
.section__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.3rem,5.4vw,4rem); line-height:1.04; letter-spacing:-.01em;
  margin:0 0 1rem; color:var(--brown-deep);
}
.section__intro{ font-size:1.08rem; color:var(--brown); max-width:52ch; margin:0; }

/* ----------------- botões ----------------- */
.btn{
  --b:var(--brown-deep);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-weight:500; font-size:.9rem; letter-spacing:.08em;
  padding:.92em 1.7em; border-radius:999px; border:1px solid transparent;
  transition:transform .35s var(--ease), background .3s var(--ease), color .3s var(--ease), box-shadow .35s var(--ease), border-color .3s var(--ease);
  white-space:nowrap; line-height:1;
}
.btn .ic{ width:1.05em; height:1.05em; }
.btn:active{ transform:scale(.97); }

.btn--solid{ background:var(--brown-deep); color:var(--cream); box-shadow:var(--sh-1); }
.btn--solid:hover{ background:var(--ink); box-shadow:var(--sh-2); transform:translateY(-2px); }
.btn--solid .ic{ transition:transform .35s var(--ease); }
.btn--solid:hover .ic{ transform:translateX(4px); }

.btn--ghost{ background:transparent; color:var(--brown-deep); border-color:var(--line); }
.btn--ghost:hover{ background:var(--cream-2); border-color:var(--taupe); }

.btn--ghost-light{ background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.5); backdrop-filter:blur(4px); }
.btn--ghost-light:hover{ background:rgba(255,255,255,.18); border-color:#fff; transform:translateY(-2px); }

.btn--wa{ background:var(--wa-deep); color:#fff; box-shadow:0 6px 18px rgba(60,116,73,.28); }
.btn--wa:hover{ background:#33623f; transform:translateY(-2px); box-shadow:0 10px 26px rgba(60,116,73,.34); }
.btn--lg{ font-size:1rem; padding:1.05em 2em; }

/* ----------------- topbar ----------------- */
.topbar{
  position:sticky; top:0; z-index:90;
  background:rgba(247,241,230,.72); backdrop-filter:blur(12px) saturate(1.1);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease);
}
.topbar.is-stuck{ border-color:var(--line-soft); box-shadow:var(--sh-1); background:rgba(247,241,230,.9); }
.topbar__inner{ display:flex; align-items:center; gap:24px; height:72px; }

.brand{ display:flex; align-items:center; margin-right:auto; }
.brand__txt{ display:flex; flex-direction:column; line-height:.82; }
.brand__logo{ height:42px; width:auto; max-width:200px; display:block; object-fit:contain; }
.brand__logo[hidden]{ display:none; }   /* respeita o atributo hidden (sem logo → mostra o texto) */
.brand__name{ font-family:var(--serif); font-weight:600; font-size:1.5rem; color:var(--brown-deep); letter-spacing:.01em; }
.brand__sub{ font-family:var(--sans); font-weight:400; font-size:.6rem; letter-spacing:.45em; text-transform:uppercase; color:var(--taupe); padding-left:.15em; }
.brand--footer .brand__logo{ height:48px; }

.topnav{ display:flex; gap:30px; }
.topnav a{
  font-size:.86rem; letter-spacing:.05em; color:var(--brown); position:relative; padding-block:4px;
  transition:color .25s var(--ease);
}
.topnav a::after{
  content:""; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--gold);
  transition:width .3s var(--ease);
}
.topnav a:hover{ color:var(--brown-deep); }
.topnav a:hover::after{ width:100%; }

/* ----------------- HERO ----------------- */
.hero{ position:relative; min-height:clamp(620px,94svh,900px); display:flex; align-items:center; overflow:hidden; }
/* cortina cinematográfica: o hero "abre" emergindo do escuro ao carregar */
.hero::after{ content:""; position:absolute; inset:0; z-index:4; pointer-events:none;
  background:var(--brown-deep); animation:curtainOut 1.7s var(--ease-lux) forwards; }
@keyframes curtainOut{ 0%{ opacity:.92; } 100%{ opacity:0; } }
.hero__media{ position:absolute; inset:0; z-index:0; }
/* fundos: começam aproximados e se AFASTAM (zoom-out) ao entrar na tela, revelando a imagem */
.hero__media img{ width:100%; height:100%; object-fit:cover; object-position:center 38%;
  transform-origin:center; transform:scale(1.18); transition:transform 7s var(--ease-soft);
  animation:heroReveal 2s var(--ease-lux) both; }
.hero__media img.is-in{ transform:scale(1); }
@keyframes heroReveal{ from{ opacity:0; } to{ opacity:1; } }
.hero__veil{
  position:absolute; inset:0;
  background:
    linear-gradient(100deg, rgba(36,27,18,.70) 0%, rgba(48,36,24,.40) 42%, rgba(50,40,28,.10) 74%),
    linear-gradient(to top, rgba(34,25,16,.55), transparent 42%),
    radial-gradient(120% 90% at 30% 40%, transparent 40%, rgba(28,20,12,.42) 100%); /* vinheta luxuosa */
}
.hero__inner{ position:relative; z-index:2; padding-block:120px; max-width:720px; }
.hero__oval{
  position:absolute; z-index:-1; top:-6%; left:-8%; width:560px; height:360px;
  background:radial-gradient(closest-side, rgba(233,220,196,.22), transparent);
  filter:blur(10px); border-radius:50%;
}
.hero__eyebrow{ opacity:0; animation:rise 1.1s var(--ease-lux) .55s forwards; }
.hero__title{ margin:0 0 1.4rem; color:#fff; }
.hero__title-word{
  display:block; font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:clamp(4rem,13vw,9rem); line-height:.88; color:var(--cream); letter-spacing:-.005em;
  text-shadow:0 4px 44px rgba(0,0,0,.3); opacity:0; animation:heroWord 1.6s var(--ease-lux) .68s forwards;
}
/* o nome "Boho" sobe e as letras assentam de espaçadas para o ponto certo (elegante, sem desfoque) */
@keyframes heroWord{ from{ opacity:0; transform:translateY(46px); letter-spacing:.14em; } to{ opacity:1; transform:none; letter-spacing:-.005em; } }
.hero__title-sub{
  display:block; font-family:var(--sans); font-weight:300;
  font-size:clamp(1rem,2.4vw,1.55rem); letter-spacing:.34em; text-transform:uppercase;
  color:rgba(255,255,255,.92); margin-top:.9rem; padding-left:.25em;
  opacity:0; animation:rise 1.2s var(--ease-lux) 1.05s forwards;
}
.hero__lede{
  font-size:1.12rem; color:rgba(255,255,255,.9); max-width:46ch; margin:0 0 2.2rem;
  text-shadow:0 2px 20px rgba(0,0,0,.3); opacity:0; animation:rise 1.2s var(--ease-lux) 1.28s forwards;
}
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; opacity:0; animation:rise 1.2s var(--ease-lux) 1.5s forwards; }
.hero__sprig{ width:140px; height:46px; color:rgba(255,255,255,.55); margin-top:38px; opacity:0; animation:fade 1.6s var(--ease) 1.9s forwards; }

@keyframes rise{ from{ opacity:0; transform:translateY(26px);} to{ opacity:1; transform:none;} }
@keyframes fade{ from{ opacity:0;} to{ opacity:1;} }

/* ----------------- INCLUSO ----------------- */
.included{ background:linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%); }
.included__grid{ list-style:none; margin:0; padding:0; display:grid; gap:18px; grid-template-columns:repeat(auto-fill, minmax(248px,1fr)); }
.inc-card{
  position:relative; background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--radius);
  padding:32px 28px; overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.inc-card::before{
  content:""; position:absolute; top:0; left:0; width:100%; height:2px;
  background:linear-gradient(90deg, var(--gold), var(--sage)); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease);
}
.inc-card:hover{ transform:translateY(-5px); box-shadow:var(--sh-2); border-color:transparent; }
.inc-card:hover::before{ transform:scaleX(1); }
.inc-card__ic{ width:30px; height:30px; color:var(--gold); margin-bottom:18px; }
.inc-card h3{ font-family:var(--serif); font-weight:600; font-size:1.5rem; color:var(--brown-deep); margin:0 0 .5rem; }
.inc-card p{ font-size:.94rem; color:var(--brown); margin:0; }
.inc-card__n{ position:absolute; top:22px; right:24px; font-family:var(--serif); font-style:italic; font-size:1.2rem; color:var(--bege); }

/* ----------------- CATÁLOGO ----------------- */
.catalog{ position:relative; z-index:2; }
.catalog--floral{ background:var(--cream); }
.catalog--itens{ background:var(--cream-2); }
.catalog__cta{ text-align:center; margin-top:clamp(34px,5vw,56px); }
.catsec__head--lead{ margin-bottom:clamp(24px,3vw,40px); }
.catsec__head--lead .eyebrow{ margin-bottom:.55rem; }
.section__head--center{ max-width:680px; margin-inline:auto; text-align:center; }
.section__head--center .eyebrow{ justify-content:center; }

/* menu interno (âncoras) — barra fixa abaixo do header */
.catnav{ position:sticky; top:72px; z-index:45; margin:0; padding-block:10px;
  background:rgba(247,241,230,.86); backdrop-filter:blur(12px) saturate(1.1); border-bottom:1px solid var(--line-soft); }
.catnav__inner{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,56px);
  display:flex; gap:10px; justify-content:center; overflow-x:auto; scrollbar-width:none; }
.catnav__inner::-webkit-scrollbar{ display:none; }
.catpill{
  display:inline-flex; align-items:center; gap:.6em; white-space:nowrap;
  font-size:.82rem; letter-spacing:.06em; color:var(--brown);
  padding:.62em 1.25em; border-radius:999px; border:1px solid var(--line);
  transition:all .3s var(--ease);
}
.catpill__n{ font-family:var(--serif); font-style:italic; font-size:.95rem; color:var(--gold-deep); }
.catpill:hover{ border-color:var(--taupe); color:var(--brown-deep); }
.catpill.is-active{ background:var(--brown-deep); border-color:var(--brown-deep); color:var(--cream); box-shadow:var(--sh-1); }
.catpill.is-active .catpill__n{ color:var(--gold-soft); }

/* ao navegar pelo menu, parar com o título logo abaixo das barras fixas
   (topbar 65px + catnav). Sem isso, o título fica escondido atrás delas. */
#pacotes, #catalogo, #avisos, #atendimento{ scroll-margin-top:140px; }

/* seções do catálogo */
.catsec{ padding-block:clamp(30px,4vw,52px); scroll-margin-top:128px; }
.catsec + .catsec{ border-top:1px solid var(--line-soft); }
.catsec__head{ display:flex; align-items:flex-start; gap:clamp(16px,2.5vw,30px); margin-bottom:clamp(28px,3.5vw,44px); }
.catsec__n{ font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(2.4rem,5vw,3.6rem); line-height:.8; color:var(--bege); flex:0 0 auto; }
.catsec__title{ font-family:var(--serif); font-weight:500; font-size:clamp(1.9rem,4vw,3rem); line-height:1.05; color:var(--brown-deep); margin:0 0 .35rem; }
.catsec__intro{ font-size:1.04rem; color:var(--brown); max-width:54ch; margin:0; }
.catsec__count{ display:inline-block; margin-top:.7rem; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--taupe); }

/* filtro do pacote completo */
.filterbar{ display:flex; gap:8px; margin-bottom:clamp(22px,3vw,34px); flex-wrap:wrap; }
.fchip{
  font-family:var(--sans); font-size:.82rem; letter-spacing:.05em; color:var(--brown);
  padding:.55em 1.2em; border-radius:999px; background:transparent; border:1px solid var(--line);
  transition:all .28s var(--ease);
}
.fchip:hover{ border-color:var(--taupe); color:var(--brown-deep); }
.fchip.is-active{ background:var(--gold-deep); border-color:var(--gold-deep); color:#fff; box-shadow:0 4px 14px rgba(138,106,44,.3); }
.fchip__n{ font-variant-numeric:tabular-nums; font-size:.74em; opacity:.7; margin-left:.15em; }
.fchip.is-active .fchip__n{ opacity:.9; }

/* grid */
.grid{ display:grid; gap:clamp(16px,2vw,28px); grid-template-columns:repeat(auto-fill, minmax(272px,1fr)); }
.grid--compact{ grid-template-columns:repeat(auto-fill, minmax(208px,1fr)); gap:clamp(12px,1.4vw,18px); transition:opacity .25s var(--ease); }
.grid--compact.is-swapping{ opacity:0; }
.grid--compact .card-wrap{ animation:none; } /* lista completa: estática (sem flutuar) */

/* ----------------- CARD FLUTUANTE ----------------- */
.card-wrap{ position:relative; }   /* sem flutuar contínuo — visual mais sóbrio */

.card{
  position:relative; display:flex; flex-direction:column; text-align:left;
  background:var(--cream); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; padding:0; color:inherit; width:100%;
  box-shadow:0 14px 30px -12px rgba(74,58,41,.30), 0 5px 14px -4px rgba(74,58,41,.14);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
}
.card-wrap:hover{ animation-play-state:paused; }
.card-wrap:hover .card,
.card:focus-visible{ transform:translateY(-10px); box-shadow:0 26px 50px -20px rgba(58,47,34,.5), 0 6px 16px rgba(74,58,41,.12); border-color:transparent; }
.card:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; }

.card__media{ position:relative; aspect-ratio:4/5; overflow:hidden; background:var(--sand); }
.grid--compact .card__media{ aspect-ratio:1/1; }
/* skeleton shimmer */
.card__media::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:linear-gradient(100deg, var(--sand) 30%, var(--cream-2) 50%, var(--sand) 70%);
  background-size:220% 100%; animation:shimmer 1.5s linear infinite;
}
.card__media img{
  position:relative; z-index:1; width:100%; height:100%; object-fit:cover;
  opacity:0; transform:scale(1.06); transition:opacity .8s var(--ease), transform .9s var(--ease);
}
.card__media img.loaded{ opacity:1; transform:scale(1); }
.card__media.is-loaded::before{ animation:none; opacity:0; }
.card-wrap:hover .card__media img{ transform:scale(1.08); }
@keyframes shimmer{ to{ background-position:-220% 0; } }
.card__media.is-error::after{
  content:""; position:absolute; inset:0; z-index:2;
  background:var(--sand) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 24 24' fill='none' stroke='%23b89357' stroke-width='1'%3E%3Cpath d='M8 4h8M9 4c0 3-2 4-2 8a5 5 0 0 0 10 0c0-4-2-5-2-8'/%3E%3C/svg%3E") center/56px no-repeat;
  opacity:.6;
}
.card__media::after{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(to top, rgba(50,38,26,.30), transparent 44%); opacity:.7; }

.card__badge{
  position:absolute; top:12px; left:12px; z-index:3;
  display:inline-flex; align-items:center; gap:.4em;
  font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; font-weight:500;
  padding:.42em .8em; border-radius:999px; backdrop-filter:blur(6px);
  background:rgba(247,241,230,.9); color:var(--brown-deep); border:1px solid rgba(255,255,255,.55);
}
.card__badge .ic{ width:.95em; height:.95em; color:var(--gold); }
.card__badge[data-tipo="permanente"] .ic{ color:var(--sage); }
.card__badge[data-tipo="natural"] .ic{ color:#c98b94; }
.card__qty{
  position:absolute; bottom:12px; right:14px; z-index:3;
  font-family:var(--serif); font-style:italic; font-size:1.05rem; color:#fff; text-shadow:0 1px 12px rgba(0,0,0,.5);
}
/* lupa que surge ao passar o mouse */
.card__view{
  position:absolute; top:50%; left:50%; z-index:3; transform:translate(-50%,-50%) scale(.7);
  width:46px; height:46px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:rgba(247,241,230,.92); color:var(--brown-deep); box-shadow:var(--sh-1);
  opacity:0; transition:opacity .35s var(--ease), transform .45s var(--ease); pointer-events:none;
}
.card__view .ic{ width:20px; height:20px; }
.card-wrap:hover .card__view{ opacity:1; transform:translate(-50%,-50%) scale(1); }

.card__body{ padding:16px 20px 20px; display:flex; flex-direction:column; gap:5px; }
.grid--compact .card__body{ padding:13px 15px 16px; }
.card__cat{ font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; color:var(--taupe); }
.card__name{ font-family:var(--serif); font-weight:600; font-size:1.32rem; line-height:1.15; color:var(--brown-deep); margin:0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:2.3em; }
.grid--compact .card__name{ font-size:1.12rem; }
.card__more{
  margin-top:7px; font-size:.76rem; letter-spacing:.06em; color:var(--gold-deep); display:inline-flex; align-items:center; gap:.5em;
  opacity:0; transform:translateX(-6px); transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.card__more .ic{ width:1.05em; height:1.05em; }
.card-wrap:hover .card__more, .card:focus-visible .card__more{ opacity:1; transform:none; }
.grid--compact .card__more{ display:none; }

/* reveal on scroll — fade de entrada elegante e luxuoso (deslize longo, curva suave) */
.reveal{ opacity:0; transform:translateY(40px); transition:opacity 1.1s var(--ease-lux), transform 1.1s var(--ease-lux); }
.reveal.in-view{ opacity:1; transform:none; }
/* cards "florescem": imagem entra com um leve zoom que assenta ao revelar */
.card-wrap.reveal .card__media img{ transform:scale(1.12); transition:transform 1.4s var(--ease-lux); }
.card-wrap.reveal.in-view .card__media img{ transform:scale(1); }
.card-wrap.reveal.in-view:hover .card__media img{ transform:scale(1.08); }

/* ----------------- FAVORITOS (gamificação) ----------------- */
.card__fav{
  position:absolute; top:12px; right:12px; z-index:5;
  width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:rgba(247,241,230,.86); border:1px solid rgba(255,255,255,.55); color:var(--taupe);
  backdrop-filter:blur(6px); box-shadow:var(--sh-1); cursor:pointer;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.card__fav .ic{ width:19px; height:19px; fill:none; stroke:currentColor; transition:fill .2s var(--ease); }
.card__fav:hover{ transform:scale(1.12); color:#c98b94; }
.card__fav.is-fav{ color:#c98b94; background:#fff; }
.card__fav.is-fav .ic{ fill:#c98b94; }
.card__fav:focus-visible{ outline:2px solid var(--gold); outline-offset:2px; }
.card__fav.pop{ animation:favPop .45s var(--ease); }
@keyframes favPop{ 0%{ transform:scale(1);} 35%{ transform:scale(1.35);} 70%{ transform:scale(.9);} 100%{ transform:scale(1);} }

/* barrinha de favoritos (canto inferior esquerdo) */
.favbar{
  position:fixed; left:18px; bottom:18px; z-index:80;
  display:inline-flex; align-items:center; gap:.6em;
  padding:.7em 1.05em; border-radius:999px;
  background:var(--brown-deep); color:var(--cream); box-shadow:var(--sh-2);
  font-size:.86rem; letter-spacing:.02em; animation:favIn .4s var(--ease) both;
}
.favbar[hidden]{ display:none; }
.favbar__heart{ width:18px; height:18px; fill:#c98b94; stroke:#c98b94; }
.favbar__txt b{ font-variant-numeric:tabular-nums; }
.favbar__send{ display:inline-flex; align-items:center; gap:.35em; padding-left:.7em; margin-left:.2em; border-left:1px solid rgba(247,241,230,.25); color:var(--gold-soft); }
.favbar__send .ic{ width:15px; height:15px; }
.favbar:hover{ background:var(--ink); }
@keyframes favIn{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }

/* pétalas/corações ao interagir */
.petal{
  position:fixed; z-index:200; pointer-events:none; font-size:18px; line-height:1;
  transform:translate(-50%,-50%); opacity:0; animation:petalUp 1s var(--ease) forwards;
  text-shadow:0 1px 6px rgba(0,0,0,.15);
}
@keyframes petalUp{
  0%{ opacity:0; transform:translate(-50%,-50%) scale(.5); }
  20%{ opacity:1; }
  100%{ opacity:0; transform:translate(calc(-50% + var(--dx,0)), calc(-50% + var(--dy,-50px))) scale(1.1) rotate(var(--rot,20deg)); }
}

/* ----------------- BAND emocional ----------------- */
.band{ position:relative; height:clamp(340px,46vw,520px); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.band img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 60%; }
.band::after{ content:""; position:absolute; inset:0; background:rgba(45,34,23,.42); }
.band__quote{ position:relative; z-index:2; text-align:center; color:#fff; padding-inline:24px; }
.band__sprig{ width:120px; height:40px; color:rgba(255,255,255,.6); margin:0 auto 10px; }
.band__quote p{ font-family:var(--script); font-weight:700; font-size:clamp(2.6rem,6vw,4.4rem); line-height:1.12; margin:0; max-width:16ch; text-shadow:0 2px 30px rgba(0,0,0,.4); color:#fff; }

/* ----------------- AVISOS ----------------- */
.notes{ background:var(--cream-2); }
.notes__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); align-items:stretch; }
.aviso{ background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--radius); padding:clamp(22px,2.6vw,32px); }
.aviso__t{ font-family:var(--serif); font-weight:600; font-size:1.45rem; color:var(--brown-deep); margin:0 0 1rem; padding-bottom:.7rem; border-bottom:1px solid var(--line-soft); }
.aviso ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.85rem; }
.aviso li{ display:flex; gap:.7em; align-items:flex-start; font-size:.96rem; color:var(--brown); line-height:1.5; }
.aviso li .ic{ width:1.05em; height:1.05em; color:var(--sage); flex:0 0 auto; margin-top:.28em; }
.legend{ display:flex; flex-wrap:wrap; gap:18px; margin:0 0 clamp(22px,3vw,32px); }
.legend__item{ display:inline-flex; align-items:center; gap:.55em; font-size:.84rem; color:var(--brown); }
.legend__item .ic{ width:1.2em; height:1.2em; }
.legend__item:nth-child(1) .ic{ color:var(--sage); }
.legend__item:nth-child(2) .ic{ color:#c98b94; }

/* ----------------- COMPARATIVO ----------------- */
.compare{ background:var(--cream-2); }
.compare__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(18px,2.6vw,30px); align-items:stretch; }
.cmp{ position:relative; display:flex; flex-direction:column; background:var(--cream); border:1px solid var(--line-soft); border-radius:14px; padding:clamp(28px,3.4vw,46px); box-shadow:var(--sh-1); transition:transform .45s var(--ease), box-shadow .45s var(--ease); overflow:hidden; }
.cmp::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg, var(--sage), var(--gold)); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.cmp:hover{ transform:translateY(-6px); box-shadow:var(--sh-2); }
.cmp:hover::before{ transform:scaleX(1); }
.cmp--itens{ background:linear-gradient(180deg, var(--cream) 0%, #f3ead9 100%); border-color:rgba(184,147,87,.28); }
.cmp__selo{ align-self:flex-start; font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; font-weight:500; color:var(--brown-deep); background:var(--sand); border:1px solid var(--line-soft); padding:.45em .9em; border-radius:999px; margin-bottom:1.2rem; }
.cmp--itens .cmp__selo{ background:var(--gold); color:#fff; border-color:transparent; }
.cmp__titulo{ font-family:var(--serif); font-weight:500; font-size:clamp(1.9rem,3.4vw,2.7rem); line-height:1.04; color:var(--brown-deep); margin:0 0 .6rem; }
.cmp__desc{ font-size:1.02rem; color:var(--brown); margin:0 0 1.4rem; }
.cmp__inc{ list-style:none; margin:0 0 1.3rem; padding:0; display:flex; flex-direction:column; gap:.7rem; }
.cmp__inc li{ display:flex; gap:.7em; align-items:flex-start; font-size:.98rem; color:var(--ink); }
.cmp__inc .ic{ width:1.15em; height:1.15em; color:var(--sage); flex:0 0 auto; margin-top:.18em; }
.cmp__nao{ display:flex; gap:.7em; align-items:flex-start; font-size:.86rem; color:var(--taupe); line-height:1.5; margin:0 0 1.8rem; padding-top:1.1rem; border-top:1px solid var(--line-soft); }
.cmp__nao .ic{ width:1.1em; height:1.1em; color:var(--bege); flex:0 0 auto; margin-top:.2em; }
.cmp__cta{ align-self:flex-start; margin-top:auto; }

/* ----------------- TABELA COMPARATIVA ----------------- */
.ptable{ max-width:780px; margin-inline:auto; background:var(--cream); border:1px solid var(--line-soft); border-radius:16px; overflow:hidden; box-shadow:var(--sh-2); }
.ptable__head, .ptable__row, .ptable__foot{ display:grid; grid-template-columns:minmax(0,1.6fr) minmax(0,1fr) minmax(0,1fr); align-items:center; }
.ptable__col, .ptable__cell, .ptable__feat{ min-width:0; }
.ptable__col h3{ overflow-wrap:break-word; }
.ptable__head{ background:linear-gradient(180deg,#f3ead9,var(--cream)); border-bottom:1px solid var(--line); }
.ptable__col{ text-align:center; padding:20px 8px; border-left:1px solid var(--line-soft); display:flex; flex-direction:column; align-items:center; gap:.4em; }
.ptable__col--hl{ background:rgba(184,147,87,.1); }
.ptable__col h3{ font-family:var(--serif); font-weight:600; font-size:1.18rem; color:var(--brown-deep); margin:0; line-height:1.1; }
.ptable__tag{ font-size:.58rem; letter-spacing:.1em; text-transform:uppercase; color:var(--taupe); }
.ptable__tag--hl{ color:#fff; background:var(--gold-deep); padding:.32em .8em; border-radius:999px; letter-spacing:.08em; }
.ptable__feat{ padding:15px 18px; }
.ptable__feat--head{ display:flex; align-items:flex-end; font-size:.64rem; letter-spacing:.18em; text-transform:uppercase; color:var(--taupe); }
.ptable__feat b{ display:block; font-family:var(--serif); font-weight:600; font-size:1.1rem; color:var(--brown-deep); line-height:1.15; }
.ptable__feat span{ display:block; font-size:.8rem; color:var(--taupe); margin-top:.15rem; line-height:1.35; }
.ptable__row{ border-top:1px solid var(--line-soft); }
.ptable__row:nth-of-type(even){ background:rgba(233,220,196,.16); }
.ptable__cell{ text-align:center; padding:15px 8px; border-left:1px solid var(--line-soft); }
.ptable__yes{ display:inline-flex; color:#5f7d4e; }
.ptable__yes .ic{ width:23px; height:23px; }
.ptable__no{ display:inline-flex; color:var(--taupe); }
.ptable__no .ic{ width:20px; height:20px; }
.ptable__row--total{ background:var(--cream-2); border-top:1px solid var(--line); }
.ptable__num{ font-family:var(--serif); font-style:italic; font-size:1.55rem; color:var(--gold); }
.ptable__foot{ border-top:1px solid var(--line); padding:16px 12px; }
.ptable__foot .ptable__cell{ border-left:0; padding:6px; }
.ptable__foot .ptable__feat{ padding:0; }
.ptable__foot .btn{ width:100%; justify-content:center; font-size:.78rem; letter-spacing:.04em; padding:.85em .8em; }

/* etiquetas de pacote (pontinhos) */
.dotp{ display:inline-block; width:9px; height:9px; border-radius:50%; vertical-align:middle; flex:0 0 auto; }
.dotp--floral{ background:var(--sage); }
.dotp--itens{ background:var(--gold); }
.card__dot{ display:inline-block; width:7px; height:7px; border-radius:50%; margin-right:.55em; vertical-align:middle; }
.card__dot[data-pkg="floral"]{ background:var(--sage); }
.card__dot[data-pkg="itens"]{ background:var(--gold); }
.legend{ justify-content:center; }
.legend__item{ gap:.5em; }
.catalog__count{ text-align:center; font-size:.82rem; letter-spacing:.04em; color:var(--taupe); margin:2px 0 24px; }

/* ----------------- CTA ----------------- */
.cta{ position:relative; overflow:hidden; color:#fff; text-align:center; }
.cta__media{ position:absolute; inset:0; z-index:0; }
.cta__media img{ width:100%; height:100%; object-fit:cover; object-position:center 30%;
  transform-origin:center; transform:scale(1.18); transition:transform 7s var(--ease-soft); }
.cta__media img.is-in{ transform:scale(1); }
.cta__veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(40,30,20,.6), rgba(45,34,23,.72)); }
.cta__inner{ position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; }
.cta__oval{ top:8%; left:50%; transform:translateX(-50%); }
.cta .eyebrow{ justify-content:center; }
.cta .eyebrow::before{ display:none; }
.cta__title{ font-family:var(--serif); font-weight:500; font-size:clamp(2.3rem,6vw,4.4rem); line-height:1.05; margin:0 0 1.2rem; color:#fff; text-shadow:0 4px 40px rgba(0,0,0,.3); }
.cta__lede{ font-size:1.12rem; color:rgba(255,255,255,.9); max-width:52ch; margin:0 0 2.3rem; }
.cta .hero__actions{ justify-content:center; animation:none; opacity:1; }
.cta__choices{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.cta__choices .btn--wa{ background:rgba(255,255,255,.96); color:var(--wa-deep); }
.cta__choices .btn--wa:hover{ background:#fff; }
.cta__choices .btn--wa .ic{ color:var(--wa); }
.cta__minor{ display:inline-block; margin-top:1.6rem; font-size:.82rem; letter-spacing:.08em; color:rgba(255,255,255,.8); border-bottom:1px solid rgba(255,255,255,.4); padding-bottom:2px; transition:color .25s var(--ease), border-color .25s var(--ease); }
.cta__minor:hover{ color:#fff; border-color:#fff; }

/* ----------------- RODAPÉ ----------------- */
.footer{ position:relative; z-index:2; background:var(--brown-deep); color:var(--cream); padding-block:46px; }
.footer__inner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px; }
.brand--footer .brand__name{ color:var(--cream); }
.brand--footer .brand__sub{ color:var(--gold-soft); }
.footer__tag{ font-size:.85rem; color:rgba(247,241,230,.7); margin:0; letter-spacing:.03em; }
.footer__site{ font-size:.9rem; letter-spacing:.08em; color:var(--gold-soft); border-bottom:1px solid transparent; transition:border-color .25s var(--ease); }
.footer__site:hover{ border-color:var(--gold-soft); }

/* ----------------- MODAL ----------------- */
.modal{ position:fixed; inset:0; z-index:150; display:flex; align-items:center; justify-content:center; padding:clamp(14px,3vw,40px); }
.modal[hidden]{ display:none; }
.modal__backdrop{ position:absolute; inset:0; background:rgba(40,30,20,.55); backdrop-filter:blur(6px); opacity:0; animation:fade .4s var(--ease) forwards; }
.modal__panel{
  position:relative; z-index:2; display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  width:min(940px,100%); height:min(90svh,560px); overflow:hidden;
  background:var(--cream); border-radius:14px; box-shadow:var(--sh-3);
  transform:translateY(20px) scale(.97); opacity:0; animation:modalIn .5s var(--ease) .05s forwards;
}
@keyframes modalIn{ to{ transform:none; opacity:1; } }
.modal__media{ position:relative; background:var(--sand); overflow:hidden; aspect-ratio:1/1; align-self:center; }
.modal__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); cursor:zoom-in; }
.modal__media.zoomed img{ transform:scale(1.7); cursor:zoom-out; }
.modal__zoom{
  position:absolute; bottom:14px; right:14px; width:38px; height:38px; border-radius:50%;
  background:rgba(247,241,230,.9); border:1px solid var(--line); color:var(--brown-deep);
  font-size:1.3rem; line-height:1; display:flex; align-items:center; justify-content:center; box-shadow:var(--sh-1);
}
.modal__body{ padding:clamp(26px,3.4vw,46px); overflow-y:auto; display:flex; flex-direction:column; }
.modal__nome{ font-family:var(--serif); font-weight:600; font-size:clamp(1.8rem,3.6vw,2.6rem); line-height:1.08; color:var(--brown-deep); margin:.2rem 0 1.1rem; }
.modal__meta{ display:flex; flex-wrap:wrap; align-items:center; gap:12px; margin-bottom:1.3rem; }
.meta-qtd{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--gold); }
.badge{
  display:inline-flex; align-items:center; gap:.45em;
  font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500;
  padding:.45em .9em; border-radius:999px; background:var(--cream-2); color:var(--brown-deep); border:1px solid var(--line);
}
.badge .ic{ width:1.05em; height:1.05em; color:var(--gold); }
.badge[data-tipo="permanente"] .ic{ color:var(--sage); }
.badge[data-tipo="natural"] .ic{ color:#c98b94; }
.badge[data-tipo="ambientacao"] .ic{ color:var(--gold); }
.modal__desc{ font-size:1.06rem; color:var(--brown); margin:0 0 1rem; }
.modal__inclui{ font-size:.92rem; color:var(--brown); margin:0 0 1.2rem; line-height:1.55; padding:.7rem .9rem; background:var(--cream-2); border-radius:8px; border:1px solid var(--line-soft); }
.modal__inclui[hidden]{ display:none; }
.modal__inclui-lbl{ display:block; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:.25rem; }
.modal__pacote{ display:flex; gap:.6em; align-items:flex-start; margin:0 0 auto; padding:.9rem 1rem; background:var(--cream-2); border:1px solid var(--line-soft); border-radius:8px; font-size:.86rem; color:var(--brown); line-height:1.45; }
.modal__pacote .ic{ width:1.1em; height:1.1em; color:var(--sage); flex:0 0 auto; margin-top:.18em; }
.modal__body .btn{ align-self:flex-start; margin-top:1.4rem; }
.modal__close{
  position:absolute; top:14px; right:14px; z-index:5; width:40px; height:40px; border-radius:50%;
  background:rgba(247,241,230,.92); border:1px solid var(--line); color:var(--brown-deep);
  display:flex; align-items:center; justify-content:center; box-shadow:var(--sh-1); transition:transform .3s var(--ease), background .3s var(--ease);
}
.modal__close .ic{ width:18px; height:18px; }
.modal__close:hover{ transform:rotate(90deg); background:var(--cream); }
/* setas de navegação: flutuam sobre a foto (sempre visíveis, fácil de passar os itens) */
.modal__navbtn{
  position:absolute; top:50%; transform:translateY(-50%); z-index:5;
  width:42px; height:42px; border-radius:50%; background:rgba(247,241,230,.92); border:1px solid var(--line); color:var(--brown-deep);
  display:flex; align-items:center; justify-content:center; box-shadow:var(--sh-1); transition:background .25s var(--ease), color .25s var(--ease); }
.modal__navbtn--prev{ left:12px; }
.modal__navbtn--next{ right:12px; }
.modal__navbtn:hover{ background:var(--brown-deep); color:var(--cream); border-color:var(--brown-deep); }
.modal__navbtn .ic{ width:18px; height:18px; }

/* ----------------- FAB whatsapp ----------------- */
.fab{
  position:fixed; right:18px; bottom:18px; z-index:80; width:56px; height:56px; border-radius:50%;
  background:var(--wa); color:#fff; display:none; align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(60,116,73,.4); transition:transform .3s var(--ease);
}
.fab .ic{ width:28px; height:28px; stroke-width:1.3; }
.fab::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid var(--wa); animation:pulse 2.6s var(--ease) infinite; }
@keyframes pulse{ 0%{ transform:scale(1); opacity:.6;} 70%{ transform:scale(1.5); opacity:0;} 100%{opacity:0;} }
.fab:hover{ transform:scale(1.08); }

/* ----------------- RESPONSIVO ----------------- */
/* alvos de toque confortáveis no celular (mín. 44px) */
@media (max-width:760px){
  .card__fav, .modal__zoom, .modal__close{ width:44px; height:44px; }
  .modal__navbtn{ width:46px; height:46px; }
  .topbar__cta{ min-width:44px; min-height:44px; }
}
@media (max-width:980px){
  .notes__grid{ grid-template-columns:1fr; gap:30px; }
  .modal__panel{ grid-template-columns:1fr; height:auto; max-height:92svh; }
  .modal__media{ aspect-ratio:1/1; min-height:0; align-self:start; }   /* quadrada no celular = mostra a foto INTEIRA */
  .modal__media img{ object-fit:contain; }                              /* garante a imagem inteira (sem cortar), mesmo se não for quadrada */
  .catsec__head{ gap:14px; }
}
@media (max-width:760px){
  .topnav{ display:none; }
  .topbar__cta span{ display:none; }
  .topbar__cta{ padding:.7em; }
  .fab{ display:flex; }
  .hero__inner{ padding-block:90px; }
  .topbar__inner{ height:64px; }
  .catnav{ top:64px; }
  .catnav__inner{ justify-content:flex-start; } /* rola na horizontal */
  .catsec__head{ flex-direction:column; gap:4px; }
  .catsec__n{ font-size:2.2rem; }
  .card__more{ opacity:1; transform:none; } /* sempre visível no toque */
  .card__view{ display:none; }               /* sem hover no toque */
  .compare__grid, .entenda__grid, .notes__grid{ grid-template-columns:1fr; }
  .catsec__head--lead{ flex-direction:row; }  /* mantém número ao lado no topo das seções-pacote */
  .cta__choices{ flex-direction:column; align-items:stretch; width:100%; max-width:420px; }
  .cta__choices .btn{ justify-content:center; }
}
@media (max-width:600px){
  .grid{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .grid--compact{ grid-template-columns:repeat(2,1fr); gap:10px; }
  .modal__body{ padding:16px 18px 18px; }
  .modal__desc{ margin-bottom:.7rem; }
  .modal__nome{ margin:.1rem 0 .7rem; }
  .modal__meta{ margin-bottom:.8rem; }
  .section__title{ font-size:clamp(1.85rem,7vw,2.5rem); }
  .catsec__title{ font-size:clamp(1.7rem,6.5vw,2.3rem); }
  .section__intro{ font-size:1rem; }
  /* tabela comparativa no celular */
  .ptable__feat{ padding:12px 12px; }
  .ptable__feat b{ font-size:.95rem; }
  .ptable__feat span{ font-size:.7rem; }
  .ptable__feat--head{ font-size:.56rem; letter-spacing:.12em; }
  .ptable__col{ padding:13px 4px; }
  .ptable__col h3{ font-size:.88rem; }
  .ptable__tag{ font-size:.5rem; }
  .ptable__tag--hl{ padding:.3em .55em; }
  .ptable__cell{ padding:12px 4px; }
  .ptable__yes .ic{ width:19px; height:19px; }
  .ptable__num{ font-size:1.2rem; }
  .ptable__foot{ grid-template-columns:1fr; gap:8px; padding:14px; }
  .ptable__foot .ptable__feat{ display:none; }
  .ptable__foot .btn{ font-size:.82rem; }
}
@media (max-width:430px){
  .grid, .grid--compact{ gap:10px; }
  .card__body, .grid--compact .card__body{ padding:12px 12px 15px; }
  .card__name, .grid--compact .card__name{ font-size:1.02rem; }
  .card__badge span{ display:none; }
  .card__badge{ padding:.42em; }
}

/* ----------------- MOVIMENTO REDUZIDO ----------------- */
/* Quando o aparelho pede "reduzir movimento", NÃO matamos tudo: mantemos um
   fade de opacidade suave (confortável e elegante) e removemos só os movimentos
   grandes — zoom, deslocamentos, parallax e laços infinitos. Assim o site
   continua animando (fade) mesmo com essa opção ligada no celular/computador. */
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto !important; }
  *, *::before, *::after{ animation-iteration-count:1 !important; }   /* para os laços infinitos */
  /* reveals e cards: só fade, sem deslizar nem dar zoom */
  .reveal{ transform:none !important; }
  .card-wrap.reveal .card__media img,
  .card-wrap.reveal.in-view .card__media img,
  .card-wrap:hover .card__media img{ transform:none !important; }
  /* textos do hero: troca o movimento por fade puro, preservando a cascata de tempos */
  .hero__eyebrow,.hero__title-word,.hero__title-sub,.hero__lede,.hero__actions,.hero__sprig{
    animation-name:fade !important;
  }
  /* imagens de fundo: mantém o fade de entrada; o zoom-out (afastar) é suave e continua valendo */
  .hero__media img{ animation:heroReveal 1.6s var(--ease-lux) both !important; }
  /* a cortina de abertura é só opacidade → pode continuar */
}
