/* ==========================================================================
   Investment Opportunities by Region — page-unique styles
   ========================================================================== */

.region-head h2 {
  font-size: var(--fs-h2);
  font-weight: 800;
  margin-bottom: 1.75rem;
}

/* Region select */
.region-filter {
  max-width: 360px;
  margin-bottom: 2.5rem;
}
.region-select {
  position: relative;
}
.region-select i.bi-geo-alt {
  position: absolute;
  inset-inline-start: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--primary);
  pointer-events: none;
}
.region-select select {
  width: 100%;
  appearance: none;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.85rem 2.75rem;
  font-family: var(--font-base);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
}
.region-select select:focus {
  outline: none;
  border-color: var(--primary);
}
.region-select i.bi-chevron-down {
  position: absolute;
  inset-inline-end: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  pointer-events: none;
  font-size: 0.85rem;
}
.region-filter-dropdown {
  width: 100%;
  min-height: 54px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.region-filter-dropdown:hover,
.region-filter-dropdown.is-open {
  border-color: var(--primary);
  box-shadow: 0 14px 34px rgba(18, 31, 62, 0.08);
}
.region-filter-dropdown__trigger {
  display: grid;
  gap: 0.1rem;
  width: 100%;
  min-height: 52px;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
  cursor: pointer;
  padding: 0.55rem 2.75rem;
  text-align: left;
}
.region-filter-dropdown__trigger span {
  color: var(--text-light);
  font-size: 0.7rem;
  font-weight: 800;
}
.region-filter-dropdown__trigger strong {
  color: var(--text);
  font-size: 0.95rem;
  font-weight: 900;
}
.region-filter-dropdown.is-open i.bi-chevron-down {
  transform: translateY(-50%) rotate(180deg);
  color: var(--primary);
}
.region-filter-dropdown__menu {
  position: absolute;
  top: calc(100% + 0.55rem);
  left: 0;
  right: 0;
  z-index: 20;
  padding: 0.45rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 18px 45px rgba(18, 31, 62, 0.16);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
}
.region-filter-dropdown.is-open .region-filter-dropdown__menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.region-filter-dropdown__option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 800;
  padding: 0.72rem 0.85rem;
  text-align: left;
}
.region-filter-dropdown__option:hover,
.region-filter-dropdown__option.is-selected {
  background: rgba(113, 31, 255, 0.08);
  color: var(--primary);
}
.region-filter-dropdown__option .bi-check2 {
  opacity: 0;
  color: var(--primary);
  font-size: 1rem;
}
.region-filter-dropdown__option.is-selected .bi-check2 {
  opacity: 1;
}
[data-region-results-grid] {
  transition: opacity 0.2s ease, transform 0.2s ease;
}
[data-region-results-grid].is-filtering {
  opacity: 0.32;
  transform: translateY(4px);
  pointer-events: none;
}
.region-filter-loader {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  margin-top: 1.1rem;
  color: var(--primary);
  font-size: 0.86rem;
  font-weight: 800;
  background: rgba(113, 31, 255, 0.08);
  border: 1px solid rgba(113, 31, 255, 0.18);
  border-radius: var(--radius-pill);
  padding: 0.65rem 0.95rem;
}
.region-filter-loader__ring {
  width: 1.15rem;
  height: 1.15rem;
  border: 2px solid rgba(113, 31, 255, 0.2);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: regionSpin 0.7s linear infinite;
}
@keyframes regionSpin {
  to {
    transform: rotate(360deg);
  }
}

/* Investment card */
.invest-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem;
  height: 100%;
  transition: all 0.25s ease;
}
.invest-card:hover {
  box-shadow: var(--shadow-card);
  transform: translateY(-4px);
}

.invest-card-head {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  margin-bottom: 1rem;
}
.invest-avatar {
  width: 40px;
  height: 40px;
  min-width: 40px;
  border-radius: 50%;
  background: var(--dark);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 1.05rem;
}
.invest-card-head .title {
  flex: 1;
}
.invest-card-head h3 {
  font-size: 0.92rem;
  margin-bottom: 0.15rem;
}
.invest-card-head .loc {
  font-size: 0.72rem;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.invest-card-head .loc i {
  color: var(--primary);
}
.invest-days {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--primary);
}

.invest-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  margin-bottom: 1rem;
}
.invest-stats .cell {
  padding: 0.6rem 0.8rem;
  border-inline-end: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.invest-stats .cell:nth-child(2n) { border-inline-end: 0; }
.invest-stats .cell:nth-child(n+3) { border-bottom: 0; }
.invest-stats .cell .k {
  font-size: 0.68rem;
  color: var(--text-muted);
  margin-bottom: 0.1rem;
}
.invest-stats .cell .v {
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.invest-stats .cell .v.accent { color: var(--accent-700); }
.invest-stats .cell .v i { color: var(--primary); }

/* Progress */
.invest-raised {
  display: flex;
  justify-content: space-between;
  font-size: 0.78rem;
  font-weight: 700;
  margin-bottom: 0.4rem;
}
.invest-raised .pct { color: var(--ink); }
.raise-bar {
  height: 8px;
  background: var(--border);
  border-radius: var(--radius-pill);
  overflow: hidden;
  margin-bottom: 1.1rem;
}
.raise-bar span {
  display: block;
  height: 100%;
  border-radius: var(--radius-pill);
  background: linear-gradient(90deg, var(--primary), var(--primary-light));
}

.invest-actions {
  display: flex;
  gap: 0.6rem;
}
.invest-actions .btn {
  flex: 1;
  justify-content: center;
}
