/* =========================================================
   AJUSTE DOS CARDBOXES KNOW-HOW (APENAS em secções "features1")
   - Antes estava global e rebentava a secção de contactos (Team)
   ========================================================= */

/* Só aplica o layout 4-colunas ao módulo de cards "features1" (Know-how etc.) */
section.features1 .media-container-row {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

section.features1 .media-container-row .card {
  display: flex;
  flex-direction: column;
  flex: 1 1 25%;
  max-width: 25%;
  box-sizing: border-box;
  padding: 0.5rem;
}

section.features1 .media-container-row .card-inner {
  display: flex;
  flex-direction: column;
  flex: 1;
}

section.features1 .media-container-row .card-box {
  flex: 1;
  display: flex;
  flex-direction: column;
}

section.features1 .media-container-row .card-box .link {
  margin-top: auto;
}

/* =========================================================
   CONTACTOS (Team / Equipa) — FIX “encavalitado”
   - força 3 colunas como o Bootstrap pretendia
   - evita partir palavras/letras
   ========================================================= */

section.contacts1 .media-container-row {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

section.contacts1 .media-container-row .card {
  flex: 1 1 33.333% !important;
  max-width: 33.333% !important;
  padding: 0.5rem;
  box-sizing: border-box;
  min-width: 0; /* importante para não “rebentar” flex */
}

/* Em ecrãs menores, empilha corretamente */
@media (max-width: 991px) {
  section.contacts1 .media-container-row .card {
    flex: 1 1 50% !important;
    max-width: 50% !important;
  }
}

@media (max-width: 575px) {
  section.contacts1 .media-container-row .card {
    flex: 1 1 100% !important;
    max-width: 100% !important;
  }
}

/* Evita partir texto de emails/links em colunas estreitas */
section.contacts1 .mbr-text,
section.contacts1 .mbr-info,
section.contacts1 a {
  word-break: normal !important;
  overflow-wrap: anywhere !important;
  hyphens: auto;
}

/* TEAM CONTACTS: garantir 3 colunas e evitar “encavalitado” */
section.contacts1 .media-container-row {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

section.contacts1 .media-container-row .card {
  flex: 0 0 33.333% !important;
  max-width: 33.333% !important;
  box-sizing: border-box;
  min-width: 0;
}

/* responsivo */
@media (max-width: 991px) {
  section.contacts1 .media-container-row .card {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
}
@media (max-width: 575px) {
  section.contacts1 .media-container-row .card {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
}

/* evitar partir palavras/letras */
section.contacts1 .mbr-text,
section.contacts1 a {
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  hyphens: auto;
}


/* =========================================================
   Fundo da bio do António (PT + EN) — rgb(51,51,51)
   ========================================================= */

#teamAMMPT,
#teamAMMENG {
  background-color: rgb(51, 51, 51) !important;
  background-image: none !important;
}


/* =========================================================
   KNOW-HOW (All contents)
   Remover traço / linha cinza decorativa
   ========================================================= */

section.features1 .card-title::before,
section.features1 .card-title::after,
section.features1 .mbr-section-title::before,
section.features1 .mbr-section-title::after,
section.features1 .card-box::before,
section.features1 .card-box::after {
    display: none !important;
    content: none !important;
}

section.features1 .card-title,
section.features1 .mbr-section-title {
    border: none !important;
}

/* =========================================================
   KNOW-HOW — Call-to-actions
   Largura total + altura uniforme (PT e ENG)
   ========================================================= */

/* Garante que o conteúdo do card empurra o botão para baixo */
section.features1 .card-box {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Botões */
section.features1 .card-box .link a,
section.features1 .card-box a.mbr-link-text {
  display: flex;
  align-items: center;
  justify-content: center;

  width: 100%;
  min-height: 64px;          /* altura igual em todos */
  padding: 14px 18px;

  border: 1px solid #c91b18;
  color: #c91b18 !important;

  font-weight: 500;
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  line-height: 1.3;
  text-align: center;
  text-decoration: none !important;

  transition: all 0.25s ease;
  box-sizing: border-box;
  margin-top: auto;          /* alinha todos no fundo */
}

/* Hover */
section.features1 .card-box .link a:hover,
section.features1 .card-box a.mbr-link-text:hover {
  background-color: #c91b18;
  color: #ffffff !important;
}


/* =========================================================
   KNOW-HOW (features1) — alinhar ícones, títulos e texto
   ========================================================= */

/* garante que os cards têm layout consistente */
section.features1 .media-container-row .card-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;
}

/* 1) Ícone: reservar a mesma “caixa” para todos */
section.features1 .media-container-row .card-img {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;   /* ajusta se quiseres (110–140 costuma ser o sweet spot) */
  width: 100%;
}

/* Se o ícone for <span> (mbr-iconfont) */
section.features1 .media-container-row .card-img .mbr-iconfont {
  line-height: 1;
}

/* Se forem imagens/svg dentro do card-img */
section.features1 .media-container-row .card-img img,
section.features1 .media-container-row .card-img svg {
  display: block;
  max-height: 90px;    /* garante que nenhum “salta” mais do que os outros */
  height: auto;
}

/* 2) Título: mesma altura para alinhar o início do texto */
section.features1 .media-container-row .card-title,
section.features1 .media-container-row .mbr-section-title {
  min-height: 52px;    /* 1–2 linhas; aumenta se algum título quebrar em 3 */
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 10px;
}

/* 3) Texto: alinhamento consistente */
section.features1 .media-container-row .mbr-text {
  width: 100%;
  text-align: center;  
}



/* =========================================================
   CARDS (ENG/PT) — Uniformizar respiro topo + alturas iguais
   Secções: #features4-4 e #features5-5
   ========================================================= */

/* 0) Row flex para esticar cartões à mesma altura */
#features4-4 .container-fluid > .row.justify-content-center,
#features5-5 .container-fluid > .row.justify-content-center{
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

/* 1) Colunas como flex vertical */
#features4-4 .container-fluid > .row.justify-content-center > [class*="col-"],
#features5-5 .container-fluid > .row.justify-content-center > [class*="col-"]{
  display: flex;
  flex-direction: column;
}

/* =========================
   TEAM CARDS
   ========================= */

#features4-4 .team-card .card-wrap,
#features5-5 .team-card .card-wrap{
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* IMPORTANTE:
   Em vez de justify-content diferente por card, mantemos TODOS no topo
   e controlamos o “respiro” com padding-top consistente (o espaço vermelho). */
#features4-4 .team-card .content-wrap,
#features5-5 .team-card .content-wrap{
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;

  justify-content: flex-start;  /* todos iguais */
  padding-top: 2.25rem;         /* <-- espaço vermelho (ajusta aqui) */
  padding-bottom: 1.5rem;
}

/* Espaçamento entre o título (Segment/Skills/Development/etc.) e o texto */
#features4-4 .team-card .content-wrap .mbr-role,
#features5-5 .team-card .content-wrap .mbr-role{
  margin: 0 0 1rem 0;
}

/* Texto: limpar margens inconsistentes */
#features4-4 .team-card .content-wrap .card-text,
#features5-5 .team-card .content-wrap .card-text{
  margin: 0;
}

