.tt-vac-box{
  border:1px solid rgba(0,0,0,.12);
  border-radius:10px;
  padding:12px;
  margin:10px 0 12px;
  background:#fff;
}
body.home .voxel-composer {
    display: none !important;
}
.tt-vac-title{ margin:0 0 8px; font-size:14px; }
.tt-vac-row{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:10px; }
.tt-vac-field{ flex:1 1 220px; }
.tt-vac-field label{ display:block; font-size:12px; opacity:.8; margin-bottom:6px; }
.tt-vac-field select, .tt-vac-field input,
.tt-vac-select{
  width:100%; padding:10px; border:1px solid rgba(0,0,0,.15);
  border-radius:8px; font-size:13px; background:#fff;
}
.tt-vac-hint{ display:block; margin-top:8px; opacity:.75; font-size:12px; }
.tt-vac-err{ display:none; color:#b00020; opacity:1; margin-top:8px; font-size:12px; }

.tt-vac-badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:999px;
  border:1px solid rgba(0,0,0,.12); background:#fff;
  font-size:12px; margin-right:8px;
}
.tt-vac-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  font-size:13px;
  margin:6px 0 0;
  opacity:.9;
}
.tt-vac-meta-item{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(0,0,0,0.04);
}
.tt-vac-meta a.tt-vac-meta-item{
  text-decoration:none;
}
.tt-vac-meta-label{ font-weight:600; }
.tt-vac-meta-icon{ line-height:1; }

/* Filter bar below composer */
.tt-vac-filterbar{
  border:1px solid rgba(0,0,0,.10);
  border-radius:12px;
  padding:12px;
  background:#fff;
  margin:8px 0 12px;
}
.tt-vac-filterbar .tt-vac-chipwrap{ display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.tt-vac-chip{
  border:1px solid rgba(0,0,0,.14);
  background:#f7f7f7;
  padding:8px 10px;
  border-radius:999px;
  cursor:pointer;
  font-size:13px;
  line-height:1;
}
.tt-vac-chip.active{ background:#111; color:#fff; border-color:#111; }

/* Collapsible Announcement Settings */
.tt-vac-box.tt-vac-collapsible .tt-vac-body{ display:none; }
.tt-vac-box.tt-vac-collapsible.is-open .tt-vac-body{ display:block; }
.tt-vac-toggle{
  display:flex;
  align-items:center;
  justify-content:space-between;
  cursor:pointer;
  user-select:none;
  margin:0;
  font-size:14px;
}
.tt-vac-toggle .tt-vac-arrow{
  font-size:14px;
  opacity:.7;
  transition:transform .18s ease;
}
.tt-vac-box.tt-vac-collapsible.is-open .tt-vac-arrow{
  transform:rotate(180deg);
}
.tt-vac-toggle-hint{
  font-size:12px;
  opacity:.7;
  margin-top:6px;
}

/* Past / expired announcements styling */
.tt-vac-expired{
  opacity: .55;
  filter: grayscale(1);
}
.tt-vac-expired .tt-vac-badge{
  background: #f3f3f3;
}

/* Related announcements list (single masjid template) */
.tt-vac-related{
  margin: 10px 0 14px;
}
.tt-vac-empty{
  border: 1px dashed rgba(0,0,0,.18);
  border-radius: 12px;
  padding: 14px;
  background: #fff;
  opacity: .85;
}
.tt-vac-list{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.tt-vac-item{
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  padding: 12px;
  background: #fff;
}
.tt-vac-item.is-past{
  opacity: .55;
  filter: grayscale(1);
}
.tt-vac-item-head{
  display:flex;
  align-items:center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}
.tt-vac-icon{ font-size: 16px; }
.tt-vac-cat{
  font-weight: 600;
  font-size: 13px;
}
.tt-vac-date{
  margin-left: auto;
  font-size: 12px;
  opacity: .7;
}
.tt-vac-when{
  display:inline-flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
}
.tt-vac-when-ico{ line-height:1; }
.tt-vac-item-body{
  font-size: 13px;
  line-height: 1.45;
  opacity: .95;
}
.tt-vac-item-foot{
  margin-top: 10px;
}
.tt-vac-link,
.tt-vac-viewall-link{
  font-size: 12px;
  text-decoration: none;
}
.tt-vac-viewall{
  margin-top: 10px;
}
.tt-vac-debug{
  background: #111;
  color: #eee;
  padding: 10px;
  border-radius: 12px;
  overflow: auto;
  font-size: 12px;
}
