*:not(.fa, .fas, .far, .fal, .fab, .fa-solid, .fa-regular, .fa-light, .fa-brands) {
  font-family: 'Roboto', sans-serif !important;
}

.fa, .fas, .fa-solid { font-family: "Font Awesome 5 Free" !important; font-weight: 900 !important; }
.far, .fa-regular   { font-family: "Font Awesome 5 Free" !important; font-weight: 400 !important; }
.fab, .fa-brands    { font-family: "Font Awesome 5 Brands" !important; font-weight: 400 !important; }

i[class^="fa"],
i[class*=" fa-"] {
  font-style: normal !important;
}

body{
  color: #141414 !important;
  font-size: 0.9rem !important;
}

body .body-page {
  background: #f9f6f3 !important;
}

.main-page{
    margin-top: 30px !important;
}

.text-gray {
    color: #141414 !important;
}

.topbar {
  background: #1C1C1C;
  height: 40px;
  display: flex;
  align-items: center; 
  justify-content: space-between;
  padding: 0;
  font-family: "Roboto", sans-serif;
  font-size: 13px;
  color: #fff;
}

.left-group,
.right-group {
  display: flex;
  align-items: center;
  gap: 16px;
}

.right-group{
  text-transform: lowercase !important;
}

.topbar a {
  color: #fff;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
}

.topbar a:hover {
  text-decoration: underline !important;
  color: #fff !important;
}

.ip-link::after {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-left: 6px;
  background: url("/sites/default/files/epic/ip-icone-branco.svg") no-repeat center center;
  background-size: contain;
}

.perfil-link::after {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-left: 8px;
  background: url("/sites/default/files/epic/user-branco.svg") no-repeat center center;
  background-size: contain;
}


.main-menu{
    text-transform: lowercase !important;
}

.header-main .branding {
  display: flex;
  align-items: center;
}

.header-main .branding .site-branding-logo {
  display: flex;
  align-items: center;
}

.header-main .branding .logo-site {
  height: auto;
}

header.header-2 .main-menu {
  background: #f26522 !important;
}

.navigation .gva_menu>li:first-child>a {
  padding-left: 0 !important;
}

.gavias_sliderlayer .tp-bullets .tp-bullet,
#gavias_slider_single .tp-bullets .tp-bullet {
  width: 10px !important;
  height: 10px !important;
  border-radius: 99px !important;
  background: rgba(255, 255, 255, 0.4) !important;
}

.gavias_sliderlayer .tp-bullets .tp-bullet.selected,
#gavias_slider_single .tp-bullets .tp-bullet.selected {
  background: #fff !important;
}

.gavias_sliderlayer .tparrows,
#gavias_slider_single .tparrows {
  width: 36px !important;
  height: 36px !important;
  border-radius: 99px !important;
  line-height: 36px !important;
  color: rgb(0, 0, 0) !important;
  font-size: 18px !important;
  background: rgba(255, 255, 255) !important;
  box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, 0.05) !important;
}

.btn {
  border: none !important;
  background-color: #0000ff !important;
  color: #fff !important;
  text-decoration: none !important;
  cursor: pointer !important;
  padding: 13px 35px 13px 35px !important;
  border-radius: 99px !important;
}

.btn:hover {
  background-color: #000 !important;
  text-decoration: none !important;
  cursor: pointer !important;
}



#footer {
    color: #fff !important;
    background: #1C1C1C !important;
}



