/* - - - - - - - - - - - - - - - - -

CSS INOVAÇÃO PEDAGÓGICA (IP) 

- - - - - - - - - - - - - - - - - */

*: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 .header-main {
    padding: 25px 0 !important;
}

@media (max-width: 480px) {

      header.header-2 .header-main .site-branding-logo {
        padding-bottom: 0px !important;
    }

}


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;
}



/*INÍCIO DOS CARDS - 16012026*/

.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);
  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;
}

/* ---------- IMAGEM ---------- */

.card-formacao-img {
  width: 108%;
  margin: -0.55rem -4% 0.65rem;
  position: relative;
}

.card-formacao-bg {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 10px;
  display: block;
}

/* ---------- LOGO ---------- */

.card-formacao-logo {
  position: absolute;
  left: 12px;
  bottom: 12px;
  height: 45px;
  width: auto;
  z-index: 2;
  pointer-events: none;
}

/* ---------- TAG IMAGEM ---------- */

.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;
}

/* ---------- TAGS INFO ---------- */

.tag-data {
  text-transform: lowercase !important;
}

.tag-formacao {
  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;
}

/*FIM DOS CARDS - 16012026*/

.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;
  }
}

/* HERO PÁGINA FORMAÇÃO */

.full-bleed{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  position:relative;
}

.hero{
  position:relative;
  padding:50px 0;
  overflow:hidden;
  margin-top:-30px;
}

/* imagem de fundo */
.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 */
.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;
}

/* coluna esquerda */
.hero-left{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  height:100%;
  align-self:stretch;
}

/* coluna direita */
.hero-right{
  display:flex;
  align-items:stretch;
}

.hero-image{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:16px;
}

/* texto */
.hero-title{
  font-size:1.8rem;
  margin:0 0 12px;
  line-height:1.2;
  font-weight:bold;
}

/* MAIS ESPAÇO ANTES DAS STATS */
.hero-desc{
  margin:0 0 8px;
}

/* =========================
   ZONA DE BAIXO EM 2 COLUNAS
   (ALINHADA AO FUNDO REAL)
   ========================= */

.hero-bottom-grid{
  margin-top:auto;
  width:100%;
  display:grid;
  grid-template-columns:1fr auto;
  gap:20px;
  align-items:end;
}

/* esquerda: stats + frase */
.hero-bottom-left{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:25px;                /* MAIS ESPAÇO ENTRE STATS E FRASE */
}

/* stats */
.hero-stats{
  display:flex;
  align-items:flex-start;
  gap:45px;
  margin:0;
  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-stats .stat-label{
  margin-top: 3px;
  line-height:1.2;
}

/* frase inscritos */
.hero-meta{
  font-size:.85rem;
  margin:0;
}

/* direita: logo */
.hero-bottom-right{
  display:flex;
  align-items:flex-end;
  justify-content:flex-end;
}

.hero-logo{
  height:65px;
  width:auto;
  max-width:180px;
  object-fit:contain;
  display:block;
}

/* botão */
.hero .button.button-inscr{
  display:inline-block;
  width:auto !important;
  align-self:flex-start;
  margin:12px 0 20px;
}

.hero .button.button-inscr a{
  display:inline-block;
  width:auto !important;
}

/* imagem direita */
.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;
  }

  .hero-bottom-grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .hero-bottom-right{
    justify-content:flex-start;
  }
}

@media (max-width:520px){
  .hero{
    padding:35px 0 35px !important;
    margin-top:-32px !important;
  }

  .hero-right img{
    border-radius:14px;
  }

  .hero .button.button-inscr{
    margin-top:-2px !important;
  }

  .hero-logo{
    height:50px;
    max-width:140px;
  }
}



/* FIM HERO PÁGINA FORMAÇÃO */

.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;
}

body.path-ip-formacao .block-title::after {
  background: #00a9f0 !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;
    margin-top: 10px;
}

