:root{
  --bg:#0b1020;
  --card:#131a2c;
  --muted:#9fb0d0;
  --text:#e9eef9;
  --brand:#3b82f6;
  --brand-2:#22d3ee;
  --ring: rgba(59,130,246,.35);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Arial, sans-serif;
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(34,211,238,.12), transparent 60%),
    radial-gradient(900px 500px at 110% 10%, rgba(59,130,246,.12), transparent 60%),
    linear-gradient(180deg, #0b1020, #0b1020 60%);
  color:var(--text);
}
.container{max-width:1280px;margin:0 auto;padding:16px}

/* Header com destaque */
.site-header{
  position:sticky; top:0; z-index:100;
  backdrop-filter:saturate(140%) blur(10px);
  background:linear-gradient(180deg, rgba(19,26,44,.92), rgba(19,26,44,.75));
  border-bottom:1px solid rgba(255,255,255,.10);
}
.header-inner{display:flex;align-items:center;justify-content:space-between; padding:10px 0;}
.brand{display:flex;gap:14px;align-items:center}

/* logo como imagem com sombra branca */
.logo{
  width:95px;height:76px;border-radius:14px;
  object-fit:contain; display:block;
  background:rgba(255,255,255,.08);
  padding:6px;
  border:1px solid rgba(255,255,255,.45);
  filter: drop-shadow(0 0 10px rgba(255,255,255,.65));
}

.site-title{
  font-weight:700;letter-spacing:.2px; font-size:1.05rem; color:#dbe7ff;
}
.site-subtitle{
  margin-top:2px;
  font-size:1.35rem; font-weight:900; letter-spacing:.3px;
  background:linear-gradient(90deg, #fff, #cfe1ff);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow:0 0 16px rgba(255,255,255,.12);
}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04); color:var(--text);
  border-radius:12px;text-decoration:none;cursor:pointer;
}
.btn:hover{border-color:rgba(255,255,255,.3)}
.btn.subtle{background:transparent}

.card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;padding:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}

/* Filtros compactos */
.filters{margin-top:20px}
.filters-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.filters-head h2{margin:0;font-size:1.05rem}
.filters-actions .chk{font-weight:600}
.filters-body{
  display:grid; gap:10px;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
.fieldset-cat{
  margin:0; padding:10px 12px;
  border:1px solid rgba(255,255,255,.08); border-radius:12px;
  background:rgba(255,255,255,.03);
}
.fieldset-cat legend{padding:0 8px;color:#cfe1ff;font-weight:700;font-size:.95rem}
.chk-grid{
  display:grid; gap:8px;
  grid-template-columns:repeat(2, minmax(0,1fr));
}
@media (max-width:520px){.chk-grid{grid-template-columns:1fr}}
.chk{
  display:flex;align-items:center;gap:8px;font-size:.95rem;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.06);
  padding:6px 8px; border-radius:10px;
}
.chk input{accent-color:var(--brand)}

.cards-wrap{margin:22px 0}
.cards-grid{
  display:grid;gap:14px;
  grid-template-columns:repeat(5, minmax(0, 1fr));
}
@media (max-width:1400px){.cards-grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:1100px){.cards-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:820px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.cards-grid{grid-template-columns:repeat(1,1fr)}}

/* Cards */
.card-item{
  background:var(--card);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;overflow:hidden;
  display:flex;flex-direction:column;
  min-height:280px; /* padrão com imagem */
}
.card-item.no-media{
  min-height:0; /* cartões menores quando não tem imagem */
}

.card-media{
  flex:0 0 150px;
  position:relative; z-index:0;
  background:#0f1729;
  /* centraliza e impede cortes usando max-constraints */
  display:flex; align-items:center; justify-content:center;
  padding:8px;
  overflow:hidden;
}
.card-media img{
  max-width:100%; max-height:100%;
  width:auto; height:auto;
  display:block;
  object-fit:contain;
}

.card-body{
  position:relative; z-index:1;
  padding:12px 12px 14px;
  display:flex;flex-direction:column;gap:8px;
  flex:1;
}
.card-title{
  font-weight:800;line-height:1.25;min-height:2.5em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden
}
.card-meta{color:var(--muted);font-size:.9rem}

/* Sempre centralizado e colado no rodapé do card */
.card-actions{margin-top:auto;display:flex;justify-content:center}
.card-actions .btn{padding:8px 12px;border-radius:10px}

/* separador entre cards com e sem imagem */
.grid-break{grid-column:1 / -1; height:0}

.cards-empty{padding:18px;text-align:center;color:var(--muted)}

/* Modal acima do header e com rolagem */
.modal{position:fixed;inset:0;display:none; z-index:2000; }
.modal.show{display:block; overflow:auto;}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5); z-index:1990;}
.modal-dialog{
  position:relative; margin:4vh auto 4vh;
  width:min(1000px, 92%); max-height:92vh; overflow:auto;
  border-radius:16px;
  background:var(--card); border:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 40px rgba(0,0,0,.5);
  z-index:2001;
}
.modal-close{
  position:sticky; top:8px; float:right;
  width:36px;height:36px;border-radius:10px;
  border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:var(--text);
  cursor:pointer; margin:10px;
}
.modal-content{padding:6px 16px 16px}
.detail-header{display:flex;gap:12px;align-items:center;margin:6px 0 8px}
.detail-title{font-size:1.35rem;font-weight:900}
.detail-sub{color:var(--muted);font-size:.95rem}
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (max-width:720px){.detail-grid{grid-template-columns:1fr}}
.detail-block{padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(255,255,255,.03)}
.detail-block h4{margin:0 0 8px;font-size:1rem;color:#cfe1ff}
.kv{margin:4px 0}
.kv b{font-weight:700}

/* Galeria do modal e lightbox */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media (max-width:720px){.gallery{grid-template-columns:repeat(2,1fr)}}
gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
}
@media (max-width:720px){
  .gallery{grid-template-columns:repeat(2,1fr)}
}
.gallery img{
  width:100%;
  height:auto;
  aspect-ratio:4 / 3;         /* cada célula fica uniforme */
  object-fit:contain;          /* não corta a imagem */
  background:#0f1729;          /* letterbox discreto */
  padding:6px;                 /* respiro para bordas */
  border-radius:10px;
  border:1px solid rgba(255,255,255,.08);
  cursor:zoom-in;
}
.lightbox{
  position:fixed; inset:0; background:rgba(0,0,0,.85);
  display:flex; align-items:center; justify-content:center;
  z-index:3000; padding:20px;
}
.lightbox img{max-width:95vw; max-height:90vh; width:auto; height:auto; border-radius:10px}
.lightbox .close{
  position:fixed; top:16px; right:16px; width:40px; height:40px;
  border-radius:12px; border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.08); color:#fff; font-size:22px; cursor:pointer;
}


/* Seletor de cidade */
.city-picker{margin-top:20px}
.city-search{margin-bottom:10px}
.city-input{
  width:100%; padding:10px 12px; border-radius:12px;
  border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.04);
  color:#fff; outline:none;
}
.city-input:focus{border-color:rgba(255,255,255,.35)}
.city-list{
  display:grid; gap:8px;
  grid-template-columns:repeat(3, minmax(0,1fr));
}
@media (max-width:900px){.city-list{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.city-list{grid-template-columns:1fr}}
.city-opt{
  text-align:left; padding:10px 12px; border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03); color:#e9eef9; cursor:pointer;
}
.city-opt:hover{border-color:rgba(255,255,255,.35)}
