/* FNJ Smart Membership - Frontend Styles */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+Devanagari:wght@300;400;500;600;700&display=swap');

:root {
  --fnj-primary:    #1a3a5c;
  --fnj-secondary:  #2c5282;
  --fnj-accent:     #e8a020;
  --fnj-success:    #27ae60;
  --fnj-danger:     #e74c3c;
  --fnj-warning:    #f39c12;
  --fnj-info:       #3498db;
  --fnj-light:      #f8fafc;
  --fnj-border:     #d1d9e6;
  --fnj-text:       #2d3748;
  --fnj-muted:      #718096;
  --fnj-radius:     8px;
  --fnj-shadow:     0 2px 12px rgba(0,0,0,.08);
  --fnj-shadow-lg:  0 8px 32px rgba(0,0,0,.12);
}

.fnj-wrap {
  font-family: 'Noto Sans Devanagari', 'Segoe UI', Arial, sans-serif;
  color: var(--fnj-text);
  max-width: 1100px;
  margin: 0 auto;
  padding: 24px 16px;
}

/* ── Alerts ──────────────────────────────────────────────── */
.fnj-alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--fnj-radius);
  margin-bottom: 16px;
  font-size: 14px;
}
.fnj-alert-success { background: #d4edda; color: #155724; border-left: 4px solid #27ae60; }
.fnj-alert-danger  { background: #f8d7da; color: #721c24; border-left: 4px solid #e74c3c; }
.fnj-alert-warning { background: #fff3cd; color: #856404; border-left: 4px solid #f39c12; }
.fnj-alert-info    { background: #d1ecf1; color: #0c5460; border-left: 4px solid #3498db; }

/* ── Buttons ─────────────────────────────────────────────── */
.fnj-btn-primary, .fnj-btn-secondary, .fnj-btn-success, .fnj-btn-danger {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 20px; border-radius: var(--fnj-radius);
  font-family: inherit; font-size: 14px; font-weight: 600;
  cursor: pointer; border: 2px solid transparent;
  transition: all .2s ease; text-decoration: none;
}
.fnj-btn-primary  { background: var(--fnj-primary);   color: #fff; }
.fnj-btn-secondary{ background: #fff; color: var(--fnj-primary); border-color: var(--fnj-primary); }
.fnj-btn-success  { background: var(--fnj-success);   color: #fff; }
.fnj-btn-danger   { background: var(--fnj-danger);    color: #fff; }
.fnj-btn-primary:hover   { background: var(--fnj-secondary); color: #fff; }
.fnj-btn-secondary:hover { background: var(--fnj-light); }
.fnj-btn-success:hover   { background: #219150; }
.w-100 { width: 100%; justify-content: center; }

/* ── Badges ──────────────────────────────────────────────── */
.fnj-badge {
  display: inline-block; padding: 2px 10px; border-radius: 20px;
  font-size: 11px; font-weight: 600; letter-spacing: .3px;
}
.fnj-badge-primary   { background: #dbeafe; color: #1e40af; }
.fnj-badge-success   { background: #d1fae5; color: #065f46; }
.fnj-badge-danger    { background: #fee2e2; color: #991b1b; }
.fnj-badge-warning   { background: #fef3c7; color: #92400e; }
.fnj-badge-info      { background: #e0f2fe; color: #075985; }
.fnj-badge-secondary { background: #f1f5f9; color: #475569; }
.fnj-badge-dark      { background: #1e293b; color: #fff; }
.fnj-badge-new       { background: #ede9fe; color: #5b21b6; }
.fnj-badge-renewal   { background: #ecfdf5; color: #065f46; }
.fnj-badge-lg        { font-size: 13px; padding: 4px 14px; }

/* ── Form Elements ───────────────────────────────────────── */
.fnj-label {
  display: block; font-size: 13px; font-weight: 600;
  color: var(--fnj-text); margin-bottom: 5px;
}
.fnj-input, .fnj-select, .fnj-textarea {
  width: 100%; padding: 9px 12px;
  border: 2px solid var(--fnj-border); border-radius: var(--fnj-radius);
  font-family: inherit; font-size: 14px; color: var(--fnj-text);
  background: #fff; transition: border-color .2s;
  box-sizing: border-box;
}
.fnj-input:focus, .fnj-select:focus, .fnj-textarea:focus {
  outline: none; border-color: var(--fnj-primary);
  box-shadow: 0 0 0 3px rgba(26,58,92,.1);
}
.fnj-input.fnj-nepali { font-family: 'Noto Sans Devanagari', serif; font-size: 15px; }
.fnj-input-group { display: flex; gap: 0; }
.fnj-input-group .fnj-input { border-radius: var(--fnj-radius) 0 0 var(--fnj-radius); }
.fnj-input-addon-btn {
  padding: 9px 14px; background: var(--fnj-primary); color: #fff;
  border: 2px solid var(--fnj-primary); border-radius: 0 var(--fnj-radius) var(--fnj-radius) 0;
  cursor: pointer; white-space: nowrap; font-size: 13px; font-weight: 600;
  transition: background .2s;
}
.fnj-input-addon-btn:hover { background: var(--fnj-secondary); }
.fnj-checkbox-group { display: flex; flex-wrap: wrap; gap: 8px 16px; }
.fnj-checkbox-label { display: flex; align-items: center; gap: 6px; font-size: 13px; cursor: pointer; }
.fnj-checkbox-label input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--fnj-primary); }
.fnj-password-wrap { position: relative; }
.fnj-toggle-pass { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; color: var(--fnj-muted); }
.fnj-password-strength { height: 4px; border-radius: 2px; margin-top: 4px; transition: width .3s; }

/* ── Auth Box ────────────────────────────────────────────── */
.fnj-auth-container { display: flex; justify-content: center; padding: 20px 0; }
.fnj-auth-box { width: 100%; max-width: 520px; background: #fff; border-radius: 16px; box-shadow: var(--fnj-shadow-lg); overflow: hidden; }
.fnj-auth-header { background: var(--fnj-primary); color: #fff; text-align: center; padding: 30px 24px 20px; }
.fnj-auth-header img { height: 60px; margin-bottom: 12px; }
.fnj-auth-header h2 { font-size: 20px; margin-bottom: 4px; }
.fnj-auth-header p { font-size: 13px; opacity: .8; }
.fnj-auth-tabs { display: flex; border-bottom: 2px solid var(--fnj-border); }
.fnj-tab-btn { flex: 1; padding: 14px; background: none; border: none; font-family: inherit; font-size: 14px; font-weight: 600; color: var(--fnj-muted); cursor: pointer; transition: all .2s; }
.fnj-tab-btn.active { color: var(--fnj-primary); border-bottom: 3px solid var(--fnj-primary); margin-bottom: -2px; }
.fnj-tab-panel { display: none; padding: 24px; }
.fnj-tab-panel.active { display: block; }
.fnj-otp-timer { font-size: 12px; color: var(--fnj-muted); margin-top: 4px; }
.fnj-otp-status { font-size: 12px; margin-top: 4px; }
.fnj-link-btn { background: none; border: none; color: var(--fnj-primary); cursor: pointer; font-size: 13px; padding: 0; text-decoration: underline; }

/* ── Dashboard ───────────────────────────────────────────── */
.fnj-dashboard { }
.fnj-dash-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; padding: 20px; background: var(--fnj-primary); border-radius: 12px; color: #fff; }
.fnj-dash-greeting { display: flex; align-items: center; gap: 14px; }
.fnj-avatar { width: 52px; height: 52px; border-radius: 50%; background: rgba(255,255,255,.2); display: flex; align-items: center; justify-content: center; font-size: 22px; font-weight: 700; color: #fff; border: 2px solid rgba(255,255,255,.4); }
.fnj-dash-greeting h2 { font-size: 20px; margin: 0; }
.fnj-dash-subtitle { font-size: 13px; opacity: .8; margin: 0; }
.fnj-cards-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; margin-bottom: 24px; }
.fnj-card { background: #fff; border-radius: 12px; padding: 20px; box-shadow: var(--fnj-shadow); display: flex; gap: 14px; align-items: flex-start; border-left: 4px solid var(--fnj-primary); }
.fnj-card-membership { border-left-color: var(--fnj-primary); }
.fnj-card-expiry     { border-left-color: var(--fnj-warning); }
.fnj-card-app        { border-left-color: var(--fnj-info); }
.fnj-card-payment    { border-left-color: var(--fnj-success); }
.fnj-card-icon { font-size: 26px; color: var(--fnj-primary); }
.fnj-card-body h3 { font-size: 12px; color: var(--fnj-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px; }
.fnj-status-badge { display: inline-block; padding: 4px 12px; border-radius: 20px; font-size: 11px; font-weight: 700; letter-spacing: .5px; }
.fnj-status-active    { background: #d1fae5; color: #065f46; }
.fnj-status-expired   { background: #fee2e2; color: #991b1b; }
.fnj-status-pending   { background: #fef3c7; color: #92400e; }
.fnj-status-none      { background: #f1f5f9; color: #475569; }
.fnj-card-detail      { font-size: 12px; color: var(--fnj-muted); margin-top: 4px; }
.fnj-expiry-date      { font-size: 15px; font-weight: 700; color: var(--fnj-text); }
.fnj-expiry-warning   { font-size: 11px; color: var(--fnj-warning); font-weight: 600; }
.fnj-expiry-expired   { font-size: 11px; color: var(--fnj-danger); font-weight: 700; }
.fnj-app-number       { font-size: 12px; font-weight: 700; color: var(--fnj-primary); }
.fnj-muted            { color: var(--fnj-muted); font-size: 13px; }
.fnj-action-buttons { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px; }
.fnj-action-btn { display: inline-flex; align-items: center; gap: 6px; padding: 10px 18px; border-radius: 8px; font-size: 13px; font-weight: 600; text-decoration: none; cursor: pointer; border: 2px solid transparent; transition: all .2s; }
.fnj-action-primary { background: var(--fnj-primary); color: #fff; }
.fnj-action-renewal  { background: var(--fnj-success); color: #fff; }
.fnj-action-edit     { background: #fff; color: var(--fnj-primary); border-color: var(--fnj-primary); }
.fnj-action-pdf      { background: #c0392b; color: #fff; }
.fnj-action-card     { background: #8e44ad; color: #fff; }
.fnj-action-status   { background: #fff; color: var(--fnj-text); border-color: var(--fnj-border); }
.fnj-action-warning  { background: var(--fnj-warning); color: #fff; }
.fnj-action-btn:hover { opacity: .88; transform: translateY(-1px); }
.fnj-dash-section { margin-top: 24px; }
.fnj-dash-section h3 { font-size: 15px; font-weight: 700; color: var(--fnj-primary); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 2px solid var(--fnj-border); }
.fnj-apps-list { display: flex; flex-direction: column; gap: 8px; }
.fnj-app-item { display: flex; align-items: center; gap: 12px; padding: 10px 14px; background: var(--fnj-light); border-radius: 8px; }
.fnj-app-number { font-weight: 700; color: var(--fnj-primary); font-size: 13px; min-width: 160px; }
.fnj-app-type   { font-size: 12px; color: var(--fnj-muted); min-width: 60px; }
.fnj-app-date   { font-size: 12px; color: var(--fnj-muted); margin-left: auto; }
.fnj-renewals-list { display: flex; flex-direction: column; gap: 6px; }
.fnj-renewal-item { display: flex; align-items: center; gap: 16px; padding: 8px 12px; background: var(--fnj-light); border-radius: 6px; font-size: 13px; }
.fnj-renewal-year { font-weight: 700; color: var(--fnj-primary); }

/* ── Notifications ───────────────────────────────────────── */
.fnj-dash-notif-btn { position: relative; }
.fnj-notif-bell { background: rgba(255,255,255,.15); border: none; border-radius: 8px; padding: 8px 10px; cursor: pointer; font-size: 18px; color: #fff; position: relative; transition: background .2s; }
.fnj-notif-bell:hover { background: rgba(255,255,255,.25); }
.fnj-notif-count { position: absolute; top: -6px; right: -6px; background: var(--fnj-danger); color: #fff; font-size: 10px; font-weight: 700; border-radius: 50%; width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; }
.fnj-notif-dropdown { position: absolute; right: 0; top: calc(100% + 8px); width: 320px; background: #fff; border-radius: 12px; box-shadow: var(--fnj-shadow-lg); border: 1px solid var(--fnj-border); z-index: 999; overflow: hidden; }
.fnj-notif-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; background: var(--fnj-light); border-bottom: 1px solid var(--fnj-border); font-weight: 600; font-size: 13px; }
.fnj-notif-item { padding: 12px 16px; border-bottom: 1px solid var(--fnj-border); cursor: pointer; transition: background .2s; }
.fnj-notif-item:hover { background: var(--fnj-light); }
.fnj-notif-item.unread { background: #eff6ff; border-left: 3px solid var(--fnj-primary); }
.fnj-notif-title { font-size: 13px; font-weight: 600; color: var(--fnj-text); }
.fnj-notif-msg   { font-size: 12px; color: var(--fnj-muted); margin-top: 2px; }
.fnj-notif-time  { font-size: 11px; color: var(--fnj-muted); margin-top: 4px; }
.fnj-notif-empty { padding: 20px; text-align: center; color: var(--fnj-muted); font-size: 13px; }

/* ── Wizard ──────────────────────────────────────────────── */
.fnj-wizard-container { background: #fff; border-radius: 16px; box-shadow: var(--fnj-shadow-lg); overflow: hidden; }
.fnj-wizard-header { background: var(--fnj-primary); color: #fff; padding: 20px 28px; display: flex; justify-content: space-between; align-items: center; }
.fnj-wizard-header h2 { font-size: 18px; margin: 0; }
.fnj-wizard-app-no { font-size: 12px; background: rgba(255,255,255,.15); padding: 4px 12px; border-radius: 20px; }
.fnj-progress-bar { display: flex; align-items: center; padding: 20px 28px; background: #f8fafc; border-bottom: 2px solid var(--fnj-border); overflow-x: auto; }
.fnj-progress-step { display: flex; flex-direction: column; align-items: center; gap: 4px; min-width: 80px; }
.fnj-step-circle { width: 36px; height: 36px; border-radius: 50%; background: var(--fnj-border); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; color: var(--fnj-muted); transition: all .3s; }
.fnj-progress-step.active   .fnj-step-circle { background: var(--fnj-primary); color: #fff; }
.fnj-progress-step.done     .fnj-step-circle { background: var(--fnj-success); color: #fff; }
.fnj-step-label { font-size: 11px; color: var(--fnj-muted); text-align: center; }
.fnj-progress-step.active .fnj-step-label { color: var(--fnj-primary); font-weight: 600; }
.fnj-progress-line { flex: 1; height: 2px; background: var(--fnj-border); min-width: 20px; }
.fnj-step { display: none; padding: 28px; }
.fnj-step.active { display: block; }
.fnj-step-title { font-size: 16px; font-weight: 700; color: var(--fnj-primary); margin-bottom: 20px; padding-bottom: 10px; border-bottom: 2px solid var(--fnj-border); }
.fnj-subsection-title { font-size: 14px; font-weight: 700; color: var(--fnj-primary); margin-bottom: 14px; }
.fnj-wizard-nav { display: flex; align-items: center; justify-content: space-between; padding: 16px 28px; border-top: 2px solid var(--fnj-border); background: var(--fnj-light); }
.fnj-autosave-msg { font-size: 12px; color: var(--fnj-success); }

/* ── Blank Form Download Card ──────────────────────────── */
.fnj-blank-form-download { margin-bottom: 20px; }
.fnj-info-card { display: flex; align-items: center; gap: 14px; background: #eff6ff; border: 1px solid #bfdbfe; border-radius: var(--fnj-radius); padding: 14px 18px; }
.fnj-info-card > i { font-size: 28px; color: var(--fnj-primary); flex-shrink: 0; }
.fnj-info-card > div { flex: 1; }
.fnj-info-card > div strong { font-size: 14px; color: var(--fnj-primary); }
.fnj-info-card > div p { font-size: 12px; color: var(--fnj-muted); margin: 2px 0 0; }
.fnj-btn-outline { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; border-radius: var(--fnj-radius); border: 2px solid var(--fnj-primary); color: var(--fnj-primary); background: #fff; font-size: 13px; font-weight: 600; text-decoration: none; white-space: nowrap; transition: all .2s; flex-shrink: 0; }
.fnj-btn-outline:hover { background: var(--fnj-primary); color: #fff; }

/* ── Document Upload ─────────────────────────────────────── */
.fnj-doc-upload-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; margin-bottom: 20px; }
.fnj-dropzone { border: 2px dashed var(--fnj-border); border-radius: var(--fnj-radius); padding: 16px; text-align: center; cursor: pointer; transition: all .2s; min-height: 110px; display: flex; align-items: center; justify-content: center; }
.fnj-dropzone:hover, .fnj-dropzone.drag-over { border-color: var(--fnj-primary); background: #eff6ff; }
.fnj-drop-placeholder i { font-size: 32px; color: var(--fnj-border); display: block; margin-bottom: 8px; }
.fnj-drop-placeholder p { font-size: 13px; color: var(--fnj-muted); margin: 0; }
.fnj-drop-placeholder small { font-size: 11px; color: var(--fnj-muted); }
.fnj-uploaded-file { display: flex; flex-direction: column; align-items: center; gap: 6px; position: relative; width: 100%; }
.fnj-thumb-preview { max-width: 100%; max-height: 80px; border-radius: 4px; object-fit: contain; }
.fnj-file-icon { font-size: 36px; color: var(--fnj-primary); }
.fnj-file-name { font-size: 11px; color: var(--fnj-muted); word-break: break-all; text-align: center; }
.fnj-remove-file { background: var(--fnj-danger); color: #fff; border: none; border-radius: 50%; width: 22px; height: 22px; font-size: 14px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.fnj-upload-progress { margin-top: 6px; }
.fnj-progress-track { height: 6px; background: var(--fnj-border); border-radius: 3px; overflow: hidden; }
.fnj-progress-fill  { height: 100%; background: var(--fnj-primary); transition: width .3s; }
.fnj-progress-text  { font-size: 11px; color: var(--fnj-muted); margin-top: 2px; display: block; }

/* ── Recommendation Box ──────────────────────────────────── */
.fnj-rec-box { background: var(--fnj-light); border-radius: var(--fnj-radius); padding: 16px; border: 1px solid var(--fnj-border); }
.fnj-rec-box h5 { font-size: 14px; font-weight: 700; color: var(--fnj-primary); margin-bottom: 12px; }

/* ── Bank Info ───────────────────────────────────────────── */
.fnj-bank-info-box { background: linear-gradient(135deg, #f0f4ff, #e8f4fd); border: 2px solid var(--fnj-primary); border-radius: 12px; padding: 20px; margin-bottom: 20px; }
.fnj-bank-info-box h4 { font-size: 15px; font-weight: 700; color: var(--fnj-primary); margin-bottom: 14px; }
.fnj-bank-details { display: flex; gap: 24px; align-items: flex-start; }
.fnj-bank-text { flex: 1; }
.fnj-bank-table { width: 100%; border-collapse: collapse; }
.fnj-bank-table th { text-align: left; padding: 4px 8px; font-size: 12px; color: var(--fnj-muted); width: 120px; }
.fnj-bank-table td { padding: 4px 8px; font-size: 13px; font-weight: 500; }
.fnj-bank-qr { text-align: center; }
.fnj-qr-img { max-width: 200px; max-height: 200px; border: 2px solid var(--fnj-border); border-radius: 8px; }
.fnj-bank-qr p { font-size: 11px; color: var(--fnj-muted); margin-top: 4px; }
.fnj-bank-note { font-size: 12px; color: var(--fnj-muted); margin-top: 12px; display: flex; align-items: center; gap: 6px; }

/* ── Review Summary ──────────────────────────────────────── */
.fnj-review-summary { background: var(--fnj-light); border-radius: var(--fnj-radius); padding: 16px; border: 1px solid var(--fnj-border); }
.fnj-review-summary h4 { font-size: 14px; font-weight: 700; color: var(--fnj-primary); margin-bottom: 12px; }
.fnj-declaration { background: #fffbeb; border: 1px solid var(--fnj-warning); border-radius: 8px; padding: 14px; }

/* ── Verification ────────────────────────────────────────── */
.fnj-verify-container { max-width: 560px; margin: 0 auto; }
.fnj-verify-header { text-align: center; padding: 30px 20px 20px; background: var(--fnj-primary); border-radius: 14px 14px 0 0; color: #fff; }
.fnj-verify-header img { height: 60px; margin-bottom: 12px; }
.fnj-verify-header h2 { font-size: 20px; margin-bottom: 4px; }
.fnj-verify-header p { font-size: 13px; opacity: .8; }
.fnj-verify-form { background: #fff; padding: 24px; border: 1px solid var(--fnj-border); }
.fnj-verify-result { background: #fff; padding: 28px; text-align: center; border: 1px solid var(--fnj-border); }
.fnj-verify-icon { font-size: 56px; margin-bottom: 12px; }
.fnj-verify-result h3 { font-size: 20px; font-weight: 700; margin-bottom: 16px; }
.fnj-verify-card { text-align: left; background: var(--fnj-light); border-radius: 8px; padding: 16px; margin: 16px 0; }
.fnj-verify-table { width: 100%; border-collapse: collapse; }
.fnj-verify-table th { font-size: 12px; color: var(--fnj-muted); padding: 6px 8px; text-align: left; width: 140px; }
.fnj-verify-table td { font-size: 13px; font-weight: 500; padding: 6px 8px; border-bottom: 1px solid var(--fnj-border); }
.fnj-verify-footer { background: var(--fnj-light); padding: 14px; text-align: center; border: 1px solid var(--fnj-border); border-top: none; border-radius: 0 0 14px 14px; font-size: 12px; color: var(--fnj-muted); }

/* ── Status Page ─────────────────────────────────────────── */
.fnj-page-title { font-size: 22px; font-weight: 700; color: var(--fnj-primary); margin-bottom: 20px; }
.fnj-status-list { display: flex; flex-direction: column; gap: 16px; }
.fnj-status-card { background: #fff; border-radius: 12px; box-shadow: var(--fnj-shadow); overflow: hidden; }
.fnj-status-card-header { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; background: var(--fnj-light); border-bottom: 1px solid var(--fnj-border); }
.fnj-status-card-body { padding: 18px; }
.fnj-status-card-footer { padding: 12px 18px; border-top: 1px solid var(--fnj-border); background: var(--fnj-light); }
.fnj-status-timeline { display: flex; flex-direction: column; gap: 12px; }
.fnj-timeline-step { display: flex; align-items: flex-start; gap: 12px; }
.fnj-tl-icon { width: 32px; height: 32px; border-radius: 50%; background: var(--fnj-border); display: flex; align-items: center; justify-content: center; color: var(--fnj-muted); font-size: 14px; flex-shrink: 0; }
.fnj-timeline-step.done    .fnj-tl-icon { background: var(--fnj-success); color: #fff; }
.fnj-timeline-step.current .fnj-tl-icon { background: var(--fnj-primary); color: #fff; }
.fnj-tl-label { font-size: 13px; font-weight: 600; color: var(--fnj-text); }
.fnj-tl-date  { font-size: 11px; color: var(--fnj-muted); }
.fnj-empty-state { text-align: center; padding: 48px 20px; color: var(--fnj-muted); }
.fnj-empty-state i { font-size: 48px; display: block; margin-bottom: 12px; }
.fnj-empty-state p { font-size: 15px; margin-bottom: 16px; }

/* ── Spinner ─────────────────────────────────────────────── */
.fnj-spinner { display: inline-block; width: 16px; height: 16px; border: 2px solid rgba(255,255,255,.4); border-top-color: #fff; border-radius: 50%; animation: fnj-spin .6s linear infinite; }
@keyframes fnj-spin { to { transform: rotate(360deg); } }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 768px) {
  .fnj-dash-header   { flex-direction: column; gap: 12px; text-align: center; }
  .fnj-cards-grid    { grid-template-columns: 1fr 1fr; }
  .fnj-action-buttons{ justify-content: center; }
  .fnj-bank-details  { flex-direction: column; }
  .fnj-doc-upload-grid { grid-template-columns: 1fr; }
  .fnj-wizard-nav    { flex-direction: column; gap: 8px; }
  .fnj-notif-dropdown{ width: 280px; right: -60px; }
  .fnj-progress-bar  { padding: 14px; gap: 4px; }
  .fnj-step-label    { display: none; }
}
@media (max-width: 480px) {
  .fnj-cards-grid { grid-template-columns: 1fr; }
  .fnj-auth-box   { border-radius: 0; box-shadow: none; }
}

/* ── Dark Mode ───────────────────────────────────────────── */
@media (prefers-color-scheme: dark) {
  .fnj-wrap { background: transparent; }
  .fnj-auth-box, .fnj-card, .fnj-wizard-container, .fnj-status-card,
  .fnj-verify-result, .fnj-verify-form { background: #1e2a3a; border-color: #2d3f55; color: #e2e8f0; }
  .fnj-input, .fnj-select { background: #162032; border-color: #2d3f55; color: #e2e8f0; }
  .fnj-light, .fnj-auth-tabs, .fnj-wizard-nav, .fnj-status-card-header,
  .fnj-status-card-footer, .fnj-rec-box, .fnj-bank-info-box,
  .fnj-review-summary, .fnj-app-item, .fnj-renewal-item { background: #162032; }
  .fnj-label { color: #cbd5e0; }
  .fnj-tab-btn { color: #94a3b8; }
}
