/* ============================================================
   DIÁRIO 94 - Responsivo
   Breakpoints: 1024 (tablet) · 760 (móvel grande) · 480 (móvel)
   ============================================================ */

/* ── ≤ 1024px ───────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
  .split {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .split aside {
    margin-top: 30px;
    border-top: 2px solid var(--black);
    padding-top: 26px;
  }
  .team-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .header-date {
    display: none;
  }
}

/* ── ≤ 880px : navegação passa a menu lateral ───────────────── */
@media (max-width: 880px) {
  .hamburger {
    display: grid;
    place-items: center;
  }
  .header-search input {
    width: 120px;
  }
  .live-badge {
    display: none;
  }

  .site-nav {
    background: transparent;
  }
  .nav-inner {
    position: fixed;
    top: 0;
    right: 0;
    height: 100dvh;
    width: min(320px, 84vw);
    background: var(--black);
    flex-direction: column;
    align-items: stretch;
    padding: 76px 0 30px;
    gap: 0;
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform 0.32s var(--ease);
    z-index: 1600;
    box-shadow: -10px 0 40px rgba(0, 0, 0, 0.3);
  }
  .nav-inner.open {
    transform: translateX(0);
  }
  .nav-inner > a {
    padding: 15px 26px;
    font-size: 13px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    border-left: 3px solid transparent;
  }
  .nav-inner > a.active {
    border-bottom-color: rgba(255, 255, 255, 0.07);
    border-left-color: var(--blue);
    background: rgba(255, 255, 255, 0.04);
  }
  .nav-fechar {
    display: grid;
    place-items: center;
    position: absolute;
    top: 18px;
    right: 18px;
    color: rgba(255, 255, 255, 0.8);
    padding: 6px;
  }

  .nav-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    transition: 0.3s;
    z-index: 1500;
  }
  .nav-overlay.show {
    opacity: 1;
    visibility: visible;
  }
  body.nav-aberto {
    overflow: hidden;
  }
}

/* ── ≤ 760px ────────────────────────────────────────────────── */
@media (max-width: 760px) {
  body {
    font-size: 14.5px;
  }
  .header-inner {
    height: 64px;
    padding: 0 16px;
  }
  .wrap,
  .section,
  .header-inner,
  .nav-inner,
  .footer-inner,
  .footer-bottom,
  .hero,
  .newsletter-inner,
  .page-head-inner,
  .related {
    padding-inline: 16px;
  }
  .section {
    padding-block: 30px;
  }

  /* hero empilha */
  .hero {
    grid-template-columns: 1fr;
    gap: 0;
    padding: 22px 16px 0;
  }
  .hero-main {
    padding-right: 0;
    border-right: none;
    padding-bottom: 22px;
    border-bottom: 1px solid var(--gray-200);
  }
  .hero-side {
    padding-top: 18px;
  }
  .hero-thumb.is-motif::after {
    font-size: 180px;
    bottom: -36px;
  }

  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr;
  }
  .card-wide {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .section-title {
    font-size: 18px;
  }
  .article {
    padding: 28px 16px 16px;
  }
  .article-lead {
    font-size: 17px;
  }
  .article-body {
    font-size: 16px;
  }
  .article-body h2 {
    font-size: 22px;
  }
  .article-body blockquote {
    font-size: 18px;
    padding: 14px 18px;
  }
  .byline-meta {
    margin-left: 0;
    width: 100%;
  }

  .values {
    grid-template-columns: 1fr;
  }
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .form-row {
    grid-template-columns: 1fr;
  }

  .newsletter-inner {
    padding: 32px 16px;
  }
  .newsletter-text h2 {
    font-size: 23px;
  }
  .newsletter-form {
    width: 100%;
  }
  .newsletter-form input {
    width: 100%;
    flex: 1;
    min-width: 0;
  }
  .newsletter-form button {
    width: 100%;
    justify-content: center;
  }
  .newsletter-94 {
    font-size: 110px;
  }

  .footer-inner {
    grid-template-columns: 1fr 1fr;
    gap: 28px;
  }
  .footer-brand {
    grid-column: 1 / -1;
  }
  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
  .footer-legal {
    flex-wrap: wrap;
    gap: 10px 16px;
  }

  .ticker-content span {
    padding: 0 26px;
  }
}

/* ── ≤ 480px ────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .logo-word {
    font-size: 24px;
    padding: 4px 7px 4px 9px;
  }
  .logo-box {
    font-size: 21px;
    padding: 6px 8px;
  }
  .header-search {
    display: none;
  } /* a pesquisa fica no menu */
  .page-title {
    font-size: 28px;
  }
  .article-title {
    font-size: 26px;
  }
  .footer-inner {
    grid-template-columns: 1fr;
  }
  .team-grid {
    grid-template-columns: 1fr 1fr;
  }
  .topo {
    right: 14px;
    bottom: 14px;
  }
}

/* ── Publicidade ────────────────────────────────────────────── */
@media (max-width: 880px) {
  .ad-wrap {
    padding: 18px 18px;
  }
  /* a barra lateral deixa de ser fixa quando passa a uma coluna */
  .ad--sticky {
    position: static;
  }
  /* limita a altura dos formatos grandes em ecrãs pequenos */
  .ad--billboard .ad-box,
  .ad--halfpage .ad-box {
    min-height: 200px;
  }
}
@media (max-width: 480px) {
  .ad-wrap {
    padding: 14px 14px;
  }
  .ad--leaderboard .ad-box,
  .ad--billboard .ad-box,
  .ad--halfpage .ad-box {
    min-height: 120px;
  }
  .ad-ph-94 {
    font-size: 70px;
  }
}

/* ── Empregos ───────────────────────────────────────────────── */
@media (max-width: 880px) {
  .vagas-grid {
    grid-template-columns: 1fr;
  }
  .filtros-busca {
    flex: 1 1 100%;
  }
  .filtros select {
    flex: 1 1 calc(50% - 6px);
  }
  .vaga-head-meta {
    gap: 12px 16px;
  }
}
@media (max-width: 480px) {
  .filtros select {
    flex: 1 1 100%;
  }
  .filtros .btn {
    width: 100%;
    justify-content: center;
  }
  .vaga-head {
    gap: 14px;
  }
  .vaga-logo--lg {
    width: 54px;
    height: 54px;
    font-size: 19px;
  }
}
