.elementor-116 .elementor-element.elementor-element-17215a9{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for container, class: .elementor-element-17215a9 */:root { --saude-vida-green-dark: #003824; --saude-vida-green: #005A3A; --saude-vida-orange: #F58320; --text-dark: #334155; --text-light: #64748b; --background-light: #f8fafc; --border-light: #e2e8f0; --white: #ffffff; --disabled-gray: #cbd5e1;}
.courses-hero { background-image: url('https://via.placeholder.com/1920x1080.png/005A3A/FFFFFF?text=Alunos+em+Aula'); height: 40vh; }
.hero-section { position: relative; display: flex; align-items: center; justify-content: center; text-align: center; color: var(--white); background-size: cover; background-position: center; }
.hero-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 56, 36, 0.7); }
.hero-content { position: relative; z-index: 2; }
.hero-content h1 { font-size: 3rem; }
.hero-content p { font-size: 1.2rem; max-width: 600px; margin: 10px auto 0; opacity: 0.9; }
.courses-page-main { padding: 60px 0; }
.filter-bar { display: flex; gap: 30px; background-color: var(--white); padding: 20px 30px; border-radius: 12px; box-shadow: 0 5px 25px rgba(0,0,0,0.07); margin-bottom: 50px; }
.filter-group { display: flex; flex-direction: column; flex-grow: 1; }
.filter-group label { font-weight: 600; font-size: 0.9rem; color: var(--saude-vida-green-dark); margin-bottom: 8px; }
.filter-group select { padding: 10px; border: 1px solid var(--border-light); border-radius: 8px; font-size: 1rem; font-family: 'Poppins', sans-serif; cursor: pointer; }
.course-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 30px; }
.course-card { background-color: var(--white); border-radius: 16px; box-shadow: 0 5px 25px rgba(0,0,0,0.05); display: flex; flex-direction: column; transition: transform 0.3s ease, box-shadow 0.3s ease; border: 1px solid var(--border-light); }
.course-card:hover { transform: translateY(-8px); box-shadow: 0 12px 35px rgba(0,0,0,0.1); border-color: var(--saude-vida-orange); }
.card-content { padding: 30px 25px 20px 25px; text-align: center; display: flex; flex-direction: column; flex-grow: 1; }
.card-icon { width: 80px; height: 80px; margin: 0 auto 20px auto; background-color: #fff0e6; border-radius: 50%; display: grid; place-items: center; font-size: 2.5rem; color: var(--saude-vida-orange); }
.card-icon.icon-green { background-color: #e6f6f0; color: var(--saude-vida-green); }
.card-icon.icon-dark-green { background-color: #e0ebe7; color: var(--saude-vida-green-dark); }
.card-content h3 { margin: 0 0 5px 0; font-size: 1.4rem; color: var(--saude-vida-green-dark); }
.card-tag { display: inline-block; background-color: var(--saude-vida-orange); color: var(--white); padding: 4px 12px; border-radius: 20px; font-size: 0.8rem; font-weight: 600; margin: 0 auto 15px auto; }
.card-tag.tag-green { background-color: var(--saude-vida-green); }
.card-tag.tag-dark-green { background-color: var(--saude-vida-green-dark); }
.card-content p { margin: 0 0 20px 0; font-size: 0.95rem; line-height: 1.6; color: var(--text-light); flex-grow: 1; }
.card-meta { padding: 15px 25px; border-top: 1px solid var(--border-light); display: flex; justify-content: center; gap: 25px; font-size: 0.9rem; color: var(--text-light); }
.card-meta span { display: flex; align-items: center; gap: 8px; }
.card-meta i { color: var(--saude-vida-green-dark); }
.card-footer { padding: 20px 25px 25px 25px; }
.btn { padding: 12px 30px; border-radius: 8px; text-decoration: none; font-weight: 600; transition: all 0.3s ease; border: none; cursor: pointer; display: inline-block; text-align: center; }
.btn-primary { background-color: var(--saude-vida-orange); color: var(--white); width: 100%; }
.btn-primary:hover { background-color: #d16b11; }
.no-results-message { text-align: center; padding: 50px; width: 100%; }
.no-results-message i { font-size: 3rem; color: var(--disabled-gray); margin-bottom: 20px; }
.no-results-message h3 { font-size: 1.5rem; color: var(--text-dark); }
.no-results-message p { color: var(--text-light); }
@media screen and (max-width: 768px) { .filter-bar { flex-direction: column; } }/* End custom CSS */