/* ========== VIVI COSMÉTICOS — DESIGN SYSTEM ========== */
:root{
  --pink-50:#fff5fa;
  --pink-100:#ffe4f1;
  --pink-200:#ffc8e1;
  --pink-300:#ff9bc9;
  --pink-400:#ff6fb3;
  --pink-500:#ff3d99;
  --pink-600:#e91e7a;
  --pink-700:#b8155f;
  --rose:#ff8ab8;
  --cream:#fff9f4;
  --ink:#2a1024;
  --muted:#7a5a6c;
  --white:#ffffff;
  --gradient-primary: linear-gradient(135deg,#ff6fb3 0%, #ff3d99 50%, #e91e7a 100%);
  --gradient-soft: linear-gradient(135deg,#fff5fa 0%, #ffe4f1 100%);
  --gradient-glow: radial-gradient(circle at 30% 20%, #ffc8e1 0%, transparent 60%);
  --shadow-soft: 0 10px 30px -10px rgba(233,30,122,.25);
  --shadow-glow: 0 20px 60px -20px rgba(255,61,153,.4);
  --radius: 18px;
  --radius-lg: 28px;
}

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

.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ===== TYPOGRAPHY ===== */
h1,h2,h3,h4{font-weight:700;line-height:1.15;letter-spacing:-.02em}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.8rem)}
h3{font-size:1.35rem}
.gradient-text{
  background:var(--gradient-primary);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.eyebrow{
  display:inline-block;
  font-size:.85rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--pink-600);margin-bottom:12px;
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border-radius:999px;font-weight:600;font-size:.95rem;
  border:none;cursor:pointer;transition:all .3s ease;
  text-decoration:none;white-space:nowrap;
}
.btn-sm{padding:10px 20px;font-size:.85rem}
.btn-lg{padding:18px 36px;font-size:1.05rem}
.btn-primary{
  background:var(--gradient-primary);color:#fff;
  box-shadow:var(--shadow-soft);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}
.btn-outline{background:transparent;color:var(--pink-600);border:2px solid var(--pink-300)}
.btn-outline:hover{background:var(--pink-100);border-color:var(--pink-500)}
.btn-light{background:#fff;color:var(--pink-600)}
.btn-light:hover{transform:translateY(-2px)}

.badge{
  display:inline-block;
  background:var(--pink-100);color:var(--pink-700);
  padding:8px 16px;border-radius:999px;font-size:.85rem;font-weight:600;
  margin-bottom:20px;
}
.badge-light{background:rgba(255,255,255,.25);color:#fff;backdrop-filter:blur(8px)}

/* ===== HEADER ===== */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,249,244,.85);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,156,202,.2);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:1.15rem}
.brand img{width:42px;height:42px;border-radius:50%;object-fit:cover;box-shadow:var(--shadow-soft)}
.brand em{font-family:'Dancing Script',cursive;font-style:normal;color:var(--pink-600);font-weight:700}
.menu{display:flex;gap:28px}
.menu a{font-weight:500;font-size:.95rem;color:var(--ink);transition:color .2s}
.menu a:hover{color:var(--pink-600)}
.menu-toggle{display:none;background:none;border:none;font-size:1.6rem;color:var(--pink-600);cursor:pointer}

/* ===== HERO ===== */
.hero{
  position:relative;padding:80px 0 100px;overflow:hidden;
  background:var(--gradient-soft);
}
.hero-bg{
  position:absolute;inset:0;
  background:var(--gradient-glow);
  pointer-events:none;
}
.hero-content{
  position:relative;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.hero-text p{font-size:1.1rem;color:var(--muted);margin:20px 0 32px;max-width:520px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:36px;margin-top:48px}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats strong{font-size:1.6rem;color:var(--pink-600)}
.hero-stats span{font-size:.85rem;color:var(--muted)}

.hero-image{position:relative;animation:float 6s ease-in-out infinite}
.hero-image img{
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-glow);
  aspect-ratio:1.6/1;object-fit:cover;
}
.float-card{
  position:absolute;background:#fff;padding:14px 18px;border-radius:16px;
  box-shadow:var(--shadow-soft);font-weight:600;font-size:.95rem;
  animation:float 4s ease-in-out infinite;
}
.float-card small{display:block;color:var(--muted);font-weight:400;font-size:.8rem}
.card-1{top:-20px;left:-30px;animation-delay:.5s}
.card-2{bottom:20px;right:-20px;animation-delay:1s;color:var(--pink-600)}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ===== BENEFITS ===== */
.benefits{
  background:#fff;padding:36px 0;
  border-top:1px solid var(--pink-100);
  border-bottom:1px solid var(--pink-100);
}
.benefits .container{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.benefit{display:flex;align-items:center;gap:14px}
.benefit span{font-size:2rem}
.benefit strong{display:block;font-weight:600;color:var(--ink)}
.benefit p{font-size:.85rem;color:var(--muted)}

/* ===== SECTIONS ===== */
.section{padding:90px 0}
.section-head{text-align:center;max-width:640px;margin:0 auto 56px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}

.sobre p{color:var(--muted);margin:16px 0}
.sobre-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.sobre-card{
  background:#fff;border-radius:var(--radius);padding:36px 24px;text-align:center;
  box-shadow:var(--shadow-soft);transition:transform .3s;
  border:1px solid var(--pink-100);
}
.sobre-card:hover{transform:translateY(-6px)}
.sobre-card h3{font-size:2.5rem;margin-bottom:8px}
.sobre-card p{font-weight:600;color:var(--pink-600)}

/* ===== CATEGORIAS ===== */
.categorias{background:linear-gradient(180deg,var(--cream) 0%,var(--pink-50) 100%)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.cat-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-soft);transition:all .4s;
  border:1px solid rgba(255,156,202,.2);
}
.cat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-glow)}
.cat-card img{width:100%;aspect-ratio:1/1;object-fit:cover}
.cat-body{padding:24px}
.cat-body h3{margin-bottom:8px;color:var(--pink-700)}
.cat-body p{color:var(--muted);font-size:.95rem;margin-bottom:14px}
.price{display:block;font-weight:700;color:var(--pink-600);margin-bottom:16px;font-size:1rem}

