:root{
  --pink:#ff4da6;
  --pink-2:#ff7cc0;
  --pink-deep:#d6357f;
  --nude:#f6e6df;
  --nude-2:#fbeee8;
  --white:#ffffff;
  --ink:#1b1518;
  --ink-2:#3a2e35;
  --muted:#7a6e75;
  --gold:#d7b46a;
  --gold-2:#bd9544;
  --shadow: 0 22px 60px rgba(20,12,18,.14);
  --shadow-soft: 0 14px 36px rgba(20,12,18,.10);
  --shadow-soft-2: 0 8px 22px rgba(20,12,18,.08);
  --radius: 18px;
  --radius-lg: 26px;
  --radius-xl: 32px;
  --border: 1px solid rgba(27,21,24,.10);
  --max: 1240px;
  --easing: cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  font-family:var(--font-body, Inter), system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size:16px;
  line-height:1.55;
  background:var(--white);
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}
h1,h2,h3,h4{font-family:var(--font-heading, "Playfair Display"), Georgia, serif;letter-spacing:-.01em;line-height:1.05;margin:0}

.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:16px;top:16px;width:auto;height:auto;z-index:9999;background:#fff;border:var(--border);padding:10px 14px;border-radius:999px;box-shadow:var(--shadow-soft)}

.container{max-width:var(--max);margin:0 auto;padding:0 22px}

/* =========================
   Top bar
   ========================= */