/* Se ainda houver <br> dentro dos h3, não deixam “mexer” no alinhamento */
#features4-4 .team-card .content-wrap .card-text br,
#features5-5 .team-card .content-wrap .card-text br{
  display: none;
}

/* =========================
   BROCHURA (só #features5-5)
   ========================= */

#features5-5 .media-container-row.col-md-12.col-lg-4{
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  height: 100%;
}

#features5-5 .media-container-row .card.align-center{
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;  /* centro vertical */
  align-items: center;      /* centro horizontal */
  height: 100%;
}

/* O panel-item ocupa a largura e dá centro “óptico” com padding */
#features5-5 .media-container-row .card.align-center .panel-item{
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
}

#features5-5 .media-container-row .card.align-center .card-text{
  width: 100%;
  max-width: 560px;
  margin: 0 auto;
  text-align: center;
}

#features5-5 .media-container-row .card.align-center .card-text h4,
#features5-5 .media-container-row .card.align-center .card-text h3{
  margin: 0.35rem 0;
}

/* =========================
   Mobile/Tablet: comportamento natural
   ========================= */
@media (max-width: 991.98px){
  #features4-4 .container-fluid > .row.justify-content-center,
  #features5-5 .container-fluid > .row.justify-content-center{
    display: block;
  }

  #features4-4 .container-fluid > .row.justify-content-center > [class*="col-"],
  #features5-5 .container-fluid > .row.justify-content-center > [class*="col-"]{
    display: block;
  }

  #features4-4 .team-card .card-wrap,
  #features4-4 .team-card .content-wrap,
  #features5-5 .team-card .card-wrap,
  #features5-5 .team-card .content-wrap,
  #features5-5 .media-container-row.col-md-12.col-lg-4,
  #features5-5 .media-container-row .card.align-center,
  #features5-5 .media-container-row .card.align-center .panel-item{
    display: block;
    height: auto;
  }

  /* Em mobile: respiro menor */
  #features4-4 .team-card .content-wrap,
  #features5-5 .team-card .content-wrap{
    padding-top: 1.5rem;
    padding-bottom: 1rem;
  }

  #features5-5 .media-container-row .card.align-center .panel-item{
    padding-top: 2.25rem;
    padding-bottom: 2.25rem;
  }
}

