/* Container das cartas */
#jobrow .container-fluid .box{
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  width: 100%;
  justify-content: center;   /* <-- centra 1 carta ou várias em cada linha */
  align-items: stretch;
  margin-left: auto;         /* <-- opcional: garante que a .box fica centrada */
  margin-right: auto;        /*     dentro do container-fluid */
  height: fit-content;
}

/* Cada carta */
#jobrow .card{
  flex: 0 1 300px;  /* base ~200px; ficam lado a lado e quebram quando não couber */
  display: block;
  text-decoration: none;
  pointer-events: auto;
}

@media (max-width: 768px){
  #jobrow .card{ flex-basis: 160px; }
}

#jobrow .container-fluid .box{
  max-width: 1200px; /* ajusta ao teu layout */
}

/* ---- Hover/Focus FX para as cartas ---- */
#jobrow .card{
  position: relative;
  border-radius: 12px;            /* se já tiveres, podes remover */
  overflow: hidden;               /* p/ shine não sair fora */
  transition: transform .25s cubic-bezier(.22,.61,.36,1),
              box-shadow .25s cubic-bezier(.22,.61,.36,1),
              filter .25s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
}

/* Variável de acento pelo naipe (vermelho/preto) */
#jobrow .card[data-suit="heart"],
#jobrow .card[data-suit="diamond"]{ --accent: rgba(0, 0, 0, .20); }   /* vermelho */
#jobrow .card[data-suit="club"],
#jobrow .card[data-suit="spade"]  { --accent: rgba(0, 0, 0, .20); }       /* preto/neutro */

/* Brilho (glow) sutil */
#jobrow .card::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(600px circle at 50% 20%, var(--accent, rgba(0,0,0,.2)) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events: none;
}

/* “Shine” a passar */
#jobrow .card::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(75deg,
              rgba(255,255,255,0) 0%,
              rgba(255,255,255,.35) 18%,
              rgba(255,255,255,0) 36%);
  transform: translateX(-120%) skewX(-15deg);
  transition: transform .7s ease;
  pointer-events: none;
}

/* Elementos internos também dão um “pop” */
#jobrow .card .symbol,
#jobrow .card .textstars{
  transition: transform .25s cubic-bezier(.22,.61,.36,1), opacity .25s ease;
}

/* Estado hover/focus */
#jobrow .card:hover,
#jobrow .card:focus-visible{
  transform: translateY(-6px) scale(1.02);
  /*box-shadow: 0 12px 24px rgba(0,0,0,.18), 0 0 0 3px var(--accent, rgba(0,0,0,.15));*/
}

#jobrow .card:hover::before,
#jobrow .card:focus-visible::before{
  opacity: 1;
}
#jobrow .card:hover::after,
#jobrow .card:focus-visible::after{
  transform: translateX(120%) skewX(-15deg);
}

/* Símbolos ligeiramente maiores no hover/focus */
#jobrow .card:hover .symbol,
#jobrow .card:focus-visible .symbol{
  transform: translateY(-2px) scale(1.06);
}
#jobrow .card:hover .textstars,
#jobrow .card:focus-visible .textstars{
  transform: scale(1.04);
}

/* Acessibilidade: highlight claro para teclado */
#jobrow .card:focus-visible{
  outline: none;
}

/* Respeitar utilizadores sensíveis a movimento */
@media (prefers-reduced-motion: reduce){
  #jobrow .card,
  #jobrow .card .symbol,
  #jobrow .card .textstars{
    transition: none;
  }
  #jobrow .card:hover,
  #jobrow .card:focus-visible{
    transform: none;
    box-shadow: 0 0 0 3px var(--accent, rgba(0,0,0,.2));
  }
  #jobrow .card::after,
  #jobrow .card::before{
    display: none;
  }
}

:root{
  /* relativo ao ficheiro CSS: ../images/...  */
  --card-row-bg: url('../images/luxury-leather-armchair-modern-office-design-generated-by-ai.jpg') center/cover no-repeat;
  --card-row-estagio-bg: url('../images/medium-shot-architect-engineer-supervising-construction.jpg') center/cover no-repeat;
}

#jobrow .card{
  position: relative;
  overflow: hidden;
  background-color: #03515A;
  border: none !important;
  border-radius: 0;
  text-decoration: none;
  
  display: flex;
  flex-wrap: wrap;
}

/* O elemento “quebra” ocupa a largura toda, não aparece visualmente */
#jobrow .box .row-break {
  flex-basis: 100%;
  width: 0;
  height: 0;
  padding: 0;
  margin: 0;
  display: block;
}

/* (Opcional) Se quiseres garantir que Estágios ficam sempre depois no fluxo visual mesmo com Flex order */
#jobrow .box .card { order: 1; }
#jobrow .box .card.cat-estagios { order: 2; }
/* A quebra fica imediatamente antes dos Estágios */
#jobrow .box .row-break { order: 2; }

#jobrow .card .svg-bg-card-star{
  position: absolute;
  inset: 0;
  background: var(--card-row-bg);
  opacity: .1;
  pointer-events: none;
}

.cat-estagios .svg-bg-card-star{
  position: absolute;
  inset: 0;
  background: var(--card-row-estagio-bg)!important;
  opacity: .1;
  pointer-events: none;
}

#jobrow .card > *{ position: relative; z-index: 1; }

#jobrow .card {
    border-radius: 0;
    border: 1px solid #bfab91;
    background: #bfab91c2;
}

#jobrow .center-content .job-title {
    color: #03515A !important;
    font-size: 1.5rem;
}

#jobrow .center-content .job-line {
    color: #03515A !important;
}

.cat-estagios {
    background: #FEEBDC !important;
}