/* ── EURIBOR MODAL ───────────────────────────── */
.eur-overlay {
  position: fixed; inset: 0; z-index: 999;
  background: rgba(12,26,46,.55);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; pointer-events: none;
  transition: opacity .22s;
}
.eur-overlay.open { opacity: 1; pointer-events: all; }

.eur-modal {
  background: var(--surface);
  border-radius: var(--r-lg);
  width: 100%; max-width: 780px;
  max-height: 90vh;
  display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(12,26,46,.25);
  transform: translateY(12px);
  transition: transform .22s;
  overflow: hidden;
}
.eur-overlay.open .eur-modal { transform: translateY(0); }

.eur-modal-header {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.eur-modal-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px; font-weight: 600;
  color: var(--navy); flex: 1;
}

.eur-modal-close {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: none; cursor: pointer;
  font-size: 16px; color: var(--muted);
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.eur-modal-close:hover { background: var(--border); color: var(--text); }

.eur-period-btns {
  display: flex; gap: 6px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.eur-period-btn {
  font-size: 12px; font-weight: 500;
  padding: 4px 12px; border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--surface); color: var(--muted);
  cursor: pointer; font-family: 'Jost', sans-serif;
  transition: all .15s;
}
.eur-period-btn:hover { border-color: var(--navy); color: var(--navy); }
.eur-period-btn.active { background: var(--navy); border-color: var(--navy); color: #fff; }

.eur-modal-body {
  overflow-y: auto; flex: 1;
  padding: 20px;
}

.eur-chart-wrap {
  position: relative; height: 280px;
  margin-bottom: 20px;
}

.eur-loading {
  text-align: center; padding: 60px 0;
  color: var(--muted); font-size: 14px; font-weight: 300;
}

.eur-table-wrap { overflow-x: auto; }

.eur-table {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.eur-table th {
  text-align: left; padding: 8px 12px;
  font-size: 10px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--muted); border-bottom: 1px solid var(--border);
  background: #F9F8F5;
}
.eur-table td {
  padding: 8px 12px;
  border-bottom: 1px solid #F2EFE9;
  color: var(--text);
}
.eur-table tr:last-child td { border-bottom: none; }
.eur-table tr:hover td { background: #FAF9F5; }
.eur-table td:last-child { font-variant-numeric: tabular-nums; text-align: right; font-weight: 500; }

.eur-hint { font-size: 11px; color: var(--muted); text-align: center; margin-top: 8px; font-style: italic; }
