/* =====================================================================
   PREMIUM V2 — Home refactor (2026-04-20) — alinhado ao tema roxo/indigo
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ---------- DESIGN TOKENS (cor tema preservada) ---------- */
body.home-page {
  --bg-base: #FAFAF9;
  --bg-soft: #F4F3FA;       /* roxo claríssimo para seções quebrar monotonia */
  --bg-card: #FFFFFF;
  --ink: #0E0E14;
  --ink-soft: #4A4A55;
  --ink-mute: #8B8B99;
  --line: rgba(14,14,20,.08);
  --line-strong: rgba(14,14,20,.14);

  /* Cor tema do site */
  --brand: #4f46e5;         /* indigo primário */
  --brand-deep: #4338ca;    /* hover/ativo */
  --brand-violet: #7c3aed;  /* acento violeta */
  --brand-soft: #EEF2FF;    /* fundo claro com tinta da marca */
  --brand-grad: linear-gradient(135deg, #7c3aed 0%, #4f46e5 55%, #3b82f6 100%);
  --brand-grad-warm: linear-gradient(135deg, #db2777 0%, #7c3aed 50%, #4f46e5 100%);

  /* Sinal de urgência — quente mas em harmonia com o roxo */
  --signal: #E11D48;        /* rose-600 — urgência alinhada ao roxo */
  --signal-deep: #BE123C;
  --signal-soft: #FFE4E6;
  --flash-grad: linear-gradient(135deg, #E11D48 0%, #9333EA 100%);

  --shadow-card: 0 1px 2px rgba(20,16,60,.04), 0 12px 32px -12px rgba(20,16,60,.10);
  --shadow-hover: 0 2px 4px rgba(20,16,60,.06), 0 20px 48px -16px rgba(79,70,229,.18);
  --shadow-brand: 0 0 0 1px rgba(79,70,229,.18), 0 14px 40px -14px rgba(79,70,229,.35);

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-ui: "Inter", "Manrope", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;

  --radius-sm: 6px;
  --radius: 10px;
  --radius-lg: 16px;
}

body.home-page {
  background: var(--bg-base);
  font-family: var(--font-ui);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body.home-page h1,
body.home-page h2,
body.home-page h3,
body.home-page .sec-title,
body.home-page .premium-section-title {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--ink);
}

body.home-page h2.sec-title,
body.home-page .premium-section-title {
  font-size: clamp(28px, 3.4vw, 42px);
  line-height: 1.1;
}

body.home-page .section .sec-title::before,
body.home-page .flash-section .sec-title::before {
  content: none;
}

/* Eyebrow */
body.home-page .pv2-eyebrow,
body.home-page .premium-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: 14px;
}
body.home-page .pv2-eyebrow::before,
body.home-page .premium-eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--brand);
}

/* ---------- HERO: legibilidade + CTA tema ---------- */
body.home-page .swiper.hero .swiper-slide { position: relative; overflow: hidden; }
body.home-page .swiper.hero .swiper-slide::after {
  content: "";
  position: absolute; inset: auto 0 0 0; height: 60%;
  background: linear-gradient(180deg, rgba(250,250,249,0) 0%, rgba(250,250,249,.2) 40%, rgba(250,250,249,.65) 100%);
  pointer-events: none; z-index: 1;
}

body.home-page .swiper.hero .caption {
  position: relative; z-index: 2; max-width: 680px; padding: 48px;
}
body.home-page .swiper.hero .caption h2 {
  font-family: var(--font-display);
  font-size: clamp(36px, 5.2vw, 64px);
  font-weight: 500; line-height: 1.05;
  letter-spacing: -0.025em; color: var(--ink);
  margin: 0 0 20px;
  text-shadow: 0 1px 2px rgba(250,250,249,.4);
}
body.home-page .swiper.hero .caption .btn {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--brand-grad);
  color: #fff;
  font-family: var(--font-ui); font-weight: 600;
  font-size: 15px; letter-spacing: .02em;
  padding: 14px 28px; border: 0; border-radius: var(--radius);
  box-shadow: 0 8px 20px -4px rgba(79,70,229,.45);
  transition: transform .2s, box-shadow .2s;
  text-decoration: none;
}
body.home-page .swiper.hero .caption .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -6px rgba(79,70,229,.55);
}

