/* Shared styles for landing pages: professional, business, student */

/* Banner */
#banner-principal-profissionais {
  /* Background image is set per page to allow custom hero images */
  background-size: cover !important;
  background-position: center !important;
  color: var(--soft-gray) !important;
  padding: var(--space-xl) 0 !important;
  text-align: center !important;
  position: relative !important;
}

#banner-principal-profissionais h1,
#banner-principal-profissionais h3 {
  font-family: var(--font-primary) !important;
  font-size: 2.5rem !important;
  font-weight: 700 !important;
  margin-bottom: var(--space-md) !important;
  color: var(--soft-gray) !important;
  line-height: 1.2 !important;
}

#banner-principal-profissionais p {
  font-family: var(--font-secondary) !important;
  font-size: 1.125rem !important;
  margin-bottom: var(--space-lg) !important;
  color: var(--soft-gray) !important;
  max-width: 800px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Default overlay for readability */
#banner-principal-profissionais::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(0deg, rgba(0,0,0,0.45), rgba(0,0,0,0.45)) !important;
  pointer-events: none !important;
}

/* Business variant: blue-teal overlay */
body.business-page #banner-principal-profissionais::after {
  background: linear-gradient(0deg, rgba(33,102,172,0.70), rgba(33,102,172,0.70)) !important;
}

/* Student variant: warm amber overlay */
body.student-page #banner-principal-profissionais::after {
  background: linear-gradient(0deg, rgba(173,96,24,0.72), rgba(173,96,24,0.72)) !important;
}

.lead {
  font-family: var(--font-primary) !important;
}

/* Sections */
section {
  padding: var(--space-xl) 0 !important;
}

section h2 {
  font-family: var(--font-primary) !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
  color: var(--graphite-black) !important;
  margin-bottom: var(--space-lg) !important;
  text-align: center !important;
}

section p {
  font-family: var(--font-secondary) !important;
  font-size: 1.125rem !important;
  line-height: 1.6 !important;
  color: var(--slate-gray) !important;
  margin-bottom: var(--space-md) !important;
}

/* Historia section variant */
#historia {
  background: url('../img/banner-section2.png?v=1.1') !important;
  background-size: cover !important;
  background-position: center !important;
  color: var(--soft-gray) !important;
  padding: var(--space-xl) 0 !important;
}

#historia h2,
#historia p {
  color: var(--soft-gray) !important;
}

/* Cases */
.caso {
  background: var(--cloud-white) !important;
  padding: var(--space-xl) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-md) !important;
}

.caso h3 {
  font-family: var(--font-primary) !important;
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  color: var(--graphite-black) !important;
  margin-bottom: var(--space-lg) !important;
  text-align: center !important;
}

.caso ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.caso li {
  font-family: var(--font-secondary) !important;
  font-size: 1rem !important;
  line-height: 1.6 !important;
  color: var(--slate-gray) !important;
  margin-bottom: var(--space-sm) !important;
  padding-left: var(--space-md) !important;
  position: relative !important;
}

.caso li:before {
  content: "✓" !important;
  color: var(--empower-blue) !important;
  font-weight: bold !important;
  position: absolute !important;
  left: 0 !important;
}

.caso span {
  font-family: var(--font-secondary) !important;
  font-size: 1.125rem !important;
  font-style: italic !important;
  color: var(--empower-blue) !important;
  display: block !important;
  margin-top: var(--space-lg) !important;
  text-align: center !important;
}

/* Test list */
.mTolBox {
  background: var(--soft-gray) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--space-lg) !important;
  margin-bottom: var(--space-md) !important;
  box-shadow: var(--shadow-sm) !important;
  transition: var(--transition-normal) !important;
  border: 1px solid var(--mist-gray) !important;
}

.mTolBox:hover {
  box-shadow: var(--shadow-md) !important;
  transform: translateY(-2px) !important;
}

.mHdng {
  font-family: var(--font-primary) !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  color: var(--graphite-black) !important;
  margin-bottom: var(--space-sm) !important;
}

.mTolBox p {
  font-family: var(--font-secondary) !important;
  font-size: 1rem !important;
  line-height: 1.6 !important;
  color: var(--slate-gray) !important;
  margin-bottom: var(--space-sm) !important;
}

.mbtns {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-xs) !important;
  padding: var(--space-sm) var(--space-md) !important;
  border-radius: var(--radius-md) !important;
  font-family: var(--font-primary) !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  text-decoration: none !important;
  transition: var(--transition-normal) !important;
  border: none !important;
  cursor: pointer !important;
  color: var(--soft-gray) !important;
  margin-right: var(--space-sm) !important;
}

.mbtns:hover {
  text-decoration: none !important;
  transform: translateY(-1px) !important;
}

.mbtns-st1 {
  background: var(--clarity-teal) !important;
  color: var(--soft-gray) !important;
}

.mbtns-st1:hover {
  background: var(--clarity-teal-hover) !important;
  color: var(--soft-gray) !important;
}

.cartBtn {
  background: var(--growth-green) !important;
  color: var(--soft-gray) !important;
  border: none !important;
  padding: var(--space-sm) var(--space-md) !important;
  border-radius: var(--radius-md) !important;
  font-family: var(--font-primary) !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-xs) !important;
  transition: var(--transition-normal) !important;
}

