@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700&display=swap");*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }

/*
! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com
*/* Adicione seus estilos personalizados aqui */

/* Custom Utility Classes */
:root {
  --azul-institucional: #2563EB;
  --verde-saude: #10B981;
  --branco: #FFFFFF;
  --cinza-medio: #6B7280;
}

.container-custom {
  width: 100%;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (min-width: 640px) {
  .container-custom {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

@media (min-width: 1024px) {
  .container-custom {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}

.bg-azul-institucional {
  background-color: var(--azul-institucional);
}

.text-azul-institucional {
  color: var(--azul-institucional);
}

.bg-verde-saude {
  background-color: var(--verde-saude);
}

.text-verde-saude {
  color: var(--verde-saude);
}

.text-branco {
  color: var(--branco);
}

.texto-secundario {
  color: #9CA3AF;
}

.btn-secondary {
  background-color: var(--verde-saude);
  color: var(--branco);
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  font-weight: 600;
  text-align: center;
  display: inline-block;
}

/* Logo sizing */
.logo-img {
  height: 3.25rem;
  max-height: 100%;
  width: auto;
  display: block;
  object-fit: contain;
  background: transparent;
  flex-shrink: 0;
}

@media (min-width: 1024px) {
  .logo-img {
    height: 4.25rem;
    max-height: 100%;
  }
}

.nav-logo {
  height: 100%;
  display: flex;
  align-items: center;
}

.btn-secondary:hover {
  background-color: #059669;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

.whatsapp-float {
  position: fixed;
  bottom: 20px;
  right: 20px;
  background-color: #25D366;
  color: white;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  z-index: 1000;
}

.whatsapp-float:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
}

*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;scrollbar-width:none;-ms-overflow-style:none}:host::-webkit-scrollbar,html::-webkit-scrollbar{display:none}body {
  margin: 0;
  line-height: inherit;
  overflow-x: hidden;
}
body::-webkit-scrollbar {
  display: none;
}
hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--cor-azul-institucional:#036;--cor-verde-saude:#0a4;--cor-branco:#fff;--cor-cinza-escuro:#333;--cor-cinza-medio:#666;--cor-cinza-claro:#f5f5f5}html{scroll-behavior:smooth}body{font-family:Montserrat,sans-serif}.btn-secondary{background-color:var(--cor-verde-saude);color:var(--cor-branco);padding:1rem 1.5rem;border-radius:.5rem;font-weight:600;transition:opacity .3s ease}.btn-secondary:hover{opacity:.9}.texto-secundario{color:var(--cor-cinza-medio);font-size:.875rem;line-height:1.625}.container-custom{max-width:1280px;margin:0 auto;padding:0 1rem}@media (min-width:640px){.container-custom{padding:0 1.5rem}}@media (min-width:1024px){.container-custom{padding:0 2rem}}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.bottom-3{bottom:.75rem}.bottom-4{bottom:1rem}.left-0{left:0}.left-3{left:.75rem}.left-4{left:1rem}.right-0{right:0}.right-3{right:.75rem}.top-0{top:0}.top-1\/2{top:50%}.z-10{z-index:10}.z-50{z-index:50}.mx-2{margin-left:.5rem;margin-right:.5rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-8{margin-top:2rem}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-16{height:4rem}.h-2\.5{height:.625rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-\[60vh\]{height:60vh}.h-full{height:100%}.min-h-\[420px\]{min-height:420px}.min-h-screen{min-height:100vh}.w-2\.5{width:.625rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-full{width:100%}.w-screen{width:100vw}.max-w-none{max-width:none}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-12{gap:3rem}.gap-2{gap:.5rem}.gap-8{gap:2rem}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1.5rem * var(--tw-space-x-reverse));margin-left:calc(1.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(2rem * var(--tw-space-x-reverse));margin-left:calc(2rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:16px}.rounded-md{border-radius:12px}.border{border-width:1px}.border-t{border-top-width:1px}.border-azul-institucional\/20{border-color:rgba(0,51,102,.2)}.border-cinza-medio{--tw-border-opacity:1;border-color:rgb(102 102 102/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-transparent{border-color:transparent}.bg-azul-institucional{--tw-bg-opacity:1;background-color:rgb(0 51 102/var(--tw-bg-opacity,1))}.bg-black\/30{background-color:rgba(0,0,0,.3)}.bg-black\/40{background-color:rgba(0,0,0,.4)}.bg-branco{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-branco\/60{background-color:hsla(0,0%,100%,.6)}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.bg-verde-saude{--tw-bg-opacity:1;background-color:rgb(0 170 68/var(--tw-bg-opacity,1))}.bg-verde-saude\/10{background-color:rgba(0,170,68,.1)}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pt-3{padding-top:.75rem}.pt-8{padding-top:2rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-tight{line-height:1.25}.text-branco{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-verde-saude{--tw-text-opacity:1;color:rgb(0 170 68/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-90{opacity:.9}.shadow-lg{--tw-shadow:0 10px 32px rgba(0,0,0,.2);--tw-shadow-colored:0 10px 32px var(--tw-shadow-color)}.shadow-lg,.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 2px 8px rgba(0,0,0,.1);--tw-shadow-colored:0 2px 8px var(--tw-shadow-color)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.duration-700{transition-duration:.7s}.hover\:bg-azul-institucional\/80:hover{background-color:rgba(0,51,102,.8)}.hover\:bg-black\/50:hover{background-color:rgba(0,0,0,.5)}.hover\:bg-branco:hover{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.hover\:bg-opacity-90:hover{--tw-bg-opacity:0.9}.hover\:text-verde-saude:hover{--tw-text-opacity:1;color:rgb(0 170 68/var(--tw-text-opacity,1))}.hover\:opacity-90:hover{opacity:.9}.focus\:border-verde-saude:focus{--tw-border-opacity:1;border-color:rgb(0 170 68/var(--tw-border-opacity,1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-verde-saude:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(0 170 68/var(--tw-ring-opacity,1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}@media (min-width:640px){.sm\:block{display:block}.sm\:h-\[70vh\]{height:70vh}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.md\:text-left{text-align:left}}@media (min-width:1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:h-20{height:5rem}.lg\:h-\[90vh\]{height:90vh}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:text-2xl{font-size:1.5rem;line-height:2rem}.lg\:text-sm{font-size:.875rem;line-height:1.25rem}}


.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.45) 0%, rgba(16, 185, 129, 0.25) 100%);
  z-index: 1;
}