/* =========================================================
   BROCHURA — centrar melhor em desktop (ajuste óptico)
   ========================================================= */

/* Desktop e acima */
@media (min-width: 992px) {
  #features5-5 .media-container-row .card.align-center .panel-item {
    padding-top: 6.5rem;
    padding-bottom: 4.5rem;
  }
}

/* =========================================================
   PT — #features4-4
   Corrigir espaço em baixo em "Segmento" e "Competências Qualitativas"
   (centrar verticalmente apenas os 2 primeiros cards da row)
   ========================================================= */

/* Apanha os 2 primeiros team-cards do #features4-4 */
#features4-4 .container-fluid > .row.justify-content-center > .team-card:nth-of-type(1) .content-wrap,
#features4-4 .container-fluid > .row.justify-content-center > .team-card:nth-of-type(2) .content-wrap {
  justify-content: center !important;
  padding-top: 1.75rem !important;
  padding-bottom: 1.75rem !important;
}

/* =========================================================
   CLIENT BASE / RELAÇÃO — PT + ENG
   Layout definitivo com divisor central alinhado ao meio
   ========================================================= */

/* Espaço vertical da secção */
#clients-rel-pt,
#clients-rel-eng{
  padding-top: 3.5rem !important;
  padding-bottom: 3.5rem !important;
}

/* Estrutura base */
#clients-rel-pt .clients-rel-grid,
#clients-rel-eng .clients-rel-grid{
  margin-top: 1.5rem !important;
}

/* Melhorar leitura do texto */
#clients-rel-pt .clients-rel-text p,
#clients-rel-eng .clients-rel-text p{
  line-height: 1.75 !important;
  margin-bottom: 0 !important;
}

/* TÍTULOS */
#clients-rel-pt .clients-rel-title,
#clients-rel-eng .clients-rel-title{
  color: #ffffff !important;
  font-weight: 800 !important;
  letter-spacing: 0.4px !important;
  margin-bottom: 1.25rem !important;
  text-align: left !important;
  position: relative !important;
}

/* Linha vermelha subtil abaixo do título */
#clients-rel-pt .clients-rel-title::after,
#clients-rel-eng .clients-rel-title::after{
  content: "";
  display: block;
  width: 44px;
  height: 2px;
  background: #c91b18;
  margin-top: 0.65rem;
}

/* =========================================================
   DESKTOP — 2 colunas perfeitamente centradas
   ========================================================= */

@media (min-width: 992px){

  /* Row em flex, sem gap (para manter centro matemático) */
  #clients-rel-pt .clients-rel-grid,
  #clients-rel-eng .clients-rel-grid{
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: flex-start !important;
    gap: 0 !important;
  }

  /* Cada coluna ocupa exactamente metade */
  #clients-rel-pt .clients-rel-col,
  #clients-rel-eng .clients-rel-col{
    flex: 0 0 50% !important;
    max-width: 50% !important;
    min-width: 0 !important;
  }

  /* Espaçamento simétrico */
  #clients-rel-pt .clients-rel-col:first-child,
  #clients-rel-eng .clients-rel-col:first-child{
    padding-right: 3rem !important;   /* ajusta aqui se quiseres mais espaço */
  }

  /* Linha exactamente no centro */
  #clients-rel-pt .clients-rel-col + .clients-rel-col,
  #clients-rel-eng .clients-rel-col + .clients-rel-col{
    border-left: 1px solid rgba(255,255,255,0.22) !important;
    padding-left: 3rem !important;    /* igual ao padding-right acima */
  }
}

/* =========================================================
   HERO / Header (id="headerPT")
   1 slide apenas — sem carrossel
   Desktop overlay / Mobile compacto (sem citação)
   Tipografia 100% via CSS (sem Mobirise: sem display-1 / display-2 no HTML)
   ========================================================= */

/* Base */
#headerPT{
  position: relative;
  overflow: hidden;
}