body.home-page .swiper.hero .swiper-pagination-bullet {
  width: 24px; height: 2px; border-radius: 1px;
  background: var(--ink-mute); opacity: .5;
  transition: opacity .2s, background .2s;
}
body.home-page .swiper.hero .swiper-pagination-bullet-active {
  background: var(--brand); opacity: 1;
}

/* ---------- TRUST STRIP ---------- */
.pv2-trust-strip {
  background: var(--bg-card);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 28px 0; margin: 0 0 8px;
}
.pv2-trust-strip-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; align-items: center;
}
.pv2-trust-item {
  display: flex; align-items: center; gap: 14px;
  color: var(--ink-soft); font-size: 14px; font-weight: 500;
}
.pv2-trust-item i {
  font-size: 22px;
  background: var(--brand-grad);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  flex-shrink: 0;
}
.pv2-trust-item strong {
  display: block; color: var(--ink); font-weight: 600;
  font-size: 14px; letter-spacing: -0.005em;
}
.pv2-trust-item span {
  display: block; font-size: 12.5px; color: var(--ink-mute);
  font-weight: 400; margin-top: 2px;
}
@media (max-width: 768px) { .pv2-trust-strip-inner { grid-template-columns: repeat(2, 1fr); gap: 20px; } }
@media (max-width: 420px) { .pv2-trust-strip-inner { grid-template-columns: 1fr; } }

/* ---------- FLASH SALE — energia real ---------- */
body.home-page .flash-section {
  position: relative;
  padding: 72px 0 56px;
  background:
    radial-gradient(ellipse at top left, rgba(225,29,72,.08) 0%, transparent 50%),
    radial-gradient(ellipse at bottom right, rgba(124,58,237,.10) 0%, transparent 55%),
    linear-gradient(180deg, #FDFAFC 0%, #F7F4FC 100%);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
/* Granulado sutil — textura viva sem poluir */
body.home-page .flash-section::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(225,29,72,.04) 1px, transparent 1px),
    radial-gradient(circle at 80% 70%, rgba(124,58,237,.04) 1px, transparent 1px);
  background-size: 36px 36px, 48px 48px;
  pointer-events: none;
}

body.home-page .flash-section .container { position: relative; z-index: 1; }

body.home-page .flash-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap; margin-bottom: 36px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(225,29,72,.15);
}

body.home-page .flash-header .sec-title {
  margin: 0;
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--font-display);
  font-size: clamp(30px, 3.4vw, 44px);
  font-weight: 500; letter-spacing: -0.025em;
  line-height: 1;
}
/* Raio com gradiente de fogo */
body.home-page .flash-header .sec-title i {
  font-size: 1.1em;
  background: var(--flash-grad);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 2px 8px rgba(225,29,72,.35));
}
/* Palavra "Flash Sale" em gradiente */
body.home-page .flash-header .sec-title {
  background: var(--flash-grad);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
/* Manter o ícone visível se o browser não suportar clip-text */
@supports not (-webkit-background-clip: text) {
  body.home-page .flash-header .sec-title { color: var(--signal); -webkit-text-fill-color: initial; }
}

/* Selo "AO VIVO" pulsante */
body.home-page .flash-header .sec-title::after {
  content: "AO VIVO";
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-ui);
  font-size: 10px; font-weight: 700; letter-spacing: .15em;
  color: #fff;
  background: var(--signal);
  padding: 4px 9px;
  border-radius: 4px;
  -webkit-text-fill-color: #fff;
  margin-left: 4px;
  box-shadow: 0 0 0 0 rgba(225,29,72,.6);
  animation: pv2-liveBlink 2s infinite;
}
@keyframes pv2-liveBlink {
  0%, 100% { box-shadow: 0 0 0 0 rgba(225,29,72,.6); }
  50%      { box-shadow: 0 0 0 6px rgba(225,29,72,0); }
}

