/**
 * Mativix Landing - Sections CSS
 * Estilos específicos de cada seção
 */

/* === HERO === */
.hero {
  padding-top: 80px;
  padding-bottom: 0;
  background: var(--gradient-hero);
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.hero .container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: calc(100vh - 80px);
}

.hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
  width: 100%;
}

.hero__content {
  max-width: 560px;
}

.hero__badge {
  display: inline-block;
  padding: var(--space-2) var(--space-4);
  background: var(--color-white);
  color: var(--color-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-6);
}

.hero__title {
  font-size: var(--text-5xl);
  font-weight: var(--font-extrabold);
  line-height: 1.1;
  margin-bottom: var(--space-6);
}

.hero__highlight {
  color: var(--color-primary);
}

.hero__text {
  font-size: var(--text-lg);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-8);
}

.hero__seals {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
}

.hero__cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-6);
}

.hero__price-info {
  font-size: var(--text-base);
  color: var(--color-gray-600);
}

.hero__price-info strong {
  font-size: var(--text-xl);
  color: var(--color-primary);
  font-weight: var(--font-extrabold);
}

.hero__image {
  display: flex;
  justify-content: center;
  align-items: center;
}

.hero__product-wrapper {
  position: relative;
  max-width: 320px;
}

.hero__product-img {
  width: 100%;
  height: auto;
  filter: drop-shadow(0 30px 60px rgba(var(--color-primary-rgb), 0.3));
  animation: float 6s ease-in-out infinite;
}

@keyframes float {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-20px);
  }
}

/* === BENEFÍCIOS === */
.benefits {
  background: var(--color-white);
}

.benefits__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

/* === SOBRE O PRODUTO === */
.about {
  background: var(--gradient-soft);
}

.about__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}

.about__image {
  position: relative;
}

.about__product-img {
  max-width: 350px;
  margin: 0 auto;
  filter: drop-shadow(0 20px 40px rgba(var(--color-primary-rgb), 0.2));
}

.about__content h2 {
  margin-bottom: var(--space-6);
}

.about__text {
  font-size: var(--text-lg);
  margin-bottom: var(--space-6);
}

.about__features {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.about__feature {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.about__feature-icon {
  width: 24px;
  height: 24px;
  color: var(--color-primary);
  flex-shrink: 0;
  margin-top: 2px;
}

/* === INGREDIENTES === */
.ingredients {
  background: var(--color-white);
}

.ingredients__grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-12);
  align-items: start;
}

.ingredients__highlight {
  background: var(--gradient-hero);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
}

.ingredients__highlight-title {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-6);
  text-align: center;
}

.ingredients__main-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

.ingredients__main-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  background: var(--color-white);
  border-radius: var(--radius-lg);
}

.ingredients__main-icon {
  width: 40px;
  height: 40px;
  background: var(--gradient-primary);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  flex-shrink: 0;
}

.ingredients__main-name {
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
}

.ingredients__table-wrapper {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.ingredients__table {
  width: 100%;
  border-collapse: collapse;
}

.ingredients__table th,
.ingredients__table td {
  padding: var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-gray-100);
}

.ingredients__table th {
  background: var(--color-gray-50);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.ingredients__table td {
  font-size: var(--text-sm);
}

.ingredients__table tbody tr:hover {
  background: var(--color-gray-50);
}

.ingredients__table tbody tr:last-child td {
  border-bottom: none;
}

.ingredients__note {
  padding: var(--space-4);
  font-size: var(--text-xs);
  color: var(--color-gray-500);
  text-align: center;
}

/* === DIFERENCIAIS === */
.differentials {
  background: var(--gradient-cta);
  color: var(--color-white);
}

.differentials .section__title,
.differentials .section__subtitle {
  color: var(--color-white);
}

.differentials__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

.differentials__item {
  text-align: center;
  padding: var(--space-8);
  background: rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-xl);
  backdrop-filter: blur(10px);
}

.differentials__icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-4);
  background: var(--color-white);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
}

.differentials__icon svg {
  width: 32px;
  height: 32px;
  color: var(--color-primary);
}