/* Slide único */
#headerPT .hero-slide.wrap{
  position: relative;
  min-height: 85vh;
  overflow: hidden;
}

/* Imagem */
#headerPT .image-element img{
  width: 100%;
  height: auto;
  display: block;
}

/* =========================================================
   TEXTO SOBRE IMAGEM — DESKTOP
   ========================================================= */

#headerPT .text-element{
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  align-items: flex-start;
  transform: translateY(-3.5vh);
}

@media (min-width: 1200px){
  #headerPT .text-element{
    transform: translateY(-5vh);
  }
}

#headerPT .text-element .text-content{
  width: 100%;
  padding-top: clamp(1rem, 3vh, 1.8rem);
  padding-bottom: clamp(3rem, 8vh, 5rem);
}

/* Reserva para quote (desktop) */
#headerPT .block-wrap{
  position: relative;
  padding-top: clamp(4.8rem, 9vh, 6.8rem);
}

/* =========================================================
   CITAÇÃO – Desktop
   ========================================================= */

#headerPT .ogilvy-quote.overlay{
  position: absolute;
  top: 0;
  left: 0;
  z-index: 6;
  max-width: min(980px, 92%);
  text-align: left;
}

#headerPT .ogilvy-text{
  display: inline-block;
  background: rgba(180,180,180,0.78);
  color: #2b2b2b;
  font-family: 'Quicksand', sans-serif;
  font-weight: 400;
  font-size: clamp(1.1rem, 1.2vw + 0.65rem, 2.05rem);
  line-height: 1.25;
  padding: 0.75rem 1.35rem;
  margin: 0 0 0.6rem 0;
}

#headerPT .ogilvy-author{
  display: inline-block;
  background: rgba(180,180,180,0.78);
  color: #2b2b2b;
  font-family: 'Quicksand', sans-serif;
  font-weight: 400;
  font-size: clamp(1rem, 0.85vw + 0.55rem, 1.5rem);
  padding: 0.55rem 1.05rem;
  margin-top: -0.15rem;
}

/* =========================================================
   TÍTULO PRINCIPAL
   ========================================================= */

#headerPT .hero-title,
#headerPT h2.mbr-title{
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  color: #ffffff !important;

  font-size: clamp(2.3rem, 4.2vw + 1rem, 4.6rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -4.5px !important;

  margin: 0 0 0.95rem 0 !important;
  text-align: left !important;
}

/* =========================================================
   SUBTÍTULO — Desktop
   ========================================================= */

#headerPT .hero-subtitle,
#headerPT .mbr-section-text p,
#headerPT p.mbr-text{
  font-family: 'Quicksand', sans-serif !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.92) !important;

  font-size: clamp(1.05rem, 0.9vw + 0.75rem, 1.45rem) !important;
  line-height: 1.7 !important;

  margin: 0 !important;
  max-width: 1100px;
  text-align: left !important;
}

/* =========================================================
   TABLET
   ========================================================= */

@media (max-width: 991px){
  #headerPT .hero-slide.wrap{
    min-height: 70vh;
  }

  #headerPT .text-element{
    transform: translateY(-2.5vh);
  }

  #headerPT .block-wrap{
    padding-top: clamp(4rem, 8vh, 6rem);
  }
}

/* =========================================================
   MOBILE — overlay compacto + texto mais acima + clamp
   ========================================================= */

@media (max-width: 768px){

  /* menos altura para não haver “ar” antes do texto */
  #headerPT .hero-slide.wrap{
    min-height: 60svh !important;
    overflow: hidden !important;
  }

  #headerPT .text-element{
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    align-items: flex-start !important;
    z-index: 5 !important;

    /* ajuste fino: sobe o texto */
    transform: translateY(-6vh) !important;
  }

  /* menos padding em cima = texto começa mais cedo */
  #headerPT .text-element .text-content{
    padding: 0.4rem 1rem 1rem 1rem !important;
  }

  /* remover quote em mobile */
  #headerPT .block-wrap{ padding-top: 0 !important; }
  #headerPT .ogilvy-quote.overlay{ display: none !important; }

  /* título menor */
  #headerPT .hero-title,
  #headerPT h2.mbr-title{
    font-size: clamp(1.26rem, 5.2vw, 1.70rem) !important;
    line-height: 1.12 !important;
    letter-spacing: -0.45px !important;
    margin: 0 0 0.32rem 0 !important;
  }

  /* subtítulo: compacto + clamp */
  #headerPT .hero-subtitle,
  #headerPT .mbr-section-text p,
  #headerPT p.mbr-text{
    font-size: 0.88rem !important;
    line-height: 1.28 !important;

    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;

    -webkit-line-clamp: 4 !important;
    line-clamp: 4 !important;

    overflow: hidden !important;
  }
}

