/* ===== Wrap ===== */
.module.jobs{
  color:#111;
  padding: 2rem 1.25rem 1rem;
  margin-bottom: -1.5rem;
}

/* ===== Title ===== */
.jobs__title{
  font-weight: 800;
  letter-spacing: .5px;
  font-size: clamp(22px, 5vw, 40px);
  color:#FF0000; /* rojo marca */
  margin: 0 0 1.25rem;
}

/* ===== Grid de cards ===== */
.jobs__grid{
  display:grid;
  gap: clamp(18px, 2vw, 24px);
  grid-template-columns: repeat(1, minmax(0, 1fr));
  margin-bottom: 1.25rem;
}
@media (min-width: 720px){
  .jobs__grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1100px){
  .jobs__grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* ===== Card ===== */
.job-card{
  position: relative;
  background: #ede8dc;        /* beige */
  border: 1px solid #000;
  padding: 28px 24px 78px;
  min-height: 420px;
  box-shadow: 10px 10px 0 #000;
}

.job-card__icon{
  width: 60px; height: 60px; object-fit: contain;
  display:block;
  margin: 0 0 8px;
}

.job-card__role{
  font-size: clamp(22px, 2.8vw, 26px);
  margin: 0 0 6px;
}

.job-card__sep{
  border: none;
  border-top: 2px solid #222;
  margin: 10px 0 14px;
}

.job-card__desc{
  font-size: 16px;
  line-height: 1.55;
  color:#1a1a1a;
  padding-bottom: 7rem;
  white-space: pre-line;   /* respeta saltos del admin */
}

/* CTA con sombra offset */
.job-card__cta{
  position:absolute;
  left: 24px; right: 24px; bottom: 24px;
  height: 48px;
  background:#fff;
  border:1px solid #000;
  letter-spacing: .04em;
  transition: transform .15s ease, box-shadow .15s ease;
  z-index:2;
}

/* ===================================================== */
/* ================== DETALLES (nuevo) ================= */
/* Panel colapsable con viewport animado (lo maneja JS) */
.jobs__details{
  display: grid;
  grid-template-rows: 0fr;       /* colapsado */
  transition: grid-template-rows 500ms ease;
}
.jobs__details.open{ grid-template-rows: 1fr; }

.jobs__details-clip{
  overflow: hidden;              /* truco del 0fr/1fr */
  position: relative;
  margin-top: 6px;
}

/* viewport que animamos en altura cuando cambia de contenido */
.jobs__details-viewport{
  position: relative;
  height: 0;                     /* seteado por JS */
  transition: height 420ms cubic-bezier(.22,.61,.36,1);
}

/* cada detail apilado y con fade */
.job-detail{
  position:absolute;
  inset: 0;
  padding: clamp(18px, 2vw, 28px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 320ms ease;
}
.job-detail.is-active{
  opacity: 1;
  pointer-events: auto;
}

/* ====== GRID de 3 columnas (cada hijo = una columna) ====== */
.job-detail__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 24px 32px;
  align-items:start;
}
@media (max-width: 1024px){
  .job-detail__grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px){
  .job-detail__grid{ grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .module.jobs {
    padding: 1.5rem 0.5rem 0.75rem;
    margin-bottom: -0.75rem;
  }
  .jobs__title {
    font-size: 7vw;
    margin-bottom: 1rem;
    text-align: center;
  }
  .jobs__grid {
    gap: 12px;
    grid-template-columns: 1fr;
    margin-bottom: 1rem;
  }
  .job-card {
    padding: 18px 10px 60px;
    min-height: 280px;
    box-shadow: 4px 4px 0 #000;
  }
  .job-card__icon {
    width: 44px;
    height: 44px;
    margin-bottom: 6px;
  }
  .job-card__role {
    font-size: 6vw;
    margin-bottom: 4px;
    text-align: center;
  }
  .job-card__desc {
    font-size: 3.8vw;
    padding-bottom: 3rem;
    text-align: left;
  }
  .job-card__cta {
    left: 10px;
    right: 10px;
    bottom: 10px;
    height: 40px;
    font-size: 4vw;
  }
  .job-detail {
    padding: 12px 6px;
  }
  .job-detail__grid {
    gap: 12px 8px;
  }
  .job-detail__title {
    font-size: 4vw;
    margin-bottom: 0.3rem;
  }
  .job-detail__text,
  .job-detail__fallback {
    font-size: 3.5vw;
  }
  .job-detail__footer {
    margin-top: 16px;
  }
  .button-v2.job-detail__apply {
    padding: 10px 8px;
    font-size: 4vw;
  }
}

/* tipografías y colores alineados a lo existente */
.job-detail__title{
  text-transform: uppercase;
  letter-spacing: .5px;
  font-size: clamp(12px, 2.2vw, 14px);
  margin: 0 0 .5rem;
  color:#111;
}

.job-detail__text,
.job-detail__fallback{
  font-size: 14px;
  line-height: 1.55;
  white-space: pre-line;   /* respeta saltos del admin */
  color:#1a1a1a;
}

/* ====== Footer + botón APPLY ====== */
.job-detail__footer{ margin-top: 24px; }

/* usamos tu .button-v2; si ya existe, solo la extensión */
.button-v2.job-detail__apply{
  width: 100%;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  text-transform: uppercase;
  text-decoration: none;
  background: #FF0000;   /* rojo marca */
  color: #fff;
  border: 1px solid #000;
  padding: 14px 18px;
  font-weight: 700;
  letter-spacing: .04em;
}
