/* ============================================================
 * 07. MODAL — Activity Report
 * ============================================================ */
#reportDownloadBtn { cursor: pointer !important; }

.report-modal-overlay {
  position: fixed; inset: 0;
  width: 100vw; height: 100vh;
  background-color: rgba(255,255,255,.8);
  z-index: 10000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity .4s cubic-bezier(.25,.8,.25,1), visibility .4s;
}
.report-modal-overlay.is-visible { opacity: 1; visibility: visible; }
.report-modal-content {
  font-family: var(--ff-body);
  background: #fff;
  padding: 30px 40px;
  border-radius: var(--radius-card);
  box-shadow: 0 10px 30px rgba(0,0,0,.2);
  width: 90%; max-width: 500px;
  text-align: center;
  position: relative;
  transform: scale(.9);
  transition: transform .4s cubic-bezier(.25,.8,.25,1);
}
.report-modal-overlay.is-visible .report-modal-content { transform: scale(1); }
.report-modal-title {
  font-family: var(--ff-body), 'Poppins', sans-serif;
  color: var(--color-primary);
  font-size: 28px; font-weight: 600;
  margin: 0 0 8px;
}
.report-modal-subtitle {
  color: var(--color-text-dark);
  font-size: 18px;
  margin: 0 0 30px;
}
.report-year-buttons {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 15px;
}
.report-year-button {
  display: block;
  text-decoration: none;
  font-family: var(--ff-body), 'Poppins', sans-serif;
  font-weight: 500;
  font-size: 18px;
  background: var(--gradient-search); /* #006b71→#00664b : 4.6:1 WCAG AA — DIVERGENCE custom.css L156 = #008b92 solide (4.07:1) */
  color: #fff !important;
  padding: 14px 20px;
  border-radius: var(--radius-button);
  border: none;
  cursor: pointer;
  transition: transform .2s ease, filter .2s ease;
}
.report-year-button:hover,
.report-year-button:focus-visible {
  transform: translateY(-3px);
  filter: brightness(1.15);
  text-decoration: none;
  color: #fff !important;
}
.report-modal-close {
  position: absolute; top: 10px; right: 15px;
  background: transparent; border: none;
  font-size: 30px; line-height: 1;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 5px;
  min-width: var(--tap-target);
  min-height: var(--tap-target);
  display: flex; align-items: center; justify-content: center;
  transition: color .2s ease;
}
.report-modal-close:hover { color: var(--color-text-dark); }