/* Cronômetro dramático em blocos */
body.home-page .flash-timer {
  font-family: var(--font-mono) !important;
  font-size: 20px !important;
  font-weight: 600 !important;
  color: #fff !important;
  background: linear-gradient(135deg, #1a1329 0%, #2d1a4a 100%) !important;
  padding: 10px 18px !important;
  border-radius: var(--radius) !important;
  letter-spacing: .08em !important;
  font-variant-numeric: tabular-nums !important;
  box-shadow:
    0 4px 14px -2px rgba(79,70,229,.4),
    inset 0 1px 0 rgba(255,255,255,.1) !important;
  border: 1px solid rgba(124,58,237,.3) !important;
  animation: none !important;
  position: relative;
}
body.home-page .flash-timer::before {
  content: "Encerra em ";
  font-family: var(--font-ui);
  font-size: 11px; font-weight: 500;
  color: rgba(255,255,255,.6);
  letter-spacing: .15em; text-transform: uppercase;
  margin-right: 8px;
}

/* Swiper flash: espaçamento */
body.home-page .flash-swiper { padding: 4px 0 40px; }

/* Card dentro da flash: halo quente */
body.home-page .flash-section .card {
  border-color: rgba(225,29,72,.12);
  position: relative;
}
body.home-page .flash-section .card::before {
  content: "";
  position: absolute; inset: -1px;
  border-radius: var(--radius-lg);
  padding: 1px;
  background: linear-gradient(135deg, rgba(225,29,72,.25), rgba(124,58,237,.25));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
          mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: 0; transition: opacity .3s;
  pointer-events: none;
}
body.home-page .flash-section .card:hover::before { opacity: 1; }

/* Badge de desconto na flash: quente mas contido */
body.home-page .flash-section .card .discount-badge {
  background: var(--flash-grad) !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: 0 4px 10px -2px rgba(225,29,72,.4) !important;
}
body.home-page .flash-section .card .discount-badge i {
  display: inline-block !important;
  font-size: 11px !important;
  margin-right: 2px;
}

/* ---------- PRODUCT CARD — base ---------- */
body.home-page .card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position: relative;
  display: flex; flex-direction: column;
}
body.home-page .card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(79,70,229,.25);
}