/* 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;
}



body.path-ip-hp .block-title {
  display: none !important;
}

body.path-ip-hp footer .block-title {
  display: block !important;
}



.gsc-quotes-rotator .cbp-qtprogress {
  background: #f26522 !important;
}

.gsc-icon-box-new.style-2 .icon-inner {
  background: #f26522 !important;
}

.milestone-block.position-no-icon .milestone-right .milestone-number-inner {
  color: #f26522 !important;
}

.gsc-heading .sub-title > span:after {
  background: #f26522 !important;
}

.gsc-icon-box-new.style-5 .icon-inner .icon {
    color: #f26522 !important;
}

.gsc-icon-box-new.style-5:hover .icon-inner .icon {
  color: #fff !important;
  background: #f26522 !important;
}

.btn-inline {
  color: #f26522 !important;
}

.gsc-call-to-action .video-inner .link-video {
  background: #f26522 !important;
}

.button, .btn, .btn-white, .btn-theme, .btn-theme-second, .more-link a, .btn-theme-submit {
  background: #f26522 !important;
}

.gsc-quotes-rotator .cbp-qtrotator .cbp-qtcontent .content-title {
    font-size: 36px !important;
    margin-top: 25px !important;
}

body.path-ufm-hp .block.block-system-main-block {
    margin-bottom: 0 !important;
    margin-top: -30px !important;
}

.gsc-icon-box-new.style-2 .content-inner .desc ul li:after {
    color: #f26522 !important;
}

.milestone-number::before {
  content: "+";
  margin-right: 6px; /* espaço entre o > e o número */
}

.milestone-number.simbolopercentagem::after {
  content: "%";
  margin-left: -5px !important;
}


.milestone-block.position-no-icon .milestone-right .milestone-number-inner .symbol {
    color: #f26522 !important;
}

.subir-foto-nea{
    margin-top: -30px !important;
}



/* logo a cores → forçado a preto */
.logopretocor {
  filter: grayscale(100%) brightness(0);
  transition: filter 0.35s ease;
}

/* quando passas o rato no link */
a:hover .logopretocor {
  filter: none;
}



/* ============================
   FORM PTUC (REGISTRATION)
   Destaque: #00a9f0
   ============================ */

:root { --ptuc-accent: #00a9f0; }

/* “Container” do form (card) */
#registration-ip-ptuc-register-form {
  max-width: 1200px;
  margin: 30px auto 60px;
  background: #ffffff;
  padding: 28px 32px;
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.06);
}

/* Espaçamento entre itens */
#registration-ip-ptuc-register-form .js-form-item,
#registration-ip-ptuc-register-form .js-form-wrapper {
  margin-bottom: 16px;
}

/* Labels */
#registration-ip-ptuc-register-form .js-form-item > label,
#registration-ip-ptuc-register-form label {
  display: block;
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 4px;
  color: #222222;
  text-transform: none !important;
}

/* Inputs / selects / textarea (base) */
#registration-ip-ptuc-register-form .form-text,
#registration-ip-ptuc-register-form .form-email,
#registration-ip-ptuc-register-form .form-number,
#registration-ip-ptuc-register-form .form-select,
#registration-ip-ptuc-register-form textarea.form-textarea,
#registration-ip-ptuc-register-form input[type="text"],
#registration-ip-ptuc-register-form input[type="email"],
#registration-ip-ptuc-register-form input[type="number"],
#registration-ip-ptuc-register-form select,
#registration-ip-ptuc-register-form textarea {
  width: 100% !important;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid #d4d4d4;
  font-size: 0.9rem;
  line-height: 1.4;
  background: #ffffff;
  box-shadow: none;
}

/* Focus azul PTUC */
#registration-ip-ptuc-register-form .form-text:focus,
#registration-ip-ptuc-register-form .form-email:focus,
#registration-ip-ptuc-register-form .form-number:focus,
#registration-ip-ptuc-register-form .form-select:focus,
#registration-ip-ptuc-register-form textarea.form-textarea:focus,
#registration-ip-ptuc-register-form input:focus,
#registration-ip-ptuc-register-form select:focus,
#registration-ip-ptuc-register-form textarea:focus {
  outline: none;
  border-color: var(--ptuc-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--ptuc-accent) 22%, transparent);
}

/* Descrições (ajuda) mais clean */
#registration-ip-ptuc-register-form .description,
#registration-ip-ptuc-register-form [id$="--description"] {
  font-size: 0.82rem;
  line-height: 1.6;
  color: #555;
  margin-top: 6px;
}

