/* ============================================================
   VAG Partner Pro — Main Stylesheet v3.0.0
   Premium, Modern, Bilingual (Hindi/English) UI
   ============================================================ */

/* ── GOOGLE FONTS ──────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Noto+Sans+Devanagari:wght@400;500;600;700&display=swap');

/* ── CSS VARIABLES ─────────────────────────────────────────── */
:root {
  --vag-primary:       #2563eb;
  --vag-primary-dark:  #1d4ed8;
  --vag-primary-light: #eff6ff;
  --vag-secondary:     #1e3a5f;
  --vag-accent:        #c9a84c;
  --vag-success:       #10b981;
  --vag-warning:       #f59e0b;
  --vag-danger:        #ef4444;
  --vag-purple:        #8b5cf6;
  --vag-teal:          #14b8a6;

  --vag-bg:            #f0f4f8;
  --vag-bg-card:       #ffffff;
  --vag-bg-dark:       #1e293b;
  --vag-text:          #1e293b;
  --vag-text-muted:    #64748b;
  --vag-text-light:    #94a3b8;
  --vag-border:        #e2e8f0;
  --vag-border-light:  #f1f5f9;

  --vag-shadow-sm:     0 1px 3px rgba(0,0,0,0.08);
  --vag-shadow:        0 4px 16px rgba(0,0,0,0.08);
  --vag-shadow-lg:     0 10px 40px rgba(0,0,0,0.12);
  --vag-shadow-xl:     0 20px 60px rgba(0,0,0,0.15);

  --vag-radius-sm:     6px;
  --vag-radius:        12px;
  --vag-radius-lg:     16px;
  --vag-radius-xl:     24px;
  --vag-radius-full:   9999px;

  --vag-font:          'Inter', 'Noto Sans Devanagari', sans-serif;
  --vag-transition:    0.2s ease;
  --vag-transition-md: 0.35s cubic-bezier(0.4,0,0.2,1);
}

/* ── GLOBAL RESET ──────────────────────────────────────────── */
.vag-wrap, .vag-wrap * {
  box-sizing: border-box;
  font-family: var(--vag-font);
}
.vag-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px 16px 60px;
  color: var(--vag-text);
  background: var(--vag-bg);
  min-height: 100vh;
}

/* ── CARD ───────────────────────────────────────────────────── */
.vag-card {
  background: var(--vag-bg-card);
  border-radius: var(--vag-radius-lg);
  box-shadow: var(--vag-shadow);
  padding: 28px;
  margin-bottom: 24px;
  transition: box-shadow var(--vag-transition);
  border: 1px solid var(--vag-border-light);
}
.vag-card:hover { box-shadow: var(--vag-shadow-lg); }
.vag-card-title { font-size: 18px; font-weight: 700; color: var(--vag-secondary); margin: 0 0 20px; }