.cartBtn:hover {
  background: var(--growth-green-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-md) !important;
  text-decoration: none !important;
}

/* CTA */
.btn-cta {
  background: var(--empower-blue) !important;
  color: var(--soft-gray) !important;
  border: none !important;
  padding: var(--space-md) var(--space-xl) !important;
  border-radius: var(--radius-md) !important;
  font-family: var(--font-primary) !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  cursor: pointer !important;
  transition: var(--transition-normal) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-sm) !important;
}

.btn-cta:hover {
  background: var(--empower-blue-hover) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-lg) !important;
  text-decoration: none !important;
}

.btn-lg {
  padding: var(--space-lg) var(--space-xl) !important;
  font-size: 1.125rem !important;
}

/* Tests dashboard section */
.tests-dashboard-section {
  padding: var(--space-xl) 0 !important;
  background: var(--cloud-white) !important;
}

.tests-dashboard-section .container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 var(--space-md) !important;
}

/* Test cards */
.dashboard-section {
  padding: var(--space-xl) 0 !important;
  background: var(--cloud-white) !important;
}

.dashboard-section .section-title {
  text-align: center !important;
  margin-bottom: var(--space-xl) !important;
  color: var(--graphite-black) !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
}

.tests-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
  gap: var(--space-lg) !important;
  margin-top: var(--space-lg) !important;
}

.test-card {
  background: var(--soft-gray) !important;
  border-radius: var(--radius-lg) !important;
  padding: var(--space-lg) !important;
  box-shadow: var(--shadow-sm) !important;
  transition: var(--transition-normal) !important;
  position: relative !important;
  overflow: hidden !important;
}

.test-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 4px !important;
  background: linear-gradient(90deg, var(--empower-blue), var(--clarity-teal)) !important;
}

.test-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-lg) !important;
}

.test-card-header {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-md) !important;
  margin-bottom: var(--space-md) !important;
}

.test-icon {
  width: 48px !important;
  height: 48px !important;
  background: var(--empower-blue) !important;
  border-radius: var(--radius-md) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--soft-gray) !important;
  font-size: 1.25rem !important;
}

.test-title {
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  color: var(--graphite-black) !important;
  margin: 0 !important;
}

.test-description {
  color: var(--slate-gray) !important;
  margin-bottom: var(--space-lg) !important;
  line-height: 1.6 !important;
}

.test-actions {
  display: flex !important;
  gap: var(--space-sm) !important;
  flex-wrap: wrap !important;
}

.test-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-xs) !important;
  padding: var(--space-sm) var(--space-md) !important;
  border-radius: var(--radius-md) !important;
  font-family: var(--font-primary) !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  text-decoration: none !important;
  border: none !important;
  cursor: pointer !important;
  transition: var(--transition-normal) !important;
  color: var(--soft-gray) !important;
}

.test-details-btn {
  background: var(--empower-blue) !important;
}

.test-details-btn:hover {
  background: var(--empower-blue-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-md) !important;
  text-decoration: none !important;
}

.test-purchase-btn {
  background: var(--growth-green) !important;
}

.test-purchase-btn:hover {
  background: var(--growth-green-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-md) !important;
  text-decoration: none !important;
}

.test-free-btn {
  background: var(--clarity-teal) !important;
}

.test-free-btn:hover {
  background: var(--clarity-teal-hover) !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-md) !important;
  text-decoration: none !important;
}

.original-price {
  text-decoration: line-through !important;
  opacity: 0.7 !important;
  font-size: 0.8em !important;
}

.discount-price {
  font-weight: 700 !important;
  color: var(--soft-gray) !important;
}

.test-unavailable {
  color: var(--alert-red) !important;
  font-style: italic !important;
  padding: var(--space-sm) !important;
}

/* Breadcrumbs */
.af-breadcrumbs {
  text-align: left !important;
  margin: 0 0 var(--space-md) !important;
  color: var(--graphite-black) !important;
}

/* Global top spacing for breadcrumb blocks */
nav.af-breadcrumbs {
  margin-top: var(--space-xl) !important;
}

.af-breadcrumbs .breadcrumb-item,
.af-breadcrumbs .breadcrumb-item a,
.af-breadcrumbs span {
  color: inherit !important;
  font-size: 0.95rem !important;
}

/* On hero banners, inherit the banner's light text and add subtle shadow for contrast */
#banner-principal-profissionais .af-breadcrumbs {
  color: var(--soft-gray) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.35) !important;
}

/* Add top spacing when breadcrumb follows the site header */
header + nav.af-breadcrumbs {
  margin-top: var(--space-xl) !important;
}

.af-related-links {
  text-align: center !important;
  margin-top: var(--space-md) !important;
}

.af-related-links a {
  margin: 0 var(--space-xs) !important;
}

/* Responsive */
@media (max-width: 768px) {
  #banner-principal-profissionais h1,
  #banner-principal-profissionais h3 {
    font-size: 2rem !important;
  }
  
  section h2 {
    font-size: 1.75rem !important;
  }
  
  .caso {
    padding: var(--space-lg) !important;
  }
  
  .mTolBox {
    padding: var(--space-md) !important;
  }
  
  .tests-grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-md) !important;
  }
  
  .tests-dashboard-section .container {
    padding: 0 var(--space-sm) !important;
  }
}