/* ====== TABLEFIELD (Equipa docente) – limpar e modernizar ====== */

/* Ocultar botão “Mostrar coluna de pesos” */
#registration-ip-ptuc-register-form .tabledrag-toggle-weight-wrapper {
  display: none !important;
}

/* Tabela mais limpa */
#registration-ip-ptuc-register-form table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 8px;
}

/* Cabeçalhos Nome/Email */
#registration-ip-ptuc-register-form table tr:first-child label {
  font-weight: 700;
  font-size: 0.9rem;
  color: #222;
}

/* Remover drag handle + coluna peso se existirem */
#registration-ip-ptuc-register-form td:first-child,
#registration-ip-ptuc-register-form .tabledrag-handle,
#registration-ip-ptuc-register-form td.field-multiple-drag,
#registration-ip-ptuc-register-form th.tabledrag-hide,
#registration-ip-ptuc-register-form td.delta-order {
  display: none !important;
}

/* Inputs do tablefield já vêm com style width:100%, só garantimos “look” */
#registration-ip-ptuc-register-form .form-tablefield .form-text {
  border-radius: 8px;
}

/* Opcional: esconder “Table Caption” (normalmente não interessa ao utilizador) */
#registration-ip-ptuc-register-form .form-item-field-equipadocente-0-caption {
  display: none !important;
}

/* ====== Ações (botões) ====== */

/* Footer do form centrado */
#registration-ip-ptuc-register-form .layout-region-registration-footer {
  margin-top: 24px !important;
  display: flex !important;
  justify-content: center !important;
}

/* Botão principal */
#registration-ip-ptuc-register-form #edit-actions input[type="submit"],
#registration-ip-ptuc-register-form .form-actions .button--primary {
  background: var(--ptuc-accent) !important;
  border-radius: 999px !important;
  padding: 10px 26px !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  border: none !important;
  text-transform: none !important;
}

/* Hover */
#registration-ip-ptuc-register-form #edit-actions input[type="submit"]:hover,
#registration-ip-ptuc-register-form .form-actions .button--primary:hover {
  filter: brightness(0.92);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ptuc-accent) 30%, transparent);
}

/* Cancelar (se quiseres esconder, ativa) */
/*
#registration-ip-ptuc-register-form #edit-cancel {
  display: none !important;
}
*/

/* Responsivo */
@media (max-width: 768px) {
  #registration-ip-ptuc-register-form {
    padding: 18px 16px;
    margin: 20px 10px 40px;
  }
}


/* Ocultar "Mostrar coluna de pesos" – PTUC */
#registration-ip-ptuc-register-form .tabledrag-toggle-weight-wrapper {
  display: none !important;
}


/* =========================================================
 * Views Exposed Filters — SESSÕES (block-1)
 * Layout: tudo lado a lado + estilo "pill clean"
 * ========================================================= */

#views-exposed-form-sessoes-block-1{
  display: flex;
  flex-wrap: wrap;
  gap: 22px;
  align-items: flex-end;   /* alinha inputs + botão pela base */
}

/* Cada filtro (Tipologia, Categoria, Ano) */
#views-exposed-form-sessoes-block-1 .form-item{
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0 !important;

  min-width: 220px;
  flex: 1 1 220px;         /* permite ficar em linha e quebrar quando necessário */
}

/* Labels */
#views-exposed-form-sessoes-block-1 .form-item > label{
  font-weight: 400;
  font-size: 0.85rem;
  margin: 0 !important;
  opacity: 0.85;
}

/* Selects + inputs com largura controlada */
#views-exposed-form-sessoes-block-1 select.form-select,
#views-exposed-form-sessoes-block-1 input.form-text{
  height: 44px;
  padding: 0 18px;
  border-radius: 9999px;
  border: 1px solid rgba(0,0,0,.22);
  background: #fff;

  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/* Remove seta do select (mantém o look limpo) */
#views-exposed-form-sessoes-block-1 select.form-select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: none;
}

/* Botão aplicar (wrapper) */
#views-exposed-form-sessoes-block-1 .form-actions{
  display: flex;
  align-items: flex-end;
  margin: 0 !important;
  flex: 0 0 auto;
}