.hero-badge {
  background-color: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(5px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 8px 16px;
  border-radius: 9999px;
  font-size: 0.875rem;
  font-weight: 500;
  color: white;
  display: inline-block;
}

.hero-title {
  text-shadow: 0px 4px 14px rgba(0, 0, 0, 0.55);
  line-height: 1.1;
  letter-spacing: -0.01em;
  font-weight: 700;
}

.hero-subtitle {
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0px 3px 10px rgba(0, 0, 0, 0.5);
  line-height: 1.6;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.hero-micro-copy {
  color: rgba(255,255,255,0.8);
  font-weight: 400;
}

.btn-primary-orange {
  background-color: #F97316;
  color: white;
  padding: 12px 24px;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 600;
  transition: all 0.2s ease;
  box-shadow: 0px 4px 12px rgba(249, 115, 22, 0.4);
  display: inline-block;
  text-decoration: none;
  white-space: nowrap;
}

.btn-primary-orange:hover {
  background-color: #EA580C;
  transform: scale(1.05) translateY(-2px);
  box-shadow: 0px 6px 16px rgba(249, 115, 22, 0.5);
}

.btn-secondary-outline {
  border: 2px solid white;
  background-color: transparent;
  color: white;
  padding: 10px 24px;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 500;
  transition: all 0.2s ease;
  display: inline-block;
  text-decoration: none;
  white-space: nowrap;
}

.btn-secondary-outline:hover {
  background-color: rgba(255, 255, 255, 0.15);
  transform: scale(1.05) translateY(-2px);
}

.hero-cta-group {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

/* Responsive adjustments from PRD */
@media (max-width: 767px) {
  .hero-title { 
    font-size: 1.2rem; /* 19.2px */
    line-height: 1.15;
    margin-bottom: 0.4rem;
  }
  .hero-subtitle { 
    font-size: 0.9rem; /* 14.4px */
    line-height: 1.35;
    margin-bottom: 0.75rem;
  }
  .btn-primary-orange, .btn-secondary-outline {
    width: 100%;
    padding: 12px 18px;
    font-size: 0.95rem;
    text-align: center;
  }
  .hero-cta-group {
    flex-direction: column;
    gap: 10px;
    margin-bottom: 0.75rem;
  }
  .hero-micro-copy {
    font-size: 0.8rem;
  }
  .hero-badge {
    padding: 6px 12px;
    font-size: 0.75rem;
  }
}

@media (min-width: 768px) {
  .btn-primary-orange, .btn-secondary-outline {
    width: auto;
    min-width: auto;
  }
}

@media (min-width: 1440px) {
  .hero-title {
    font-size: 3.25rem; /* 52px */
  }
  .hero-subtitle {
    font-size: 1.25rem; /* 20px */
  }
}

/* Carousel Content - must be above overlay */
.z-20 {
  z-index: 20 !important;
}

/* Carousel Controls */
#carousel-prev,
#carousel-next {
  z-index: 50;
}

#carousel-dots {
  z-index: 50;
  display: flex;
  justify-content: center;
  gap: 10px;
}

#carousel-dots button {
  cursor: pointer;
  height: 12px;
  width: 12px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.6);
  border: none;
  transition: all 0.3s ease;
}