/* =========================================================
   Ecrãs altos (ex.: Redmi Note 14 Pro) — 5 linhas
   ========================================================= */

@media (max-width: 768px) and (min-height: 780px){

  #headerPT .hero-subtitle,
  #headerPT .mbr-section-text p,
  #headerPT p.mbr-text{

    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;

    -webkit-line-clamp: 5 !important;
    line-clamp: 5 !important;

    overflow: hidden !important;
  }
}

/* =========================================================
   Segurança: remover vestígios de carrossel
   ========================================================= */

#headerPT .carousel-controls,
#headerPT .carousel-control-prev,
#headerPT .carousel-control-next,
#headerPT .carousel-indicators{
  display: none !important;
}


/* =========================================================
   VISION / VISÃO — aumentar frase introdutória
   "O futuro projectado pela RPBA é o de:"
   ========================================================= */

#visionheaderPT .mbr-text{

  font-family: 'Quicksand', sans-serif !important;
  font-weight: 500 !important;

  font-size: clamp(1.25rem, 1.2vw + 0.8rem, 1.6rem) !important;
  line-height: 1.55 !important;

  max-width: 900px;
  margin: 0 auto !important;
  text-align: center !important;
}

/* Mobile */
@media (max-width: 768px){
  #visionheaderPT .mbr-text{
    font-size: 1.05rem !important;
    line-height: 1.5 !important;
  }
}


/* =========================================================
   KNOW-HOW (PT + ENG) — mobile legível (corrige “encavalitado”)
   Aplica a: #knowhowdocs1PT e #knowhowdocs2PT
   ========================================================= */

#knowhowdocs1PT .media-container-row,
#knowhowdocs2PT .media-container-row{
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: stretch !important;
}

/* Garantir que os cards não ficam “presos” a larguras estranhas */
#knowhowdocs1PT .card,
#knowhowdocs2PT .card{
  float: none !important;
  height: auto !important;
}

/* Conteúdo com mais ar */
#knowhowdocs1PT .card-inner,
#knowhowdocs2PT .card-inner{
  height: 100% !important;
  padding: 1.1rem 1.15rem !important;
}

/* Ícones: centrados e consistentes */
#knowhowdocs1PT .card-img,
#knowhowdocs2PT .card-img{
  text-align: center !important;
  margin-bottom: 0.8rem !important;
}

#knowhowdocs1PT .card-img .mbr-iconfont,
#knowhowdocs2PT .card-img .mbr-iconfont{
  font-size: 3rem !important;
  line-height: 1 !important;
  display: inline-block !important;
}

/* Títulos: evitar que partam letra a letra */
#knowhowdocs1PT .card-title,
#knowhowdocs2PT .card-title{
  font-size: 1.15rem !important;
  line-height: 1.25 !important;
  margin-bottom: 0.55rem !important;
  text-align: center !important;

  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  hyphens: auto !important;
}

/* Texto: legível */
#knowhowdocs1PT .mbr-text,
#knowhowdocs2PT .mbr-text{
  font-size: 0.98rem !important;
  line-height: 1.55 !important;
  margin-bottom: 0 !important;
  text-align: left !important;
}

/* =========================================================
   MOBILE — 1 cartão por linha (resolve o “encavalitado”)
   ========================================================= */
@media (max-width: 768px){

  #knowhowdocs1PT .media-container-row,
  #knowhowdocs2PT .media-container-row{
    gap: 1rem !important;
  }

  #knowhowdocs1PT .card,
  #knowhowdocs2PT .card{
    flex: 0 0 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  #knowhowdocs1PT .container,
  #knowhowdocs2PT .container{
    padding-left: 1.1rem !important;
    padding-right: 1.1rem !important;
  }
}

/* =========================================================
   TABLET — 2 cartões por linha (opcional, fica muito bem)
   ========================================================= */
@media (min-width: 769px) and (max-width: 991px){

  #knowhowdocs1PT .media-container-row,
  #knowhowdocs2PT .media-container-row{
    gap: 1.2rem !important;
  }

  #knowhowdocs1PT .card,
  #knowhowdocs2PT .card{
    flex: 0 0 calc(50% - 0.6rem) !important;
    max-width: calc(50% - 0.6rem) !important;
    margin: 0 !important;
  }
}