/* =========================================================
   U Dream Partner – Frontend Stylesheet v1.0
   ========================================================= */

/* ── Variables ─────────────────────────────────────────── */
:root {
  --udp-primary:   #e91e8c;
  --udp-secondary: #7c3aed;
  --udp-accent:    #f59e0b;
  --udp-dark:      #1e1b4b;
  --udp-light:     #fdf2f8;
  --udp-muted:     #6b7280;
  --udp-border:    #e5e7eb;
  --udp-white:     #ffffff;
  --udp-success:   #10b981;
  --udp-danger:    #ef4444;
  --udp-warning:   #f59e0b;
  --udp-info:      #3b82f6;
  --udp-radius:    12px;
  --udp-shadow:    0 4px 24px rgba(233,30,140,.12);
  --udp-shadow-lg: 0 8px 40px rgba(233,30,140,.18);
  --udp-font:      'Segoe UI', system-ui, -apple-system, sans-serif;
  --udp-trans:     all .25s ease;
}

/* ── Reset / Base ──────────────────────────────────────── */
.udp-wrap { font-family: var(--udp-font); color: #374151; line-height: 1.6; }
.udp-wrap *, .udp-wrap *::before, .udp-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }
.udp-wrap a { color: var(--udp-primary); text-decoration: none; }
.udp-wrap a:hover { opacity: .85; }
.udp-wrap img { max-width: 100%; height: auto; }

/* ── Layout Helpers ────────────────────────────────────── */
.udp-container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.udp-row       { display: flex; flex-wrap: wrap; gap: 20px; }
.udp-col-4     { flex: 0 0 calc(33.333% - 14px); }
.udp-col-6     { flex: 0 0 calc(50% - 10px); }
.udp-col-8     { flex: 0 0 calc(66.666% - 7px); }
.udp-col-full  { flex: 0 0 100%; }
.udp-text-center { text-align: center; }
.udp-mt-2 { margin-top: 16px; }
.udp-mt-4 { margin-top: 32px; }
.udp-mb-2 { margin-bottom: 16px; }
.udp-hidden   { display: none !important; }