#carousel-dots button:hover {
  background-color: rgba(255, 255, 255, 0.8);
}

#carousel-dots .carousel-dot.active {
  background-color: #ffffff;
  border: 2px solid var(--verde-saude);
  box-shadow: 0 0 0 2px rgba(0,0,0,0.25);
  transform: scale(1.15);
}

.hero-content {
  max-width: 720px;
}

/* Courses Cards - Vibrante Saúde */
.course-card {
  background: linear-gradient(180deg, #ffffff 0%, #f0f7ff 100%);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 16px 36px rgba(37, 99, 235, 0.12), 0 2px 8px rgba(15, 23, 42, 0.08);
  transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
  border: 1px solid rgba(37, 99, 235, 0.22);
  position: relative;
}

.course-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1px;
  background: linear-gradient(140deg, rgba(37, 99, 235, 0.6), rgba(16, 185, 129, 0.55));
  -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.6;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.course-card:hover {
  transform: translateY(-10px) rotate(-0.2deg);
  box-shadow: 0 26px 55px rgba(16, 185, 129, 0.25), 0 10px 25px rgba(37, 99, 235, 0.2);
  background: linear-gradient(180deg, #ffffff 0%, #ecfeff 100%);
}

.course-card:hover::before {
  opacity: 1;
}

.course-card__image-wrap {
  position: relative;
  overflow: hidden;
}

.course-card__image-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.35), rgba(16, 185, 129, 0.4));
  transition: opacity 0.35s ease;
  opacity: 0.65;
}

.course-card__image {
  transform: scale(1);
  transition: transform 0.6s ease, filter 0.6s ease;
}

.course-card:hover .course-card__image {
  transform: scale(1.08);
  filter: saturate(1.08) contrast(1.05);
}

.course-card__body {
  position: relative;
}

.course-card__body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 24px;
  right: 24px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(37, 99, 235, 0.95), rgba(16, 185, 129, 0.95));
  opacity: 0.85;
}

.course-card__list li {
  position: relative;
  padding-left: 20px;
}

.course-card__list li::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: linear-gradient(120deg, #2563eb, #10b981);
  box-shadow: 0 0 10px rgba(16, 185, 129, 0.5);
  position: absolute;
  left: 0;
  top: 7px;
}

/* Generic Cards - Vibrante Saúde */
.vibrant-card {
  background: linear-gradient(180deg, #ffffff 0%, #f0f7ff 100%);
  border-radius: 18px;
  box-shadow: 0 16px 36px rgba(37, 99, 235, 0.12), 0 2px 8px rgba(15, 23, 42, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.22);
  transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
  position: relative;
  overflow: hidden;
}

.vibrant-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1px;
  background: linear-gradient(140deg, rgba(37, 99, 235, 0.6), rgba(16, 185, 129, 0.55));
  -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.6;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.vibrant-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 24px;
  right: 24px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(37, 99, 235, 0.95), rgba(16, 185, 129, 0.95));
  opacity: 0.85;
  pointer-events: none;
}

