/* Meetup budget preference — premium glass cards & gradient badges */

.tm-meetup-disclaimer {
  margin: 0 0 14px;
  padding: 12px 14px;
  font-size: 0.78rem;
  line-height: 1.55;
  color: rgba(148, 163, 184, 0.95);
  border-radius: 12px;
  border: 1px solid rgba(99, 102, 241, 0.18);
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.55), rgba(30, 27, 75, 0.35));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.tm-meetup-section {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(148, 163, 184, 0.12);
}

.tm-meetup-section__title {
  margin: 0 0 6px;
  font-family: 'Montserrat', 'Plus Jakarta Sans', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  background: linear-gradient(90deg, #e2e8f0, #a5b4fc);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.tm-meetup-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.tm-meetup-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid rgba(129, 140, 248, 0.28);
  background: rgba(15, 23, 42, 0.45);
  color: rgba(226, 232, 240, 0.92);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
  user-select: none;
}

.tm-meetup-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(129, 140, 248, 0.55);
  box-shadow: 0 0 18px rgba(99, 102, 241, 0.22);
}

.tm-meetup-chip.is-selected {
  border-color: rgba(167, 139, 250, 0.75);
  background: linear-gradient(135deg, rgba(79, 70, 229, 0.45), rgba(124, 58, 237, 0.35));
  box-shadow: 0 0 22px rgba(99, 102, 241, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  color: #f8fafc;
}

.tm-meetup-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  margin-top: 12px;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  background: rgba(15, 23, 42, 0.35);
}

.tm-meetup-toggle-row span {
  font-size: 0.88rem;
  font-weight: 600;
  color: rgba(226, 232, 240, 0.95);
}

.tm-meetup-toggle-row small {
  display: block;
  margin-top: 3px;
  font-size: 0.75rem;
  font-weight: 400;
  color: rgba(148, 163, 184, 0.9);
}

.tm-meetup-vis {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}

.tm-meetup-vis label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(129, 140, 248, 0.22);
  background: rgba(15, 23, 42, 0.4);
  font-size: 0.82rem;
  cursor: pointer;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.tm-meetup-vis label:has(input:checked) {
  border-color: rgba(167, 139, 250, 0.65);
  box-shadow: 0 0 16px rgba(99, 102, 241, 0.25);
}

/* Discovery cards */
.tm-profile-card__meetup-styles {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.tm-meetup-style-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  border: 1px solid rgba(129, 140, 248, 0.35);
  background: linear-gradient(135deg, rgba(30, 27, 75, 0.65), rgba(49, 46, 129, 0.45));
  color: rgba(224, 231, 255, 0.98);
  box-shadow: 0 0 14px rgba(99, 102, 241, 0.15);
}

.tm-profile-card__meetup-budget {
  margin-top: 10px;
  padding: 8px 12px;
  border-radius: 12px;
  font-size: 0.78rem;
  font-weight: 600;
  border: 1px solid rgba(56, 189, 248, 0.22);
  background: linear-gradient(135deg, rgba(15, 23, 42, 0.55), rgba(30, 58, 138, 0.25));
  color: rgba(186, 230, 253, 0.98);
  box-shadow: 0 0 18px rgba(56, 189, 248, 0.12);
}

.tm-profile-card__meetup-budget strong {
  font-weight: 700;
  color: #e0f2fe;
}

/* Profile detail page */
.tm-dp-meetup-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.tm-dp-meetup-budget {
  display: inline-flex;
  align-self: flex-start;
  padding: 10px 16px;
  border-radius: 14px;
  font-size: 0.92rem;
  font-weight: 700;
  border: 1px solid rgba(129, 140, 248, 0.35);
  background: linear-gradient(135deg, rgba(67, 56, 202, 0.35), rgba(124, 58, 237, 0.28));
  color: #eef2ff;
  box-shadow: 0 0 24px rgba(99, 102, 241, 0.28);
}

.tm-dp-meetup-budget span {
  font-weight: 500;
  opacity: 0.85;
  margin-right: 6px;
}

/* Chat quick suggestions */
.tm-pro-chat__meetup-hint {
  margin: 0 0 8px;
  padding: 0 4px;
  font-size: 0.78rem;
  color: rgba(148, 163, 184, 0.95);
}

.tm-pro-chat__suggest-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 4px 10px;
}

.tm-pro-chat__suggest-chip {
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(129, 140, 248, 0.3);
  background: rgba(15, 23, 42, 0.55);
  color: rgba(224, 231, 255, 0.95);
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.tm-pro-chat__suggest-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(167, 139, 250, 0.6);
  box-shadow: 0 0 16px rgba(99, 102, 241, 0.28);
}

.tm-pro-chat__compose .tm-meetup-disclaimer {
  margin: 8px 4px 10px;
  font-size: 0.72rem;
}

@media (max-width: 640px) {
  .tm-meetup-vis label {
    flex: 1 1 100%;
  }
}