/* ── Buttons ───────────────────────────────────────────── */
.udp-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 22px; border-radius: 50px; font-size: 14px;
  font-weight: 600; border: none; cursor: pointer;
  transition: var(--udp-trans); font-family: var(--udp-font);
}
.udp-btn-primary   { background: linear-gradient(135deg,var(--udp-primary),var(--udp-secondary)); color:#fff; box-shadow:0 4px 15px rgba(233,30,140,.35); }
.udp-btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 25px rgba(233,30,140,.45); color:#fff; }
.udp-btn-secondary { background: var(--udp-white); color: var(--udp-primary); border: 2px solid var(--udp-primary); }
.udp-btn-secondary:hover { background: var(--udp-light); }
.udp-btn-danger    { background: var(--udp-danger); color: #fff; }
.udp-btn-success   { background: var(--udp-success); color: #fff; }
.udp-btn-sm  { padding: 6px 14px; font-size: 12px; }
.udp-btn-lg  { padding: 14px 32px; font-size: 16px; }
.udp-btn-block { width: 100%; justify-content: center; }
.udp-btn:disabled { opacity: .55; cursor: not-allowed; transform: none !important; }

/* ── Cards ─────────────────────────────────────────────── */
.udp-card {
  background: var(--udp-white); border-radius: var(--udp-radius);
  box-shadow: 0 2px 12px rgba(0,0,0,.07); padding: 24px;
  transition: var(--udp-trans);
}
.udp-card:hover { box-shadow: var(--udp-shadow); }
.udp-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.udp-card-title  { font-size: 18px; font-weight: 700; color: var(--udp-dark); }

/* ── Forms ─────────────────────────────────────────────── */
.udp-form-group { margin-bottom: 18px; }
.udp-label { display: block; font-size: 13px; font-weight: 600; color: #4b5563; margin-bottom: 6px; }
.udp-input, .udp-select, .udp-textarea {
  width: 100%; padding: 10px 14px; border: 1.5px solid var(--udp-border);
  border-radius: 8px; font-size: 14px; font-family: var(--udp-font);
  transition: border-color .2s; background: #fff; color: #374151;
}
.udp-input:focus, .udp-select:focus, .udp-textarea:focus {
  outline: none; border-color: var(--udp-primary);
  box-shadow: 0 0 0 3px rgba(233,30,140,.1);
}
.udp-textarea { resize: vertical; min-height: 80px; }
.udp-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b7280' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 36px; }
.udp-form-row { display: flex; gap: 16px; }
.udp-form-row .udp-form-group { flex: 1; }
.udp-error-msg { color: var(--udp-danger); font-size: 12px; margin-top: 4px; }
.udp-help-text { color: var(--udp-muted); font-size: 12px; margin-top: 4px; }
.udp-checkbox-group, .udp-radio-group { display: flex; flex-wrap: wrap; gap: 8px; }
.udp-checkbox-item, .udp-radio-item {
  display: flex; align-items: center; gap: 6px; cursor: pointer;
  padding: 6px 12px; border: 1.5px solid var(--udp-border);
  border-radius: 20px; font-size: 13px; transition: var(--udp-trans);
}
.udp-checkbox-item:hover, .udp-radio-item:hover { border-color: var(--udp-primary); background: var(--udp-light); }
.udp-checkbox-item input:checked + span, .udp-radio-item input:checked + span { color: var(--udp-primary); font-weight: 600; }
.udp-checkbox-item:has(input:checked), .udp-radio-item:has(input:checked) { border-color: var(--udp-primary); background: var(--udp-light); }

/* ── Auth Page ─────────────────────────────────────────── */
.udp-auth-wrap {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #fdf2f8 0%, #f0f4ff 100%);
  padding: 40px 20px;
}
.udp-auth-box {
  background: #fff; border-radius: 20px; box-shadow: var(--udp-shadow-lg);
  width: 100%; max-width: 460px; overflow: hidden;
}
.udp-auth-logo {
  background: linear-gradient(135deg,var(--udp-primary),var(--udp-secondary));
  padding: 30px; text-align: center;
}
.udp-auth-logo h2 { color: #fff; font-size: 26px; font-weight: 800; margin: 0; }
.udp-auth-logo p  { color: rgba(255,255,255,.85); font-size: 13px; margin-top: 4px; }
.udp-auth-tabs { display: flex; border-bottom: 1px solid var(--udp-border); }
.udp-auth-tab {
  flex: 1; padding: 14px; text-align: center; font-size: 14px;
  font-weight: 600; color: var(--udp-muted); cursor: pointer;
  border: none; background: none; transition: var(--udp-trans);
}
.udp-auth-tab.active { color: var(--udp-primary); border-bottom: 2px solid var(--udp-primary); }
.udp-auth-body { padding: 28px; }
.udp-auth-panel { display: none; }
.udp-auth-panel.active { display: block; }
.udp-auth-footer { text-align: center; font-size: 13px; color: var(--udp-muted); margin-top: 16px; }

/* ── Wizard / Multi-step Profile ───────────────────────── */
.udp-wizard-wrap { max-width: 860px; margin: 40px auto; padding: 0 20px; }
.udp-wizard-progress { display: flex; margin-bottom: 32px; position: relative; }
.udp-wizard-progress::before {
  content: ''; position: absolute; top: 50%; left: 0; right: 0;
  height: 2px; background: var(--udp-border); transform: translateY(-50%); z-index: 0;
}
.udp-step-indicator {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  gap: 6px; position: relative; z-index: 1;
}
.udp-step-num {
  width: 36px; height: 36px; border-radius: 50%; background: var(--udp-border);
  color: var(--udp-muted); display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 13px; transition: var(--udp-trans);
}
.udp-step-indicator.active .udp-step-num,
.udp-step-indicator.done   .udp-step-num {
  background: linear-gradient(135deg,var(--udp-primary),var(--udp-secondary));
  color: #fff; box-shadow: 0 3px 10px rgba(233,30,140,.35);
}
.udp-step-label { font-size: 11px; font-weight: 600; color: var(--udp-muted); text-align: center; }
.udp-step-indicator.active .udp-step-label { color: var(--udp-primary); }
.udp-wizard-step { display: none; }
.udp-wizard-step.active { display: block; animation: udpFadeIn .3s ease; }
.udp-wizard-nav { display: flex; justify-content: space-between; margin-top: 28px; }

/* Photo Upload */
.udp-photo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 12px; }
.udp-photo-item {
  aspect-ratio: 1; border-radius: 10px; overflow: hidden; position: relative;
  background: var(--udp-light); border: 2px dashed var(--udp-border);
}
.udp-photo-item img { width: 100%; height: 100%; object-fit: cover; }
.udp-photo-item .udp-photo-actions {
  position: absolute; inset: 0; background: rgba(0,0,0,.5);
  display: none; align-items: center; justify-content: center; gap: 6px;
}
.udp-photo-item:hover .udp-photo-actions { display: flex; }
.udp-photo-add {
  aspect-ratio: 1; border-radius: 10px; background: var(--udp-light);
  border: 2px dashed var(--udp-border); display: flex; align-items: center;
  justify-content: center; flex-direction: column; gap: 6px; cursor: pointer;
  transition: var(--udp-trans); color: var(--udp-muted); font-size: 12px;
}
.udp-photo-add:hover { border-color: var(--udp-primary); background: #fff5fb; color: var(--udp-primary); }
.udp-photo-add span.dashicons { font-size: 24px; }
.udp-primary-badge {
  position: absolute; top: 6px; left: 6px; background: var(--udp-primary);
  color: #fff; font-size: 9px; font-weight: 700; padding: 2px 6px; border-radius: 10px;
}

/* ── Dashboard ─────────────────────────────────────────── */
.udp-dashboard { padding: 32px 0; }
.udp-dashboard-header { text-align: center; margin-bottom: 32px; }
.udp-dashboard-header h2 { font-size: 28px; font-weight: 800; color: var(--udp-dark); }
.udp-dashboard-header p  { color: var(--udp-muted); margin-top: 6px; }

.udp-stats-row { display: grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap: 16px; margin-bottom: 32px; }
.udp-stat-card {
  background: linear-gradient(135deg,var(--udp-primary),var(--udp-secondary));
  border-radius: 16px; padding: 20px; color: #fff; text-align: center;
}
.udp-stat-card.alt { background: linear-gradient(135deg,var(--udp-secondary),#4f46e5); }
.udp-stat-card.alt2 { background: linear-gradient(135deg,var(--udp-accent),#f97316); }
.udp-stat-card.alt3 { background: linear-gradient(135deg,var(--udp-success),#059669); }
.udp-stat-num  { font-size: 36px; font-weight: 800; }
.udp-stat-label { font-size: 12px; opacity: .85; margin-top: 4px; }

.udp-completion-bar-wrap { margin-bottom: 32px; }
.udp-completion-label { display: flex; justify-content: space-between; margin-bottom: 8px; font-size: 14px; font-weight: 600; }
.udp-completion-bar { height: 10px; background: var(--udp-border); border-radius: 5px; overflow: hidden; }
.udp-completion-fill { height: 100%; background: linear-gradient(90deg,var(--udp-primary),var(--udp-secondary)); border-radius: 5px; transition: width .6s ease; }

/* ── Profile Cards (Match grid) ────────────────────────── */
.udp-profiles-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(240px,1fr)); gap: 20px; }
.udp-profile-card {
  background: #fff; border-radius: 16px; overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,.07); transition: var(--udp-trans); cursor: pointer;
}
.udp-profile-card:hover { transform: translateY(-4px); box-shadow: var(--udp-shadow-lg); }
.udp-profile-photo { position: relative; }
.udp-profile-photo img { width: 100%; height: 220px; object-fit: cover; display: block; }
.udp-match-badge {
  position: absolute; top: 12px; right: 12px;
  background: linear-gradient(135deg,var(--udp-primary),var(--udp-secondary));
  color: #fff; border-radius: 50px; padding: 4px 10px; font-size: 12px; font-weight: 700;
}
.udp-verified-badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--udp-success); color: #fff; border-radius: 50%; width: 26px; height: 26px;
  display: flex; align-items: center; justify-content: center; font-size: 13px;
}
.udp-profile-body { padding: 14px; }
.udp-profile-name { font-size: 16px; font-weight: 700; color: var(--udp-dark); }
.udp-profile-meta { font-size: 12px; color: var(--udp-muted); margin-top: 4px; }
.udp-profile-actions { display: flex; gap: 8px; padding: 0 14px 14px; }
.udp-profile-actions .udp-btn { flex: 1; font-size: 12px; padding: 7px 10px; }

/* ── Match Tabs ─────────────────────────────────────────── */
.udp-tab-nav { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
.udp-tab-btn {
  padding: 8px 18px; border-radius: 50px; font-size: 13px; font-weight: 600;
  border: 1.5px solid var(--udp-border); background: #fff; cursor: pointer;
  transition: var(--udp-trans); color: var(--udp-muted);
}
.udp-tab-btn.active { background: var(--udp-primary); color: #fff; border-color: var(--udp-primary); }
.udp-tab-pane { display: none; }
.udp-tab-pane.active { display: block; animation: udpFadeIn .3s ease; }

/* ── Search Page ────────────────────────────────────────── */
.udp-search-wrap { display: flex; gap: 24px; align-items: flex-start; }
.udp-search-sidebar {
  width: 280px; flex-shrink: 0; background: #fff; border-radius: 16px;
  padding: 20px; box-shadow: 0 2px 12px rgba(0,0,0,.07); position: sticky; top: 80px;
}
.udp-search-main { flex: 1; }
.udp-filter-title { font-size: 16px; font-weight: 700; color: var(--udp-dark); margin-bottom: 20px; }
.udp-filter-group { margin-bottom: 16px; }
.udp-filter-group label { display: block; font-size: 12px; font-weight: 600; color: var(--udp-muted); margin-bottom: 6px; text-transform: uppercase; letter-spacing: .5px; }
.udp-range-row { display: flex; align-items: center; gap: 8px; }
.udp-range-input { flex: 1; }
.udp-range-sep { color: var(--udp-muted); font-size: 12px; }

/* ── Profile View Page ──────────────────────────────────── */
.udp-profile-view { max-width: 900px; margin: 0 auto; }
.udp-profile-hero { position: relative; border-radius: 20px; overflow: hidden; margin-bottom: 28px; }
.udp-profile-hero-img { width: 100%; height: 380px; object-fit: cover; }
.udp-profile-hero-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent,rgba(0,0,0,.75));
  padding: 30px 24px 24px;
}
.udp-hero-name  { font-size: 28px; font-weight: 800; color: #fff; }
.udp-hero-meta  { color: rgba(255,255,255,.85); font-size: 14px; margin-top: 4px; }
.udp-hero-actions { display: flex; gap: 10px; margin-top: 14px; }

.udp-compat-ring-row { display: flex; align-items: center; gap: 28px; margin-bottom: 28px; }
.udp-compat-ring-wrap { text-align: center; flex-shrink: 0; }
.udp-compat-ring { position: relative; width: 130px; height: 130px; }
.udp-compat-ring canvas { border-radius: 50%; }
.udp-compat-ring-label {
  position: absolute; inset: 0; display: flex; align-items: center;
  justify-content: center; flex-direction: column;
}
.udp-compat-pct  { font-size: 26px; font-weight: 800; color: var(--udp-dark); }
.udp-compat-text { font-size: 11px; color: var(--udp-muted); }
.udp-compat-bars { flex: 1; }
.udp-compat-item { margin-bottom: 10px; }
.udp-compat-item-label { display: flex; justify-content: space-between; font-size: 12px; font-weight: 600; margin-bottom: 4px; }
.udp-compat-bar { height: 6px; background: var(--udp-border); border-radius: 3px; overflow: hidden; }
.udp-compat-bar-fill { height: 100%; background: linear-gradient(90deg,var(--udp-primary),var(--udp-secondary)); border-radius: 3px; }

.udp-section-title { font-size: 18px; font-weight: 700; color: var(--udp-dark); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 2px solid var(--udp-light); }
.udp-profile-info-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(200px,1fr)); gap: 14px; }
.udp-info-item label { font-size: 11px; text-transform: uppercase; letter-spacing: .5px; color: var(--udp-muted); font-weight: 600; }
.udp-info-item span  { display: block; font-size: 14px; font-weight: 600; color: var(--udp-dark); margin-top: 2px; }

.udp-photos-gallery { display: grid; grid-template-columns: repeat(auto-fill,minmax(130px,1fr)); gap: 10px; }
.udp-photos-gallery img { width: 100%; height: 130px; object-fit: cover; border-radius: 10px; cursor: pointer; transition: opacity .2s; }
.udp-photos-gallery img:hover { opacity: .85; }

/* ── Chat ───────────────────────────────────────────────── */
.udp-chat-layout { display: flex; gap: 0; height: calc(100vh - 160px); min-height: 500px; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 24px rgba(0,0,0,.1); }
.udp-threads-panel { width: 300px; flex-shrink: 0; border-right: 1px solid var(--udp-border); background: #fff; display: flex; flex-direction: column; }
.udp-threads-header { padding: 16px; border-bottom: 1px solid var(--udp-border); font-size: 16px; font-weight: 700; }
.udp-threads-list { flex: 1; overflow-y: auto; }
.udp-thread-item { display: flex; gap: 12px; padding: 14px 16px; cursor: pointer; border-bottom: 1px solid var(--udp-border); transition: background .15s; }
.udp-thread-item:hover, .udp-thread-item.active { background: var(--udp-light); }
.udp-thread-avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.udp-thread-info { flex: 1; min-width: 0; }
.udp-thread-name { font-size: 14px; font-weight: 700; color: var(--udp-dark); }
.udp-thread-preview { font-size: 12px; color: var(--udp-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }
.udp-thread-badge { background: var(--udp-primary); color: #fff; border-radius: 50%; width: 18px; height: 18px; font-size: 10px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

.udp-chat-main { flex: 1; display: flex; flex-direction: column; background: #f9fafb; }
.udp-chat-header { padding: 14px 20px; background: #fff; border-bottom: 1px solid var(--udp-border); display: flex; align-items: center; gap: 12px; }
.udp-chat-header img { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.udp-chat-header-name { font-size: 15px; font-weight: 700; color: var(--udp-dark); }
.udp-messages-area { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.udp-message { max-width: 70%; }
.udp-message.sent { align-self: flex-end; }
.udp-message.received { align-self: flex-start; }
.udp-message-bubble {
  padding: 10px 14px; border-radius: 18px; font-size: 14px; line-height: 1.5;
  word-break: break-word;
}
.udp-message.sent .udp-message-bubble { background: linear-gradient(135deg,var(--udp-primary),var(--udp-secondary)); color: #fff; border-bottom-right-radius: 4px; }
.udp-message.received .udp-message-bubble { background: #fff; border: 1px solid var(--udp-border); border-bottom-left-radius: 4px; }
.udp-message-time { font-size: 10px; color: var(--udp-muted); margin-top: 4px; }
.udp-message.sent .udp-message-time { text-align: right; }

.udp-chat-input-area { padding: 14px 20px; background: #fff; border-top: 1px solid var(--udp-border); display: flex; gap: 10px; align-items: flex-end; }
.udp-chat-input { flex: 1; border: 1.5px solid var(--udp-border); border-radius: 24px; padding: 10px 16px; font-size: 14px; font-family: var(--udp-font); resize: none; max-height: 120px; outline: none; transition: border-color .2s; }
.udp-chat-input:focus { border-color: var(--udp-primary); }
.udp-chat-file-btn { color: var(--udp-muted); font-size: 20px; cursor: pointer; padding: 8px; flex-shrink: 0; }
.udp-chat-send-btn { background: linear-gradient(135deg,var(--udp-primary),var(--udp-secondary)); color: #fff; border: none; border-radius: 50%; width: 40px; height: 40px; cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 16px; transition: var(--udp-trans); }
.udp-chat-send-btn:hover { transform: scale(1.1); }
.udp-chat-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; color: var(--udp-muted); gap: 12px; }
.udp-chat-placeholder .dashicons { font-size: 48px; opacity: .3; }

/* ── Privacy Settings ───────────────────────────────────── */
.udp-privacy-wrap { max-width: 680px; margin: 0 auto; }
.udp-privacy-item { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-bottom: 1px solid var(--udp-border); gap: 20px; }
.udp-privacy-item label { font-size: 14px; font-weight: 600; color: var(--udp-dark); flex: 1; }
.udp-privacy-item select { width: 200px; }

/* ── Notification Panel ─────────────────────────────────── */
.udp-notif-toggle { position: relative; cursor: pointer; }
.udp-notif-count { position: absolute; top: -6px; right: -6px; background: var(--udp-danger); color: #fff; border-radius: 50%; width: 18px; height: 18px; font-size: 10px; display: flex; align-items: center; justify-content: center; font-weight: 700; }
.udp-notif-panel {
  position: absolute; right: 0; top: calc(100% + 12px); width: 340px;
  background: #fff; border-radius: 16px; box-shadow: var(--udp-shadow-lg);
  z-index: 9999; overflow: hidden; display: none;
}
.udp-notif-panel.open { display: block; }
.udp-notif-header { padding: 14px 16px; border-bottom: 1px solid var(--udp-border); font-size: 14px; font-weight: 700; display: flex; justify-content: space-between; }
.udp-notif-list { max-height: 300px; overflow-y: auto; }
.udp-notif-item { padding: 12px 16px; border-bottom: 1px solid var(--udp-border); font-size: 13px; }
.udp-notif-item.unread { background: var(--udp-light); }
.udp-notif-time { font-size: 11px; color: var(--udp-muted); margin-top: 2px; }

/* ── Lightbox ───────────────────────────────────────────── */
.udp-lightbox-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.9);
  z-index: 99999; display: none; align-items: center; justify-content: center;
}
.udp-lightbox-overlay.open { display: flex; }
.udp-lightbox-img { max-width: 90vw; max-height: 90vh; border-radius: 8px; }
.udp-lightbox-close { position: absolute; top: 20px; right: 20px; color: #fff; font-size: 30px; cursor: pointer; background: none; border: none; line-height: 1; }

/* ── Toast ──────────────────────────────────────────────── */
.udp-toast-container { position: fixed; bottom: 24px; right: 24px; z-index: 99998; display: flex; flex-direction: column; gap: 10px; }
.udp-toast {
  background: #1f2937; color: #fff; border-radius: 10px;
  padding: 12px 18px; font-size: 14px; box-shadow: 0 4px 20px rgba(0,0,0,.25);
  display: flex; align-items: center; gap: 10px; min-width: 260px;
  animation: udpSlideIn .3s ease, udpFadeOut .3s ease 2.7s forwards;
}
.udp-toast.success { border-left: 4px solid var(--udp-success); }
.udp-toast.error   { border-left: 4px solid var(--udp-danger); }
.udp-toast.warning { border-left: 4px solid var(--udp-warning); }
.udp-toast.info    { border-left: 4px solid var(--udp-info); }

/* ── Verification ───────────────────────────────────────── */
.udp-verify-cards { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: 16px; }
.udp-verify-card { border: 2px solid var(--udp-border); border-radius: 14px; padding: 20px; text-align: center; transition: var(--udp-trans); }
.udp-verify-card.verified { border-color: var(--udp-success); background: #f0fdf4; }
.udp-verify-icon { font-size: 36px; margin-bottom: 10px; }
.udp-verify-name { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.udp-verify-status { font-size: 12px; color: var(--udp-muted); margin-bottom: 12px; }

/* ── Badges ─────────────────────────────────────────────── */
.udp-badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 50px; font-size: 11px; font-weight: 700; }
.udp-badge-primary { background: #fce7f3; color: var(--udp-primary); }
.udp-badge-success { background: #d1fae5; color: #065f46; }
.udp-badge-warning { background: #fef3c7; color: #92400e; }
.udp-badge-muted   { background: #f3f4f6; color: #6b7280; }

/* ── Spinners / Loading ─────────────────────────────────── */
.udp-loading { display: flex; align-items: center; justify-content: center; padding: 40px; color: var(--udp-muted); gap: 10px; }
.udp-spinner { width: 24px; height: 24px; border: 3px solid var(--udp-border); border-top-color: var(--udp-primary); border-radius: 50%; animation: udpSpin .8s linear infinite; }

/* ── Radar / Chart Canvas ───────────────────────────────── */
.udp-radar-wrap { max-width: 300px; margin: 0 auto; }

/* ── Interest Tabs ─────────────────────────────────────── */
.udp-interest-list { display: flex; flex-direction: column; gap: 12px; }
.udp-interest-item { display: flex; align-items: center; gap: 14px; padding: 14px; background: #fff; border-radius: 12px; border: 1px solid var(--udp-border); transition: var(--udp-trans); }
.udp-interest-item img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.udp-interest-body { flex: 1; }
.udp-interest-name { font-size: 14px; font-weight: 700; color: var(--udp-dark); }
.udp-interest-meta { font-size: 12px; color: var(--udp-muted); margin-top: 2px; }
.udp-interest-actions { display: flex; gap: 8px; }

/* ── Animations ─────────────────────────────────────────── */
@keyframes udpFadeIn    { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes udpSlideIn   { from { transform: translateX(100%); opacity: 0; } to { transform: none; opacity: 1; } }
@keyframes udpFadeOut   { from { opacity: 1; } to { opacity: 0; transform: translateX(100%); } }
@keyframes udpSpin      { to { transform: rotate(360deg); } }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 768px) {
  .udp-col-4, .udp-col-6, .udp-col-8 { flex: 0 0 100%; }
  .udp-form-row { flex-direction: column; }
  .udp-search-wrap { flex-direction: column; }
  .udp-search-sidebar { width: 100%; position: static; }
  .udp-chat-layout { flex-direction: column; height: auto; }
  .udp-threads-panel { width: 100%; max-height: 250px; }
  .udp-profile-hero-img { height: 260px; }
  .udp-hero-name { font-size: 22px; }
  .udp-compat-ring-row { flex-direction: column; }
  .udp-wizard-progress .udp-step-label { display: none; }
  .udp-stats-row { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 480px) {
  .udp-profiles-grid { grid-template-columns: repeat(auto-fill,minmax(160px,1fr)); }
  .udp-auth-body { padding: 20px; }
  .udp-stats-row { grid-template-columns: 1fr 1fr; }
}