.formacoes-grelha {
  background-color: #fff;
  box-shadow: 0 2px 4px rgba(0,0,0,.05);
  border-radius: 12px;
  padding: 1rem 1.25rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.formacoes-grelha:hover {
  transform: scale(1.03); /* aumenta 3% */
  box-shadow: 0 4px 8px rgba(0,0,0,.08);
}

.formacoes-titulo {
  margin-top: 0;
  font-size: 1rem;
  color: #333;
  font-weight: bold;
  margin-bottom: 0.9rem !important;
}

.formacoes-grelha p {
  margin: 0.25rem 0;
  font-size: 0.9rem;
  color: #333;
}

.card-formacao-img {
  width: 108%;
  margin: -0.55rem -4% 0.65rem;
  position: relative;
}

.card-formacao-img img {
  width: 100%;
  height: 180px;    
  object-fit: cover;
  border-radius: 10px; 
  display: block;
}

.tag-imagem {
  position: absolute;
  top: 10px;
  right: 10px;
  background: #ffffff2e;
  color: #fff !important;
  padding: 0.35rem 0.65rem;
  font-size: 0.78rem;
  border-radius: 6px;
  white-space: nowrap;
  text-transform: lowercase !important;
}

.tag-formacao {
  text-align: center !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 0.30rem 0.55rem !important;
  border-radius: 6px !important;
  font-size: 0.78rem !important;
  color: #333 !important;
  background-color: #b3b3b333 !important;
    margin-top: 4px !important;
}

.tag-formacao:not(:last-child) {
  margin-right: 6px;
}

.card-formacoes-link {
  text-decoration: none !important;
  color: inherit !important;
  display: block;
}

.card-formacoes-link:hover {
  text-decoration: none !important;
}


/* ===== Estilo da barra ===== */
.info-bar{
  background:#EDE9E6;
  padding:55px 0;                 /* altura */
  margin-bottom:42px !important;  /* espaço depois da barra */
}

/* ===== Grid com larguras iguais + respiro ===== */
:root{
  --ib-gap: 56px;     /* espaço entre colunas (ajusta para 64px se quiseres ainda mais) */
  --ib-pad: 12px;     /* acolchoamento interno de cada coluna */
}

.info-bar .ib-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 3px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr)); /* 4 colunas iguais */
  gap:var(--ib-gap);                               /* gap horizontal e vertical */
  align-items:start;
}

.info-bar .info-item{
  display:flex;
  flex-direction:column; 
  min-width:0;                 
  padding-inline:var(--ib-pad); /* respiro dentro de cada coluna */
}

.info-bar .info-item .label{
  font-weight:700;
  line-height:1.15;
  margin:0 0 8px 0;
}

.info-bar .info-item .value{
  line-height:1.55;
  overflow-wrap:anywhere;  /* evita empurrões por palavras longas */
  word-break:break-word;
}

/* ===== Responsivo ===== */
@media (max-width: 900px){
  :root{
    --ib-gap: 28px;
    --ib-pad: 10px;
  }

  .info-bar .ib-container{
    display: grid;
    grid-template-columns: 1fr 1fr;   /* 2 colunas fixas */
    gap: var(--ib-gap) 20px;          /* espaçamento entre linhas e colunas */
  }

  .info-bar .info-item{
    display: flex;
    flex-direction: column;           /* label em cima, valor em baixo */
    margin: 0;
    word-break: break-word;           /* se o local for longo, quebra linha */
  }

  .info-bar .label{
    font-weight: 600;
    margin-bottom: 4px;
    white-space: nowrap;
  }
}

/* opcional: mantém 2 colunas até mesmo em ecrãs muito pequenos */
@media (max-width: 380px){
  .info-bar .ib-container{
    grid-template-columns: 1fr 1fr;
  }
}

.full-bleed{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  position:relative;
}

.hero{
  position:relative;
  padding: 50px 0 50px;
  overflow:hidden;
  margin-top: -30px;
}

/* a imagem de fundo ocupa sempre 100% */
.hero-bg{
  position:absolute;
  inset:0;
  z-index:0;
}

.hero-bg img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter: blur(6px) brightness(0.85); 
  transform:scale(1.05);           
}

/* conteúdo por cima */
.hero-inner{
  position:relative;
  z-index:1;
  max-width:1200px;
  margin:0 auto;
  padding:0 15px;
}

.hero-card{
  background:#fff;
  border-radius:20px;
  box-shadow:0 12px 40px rgba(0,0,0,.12);
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:28px;
  padding:40px;
  align-items:stretch;   /* <— garante que as duas colunas têm a mesma altura */
}

.hero-right{
  display:flex;
  align-items:stretch;   /* imagem ocupa toda a altura */
}