/* Botão aplicar (mesma altura dos inputs) */
#views-exposed-form-sessoes-block-1 .form-actions .form-submit{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  height: 44px;
  padding: 0 1.2rem;

  border-radius: 9999px;
  border: none !important;
  background-color: #000 !important;
  color: #fff !important;

  transition: all 0.4s ease-in-out;
  line-height: 1;
  cursor: pointer;

  margin: 0 !important;
  font-weight: 400;
}

/* Hover subtil */
#views-exposed-form-sessoes-block-1 .form-actions .form-submit:hover{
  background: #00a9f0 !important;
  box-shadow: none !important;
}

/* Ajuste opcional: Ano mais estreito */
#views-exposed-form-sessoes-block-1 .form-item-field-event-calendar-date-value-1{
  min-width: 160px;
  flex: 0 1 160px;
}

/* Mobile */
@media (max-width: 768px){
  #views-exposed-form-sessoes-block-1{
    gap: 14px;
  }

  #views-exposed-form-sessoes-block-1 .form-item{
    min-width: 100%;
    flex: 1 1 100%;
  }

  #views-exposed-form-sessoes-block-1 .form-actions{
    width: 100%;
  }

  #views-exposed-form-sessoes-block-1 .form-actions .form-submit{
    width: 100%;
  }
}

#views-exposed-form-sessoes-block-1{
  margin-bottom: 20px !important;
}



.milestone-block.position-no-icon .milestone-right .milestone-text {
    font-weight: 400 !important;
}

.gsc-quotes-rotator .cbp-qtrotator .cbp-qtcontent .content-title {
    font-weight: 400 !important;
}

.gsc-icon-box-new.style-4 .icon-inner .icon {
  color: #ffffff !important;
  background: #f26522 !important;
}

.gsc-icon-box-new.style-4 .content-inner .title {
    font-size: 16px !important;
    line-height: 24px !important;
}

.symbol {
  margin-left: -10px !important;
}


.aviso {
  font-size: 0.95rem;
  background-color: #e2e3e5;
  border-color: #d6d8db;
  position: relative;
  padding: .75rem 1.25rem;
  margin-bottom: 1.5rem;
  border: 2px solid transparent;
  border-radius: .25rem;
}

iconeaviso {
  font-size: 1.4rem;
  vertical-align: middle;
  margin-right: 0.65rem;
}

.aviso a{
text-decoration: underline;
}



.registration-waitlist-message {
  background-color: #f8d7da;
  position: relative;
  padding: .75rem .75rem;
  border: 1px solid #f5c2c7;
  border-radius: .25rem;
  padding-bottom: 0 !important;
}

@media (max-width: 768px) {

      .gbb-row-wrapper.subir-foto-nea {
    width: 100% !important;
    height: 230px !important;

  }


      
.block-menu .gva_menu > li.menu-item > a {
    color: #f26522 !important;
}

body.path-ip-formacao .block-menu .gva_menu > li.menu-item > a {
  color: #00a9f0 !important;
}

.block-menu .gva_menu > li.menu-item > a:hover {
    color: #000 !important;
}

.cimahub {
    margin-top: -100px !important;
}

  .block-menu .gva_menu > li.menu-item > a::after {
    transform: none !important;
    width: 0 !important;
  }


  .gva-offcanvas-mobile .gva_menu {
    list-style: none !important;
    padding-left: 0 !important;
    margin-left: 0 !important;
  }

  .gva-offcanvas-mobile .gva_menu li {
    list-style: none !important;
  }
    .gva-offcanvas-mobile .close-offcanvas {
    display: none !important;
  }

  .gva-offcanvas-mobile .gva_menu > li {
    margin-bottom: 8px !important; 
  }

    .gva-offcanvas-mobile .block {
        border-bottom: 0px solid transparent !important;
        padding: 20px;
    }


}

#edit-field-observacoes-0-format {
  display: none !important;
}


/* ============================
   FORM "Novos Docentes" – estilo bonito (IP)
   Destaque: #00a9f0
   ============================ */