.differentials__title {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  margin-bottom: var(--space-2);
  color: var(--color-white);
}

.differentials__text {
  font-size: var(--text-base);
  opacity: 0.9;
  color: var(--color-white);
}

/* === COMO USAR === */
.how-to-use {
  background: var(--color-white);
}

.how-to-use__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.how-to-use__steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.how-to-use__step {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
}

.how-to-use__step-number {
  width: 48px;
  height: 48px;
  background: var(--gradient-primary);
  color: var(--color-white);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-bold);
  font-size: var(--text-xl);
  flex-shrink: 0;
}

.how-to-use__step-content h4 {
  margin-bottom: var(--space-2);
}

.how-to-use__image {
  display: flex;
  justify-content: center;
}

.how-to-use__product-img {
  max-width: 450px;
}

/* === FAQ === */
.faq {
  background: var(--gradient-soft);
}

.faq__list {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.faq__item {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: var(--transition-base);
}

.faq__item:hover {
  box-shadow: var(--shadow-md);
}

.faq__item--active {
  box-shadow: var(--shadow-md);
}

.faq__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-6);
  text-align: left;
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-gray-800);
  background: none;
  border: none;
  cursor: pointer;
  transition: var(--transition-fast);
}

.faq__question:hover {
  color: var(--color-primary);
}

.faq__icon {
  width: 24px;
  height: 24px;
  color: var(--color-primary);
  transition: var(--transition-base);
  flex-shrink: 0;
}

.faq__item--active .faq__icon {
  transform: rotate(180deg);
}

.faq__answer {
  padding: 0 var(--space-6) var(--space-6);
}

.faq__answer p {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
}

/* === CTA FINAL === */
.cta-final {
  background: var(--gradient-hero);
  text-align: center;
}

.cta-final__content {
  max-width: 600px;
  margin: 0 auto;
}

.cta-final__title {
  font-size: var(--text-4xl);
  margin-bottom: var(--space-4);
}

.cta-final__text {
  font-size: var(--text-lg);
  color: var(--color-gray-600);
  margin-bottom: var(--space-8);
}

.cta-final__product {
  background: var(--color-white);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-xl);
}

.cta-final__pricing {
  margin-bottom: var(--space-6);
}

.cta-final__price-old {
  font-size: var(--text-lg);
  color: var(--color-gray-400);
  text-decoration: line-through;
  display: block;
}

.cta-final__price {
  font-size: var(--text-5xl);
  font-weight: var(--font-extrabold);
  color: var(--color-primary);
}

.cta-final__price-info {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  display: block;
  margin-top: var(--space-2);
}

.cta-final__form {
  margin-bottom: var(--space-6);
}

.cta-final__trust {
  display: flex;
  justify-content: center;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.cta-final__trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-gray-600);
}

.cta-final__trust-item svg {
  width: 20px;
  height: 20px;
  color: var(--color-success);
}

/* === FOOTER === */
.footer {
  background: var(--color-gray-900);
  color: var(--color-gray-300);
  padding: var(--space-16) 0 var(--space-8);
}

.footer__content {
  display: grid;
  grid-template-columns: 1.5fr repeat(2, 1fr) 1fr;
  gap: var(--space-12);
  padding-bottom: var(--space-12);
  border-bottom: 1px solid var(--color-gray-800);
}

.footer__logo {
  height: 32px;
  width: auto;
  margin-bottom: var(--space-4);
}

.footer__contact a {
  color: var(--color-gray-400);
  transition: var(--transition-fast);
}

.footer__contact a:hover {
  color: var(--color-primary);
}

.footer__nav-title {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  color: var(--color-white);
  margin-bottom: var(--space-4);
}

.footer__nav ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer__nav a {
  color: var(--color-gray-400);
  font-size: var(--text-sm);
  transition: var(--transition-fast);
}

.footer__nav a:hover {
  color: var(--color-primary);
}

.footer__seals-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer__seal {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-gray-400);
}

.footer__seal svg {
  width: 20px;
  height: 20px;
  color: var(--color-success);
}