.hero-image{
  width:100%;
  height:100%;           /* ocupa toda a altura da coluna */
  object-fit:cover;      /* adapta-se sem distorcer */
  border-radius:16px;
}

.hero-title{
  font-size: 1.8rem;
  margin:0 0 12px 0;
  line-height:1.2;
  font-weight: bold;
}

.hero-desc{ 
    margin:0 0 -6px; 
}

/* blocos de info */
.hero-stats{
  display:flex;
  align-items:flex-start;
  gap:45px;           /* espaço entre vagas e horas */
  margin-top: 15px;   /* só em cima */
  margin-bottom: 20px;
  text-transform: lowercase !important;
  
}

.hero-stats .stat{
  text-align: left;
}

.hero-stats .stat-value{
  font-size:1.5rem;
  font-weight:700;
  line-height:1.2;
}


.hero .button.button-inscr {
  display: inline-block;
  margin: 12px 0 20px;  /* só afeta o botão no hero */
}

.hero-left{
  display:flex;
  flex-direction:column;
  align-items:flex-start;   /* evita esticar os filhos na largura */
}

.hero .button.button-inscr {
  display: inline-block;
  width: auto !important;
  align-self: flex-start;
  margin: 12px 0 20px; /* ↑ ↑ ↑ aumenta o espaço abaixo do botão */
}


/* alguns temas metem o <a> a 100% — reset também */
.hero .button.button-inscr a{
  display:inline-block;
  width:auto !important;
}


.hero-meta{
  margin-top:auto;        /* empurra para o fundo */
  font-size:.85rem;
}

.hero-right img{
  width:100%;
  border-radius:16px;
  object-fit:cover;
}

/* responsivo */
@media (max-width:980px){
  .hero-card{ grid-template-columns:1fr; padding:24px; }
  .hero-right{ order:-1; }
}
@media (max-width:520px){
  .hero{ padding:28px 0 40px; }
  .hero-right img{ border-radius:14px; }

  .hero-stats{
    margin-bottom: 25px;}

    .hero {
        padding: 35px 0 35px !important;
        margin-top: -32px !important;
    }
    
    .hero .button.button-inscr {
    margin-top: -2px !important;
    }

}

.formacoes-compacto {
  background-color: #fff;
  border-radius: 12px;
  padding: 0.65rem 1rem 0.65rem 0.75rem; /* menos espaço à esquerda */
  box-shadow: 0 2px 4px rgba(0,0,0,.05);
  transition: transform .2s ease, box-shadow .2s ease;
  display: flex;
  align-items: center;
  gap: 0.9rem; /* espaço entre imagem e texto */
}

.formacoes-compacto:hover {
  transform: scale(1.03);
  box-shadow: 0 4px 8px rgba(0,0,0,.08);
}


.compacto-img {
  flex: 0 0 70px;
  width: 70px;
  height: 70px;
  border-radius: 10px;
  overflow: hidden;
  margin-left: 0;
}

.compacto-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.compacto-titulo {
  margin: 0;
  font-size: 0.85rem;
  color: #333;
}

/* Link do card (reaproveita a tua classe) */
.card-formacoes-link {
  text-decoration: none !important;
  color: inherit !important;
  display: block;
}

/* Responsivo: em ecrãs muito pequenos, reduz ligeiramente o espaço */
@media (max-width: 480px) {
  .formacoes-compacto { padding: 0.65rem 0.85rem; gap: 0.75rem; }
  .compacto-img { width: 64px; height: 64px; flex-basis: 64px; }
  .compacto-titulo { font-size: 0.98rem; }
}

.subt {
  margin-top: 20px !important;
  margin-bottom: 15px !important;
  font-size: 1.40rem !important;
}


/* --- Browsers modernos (suporte a :has) --- */
.content-main:has(.ip-formacao) h2.block-title {
  display: none !important;
}

.block-title:after {
    background: #f26522 !important;
}

#footer {
  font-size: 0.85rem !important;
}


#footer a {
  color: #fff !important;
  text-decoration: none !important;
  text-transform: lowercase !important;
}

#footer a:hover {
  text-decoration: underline !important;
}

#footer .block-title {
    font-size: 18px !important;
    font-weight: 500 !important;
}