#registration-novos-docentes-register-form {
  --ip-accent: #00a9f0;
  --ip-accent-soft: #00a9f014;
  --ip-accent-soft2: #00a9f026;
  --ip-border: #e5e5e5;
  --ip-muted: #fafafa;
}

/* Fix layout (evita cinzentos/caixas do tema) */
body #registration-novos-docentes-register-form .layout-region-registration-main,
body #registration-novos-docentes-register-form .layout-region-registration-footer {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  background: transparent !important;
  display: block !important;
}

/* Card do formulário */
body #registration-novos-docentes-register-form {
  max-width: 1200px;
  margin: 30px auto 60px;
  background: #ffffff;
  padding: 28px 32px;
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.06);
}

/* Espaçamento geral */
body #registration-novos-docentes-register-form .js-form-item {
  margin-bottom: 16px;
}

/* Labels */
body #registration-novos-docentes-register-form .js-form-item > label,
body #registration-novos-docentes-register-form fieldset > legend span.fieldset-legend {
  display: block;
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 4px;
  color: #222;
  text-transform: none !important;
}

/* Inputs / selects */
body #registration-novos-docentes-register-form .form-text,
body #registration-novos-docentes-register-form .form-email,
body #registration-novos-docentes-register-form .form-number,
body #registration-novos-docentes-register-form .form-select,
body #registration-novos-docentes-register-form textarea.form-textarea {
  width: 100% !important;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid #d4d4d4;
  font-size: 0.9rem;
  line-height: 1.4;
  background: #ffffff;
  box-shadow: none;
}

body #registration-novos-docentes-register-form .form-text:focus,
body #registration-novos-docentes-register-form .form-email:focus,
body #registration-novos-docentes-register-form .form-number:focus,
body #registration-novos-docentes-register-form .form-select:focus,
body #registration-novos-docentes-register-form textarea.form-textarea:focus {
  outline: none;
  border-color: var(--ip-accent);
  box-shadow: 0 0 0 2px var(--ip-accent-soft2);
}

/* Descrições (hint text) */
body #registration-novos-docentes-register-form .description {
  font-size: 0.82rem;
  line-height: 1.6;
  color: #555;
  margin-top: 6px;
}

/* ====== Fieldset Semestre (radios) como cartões ====== */
body #registration-novos-docentes-register-form #edit-field-semestre--wrapper {
  border: 1px solid var(--ip-border);
  border-radius: 14px;
  padding: 14px 18px 18px;
  margin-bottom: 24px;
  background: var(--ip-muted);
}

body #registration-novos-docentes-register-form #edit-field-semestre {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 18px;
  margin-top: 10px;
}

/* Cada opção radio em “card” */
body #registration-novos-docentes-register-form #edit-field-semestre .js-form-item {
  background: #ffffff;
  border-radius: 10px;
  border: 1px solid #e4e4e4;
  padding: 10px 10px 10px 12px;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 0;
}

body #registration-novos-docentes-register-form #edit-field-semestre .form-radio {
  margin-top: 3px;
}

body #registration-novos-docentes-register-form #edit-field-semestre label.option {
  font-weight: 500;
  font-size: 0.85rem;
  line-height: 1.5;
}

/* Hover nos cards */
body #registration-novos-docentes-register-form #edit-field-semestre .js-form-item:hover {
  border-color: var(--ip-accent);
  box-shadow: 0 0 0 1px var(--ip-accent-soft2);
}

/* Selecionado (quando o radio está checked) */
body #registration-novos-docentes-register-form #edit-field-semestre .js-form-item:has(input.form-radio:checked) {
  border-color: var(--ip-accent);
  box-shadow: 0 0 0 2px var(--ip-accent-soft2);
  background: #ffffff;
}

/* ====== Ocultar formatos de texto (Observações) ====== */
body #registration-novos-docentes-register-form #edit-field-observacoes-0-format-help-about,
body #registration-novos-docentes-register-form #edit-field-observacoes-0-format,
body #registration-novos-docentes-register-form #edit-field-observacoes-0-format-guidelines {
  display: none !important;
}

/* ====== Botão submit (Inscrever-me / Guardar) ====== */
body #registration-novos-docentes-register-form #edit-actions input[type="submit"] {
  background: var(--ip-accent) !important;
  border-radius: 999px !important;
  padding: 10px 26px !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  border: none !important;
  text-transform: none !important;
}

