/* =========================================================
 * BSSP na Mídia — visual elegante, corporativo, minimalista
 * Compatível com Astra / Elementor
 * ========================================================= */
:root{
  --bssp-azul:        #0b2447;
  --bssp-azul-2:      #19376d;
  --bssp-azul-soft:   #1b4a8a;
  --bssp-neutro-bg:   #f7f8fb;
  --bssp-neutro-line: #e6e8ee;
  --bssp-text:        #1b1f2a;
  --bssp-muted:       #6b7280;
  --bssp-white:       #ffffff;
  --bssp-radius:      14px;
  --bssp-shadow:      0 6px 24px rgba(11,36,71,.06);
  --bssp-shadow-hov:  0 16px 40px rgba(11,36,71,.14);
}

.bssp-midia-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px 20px 64px;
  color: var(--bssp-text);
  font-family: inherit;
}

/* ===== HERO (renderizado pelo template da página) ===== */
.bssp-hero{
  position: relative;
  background: linear-gradient(135deg, var(--bssp-azul) 0%, var(--bssp-azul-2) 100%);
  color: #fff;
  padding: 96px 24px 88px;
  text-align: center;
  overflow: hidden;
}
.bssp-hero::after{
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(circle at 20% 10%, rgba(255,255,255,.08), transparent 40%),
                    radial-gradient(circle at 80% 90%, rgba(255,255,255,.06), transparent 45%);
  pointer-events:none;
}
.bssp-hero__eyebrow{
  letter-spacing: .25em; text-transform: uppercase; font-size: 12px;
  color: rgba(255,255,255,.7); margin-bottom: 18px;
}
.bssp-hero__title{
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 700; line-height: 1.05; margin: 0 0 18px;
  letter-spacing: -0.02em;
}
.bssp-hero__sub{
  max-width: 760px; margin: 0 auto;
  font-size: clamp(16px, 1.6vw, 18px);
  color: rgba(255,255,255,.85); line-height: 1.6;
}
.bssp-hero__cta{
  display:inline-block; margin-top: 28px;
  padding: 14px 28px; border-radius: 999px;
  background:#fff; color: var(--bssp-azul);
  font-weight: 600; text-decoration:none;
  transition: transform .25s ease, box-shadow .25s ease;
}
.bssp-hero__cta:hover{ transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0,0,0,.18); }

/* ===== Breadcrumbs ===== */
.bssp-breadcrumbs{
  max-width:1200px; margin: 18px auto 0; padding: 0 20px;
  font-size: 13px; color: var(--bssp-muted);
}
.bssp-breadcrumbs a{ color: var(--bssp-azul); text-decoration:none; }
.bssp-breadcrumbs span{ margin: 0 6px; }