#footer .block-title:after {
    content: '';
    width: 30px;
    height: 2px;
    background: #ffffff !important;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}

.logo-footer{
  margin-top: 20px !important;
}

icone,
icone a {
  font-size: 24px;
  transition: color 0.3s ease;
}

a:hover icone {
  color: #f26522 !important;
  transition: color 0.3s ease;
}


.navigation .gva_menu .sub-menu>li>a {
  color: #141414 !important;
}

.navigation .gva_menu .sub-menu>li>a:hover,
.navigation .gva_menu .sub-menu>li>a:focus,
.navigation .gva_menu .sub-menu>li>a:active {
  color: #f26522 !important;
}

.navigation .gva_menu>li>a {
  font-weight: 400 !important;
}

header.header-2 .main-menu .navigation .gva_menu>li>a {
  opacity: 1 !important;
}
    
.block-menu .gva_menu > li.menu-item > a {
  position: relative;
  display: inline-block;
  padding-bottom: 4px; /* ligeiramente menor para aproximar o traço */
  color: #ffffff !important;
  text-decoration: none !important;
  transition: color 0.25s ease !important;
  padding-left: 0 !important;
  margin-left: 0 !important; /* garante que o traço começa na 1ª letra */
}

/* Traço branco no hover */
.block-menu .gva_menu > li.menu-item > a::after {
  content: "";
  position: absolute;
  bottom: 18px; /* encosta mais ao texto */
  left: 0; /* começa exatamente na 1ª letra */
  width: 25px;
  height: 2px;
  background: #ffffff !important;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.25s ease !important;
  pointer-events: none;
}

/* Hover / ativo / foco */
.block-menu .gva_menu > li.menu-item > a:hover::after,
.block-menu .gva_menu > li.menu-item:hover > a::after,
.block-menu .gva_menu > li.menu-item.active > a::after {
  transform: scaleX(1) !important;
}

/* Mantém o texto branco no hover */
.block-menu .gva_menu > li.menu-item > a:hover {
  color: #ffffff !important;
  text-decoration: none !important;
}


.button-inscrever a, .button-inscrever a:hover{
  color: #fff !important;
}

.button-inscrever{
    display: inline-block;
    padding: 8px 1rem;
    border-radius: 0.25rem;
    transition: all 0.4s ease-in-out;
    line-height: 1.6;
    border: none !important;
    background-color: #f26522 !important;
    color: #fff !important;
    text-decoration: none !important;
    cursor: pointer;
    margin-top: 8px;
    margin-bottom: 18px;
    font-weight: 400;
}

.button-inscrever:hover{
    background-color: #000 !important;
    color: #fff !important;
    text-decoration: none !important;
    cursor: pointer;
    transition: all 0.4s ease-in-out;
}






/* ===== BARRA BASE ===== */
.trainer-bar {
  background: #EDE9E6;
  padding: 55px 0 52px;
  margin-bottom: -52px !important;
  margin-top: -20px !important;
}

.trainer-bar .tb-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 3px;
  display: grid;
  grid-template-columns: 180px 120px 1fr;
  gap: 25px;
  align-items: start;
}

/* ===== RÓTULO ===== */
.tb-title {
  font-weight: 700;
  line-height: 1.2;
  color: transparent !important;
  align-self: start;
  padding-left: var(--ib-pad, 12px);
  font-size: 0px !important;
}

.tb-title2 {
  font-weight: 700;
  line-height: 1.2;
  color: #1a1a1a;
  position: relative;
  top: 54px !important;
  z-index: 2;
  width: 150px;
}