body.home-page .card .media {
  background: linear-gradient(180deg, #fff 0%, #F4F3FA 100%);
  aspect-ratio: 1/1; position: relative; overflow: hidden;
  padding: 18px; display: flex; align-items: center; justify-content: center;
}
body.home-page .card .media img {
  max-width: 100%; max-height: 100%; object-fit: contain;
  filter: drop-shadow(0 10px 24px rgba(20,16,60,.14));
  transition: transform .4s ease;
}
body.home-page .card:hover .media img { transform: scale(1.05); }

/* ---------- VIDEO LAZY REVEAL ---------- */
/* Iframe/video rodam em visibility:hidden (YouTube precisa estar no layout
   para autoplay + postMessage). Ao confirmar PLAYING, viram visible. */
body.home-page .card .media video,
body.home-page .card .media iframe {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
  border: 0;
  z-index: 2;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  transition: opacity .5s ease;
}
body.home-page .card .media video.is-ready,
body.home-page .card .media iframe.is-ready {
  visibility: visible;
  opacity: 1;
}
/* Imagem SEMPRE visivel no z-index 1. Iframe ao ficar ready cobre por cima. */
body.home-page .card .media img {
  position: relative;
  z-index: 1;
}

/* Badge de desconto — pill pequeno, tema */
body.home-page .card .discount-badge {
  position: absolute !important;
  top: 12px !important; left: 12px !important;
  background: var(--brand) !important;
  color: #fff !important;
  font-family: var(--font-ui) !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  letter-spacing: .02em !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  box-shadow: 0 4px 10px -2px rgba(79,70,229,.35) !important;
  border: 0 !important;
  max-height: 22px !important;
  line-height: 1.2 !important;
  z-index: 3;
  animation: none !important;
  transform: none !important;
}
body.home-page .card .discount-badge i { display: none !important; }

body.home-page .card .sold-out-badge {
  position: absolute; top: 12px; right: 12px;
  background: rgba(14,14,20,.88); color: #fff;
  font-size: 11px; font-weight: 600; padding: 4px 10px;
  border-radius: 4px; letter-spacing: .03em; z-index: 3;
}

body.home-page .card .card-body {
  padding: 16px 18px 18px;
  display: flex; flex-direction: column; gap: 8px; flex: 1;
}
body.home-page .card .card-body h4 {
  font-family: var(--font-ui);
  font-size: 14.5px; font-weight: 500;
  line-height: 1.35; color: var(--ink);
  margin: 0; letter-spacing: -0.005em;
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
  min-height: 2.7em;
}
body.home-page .card .card-body .stars { margin: 0 0 4px; }

body.home-page .card .card-body .price {
  font-family: var(--font-ui) !important;
  font-size: 20px !important; font-weight: 700 !important;
  color: var(--ink) !important;
  letter-spacing: -0.015em;
  font-variant-numeric: tabular-nums;
}
body.home-page .card .card-body .old {
  font-size: 13px !important; color: var(--ink-mute) !important;
  text-decoration: line-through; font-weight: 400 !important;
  margin-left: 8px !important; font-variant-numeric: tabular-nums;
}

/* Flash: preço em gradiente quente */
body.home-page .flash-section .card .card-body .price {
  background: var(--flash-grad);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 800 !important;
}
@supports not (-webkit-background-clip: text) {
  body.home-page .flash-section .card .card-body .price {
    color: var(--signal) !important; -webkit-text-fill-color: initial;
  }
}

/* CTA Adicionar */
body.home-page .card .add {
  margin: 0 18px 18px;
  background: var(--brand-grad);
  color: #fff;
  font-family: var(--font-ui); font-weight: 600;
  font-size: 13.5px; letter-spacing: .02em;
  padding: 11px 16px; border: 0; border-radius: var(--radius);
  cursor: pointer;
  transition: transform .2s, box-shadow .2s, filter .2s;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  box-shadow: 0 4px 14px -4px rgba(79,70,229,.45);
}
body.home-page .card .add::before {
  content: "\f07a";
  font-family: "Font Awesome 6 Free"; font-weight: 900; font-size: 13px;
}
body.home-page .card .add:hover {
  transform: translateY(-1px); filter: brightness(1.08);
  box-shadow: 0 10px 22px -6px rgba(79,70,229,.55);
}

/* ---------- SECTIONS ---------- */
body.home-page .section { padding: 72px 0; }
body.home-page .section .container { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
body.home-page .section .sec-title {
  text-align: left; margin-bottom: 32px;
  padding-bottom: 16px; border-bottom: 1px solid var(--line);
  position: relative;
}
body.home-page .section .sec-title::after {
  content: ""; position: absolute; bottom: -1px; left: 0;
  width: 64px; height: 2px; background: var(--brand-grad);
}
body.home-page .section .grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 24px;
}

/* ---------- CUPOM DO DIA — layout 3 colunas ---------- */
body.home-page .coupon-section { padding: 40px 0; }
body.home-page .coupon-section .container {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
}
body.home-page .coupon {
  background: var(--brand-grad);
  border: 0;
  border-radius: var(--radius-lg);
  padding: 28px 32px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
  box-shadow: 0 14px 36px -12px rgba(79,70,229,.5);
  position: relative; overflow: hidden;
  color: #fff;
}
/* Glow decorativo */
body.home-page .coupon::before {
  content: ""; position: absolute;
  top: -80px; right: -80px;
  width: 280px; height: 280px;
  background: radial-gradient(circle, rgba(255,255,255,.18) 0%, transparent 65%);
  pointer-events: none;
}
body.home-page .coupon::after {
  content: ""; position: absolute;
  bottom: -100px; left: 30%;
  width: 240px; height: 240px;
  background: radial-gradient(circle, rgba(219,39,119,.25) 0%, transparent 65%);
  pointer-events: none;
}

/* Coluna 1 — ícone */
body.home-page .coupon-icon {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 14px;
  color: #fff; font-size: 24px;
  flex-shrink: 0;
  position: relative; z-index: 1;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.2);
}