.topbar{
  background:linear-gradient(90deg, #1b1518 0%, #2a1f25 50%, #1b1518 100%);
  color:#f7e9df;
  font-size:12.5px;
  letter-spacing:.06em;
  padding:9px 0;
  position:relative;overflow:hidden;
}
.topbar__row{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.topbar__row span{display:inline-flex;align-items:center;gap:8px;opacity:.95}
.topbar__row b{color:#ffd9ec;font-weight:800}

/* Header */
.header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(27,21,24,.06);
}
.header__inner{
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;
  min-height:84px;gap:18px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg, rgba(255,77,166,.12) 0%, rgba(215,180,106,.18) 100%);
  border:1px solid rgba(27,21,24,.08);
  box-shadow: 0 14px 30px rgba(255,77,166,.18);
  overflow:hidden;
}
.brand__mark--text{
  background:linear-gradient(135deg, var(--pink) 0%, var(--gold) 130%);
  color:#fff;font-weight:900;letter-spacing:.08em;font-size:14px;
}
.brand__logo{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:4px;
  display:block;
}
.brand__name{font-family:"Playfair Display", serif;font-size:22px;font-weight:700;line-height:1}
.brand__sub{font-size:11px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;margin-top:4px}
.brand__txt{display:flex;flex-direction:column}

.nav{display:flex;align-items:center;gap:6px;justify-content:center}
.nav__link{
  padding:12px 14px;border-radius:999px;font-weight:600;color:rgba(27,21,24,.78);
  font-size:14.5px;
  position:relative;
  transition: color .2s var(--easing), background .2s var(--easing);
}
.nav__link::after{
  content:"";position:absolute;left:14px;right:14px;bottom:6px;height:2px;
  background:linear-gradient(90deg, var(--pink), var(--gold));
  border-radius:2px;transform:scaleX(0);transform-origin:left;
  transition: transform .25s var(--easing);
}
.nav__link:hover{color:var(--ink)}
.nav__link:hover::after,
.nav__link.is-active::after{transform:scaleX(1)}
.nav__link.is-active{color:var(--pink-deep)}

.header__actions{display:flex;align-items:center;gap:8px;justify-self:end}
.icon-btn{
  width:44px;height:44px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  border:var(--border);background:rgba(255,255,255,.7);
  transition: transform .2s var(--easing), background .2s var(--easing);
}
.icon-btn:hover{transform: translateY(-1px);background:rgba(255,77,166,.10)}
.icon-btn svg{width:18px;height:18px;color:var(--ink)}

.nav__cta{
  padding:12px 18px;border-radius:999px;
  background:linear-gradient(135deg, var(--pink) 0%, #ff2f90 60%, var(--gold) 160%);
  color:#fff;font-weight:800;font-size:14px;letter-spacing:.02em;
  box-shadow: 0 18px 40px rgba(255,77,166,.26);
  transition: transform .2s var(--easing), box-shadow .2s var(--easing), filter .2s var(--easing);
  display:inline-flex;align-items:center;gap:8px;
}
.nav__cta:hover{transform: translateY(-2px);filter:saturate(1.05);box-shadow: 0 22px 52px rgba(255,77,166,.34)}
.nav__cta svg{width:16px;height:16px}

.nav__toggle{display:none;border:var(--border);background:rgba(255,255,255,.7);border-radius:14px;width:46px;height:46px;align-items:center;justify-content:center;padding:10px;cursor:pointer}
.nav__toggle span{display:block;height:2px;background:rgba(27,21,24,.85);border-radius:2px;transition: transform .25s var(--easing), opacity .2s var(--easing)}
.nav__toggle span:nth-child(1){width:18px}
.nav__toggle span:nth-child(2){width:22px;margin:6px 0}
.nav__toggle span:nth-child(3){width:14px}
.nav.is-open ~ .nav__toggle span:nth-child(2){opacity:0}

main{display:block}

/* =========================
   Buttons
   ========================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border-radius:999px;
  padding:14px 22px;
  border:1px solid rgba(27,21,24,.10);
  font-weight:700;font-size:14.5px;letter-spacing:.02em;
  background:#fff;color:var(--ink);
  transition: transform .2s var(--easing), box-shadow .2s var(--easing), background .2s var(--easing), color .2s var(--easing), border-color .2s var(--easing);
  cursor:pointer;user-select:none;
}
.btn:hover{transform: translateY(-2px)}
.btn--primary{
  border:none;color:#fff;
  background:linear-gradient(135deg, var(--pink) 0%, #ff2f90 60%, var(--gold) 160%);
  box-shadow: 0 18px 40px rgba(255,77,166,.26);
}
.btn--primary:hover{box-shadow: 0 22px 52px rgba(255,77,166,.34)}
.btn--dark{background:var(--ink);color:#fff;border-color:transparent}
.btn--dark:hover{background:#000}
.btn--soft{background:rgba(255,77,166,.10);border:1px solid rgba(255,77,166,.22);color:var(--pink-deep)}
.btn--soft:hover{background:rgba(255,77,166,.16)}
.btn--ghost{background:rgba(255,255,255,.6)}
.btn--ghost:hover{border-color:rgba(215,180,106,.45)}
.btn svg{width:16px;height:16px}
.btn--lg{padding:16px 26px;font-size:15px}
.btn--xl{padding:18px 28px;font-size:16px}

.tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12.5px;color:rgba(27,21,24,.78);
  background:rgba(246,230,223,.75);
  border:1px solid rgba(27,21,24,.06);
  padding:8px 12px;border-radius:999px;font-weight:600;letter-spacing:.04em;
}
.tag__dot{width:8px;height:8px;border-radius:999px;background:linear-gradient(135deg, var(--pink), var(--gold))}

/* =========================
   Marquee
   ========================= */
.marquee{
  background:linear-gradient(90deg, #ff4da6 0%, #ff2f90 50%, #d7b46a 100%);
  color:#fff;
  padding:12px 0;
  overflow:hidden;
  position:relative;
}
.marquee__track{
  display:flex;gap:48px;
  width:max-content;
  animation: marquee 36s linear infinite;
  font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:13px;
  white-space:nowrap;
}
.marquee__track span{display:inline-flex;align-items:center;gap:14px}
.marquee__track svg{width:14px;height:14px;opacity:.9}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* =========================
   HERO
   ========================= */
.hero{
  position:relative;
  padding:60px 0 30px;
  background:
    radial-gradient(900px 420px at 12% 8%, rgba(255,77,166,.20), transparent 60%),
    radial-gradient(900px 480px at 95% 12%, rgba(215,180,106,.20), transparent 65%),
    radial-gradient(700px 600px at 50% 110%, rgba(246,230,223,.85), transparent 70%),
    linear-gradient(180deg, #fff 0%, #fff7fb 60%, #ffffff 100%);
  overflow:hidden;
}
.hero::before, .hero::after{
  content:"";position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;
}
.hero::before{
  top:-120px;left:-100px;width:340px;height:340px;
  background:radial-gradient(circle, rgba(255,77,166,.55), transparent 70%);
  animation: float 12s ease-in-out infinite;
}
.hero::after{
  bottom:-160px;right:-120px;width:380px;height:380px;
  background:radial-gradient(circle, rgba(215,180,106,.50), transparent 70%);
  animation: float 14s ease-in-out -3s infinite;
}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(20px,-20px) scale(1.05)}
}

.hero__inner{
  display:grid;grid-template-columns: 1.05fr .95fr;gap:30px;align-items:center;
  position:relative;z-index:1;
}
.hero__badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(27,21,24,.08);
  font-size:13px;color:var(--ink-2);font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;
  box-shadow: var(--shadow-soft-2);
}
.hero__badge .pulse{position:relative;display:inline-flex;width:10px;height:10px}
.hero__badge .pulse::before, .hero__badge .pulse::after{
  content:"";position:absolute;inset:0;border-radius:999px;background:var(--pink);
}
.hero__badge .pulse::after{animation:pulse 1.6s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(2.6);opacity:0}}