body #registration-novos-docentes-register-form #edit-actions input[type="submit"]:hover {
  filter: brightness(0.92);
  box-shadow: 0 10px 24px rgba(0,169,240,0.30);
}

/* Esconder Cancelar (se quiseres manter, apaga) */
body #registration-novos-docentes-register-form #edit-cancel {
  display: none !important;
}

/* Footer centrado */
body #registration-novos-docentes-register-form .layout-region-registration-footer {
  margin-top: 24px !important;
  display: flex !important;
  justify-content: center !important;
}

/* Responsivo */
@media (max-width: 768px) {
  body #registration-novos-docentes-register-form {
    padding: 18px 16px;
    margin: 20px 10px 40px;
  }

  body #registration-novos-docentes-register-form #edit-field-semestre {
    grid-template-columns: 1fr;
  }
}


/* Links apenas dentro de .view-content-wrap */
body.path-ip-formacao .view-content-wrap a {
  color: #00a9f0;
  text-decoration: none;
}

/* Hover: azul + sublinhado */
body.path-ip-formacao .view-content-wrap a:hover,
body.path-ip-formacao .view-content-wrap a:focus {
  color: #00a9f0;
  text-decoration: underline;
}


/* =========================================================
 * Views Exposed Filters — SESSÕES (page-2)
 * Layout: tudo lado a lado + estilo "pill clean"
 * ========================================================= */

#views-exposed-form-sessoes-page-2{
  display: flex;
  flex-wrap: wrap;
  gap: 22px;
  align-items: flex-end;   /* alinha inputs + botão pela base */
}

/* Cada filtro (Tipologia, Categoria, Ano) */
#views-exposed-form-sessoes-page-2 .form-item{
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0 !important;

  min-width: 220px;
  flex: 1 1 220px;         /* permite ficar em linha e quebrar quando necessário */
}

/* Labels */
#views-exposed-form-sessoes-page-2 .form-item > label{
  font-weight: 400;
  font-size: 0.85rem;
  margin: 0 !important;
  opacity: 0.85;
}

/* Selects + inputs com largura controlada */
#views-exposed-form-sessoes-page-2 select.form-select,
#views-exposed-form-sessoes-page-2 input.form-text{
  height: 44px;
  padding: 0 18px;
  border-radius: 9999px;
  border: 1px solid rgba(0,0,0,.22);
  background: #fff;

  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/* Remove seta do select (mantém o look limpo) */
#views-exposed-form-sessoes-page-2 select.form-select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: none;
}

/* Botão aplicar (wrapper) */
#views-exposed-form-sessoes-page-2 .form-actions{
  display: flex;
  align-items: flex-end;
  margin: 0 !important;
  flex: 0 0 auto;
}

/* Botão aplicar (mesma altura dos inputs) */
#views-exposed-form-sessoes-page-2 .form-actions .form-submit{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  height: 44px;
  padding: 0 1.2rem;

  border-radius: 9999px;
  border: none !important;
  background-color: #000 !important;
  color: #fff !important;

  transition: all 0.4s ease-in-out;
  line-height: 1;
  cursor: pointer;

  margin: 0 !important;
  font-weight: 400;
}

/* Hover subtil */
#views-exposed-form-sessoes-page-2 .form-actions .form-submit:hover{
  background: #00a9f0 !important;
  box-shadow: none !important;
}

/* Ajuste opcional: Ano mais estreito */
#views-exposed-form-sessoes-page-2 .form-item-field-event-calendar-date-value-1{
  min-width: 160px;
  flex: 0 1 160px;
}

/* Mobile */
@media (max-width: 768px){
  #views-exposed-form-sessoes-page-2{
    gap: 14px;
  }

  #views-exposed-form-sessoes-page-2 .form-item{
    min-width: 100%;
    flex: 1 1 100%;
  }

  #views-exposed-form-sessoes-page-2 .form-actions{
    width: 100%;
  }

  #views-exposed-form-sessoes-page-2 .form-actions .form-submit{
    width: 100%;
  }
}

#views-exposed-form-sessoes-page-2{
  margin-bottom: 20px !important;
}