.footer__disclaimers {
  padding: var(--space-8) 0;
  border-bottom: 1px solid var(--color-gray-800);
}

.footer__disclaimer {
  font-size: var(--text-xs);
  color: var(--color-gray-500);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-4);
}

.footer__disclaimer:last-child {
  margin-bottom: 0;
}

.footer__disclaimer strong {
  color: var(--color-gray-400);
}

.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-8);
}

.footer__copyright,
.footer__cnpj {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

/* === PRICING / KITS === */
.pricing {
  background: var(--gradient-hero);
}

.pricing__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  max-width: 1000px;
  margin: 0 auto var(--space-12);
}

.pricing__card {
  position: relative;
  background: var(--color-white);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  text-align: center;
  box-shadow: var(--shadow-card);
  transition: all var(--transition-base);
  border: 2px solid transparent;
}

.pricing__card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
}

.pricing__card--featured {
  border-color: var(--color-primary);
  transform: scale(1.05);
  z-index: 1;
}

.pricing__card--featured:hover {
  transform: scale(1.05) translateY(-8px);
}

.pricing__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--gradient-cta);
  color: var(--color-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  white-space: nowrap;
}

.pricing__image {
  width: 100%;
  max-width: 180px;
  height: 140px;
  margin: 0 auto var(--space-4);
  display: flex;
  align-items: center;
  justify-content: center;
}

.pricing__image img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}

.pricing__name {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-gray-800);
  margin-bottom: var(--space-2);
}

.pricing__quantity {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  margin-bottom: var(--space-1);
}

.pricing__duration {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  margin-bottom: var(--space-4);
}

.pricing__original {
  font-size: var(--text-sm);
  color: var(--color-gray-400);
  margin-bottom: var(--space-2);
}

.pricing__original s {
  text-decoration: line-through;
}

.pricing__price {
  margin-bottom: var(--space-2);
}

.pricing__currency {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-primary);
  vertical-align: top;
}

.pricing__value {
  font-size: var(--text-4xl);
  font-weight: var(--font-extrabold);
  color: var(--color-primary);
}

.pricing__savings {
  display: inline-block;
  background: var(--color-success-light, #dcfce7);
  color: var(--color-success);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
}

.pricing__installments {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  margin-bottom: var(--space-6);
}

.pricing__form {
  width: 100%;
}

.pricing__trust {
  display: flex;
  justify-content: center;
  gap: var(--space-8);
  flex-wrap: wrap;
  background: var(--color-white);
  padding: var(--space-6) var(--space-8);
  border-radius: var(--radius-xl);
  max-width: 800px;
  margin: 0 auto;
}

.pricing__trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-gray-600);
}

.pricing__trust-item svg {
  width: 24px;
  height: 24px;
  color: var(--color-success);
}

/* Fix: Alinhamento dos botões nos cards de preço */
.pricing__card {
  display: flex;
  flex-direction: column;
}

.pricing__form {
  margin-top: auto;
}

/* Banner Marketplace centralizado */
.pricing__marketplace {
  max-width: 600px;
  margin: var(--space-12) auto;
  padding: var(--space-8);
  background: var(--color-white);
  border: 2px dashed var(--color-gray-300);
  border-radius: var(--radius-xl);
  text-align: center;
  transition: var(--transition-base);
}

.pricing__marketplace:hover {
  border-color: #FFD100;
  border-style: solid;
  background: #FFFEF5;
}

.pricing__marketplace-text {
  font-size: var(--text-base);
  color: var(--color-gray-600);
  margin-bottom: var(--space-4);
  font-weight: var(--font-medium);
}

.pricing__marketplace-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: #2D3277;
  text-decoration: none;
  padding: var(--space-4) var(--space-6);
  background: #FFD100;
  border-radius: var(--radius-full);
  transition: var(--transition-base);
}

.pricing__marketplace-link:hover {
  background: #2D3277;
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(45, 50, 119, 0.3);
}

.pricing__marketplace-icon {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  transition: var(--transition-base);
  object-fit: contain;
}

.pricing__marketplace-link:hover .pricing__marketplace-icon {
  transform: scale(1.05);
}