/* Coluna 2 — texto */
body.home-page .coupon-body {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; gap: 4px;
  min-width: 0;
}
body.home-page .coupon-body .coupon-label {
  display: inline-flex; align-items: center;
  font-family: var(--font-ui);
  font-size: 11px; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.78);
}
body.home-page .coupon-body h3 {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 500; letter-spacing: -0.015em;
  line-height: 1.2;
  color: #fff; margin: 2px 0 4px;
}
body.home-page .coupon-body p {
  font-family: var(--font-ui);
  font-size: 14px; line-height: 1.4;
  color: rgba(255,255,255,.82);
  margin: 0;
}

/* Coluna 3 — código + timer */
body.home-page .coupon-action {
  display: flex; flex-direction: column; gap: 10px;
  align-items: stretch;
  position: relative; z-index: 1;
  min-width: 180px;
}

body.home-page .coupon-code-box {
  background: rgba(255,255,255,.12);
  border: 1.5px dashed rgba(255,255,255,.45);
  border-radius: 10px;
  padding: 10px 16px;
  display: flex; flex-direction: column; align-items: center;
  gap: 2px;
  transition: background .2s, border-color .2s;
}
body.home-page .coupon-code-box:hover {
  background: rgba(255,255,255,.2);
  border-color: rgba(255,255,255,.7);
}
body.home-page .coupon-code-label {
  font-family: var(--font-ui);
  font-size: 10px; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,255,255,.7);
}
body.home-page .coupon-code {
  display: block;
  font-family: var(--font-mono);
  font-size: 18px; font-weight: 600;
  letter-spacing: .12em;
  color: #fff;
  cursor: copy;
  background: transparent;
  padding: 0;
  border: 0;
}
body.home-page .coupon-code::after {
  content: "  ⧉";
  font-size: 12px;
  opacity: .55;
  font-weight: 400;
  letter-spacing: 0;
}

body.home-page .coupon-timer-display {
  display: flex; align-items: center; justify-content: center;
  gap: 6px;
  font-family: var(--font-ui);
  font-size: 11.5px;
  color: rgba(255,255,255,.75);
  letter-spacing: .05em;
}
body.home-page .coupon-timer-label {
  text-transform: uppercase; font-weight: 600; letter-spacing: .18em;
}
body.home-page .coupon-timer-value {
  font-family: var(--font-mono);
  font-size: 13px; font-weight: 600;
  color: #fff;
  font-variant-numeric: tabular-nums;
  padding: 2px 8px;
  background: rgba(0,0,0,.22);
  border-radius: 4px;
  min-width: 64px; text-align: center;
}

/* Estado copiado */
body.home-page .coupon-code.copied::after { content: "  ✓"; opacity: 1; }

/* Esconde bloco timer se valor ficar '--:--' apos 2s (JS trata) */
body.home-page .coupon-timer-display[data-empty="true"] { visibility: hidden; }

/* Responsivo */
@media (max-width: 760px) {
  body.home-page .coupon {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 24px 22px;
    text-align: center;
  }
  body.home-page .coupon-icon { margin: 0 auto; }
  body.home-page .coupon-action { min-width: 0; }
  body.home-page .coupon-body .coupon-label { justify-content: center; }
}

/* ---------- BUNDLES ---------- */
body.home-page .bundle-section { padding: 64px 0; }
body.home-page .bundle {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-card);
  overflow: hidden; display: flex; align-items: center;
  gap: 24px; padding: 20px;
  transition: transform .25s, box-shadow .25s, border-color .25s;
}
body.home-page .bundle:hover {
  transform: translateY(-2px); box-shadow: var(--shadow-hover);
  border-color: rgba(79,70,229,.22);
}
body.home-page .bundle img { border-radius: var(--radius); object-fit: cover; }
body.home-page .bundle-content h3 {
  font-family: var(--font-display); font-size: 24px; font-weight: 500;
  margin: 0 0 8px; letter-spacing: -0.015em;
}
body.home-page .bundle-content p {
  color: var(--ink-soft); font-size: 14.5px; line-height: 1.5; margin: 0 0 16px;
}
body.home-page .bundle-content .btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--brand-grad); color: #fff;
  padding: 11px 22px; border-radius: var(--radius);
  font-size: 14px; font-weight: 600; text-decoration: none;
  transition: transform .2s, filter .2s;
  box-shadow: 0 4px 14px -4px rgba(79,70,229,.4);
}
body.home-page .bundle-content .btn:hover { filter: brightness(1.08); transform: translateY(-1px); }

