.reports-hero {
  background: linear-gradient(135deg, rgba(99,102,241,.08), rgba(14,165,233,.1));
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.reports-hero__title {
  font-weight: 800;
  font-size: clamp(2rem, 2.8vw, 2.7rem);
}

.btn-gradient {
  padding: 0.85rem 1.75rem;
  border-radius: 999px;
  font-weight: 600;
  color: #fff !important;
  background-image: linear-gradient(120deg, #6366f1, #0ea5e9);
  border: 0;
  transition: transform .22s ease, box-shadow .22s ease;
}
.btn-gradient:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 30px rgba(14,165,233,.25);
}

.reports-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.report-card {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  overflow: hidden;
  background: var(--bs-body-bg, #fff);
  box-shadow: 0 20px 35px rgba(15,23,42,.08);
  transition: transform .2s ease, box-shadow .2s ease;
}
.report-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 45px rgba(15,23,42,.12);
}
.report-card__media {
  position: relative;
  overflow: hidden;
  background: #0f172a;
}
.report-card__media::before {
  content: "";
  display: block;
  padding-bottom: 62.5%;
}
.report-card__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.report-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 18px 20px 20px;
}
.report-card__meta {
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  display: flex;
  align-items: center;
  gap: 10px;
}
.report-card__meta .dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
}
.report-card__title {
  margin: 12px 0 8px;
  font-size: 1rem;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.report-card__title a {
  display: block;
  color: inherit;
  text-decoration: none;
}

.report-card__excerpt {
  color: #475569;
  line-height: 1.5;
  flex-grow: 1;
}
.report-card__footer {
  margin-top: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .9rem;
  gap: 12px;
}
.report-card__cta {
  font-weight: 600;
  color: #2563eb;
  text-decoration: none;
}
.report-card__cta::after {
  content: '→';
  margin-left: 6px;
  transition: transform .2s ease;
}
.report-card__cta:hover::after {
  transform: translateX(3px);
}

.report-guide-card {
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 22px;
  background: var(--bs-body-bg, #fff);
  box-shadow: 0 25px 50px rgba(15,23,42,.08);
  background: linear-gradient(135deg, #eef2ff, #ecfeff);
}
.guide-step {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.25rem;
}
.guide-step__number {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: #0ea5e9;
  color: #fff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.report-form-card .form-control{
  border-radius: 0 !important;
}

.report-map {
  width: 100%;
  height: 320px;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.12);
  overflow: hidden;
  background: #f8fafc;
}
.reports-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 340px));
}

.report-card {
  width: 100%;
  max-width: 360px;
  margin-inline: auto;
}

/** Report Details **/

.report-detail {
  padding: 32px 0 72px;
}
.report-detail__grid {
  display: grid;
  gap: 32px;
  grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr);
}
@media (max-width: 992px) {
  .report-detail__grid { grid-template-columns: 1fr; }
}