.hero h1{
  font-size: clamp(40px, 6.4vw, 84px);
  font-weight:700;
  margin:18px 0 14px;
  letter-spacing:-.02em;
}
.hero h1 .accent{
  background: linear-gradient(135deg, var(--pink) 0%, var(--pink-deep) 50%, var(--gold) 120%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-style:italic;
}
.hero p.lead{
  margin:0 0 22px;color:rgba(27,21,24,.72);
  font-size: clamp(15.5px, 1.4vw, 18px);
  max-width: 56ch;line-height:1.65;
}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.hero__meta{display:flex;flex-wrap:wrap;gap:18px;margin-top:24px;align-items:center}
.hero__meta .meta{
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:rgba(27,21,24,.74);
}
.hero__meta .meta strong{color:var(--ink);font-weight:800}
.hero__meta .star{
  width:16px;height:16px;color:var(--gold-2);
  filter: drop-shadow(0 4px 8px rgba(215,180,106,.45));
}

.hero__art{
  position:relative;
  height:100%;
  min-height:520px;
  display:flex;align-items:center;justify-content:center;
}
.hero__photo{
  position:relative;
  width:100%;
  max-width:520px;
  aspect-ratio: 4/5;
  border-radius:36px;
  background:
    radial-gradient(140% 70% at 50% -10%, rgba(255,77,166,.28), transparent 60%),
    radial-gradient(120% 70% at 50% 110%, rgba(215,180,106,.28), transparent 65%),
    linear-gradient(160deg, #ffd0e6 0%, #fbeee8 45%, #f0d9c0 100%);
  box-shadow: 0 40px 90px rgba(214,53,127,.22), 0 14px 26px rgba(20,12,18,.10);
  border: 1px solid rgba(255,255,255,.6);
  overflow:hidden;
}
.hero__photo svg{position:absolute;inset:0;width:100%;height:100%}
.hero__photo .frame{
  position:absolute;inset:18px;border-radius:28px;border:1px dashed rgba(27,21,24,.16);
}
.hero__chip{
  position:absolute;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(27,21,24,.06);
  border-radius:18px;
  padding:12px 14px;
  display:flex;align-items:center;gap:12px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.hero__chip--tl{top:24px;left:-22px}
.hero__chip--br{bottom:30px;right:-26px}
.hero__chip__icon{
  width:38px;height:38px;border-radius:12px;
  background:linear-gradient(135deg, rgba(255,77,166,.16), rgba(215,180,106,.20));
  display:flex;align-items:center;justify-content:center;
}
.hero__chip__icon svg{width:18px;height:18px;color:var(--ink)}
.hero__chip__txt{display:flex;flex-direction:column;line-height:1.2}
.hero__chip__txt b{font-weight:800;font-size:13px}
.hero__chip__txt span{color:var(--muted);font-size:11.5px}

/* =========================
   Section base
   ========================= */
.section{padding:70px 0}
.section--tight{padding:48px 0}
.section__head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:22px;
  margin-bottom:26px;
}
.section__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12.5px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--pink-deep);
  margin-bottom:10px;
}
.section__eyebrow::before{content:"";width:24px;height:2px;background:linear-gradient(90deg,var(--pink),var(--gold));border-radius:2px}
.section__title{
  font-size: clamp(28px, 3.6vw, 48px);
  font-weight:700;margin:0;letter-spacing:-.01em;
}
.section__desc{margin:10px 0 0;color:rgba(27,21,24,.72);max-width:62ch;line-height:1.65}
.section__head .right{flex-shrink:0}

/* =========================
   Mother's Day banner
   ========================= */