/* ---------- PACKING ---------- */
body.home-page .packing-section {
  background: var(--bg-soft);
  padding: 88px 0; margin: 64px 0 0;
}
body.home-page .packing-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 56px; align-items: center;
}
body.home-page .packing-text h2 {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 42px);
  font-weight: 500; letter-spacing: -0.02em;
  margin: 0 0 16px; line-height: 1.1;
}
body.home-page .packing-text p {
  color: var(--ink-soft); font-size: 16px; line-height: 1.6; margin: 0 0 24px;
}
body.home-page .packing-list { list-style: none; padding: 0; margin: 0; }
body.home-page .packing-list li {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0; color: var(--ink);
  font-weight: 500; font-size: 15px;
  border-bottom: 1px solid var(--line);
}
body.home-page .packing-list li:last-child { border-bottom: 0; }
body.home-page .packing-list li i {
  color: var(--brand); font-size: 18px;
}
body.home-page .packing-media video,
body.home-page .packing-media img {
  width: 100%; border-radius: var(--radius-lg);
  box-shadow: var(--shadow-hover);
}
@media (max-width: 860px) {
  body.home-page .packing-inner { grid-template-columns: 1fr; gap: 32px; }
}

/* ---------- TESTIMONIALS ---------- */
body.home-page .test-wrap { padding: 80px 0; background: var(--bg-base); }
body.home-page .test-wrap .sec-title {
  text-align: center; border-bottom: 0; margin-bottom: 48px;
}
body.home-page .test-wrap .sec-title::after {
  left: 50%; transform: translateX(-50%); bottom: -14px;
}
body.home-page .tswiper .swiper-slide {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 28px 24px; box-shadow: var(--shadow-card);
  position: relative; min-height: 220px;
}
body.home-page .tswiper .swiper-slide::before {
  content: "\201C"; font-family: var(--font-display);
  position: absolute; top: 8px; right: 20px;
  font-size: 72px;
  background: var(--brand-grad);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  opacity: .35; line-height: 1;
}
body.home-page .tswiper .swiper-slide strong {
  display: block; font-family: var(--font-display);
  font-size: 17px; font-weight: 500; margin-top: 12px; color: var(--ink);
}
body.home-page .tswiper .swiper-slide p {
  font-size: 14.5px; color: var(--ink-soft);
  line-height: 1.55; margin: 12px 0 0;
}

/* ---------- ENTERPRISE B2B ---------- */
body.home-page .premium-enterprise {
  background: linear-gradient(135deg, #FFFFFF 0%, var(--bg-soft) 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 56px;
  display: grid; grid-template-columns: 3fr 2fr;
  gap: 56px; align-items: center;
  box-shadow: var(--shadow-card);
  position: relative; overflow: hidden;
}
body.home-page .premium-enterprise::before {
  content: ""; position: absolute; top: 0; right: 0;
  width: 320px; height: 320px;
  background: radial-gradient(circle, var(--brand-violet) 0%, transparent 65%);
  opacity: .12; pointer-events: none;
}
body.home-page .premium-enterprise-copy h2 {
  font-family: var(--font-display);
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 500; letter-spacing: -0.02em;
  line-height: 1.12; margin: 0 0 16px; color: var(--ink);
}
body.home-page .premium-enterprise-copy p {
  color: var(--ink-soft); font-size: 15.5px;
  line-height: 1.6; margin: 0 0 28px;
}
body.home-page .premium-enterprise-cta {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--brand-grad);
  color: #fff !important;
  font-family: var(--font-ui); font-weight: 600;
  font-size: 14.5px; padding: 13px 26px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 8px 20px -4px rgba(79,70,229,.4);
}
body.home-page .premium-enterprise-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -6px rgba(79,70,229,.55);
}
body.home-page .premium-enterprise-features > div {
  padding: 14px 0; border-bottom: 1px solid var(--line);
  position: relative; padding-left: 20px;
}
body.home-page .premium-enterprise-features > div:last-child { border-bottom: 0; }
body.home-page .premium-enterprise-features > div::before {
  content: ""; position: absolute;
  left: 0; top: 22px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--brand-grad);
}
body.home-page .premium-enterprise-features strong {
  display: block; font-family: var(--font-ui);
  font-size: 14px; font-weight: 600; color: var(--ink);
  margin-bottom: 2px; letter-spacing: -0.005em;
}
body.home-page .premium-enterprise-features span {
  display: block; color: var(--ink-mute);
  font-size: 13px; line-height: 1.4;
}
@media (max-width: 860px) {
  body.home-page .premium-enterprise {
    grid-template-columns: 1fr; padding: 36px 24px; gap: 32px;
  }
}