.vibrant-card:hover {
  transform: translateY(-8px) rotate(-0.2deg);
  box-shadow: 0 26px 55px rgba(16, 185, 129, 0.25), 0 10px 25px rgba(37, 99, 235, 0.2);
  background: linear-gradient(180deg, #ffffff 0%, #ecfeff 100%);
}

.vibrant-card:hover::before {
  opacity: 1;
}

/* News Cards - Vibrante Saúde */
.news-card {
  background: linear-gradient(180deg, #ffffff 0%, #f0f7ff 100%);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 16px 36px rgba(37, 99, 235, 0.12), 0 2px 8px rgba(15, 23, 42, 0.08);
  transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(37, 99, 235, 0.22);
  position: relative;
}

.news-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1px;
  background: linear-gradient(140deg, rgba(37, 99, 235, 0.6), rgba(16, 185, 129, 0.55));
  -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.6;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.news-card:hover {
  transform: translateY(-10px) rotate(-0.2deg);
  box-shadow: 0 26px 55px rgba(16, 185, 129, 0.25), 0 10px 25px rgba(37, 99, 235, 0.2);
  background: linear-gradient(180deg, #ffffff 0%, #ecfeff 100%);
}

.news-card:hover::before {
  opacity: 1;
}

.news-card__image-wrap {
  position: relative;
  overflow: hidden;
}

.news-card__image-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.35), rgba(16, 185, 129, 0.4));
  transition: opacity 0.35s ease;
  opacity: 0.65;
}

.news-card__image {
  transform: scale(1);
  transition: transform 0.6s ease, filter 0.6s ease;
}

.news-card:hover .news-card__image {
  transform: scale(1.08);
  filter: saturate(1.08) contrast(1.05);
}

/* Sobre Nós - imagem com efeito semelhante aos cards */
.about-image-wrap {
  background: linear-gradient(180deg, #ffffff 0%, #f0f7ff 100%);
  border-radius: 18px;
  box-shadow: 0 16px 36px rgba(37, 99, 235, 0.12), 0 2px 8px rgba(15, 23, 42, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.22);
  transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
  position: relative;
  overflow: hidden;
}

.about-image-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  padding: 1px;
  background: linear-gradient(140deg, rgba(37, 99, 235, 0.6), rgba(16, 185, 129, 0.55));
  -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.6;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.about-image-wrap::after {
  content: "";
  position: absolute;
  top: 0;
  left: 24px;
  right: 24px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(37, 99, 235, 0.95), rgba(16, 185, 129, 0.95));
  opacity: 0.85;
  pointer-events: none;
}

.about-image {
  width: 100%;
  height: auto;
  display: block;
  transform: scale(1);
  transition: transform 0.6s ease, filter 0.6s ease;
}

.about-image-wrap:hover {
  transform: translateY(-8px) rotate(-0.2deg);
  box-shadow: 0 26px 55px rgba(16, 185, 129, 0.25), 0 10px 25px rgba(37, 99, 235, 0.2);
  background: linear-gradient(180deg, #ffffff 0%, #ecfeff 100%);
}

.about-image-wrap:hover::before {
  opacity: 1;
}

.about-image-wrap:hover .about-image {
  transform: scale(1.03);
  filter: saturate(1.05) contrast(1.04);
}

.news-card__body {
  position: relative;
}

.news-card__body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 24px;
  right: 24px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(37, 99, 235, 0.95), rgba(16, 185, 129, 0.95));
  opacity: 0.85;
}

.news-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 20px;
  color: var(--azul-institucional);
  font-weight: 700;
  transition: color 0.2s ease, transform 0.2s ease;
}

.news-card__cta:hover {
  color: var(--verde-saude);
  transform: translateX(6px);
}

.news-see-all {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 36px;
  border-radius: 9999px;
  background: linear-gradient(90deg, #1d4ed8, #2563eb);
  color: #ffffff;
  font-weight: 700;
  font-size: 1rem;
  transition: transform 0.2s ease, box-shadow 0.3s ease;
  text-decoration: none;
  box-shadow: 0 10px 25px rgba(37, 99, 235, 0.35);
  margin-top: 24px;
}

.news-see-all:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 35px rgba(37, 99, 235, 0.45);
}

/* Keyframe Animations */
@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-20px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.animate-fade-in-down {
  animation: fadeInDown 0.8s ease-out forwards;
}

.animate-fade-in-up {
  animation: fadeInUp 0.8s ease-out 0.3s forwards;
  opacity: 0; /* Start hidden */
}