/* ===== Matéria em destaque ===== */
.bssp-destaque{
  position:relative; border-radius: var(--bssp-radius); overflow:hidden;
  background: #0b2447 var(--bg) center/cover no-repeat;
  min-height: 320px; margin-bottom: 36px;
  box-shadow: var(--bssp-shadow);
}
.bssp-destaque::before{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(11,36,71,.25) 0%, rgba(11,36,71,.85) 100%);
}
.bssp-destaque__inner{
  position:relative; z-index:1; color:#fff; padding: 48px;
  max-width: 760px;
}
.bssp-destaque__tag{
  display:inline-block; padding: 6px 12px; border-radius: 999px;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.25);
  font-size: 11px; letter-spacing: .2em; text-transform: uppercase; margin-bottom: 14px;
}
.bssp-destaque__title{ font-size: clamp(24px, 3vw, 36px); line-height:1.15; margin: 0 0 12px; letter-spacing:-.01em; }
.bssp-destaque__resumo{ opacity:.9; line-height:1.6; margin: 0 0 20px; }
.bssp-destaque__cta{ color:#fff; text-decoration:none; border-bottom: 1px solid rgba(255,255,255,.5); padding-bottom: 4px; font-weight:600; }
.bssp-destaque__cta:hover{ border-color:#fff; }
.bssp-destaque__veiculo{ display:block; margin-top: 18px; font-size:12px; opacity:.75; letter-spacing:.12em; text-transform:uppercase; }

/* ===== Filtros ===== */
.bssp-midia-filters{
  display:grid; gap: 14px;
  grid-template-columns: repeat(4, minmax(0,1fr));
  background: var(--bssp-white);
  border: 1px solid var(--bssp-neutro-line);
  border-radius: var(--bssp-radius);
  padding: 18px; margin-bottom: 28px;
  box-shadow: var(--bssp-shadow);
}
.bssp-filter label{
  display:block; font-size: 11px; letter-spacing:.18em; text-transform:uppercase;
  color: var(--bssp-muted); margin-bottom: 6px;
}
.bssp-filter select, .bssp-filter input[type=search]{
  width:100%; padding: 12px 14px; border-radius: 10px;
  border: 1px solid var(--bssp-neutro-line); background: var(--bssp-neutro-bg);
  font-size: 14px; color: var(--bssp-text); outline:none;
  transition: border-color .2s, background .2s;
}
.bssp-filter select:focus, .bssp-filter input:focus{
  border-color: var(--bssp-azul-soft); background:#fff;
}

/* ===== Grid de cards ===== */
.bssp-midia-grid{
  display:grid; gap: 28px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.bssp-card{
  background:#fff; border:1px solid var(--bssp-neutro-line); border-radius: var(--bssp-radius);
  overflow:hidden; display:flex; flex-direction:column;
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  box-shadow: var(--bssp-shadow);
}
.bssp-card:hover{ transform: translateY(-6px); box-shadow: var(--bssp-shadow-hov); border-color:#dbe0ea; }
.bssp-card__media{ display:block; aspect-ratio: 16/10; overflow:hidden; background: var(--bssp-neutro-bg); }
.bssp-card__media img{ width:100%; height:100%; object-fit:cover; transition: transform .6s ease; }
.bssp-card:hover .bssp-card__media img{ transform: scale(1.05); }
.bssp-card__placeholder{
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  font-weight:700; letter-spacing:.3em; color: var(--bssp-azul); background: linear-gradient(135deg,#eef2f8,#dde6f3);
}
.bssp-card__body{ padding: 22px; display:flex; flex-direction:column; gap:10px; flex:1; }
.bssp-card__meta{ font-size: 12px; color: var(--bssp-muted); display:flex; gap:8px; align-items:center; letter-spacing:.04em; }
.bssp-card__veiculo{ text-transform:uppercase; letter-spacing:.18em; color: var(--bssp-azul); font-weight:600; }
.bssp-card__title{ font-size: 18px; line-height:1.3; margin:4px 0 0; color: var(--bssp-text); letter-spacing:-.01em; }
.bssp-card__resumo{
  font-size: 14px; color: var(--bssp-muted); line-height:1.55; margin:0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient: vertical; overflow:hidden;
}
.bssp-card__pessoa{ font-size: 12px; color: var(--bssp-azul-2); }
.bssp-card__pessoa a{ color: inherit; text-decoration:none; }
.bssp-card__cta{
  margin-top:auto; align-self:flex-start; color: var(--bssp-azul);
  font-weight:600; text-decoration:none; font-size:14px;
  border-bottom: 1px solid transparent; transition: border-color .2s;
}
.bssp-card__cta:hover{ border-color: var(--bssp-azul); }

/* ===== Paginação ===== */
.bssp-midia-pagination{ display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin-top: 40px; }
.bssp-midia-pagination a, .bssp-midia-pagination .current{
  display:inline-flex; align-items:center; justify-content:center;
  min-width: 40px; height: 40px; padding: 0 12px; border-radius: 10px;
  border: 1px solid var(--bssp-neutro-line); background:#fff;
  color: var(--bssp-text); text-decoration:none; font-size:14px;
  transition: all .2s;
}
.bssp-midia-pagination a:hover{ border-color: var(--bssp-azul); color: var(--bssp-azul); }
.bssp-midia-pagination .current{ background: var(--bssp-azul); color:#fff; border-color: var(--bssp-azul); }

/* ===== Vazio ===== */
.bssp-midia-empty{ text-align:center; padding: 60px 20px; color: var(--bssp-muted); }

/* ===== Animação suave dos cards ===== */
@keyframes bssp-fade-up{ from{opacity:0; transform: translateY(12px);} to{opacity:1; transform:none;} }
.bssp-midia-grid .bssp-card{ animation: bssp-fade-up .5s ease both; }
.bssp-midia-grid .bssp-card:nth-child(2){ animation-delay:.05s; }
.bssp-midia-grid .bssp-card:nth-child(3){ animation-delay:.10s; }
.bssp-midia-grid .bssp-card:nth-child(4){ animation-delay:.15s; }
.bssp-midia-grid .bssp-card:nth-child(5){ animation-delay:.20s; }
.bssp-midia-grid .bssp-card:nth-child(6){ animation-delay:.25s; }
.bssp-midia-grid .bssp-card:nth-child(7){ animation-delay:.30s; }
.bssp-midia-grid .bssp-card:nth-child(8){ animation-delay:.35s; }
.bssp-midia-grid .bssp-card:nth-child(9){ animation-delay:.40s; }

/* ===== Compartilhamento social ===== */
.bssp-share{ display:flex; gap:10px; align-items:center; margin: 24px 0 8px; font-size:13px; color: var(--bssp-muted); }
.bssp-share a{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--bssp-neutro-line); color: var(--bssp-azul);
  text-decoration:none; transition: all .2s;
}
.bssp-share a:hover{ background: var(--bssp-azul); color:#fff; border-color: var(--bssp-azul); }

/* ===== Responsivo ===== */
@media (max-width: 980px){
  .bssp-midia-filters{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .bssp-midia-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .bssp-destaque__inner{ padding: 32px; }
}
@media (max-width: 620px){
  .bssp-hero{ padding: 64px 20px 56px; }
  .bssp-midia-filters{ grid-template-columns: 1fr; }
  .bssp-midia-grid{ grid-template-columns: 1fr; }
  .bssp-destaque{ min-height: 260px; }
  .bssp-destaque__inner{ padding: 24px; }
}