/* ---------- PREMIUM CATEGORIES ---------- */
body.home-page .premium-categories {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 20px; margin-top: 28px;
}
body.home-page .premium-category-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 32px 24px 28px;
  text-decoration: none; color: var(--ink);
  min-height: 170px;
  display: flex; flex-direction: column; justify-content: flex-end;
  transition: transform .25s, box-shadow .25s, border-color .25s;
  position: relative; overflow: hidden;
}
body.home-page .premium-category-card::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 20%, rgba(124,58,237,.10) 0%, transparent 60%);
  opacity: .8; pointer-events: none;
  transition: opacity .3s;
}
body.home-page .premium-category-card:hover {
  transform: translateY(-4px); box-shadow: var(--shadow-hover);
  border-color: rgba(79,70,229,.3);
}
body.home-page .premium-category-card:hover::before { opacity: 1; }
body.home-page .premium-category-card h3 {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 500;
  letter-spacing: -0.015em; margin: 0 0 6px;
  position: relative; z-index: 1;
}
body.home-page .premium-category-card p {
  color: var(--ink-soft); font-size: 13.5px;
  margin: 0; line-height: 1.45;
  position: relative; z-index: 1;
}
body.home-page .premium-category-card::after {
  content: "\2192"; position: absolute;
  top: 22px; right: 22px; font-size: 18px;
  color: var(--brand); opacity: 0;
  transform: translateX(-6px);
  transition: opacity .25s, transform .25s;
}
body.home-page .premium-category-card:hover::after {
  opacity: 1; transform: translateX(0);
}
@media (max-width: 960px) { body.home-page .premium-categories { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { body.home-page .premium-categories { grid-template-columns: 1fr; } }

/* ---------- CATS chips ---------- */
body.home-page .cats {
  padding: 20px 0; border-bottom: 1px solid var(--line);
  background: var(--bg-card);
}
body.home-page .cats ul {
  list-style: none; display: flex; gap: 10px; flex-wrap: wrap;
  padding: 0; margin: 0; max-width: 1240px;
  margin: 0 auto; padding: 0 24px;
}
body.home-page .cats a {
  display: inline-block; padding: 8px 16px;
  font-size: 13.5px; font-weight: 500;
  color: var(--ink-soft);
  border: 1px solid var(--line-strong);
  border-radius: 999px; text-decoration: none;
  transition: all .2s;
}
body.home-page .cats a:hover {
  color: var(--brand); border-color: var(--brand);
  background: var(--brand-soft);
}

/* ---------- SCROLL REVEAL ---------- */
.pv2-reveal {
  opacity: 0; transform: translateY(16px);
  transition: opacity .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1);
  will-change: opacity, transform;
}
.pv2-reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .pv2-reveal { opacity: 1; transform: none; transition: none; }
}

/* ---------- DESATIVAR animações distraentes ---------- */
body.home-page .discount-badge,
body.home-page .flash-badge {
  animation: none !important;
}
@keyframes pv2-killpulse { from {} to {} }
body.home-page [class*="pulse"]:not(.flash-header .sec-title) {
  animation-name: pv2-killpulse !important;
}

/* ---------- PUSH POPUP refino ---------- */
body.home-page #pushPopup {
  box-shadow: var(--shadow-hover) !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--line) !important;
  font-family: var(--font-ui) !important;
  max-width: 320px !important;
}