/* ── BUTTONS ────────────────────────────────────────────────── */
.vag-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 22px; border-radius: var(--vag-radius-full);
  font-size: 14px; font-weight: 600; text-decoration: none;
  border: none; cursor: pointer; transition: all var(--vag-transition);
  white-space: nowrap; line-height: 1.4;
}
.vag-btn:disabled { opacity: 0.65; cursor: not-allowed; }
.vag-btn-primary   { background: var(--vag-primary); color: #fff; }
.vag-btn-primary:hover:not(:disabled) { background: var(--vag-primary-dark); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(37,99,235,0.35); }
.vag-btn-secondary { background: #f1f5f9; color: var(--vag-text); }
.vag-btn-secondary:hover:not(:disabled) { background: #e2e8f0; }
.vag-btn-success   { background: var(--vag-success); color: #fff; }
.vag-btn-success:hover:not(:disabled) { background: #059669; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(16,185,129,0.35); }
.vag-btn-danger    { background: var(--vag-danger); color: #fff; }
.vag-btn-danger:hover:not(:disabled) { background: #dc2626; }
.vag-btn-outline   { background: transparent; color: var(--vag-primary); border: 2px solid var(--vag-primary); }
.vag-btn-outline:hover { background: var(--vag-primary-light); }
.vag-btn-whatsapp  { background: #25D366; color: #fff; }
.vag-btn-whatsapp:hover { background: #1ebe58; transform: translateY(-1px); }
.vag-btn-xl        { padding: 14px 32px; font-size: 16px; }
.vag-btn-lg        { padding: 12px 28px; font-size: 15px; }
.vag-btn-sm        { padding: 6px 14px; font-size: 12px; border-radius: var(--vag-radius); }
.vag-btn-full      { width: 100%; justify-content: center; }
.vag-btn-arrow     { font-size: 18px; }
.vag-link-btn      { background: none; border: none; color: var(--vag-primary); cursor: pointer; font-size: 13px; text-decoration: underline; padding: 0; }

/* ── FORM ELEMENTS ──────────────────────────────────────────── */
.vag-input, .vag-select, .vag-textarea {
  width: 100%; padding: 12px 16px;
  border: 1.5px solid var(--vag-border);
  border-radius: var(--vag-radius); font-size: 15px;
  color: var(--vag-text); background: #fff;
  transition: border-color var(--vag-transition), box-shadow var(--vag-transition);
  outline: none; font-family: var(--vag-font);
}
.vag-input:focus, .vag-select:focus, .vag-textarea:focus {
  border-color: var(--vag-primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.12);
}
.vag-input.vag-input-lg { padding: 14px 18px; font-size: 16px; }
.vag-input::placeholder { color: var(--vag-text-light); }
.vag-textarea { resize: vertical; min-height: 80px; }
.vag-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }

.vag-field { margin-bottom: 20px; }
.vag-field-full { grid-column: 1 / -1; }
.vag-label { display: block; font-size: 14px; font-weight: 600; color: var(--vag-secondary); margin-bottom: 8px; }
.vag-req { color: var(--vag-danger); margin-left: 3px; }
.vag-opt { color: var(--vag-text-light); font-weight: 400; font-size: 12px; margin-left: 4px; }
.vag-field-error { display: block; color: var(--vag-danger); font-size: 12px; margin-top: 5px; }
.vag-hint { display: block; color: var(--vag-text-muted); font-size: 12px; margin-top: 5px; }

.vag-form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 24px;
}

.vag-input-group-addon { display: flex; align-items: stretch; }
.vag-addon { background: var(--vag-bg); border: 1.5px solid var(--vag-border); border-right: none; border-radius: var(--vag-radius) 0 0 var(--vag-radius); padding: 12px 14px; font-size: 14px; color: var(--vag-text-muted); white-space: nowrap; display: flex; align-items: center; }
.vag-input-group-addon .vag-input { border-radius: 0 var(--vag-radius) var(--vag-radius) 0; }

.vag-checkbox-label { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; font-size: 14px; color: var(--vag-text-muted); line-height: 1.5; }
.vag-checkbox-label input[type="checkbox"] { margin-top: 2px; width: 16px; height: 16px; accent-color: var(--vag-primary); flex-shrink: 0; }

.vag-password-field { position: relative; }
.vag-toggle-pass { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; font-size: 18px; color: var(--vag-text-muted); padding: 4px; }

/* ── STATUS BADGE ───────────────────────────────────────────── */
.vag-status-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 12px; border-radius: var(--vag-radius-full);
  font-size: 12px; font-weight: 600; white-space: nowrap;
}

/* ── ALERTS ─────────────────────────────────────────────────── */
.vag-alert { padding: 14px 18px; border-radius: var(--vag-radius); font-size: 14px; margin-bottom: 16px; line-height: 1.6; }
.vag-alert-green  { background: #ecfdf5; color: #065f46; border-left: 4px solid var(--vag-success); }
.vag-alert-orange { background: #fffbeb; color: #92400e; border-left: 4px solid var(--vag-warning); }
.vag-alert-red    { background: #fef2f2; color: #991b1b; border-left: 4px solid var(--vag-danger); }
.vag-alert-blue   { background: #eff6ff; color: #1e40af; border-left: 4px solid var(--vag-primary); }

/* ── PROGRESS BAR (Multi-Step Form) ────────────────────────── */
.vag-progress-bar {
  display: flex; align-items: center; justify-content: center;
  padding: 30px 20px 20px; gap: 0;
}
.vag-progress-step { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.vag-prog-dot {
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--vag-bg-card); border: 2.5px solid var(--vag-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 700; color: var(--vag-text-light);
  transition: all var(--vag-transition-md);
}
.vag-progress-step.active .vag-prog-dot { background: var(--vag-primary); border-color: var(--vag-primary); color: #fff; box-shadow: 0 0 0 4px rgba(37,99,235,0.2); }
.vag-progress-step.done .vag-prog-dot { background: var(--vag-success); border-color: var(--vag-success); color: #fff; }
.vag-prog-label { font-size: 11px; color: var(--vag-text-muted); text-align: center; font-weight: 600; }
.vag-progress-step.active .vag-prog-label { color: var(--vag-primary); }
.vag-progress-line { flex: 1; height: 2px; background: var(--vag-border); margin: 0 6px; min-width: 40px; }

/* ── APPLICATION FORM (Card) ────────────────────────────────── */
.vag-apply-card { padding: 0; overflow: hidden; }
.vag-form-hero { background: linear-gradient(135deg, var(--vag-secondary) 0%, var(--vag-primary) 100%); color: #fff; padding: 40px 36px; text-align: center; }
.vag-form-hero-icon { font-size: 48px; margin-bottom: 12px; }
.vag-form-hero h1 { font-size: 26px; font-weight: 800; margin: 0 0 8px; letter-spacing: -0.5px; }
.vag-form-hero p { opacity: 0.88; font-size: 15px; margin: 0; }

.vag-step { display: none; padding: 36px; }
.vag-step.active { display: block; animation: vag-fadein 0.35s ease; }
.vag-step-header { margin-bottom: 28px; }
.vag-step-header h2 { font-size: 20px; font-weight: 700; color: var(--vag-secondary); margin: 0; }
.vag-step-footer { display: flex; justify-content: flex-end; margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--vag-border-light); }
.vag-step-footer-split { justify-content: space-between; }

/* ── DOCUMENT UPLOAD ────────────────────────────────────────── */
.vag-docs-upload-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; margin-bottom: 24px; }
.vag-upload-card { background: var(--vag-bg); border: 2px dashed var(--vag-border); border-radius: var(--vag-radius); padding: 20px 16px; text-align: center; transition: all var(--vag-transition); cursor: pointer; }
.vag-upload-card:hover { border-color: var(--vag-primary); background: var(--vag-primary-light); }
.vag-upload-card.uploaded { border-color: var(--vag-success); border-style: solid; background: #ecfdf5; }
.vag-upload-icon { font-size: 32px; margin-bottom: 8px; }
.vag-upload-title { font-size: 13px; font-weight: 600; color: var(--vag-text); margin-bottom: 12px; }
.vag-file-input { position: absolute; width: 1px; height: 1px; opacity: 0; }
.vag-file-label { display: block; cursor: pointer; }
.vag-file-placeholder { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 14px; border-radius: var(--vag-radius-sm); background: #fff; border: 1.5px solid var(--vag-border); font-size: 12px; color: var(--vag-text-muted); transition: all var(--vag-transition); }
.vag-file-placeholder:hover { border-color: var(--vag-primary); color: var(--vag-primary); }
.vag-file-icon { font-size: 22px; }
.vag-file-error { font-size: 11px; color: var(--vag-danger); margin-top: 6px; }
.vag-info-banner { background: #eff6ff; border-radius: var(--vag-radius); padding: 14px 18px; font-size: 13px; color: var(--vag-primary); margin-bottom: 20px; }

/* ── DECLARATION ────────────────────────────────────────────── */
.vag-declaration { background: var(--vag-bg); border-radius: var(--vag-radius); padding: 16px; margin-top: 16px; }

/* ── SUCCESS CARD (After Submit) ────────────────────────────── */
.vag-success-card { text-align: center; padding: 36px; }
.vag-success-icon { font-size: 64px; margin-bottom: 16px; animation: vag-bounce 0.6s ease; }
.vag-success-card h3 { font-size: 22px; font-weight: 800; color: var(--vag-success); margin: 0 0 8px; }
.vag-success-card h3 span { font-size: 16px; font-weight: 400; color: var(--vag-text-muted); display: block; }
.vag-success-sub { color: var(--vag-text-muted); font-size: 15px; margin-bottom: 24px; }
.vag-info-box { background: var(--vag-bg); border-radius: var(--vag-radius); padding: 16px; margin-bottom: 20px; text-align: left; }
.vag-info-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px dashed var(--vag-border-light); font-size: 14px; }
.vag-info-row:last-child { border-bottom: none; }
.vag-password-box { background: #fff; border: 2px solid var(--vag-primary); border-radius: var(--vag-radius); padding: 20px; margin-bottom: 24px; }
.vag-password-box label { display: block; font-size: 13px; font-weight: 600; color: var(--vag-text-muted); margin-bottom: 12px; }
.vag-pass-copy-row { display: flex; gap: 10px; align-items: center; }
.vag-pass-copy-row input { flex: 1; font-size: 22px; font-weight: 800; color: var(--vag-primary); background: transparent; border: none; outline: none; font-family: monospace; }
.vag-warn { color: var(--vag-warning); font-size: 12px; margin-top: 10px; }
.vag-success-actions { display: flex; flex-direction: column; gap: 12px; }

/* ── AUTH (Login) ───────────────────────────────────────────── */
.vag-auth-wrap { padding: 0; background: var(--vag-bg); min-height: 100vh; display: flex; align-items: stretch; }
.vag-auth-container { display: flex; min-height: 100vh; width: 100%; max-width: 1000px; margin: 0 auto; border-radius: 0; box-shadow: var(--vag-shadow-xl); overflow: hidden; }
.vag-auth-brand-panel { flex: 0 0 420px; background: linear-gradient(160deg, var(--vag-secondary) 0%, var(--vag-primary) 60%, #3b82f6 100%); padding: 60px 48px; display: flex; align-items: center; }
.vag-auth-brand-content { color: #fff; width: 100%; }
.vag-auth-logo { font-size: 64px; margin-bottom: 20px; display: block; }
.vag-auth-brand-content h1 { font-size: 32px; font-weight: 800; margin: 0 0 8px; letter-spacing: -1px; }
.vag-auth-brand-content p { opacity: 0.8; font-size: 16px; margin: 0 0 36px; }
.vag-auth-features { display: flex; flex-direction: column; gap: 14px; margin-bottom: 40px; }
.vag-auth-feature { display: flex; align-items: center; gap: 12px; font-size: 15px; }
.vag-auth-brand-badge { background: rgba(255,255,255,0.15); border-radius: var(--vag-radius); padding: 12px 16px; font-size: 11px; letter-spacing: 0.5px; }
.vag-auth-form-panel { flex: 1; background: #fff; padding: 60px 48px; display: flex; align-items: center; }
.vag-auth-form-inner { width: 100%; max-width: 400px; }
.vag-auth-title { font-size: 28px; font-weight: 800; color: var(--vag-secondary); margin: 0 0 32px; line-height: 1.3; }
.vag-auth-title span { font-size: 18px; font-weight: 400; color: var(--vag-text-muted); display: block; }
.vag-login-options { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.vag-auth-divider { text-align: center; position: relative; margin: 24px 0; color: var(--vag-text-light); font-size: 13px; }
.vag-auth-divider::before, .vag-auth-divider::after { content: ''; position: absolute; top: 50%; width: 42%; height: 1px; background: var(--vag-border); }
.vag-auth-divider::before { left: 0; }
.vag-auth-divider::after { right: 0; }
.vag-auth-support { text-align: center; margin-top: 24px; }
.vag-whatsapp-link { color: #25D366; text-decoration: none; font-weight: 600; font-size: 14px; display: inline-flex; align-items: center; gap: 6px; }

/* ── DASHBOARD NAV ──────────────────────────────────────────── */
.vag-dashboard-wrap { max-width: 100%; padding: 0; background: var(--vag-bg); }
.vag-dash-nav { background: #fff; border-bottom: 1px solid var(--vag-border); padding: 0 24px; display: flex; align-items: center; gap: 0; position: sticky; top: 0; z-index: 100; box-shadow: var(--vag-shadow-sm); }
.vag-dash-nav-brand { display: flex; align-items: center; gap: 10px; font-size: 18px; font-weight: 800; color: var(--vag-secondary); padding: 16px 0; margin-right: 20px; white-space: nowrap; }
.vag-dash-logo { font-size: 24px; }
.vag-dash-nav-links { display: flex; align-items: center; gap: 2px; flex: 1; overflow-x: auto; }
.vag-dash-tab-btn { background: none; border: none; padding: 18px 14px; font-size: 13px; font-weight: 600; color: var(--vag-text-muted); cursor: pointer; white-space: nowrap; border-bottom: 3px solid transparent; transition: all var(--vag-transition); font-family: var(--vag-font); }
.vag-dash-tab-btn:hover { color: var(--vag-primary); }
.vag-dash-tab-btn.active { color: var(--vag-primary); border-bottom-color: var(--vag-primary); }
.vag-dash-nav-right { display: flex; align-items: center; gap: 12px; margin-left: auto; padding-left: 16px; }

/* ── NOTIFICATION BELL ──────────────────────────────────────── */
.vag-notif-bell { position: relative; }
.vag-bell-btn { background: none; border: none; cursor: pointer; font-size: 22px; padding: 8px; border-radius: var(--vag-radius); color: var(--vag-text-muted); position: relative; transition: all var(--vag-transition); }
.vag-bell-btn:hover { background: var(--vag-bg); color: var(--vag-primary); }
.vag-notif-badge { position: absolute; top: 4px; right: 4px; background: var(--vag-danger); color: #fff; font-size: 10px; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; border: 2px solid #fff; }
.vag-notif-panel { position: absolute; right: 0; top: 48px; width: 340px; background: #fff; border-radius: var(--vag-radius); box-shadow: var(--vag-shadow-xl); border: 1px solid var(--vag-border); z-index: 200; overflow: hidden; }
.vag-notif-header { display: flex; justify-content: space-between; align-items: center; padding: 14px 16px; border-bottom: 1px solid var(--vag-border-light); font-weight: 700; font-size: 14px; }
.vag-mark-all-read { background: none; border: none; color: var(--vag-primary); font-size: 12px; cursor: pointer; }
.vag-notif-list { max-height: 380px; overflow-y: auto; }
.vag-notif-item { padding: 14px 16px; border-bottom: 1px solid var(--vag-border-light); cursor: pointer; transition: background var(--vag-transition); }
.vag-notif-item:hover { background: var(--vag-bg); }
.vag-notif-item.unread { background: #eff6ff; }
.vag-notif-item-title { font-size: 13px; font-weight: 700; color: var(--vag-text); margin-bottom: 4px; }
.vag-notif-item-msg { font-size: 12px; color: var(--vag-text-muted); line-height: 1.5; }
.vag-notif-item-time { font-size: 11px; color: var(--vag-text-light); margin-top: 4px; }

/* ── USER DROPDOWN ──────────────────────────────────────────── */
.vag-user-menu { position: relative; }
.vag-user-btn { background: none; border: 1.5px solid var(--vag-border); border-radius: var(--vag-radius-full); padding: 7px 14px 7px 8px; cursor: pointer; display: flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; color: var(--vag-text); transition: all var(--vag-transition); font-family: var(--vag-font); }
.vag-user-btn:hover { border-color: var(--vag-primary); color: var(--vag-primary); }
.vag-nav-avatar, .vag-nav-avatar-placeholder { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; background: var(--vag-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; }
.vag-user-dropdown { position: absolute; right: 0; top: 48px; width: 220px; background: #fff; border-radius: var(--vag-radius); box-shadow: var(--vag-shadow-xl); border: 1px solid var(--vag-border); z-index: 200; overflow: hidden; }
.vag-dropdown-header { padding: 14px 16px; border-bottom: 1px solid var(--vag-border-light); }
.vag-dropdown-header strong { display: block; font-size: 14px; color: var(--vag-text); }
.vag-dropdown-header small { color: var(--vag-text-muted); font-size: 12px; }
.vag-dropdown-item { display: block; padding: 11px 16px; font-size: 14px; color: var(--vag-text); text-decoration: none; transition: background var(--vag-transition); cursor: pointer; border: none; width: 100%; text-align: left; background: none; font-family: var(--vag-font); }
.vag-dropdown-item:hover { background: var(--vag-bg); }
.vag-dropdown-divider { height: 1px; background: var(--vag-border-light); margin: 4px 0; }

/* ── APPOINTMENT BANNER ──────────────────────────────────────── */
.vag-appointment-banner { background: linear-gradient(135deg, #065f46, #10b981); color: #fff; padding: 16px 28px; display: flex; align-items: center; gap: 16px; }
.vag-appt-icon { font-size: 32px; }
.vag-appt-content { flex: 1; }
.vag-appt-countdown { font-size: 22px; font-weight: 800; }

/* ── DASHBOARD SECTIONS ─────────────────────────────────────── */
.vag-dashboard-content { padding: 28px 24px; }
.vag-dash-section { display: none; }
.vag-dash-section.active { display: block; animation: vag-fadein 0.3s ease; }
.vag-section-heading { font-size: 22px; font-weight: 800; color: var(--vag-secondary); margin: 0 0 24px; }

/* ── WELCOME CARD ────────────────────────────────────────────── */
.vag-welcome-card { display: flex; align-items: center; gap: 20px; background: linear-gradient(135deg, var(--vag-secondary), var(--vag-primary)); color: #fff; border-radius: var(--vag-radius-xl); padding: 28px 32px; margin-bottom: 24px; flex-wrap: wrap; }
.vag-welcome-avatar img, .vag-avatar-big { width: 70px; height: 70px; border-radius: 50%; object-fit: cover; border: 3px solid rgba(255,255,255,0.4); background: rgba(255,255,255,0.2); display: flex; align-items: center; justify-content: center; font-size: 28px; font-weight: 800; color: #fff; }
.vag-welcome-text { flex: 1; }
.vag-welcome-text h2 { font-size: 24px; font-weight: 800; margin: 0 0 6px; }
.vag-welcome-text p { opacity: 0.85; margin: 0; font-size: 14px; }
.vag-status-pill { padding: 8px 20px; border-radius: var(--vag-radius-full); font-size: 14px; font-weight: 700; backdrop-filter: blur(10px); }

/* ── STATS ROW ───────────────────────────────────────────────── */
.vag-stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.vag-mini-stat { background: #fff; border-radius: var(--vag-radius); padding: 20px; text-align: center; box-shadow: var(--vag-shadow-sm); border: 1px solid var(--vag-border-light); transition: all var(--vag-transition); }
.vag-mini-stat:hover { transform: translateY(-2px); box-shadow: var(--vag-shadow); }
.vag-mini-stat-icon { font-size: 28px; margin-bottom: 8px; }
.vag-mini-stat-val { font-size: 22px; font-weight: 800; margin-bottom: 4px; }
.vag-mini-stat-label { font-size: 12px; color: var(--vag-text-muted); font-weight: 600; }
.vag-stat-blue .vag-mini-stat-val { color: var(--vag-primary); }
.vag-stat-green .vag-mini-stat-val { color: var(--vag-success); }
.vag-stat-purple .vag-mini-stat-val { color: var(--vag-purple); }
.vag-stat-gold .vag-mini-stat-val { color: var(--vag-accent); }

/* ── PROGRESS TRACKER ─────────────────────────────────────────── */
.vag-progress-tracker { display: flex; align-items: center; padding: 24px 0; margin-bottom: 20px; overflow-x: auto; }
.vag-tracker-step { display: flex; flex-direction: column; align-items: center; gap: 10px; min-width: 80px; }
.vag-tracker-dot { width: 44px; height: 44px; border-radius: 50%; background: var(--vag-bg); border: 2px solid var(--vag-border); display: flex; align-items: center; justify-content: center; font-size: 18px; transition: all var(--vag-transition-md); }
.vag-tracker-step.done .vag-tracker-dot { background: var(--vag-success); border-color: var(--vag-success); color: #fff; font-size: 16px; }
.vag-tracker-step.active .vag-tracker-dot { background: var(--vag-primary); border-color: var(--vag-primary); box-shadow: 0 0 0 4px rgba(37,99,235,0.2); }
.vag-tracker-label { font-size: 11px; color: var(--vag-text-muted); text-align: center; font-weight: 600; }
.vag-tracker-step.done .vag-tracker-label { color: var(--vag-success); }
.vag-tracker-step.active .vag-tracker-label { color: var(--vag-primary); }
.vag-tracker-line { flex: 1; height: 3px; background: var(--vag-border); margin: 0 4px; min-width: 50px; transition: background var(--vag-transition-md); }
.vag-tracker-line.done { background: var(--vag-success); }

/* ── QUICK LINKS ──────────────────────────────────────────────── */
.vag-quick-links { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.vag-quick-link-card { background: #fff; border-radius: var(--vag-radius); padding: 24px 16px; text-align: center; border: 2px solid var(--vag-border-light); cursor: pointer; transition: all var(--vag-transition); font-family: var(--vag-font); }
.vag-quick-link-card:hover { border-color: var(--vag-primary); background: var(--vag-primary-light); transform: translateY(-2px); }
.vag-ql-icon { display: block; font-size: 32px; margin-bottom: 10px; }
.vag-quick-link-card span:last-child { font-size: 13px; font-weight: 600; color: var(--vag-text-muted); }

/* ── DOCUMENTS DISPLAY ────────────────────────────────────────── */
.vag-docs-display-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.vag-doc-display-card { background: var(--vag-bg); border-radius: var(--vag-radius); padding: 16px; border: 1.5px solid var(--vag-border); }
.vag-doc-display-label { font-size: 12px; font-weight: 700; color: var(--vag-text-muted); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.5px; }
.vag-doc-badge { display: inline-block; padding: 3px 10px; border-radius: var(--vag-radius-full); font-size: 11px; font-weight: 700; }
.vag-badge-pending  { background: #fffbeb; color: #92400e; }
.vag-badge-approved { background: #ecfdf5; color: #065f46; }
.vag-badge-rejected { background: #fef2f2; color: #991b1b; }

/* ── CERTIFICATES GRID ────────────────────────────────────────── */
.vag-certs-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }
.vag-cert-card { background: linear-gradient(135deg, var(--vag-secondary), #2563eb); color: #fff; border-radius: var(--vag-radius-lg); padding: 28px; position: relative; overflow: hidden; }
.vag-cert-card::before { content: '🏆'; position: absolute; right: -10px; top: -10px; font-size: 80px; opacity: 0.1; }
.vag-cert-no { font-size: 12px; opacity: 0.7; font-family: monospace; margin-bottom: 8px; }
.vag-cert-name { font-size: 22px; font-weight: 800; margin-bottom: 4px; }
.vag-cert-type { font-size: 13px; opacity: 0.8; margin-bottom: 16px; }
.vag-cert-dates { display: flex; gap: 20px; font-size: 12px; opacity: 0.8; margin-bottom: 20px; }
.vag-cert-actions { display: flex; gap: 10px; }

/* ── CAMP LIST ────────────────────────────────────────────────── */
.vag-camp-list-item { border: 1.5px solid var(--vag-border); border-radius: var(--vag-radius); padding: 18px 20px; margin-bottom: 12px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.vag-camp-info { flex: 1; }
.vag-camp-title { font-size: 16px; font-weight: 700; color: var(--vag-text); margin-bottom: 4px; }
.vag-camp-meta { font-size: 13px; color: var(--vag-text-muted); }

/* ── MESSAGE / WHATSAPP CARD ───────────────────────────────────── */
.vag-whatsapp-card { background: linear-gradient(135deg, #25D366, #1ebe58); color: #fff; border-radius: var(--vag-radius-lg); padding: 28px; display: flex; align-items: center; gap: 20px; margin-top: 20px; }
.vag-wa-icon { font-size: 48px; }
.vag-wa-content h3 { margin: 0 0 4px; font-size: 18px; }
.vag-wa-content p { margin: 0 0 16px; opacity: 0.9; font-size: 14px; }
.vag-wa-content .vag-btn { background: rgba(255,255,255,0.2); color: #fff; border: 2px solid rgba(255,255,255,0.5); }
.vag-wa-content .vag-btn:hover { background: rgba(255,255,255,0.3); }

/* ── PROFILE GRID ─────────────────────────────────────────────── */
.vag-profile-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.vag-info-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.vag-info-table th { width: 42%; padding: 10px 0; color: var(--vag-text-muted); font-weight: 600; text-align: left; border-bottom: 1px solid var(--vag-border-light); vertical-align: top; }
.vag-info-table td { padding: 10px 0 10px 12px; color: var(--vag-text); border-bottom: 1px solid var(--vag-border-light); }

/* ── COLLAPSIBLE ──────────────────────────────────────────────── */
.vag-collapsible-toggle { display: flex; justify-content: space-between; align-items: center; cursor: pointer; padding: 14px 0; font-weight: 700; color: var(--vag-primary); font-size: 15px; }
.vag-collapsible-toggle:hover { color: var(--vag-primary-dark); }
.vag-toggle-icon, .vag-toggle-arrow { transition: transform var(--vag-transition); }
.vag-collapsible-toggle.open .vag-toggle-icon,
.vag-collapsible-card .vag-card-toggle.open .vag-toggle-arrow { transform: rotate(180deg); }
.vag-collapsible-card .vag-card-toggle { cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
.vag-collapsible-card .vag-card-toggle h3 { margin: 0; }
.vag-section-divider { font-weight: 700; color: var(--vag-text-muted); font-size: 13px; text-transform: uppercase; letter-spacing: 0.5px; padding: 8px 0; border-bottom: 1px solid var(--vag-border-light); margin-bottom: 16px; }
.vag-divider { text-align: center; position: relative; margin: 24px 0; color: var(--vag-text-light); font-size: 13px; }
.vag-divider::before, .vag-divider::after { content: ''; position: absolute; top: 50%; width: 44%; height: 1px; background: var(--vag-border); }
.vag-divider::before { left: 0; } .vag-divider::after { right: 0; }

/* ── FEE NOTICE ─────────────────────────────────────────────────── */
.vag-fee-notice { background: #fffbeb; border: 1.5px solid var(--vag-warning); border-radius: var(--vag-radius); padding: 16px; margin-bottom: 20px; font-size: 15px; font-weight: 600; color: #92400e; }
.vag-fee-notice p { font-size: 13px; font-weight: 400; margin: 6px 0 0; }

/* ── WHATSAPP FLOAT ─────────────────────────────────────────────── */
.vag-wa-float {
  position: fixed; bottom: 28px; right: 28px;
  background: #25D366; color: #fff;
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 20px rgba(37,211,102,0.45);
  text-decoration: none; z-index: 999;
  transition: all var(--vag-transition);
}
.vag-wa-float:hover { transform: scale(1.1) translateY(-2px); box-shadow: 0 10px 28px rgba(37,211,102,0.55); }

/* ── LOADING SPINNER ─────────────────────────────────────────────── */
.vag-loading { text-align: center; padding: 32px; color: var(--vag-text-muted); font-size: 14px; }
.vag-loading::before { content: ''; display: inline-block; width: 24px; height: 24px; border: 3px solid var(--vag-border); border-top-color: var(--vag-primary); border-radius: 50%; animation: vag-spin 0.8s linear infinite; margin-right: 10px; vertical-align: middle; }

/* ── EMPTY STATE ─────────────────────────────────────────────────── */
.vag-empty-state { text-align: center; padding: 48px 20px; color: var(--vag-text-muted); }
.vag-empty-state-icon { font-size: 48px; margin-bottom: 16px; }

/* ── AADHAAR MASKING ──────────────────────────────────────────────── */
.vag-aadhaar-mask { letter-spacing: 3px; font-family: monospace; }

/* ── FORM ROW ────────────────────────────────────────────────────── */
.vag-form-row { display: flex; gap: 12px; align-items: flex-end; flex-wrap: wrap; }
.vag-form-row .vag-select { flex: 1; min-width: 180px; }
.vag-file-btn { display: inline-flex; align-items: center; gap: 8px; padding: 11px 18px; border-radius: var(--vag-radius); background: var(--vag-bg); border: 1.5px solid var(--vag-border); font-size: 14px; font-weight: 600; color: var(--vag-text-muted); cursor: pointer; transition: all var(--vag-transition); }
.vag-file-btn:hover { border-color: var(--vag-primary); color: var(--vag-primary); }
.vag-file-btn input { display: none; }

/* ── MISC ──────────────────────────────────────────────────────── */
.vag-text-center { text-align: center; }
.vag-muted { color: var(--vag-text-muted); font-size: 13px; }
.vag-form-group { margin-bottom: 20px; }
.vag-form-row-split { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }

/* ── ANIMATIONS ─────────────────────────────────────────────────── */
@keyframes vag-fadein  { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes vag-bounce  { 0%,100% { transform: scale(1); } 50% { transform: scale(1.15); } }
@keyframes vag-spin    { to { transform: rotate(360deg); } }
@keyframes vag-pulse   { 0%,100% { opacity: 1; } 50% { opacity: 0.5; } }
@keyframes vag-slideup { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