/* ===== PROMO ===== */
.promo{background:var(--cream)}
.promo-box{
  background:var(--gradient-primary);
  border-radius:var(--radius-lg);padding:60px;color:#fff;
  display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:center;
  box-shadow:var(--shadow-glow);position:relative;overflow:hidden;
}
.promo-box::before{
  content:'';position:absolute;width:300px;height:300px;border-radius:50%;
  background:rgba(255,255,255,.1);top:-100px;right:-100px;
}
.promo-box h2{color:#fff;margin:14px 0 16px}
.promo-box p{margin-bottom:24px;opacity:.95}
.huge{font-size:1.4em;font-family:'Dancing Script',cursive}
.promo-tags{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.promo-tags span{
  background:#fff;color:var(--pink-600);
  padding:24px 28px;border-radius:50%;font-weight:700;font-size:1.5rem;
  width:90px;height:90px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(0,0,0,.15);
  animation:wobble 3s ease-in-out infinite;
}
.promo-tags span:nth-child(2){animation-delay:.4s;transform:scale(1.15)}
.promo-tags span:nth-child(3){animation-delay:.8s}
@keyframes wobble{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-8px) rotate(3deg)}}
.promo-tags span:nth-child(2){animation-delay:.4s}

/* ===== DEPOIMENTOS ===== */
.depoimentos{background:#fff}
.depo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.depo{
  background:var(--gradient-soft);padding:32px;border-radius:var(--radius);
  border:1px solid var(--pink-100);
}
.depo p{color:var(--ink);font-style:italic;margin-bottom:14px}
.depo strong{color:var(--pink-600)}

/* ===== LOCALIZAÇÃO ===== */
.localizacao{background:var(--pink-50)}
.localizacao p{margin:8px 0;color:var(--muted)}
.localizacao strong{color:var(--ink)}
.map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft);height:380px}
.map iframe{width:100%;height:100%;border:0}

/* ===== CTA FINAL ===== */
.cta-final{
  background:var(--gradient-primary);
  padding:90px 24px;text-align:center;color:#fff;position:relative;overflow:hidden;
}
.cta-final::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 50%, rgba(255,255,255,.15) 0%, transparent 70%);
}
.cta-final h2{color:#fff;margin-bottom:16px;position:relative}
.cta-final .gradient-text{
  background:linear-gradient(135deg,#fff,#ffe4f1);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cta-final p{font-size:1.15rem;margin-bottom:32px;opacity:.95;position:relative}
.cta-final .btn{position:relative;background:#fff;color:var(--pink-600)}

/* ===== FOOTER ===== */
.footer{background:var(--ink);color:#fff;padding:60px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer .brand{margin-bottom:14px;color:#fff}
.footer .brand em{color:var(--pink-300)}
.footer p{color:rgba(255,255,255,.7);font-size:.92rem;margin:6px 0}
.footer h4{margin-bottom:14px;color:var(--pink-300)}
.footer a{display:block;color:rgba(255,255,255,.7);margin:6px 0;font-size:.92rem;transition:color .2s}
.footer a:hover{color:var(--pink-300)}
.copy{text-align:center;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.5);font-size:.85rem}

/* ===== WHATSAPP FLOAT ===== */
.wpp-float{
  position:fixed;bottom:24px;right:24px;z-index:60;
  width:60px;height:60px;border-radius:50%;
  background:#25d366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(37,211,102,.5);
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 10px 30px rgba(37,211,102,.5)}50%{box-shadow:0 10px 40px rgba(37,211,102,.8)}}

/* ===== REVEAL ANIMATION ===== */
.reveal{opacity:0;transform:translateY(30px);transition:all .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  .hero-content,.two-col,.promo-box{grid-template-columns:1fr;gap:40px}
  .cat-grid,.depo-grid{grid-template-columns:1fr}
  .benefits .container{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:20px;box-shadow:var(--shadow-soft)}
  .menu.open{display:flex}
  .menu-toggle{display:block}
  .hero{padding:50px 0 70px}
  .section{padding:60px 0}
  .promo-box{padding:40px 28px;text-align:center}
  .hero-stats{gap:20px}
  .float-card{display:none}
}