.report-detail__card {
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 20px;
  background: var(--card-bg, #fff);
  box-shadow: 0 20px 35px rgba(15,23,42,.08);
  overflow: hidden;
}
.report-detail__image {
  position: relative;
  overflow: hidden;
  background: #0f172a;
}
.report-detail__image::before {
  content: "";
  display: block;
  padding-bottom: 56%; /* 16:9 */
}
.report-detail__image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.report-detail__body {
  padding: 24px 26px 30px;
}
.report-detail__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}
.report-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 11px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(15,23,42,.03);
  color: #0f172a;
  font-weight: 600;
  font-size: .9rem;
}
.dark .report-chip {
  color: #e5e7eb;
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
}
.report-detail__summary {
  font-size: 1.05rem;
  color: #475569;
  margin: 14px 0 18px;
  line-height: 1.6;
}
.dark .report-detail__summary { color: #cbd5e1; }
.report-detail__content {
  color: #0f172a;
  line-height: 1.7;
}
.report-detail__content p + p { margin-top: 1em; }
.dark .report-detail__content { color: #e5e7eb; }

.report-detail__sidebar {
  position: sticky;
  top: 90px;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  background: var(--card-bg, #fff);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  padding: 18px;
}

.reports-grid--mini {
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.report-card--compact {
  box-shadow: none;
}
.report-card--compact .report-card__body {
  padding: 14px 15px 16px;
}
.report-card--compact .report-card__title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fw-bold{
  font-weight: bold;
}

.report-chip--action {
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s;
  text-decoration: none;
}
.report-chip--action:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(15,23,42,.12);
}
.report-chip--primary {
  background: linear-gradient(120deg, #6366f1, #0ea5e9);
  color: #fff;
  border-color: rgba(255,255,255,.2);
}

.report-updates {
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  background: var(--card-bg, #fff);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  padding: 18px;
}
.update-card {
  border: 1px solid rgba(15,23,42,.06);
  border-radius: 14px;
  padding: 14px 16px;
  background: linear-gradient(135deg, rgba(99,102,241,.04), rgba(14,165,233,.05));
  box-shadow: 0 12px 24px rgba(15,23,42,.06);
}
.update-card + .update-card { margin-top: 12px; }
.status-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #eef2ff;
  color: #4338ca;
  font-weight: 700;
  font-size: .75rem;
  letter-spacing: .04em;
}
.update-attachments ul { padding-left: 18px; }
.update-attachments a { color: #2563eb; text-decoration: none; }
.update-attachments a:hover { text-decoration: underline; }

.response-card {
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  background: var(--card-bg, #fff);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  padding: 18px;
}


/* Projects page */
.pgp{
  --bg:#f8fafc;
  --card:#ffffff;
  --muted:#6b7280;
  --text:#0f172a;
  --line:rgba(15,23,42,.08);
  --ring:rgba(14,165,233,.25);
  --brand:#6366f1; --brand-2:#0ea5e9;
  --green:#16a34a; --amber:#d97706; --red:#dc2626;
  color:var(--text);
}
.pgp h1{ letter-spacing:-.02em; color:var(--text); }

/* Filter bar */
.pgp-filterbar{
  display:grid;
  gap:12px;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--card);
  box-shadow:0 16px 30px rgba(15,23,42,.08);
}
.pgp-filterbar .field{ display:flex; flex-direction:column; gap:6px; }
.pgp-filterbar label{ font-size:.82rem; color:var(--muted); }
.pgp-filterbar input,
.pgp-filterbar select{
  height:44px; padding:0 12px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fdfefe;
  color:var(--text);
  transition:border-color .15s, box-shadow .15s;
}
.pgp-filterbar input:focus,
.pgp-filterbar select:focus{
  border-color:transparent;
  box-shadow:0 0 0 .35rem var(--ring);
}
.pgp-filterbar .actions{
  display:flex;
  flex-wrap:nowrap;
  align-items:flex-end;
  gap:10px;
  justify-content:flex-start;
  justify-self:start;
  align-self:end;
}

.pgp .btn{
  border-radius:12px;
  padding:.7rem 1rem;
  border:1px solid rgba(99,102,241,.32);
  background:linear-gradient(120deg, var(--brand), var(--brand-2));
  color:#fff;
  font-weight:700;
  box-shadow:0 16px 32px rgba(14,165,233,.26);
  transition:transform .14s, box-shadow .14s, filter .14s;
  text-decoration:none;
}
.pgp .btn:hover{ transform:translateY(-1px); filter:brightness(1.02); }

.pgp-filterbar .btn-soft, #pgpMapToggle{
  height:44px;
  padding:0 14px;
  border-radius:10px;
  border:1px solid rgba(15,23,42,.12);
  background:#f5f6f8;
  color:#0f172a;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  line-height:1;
  transition:background .15s, border-color .15s;
}
.pgp-filterbar .btn-soft:hover, #pgpMapToggle:hover{
  background:#eceff2;
  border-color:rgba(15,23,42,.18);
}
#pgpMapToggle{
  white-space:nowrap;
  min-width:130px;    
}

.pgp-filterbar .btn-solid{
  height:44px; padding:0 18px;
  border-radius:10px;
  border:1px solid rgba(99,102,241,.35);
  background:linear-gradient(120deg, var(--brand), var(--brand-2));
  color:#fff; box-shadow:0 16px 32px rgba(14,165,233,.28);
}
.pgp-filterbar .btn-solid:hover{ transform:translateY(-1px); }

/* KPI row */
.pgp .kpi-row{ display:grid; gap:12px; grid-template-columns:repeat(6,1fr); margin:18px 0 22px; }
.pgp .kpi{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:14px;
  padding:16px 14px;
  min-height:92px;
  display:flex; flex-direction:column; justify-content:center;
  box-shadow:0 16px 30px rgba(15,23,42,.08);
}
.pgp .kpi .kpi-label{ color:var(--muted); font-size:.82rem; margin-bottom:.3rem; }
.pgp .kpi .kpi-value{ color:var(--text); font-size:1.5rem; font-weight:800; letter-spacing:-.01em; }

/* Grid */
.pgp-grid{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  margin-top:16px;
}

@media (max-width: 1100px){
  .pgp-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 820px){
  .pgp-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 540px){
  .pgp-grid{ grid-template-columns: 1fr; }
}

/* Cards */
.proj-card{
  display:flex; flex-direction:column;
  height:100%;
  gap:12px;
  border-radius:16px;
  background:var(--card);
  border:1px solid var(--line);
  padding:14px;
  box-shadow:0 20px 36px rgba(15,23,42,.10);
  transition:transform .16s, box-shadow .16s, border-color .16s;
}
.proj-card:hover{ transform:translateY(-2px); border-color:rgba(99,102,241,.35); box-shadow:0 28px 44px rgba(14,165,233,.18); }

.proj-media-container{ width:100%; aspect-ratio:16/9; border-radius:12px; overflow:hidden; border:1px solid var(--line); background:#0f172a; }
.proj-media{ width:100%; height:100%; object-fit:cover; display:block; }

.proj-card__body{ display:flex; flex-direction:column; gap:10px; flex:1; }
.proj-meta{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }

.proj-title{ color:var(--text); font-size:1.15rem; font-weight:700; letter-spacing:-.01em; margin:0; }
.proj-sub{ color:var(--muted); font-size:.9rem; }

.badge{
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.35rem .6rem;
  border-radius:999px;
  border:1px solid var(--line);
  background:#f6f7fb;
  color:var(--muted);
  font-weight:600; font-size:.74rem;
}
.badge.status{ background:#eef2ff; border-color:#e0e7ff; color:#4f46e5; }
.badge.health.low{ background:#fee2e2; border-color:#fecdd3; color:#b91c1c; }
.badge.health.mid{ background:#fff7ed; border-color:#fed7aa; color:#b45309; }
.badge.health.high{ background:#e2fbe8; border-color:#bbf7d0; color:#15803d; }
.badge.tag{ background:#eef2ff; border-color:#e0e7ff; color:#4f46e5; }

.facts{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.fact{ border:1px solid var(--line); border-radius:12px; padding:10px 12px; background:#f8fafc; }
.fact .label{ color:var(--muted); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; }
.fact .value{ color:var(--text); font-weight:700; margin-top:4px; }

.proj-card__footer{ margin-top:auto; display:flex; align-items:center; gap:12px; }

.progress{
  position:relative; height:10px; border-radius:999px;
  background:#e5e7eb;
  border:1px solid #d7dce2;
  flex:1;
}
.progress > span:first-child{
  display:block; height:100%; border-radius:inherit;
  background:linear-gradient(120deg, var(--brand), var(--brand-2));
}
.progress .progress-label{
  position:absolute; right:-4px; bottom:16px;
  color:var(--text); font-weight:700; font-size:.85rem;
}

/* Map */
.pgp .pgp-mapwrap{
  margin:16px 0 22px;
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--card);
  overflow:hidden;
  box-shadow:0 16px 30px rgba(15,23,42,.08);
}
.pgp #projectsMap{ height:420px; }
.pgp .pgp-map-legend{
  position:absolute; top:12px; right:12px;
  display:inline-flex; gap:12px; align-items:center;
  padding:6px 10px; border-radius:999px;
  background:#ffffff;
  color:var(--text); border:1px solid var(--line);
  font-size:.8rem; font-weight:600; z-index:1001;
}
.pgp .pgp-map-legend .dot{ width:10px; height:10px; border-radius:50%; margin-right:6px; display:inline-block; }
.pgp .dot-ongoing{ background:var(--green); }
.pgp .dot-completed{ background:var(--brand); }
.pgp .dot-delayed{ background:var(--red); }

/* Responsive */
@media (max-width:1200px){
  .pgp-filterbar{ grid-template-columns:repeat(auto-fit, minmax(180px, 1fr)); }
  .pgp-filterbar .actions{ justify-content:flex-start; }
  .pgp .kpi-row{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:1100px){
  .pgp-filterbar .actions{
    grid-column:1 / -1;
    justify-self:start;
    flex-wrap:wrap;
  }
}
@media (max-width:860px){
  .pgp .kpi-row{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .pgp-filterbar{ grid-template-columns:1fr; }
  .facts{ grid-template-columns:1fr; }
  .proj-card__footer{ flex-direction:column; align-items:flex-start; }
}