.mothers{
  position:relative;
  padding:0;
}
.mothers__inner{
  position:relative;
  border-radius: var(--radius-xl);
  overflow:hidden;
  background:
    radial-gradient(700px 400px at 80% 30%, rgba(215,180,106,.30), transparent 60%),
    linear-gradient(135deg, #ff4da6 0%, #d6357f 50%, #8b1f4d 110%);
  color:#fff;
  padding: 60px 50px;
  display:grid;grid-template-columns: 1.15fr .85fr;gap:30px;align-items:center;
  box-shadow: 0 40px 90px rgba(214,53,127,.32);
}
.mothers__inner::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(40px 40px at 12% 22%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(30px 30px at 22% 70%, rgba(255,255,255,.4), transparent 60%),
    radial-gradient(50px 50px at 78% 80%, rgba(255,255,255,.35), transparent 60%),
    radial-gradient(35px 35px at 62% 25%, rgba(255,255,255,.45), transparent 60%);
  opacity:.6;pointer-events:none;
}
.mothers__copy{position:relative;z-index:1}
.mothers__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);
  padding:8px 14px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  backdrop-filter: blur(8px);
}
.mothers h2{
  font-family:"Playfair Display", serif;
  font-size: clamp(34px, 4vw, 58px);
  font-weight:700;margin:18px 0 12px;line-height:1.05;
}
.mothers p{font-size:16.5px;line-height:1.7;color:rgba(255,255,255,.92);max-width:50ch;margin:0 0 22px}
.mothers__actions{display:flex;flex-wrap:wrap;gap:12px}
.mothers .btn--ghost{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.28);backdrop-filter:blur(6px)}
.mothers .btn--ghost:hover{background:rgba(255,255,255,.22)}
.mothers .btn--white{background:#fff;color:var(--pink-deep);border-color:transparent}
.mothers .btn--white:hover{box-shadow:0 16px 40px rgba(0,0,0,.18)}

.mothers__count{
  display:flex;gap:10px;margin-top:26px;
}
.mothers__count .cell{
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  padding:10px 14px;border-radius:14px;text-align:center;
  min-width:64px;backdrop-filter: blur(6px);
}
.mothers__count .cell b{display:block;font-size:22px;font-weight:800;font-family:"Playfair Display",serif;line-height:1}
.mothers__count .cell span{display:block;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-top:6px}

.mothers__art{
  position:relative;z-index:1;height:100%;display:flex;align-items:center;justify-content:center;
}
.mothers__art-card{
  width:100%;max-width:380px;aspect-ratio: 4/5;border-radius:24px;
  background: linear-gradient(160deg, #ffe6f0 0%, #fbeee8 50%, #f0d9c0 100%);
  border:1px solid rgba(255,255,255,.55);
  position:relative;overflow:hidden;
  box-shadow: 0 30px 60px rgba(0,0,0,.18);
  transform: rotate(2deg);
  transition: transform .5s var(--easing);
}
.mothers__art-card:hover{transform: rotate(-1deg) translateY(-4px)}
.mothers__art-card svg{position:absolute;inset:0;width:100%;height:100%}

/* =========================
   Categorias
   ========================= */
.cats{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:18px;
}
.cat{
  position:relative;
  border-radius:24px;overflow:hidden;
  border:1px solid rgba(27,21,24,.08);
  background:linear-gradient(160deg, #ffe6f0 0%, #fbeee8 50%, #f0d9c0 100%);
  aspect-ratio: 3/4;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:18px;
  box-shadow: var(--shadow-soft-2);
  transition: transform .4s var(--easing), box-shadow .4s var(--easing);
  cursor:pointer;
}
.cat:hover{transform: translateY(-4px);box-shadow: var(--shadow)}
.cat__art{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  transition: transform .6s var(--easing);
}
.cat:hover .cat__art{transform: scale(1.05)}
.cat__art svg, .cat__art img{width:60%;height:60%;object-fit:contain;opacity:.92}
.cat__bottom{
  position:relative;z-index:1;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(27,21,24,.06);
  border-radius:16px;padding:12px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  backdrop-filter: blur(8px);
}
.cat__name{font-weight:800;font-size:15px}
.cat__arrow{
  width:32px;height:32px;border-radius:999px;
  background:linear-gradient(135deg, var(--pink), var(--gold));
  display:flex;align-items:center;justify-content:center;color:#fff;
  transition: transform .3s var(--easing);
}
.cat:hover .cat__arrow{transform: translateX(2px) rotate(-15deg)}
.cat__arrow svg{width:14px;height:14px}

/* =========================
   Produtos / destaques
   ========================= */
.products{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:18px;
}
.product{
  position:relative;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(27,21,24,.08);
  overflow:hidden;
  box-shadow: var(--shadow-soft-2);
  transition: transform .35s var(--easing), box-shadow .35s var(--easing);
  display:flex;flex-direction:column;
}
.product:hover{transform: translateY(-4px);box-shadow: var(--shadow)}
.product__img{
  position:relative;
  aspect-ratio: 4/5;
  overflow:hidden;
  background:linear-gradient(160deg, #ffe6f0 0%, #fbeee8 60%, #f0d9c0 100%);
}
.product__img img{
  width:100%;height:100%;object-fit:cover;
  transition: transform .6s var(--easing);
}
.product:hover .product__img img{transform: scale(1.04)}
.product__badge{
  position:absolute;top:12px;left:12px;
  background:#fff;color:var(--pink-deep);
  padding:6px 10px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  box-shadow: var(--shadow-soft-2);
}
.product__fav{
  position:absolute;top:12px;right:12px;
  width:36px;height:36px;border-radius:999px;
  background:rgba(255,255,255,.9);border:1px solid rgba(27,21,24,.06);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition: transform .25s var(--easing), background .25s var(--easing);
}
.product__fav:hover{transform: scale(1.06);background:#fff}
.product__fav svg{width:16px;height:16px;color:var(--ink)}

.product__body{padding:14px 14px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.product__name{font-family:"Playfair Display", serif;font-size:18px;font-weight:700;margin:0;letter-spacing:-.005em}
.product__cat{color:var(--muted);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:700}
.product__meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto}
.price{font-family:"Playfair Display", serif;font-size:22px;font-weight:700;letter-spacing:-.01em}
.price small{font-size:12px;color:var(--muted);font-weight:500;font-family:Inter, sans-serif;margin-right:4px}
.product__buy{
  border:none;cursor:pointer;
  width:42px;height:42px;border-radius:999px;
  background:linear-gradient(135deg, var(--pink), var(--gold));
  color:#fff;display:flex;align-items:center;justify-content:center;
  transition: transform .25s var(--easing), box-shadow .25s var(--easing);
  box-shadow: 0 12px 24px rgba(255,77,166,.30);
}
.product__buy:hover{transform: rotate(-12deg) scale(1.06);box-shadow: 0 16px 32px rgba(255,77,166,.36)}
.product__buy svg{width:18px;height:18px}

/* =========================
   História
   ========================= */
.story{
  display:grid;grid-template-columns: .95fr 1.05fr;gap:36px;align-items:center;
}
.story__art{
  position:relative;
  border-radius: var(--radius-xl);overflow:hidden;
  background: linear-gradient(160deg, #ffe6f0 0%, #fbeee8 50%, #f0d9c0 100%);
  aspect-ratio: 4/5;
  border:1px solid rgba(27,21,24,.06);
  box-shadow: var(--shadow);
}
.story__art svg{position:absolute;inset:0;width:100%;height:100%}
.story__copy h2{font-size: clamp(28px, 3.4vw, 46px);font-weight:700;margin:6px 0 14px}
.story__copy p{color:rgba(27,21,24,.74);line-height:1.85;font-size:15.5px;margin:10px 0 0}
.story__features{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:22px}
.story__features .feat{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px;border-radius:16px;background:rgba(246,230,223,.55);border:1px solid rgba(27,21,24,.06);
}
.story__features .feat svg{width:20px;height:20px;color:var(--pink-deep);flex-shrink:0;margin-top:2px}
.story__features .feat b{font-size:14px;font-weight:800}
.story__features .feat span{display:block;color:var(--muted);font-size:12.5px;margin-top:2px}

/* =========================
   Testemunhos
   ========================= */
.testi{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.testi__card{
  background:#fff;border:1px solid rgba(27,21,24,.08);
  border-radius:24px;padding:22px;
  box-shadow: var(--shadow-soft-2);
  transition: transform .3s var(--easing), box-shadow .3s var(--easing);
}
.testi__card:hover{transform: translateY(-3px);box-shadow:var(--shadow)}
.testi__stars{display:flex;gap:2px;margin-bottom:10px;color:var(--gold-2)}
.testi__stars svg{width:16px;height:16px}
.testi__text{font-family:"Playfair Display", serif;font-size:18px;line-height:1.55;color:var(--ink-2);margin:0 0 16px}
.testi__author{display:flex;gap:12px;align-items:center}
.testi__avatar{
  width:44px;height:44px;border-radius:999px;
  background: linear-gradient(135deg, #ffd0e6, #f0d9c0);
  display:flex;align-items:center;justify-content:center;
  color:var(--pink-deep);font-weight:900;font-size:14px;
  border:1px solid rgba(27,21,24,.06);
}
.testi__name{font-weight:800;font-size:14px}
.testi__role{color:var(--muted);font-size:12.5px}

/* =========================
   Insta grid
   ========================= */
.insta{
  display:grid;grid-template-columns:repeat(6, 1fr);gap:8px;
}
.insta__item{
  position:relative;aspect-ratio:1/1;border-radius:14px;overflow:hidden;
  background: linear-gradient(160deg, #ffe6f0 0%, #fbeee8 50%, #f0d9c0 100%);
  border:1px solid rgba(27,21,24,.06);
  cursor:pointer;
  transition: transform .35s var(--easing);
}
.insta__item:hover{transform: scale(1.02)}
.insta__item svg{position:absolute;inset:0;width:100%;height:100%}
.insta__item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.35));
  opacity:0;transition: opacity .25s var(--easing);
}
.insta__item:hover::after{opacity:1}
.insta__overlay{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#fff;opacity:0;transition: opacity .25s var(--easing);z-index:1;
}
.insta__item:hover .insta__overlay{opacity:1}
.insta__overlay svg{width:24px;height:24px;position:static}

/* =========================
   Newsletter / CTA
   ========================= */
.newsletter{
  position:relative;
  border-radius: var(--radius-xl);
  background:
    radial-gradient(700px 400px at 90% 100%, rgba(215,180,106,.35), transparent 60%),
    linear-gradient(135deg, #1b1518 0%, #2a1f25 50%, #1b1518 100%);
  color:#fff;
  padding:60px 50px;
  overflow:hidden;
  box-shadow: var(--shadow);
}
.newsletter::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(40px 40px at 12% 22%, rgba(255,77,166,.6), transparent 60%),
    radial-gradient(40px 40px at 70% 28%, rgba(215,180,106,.6), transparent 60%);
  opacity:.6;pointer-events:none;
}
.newsletter__grid{position:relative;z-index:1;display:grid;grid-template-columns: 1fr 1fr;gap:30px;align-items:center}
.newsletter h2{font-size: clamp(28px, 3.4vw, 44px);font-weight:700;margin:8px 0 8px}
.newsletter p{color:rgba(255,255,255,.78);max-width:46ch;line-height:1.7}
.newsletter__form{display:flex;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:8px;backdrop-filter:blur(8px)}
.newsletter__form input{
  flex:1;border:none;outline:none;background:transparent;color:#fff;
  padding:10px 14px;font-size:15px;font-family:inherit;
}
.newsletter__form input::placeholder{color:rgba(255,255,255,.55)}
.newsletter__form button{padding:12px 20px}

/* =========================
   Footer
   ========================= */
.footer{
  margin-top:50px;
  background:#15101280;
  background:linear-gradient(180deg, #fff 0%, #fbeee8 100%);
  border-top:1px solid rgba(27,21,24,.06);
  padding:50px 0 30px;
}
.footer__grid{
  display:grid;grid-template-columns: 1.4fr .7fr .7fr 1fr;gap:30px;
}
.footer__brand{font-family:"Playfair Display", serif;font-weight:800;font-size:24px;margin:0 0 8px}
.footer__text{color:rgba(27,21,24,.72);margin:6px 0 16px;line-height:1.7;font-size:14.5px}
.footer__title{font-weight:800;margin-bottom:14px;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2)}
.footer__link{display:block;color:rgba(27,21,24,.72);padding:6px 0;font-size:14px;transition: color .2s var(--easing)}
.footer__link:hover{color:var(--pink-deep)}
.footer__social{display:flex;gap:8px;margin-top:8px}
.footer__social a{
  width:38px;height:38px;border-radius:12px;
  background:#fff;border:1px solid rgba(27,21,24,.08);
  display:flex;align-items:center;justify-content:center;
  transition: transform .25s var(--easing), background .25s var(--easing), color .25s var(--easing);
  color:var(--ink-2);
}
.footer__social a:hover{transform: translateY(-2px);background:var(--ink);color:#fff}
.footer__social svg{width:16px;height:16px}
.footer__bottom{
  margin-top:30px;padding-top:18px;border-top:1px solid rgba(27,21,24,.08);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  color:var(--muted);font-size:12.5px;
}

/* =========================
   WhatsApp FAB
   ========================= */
.whats-fab{
  position:fixed;right:16px;bottom:16px;z-index:80;
  display:flex;align-items:center;gap:10px;
  border-radius:999px;padding:14px 16px;
  background:linear-gradient(135deg, #1fbf5b 0%, #14a44d 60%, rgba(215,180,106,.85) 160%);
  color:#fff;font-weight:800;letter-spacing:.02em;
  box-shadow: 0 18px 40px rgba(20,164,77,.30);
  border:1px solid rgba(255,255,255,.28);
  transition: transform .25s var(--easing), filter .25s var(--easing);
}
.whats-fab:hover{transform: translateY(-2px) scale(1.02);filter:saturate(1.06)}
.whats-fab svg{width:20px;height:20px}

/* =========================
   Reveal
   ========================= */
[data-reveal]{opacity:0;transform: translateY(20px);transition: opacity .9s var(--easing), transform .9s var(--easing)}
[data-reveal].is-visible{opacity:1;transform:none}
[data-reveal="fade"]{transform:translateY(14px)}
[data-reveal="left"]{transform:translateX(-24px)}
[data-reveal="right"]{transform:translateX(24px)}
[data-reveal="zoom"]{transform:scale(.96)}
[data-reveal].is-visible{transform:translate(0,0) scale(1)}

/* Stagger children */
[data-reveal-stagger] > *{opacity:0;transform:translateY(18px);transition: opacity .8s var(--easing), transform .8s var(--easing)}
[data-reveal-stagger].is-visible > *{opacity:1;transform:none}
[data-reveal-stagger].is-visible > *:nth-child(1){transition-delay:.05s}
[data-reveal-stagger].is-visible > *:nth-child(2){transition-delay:.13s}
[data-reveal-stagger].is-visible > *:nth-child(3){transition-delay:.21s}
[data-reveal-stagger].is-visible > *:nth-child(4){transition-delay:.29s}
[data-reveal-stagger].is-visible > *:nth-child(5){transition-delay:.37s}
[data-reveal-stagger].is-visible > *:nth-child(6){transition-delay:.45s}

/* =========================
   Page heads (loja/sobre/contato)
   ========================= */
.page-head{
  position:relative;
  padding: 70px 0 40px;
  background:
    radial-gradient(700px 380px at 12% 0%, rgba(255,77,166,.18), transparent 60%),
    radial-gradient(700px 400px at 95% 30%, rgba(215,180,106,.18), transparent 65%),
    linear-gradient(180deg, #fff 0%, #fff7fb 100%);
  overflow:hidden;
}
.page-head__crumbs{font-size:12.5px;color:var(--muted);letter-spacing:.06em;display:flex;gap:8px;align-items:center}
.page-head__crumbs a{color:var(--ink-2)}
.page-head__crumbs a:hover{color:var(--pink-deep)}
.page-head__crumbs svg{width:12px;height:12px;opacity:.6}
.page-head h1{font-size: clamp(36px, 5vw, 64px);font-weight:700;margin:14px 0 10px;letter-spacing:-.01em}
.page-head p{margin:0;color:rgba(27,21,24,.74);font-size: clamp(15px, 1.3vw, 17px);max-width:60ch;line-height:1.7}

/* Loja filtros */
.shop-bar{
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between;
  padding:14px 18px;background:#fff;border:1px solid rgba(27,21,24,.06);border-radius:18px;box-shadow: var(--shadow-soft-2);
  margin-bottom:22px;
}
.shop-bar__chips{display:flex;gap:8px;flex-wrap:wrap}
.chip-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:rgba(246,230,223,.6);border:1px solid rgba(27,21,24,.06);
  font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer;
  transition: background .2s var(--easing), color .2s var(--easing), transform .2s var(--easing);
}
.chip-pill:hover{transform:translateY(-1px)}
.chip-pill.is-active{background:var(--ink);color:#fff;border-color:transparent}

/* Form */
.form{background:#fff;border:1px solid rgba(27,21,24,.08);border-radius:24px;padding:22px;box-shadow:var(--shadow-soft);display:grid;gap:14px}
.field{display:grid;gap:6px}
.field label{font-weight:700;font-size:13px;letter-spacing:.04em;color:var(--ink-2)}
.field input,.field textarea{
  width:100%;padding:14px;border-radius:14px;border:1px solid rgba(27,21,24,.12);
  background:#fff;outline:none;font-family:inherit;font-size:14.5px;
  transition: border-color .2s var(--easing), box-shadow .2s var(--easing);
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus{border-color: rgba(255,77,166,.55);box-shadow: 0 0 0 4px rgba(255,77,166,.14)}

.notice{
  border-radius:16px;border:1px solid rgba(27,21,24,.10);background:rgba(246,230,223,.65);
  padding:14px;color:rgba(27,21,24,.78);
}
.notice--ok{background:rgba(31,191,91,.10);border-color: rgba(31,191,91,.28)}
.notice--bad{background:rgba(214,53,127,.08);border-color: rgba(214,53,127,.20)}

/* Admin table */
.admin-wrap{padding:26px 0}
.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid rgba(27,21,24,.08);border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft-2)}
.table th,.table td{padding:14px 12px;border-bottom:1px solid rgba(27,21,24,.06);text-align:left;font-size:13.5px}
.table th{font-weight:900;color:var(--ink-2);background:rgba(246,230,223,.55);letter-spacing:.04em}
.table tr:last-child td{border-bottom:none}
.admin-actions{display:flex;gap:8px;flex-wrap:wrap}

/* =========================
   Responsivo
   ========================= */
@media (max-width: 1100px){
  .cats{grid-template-columns:repeat(3, 1fr)}
  .products{grid-template-columns:repeat(3, 1fr)}
  .insta{grid-template-columns:repeat(4, 1fr)}
  .footer__grid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width: 920px){
  .hero{padding:46px 0 24px}
  .hero__inner{grid-template-columns:1fr;gap:24px}
  .hero__art{min-height:auto}
  .mothers__inner{grid-template-columns:1fr;padding:40px 26px;text-align:center}
  .mothers__copy{display:flex;flex-direction:column;align-items:center}
  .mothers__count{justify-content:center}
  .story{grid-template-columns:1fr}
  .newsletter{padding:40px 26px}
  .newsletter__grid{grid-template-columns:1fr}
  .testi{grid-template-columns:1fr}
  .cats{grid-template-columns:repeat(2, 1fr)}
  .products{grid-template-columns:repeat(2, 1fr)}
  .insta{grid-template-columns:repeat(3, 1fr)}
  .section{padding:50px 0}
  .header__inner{grid-template-columns:auto auto}
  .nav{
    position:fixed;left:14px;right:14px;top:90px;
    background:#fff;border:1px solid rgba(27,21,24,.08);border-radius:22px;
    box-shadow: var(--shadow);
    padding:14px;flex-direction:column;align-items:stretch;gap:6px;
    display:none;z-index:90;
  }
  .nav.is-open{display:flex}
  .nav__link, .nav__cta{justify-content:center;width:100%}
  .nav__toggle{display:inline-flex}
  .header__actions{order:3}
}
@media (max-width: 560px){
  .footer__grid{grid-template-columns:1fr}
  .insta{grid-template-columns:repeat(2, 1fr)}
  .hero__chip--tl{left:8px}
  .hero__chip--br{right:8px}
}

/* =========================
   Chip (checkbox-label + pill)
   ========================= */
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:999px;
  background:rgba(246,230,223,.72);
  border:1px solid rgba(27,21,24,.09);
  color:var(--ink-2);font-size:13px;font-weight:600;
  cursor:pointer;user-select:none;
  transition: background .18s var(--easing), border-color .18s var(--easing);
}
.chip input[type="checkbox"]{accent-color:var(--pink);width:15px;height:15px}
.chip:has(input:checked){background:rgba(255,77,166,.12);border-color:rgba(255,77,166,.3);color:var(--pink-deep)}
/* grid helpers for admin forms */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
/* admin nav breadcrumb */
.admin-bc{font-size:13px;color:rgba(30,26,28,.5);margin:0 0 6px}
.admin-bc a{color:var(--pink-deep);font-weight:600}
/* upload zone */
.upload-zone{
  border:2px dashed rgba(255,77,166,.35);
  border-radius:18px;background:rgba(255,77,166,.04);
  padding:30px 20px;text-align:center;cursor:pointer;
  transition: border-color .2s var(--easing), background .2s var(--easing);
}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--pink);background:rgba(255,77,166,.09)}
.upload-zone input[type="file"]{display:none}
/* gallery grid */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
.media-item{
  position:relative;border-radius:14px;overflow:hidden;
  border:1px solid rgba(27,21,24,.08);background:#fafafa;
  aspect-ratio:1/1;
}
.media-item img{width:100%;height:100%;object-fit:cover;display:block}
.media-item__bar{
  position:absolute;bottom:0;left:0;right:0;
  background:rgba(27,21,24,.72);backdrop-filter:blur(6px);
  display:flex;gap:6px;align-items:center;
  padding:7px 8px;
}
.media-item__bar button,.media-item__bar a{
  font-size:11px;color:#fff;font-weight:700;
  background:rgba(255,255,255,.18);border:none;border-radius:6px;
  padding:4px 8px;cursor:pointer;transition:background .15s ease;text-decoration:none;
}
.media-item__bar button:hover,.media-item__bar a:hover{background:rgba(255,255,255,.32)}
.media-item__bar button.del{background:rgba(214,53,127,.55)}
.media-item__bar button.del:hover{background:rgba(214,53,127,.8)}
.media-item__name{
  position:absolute;top:6px;left:6px;
  font-size:10px;background:rgba(255,255,255,.82);border-radius:6px;padding:3px 6px;
  color:var(--ink-2);max-width:calc(100% - 12px);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
/* dimension guide table */
.dim-table{width:100%;border-collapse:collapse;font-size:13px}
.dim-table th,.dim-table td{padding:10px 12px;border-bottom:1px solid rgba(27,21,24,.06);text-align:left}
.dim-table th{font-weight:800;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);background:rgba(246,230,223,.55)}
.dim-table td:last-child{color:rgba(27,21,24,.6)}
.dim-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,77,166,.1);border-radius:8px;padding:4px 8px;font-weight:700;color:var(--pink-deep);font-size:12px}
/* color swatch preview */
.swatch-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:6px}
.swatch{width:36px;height:36px;border-radius:10px;border:2px solid rgba(27,21,24,.12);cursor:pointer;transition:transform .15s ease}
.swatch:hover{transform:scale(1.1)}
/* tab nav */
.tab-nav{display:flex;gap:4px;border-bottom:2px solid rgba(27,21,24,.08);margin-bottom:22px;flex-wrap:wrap}
.tab-btn{
  padding:12px 18px;border:none;background:none;font-weight:700;font-size:14px;
  color:rgba(27,21,24,.55);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;
  transition: color .2s ease, border-color .2s ease;border-radius:8px 8px 0 0;
}
.tab-btn.is-active{color:var(--pink-deep);border-bottom-color:var(--pink)}
.tab-pane{display:none}
.tab-pane.is-active{display:block}
/* painel stats */
.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-bottom:24px}
.stat-card{
  background:#fff;border:1px solid rgba(27,21,24,.08);border-radius:20px;
  padding:18px 20px;box-shadow:var(--shadow-soft-2);
  display:flex;flex-direction:column;gap:6px;
}
.stat-card__label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(27,21,24,.55)}
.stat-card__value{font-family:var(--font-heading,"Playfair Display"),Georgia,serif;font-size:32px;font-weight:700;line-height:1}
.stat-card__sub{font-size:12px;color:rgba(27,21,24,.5)}
/* nav card grid in painel */
.area-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.area-card{
  padding:24px;text-decoration:none;color:inherit;display:block;
  border:1px solid rgba(27,21,24,.08);border-radius:22px;
  box-shadow:0 8px 24px rgba(27,21,24,.06);background:#fff;
  transition:transform .25s var(--easing),box-shadow .25s var(--easing);
}
.area-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.area-card__icon{
  width:48px;height:48px;border-radius:14px;margin-bottom:14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(255,77,166,.14),rgba(215,180,106,.18));
}
.area-card__icon svg{width:22px;height:22px;color:var(--pink-deep)}
.area-card h2{font-size:1.15rem;margin:0 0 6px}
.area-card p{margin:0;color:rgba(30,26,28,.62);line-height:1.55;font-size:13.5px}
.area-card__badge{
  display:inline-block;margin-top:14px;
  background:rgba(255,77,166,.1);border-radius:999px;
  padding:5px 12px;font-size:12px;font-weight:800;color:var(--pink-deep);
}

/* Hero carousel (admin / campanhas) */
.hero__dots{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;align-items:center}
.hero__dots[hidden]{display:none !important}
.hero__dot{
  width:10px;height:10px;border-radius:999px;border:0;padding:0;cursor:pointer;
  background:rgba(27,21,24,.22);transition:transform .2s ease,background .2s ease;
}
.hero__dot.is-active{background:#ff4da6;transform:scale(1.12)}
.hero__dot:focus-visible{outline:2px solid #ff4da6;outline-offset:2px}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  [data-reveal],[data-reveal-stagger] > *{opacity:1 !important;transform:none !important}
}