/* ===== FOTO ===== */
.tb-media {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.tb-avatar {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  box-shadow: 0 1px 0 rgba(0,0,0,.05);
}

/* ===== CONTEÚDO ===== */
.tb-content {
  min-width: 0;
  padding-right: 10px;
}

.tb-name {
  margin: 0 0 8px 0;
  font-weight: 700;
  line-height: 1.2;
  font-size: 1.45rem !important;
}

.tb-bio {
  margin: 0;
  line-height: 1.6;
  color: #333;
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* ===== LINKS / ÍCONE ===== */
.tb-links {
  margin-top: 16px !important;
  margin-bottom: 12px !important; /* 👈 evita corte do ícone */
}

.trainer-bar .tb-links a.tb-icon-link {
  color: #333 !important;
  display: inline-flex;
  align-items: center;
  transition: color .25s ease;
}

.trainer-bar .tb-links a.tb-icon-link:hover {
  color: #f26522 !important;
}

.tb-links a:hover, .tb-links a:active, .tb-links a:focus {
    color: #f26522 !important;
}

.tb-icon {
  width: 22px;
  height: 22px;
  display: inline-block;
  transition: transform 0.25s ease;
}

.trainer-bar .tb-links a.tb-icon-link:hover .tb-icon {
  transform: scale(1.06);
}

/* ===== RESPONSIVO ===== */
@media (max-width: 900px) {
  .trainer-bar {
    padding: 55px 0 45px; 
  }

  .trainer-bar .tb-container {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    gap: 20px 0;
    grid-template-areas: none;
    padding: 0 24px; /* margem lateral */
  }

  .trainer-bar .tb-title {
    display: none !important; /* Esconde a coluna do rótulo */
  }

  .tb-title2 {
    display: none !important; /* Esconde a coluna do rótulo */
  }

  .tb-media,
  .tb-content {
    grid-column: 1 / -1;
  }

  .tb-media {
    justify-content: flex-start;
    align-self: start;
  }

  .tb-avatar {
    width: 96px;
    height: 96px;
    margin-bottom: 8px;
  }
}

@media (max-width: 480px) {
  .trainer-bar .tb-container {
    grid-template-columns: 1fr;
    gap: 16px 0;
    padding: 0 20px;
  }

  .tb-avatar {
    width: 88px;
    height: 88px;
  }
}

/* ===== AJUSTE DE ESPAÇAMENTO ENTRE BLOCO(S) ===== */
.trainer-bar + .trainer-bar {
  padding-top: 0;
}

/* Caso o formador não tenha biografia, centraliza verticalmente */
.trainer-bar:has(.tb-bio:empty) .tb-container {
  align-items: center !important; /* centraliza verticalmente */
}

/* Ajusta também o nome para não ficar colado à imagem */
.trainer-bar:has(.tb-bio:empty) .tb-name {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}


/* PÁGINA FORMAÇÃO - COR AZUL */

body.path-ip-formacao header.header-2 .main-menu {
  background: #00a9f0 !important;
}

body.path-ip-formacao .button-inscrever {
  background-color: #00a9f0 !important;
}

body.path-ip-formacao .button-inscrever:hover {
  background-color: #000000 !important;
}


body.path-ip-formacao .trainer-bar .tb-links a.tb-icon-link:hover {
  color: #00a9f0 !important;
}

body.path-ip-formacao .tb-links a:hover, .tb-links a:active, .tb-links a:focus {
    color: #00a9f0 !important;
}

body.path-ip-formacao .navigation .gva_menu .sub-menu>li>a:hover,
body.path-ip-formacao .navigation .gva_menu .sub-menu>li>a:focus,
body.path-ip-formacao .navigation .gva_menu .sub-menu>li>a:active {
  color: #00a9f0 !important;
}



.path-ip-formacao .registration-who-msg,
.path-ip-formacao #edit-cancel {
  display: none !important;
}

.path-ip-formacao .field-content{
    margin-bottom: 18px !important;
}

.path-ip-formacao #edit-submit {
    display: inline-block;
    padding: 8px 1rem;
    border-radius: 99px;
    transition: all 0.4s ease-in-out;
    line-height: 1.6;
    border: none !important;
    background-color: #00a9f0  !important;
    color: #fff !important;
    text-decoration: none !important;
    cursor: pointer;
    margin-bottom: 18px;
    font-weight: 400;
}

/* Efeito ao passar o rato */
.path-ip-formacao #edit-submit:hover {
    background-color: #000 !important;
    color: #fff !important;
    text-decoration: none !important;
    cursor: pointer;
    transition: all 0.4s ease-in-out;
}


