/* ==========================================================
   YENBOA — PREMIUM DESIGN SYSTEM
   Part 1/5: Tokens · Reset · Typography · Layout
   ========================================================== */

/* ----------------------------------------------------------
   1. DESIGN TOKENS — LIGHT MODE
   ---------------------------------------------------------- */
:root {
  /* Brand */
  --brand-green:       #1a8a4a;
  --brand-green-deep:  #0d5c30;
  --brand-green-light: #d4f0e0;
  --brand-gold:        #e6a817;
  --brand-gold-light:  #fef3d0;
  --brand-gold-deep:   #9c6e00;

  /* Surfaces */
  --surface-0:  #f4faf6;
  --surface-1:  #ffffff;
  --surface-2:  #eaf4ee;
  --surface-3:  #ddeee4;

  /* Text */
  --text-primary: #0d3b22;
  --text-muted:   #4d7460;
  --text-faint:   #8aaa96;
  --text-inverse: #ffffff;

  /* Borders & Shadows */
  --border-color:   rgba(26, 138, 74, 0.15);
  --border-subtle:  rgba(26, 138, 74, 0.08);
  --shadow-xs:  0 1px 3px rgba(13, 59, 34, 0.08);
  --shadow-sm:  0 4px 12px rgba(13, 59, 34, 0.10);
  --shadow-md:  0 8px 24px rgba(13, 59, 34, 0.12);
  --shadow-lg:  0 18px 45px rgba(13, 59, 34, 0.14);
  --shadow-xl:  0 28px 60px rgba(13, 59, 34, 0.18);

  /* Semantic colors */
  --color-success-bg:  rgba(26, 138, 74, 0.10);
  --color-success-bd:  rgba(26, 138, 74, 0.22);
  --color-success-tx:  #0d5c30;
  --color-warning-bg:  rgba(230, 168, 23, 0.12);
  --color-warning-bd:  rgba(230, 168, 23, 0.28);
  --color-warning-tx:  #7a5200;
  --color-danger-bg:   rgba(185, 28, 28, 0.08);
  --color-danger-bd:   rgba(185, 28, 28, 0.20);
  --color-danger-tx:   #8b1a1a;
  --color-info-bg:     rgba(23, 78, 166, 0.08);
  --color-info-bd:     rgba(23, 78, 166, 0.18);
  --color-info-tx:     #1e3a8a;

  /* Radii */
  --radius-full: 999px;
  --radius-xl:   24px;
  --radius-lg:   18px;
  --radius-md:   14px;
  --radius-sm:   10px;
  --radius-xs:   7px;

  /* Button signature shape */
  --btn-radius: 14px;

  /* Spacing scale */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;

  /* Typography */
  --font-display: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-body:    system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* Transitions */
  --ease:       cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out:   cubic-bezier(0, 0, 0.2, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --dur-fast:   150ms;
  --dur-base:   220ms;
  --dur-slow:   340ms;

  /* Nav height for sticky offset */
  --nav-height: 72px;

  /* Page background */
  --page-bg: radial-gradient(ellipse 80% 50% at 10% 0%, rgba(26,138,74,0.07) 0%, transparent 60%),
             radial-gradient(ellipse 60% 40% at 90% 100%, rgba(230,168,23,0.08) 0%, transparent 55%),
             var(--surface-0);
}

/* ----------------------------------------------------------
   2. DARK MODE TOKEN OVERRIDES
   ---------------------------------------------------------- */
[data-theme="dark"] {
  --brand-green:       #2ed573;
  --brand-green-deep:  #a7f3c8;
  --brand-green-light: rgba(46, 213, 115, 0.14);
  --brand-gold:        #f5c842;
  --brand-gold-light:  rgba(245, 200, 66, 0.14);
  --brand-gold-deep:   #fde68a;

  --surface-0:  #0c1610;
  --surface-1:  #111d15;
  --surface-2:  #182a1d;
  --surface-3:  #1f3526;

  --text-primary: #d8f0e2;
  --text-muted:   #7aab8a;
  --text-faint:   #4d7460;
  --text-inverse: #0c1610;

  --border-color:  rgba(46, 213, 115, 0.14);
  --border-subtle: rgba(46, 213, 115, 0.07);

  --shadow-xs: 0 1px 3px rgba(0,0,0,0.25);
  --shadow-sm: 0 4px 12px rgba(0,0,0,0.30);
  --shadow-md: 0 8px 24px rgba(0,0,0,0.35);
  --shadow-lg: 0 18px 45px rgba(0,0,0,0.40);
  --shadow-xl: 0 28px 60px rgba(0,0,0,0.48);

  --color-success-bg:  rgba(46, 213, 115, 0.12);
  --color-success-bd:  rgba(46, 213, 115, 0.24);
  --color-success-tx:  #6ee7a4;
  --color-warning-bg:  rgba(245, 200, 66, 0.12);
  --color-warning-bd:  rgba(245, 200, 66, 0.26);
  --color-warning-tx:  #fde68a;
  --color-danger-bg:   rgba(239, 68, 68, 0.12);
  --color-danger-bd:   rgba(239, 68, 68, 0.24);
  --color-danger-tx:   #fca5a5;
  --color-info-bg:     rgba(96, 165, 250, 0.12);
  --color-info-bd:     rgba(96, 165, 250, 0.24);
  --color-info-tx:     #93c5fd;

  --page-bg: radial-gradient(ellipse 80% 50% at 10% 0%, rgba(46,213,115,0.05) 0%, transparent 60%),
             radial-gradient(ellipse 60% 40% at 90% 100%, rgba(245,200,66,0.05) 0%, transparent 55%),
             var(--surface-0);
}

/* ----------------------------------------------------------
   3. RESET & BASE
   ---------------------------------------------------------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  tab-size: 4;
}

body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--text-primary);
  background: var(--page-bg);
  background-attachment: fixed;
  min-height: 100vh;
  transition: background-color var(--dur-slow) var(--ease),
              color var(--dur-slow) var(--ease);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, video {
  max-width: 100%;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

button, input, select, textarea {
  font: inherit;
  color: inherit;
}

button {
  cursor: pointer;
  border: none;
  background: none;
}

ul, ol { list-style: none; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  line-height: 1.15;
  color: var(--text-primary);
}

p { color: var(--text-muted); line-height: 1.75; }

small {
  display: block;
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.5;
  min-height: 1.3rem;
}

strong { font-weight: 700; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ----------------------------------------------------------
   4. TYPOGRAPHY SCALE
   ---------------------------------------------------------- */
.text-display {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 5rem);
  font-weight: 800;
  line-height: 1.02;
}
.text-h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 4rem);
  font-weight: 800;
  line-height: 1.05;
}
.text-h2 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  font-weight: 700;
}
.text-h3 {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2vw, 1.7rem);
  font-weight: 700;
}

.lead { font-size: 1.1rem; line-height: 1.8; color: var(--text-muted); }
.muted-copy { color: var(--text-muted); }

/* ----------------------------------------------------------
   5. LAYOUT UTILITIES
   ---------------------------------------------------------- */
.container {
  width: min(1400px, calc(100% - 2rem));
  margin-inline: auto;
}

.container-narrow {
  width: min(760px, calc(100% - 2rem));
  margin-inline: auto;
}

.page-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.page-shell > main { flex: 1; }

.section { padding: 3rem 0 5rem; }
.compact-section { padding: 2rem 0 0; }
.admin-section { padding-top: 2rem; }

.grid { display: grid; gap: var(--space-4); }
.flex { display: flex; gap: var(--space-4); }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-wrap { flex-wrap: wrap; }

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

.narrow { width: min(760px, calc(100% - 2rem)); }

/* Two-column grids */
.hero-grid,
.campaign-detail-grid,
.donation-layout,
.payment-layout,
.form-layout,
.auth-layout,
.contributor-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6);
  align-items: start;
}

.form-layout { align-items: stretch; }

.admin-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-6);
  align-items: start;
}

.fundraiser-shell {
  display: grid;
  grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
  gap: var(--space-6);
  align-items: start;
}

.section-heading {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

/* Shared heading styles */
.hero-copy h1,
.form-intro h1,
.thank-you-card h1,
.story-card h1,
.form-card h1 {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4vw, 4.5rem);
  font-weight: 800;
  line-height: 1.03;
  margin-bottom: var(--space-4);
  color: var(--text-primary);
}

.form-card h2,
.section-heading h2,
.form-section h2,
.summary-card h2,
.receipt-card h2,
.donation-sidebar h2 {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.5vw, 2.2rem);
  font-weight: 700;
  margin-bottom: var(--space-2);
  color: var(--text-primary);
}

/* ==========================================================
   Part 2/5: Navigation · Header · Hero · Footer
   ========================================================== */

/* ----------------------------------------------------------
   6. SITE HEADER & NAV
   ---------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--nav-height);
  display: flex;
  align-items: center;
  background: rgba(244, 250, 246, 0.85);
  backdrop-filter: blur(18px) saturate(180%);
  -webkit-backdrop-filter: blur(18px) saturate(180%);
  border-bottom: 1px solid var(--border-subtle);
  transition: background var(--dur-base) var(--ease),
              box-shadow var(--dur-base) var(--ease);
}

[data-theme="dark"] .site-header {
  background: rgba(12, 22, 16, 0.88);
}

.site-header.is-scrolled {
  box-shadow: var(--shadow-sm);
  background: rgba(244, 250, 246, 0.96);
}

[data-theme="dark"] .site-header.is-scrolled {
  background: rgba(12, 22, 16, 0.97);
}

.nav-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  width: 100%;
  padding-left: max(1rem, calc(50% - 700px));
  padding-right: 2rem;
}

/* Brand */
.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--text-primary);
  flex-shrink: 0;
  transition: opacity var(--dur-fast) var(--ease);
}

.brand:hover { opacity: 0.85; }

.brand img {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
}

/* Nav links */
.nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.nav-links a {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 0.95rem;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-muted);
  transition: color var(--dur-fast) var(--ease),
              background var(--dur-fast) var(--ease);
  white-space: nowrap;
}

.nav-links a:hover {
  color: var(--text-primary);
  background: var(--surface-2);
}

.nav-links a.active {
  color: var(--brand-green);
  background: var(--brand-green-light);
  font-weight: 700;
}

/* Nav right cluster */
.nav-right {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}

.nav-balance-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 40px;
  padding: 0.35rem 0.8rem;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-full);
  background: var(--surface-2);
  color: var(--text-primary);
  cursor: pointer;
  white-space: nowrap;
  font: inherit;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}

.nav-balance-pill:hover,
.nav-balance-pill[aria-expanded="true"] {
  background: var(--surface-3);
  border-color: var(--brand-green);
}

.nav-balance-pill span {
  color: var(--text-muted);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.nav-balance-pill strong {
  color: var(--brand-green);
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 800;
}

.wallet-dropdown-menu {
  width: 230px;
}

/* Profile Dropdown */
.profile-dropdown {
  position: relative;
  display: inline-flex;
}

.profile-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem 0.5rem 0.25rem 0.25rem;
  border-radius: var(--radius-full);
  background: var(--surface-2);
  border: 1px solid var(--border-color);
  color: var(--text-primary);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}

.profile-toggle:hover, .profile-toggle[aria-expanded="true"] {
  background: var(--surface-3);
  border-color: var(--brand-green);
}

.avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-green), #0f6435);
  color: #fff;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.05em;
}

.profile-name {
  font-size: 0.9rem;
  font-weight: 700;
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dropdown-menu {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  width: 220px;
  background: var(--surface-1);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), visibility var(--dur-fast);
  z-index: 200;
  padding: var(--space-2);
}

.profile-dropdown.is-open .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.dropdown-header {
  padding: var(--space-3) var(--space-3);
  display: flex;
  flex-direction: column;
}

.dropdown-header strong {
  font-size: 0.95rem;
  font-family: var(--font-display);
  color: var(--text-primary);
}

.dropdown-header span {
  font-size: 0.8rem;
  color: var(--text-muted);
}

.dropdown-divider {
  height: 1px;
  background: var(--border-subtle);
  margin: var(--space-1) 0;
}

.dropdown-item {
  display: block;
  padding: 0.6rem var(--space-3);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}

.dropdown-item:hover {
  background: var(--surface-2);
  color: var(--brand-green);
}

.dropdown-item.text-danger {
  color: #c0392b;
}

.dropdown-item.text-danger:hover {
  background: rgba(192, 57, 43, 0.08);
  color: #a93226;
}

/* Theme toggle button */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--surface-2);
  border: 1px solid var(--border-color);
  color: var(--text-muted);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease),
              transform var(--dur-fast) var(--ease-spring);
  font-size: 1.1rem;
  flex-shrink: 0;
}

.theme-toggle:hover {
  background: var(--surface-3);
  color: var(--text-primary);
  transform: rotate(15deg);
}

/* Hamburger */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  gap: 5px;
  border-radius: var(--radius-md);
  background: var(--surface-2);
  border: 1px solid var(--border-color);
  cursor: pointer;
  flex-shrink: 0;
  transition: background var(--dur-fast) var(--ease);
}

.nav-hamburger span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--text-primary);
  border-radius: 2px;
  transition: transform var(--dur-base) var(--ease),
              opacity var(--dur-base) var(--ease),
              width var(--dur-base) var(--ease);
}

.nav-hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.is-open span:nth-child(2) { opacity: 0; width: 0; }
.nav-hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav drawer */
.nav-drawer {
  display: none;
  position: fixed;
  top: var(--nav-height);
  left: 0; right: 0;
  z-index: 99;
  background: var(--surface-1);
  border-bottom: 1px solid var(--border-color);
  box-shadow: var(--shadow-lg);
  padding: var(--space-4);
  transform: translateY(-8px);
  opacity: 0;
  transition: transform var(--dur-base) var(--ease-out),
              opacity var(--dur-base) var(--ease-out);
}

.nav-drawer.is-open {
  display: block;
  transform: translateY(0);
  opacity: 1;
}

.nav-drawer-links {
  display: grid;
  gap: var(--space-2);
}

.nav-drawer-links a {
  display: flex;
  align-items: center;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-lg);
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-muted);
  transition: background var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease);
}

.nav-drawer-links a:hover,
.nav-drawer-links a.active {
  background: var(--brand-green-light);
  color: var(--brand-green-deep);
}

/* ----------------------------------------------------------
   7. EYEBROW LABEL
   ---------------------------------------------------------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.38rem 0.85rem;
  border-radius: var(--radius-full);
  background: var(--brand-gold-light);
  color: var(--brand-gold-deep);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: var(--space-4);
  border: 1px solid rgba(230, 168, 23, 0.22);
}

[data-theme="dark"] .eyebrow {
  background: rgba(245, 200, 66, 0.12);
  color: var(--brand-gold);
  border-color: rgba(245, 200, 66, 0.22);
}

/* ----------------------------------------------------------
   8. HERO SECTION
   ---------------------------------------------------------- */
.hero {
  padding: 3.5rem 0 2.5rem;
}

.hero-grid {
  align-items: center;
  gap: var(--space-10);
}

.hero-copy p,
.lead {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--text-muted);
  margin-bottom: var(--space-4);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin: var(--space-6) 0 var(--space-8);
}

.hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.hero-visual img,
.form-intro img {
  filter: drop-shadow(0 24px 40px rgba(13, 59, 34, 0.14));
  border-radius: var(--radius-xl);
}

/* Stats grid */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-4);
}

.stat-card {
  padding: var(--space-4) var(--space-5);
  background: var(--surface-1);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-base) var(--ease),
              box-shadow var(--dur-base) var(--ease);
}

.stat-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.stat-card strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--brand-green);
  margin-bottom: var(--space-1);
  line-height: 1.1;
}

.stat-card span {
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--text-muted);
}

/* ----------------------------------------------------------
   9. SEARCH PANEL
   ---------------------------------------------------------- */
.search-panel {
  padding: 1.5rem 0 5rem;
}

.search-form {
  display: flex;
  gap: var(--space-3);
  align-items: stretch;
}

.search-form input {
  flex: 1;
  min-width: 0;
}

/* ----------------------------------------------------------
   10. SITE FOOTER
   ---------------------------------------------------------- */
.site-footer {
  padding: var(--space-10) 0 var(--space-8);
  border-top: 1px solid var(--border-subtle);
  background: var(--surface-1);
  margin-top: auto;
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}

.footer-grid h3, .footer-grid h4 {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: var(--space-3);
}

.footer-grid p {
  font-size: 0.9rem;
  line-height: 1.75;
  color: var(--text-muted);
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-subtle);
  font-size: 0.85rem;
  color: var(--text-faint);
}

/* ==========================================================
   Part 3/5: Buttons · Forms · Badges · Alerts · Toasts
   ========================================================== */

/* ----------------------------------------------------------
   11. BUTTONS — Signature squircle-pill shape
   ---------------------------------------------------------- */
.button, .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.4rem;
  min-height: 48px;
  border: 2px solid transparent;
  border-radius: var(--btn-radius);
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  position: relative;
  overflow: hidden;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition:
    transform var(--dur-fast) var(--ease-spring),
    box-shadow var(--dur-base) var(--ease),
    background var(--dur-fast) var(--ease),
    border-color var(--dur-fast) var(--ease),
    color var(--dur-fast) var(--ease),
    opacity var(--dur-fast) var(--ease);
}

/* Ripple effect layer */
.button::after, .btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(255,255,255,0.28) 0%, transparent 70%);
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease);
  border-radius: inherit;
  pointer-events: none;
}

.button:hover::after, .btn:hover::after { opacity: 1; }

.button:hover { transform: translateY(-2px); }
.button:active { transform: translateY(0) scale(0.98); }

/* Primary */
.button-primary, .btn-primary {
  background: linear-gradient(135deg, var(--brand-green) 0%, #12703c 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(26, 138, 74, 0.35);
}
.button-primary:hover, .btn-primary:hover {
  box-shadow: 0 8px 24px rgba(26, 138, 74, 0.45);
  background: linear-gradient(135deg, #1fa056 0%, #0f6435 100%);
}

/* Secondary / ghost-outlined */
.button-secondary, .btn-secondary {
  background: var(--surface-1);
  color: var(--text-primary);
  border-color: var(--border-color);
  box-shadow: var(--shadow-xs);
}
.button-secondary:hover, .btn-secondary:hover {
  background: var(--surface-2);
  border-color: var(--brand-green);
  box-shadow: var(--shadow-sm);
}

/* Danger */
.button-danger, .btn-danger {
  background: linear-gradient(135deg, #c0392b, #8e1a1a);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(192, 57, 43, 0.32);
}
.button-danger:hover, .btn-danger:hover {
  box-shadow: 0 8px 22px rgba(192, 57, 43, 0.44);
}

/* Warning */
.button-warning, .btn-warning {
  background: linear-gradient(135deg, var(--brand-gold), #c07c00);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(230, 168, 23, 0.32);
}

/* Ghost */
.button-ghost, .btn-ghost {
  background: transparent;
  color: var(--brand-green);
  border-color: transparent;
  box-shadow: none;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}
.button-ghost:hover, .btn-ghost:hover {
  background: var(--brand-green-light);
  transform: none;
}

/* Sizes */
.button-small, .btn-sm {
  min-height: 38px;
  padding: 0.5rem 1rem;
  font-size: 0.87rem;
  border-radius: 11px;
}
.btn-lg {
  min-height: 56px;
  padding: 1rem 1.8rem;
  font-size: 1.05rem;
  border-radius: 16px;
}

/* Modifiers */
.button-block, .btn-block { width: 100%; }

.danger-button {
  border-color: var(--color-danger-bd);
  color: var(--color-danger-tx);
  background: transparent;
}
.danger-button:hover { background: var(--color-danger-bg); }

/* Disabled */
.button:disabled, .btn:disabled,
button:disabled {
  opacity: 0.52;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

/* Icon-only */
.btn-icon {
  width: 44px;
  height: 44px;
  min-height: auto;
  padding: 0;
  border-radius: var(--radius-md);
}

/* label used as button */
label.button { cursor: pointer; }

/* Loading state */
.button[data-loading]::before, .btn[data-loading]::before {
  content: '';
  display: inline-block;
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: btn-spin 0.7s linear infinite;
  margin-right: 0.5rem;
}
@keyframes btn-spin { to { transform: rotate(360deg); } }

/* ----------------------------------------------------------
   12. FORM CONTROLS
   ---------------------------------------------------------- */
.form-card,
.story-card,
.donation-sidebar,
.summary-card,
.receipt-card,
.thank-you-card {
  display: grid;
  gap: var(--space-5);
  padding: var(--space-6);
  background: var(--surface-1);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
}

.form-section {
  display: grid;
  gap: var(--space-4);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
}
.form-section:last-of-type { border-bottom: none; padding-bottom: 0; }

.field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

label {
  display: block;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}

label span {
  display: block;
  margin-bottom: var(--space-2);
  font-weight: 700;
}

input,
select,
textarea {
  display: block;
  width: 100%;
  padding: 0.82rem 1.05rem;
  background: var(--surface-1);
  color: var(--text-primary);
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-lg);
  font-family: var(--font-body);
  font-size: 0.96rem;
  line-height: 1.5;
  transition:
    border-color var(--dur-fast) var(--ease),
    box-shadow var(--dur-fast) var(--ease),
    background var(--dur-fast) var(--ease);
  appearance: none;
  -webkit-appearance: none;
}

input::placeholder,
textarea::placeholder { color: var(--text-faint); }

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--brand-green);
  box-shadow: 0 0 0 3.5px rgba(26, 138, 74, 0.18);
  background: var(--surface-1);
}

input[type="checkbox"],
input[type="radio"] {
  display: inline-block;
  width: 18px;
  height: 18px;
  padding: 0;
  accent-color: var(--brand-green);
  cursor: pointer;
  border-radius: 5px;
}

input[type="checkbox"]:checked {
  border-color: var(--brand-green);
  background:
    var(--brand-green)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3 7.2l2.4 2.4L11 4' fill='none' stroke='white' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")
    center / 14px 14px no-repeat;
}

input[type="radio"] {
  border-radius: var(--radius-full);
}

input[type="radio"]:checked {
  border-color: var(--brand-green);
  background:
    radial-gradient(circle at center, var(--brand-green) 0 42%, transparent 46%);
}

textarea { resize: vertical; min-height: 120px; }

select {
  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 d='M1 1l5 5 5-5' stroke='%234d7460' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

/* Input error/success states */
input.input-error, select.input-error, textarea.input-error {
  border-color: #c0392b;
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.14);
}
input.input-success, select.input-success, textarea.input-success {
  border-color: var(--brand-green);
  box-shadow: 0 0 0 3px rgba(26, 138, 74, 0.14);
}

/* Image upload preview */
.image-preview {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.image-preview img {
  width: 100%;
  max-width: 300px;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: var(--radius-lg);
  border: 1.5px solid var(--border-color);
  box-shadow: var(--shadow-sm);
}

/* Checkbox row */
.checkbox-row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-3);
  align-items: start;
}
.checkbox-row input { width: auto; margin-top: 3px; }

.phone-prefix-field {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: stretch;
  width: 100%;
  height: 54px;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-lg);
  background: var(--surface-1);
  overflow: hidden;
  transition:
    border-color var(--dur-fast) var(--ease),
    box-shadow var(--dur-fast) var(--ease),
    background var(--dur-fast) var(--ease);
}

.phone-prefix-field > span {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-width: 104px;
  height: 100%;
  padding: 0 0.9rem;
  border-right: 1.5px solid var(--border-color);
  background: var(--surface-2);
  color: var(--text-muted);
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.phone-prefix-field > span span {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

.phone-prefix-flag {
  display: block;
  width: 24px;
  height: 16px;
  flex: 0 0 auto;
  border-radius: 3px;
  object-fit: cover;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
}

.phone-prefix-field input {
  min-width: 0;
  width: 100%;
  height: 100%;
  min-height: 0;
  margin: 0;
  padding: 0.82rem 1.05rem;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: var(--surface-1);
}

.phone-prefix-field:focus-within {
  border-color: var(--brand-green);
  box-shadow: 0 0 0 3.5px rgba(26, 138, 74, 0.18);
  background: var(--surface-1);
}

.phone-prefix-field input:focus {
  box-shadow: none;
}

/* Amount chips */
.amount-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--space-3);
}

.amount-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-lg);
  background: var(--surface-1);
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 800;
  cursor: pointer;
  color: var(--text-primary);
  transition:
    background var(--dur-fast) var(--ease),
    border-color var(--dur-fast) var(--ease),
    color var(--dur-fast) var(--ease),
    transform var(--dur-fast) var(--ease-spring),
    box-shadow var(--dur-fast) var(--ease);
}

.amount-chip:hover {
  border-color: var(--brand-green);
  background: var(--brand-green-light);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}

.amount-chip.selected {
  background: var(--brand-green);
  color: #fff;
  border-color: var(--brand-green);
  box-shadow: 0 4px 14px rgba(26, 138, 74, 0.35);
}

/* Payment method */
.payment-choice, .payment-panel { display: grid; gap: var(--space-4); }

.method-option {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: start;
  padding: var(--space-4);
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-lg);
  background: var(--surface-1);
  transition: border-color var(--dur-fast) var(--ease),
              background var(--dur-fast) var(--ease);
  cursor: pointer;
}

.method-option:has(input:checked),
.method-option.is-selected {
  border-color: var(--brand-green);
  background: var(--brand-green-light);
}

.method-option p { margin: 0.2rem 0 0; font-size: 0.9rem; }

.payment-choice > span { display: block; margin-bottom: var(--space-2); font-weight: 700; }

/* Payment logos */
.payment-logo-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.payment-logo-strip img {
  height: 34px;
  width: 86px;
  border-radius: var(--radius-sm);
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  padding: 0.18rem 0.35rem;
  box-shadow: var(--shadow-xs);
  object-fit: contain;
}

.payment-icon, .success-mark { width: 80px; height: 80px; }

/* ----------------------------------------------------------
   13. BADGES, PILLS, STATUS INDICATORS
   ---------------------------------------------------------- */
.category-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.8rem;
  border-radius: var(--radius-full);
  background: var(--brand-gold-light);
  color: var(--brand-gold-deep);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  border: 1px solid rgba(230, 168, 23, 0.25);
}

.campaign-image .category-pill {
  position: absolute;
  left: var(--space-3);
  top: var(--space-3);
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  padding: 0.35rem 0.78rem;
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
}

.status-approved, .status-active {
  background: var(--color-success-bg);
  color: var(--color-success-tx);
  border: 1px solid var(--color-success-bd);
}
.status-card {
  background: var(--color-info-bg);
  color: var(--color-info-tx);
  border: 1px solid var(--color-info-bd);
}
.status-momo {
  background: var(--brand-gold-light);
  color: var(--brand-green-deep);
  border: 1px solid rgba(230, 168, 23, 0.32);
}
.status-payout {
  background: var(--color-danger-bg);
  color: var(--color-danger-tx);
  border: 1px solid var(--color-danger-bd);
}
.status-pending {
  background: var(--color-warning-bg);
  color: var(--color-warning-tx);
  border: 1px solid var(--color-warning-bd);
}
.status-initialized {
  background: var(--color-warning-bg);
  color: var(--color-warning-tx);
  border: 1px solid var(--color-warning-bd);
}
.status-failed,
.status-abandoned {
  background: var(--color-danger-bg);
  color: var(--color-danger-tx);
  border: 1px solid var(--color-danger-bd);
}
.status-dormant {
  background: var(--color-warning-bg);
  color: var(--color-warning-tx);
  border: 1px solid var(--color-warning-bd);
}
.status-draft {
  background: rgba(139, 111, 34, 0.14);
  color: #8b6f22;
  border: 1px solid rgba(139, 111, 34, 0.28);
}
.status-rejected, .status-disabled {
  background: var(--color-danger-bg);
  color: var(--color-danger-tx);
  border: 1px solid var(--color-danger-bd);
}
.status-closed {
  background: var(--color-info-bg);
  color: var(--color-info-tx);
  border: 1px solid var(--color-info-bd);
}

.status-inline-on {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.3rem 0.65rem;
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  text-align: center;
  line-height: 1.2;
  background: var(--color-success-bg);
  color: var(--color-success-tx);
}
.status-inline-off {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.3rem 0.65rem;
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  text-align: center;
  line-height: 1.2;
  background: var(--color-danger-bg);
  color: var(--color-danger-tx);
}

.account-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem 0.78rem;
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
}
.account-pill.account-admin {
  background: var(--color-info-bg);
  color: var(--color-info-tx);
  border: 1px solid var(--color-info-bd);
}
.account-pill.account-accountant {
  background: rgba(20, 106, 92, 0.12);
  color: #0f5d51;
  border: 1px solid rgba(20, 106, 92, 0.22);
}
.account-pill.account-regular {
  background: var(--surface-2);
  color: var(--text-muted);
}
.account-pill.account-super {
  background: var(--color-warning-bg);
  color: var(--color-warning-tx);
  border: 1px solid var(--color-warning-bd);
}

.verify-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.35rem 0.72rem;
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
}
.verify-badge-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.05rem; height: 1.05rem;
  border-radius: 50%;
  background: currentColor;
  color: #fff;
  font-size: 0;
}
.verify-badge-yes .verify-badge-icon::before { content: '✓'; font-size: 0.72rem; }
.verify-badge-no .verify-badge-icon::before  { content: '!'; font-size: 0.72rem; }
.verify-badge-yes { background: var(--color-success-bg); color: var(--color-success-tx); }
.verify-badge-no  { background: var(--color-warning-bg); color: var(--color-warning-tx); }

/* ----------------------------------------------------------
   14. ALERT CARDS
   ---------------------------------------------------------- */
.alert-card {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-lg);
  border: 1.5px solid transparent;
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1.55;
}
.alert-success {
  background: var(--color-success-bg);
  border-color: var(--color-success-bd);
  color: var(--color-success-tx);
}
.alert-warning {
  background: var(--color-warning-bg);
  border-color: var(--color-warning-bd);
  color: var(--color-warning-tx);
}
.alert-danger {
  background: var(--color-danger-bg);
  border-color: var(--color-danger-bd);
  color: var(--color-danger-tx);
}
.alert-info {
  background: var(--color-info-bg);
  border-color: var(--color-info-bd);
  color: var(--color-info-tx);
}

/* ----------------------------------------------------------
   15. TOAST NOTIFICATIONS
   ---------------------------------------------------------- */
.toast-stack {
  position: fixed;
  top: calc(var(--nav-height) + 1rem);
  right: var(--space-6);
  z-index: 200;
  display: grid;
  gap: var(--space-3);
  width: min(420px, calc(100% - 2rem));
  pointer-events: none;
}

.toast-card {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-lg);
  border: 1.5px solid transparent;
  box-shadow: var(--shadow-lg);
  background: var(--surface-1);
  font-weight: 600;
  font-size: 0.92rem;
  line-height: 1.55;
  pointer-events: auto;
  animation: toast-in var(--dur-base) var(--ease-out);
  position: relative;
  overflow: hidden;
}

/* progress bar underlay */
.toast-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  height: 3px;
  background: currentColor;
  opacity: 0.35;
  width: 100%;
  animation: toast-progress linear forwards;
  animation-duration: var(--toast-duration, 15s);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

@keyframes toast-progress { to { width: 0; } }

.toast-success {
  background: rgba(238, 251, 242, 0.98);
  border-color: var(--color-success-bd);
  color: var(--color-success-tx);
}
[data-theme="dark"] .toast-success {
  background: rgba(17, 48, 28, 0.97);
}
.toast-error {
  background: rgba(255, 244, 244, 0.98);
  border-color: var(--color-danger-bd);
  color: var(--color-danger-tx);
}
[data-theme="dark"] .toast-error {
  background: rgba(45, 12, 12, 0.97);
}
.toast-warning {
  background: rgba(255, 249, 234, 0.98);
  border-color: var(--color-warning-bd);
  color: var(--color-warning-tx);
}
.toast-info {
  background: rgba(237, 244, 255, 0.98);
  border-color: var(--color-info-bd);
  color: var(--color-info-tx);
}

@keyframes toast-in {
  from { opacity: 0; transform: translateX(16px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ----------------------------------------------------------
   16. TOGGLE BUTTON (2FA etc.)
   ---------------------------------------------------------- */
.toggle-button {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 148px;
  padding: 0.6rem 0.9rem;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-full);
  color: var(--text-primary);
  background: var(--surface-1);
  cursor: pointer;
  font-weight: 700;
  font-size: 0.9rem;
  transition: border-color var(--dur-fast) var(--ease);
}

.toggle-button span {
  position: relative;
  width: 46px; height: 25px;
  border-radius: var(--radius-full);
  background: rgba(185, 28, 28, 0.18);
  transition: background var(--dur-base) var(--ease);
  flex-shrink: 0;
}

.toggle-button span::after {
  content: '';
  position: absolute;
  top: 4px; left: 4px;
  width: 17px; height: 17px;
  border-radius: 50%;
  background: #fff;
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-base) var(--ease-spring);
}

.toggle-button.is-on span { background: rgba(26, 138, 74, 0.7); }
.toggle-button.is-on span::after { transform: translateX(21px); }

/* ==========================================================
   Part 4/5: Cards - Modals - Campaign - Progress - Dashboard - Admin
   ========================================================== */

/* 17. BASE CARD */
.card, .admin-side-panel {
  background: var(--surface-1);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  padding: var(--space-6);
  transition: box-shadow var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.card-elevated { box-shadow: var(--shadow-lg); }
.card-elevated:hover { transform: translateY(-3px); box-shadow: var(--shadow-xl); }
.card-accent { border-left: 3px solid var(--brand-gold); background: linear-gradient(135deg, var(--brand-gold-light) 0%, var(--surface-1) 60%); }
.accent-card { background: radial-gradient(ellipse at top right, rgba(230,168,23,0.12), transparent 55%), linear-gradient(160deg, var(--brand-green-light) 0%, var(--surface-1) 60%); }
.empty-state { text-align: center; padding: 3rem 1.5rem; background: var(--surface-1); border: 1px solid var(--border-color); border-radius: var(--radius-xl); box-shadow: var(--shadow-sm); }

/* 18. CAMPAIGN CARDS */
.campaign-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-5); }
.campaign-card { background: var(--surface-1); border: 1px solid var(--border-color); border-radius: var(--radius-xl); box-shadow: var(--shadow-sm); overflow: hidden; transition: transform var(--dur-base) var(--ease), box-shadow var(--dur-base) var(--ease); }
.campaign-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.campaign-image { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--surface-2); }
.campaign-image img, .summary-card img, .detail-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease); }
.campaign-card:hover .campaign-image img { transform: scale(1.04); }
.campaign-body { padding: var(--space-5); display: grid; gap: var(--space-3); }
.campaign-body h3 { font-family: var(--font-display); font-size: 1.15rem; font-weight: 700; color: var(--text-primary); line-height: 1.3; }
.campaign-body p { font-size: 0.9rem; line-height: 1.65; color: var(--text-muted); }
.campaign-meta { display: flex; justify-content: space-between; gap: var(--space-3); font-size: 0.85rem; color: var(--text-muted); font-weight: 600; }
.campaign-detail-grid { gap: var(--space-8); }
.detail-image { border-radius: var(--radius-xl); overflow: hidden; }
.campaign-gallery { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: var(--space-3); }
.campaign-gallery img { width:100%; height:auto; border-radius: var(--radius-lg); aspect-ratio:4/3; object-fit:cover; }
.campaign-gallery img:first-child { grid-column: 1/-1; }
.summary-card img { border-radius: var(--radius-lg); aspect-ratio: 4/3; }
.summary-gallery, .admin-campaign-gallery { margin-bottom: var(--space-4); }
.dashboard-image { width:100%; border-radius: var(--radius-xl); aspect-ratio:16/10; object-fit:cover; }

/* Campaign status panels */
.campaign-status-panel { display: grid; grid-template-columns: auto 1fr; gap: var(--space-4); align-items: center; padding: var(--space-4); border-radius: var(--radius-lg); border: 1px solid var(--border-color); margin-top: var(--space-4); }
.campaign-status-icon { display: grid; place-items: center; width: 48px; height: 48px; border-radius: var(--radius-md); font-size: 1.3rem; background: var(--surface-1); box-shadow: var(--shadow-sm); }
.campaign-status-panel span { display: inline-flex; margin-bottom: 0.2rem; font-size: 0.74rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; }
.campaign-status-panel strong { display: block; font-family: var(--font-display); font-size: 1rem; }
.campaign-status-panel p { margin: 0.2rem 0 0; font-size: 0.9rem; }
.campaign-status-approved { border-color: var(--color-success-bd); background: var(--color-success-bg); }
.campaign-status-pending { border-color: var(--color-warning-bd); background: var(--color-warning-bg); }
.campaign-status-rejected { border-color: var(--color-danger-bd); background: var(--color-danger-bg); }
.campaign-status-closed { border-color: var(--color-info-bd); background: var(--color-info-bg); }

/* Dashboard campaign hub */
.campaign-hub-layout { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.65fr); gap: var(--space-5); align-items: start; }
.campaign-hub-main, .campaign-hub-side { display: grid; gap: var(--space-5); }
.campaign-hub-gallery { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-3); }
.campaign-hub-gallery img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--radius-lg); background: var(--surface-2); }
.campaign-hub-gallery img:first-child { grid-column: 1 / -1; aspect-ratio: 16 / 9; }
.campaign-carousel { position: relative; overflow: hidden; border-radius: var(--radius-lg); background: var(--surface-2); }
.campaign-carousel-track { position: relative; aspect-ratio: 16 / 9; }
.campaign-carousel-slide { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 0.45s var(--ease); }
.campaign-carousel-slide.is-active { opacity: 1; }
.campaign-carousel-video-slide { display: grid; place-items: center; background: #000; }
.campaign-carousel-video-slide video { width: 100%; height: 100%; min-height: 0; object-fit: contain; background: #000; }
.campaign-video-player { display: grid; grid-template-rows: minmax(0, 1fr) auto; width: 100%; height: 100%; background: #000; }
.campaign-video-controls { z-index: 4; display: grid; grid-template-columns: 46px minmax(0, 1fr) auto; gap: var(--space-3); align-items: center; width: 100%; padding: 10px 12px; border-top: 2px solid var(--brand-gold); background: #101010; color: #fff; opacity: 1; transform: none; box-shadow: 0 -8px 24px rgba(0,0,0,0.38); }
.campaign-video-toggle { display: grid; place-items: center; width: 38px; height: 38px; border: 2px solid rgba(255,255,255,0.75); border-radius: var(--radius-full); background: var(--brand-gold); color: #111; line-height: 1; cursor: pointer; font-weight: 900; }
.campaign-video-toggle:hover { background: #ffd56a; }
.campaign-video-seek { width: 100%; min-width: 0; height: 22px; accent-color: var(--brand-gold); cursor: pointer; }
.campaign-video-time { min-width: 3.25rem; font-size: 0.82rem; font-weight: 800; text-align: right; font-variant-numeric: tabular-nums; }
.campaign-carousel-btn { position: absolute; top: 50%; z-index: 2; transform: translateY(-50%); display: grid; place-items: center; width: 42px; height: 42px; border-radius: var(--radius-full); border: 1px solid rgba(255,255,255,0.38); background: rgba(0,0,0,0.42); color: #fff; font-size: 1.8rem; cursor: pointer; }
.campaign-carousel-btn:hover { background: rgba(0,0,0,0.62); }
.carousel-prev { left: var(--space-3); }
.carousel-next { right: var(--space-3); }
.campaign-carousel-dots { position: absolute; left: 0; right: 0; bottom: var(--space-3); z-index: 2; display: flex; justify-content: center; gap: var(--space-2); }
.campaign-carousel-dots button { width: 10px; height: 10px; padding: 0; border-radius: var(--radius-full); border: 1px solid rgba(255,255,255,0.7); background: rgba(255,255,255,0.32); cursor: pointer; }
.campaign-carousel-dots button.is-active { width: 24px; background: #fff; }
.campaign-carousel.is-video-active .campaign-carousel-dots { top: var(--space-3); bottom: auto; }
.public-campaign-carousel { touch-action: pan-y; }
.public-campaign-carousel .campaign-carousel-track { display: flex; transition: transform 0.42s var(--ease); will-change: transform; }
.public-campaign-carousel .campaign-carousel-slide { position: relative; inset: auto; flex: 0 0 100%; opacity: 1; user-select: none; }
.public-campaign-carousel .campaign-carousel-video-slide,
.public-campaign-carousel .campaign-carousel-video-slide video { user-select: auto; }
.public-campaign-carousel:focus-visible { outline: 3px solid rgba(35, 160, 93, 0.45); outline-offset: 3px; }
.campaign-video-panel video { display: block; width: 100%; max-height: 420px; border-radius: var(--radius-lg); background: #000; }
.campaign-story-panel { display: grid; gap: var(--space-3); }
.campaign-story-panel h2, .payment-focus-card h2, .share-card h2, .organizer-card h2 { margin: 0; font-family: var(--font-display); }
.campaign-story-panel p { margin: 0; line-height: 1.8; color: var(--text-muted); white-space: normal; }
.campaign-detail-cards { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-3); }
.campaign-detail-cards div, .payment-metrics div { display: grid; gap: var(--space-1); padding: var(--space-3) var(--space-4); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); background: var(--surface-2); }
.campaign-detail-cards span, .payment-metrics span { color: var(--text-muted); font-size: 0.78rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.05em; }
.campaign-detail-cards strong, .payment-metrics strong { overflow-wrap: anywhere; }
.payment-focus-card { border-color: rgba(46, 213, 115, 0.34); }
.payment-total { color: var(--brand-green); font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); font-weight: 900; line-height: 1; }
.payment-metrics { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-3); }
.payment-metrics-split { grid-template-columns: minmax(0, 7fr) minmax(0, 5fr); }
.share-link-box { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: var(--space-2); align-items: center; }
.share-link-box input { min-width: 0; }
.share-action-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-2); margin-top: var(--space-3); }
.share-action-grid .button { justify-content: center; }
.dashboard-copy-action { color: var(--brand-green-deep); background: var(--brand-gold-light); border-color: rgba(230, 168, 23, 0.32); }
.organizer-card { display: grid; gap: var(--space-4); }
.organizer-card.public-organizer-card { display: grid; align-items: initial; gap: var(--space-4); margin-bottom: 0; padding: var(--space-6); background: var(--surface-1); border-radius: var(--radius-xl); }
.organizer-info-list { display: grid; gap: var(--space-3); }
.organizer-info-list div { display: grid; grid-template-columns: minmax(82px, 0.42fr) minmax(0, 1fr); gap: var(--space-3); align-items: baseline; padding-bottom: var(--space-3); border-bottom: 1px solid var(--border-subtle); }
.organizer-info-list div:last-child { border-bottom: none; padding-bottom: 0; }
.organizer-info-list span { color: var(--text-muted); font-weight: 700; }
.organizer-info-list strong { min-width: 0; overflow-wrap: anywhere; color: var(--text-primary); }
.public-organizer-card .organizer-info-list div { grid-template-columns: 82px minmax(0, 1fr); }
.public-organizer-card h2 { overflow-wrap: anywhere; }
.organizer-bio { margin: 0; padding-top: var(--space-3); border-top: 1px solid var(--border-subtle); color: var(--text-muted); line-height: 1.6; }
.public-campaign-page { padding-top: var(--space-8); }
.campaign-public-hero { display: flex; justify-content: space-between; align-items: flex-end; gap: var(--space-5); margin-bottom: var(--space-6); }
.campaign-public-hero h1 { margin: var(--space-3) 0 var(--space-2); font-family: var(--font-display); font-size: clamp(2.2rem, 5vw, 4.5rem); line-height: 1.02; max-width: 980px; }
.campaign-public-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; justify-content: flex-end; }
.public-payment-card { position: static; }

/* Progress */
.progress-wrap { display: grid; gap: var(--space-2); margin: var(--space-3) 0 var(--space-4); }
.progress-bar { height: 10px; border-radius: var(--radius-full); background: var(--surface-2); overflow: hidden; }
.progress-bar span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--brand-gold) 0%, var(--brand-green) 100%); transition: width 0.8s var(--ease-out); }
.progress-text { display: flex; justify-content: space-between; gap: var(--space-3); font-size: 0.88rem; }
.progress-text strong { font-family: var(--font-display); font-weight: 700; color: var(--text-primary); }
.donation-progress-card { display: grid; gap: var(--space-3); }
.donation-progress-meta { margin: 0; font-weight: 700; color: var(--brand-green); }
.summary-lines { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: var(--space-3); }
.summary-lines span { color: var(--text-muted); }
.summary-lines strong { font-family: var(--font-display); }

/* 19. MODALS */
.verification-modal, .confirmation-modal {
  position: fixed; inset: 0; z-index: 150;
  display: grid; place-items: center;
  padding: clamp(0.75rem, 2vh, var(--space-4));
  overflow-y: auto;
  background: rgba(10,25,15,0.72);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.confirmation-modal { display: none; z-index: 160; }
.confirmation-modal.is-open { display: grid; }
.modal-toggle { position: fixed; opacity: 0; pointer-events: none; }
.modal-toggle:checked + .confirmation-modal { display: grid; }
.verification-modal-card, .confirmation-modal-card {
  position: relative; z-index: 1;
  background: var(--surface-1); border: 1px solid var(--border-color);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-xl);
  max-height: calc(100vh - 1.5rem);
  overflow-y: auto;
  padding: clamp(var(--space-4), 3vh, var(--space-6));
  animation: modal-in var(--dur-slow) var(--ease-spring);
}
.verification-modal-card { width: min(480px,100%); }
.confirmation-modal-card { width: min(520px,100%); }
@keyframes modal-in { from { opacity:0; transform: translateY(24px) scale(0.97); } to { opacity:1; transform: translateY(0) scale(1); } }
.verification-modal-card h2, .confirmation-modal-card h2 { font-family: var(--font-display); font-size: clamp(1.25rem,2.5vw,1.8rem); margin-bottom: var(--space-3); }
.verification-modal-actions, .confirmation-modal-actions { display: grid; gap: var(--space-2); margin-top: var(--space-4); }
.verification-modal-actions .button, .confirmation-modal-actions .button { width: 100%; }
.confirmation-modal-backdrop { position:absolute; inset:0; border:0; background:transparent; cursor:pointer; }

/* 20. DASHBOARD & PROFILE */
.dashboard-stats-group { display: grid; gap: var(--space-3); margin-top: var(--space-5); }
.dashboard-status-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-4); margin-top: var(--space-2); }
.dashboard-summary-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: center;
  min-height: 112px;
  padding: var(--space-5);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  background: var(--surface-1);
  box-shadow: var(--shadow-sm);
}
.summary-card-icon {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 900;
}
.dashboard-summary-card strong {
  display: block;
  color: var(--text-primary);
  font-family: var(--font-display);
  font-size: 2rem;
  line-height: 1;
}
.dashboard-summary-card span:not(.summary-card-icon) {
  display: block;
  margin-top: var(--space-2);
  color: var(--text-muted);
  font-weight: 700;
  line-height: 1.25;
}
.summary-active .summary-card-icon { background: var(--brand-green); }
.summary-draft .summary-card-icon { background: #8b6f22; }
.summary-pending .summary-card-icon { background: #b7791f; }
.summary-rejected .summary-card-icon { background: #b91c1c; }
.dashboard-insight-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.85fr); gap: var(--space-5); align-items: stretch; }
.dashboard-panel {
  display: grid;
  align-content: start;
  gap: var(--space-4);
  min-width: 0;
  padding: var(--space-5);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  background: var(--surface-1);
  box-shadow: var(--shadow-sm);
}
.dashboard-panel-head, .dashboard-table-head { display: flex; justify-content: space-between; gap: var(--space-4); align-items: flex-end; flex-wrap: wrap; }
.dashboard-panel-head h2, .dashboard-table-head h2 { margin: 0; font-family: var(--font-display); font-size: clamp(1.3rem, 2vw, 1.85rem); }
.dashboard-chart-wrap { position: relative; height: 330px; min-height: 330px; width: 100%; }
.dashboard-empty-state { box-shadow: none; padding: var(--space-7); }
.active-campaign-list { display: grid; gap: var(--space-4); max-height: 420px; overflow: auto; padding-right: var(--space-1); }
.active-campaign-progress { display: grid; gap: var(--space-3); padding: var(--space-4); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); background: var(--surface-2); }
.active-campaign-row { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-4); }
.active-campaign-row strong { display: block; color: var(--text-primary); line-height: 1.25; }
.active-campaign-row span { display: block; margin-top: var(--space-1); color: var(--text-muted); font-size: 0.84rem; }
.active-campaign-row b { color: var(--brand-green); font-family: var(--font-display); white-space: nowrap; }
.campaign-filter-form { display: flex; align-items: center; gap: var(--space-2); }
.campaign-filter-form label { color: var(--text-muted); font-size: 0.84rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.05em; }
.campaign-filter-form select { min-width: 150px; padding: 0.7rem 2.3rem 0.7rem 0.9rem; }
.campaign-management-table table { min-width: 860px; }
.campaign-table-card-head { padding: var(--space-5) var(--space-5) var(--space-4); border-bottom: 1px solid var(--border-subtle); }
.campaign-management-table.card { padding: 0; }
.campaign-row-actions { display: flex; align-items: center; gap: var(--space-2); }
.campaign-management-table th:nth-child(n+2),
.campaign-management-table td:nth-child(n+2) { text-align: center; vertical-align: middle; }
.campaign-management-table td:nth-child(n+2) .status-pill,
.campaign-management-table .campaign-row-actions { justify-content: center; }
.dashboard-view-action, .dashboard-edit-action { text-decoration: none; }
.dashboard-view-action { color: var(--brand-green-deep); background: var(--brand-gold-light); border-color: rgba(230, 168, 23, 0.32); }
.dashboard-edit-action { color: var(--color-info-tx); background: var(--color-info-bg); border-color: var(--color-info-bd); }
.dashboard-hero { display: flex; justify-content: space-between; gap: var(--space-4); align-items: center; flex-wrap: wrap; }
.profile-summary { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: var(--space-3); }
.profile-summary div { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-1); padding: var(--space-4); border-radius: var(--radius-lg); background: var(--surface-2); border: 1px solid var(--border-subtle); }
.otp-status-row { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: var(--space-3); }
.otp-status-card { padding: var(--space-4); border-radius: var(--radius-lg); border: 1px solid var(--border-color); background: var(--surface-1); }
.otp-status-card strong { display: block; margin-bottom: var(--space-2); font-family: var(--font-display); font-size: 1.5rem; color: var(--brand-green); }
.otp-status-card span { color: var(--text-muted); font-weight: 600; font-size: 0.88rem; }
.verification-modal .otp-status-row {
  grid-template-columns: 1fr;
  gap: var(--space-2);
}
.verification-modal .otp-status-card {
  padding: var(--space-3);
}
.verification-modal .otp-status-card strong {
  margin-bottom: var(--space-1);
  font-size: 1.2rem;
}
.otp-code-label {
  display: grid;
  gap: var(--space-2);
  margin-bottom: 0;
}
.otp-code-input {
  display: block !important;
  width: 100% !important;
  min-height: 52px;
  padding: 0.75rem 1rem !important;
  background: var(--surface-1) !important;
  color: var(--text-primary) !important;
  border: 2px solid var(--brand-green) !important;
  border-radius: var(--radius-lg) !important;
  font-size: 1.2rem !important;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-align: center;
  opacity: 1 !important;
  visibility: visible !important;
}
.otp-code-input::placeholder {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0;
  text-align: center;
}
.login-lockout-row { grid-template-columns: 1fr; margin: var(--space-2) 0 var(--space-3); }
.two-factor-card { display: flex; justify-content: space-between; gap: var(--space-4); align-items: center; padding: var(--space-4); border-radius: var(--radius-lg); border: 1px solid var(--border-color); background: linear-gradient(135deg, var(--brand-green-light), var(--brand-gold-light)); }
.two-factor-card h3 { margin-bottom: var(--space-2); font-family: var(--font-display); }
.two-factor-card p { margin: 0 0 var(--space-2); font-size: 0.9rem; }
.policy-select-card { display: grid; gap: var(--space-2); flex: 0 0 min(260px,100%); padding: var(--space-4); border: 1px solid var(--border-color); border-radius: var(--radius-lg); background: var(--surface-1); }
.policy-select-card span { color: var(--text-muted); font-size: 0.8rem; font-weight: 700; }

/* 21. SETTINGS HUB */
.settings-hub, .settings-summary-grid { display: grid; gap: var(--space-4); }
.settings-summary-grid { grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); }
.settings-summary-card { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-4); }
.settings-summary-card h2 { margin: 0.1rem 0 var(--space-2); font-family: var(--font-display); font-size: 1.15rem; }
.settings-summary-card p { margin: 0; color: var(--text-muted); font-size: 0.9rem; }
.settings-card { display: grid; gap: var(--space-4); }
.settings-card-head { display: grid; gap: var(--space-2); align-content: start; }
.settings-card h2 { font-size: clamp(1.1rem,1.5vw,1.4rem); line-height: 1.2; }
.settings-card .button { margin-top: var(--space-2); white-space: nowrap; }
.settings-card .settings-eyebrow { margin-bottom: 0; padding: 0.3rem 0.65rem; font-size: 0.7rem; }
.settings-menu-card { display: grid; gap: var(--space-4); }
.settings-menu-grid { align-items: stretch; }
.settings-menu-item { min-height: 128px; padding: var(--space-4); border: 1.5px solid var(--border-color); border-radius: var(--radius-xl); color: inherit; text-decoration: none; background: var(--surface-1); transition: transform var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), box-shadow var(--dur-base) var(--ease); display: grid; gap: var(--space-2); align-content: start; }
.settings-menu-item:hover, .settings-menu-item.is-active { transform: translateY(-3px); border-color: var(--brand-green); background: var(--brand-green-light); box-shadow: var(--shadow-md); }
.settings-menu-icon { display: grid; place-items: center; width: 46px; height: 46px; border-radius: var(--radius-md); font-weight: 900; color: var(--brand-green-deep); background: var(--brand-gold-light); box-shadow: var(--shadow-sm); }
.settings-menu-item strong { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--text-primary); }
.settings-menu-item small { color: var(--text-muted); line-height: 1.4; }
.settings-panel, .form-card.settings-panel { display: none; }
.settings-panel.is-open, .form-card.settings-panel.is-open { display: grid; }
.settings-panel-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; align-items: center; }

/* 22. FUNDRAISER & ADMIN SIDEBARS */
.fundraiser-sidebar { position: sticky; top: calc(var(--nav-height) + 1.5rem); display: grid; gap: var(--space-4); padding: var(--space-5); overflow: hidden; align-self: start; background: var(--surface-1); border: 1px solid var(--border-color); border-radius: var(--radius-xl); box-shadow: var(--shadow-md); }
.fundraiser-sidebar-head h2 { margin: 0.2rem 0; font-family: var(--font-display); font-size: clamp(1.1rem,2vw,1.45rem); line-height: 1.15; }
.fundraiser-sidebar-head p { margin: 0; color: var(--text-muted); font-size: 0.88rem; overflow-wrap: anywhere; }
.fundraiser-sidebar-nav, .admin-sidebar-nav { display: grid; gap: var(--space-2); }
.fundraiser-sidebar-badges, .fundraiser-welcome-head, .table-action-row { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
.fundraiser-sidebar-foot, .admin-sidebar-foot { margin-top: auto; }
.fundraiser-nav-link, .admin-nav-link { display: grid; grid-template-columns: auto 1fr; gap: var(--space-3); align-items: center; padding: 0.82rem var(--space-4); border-radius: var(--radius-lg); color: var(--text-muted); font-weight: 600; transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease); }
.fundraiser-nav-link:hover, .fundraiser-nav-link.active, .admin-nav-link:hover, .admin-nav-link.active { background: var(--brand-green-light); color: var(--brand-green-deep); transform: translateX(2px); font-weight: 700; }
.fundraiser-nav-icon, .admin-nav-icon { display: inline-flex; width: 34px; height: 34px; align-items: center; justify-content: center; border-radius: var(--radius-sm); background: var(--brand-gold-light); font-size: 0.72rem; font-weight: 800; }
.fundraiser-welcome-card, .fundraiser-main { display: grid; gap: var(--space-6); }
.fundraiser-main { min-width: 0; align-content: start; }
.admin-sidebar { position: sticky; top: calc(var(--nav-height) + 1.5rem); display: grid; gap: var(--space-5); padding: var(--space-5); background: var(--surface-1); border: 1px solid var(--border-color); border-radius: var(--radius-xl); box-shadow: var(--shadow-md); }
.admin-sidebar-head h2 { margin: 0.2rem 0; font-family: var(--font-display); font-size: 1.6rem; }
.admin-sidebar-head p { margin: 0; color: var(--text-muted); }
.admin-main { display: grid; gap: var(--space-6); }

/* 23. TABLES */
.dashboard-table { overflow-x: auto; border-radius: var(--radius-xl); border: 1px solid var(--border-color); background: var(--surface-1); box-shadow: var(--shadow-sm); }
.dashboard-table table { width: 100%; border-collapse: collapse; min-width: 600px; }
.dashboard-table th, .dashboard-table td { padding: var(--space-4) var(--space-5); text-align: left; border-bottom: 1px solid var(--border-subtle); vertical-align: top; }
.dashboard-table th { font-family: var(--font-display); font-size: 0.84rem; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; background: var(--surface-2); }
.dashboard-table tr:last-child td { border-bottom: none; }
.dashboard-table tr:hover td { background: var(--surface-2); transition: background var(--dur-fast) var(--ease); }
.dashboard-table td span { display: block; color: var(--text-muted); margin-top: 0.2rem; font-size: 0.88rem; }
.wallet-history-table td:last-child {
  text-align: right;
  font-family: var(--font-display);
  font-weight: 800;
  white-space: nowrap;
}
.wallet-amount-in { color: var(--brand-green); }
.wallet-amount-out { color: var(--color-danger-tx); }
.wallet-filter-bar {
  display: flex;
  align-items: end;
  gap: var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  background: var(--surface-1);
  box-shadow: var(--shadow-sm);
}
.wallet-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: var(--space-2);
  flex: 1;
  min-width: 0;
}
.wallet-filter-bar label {
  margin-bottom: 0;
  font-size: 0.78rem;
}
.wallet-filter-bar label span {
  margin-bottom: 0.3rem;
}
.wallet-filter-bar input,
.wallet-filter-bar select {
  min-height: 38px;
  padding: 0.48rem 0.72rem;
  border-radius: var(--radius-md);
  font-size: 0.84rem;
}
.wallet-filter-bar select {
  padding-right: 2rem;
  background-position: right 0.75rem center;
}
.wallet-filter-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.wallet-export-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.wallet-type-indicator {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  margin: 0 var(--space-2) 0 0 !important;
  border-radius: var(--radius-full);
  color: #fff !important;
  font-size: 0.9rem !important;
  font-weight: 900;
  line-height: 1;
  vertical-align: middle;
}
.wallet-type-in {
  background: var(--brand-green);
}
.wallet-type-out {
  background: var(--color-danger-tx);
}
.transaction-decline-reason {
  display: block;
  margin-top: var(--space-1);
  max-width: 220px;
  color: var(--color-danger-tx);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.35;
}
.admin-users-table table { min-width: 860px; }
.table-action-cell { width: 1%; white-space: nowrap; }
.admin-inline-actions { display: flex; justify-content: flex-start; gap: var(--space-2); }
.icon-action { width: 40px; height: 40px; border: 1.5px solid var(--border-color); border-radius: var(--radius-md); background: var(--surface-1); font-size: 1rem; font-weight: 700; cursor: pointer; transition: transform var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease); display: inline-flex; align-items: center; justify-content: center; }
.view-action, .wide-action { width: auto; min-width: 40px; padding: 0 var(--space-3); }
.view-action { color: var(--brand-green-deep); background: var(--brand-gold-light); text-decoration: none; }
.icon-action:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.success-action { color: var(--color-success-tx); background: var(--color-success-bg); border-color: var(--color-success-bd); }
.pending-action { color: var(--color-warning-tx); background: var(--color-warning-bg); border-color: var(--color-warning-bd); }
.reject-action { color: var(--color-danger-tx); background: var(--color-danger-bg); border-color: var(--color-danger-bd); }
.campaign-action-icons { display: flex; gap: var(--space-2); margin-bottom: var(--space-3); }
.inline-action-form { margin: 0; }
.pagination-bar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-3); margin-top: var(--space-4); }
.pagination-pages { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.pagination-link { min-width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; padding: 0 var(--space-3); border-radius: var(--radius-md); border: 1.5px solid var(--border-color); background: var(--surface-1); color: var(--text-primary); font-weight: 700; text-decoration: none; transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease); }
.pagination-link.active { background: var(--brand-green); border-color: var(--brand-green); color: #fff; box-shadow: 0 4px 12px rgba(26,138,74,0.3); }
.pagination-link:hover:not(.active) { background: var(--surface-2); border-color: var(--brand-green); }
.detail-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(170px,1fr)); gap: var(--space-3); }
.detail-grid > div { display: grid; gap: var(--space-1); padding: var(--space-3) var(--space-4); border-radius: var(--radius-lg); background: var(--surface-2); border: 1px solid var(--border-subtle); }
.detail-label { font-size: 0.78rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--text-muted); }

/* 24. ADMIN COMPONENTS */
.admin-links-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: var(--space-4); margin-top: var(--space-8); }
.admin-admins-layout { display: grid; grid-template-columns: minmax(0,1.25fr) minmax(280px,0.75fr); gap: var(--space-6); align-items: start; margin-top: var(--space-6); }
.admin-page-tabs, .messaging-subnav, .admin-subnav { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-6); padding: var(--space-4) var(--space-5); background: var(--surface-1); border: 1px solid var(--border-color); border-radius: var(--radius-xl); box-shadow: var(--shadow-xs); }
.admin-page-tab, .messaging-subnav-link, .admin-subnav-link { display: inline-flex; align-items: center; justify-content: center; padding: 0.62rem var(--space-4); border-radius: var(--radius-md); border: 1.5px solid var(--border-color); background: var(--surface-2); color: var(--text-muted); font-weight: 600; text-decoration: none; transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease); font-size: 0.9rem; }
.admin-page-tab:hover, .admin-page-tab.active, .messaging-subnav-link:hover, .messaging-subnav-link.active, .admin-subnav-link:hover, .admin-subnav-link.active { background: var(--brand-green-light); border-color: var(--brand-green); color: var(--brand-green-deep); font-weight: 700; }
.admin-subnav-link.is-disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }
.admin-mini-stats { margin-top: var(--space-6); }
.admin-campaign-stack, .admin-side-stack { display: grid; gap: var(--space-4); }
.admin-side-stack { align-content: start; }
.admin-campaign-head { display: flex; justify-content: space-between; gap: var(--space-4); align-items: flex-start; flex-wrap: wrap; }
.admin-link-card { min-height: 180px; display: flex; flex-direction: column; justify-content: space-between; }
.admin-link-card h2, .admin-campaign-card h2, .admin-side-panel h2 { margin-top: 0; font-family: var(--font-display); }
.admin-section-head h3 { margin: 0.3rem 0 0; font-family: var(--font-display); font-size: 1.1rem; }
.admin-role-panel { align-self: start; }
.admin-role-panel .role-grid { grid-template-columns: repeat(2,minmax(0,1fr)); gap: var(--space-3); }
.admin-role-option { padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); border: 1px solid var(--border-color); background: var(--surface-2); }
.admin-admins-form { gap: var(--space-4); }
.admin-admins-table-card { margin-top: var(--space-6); }
.admin-filter-card { padding: var(--space-5); }
.admin-table-filter { display: grid; grid-template-columns: minmax(0,2fr) minmax(160px,0.8fr) auto; gap: var(--space-3); align-items: end; }
.admin-filter-actions { display: flex; gap: var(--space-3); align-items: center; }
.filter-row, .action-row { display: grid; gap: var(--space-3); grid-auto-flow: column; justify-content: start; margin: var(--space-4) 0 var(--space-6); }
.role-grid { display: grid; gap: var(--space-3); margin: var(--space-2) 0 var(--space-4); }
.messaging-page-stack { display: grid; gap: var(--space-6); margin-top: var(--space-6); }
.messaging-category-grid { display: grid; gap: var(--space-3); margin: var(--space-2) 0 var(--space-3); }
.messaging-category-item { padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); border: 1px solid var(--border-color); background: var(--surface-2); }
.auth-type-grid { display: grid; gap: var(--space-3); }
.auth-aside, .dashboard-hero { min-height: 100%; }
.log-pre { margin: var(--space-3) 0 0; padding: var(--space-4); border-radius: var(--radius-lg); background: var(--surface-2); border: 1px solid var(--border-subtle); overflow-x: auto; white-space: pre-wrap; word-break: break-word; font-size: 0.85rem; color: var(--text-muted); }
.admin-note-details summary { cursor: pointer; font-weight: 700; color: var(--brand-green); }
.note-form { display: grid; gap: var(--space-3); margin-top: var(--space-3); }
.muted-inline { display: block; margin-top: var(--space-2); color: var(--text-muted); font-size: 0.9rem; }
.user-search { margin: var(--space-6) 0; }
.contributor-history-table { padding: 0; box-shadow: none; border: none; }
.thank-you-card { text-align: center; justify-items: center; }
.organizer-list { padding-left: var(--space-5); margin: 0; line-height: 1.9; }
.compact-heading { margin-bottom: 0; }

/* ==========================================================
   Part 5/5: Responsive Breakpoints
   ========================================================== */

/* ----------------------------------------------------------
   TABLET â€” max 1024px
   ---------------------------------------------------------- */
@media (max-width: 1024px) {
  .campaign-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dashboard-status-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dashboard-insight-grid { grid-template-columns: 1fr; }
  .campaign-hub-layout { grid-template-columns: 1fr; }
  .admin-shell { grid-template-columns: minmax(0, 1fr); }
  .fundraiser-shell { grid-template-columns: 220px minmax(0, 1fr); }
}

/* ----------------------------------------------------------
   TABLET/MOBILE â€” max 980px
   ---------------------------------------------------------- */
@media (max-width: 980px) {
  .hero-grid,
  .campaign-detail-grid,
  .donation-layout,
  .payment-layout,
  .form-layout,
  .admin-admins-layout,
  .auth-layout,
  .contributor-layout,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .admin-shell,
  .fundraiser-shell {
    grid-template-columns: 1fr;
  }

  .admin-sidebar,
  .fundraiser-sidebar {
    position: static;
  }

  .dashboard-chart-wrap { height: 280px; min-height: 280px; }

  .settings-summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }

  .section-heading { grid-template-columns: 1fr; }

  .campaign-grid { grid-template-columns: 1fr; }

  .admin-links-grid { grid-template-columns: 1fr; }

  .admin-table-filter { grid-template-columns: 1fr; }

  .toast-stack { left: var(--space-4); right: var(--space-4); width: auto; }
}

/* ----------------------------------------------------------
   MOBILE â€” max 720px
   ---------------------------------------------------------- */
@media (max-width: 720px) {
  :root { --nav-height: 64px; }

  /* Nav: hide desktop links, show hamburger */
  .nav-links { display: none !important; }
  .wallet-dropdown .nav-balance-pill {
    display: inline-flex !important;
    min-height: 38px;
    padding: 0.3rem 0.55rem;
  }
  .wallet-dropdown .nav-balance-pill span {
    display: none;
  }
  .nav-hamburger { display: flex; }

  .hero { padding: 2rem 0 1.5rem; }

  .field-grid,
  .amount-grid,
  .summary-lines,
  .profile-summary,
  .otp-status-row {
    grid-template-columns: 1fr;
  }

  .wallet-filter-bar {
    align-items: stretch;
    flex-direction: column;
  }

  .wallet-filter-grid {
    grid-template-columns: 1fr;
  }

  .amount-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }

  .campaign-meta,
  .progress-text,
  .footer-bottom,
  .dashboard-hero,
  .campaign-public-hero,
  .campaign-public-actions,
  .admin-campaign-head,
  .fundraiser-welcome-head,
  .table-action-row,
  .two-factor-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .filter-row, .action-row { grid-auto-flow: row; }

  .admin-filter-actions,
  .campaign-action-icons,
  .settings-panel-actions { flex-wrap: wrap; }

  .form-card,
  .story-card,
  .donation-sidebar,
  .summary-card,
  .receipt-card,
  .thank-you-card,
  .card,
  .admin-side-panel {
    padding: var(--space-4);
  }

  .admin-sidebar,
  .fundraiser-sidebar { position: static; }

  /* Modal becomes bottom sheet on mobile */
  .verification-modal,
  .confirmation-modal {
    align-items: flex-end;
    padding: var(--space-2);
  }
  .verification-modal-card,
  .confirmation-modal-card {
    width: 100%;
    max-height: calc(100dvh - 1rem);
    padding: var(--space-4);
    animation: modal-slide-up var(--dur-slow) var(--ease-out);
  }
  @keyframes modal-slide-up {
    from { transform: translateY(100%); opacity: 0.6; }
    to   { transform: translateY(0); opacity: 1; }
  }

  .hero-copy h1,
  .form-intro h1,
  .thank-you-card h1,
  .story-card h1,
  .form-card h1 {
    font-size: clamp(1.8rem, 8vw, 3rem);
  }

  .settings-summary-grid { grid-template-columns: 1fr; }

  .admin-admins-layout { grid-template-columns: 1fr; }

  .admin-page-tabs,
  .messaging-subnav,
  .admin-subnav {
    gap: var(--space-2);
    padding: var(--space-3);
  }

  .admin-page-tab,
  .messaging-subnav-link,
  .admin-subnav-link {
    font-size: 0.84rem;
    padding: 0.55rem var(--space-3);
  }

  .campaign-grid { grid-template-columns: 1fr; }
  .campaign-hub-gallery,
  .campaign-detail-cards,
  .payment-metrics,
  .share-action-grid { grid-template-columns: 1fr; }
  .organizer-info-list div { grid-template-columns: 1fr; gap: var(--space-1); }
  .dashboard-status-grid { grid-template-columns: 1fr; }
  .dashboard-summary-card { min-height: 96px; }
  .dashboard-panel-head,
  .dashboard-table-head,
  .active-campaign-row {
    align-items: flex-start;
    flex-direction: column;
  }
  .campaign-filter-form,
  .campaign-filter-form select {
    width: 100%;
  }

  .toast-stack {
    left: var(--space-3);
    right: var(--space-3);
    width: auto;
    top: calc(var(--nav-height) + var(--space-3));
  }

  .section-heading { margin-bottom: var(--space-4); }

  /* Wider buttons on mobile for touch targets */
  .hero-actions .button { width: 100%; justify-content: center; }

  .search-form { flex-direction: column; }
  .search-form input, .search-form .button { width: 100%; }

  .button { min-height: 52px; }
  .button-small, .btn-sm { min-height: 44px; }

  /* Prevent horizontal scroll on tables */
  .dashboard-table { border-radius: var(--radius-lg); }
  .log-pre { font-size: 0.78rem; }
}

/* ----------------------------------------------------------
   SMALL MOBILE â€” max 420px
   ---------------------------------------------------------- */
@media (max-width: 420px) {
  .container { width: calc(100% - 1.5rem); }

  .amount-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }

  .stat-card strong { font-size: 1.4rem; }

  .campaign-body { padding: var(--space-4); }

  .footer-grid { gap: var(--space-5); }
}

/* ----------------------------------------------------------
   BUA ALERT (Custom SweetAlert Replacement)
   ---------------------------------------------------------- */
.bua-alert-overlay {
  position: fixed;
  inset: 0;
  background: var(--modal-overlay, rgba(0, 0, 0, 0.6));
  backdrop-filter: blur(4px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s ease, visibility 0.25s;
  padding: var(--space-4);
}

.bua-alert-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.bua-alert-box {
  background: var(--surface-1);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-6) var(--space-5);
  max-width: 420px;
  width: 100%;
  text-align: center;
  box-shadow: var(--shadow-xl);
  transform: scale(0.9);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.bua-alert-overlay.is-open .bua-alert-box {
  transform: scale(1);
}

.bua-alert-icon {
  width: 72px;
  height: 72px;
  margin: 0 auto var(--space-4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bua-alert-icon svg {
  width: 36px;
  height: 36px;
  stroke-width: 2.5;
}

.bua-alert-icon.warning {
  color: var(--brand-gold);
  background: rgba(230, 168, 23, 0.12);
  border: 3px solid rgba(230, 168, 23, 0.25);
}

.bua-alert-icon.success {
  color: var(--brand-green);
  background: rgba(30, 138, 74, 0.12);
  border: 3px solid rgba(30, 138, 74, 0.25);
}

.bua-alert-icon.error {
  color: #e74c3c;
  background: rgba(231, 76, 60, 0.12);
  border: 3px solid rgba(231, 76, 60, 0.25);
}

.bua-alert-icon.question {
  color: var(--text-muted);
  background: var(--surface-2);
  border: 3px solid var(--border-color);
}

.bua-alert-title {
  font-family: var(--font-display);
  font-size: 1.45rem;
  color: var(--text-primary);
  margin-bottom: var(--space-2);
}

.bua-alert-text {
  color: var(--text-muted);
  font-size: 0.95rem;
  margin-bottom: var(--space-5);
  line-height: 1.5;
}

.bua-alert-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
}

.bua-alert-actions .button {
  flex: 1;
  justify-content: center;
}

@media (max-width: 420px) {
  .bua-alert-actions { flex-direction: column-reverse; }
}

/* ----------------------------------------------------------
   IMMERSIVE AUTHENTICATION LAYOUT (Login/Register)
   ---------------------------------------------------------- */
.immersive-auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  padding: var(--space-4);
  background: var(--surface-1);
}

/* Animated Mesh Gradient Background */
.mesh-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background: var(--surface-1);
}
.mesh-bg::before, .mesh-bg::after, .mesh-orb {
  content: '';
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.5;
  animation: float 20s infinite alternate ease-in-out;
}
.mesh-bg::before {
  width: 600px;
  height: 600px;
  background: rgba(30, 138, 74, 0.4); /* Brand Green */
  top: -100px;
  left: -100px;
}
.mesh-bg::after {
  width: 500px;
  height: 500px;
  background: rgba(230, 168, 23, 0.3); /* Brand Gold */
  bottom: -50px;
  right: -50px;
  animation-delay: -5s;
}
.mesh-orb {
  width: 400px;
  height: 400px;
  background: rgba(12, 22, 16, 0.2);
  top: 40%;
  left: 60%;
  animation-delay: -10s;
}

@keyframes float {
  0% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(50px, 30px) scale(1.05); }
  100% { transform: translate(-30px, 50px) scale(0.95); }
}

[data-theme="dark"] .mesh-bg::before { background: rgba(30, 138, 74, 0.2); }
[data-theme="dark"] .mesh-bg::after { background: rgba(230, 168, 23, 0.15); }
[data-theme="dark"] .mesh-orb { background: rgba(0,0,0, 0.5); }

/* Glassmorphic Card */
.glass-auth-card {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 480px;
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
}

[data-theme="dark"] .glass-auth-card {
  background: rgba(20, 26, 22, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4);
}

.glass-auth-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}

.glass-auth-header .brand {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--text-primary);
  font-size: 1.25rem;
}

.glass-auth-header .brand img {
  height: 32px;
}

.auth-title {
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--text-primary);
  margin-bottom: var(--space-2);
  line-height: 1.2;
}

.auth-subtitle {
  color: var(--text-muted);
  margin-bottom: var(--space-6);
  font-size: 1.05rem;
}

/* Floating Label Inputs */
.floating-label-group {
  position: relative;
  margin-bottom: var(--space-4);
}

.floating-label-group input,
.floating-label-group textarea {
  width: 100%;
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1rem 0.5rem; /* Space for top label */
  font-size: 1rem;
  color: var(--text-primary);
  transition: all var(--dur-normal) var(--ease);
}

[data-theme="dark"] .floating-label-group input,
[data-theme="dark"] .floating-label-group textarea {
  background: rgba(0, 0, 0, 0.2);
}

.floating-label-group input:focus,
.floating-label-group textarea:focus {
  outline: none;
  border-color: var(--brand-green);
  background: var(--surface-1);
  box-shadow: 0 0 0 4px rgba(30, 138, 74, 0.1);
}

.floating-label-group label {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  pointer-events: none;
  transition: all var(--dur-normal) var(--ease);
  font-size: 1rem;
}

/* Trigger floating state when focused or has value */
.floating-label-group input:focus ~ label,
.floating-label-group input:not(:placeholder-shown) ~ label,
.floating-label-group textarea:focus ~ label,
.floating-label-group textarea:not(:placeholder-shown) ~ label {
  top: 1rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--brand-green);
}
.floating-label-group input:not(:focus):not(:placeholder-shown) ~ label,
.floating-label-group textarea:not(:focus):not(:placeholder-shown) ~ label {
  color: var(--text-muted);
}

/* Password Toggle Icon */
.pwd-toggle {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pwd-toggle:hover { color: var(--text-primary); }
.pwd-toggle svg { width: 20px; height: 20px; }

.auth-footer {
  margin-top: var(--space-6);
  text-align: center;
  color: var(--text-muted);
  font-size: 0.95rem;
}
.auth-footer a {
  color: var(--brand-green);
  font-weight: 600;
  text-decoration: none;
}
.auth-footer a:hover { text-decoration: underline; }

/* ==========================================================
   CREATE-CAMPAIGN — Media Upload & Enhanced Form Styles
   ========================================================== */

/* Campaign creation intro panel */
.create-campaign-intro img { display: none; }

.create-steps {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  margin-top: var(--space-5);
}

.create-step {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: rgba(255,255,255,0.45);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(8px);
}

[data-theme="dark"] .create-step {
  background: rgba(0,0,0,0.2);
}

.step-num {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-green), var(--brand-green-deep));
  color: #fff;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 0.9rem;
}

.create-step div { display: flex; flex-direction: column; }
.create-step strong { font-size: 0.88rem; color: var(--text-primary); font-family: var(--font-display); }
.create-step span  { font-size: 0.78rem; color: var(--text-muted); }

/* Organizer card */
.organizer-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--surface-2);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-subtle);
  margin-bottom: var(--space-4);
}

.organizer-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-green), var(--brand-green-deep));
  color: #fff;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: 0.05em;
}

.organizer-info {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.organizer-info strong {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--text-primary);
}

.organizer-info span {
  font-size: 0.84rem;
  color: var(--text-muted);
}

.organizer-bio {
  font-size: 0.9rem;
  margin-bottom: var(--space-4);
}

/* Form section icon */
.section-icon { margin-right: var(--space-2); }

/* Field label enhancements */
.field-label { display: flex; flex-direction: column; gap: var(--space-1); }
.field-label > span em { color: var(--color-danger-tx); font-style: normal; margin-left: 0.1rem; }
.field-label.has-error input,
.field-label.has-error select,
.field-label.has-error textarea {
  border-color: var(--color-danger-bd) !important;
  background: rgba(185, 28, 28, 0.03);
}

small.field-error { color: var(--color-danger-tx); font-weight: 600; }

/* Input with prefix (GHS symbol) */
.input-with-prefix {
  position: relative;
  display: flex;
  align-items: center;
}

.input-prefix {
  position: absolute;
  left: var(--space-4);
  color: var(--text-muted);
  font-weight: 700;
  font-size: 0.95rem;
  pointer-events: none;
  z-index: 1;
}

.input-with-prefix input {
  padding-left: 3.2rem;
  width: 100%;
}

/* Textarea footer (char count) */
.textarea-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.char-count {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-faint);
  white-space: nowrap;
}

/* ── Media Block ────────────────────────────────────── */
.media-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.media-step-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

@media (max-width: 980px) {
  .media-step-grid {
    grid-template-columns: 1fr;
  }
}

.media-block-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
}

.media-block-header > div strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--text-primary);
  margin-bottom: 0.3rem;
}

.media-block-header > div p {
  font-size: 0.87rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
}

.media-badge {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--brand-green-light);
  color: var(--brand-green-deep);
  border: 1px solid rgba(26,138,74,0.18);
}

.video-badge {
  background: var(--brand-gold-light);
  color: var(--brand-gold-deep);
  border-color: rgba(230,168,23,0.22);
}

.badge-optional {
  display: inline-block;
  margin-left: var(--space-2);
  padding: 0.15rem 0.55rem;
  border-radius: var(--radius-full);
  font-size: 0.7rem;
  font-weight: 700;
  background: var(--surface-2);
  color: var(--text-muted);
  vertical-align: middle;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ── Drop Zone ────────────────────────────────────── */
.drop-zone {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 140px;
  padding: var(--space-6) var(--space-4);
  border: 2px dashed var(--border-color);
  border-radius: var(--radius-xl);
  background: var(--surface-2);
  cursor: pointer;
  text-align: center;
  transition: border-color var(--dur-fast) var(--ease),
              background var(--dur-fast) var(--ease),
              transform var(--dur-fast) var(--ease-spring);
  outline: none;
}

.drop-zone:hover,
.drop-zone:focus,
.drop-zone-active {
  border-color: var(--brand-green);
  background: var(--brand-green-light);
  transform: scale(1.008);
}

.drop-zone-error {
  border-color: var(--color-danger-bd) !important;
  background: var(--color-danger-bg) !important;
}

.drop-zone-has-files {
  border-style: solid;
  border-color: var(--brand-green);
  background: rgba(26, 138, 74, 0.06);
}

.drop-zone-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.drop-zone-icon {
  font-size: 2.2rem;
  line-height: 1;
  transition: transform var(--dur-base) var(--ease-spring);
}

.drop-zone:hover .drop-zone-icon,
.drop-zone-active .drop-zone-icon { transform: scale(1.15) translateY(-2px); }

.drop-zone-title {
  font-family: var(--font-display);
  font-size: 0.98rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}

.drop-zone-hint {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin: 0;
}

.drop-zone-link {
  color: var(--brand-green);
  font-weight: 700;
  text-decoration: underline;
  cursor: pointer;
}

.video-drop-zone { min-height: 120px; }

/* ── Image Preview Grid ─────────────────────────── */
.image-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
}

.img-preview-item {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--surface-3);
  box-shadow: var(--shadow-sm);
}

.img-preview-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--dur-slow) var(--ease);
}

.img-preview-item:hover img { transform: scale(1.04); }

.img-badge {
  position: absolute;
  bottom: var(--space-2);
  left: var(--space-2);
  padding: 0.18rem 0.55rem;
  border-radius: var(--radius-full);
  background: rgba(0,0,0,0.55);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  backdrop-filter: blur(4px);
}

/* ── Video Preview ──────────────────────────────── */
.video-preview-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--surface-2);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
}

.video-preview-wrap[hidden],
.video-duration-bar[hidden] {
  display: none !important;
}

.video-preview-wrap video {
  width: 100%;
  border-radius: var(--radius-lg);
  max-height: 260px;
  background: #000;
  outline: none;
}

.video-preview-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--text-muted);
}

.video-remove-btn {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.4rem 0.9rem;
  border-radius: var(--radius-md);
  background: var(--color-danger-bg);
  border: 1px solid var(--color-danger-bd);
  color: var(--color-danger-tx);
  font-size: 0.84rem;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease);
}

.video-remove-btn:hover { background: rgba(185, 28, 28, 0.15); }

/* Duration bar */
.video-duration-bar {
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--surface-3);
  overflow: hidden;
}

.video-duration-fill {
  height: 100%;
  border-radius: var(--radius-full);
  background: var(--brand-green);
  transition: width 0.6s var(--ease-out), background 0.3s var(--ease);
}

/* ── Submit Row ─────────────────────────────────── */
.form-submit-row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
  margin-top: var(--space-2);
}

.button-lg {
  font-size: 1.05rem;
  padding: 0.95rem 2.2rem;
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}

.btn-icon { font-size: 1.2rem; transition: transform var(--dur-fast) var(--ease-spring); }
.button-lg:hover:not(:disabled) .btn-icon { transform: translateX(4px) rotate(-15deg); }

.submit-note {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin: 0;
}

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 640px) {
  .create-steps { grid-template-columns: 1fr; }
  .image-preview-grid { grid-template-columns: repeat(2, 1fr); }
  .media-block-header { flex-direction: column; }
}

/* ==========================================================
   CAMPAIGN WIZARD
   ========================================================== */

/* ── Auth Gate ─────────────────────────────────── */
.wizard-auth-gate {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  align-items: center;
  min-height: 60vh;
  padding: var(--space-8) 0;
}

.wizard-auth-hero { display: flex; flex-direction: column; gap: var(--space-5); }
.wizard-auth-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 800;
  line-height: 1.08;
  color: var(--text-primary);
  margin: 0;
}
.wizard-auth-hero p { font-size: 1.08rem; color: var(--text-muted); margin: 0; }
.wizard-auth-bullets { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-2); }
.wizard-auth-bullet {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: 0.95rem;
  color: var(--text-muted);
}
.wizard-auth-bullet-icon {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  background: var(--brand-green-light);
  border-radius: var(--radius-sm);
  font-size: 1rem;
  flex-shrink: 0;
}
.wizard-auth-card {
  background: var(--surface-1);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: var(--space-10) var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  text-align: center;
}
.wizard-auth-card h2 {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
}
.wizard-auth-card p { color: var(--text-muted); font-size: 0.9rem; margin: 0; }
.wizard-auth-divider {
  display: flex; align-items: center; gap: var(--space-3);
  color: var(--text-faint); font-size: 0.82rem;
}
.wizard-auth-divider::before,
.wizard-auth-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--border-subtle);
}

/* ── Wizard Shell ──────────────────────────────── */
.wizard-shell {
  width: 100%;
  padding-bottom: var(--space-16);
}

.wizard-page-title {
  text-align: center;
  margin-bottom: var(--space-10);
  padding: var(--space-8) var(--space-4) 0;
}
.wizard-page-title h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  color: var(--text-primary);
  margin: 0 0 var(--space-3);
  line-height: 1.1;
}
.wizard-page-title p { color: var(--text-muted); margin: 0; font-size: 1.05rem; line-height: 1.55; }

/* ── Progress Indicator ────────────────────────── */
.wizard-progress {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
  max-width: 680px;
  margin-inline: auto;
  margin-bottom: var(--space-8);
}

.wizard-track-wrap {
  position: relative;
  height: 5px;
  background: var(--surface-3);
  border-radius: var(--radius-full);
  overflow: hidden;
}
.wizard-track-fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: linear-gradient(90deg, var(--brand-green) 0%, #12703c 100%);
  border-radius: var(--radius-full);
  transition: width 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}

.wizard-steps-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-2);
}

.wizard-step-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  background: none;
  border: none;
  cursor: default;
  padding: var(--space-1) 0;
  pointer-events: none;
}
.wizard-step-btn.clickable { pointer-events: auto; cursor: pointer; }

.wizard-step-dot {
  width: 36px; height: 36px;
  border-radius: var(--radius-full);
  background: var(--surface-3);
  border: 2px solid var(--border-color);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text-faint);
  transition: background var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), color var(--dur-base) var(--ease), box-shadow var(--dur-base) var(--ease);
}
.wizard-step-btn.active .wizard-step-dot {
  background: var(--brand-green);
  border-color: var(--brand-green);
  color: #fff;
  box-shadow: 0 0 0 5px rgba(26, 138, 74, 0.18);
}
.wizard-step-btn.done .wizard-step-dot {
  background: var(--color-success-bg);
  border-color: var(--color-success-bd);
  color: var(--color-success-tx);
}
.wizard-step-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-faint);
  text-align: center;
  transition: color var(--dur-base) var(--ease);
  letter-spacing: 0.01em;
}
.wizard-step-btn.active .wizard-step-label { color: var(--brand-green); font-weight: 700; }
.wizard-step-btn.done .wizard-step-label { color: var(--text-muted); }

/* ── Wizard Card ───────────────────────────────── */
.wizard-card {
  background: var(--surface-1);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: var(--space-10) var(--space-10);
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
}

.wizard-section-head {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--border-subtle);
}
.wizard-section-head h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
  line-height: 1.2;
}
.wizard-section-head p { color: var(--text-muted); font-size: 0.93rem; margin: 0; line-height: 1.5; }

/* ── Panel visibility ──────────────────────────── */
.wizard-panel { display: none; }
.wizard-panel.active { display: flex; flex-direction: column; gap: var(--space-8); }

/* ── For-Cards (who is it for) ─────────────────── */
.for-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 360px));
  gap: var(--space-5);
  justify-content: center;
}

.for-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-8) var(--space-4);
  border: 2px solid var(--border-color);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
  cursor: pointer;
  text-align: center;
  transition:
    border-color var(--dur-base) var(--ease),
    background var(--dur-base) var(--ease),
    box-shadow var(--dur-base) var(--ease),
    transform var(--dur-fast) var(--ease-spring);
  user-select: none;
  min-height: 148px;
  justify-content: center;
}
.for-card:hover {
  border-color: var(--brand-green);
  background: var(--brand-green-light);
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}
.for-card.selected {
  border-color: var(--brand-green);
  background: var(--brand-green-light);
  box-shadow: 0 0 0 4px rgba(26, 138, 74, 0.18), var(--shadow-sm);
}
.for-card-icon { font-size: 2.8rem; line-height: 1; }
.for-card-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
}
.for-card-desc { font-size: 0.8rem; color: var(--text-muted); line-height: 1.4; }

/* ── Category Grid ─────────────────────────────── */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
}

.cat-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border: 2px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--surface-2);
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
  transition:
    border-color var(--dur-base) var(--ease),
    background var(--dur-base) var(--ease),
    transform var(--dur-fast) var(--ease-spring),
    box-shadow var(--dur-base) var(--ease);
  user-select: none;
}
.cat-card:hover {
  border-color: var(--brand-green);
  background: var(--brand-green-light);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.cat-card.selected {
  border-color: var(--brand-green);
  background: var(--brand-green-light);
  box-shadow: 0 0 0 4px rgba(26, 138, 74, 0.18);
}
.cat-card-icon { font-size: 1.5rem; flex-shrink: 0; }

/* ── Wizard Nav ────────────────────────────────── */
.wizard-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-6);
  border-top: 1px solid var(--border-subtle);
}
.wizard-nav-left { display: flex; align-items: center; gap: var(--space-3); }
.wizard-nav-right { display: flex; align-items: center; gap: var(--space-3); }

/* ── Story / Step 3 ────────────────────────────── */
.story-textarea-wrap { position: relative; }
.story-textarea {
  min-height: 260px;
  resize: vertical;
  font-size: 1rem;
  line-height: 1.7;
}

.ai-rewrite-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.65rem 1.3rem;
  background: linear-gradient(135deg, #6d28d9 0%, #4c1d95 100%);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease-spring);
  white-space: nowrap;
}
.ai-rewrite-btn:hover { opacity: 0.88; transform: translateY(-1px); }
.ai-rewrite-btn:disabled { opacity: 0.55; cursor: not-allowed; transform: none; }
.ai-rewrite-btn .ai-spinner {
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: ai-spin 0.7s linear infinite;
  display: none;
}
.ai-rewrite-btn.loading .ai-spinner { display: block; }
.ai-rewrite-btn.loading .ai-btn-icon { display: none; }
@keyframes ai-spin { to { transform: rotate(360deg); } }

.story-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-2);
}
.story-char-count { font-size: 0.8rem; color: var(--text-faint); font-weight: 600; }

.field-input-action {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.field-input-action input {
  flex: 1 1 320px;
  min-width: 0;
}
.field-input-action .ai-rewrite-btn {
  flex: 0 0 auto;
}

/* Wizard final actions */
.wizard-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-subtle);
}
.wizard-actions-spacer { flex: 1; }

.btn-draft {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 0.75rem 1.4rem;
  background: var(--surface-2);
  color: var(--text-primary);
  border: 1.5px solid var(--border-color);
  border-radius: var(--btn-radius);
  font-weight: 700; font-size: 0.92rem;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.btn-draft:hover { background: var(--surface-3); border-color: var(--brand-green); }

.btn-preview {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 0.75rem 1.4rem;
  background: transparent;
  color: var(--brand-green);
  border: 2px solid var(--brand-green);
  border-radius: var(--btn-radius);
  font-weight: 700; font-size: 0.92rem;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.btn-preview:hover { background: var(--brand-green-light); }

/* ── Preview Modal ─────────────────────────────── */
.preview-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.62);
  z-index: 900;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}
.preview-overlay:not([hidden]) {
  display: flex;
}
[data-theme="dark"] .preview-overlay { background: rgba(0,0,0,0.75); }

.preview-modal-box {
  background: var(--surface-1);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 860px;
  max-height: 88vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.preview-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--border-subtle);
  position: sticky;
  top: 0;
  background: var(--surface-1);
  z-index: 1;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}
.preview-modal-header h3 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}
.preview-close-btn {
  width: 36px; height: 36px;
  background: var(--surface-2);
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  color: var(--text-muted);
  transition: background var(--dur-fast) var(--ease);
}
.preview-close-btn:hover { background: var(--surface-3); color: var(--text-primary); }

.preview-body {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 0;
}

.preview-main { padding: var(--space-6); border-right: 1px solid var(--border-subtle); }
.preview-sidebar { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-4); }

.preview-gallery-slot {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface-2);
  aspect-ratio: 16/9;
  margin-bottom: var(--space-5);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-faint);
  font-size: 0.88rem;
}
.preview-gallery-slot img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.preview-category-pill {
  display: inline-block;
  padding: 0.2rem 0.8rem;
  background: var(--brand-green-light);
  color: var(--brand-green-deep);
  border-radius: var(--radius-full);
  font-size: 0.8rem;
  font-weight: 700;
  margin-bottom: var(--space-3);
}
.preview-title {
  font-family: var(--font-display);
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0 0 var(--space-4);
  line-height: 1.15;
}
.preview-story {
  font-size: 0.95rem;
  color: var(--text-muted);
  line-height: 1.75;
  white-space: pre-wrap;
  word-break: break-word;
}
.preview-goal-label { font-size: 0.8rem; color: var(--text-faint); font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; }
.preview-goal-amount {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
}
.preview-organizer-block { display: flex; flex-direction: column; gap: var(--space-1); font-size: 0.88rem; }
.preview-organizer-block strong { color: var(--text-primary); font-weight: 700; }
.preview-organizer-block span { color: var(--text-muted); }
.preview-badge {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 0.45rem 0.9rem;
  background: var(--color-warning-bg);
  border: 1px solid var(--color-warning-bd);
  border-radius: var(--radius-sm);
  font-size: 0.8rem;
  color: var(--color-warning-tx);
}

/* ── Page background tint ──────────────────────── */
.wizard-page-bg { background: var(--surface-0); }
[data-theme="dark"] .wizard-page-bg { background: var(--surface-0); }

/* ── Responsive ────────────────────────────────── */
@media (max-width: 768px) {
  .wizard-auth-gate { grid-template-columns: 1fr; }
  .preview-body { grid-template-columns: 1fr; }
  .preview-sidebar { border-top: 1px solid var(--border-subtle); }
  .preview-main { border-right: none; }
  .wizard-card { padding: var(--space-8) var(--space-6); gap: var(--space-8); }
  .wizard-steps-row { grid-template-columns: repeat(5, 1fr); }
  .wizard-step-label { font-size: 0.7rem; }
}
@media (max-width: 640px) {
  .for-cards { grid-template-columns: 1fr; gap: var(--space-3); }
  .for-card { flex-direction: row; min-height: auto; padding: var(--space-4) var(--space-5); text-align: left; }
  .for-card-icon { font-size: 2rem; }
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .wizard-card { padding: var(--space-6) var(--space-5); gap: var(--space-6); }
  .wizard-page-title { padding-top: var(--space-4); margin-bottom: var(--space-6); }
  .wizard-page-title h1 { font-size: 1.8rem; }
  .wizard-steps-row { gap: var(--space-1); }
  .wizard-step-dot { width: 28px; height: 28px; font-size: 0.75rem; }
  .wizard-step-label { font-size: 0.65rem; }
  .wizard-actions { flex-direction: column-reverse; align-items: stretch; }
  .wizard-actions > * { width: 100%; justify-content: center; }
  .wizard-actions-spacer { display: none; }
}

/* ----------------------------------------------------------
   ADMIN USER PROFILE PAGE
   ---------------------------------------------------------- */
.admin-user-page { display: flex; flex-direction: column; gap: var(--space-8); }
.admin-user-back { font-size: 0.88rem; font-weight: 600; color: var(--text-muted); text-decoration: none; }
.admin-user-back:hover { color: var(--text-primary); }
.admin-user-header { display: flex; flex-direction: column; gap: var(--space-5); }
.admin-user-identity { display: flex; justify-content: space-between; align-items: center; gap: var(--space-5); }
.admin-user-identity-left { display: flex; gap: var(--space-5); align-items: flex-start; min-width: 0; flex: 1; }
.admin-user-avatar { width: 64px; height: 64px; border-radius: var(--radius-full); background: var(--brand-green); color: #fff; font-family: var(--font-display); font-weight: 800; font-size: 1.35rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; letter-spacing: 0.03em; }
.admin-user-identity-body { display: flex; flex-direction: column; gap: var(--space-2); min-width: 0; }
.admin-user-identity-top { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.admin-user-identity-top h1 { margin: 0; font-size: clamp(1.5rem, 3vw, 2rem); line-height: 1.1; }
.admin-user-meta { display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-2) var(--space-4); font-size: 0.9rem; color: var(--text-muted); }
.admin-user-grid { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); gap: var(--space-12); align-items: start; }
.admin-user-section-head { margin-bottom: var(--space-5); }
.admin-user-section-head .eyebrow { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 700; color: var(--text-muted); display: block; margin-bottom: var(--space-1); }
.admin-user-section-head h2 { margin: 0; font-family: var(--font-display); font-size: 1.25rem; }
.admin-user-banner-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; flex-shrink: 0; }
.admin-user-controls { display: flex; flex-direction: column; gap: var(--space-5); }
.admin-user-control-section { display: flex; flex-direction: column; gap: var(--space-4); }
.admin-user-control-section h2 { margin: 0 0 var(--space-1); font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--text-primary); }
@media (max-width: 768px) {
  .admin-user-grid { grid-template-columns: 1fr; gap: var(--space-8); }
  .admin-user-avatar { width: 52px; height: 52px; font-size: 1.1rem; }
}

/* ----------------------------------------------------------
   ADMIN USERS TABBED INTERFACE
   ---------------------------------------------------------- */
.admin-users-tabbed { padding: 0; overflow: hidden; }
.admin-tab-nav { display: flex; border-bottom: 1px solid var(--border-color); background: var(--surface-2); border-radius: var(--radius-xl) var(--radius-xl) 0 0; overflow: hidden; }
.admin-tab-btn { flex: 1; padding: var(--space-4) var(--space-5); border: none; border-right: 1px solid var(--border-color); background: transparent; font-weight: 700; font-family: var(--font-display); font-size: 0.88rem; color: var(--text-muted); cursor: pointer; transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); letter-spacing: 0.01em; }
.admin-tab-btn:last-child { border-right: none; }
.admin-tab-btn:hover { background: var(--surface-1); color: var(--text-primary); }
.admin-tab-btn.active { background: var(--surface-1); color: var(--brand-green); box-shadow: inset 0 -2px 0 var(--brand-green); }
.admin-tab-panel { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-5); }
.admin-tab-panel[hidden] { display: none; }
.admin-blacklist-toolbar { display: flex; align-items: flex-end; gap: var(--space-4); flex-wrap: wrap; }
.admin-blacklist-toolbar .admin-table-filter { flex: 1; min-width: 0; }
.blacklist-type-hint { display: block; font-size: 0.82rem; margin-top: var(--space-1); min-height: 1.1em; }
.blacklist-type-hint.hint-ok  { color: var(--brand-green); }
.blacklist-type-hint.hint-err { color: var(--color-danger-tx); }
#blacklistAddModal.confirmation-modal { display: none; }
#blacklistAddModal.confirmation-modal.is-open { display: grid; }
#blacklistAddModal.confirmation-modal {
  padding: clamp(0.75rem, 2vh, var(--space-4));
  align-items: center;
}
#blacklistAddModal .confirmation-modal-card {
  width: min(460px, calc(100vw - 1.5rem));
  max-height: calc(100vh - 1.5rem);
  overflow-y: auto;
  padding: clamp(var(--space-4), 3vh, var(--space-6));
}
#blacklistAddModal .confirmation-modal-card h2 {
  font-size: clamp(1.25rem, 2.5vw, 1.7rem);
  margin-bottom: var(--space-3);
}
#blacklistAddModal .confirmation-modal-card p {
  margin-bottom: var(--space-4) !important;
}
#blacklistAddModal .confirmation-modal-actions {
  margin-top: var(--space-4);
}
@media (max-width: 768px) {
  .admin-tab-btn { padding: var(--space-3) var(--space-3); font-size: 0.8rem; }
  .admin-blacklist-toolbar { flex-direction: column; align-items: stretch; }
}
@media (max-width: 480px) {
  .admin-tab-nav { flex-wrap: wrap; }
  .admin-tab-btn { border-right: none; border-bottom: 1px solid var(--border-color); flex-basis: 100%; }
  .admin-tab-btn:last-child { border-bottom: none; }
}

/* ----------------------------------------------------------
   ADMIN DASHBOARD
   ---------------------------------------------------------- */
.admin-dash-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
.admin-attention-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.admin-attention-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  min-height: 104px;
  padding: var(--space-4);
  border: 1px solid var(--border-color);
  border-left: 4px solid var(--brand-green);
  border-radius: var(--radius-lg);
  background: var(--surface-1);
  box-shadow: var(--shadow-sm);
  color: var(--text-primary);
}
.admin-attention-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.admin-attention-count {
  min-width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--surface-2);
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 800;
}
.admin-attention-card strong {
  display: block;
  font-size: 0.92rem;
}
.admin-attention-card small {
  display: block;
  margin-top: var(--space-1);
  color: var(--text-muted);
  font-size: 0.78rem;
  line-height: 1.35;
}
.attention-warning { border-left-color: var(--brand-gold); }
.attention-danger { border-left-color: var(--color-danger-tx); }
.attention-info { border-left-color: #3da5ff; }
.admin-dash-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.admin-dash-card-head {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}
.admin-dash-icon {
  width: 44px; height: 44px;
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.admin-dash-icon svg {
  width: 22px; height: 22px;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.adc-green { background: var(--brand-green-light); color: var(--brand-green); }
.adc-gold  { background: #fef3c7; color: #d97706; }
.adc-blue  { background: #dbeafe; color: #2563eb; }
.adc-red   { background: #fee2e2; color: #dc2626; }
[data-theme="dark"] .adc-gold { background: rgba(217,119,6,0.15); color: #fbbf24; }
[data-theme="dark"] .adc-blue { background: rgba(37,99,235,0.15); color: #60a5fa; }
[data-theme="dark"] .adc-red  { background: rgba(220,38,38,0.15); color: #f87171; }
.admin-dash-card-title {
  font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em;
  font-weight: 700; color: var(--text-muted); margin-bottom: var(--space-1);
}
.admin-dash-stat {
  font-family: var(--font-display); font-size: 1.9rem;
  font-weight: 800; color: var(--text-primary); line-height: 1;
}
.admin-dash-stat-sm { font-size: 1.35rem; }
.admin-dash-breakdown {
  display: flex; flex-direction: column; gap: var(--space-2);
  margin-top: var(--space-2); padding-top: var(--space-3);
  border-top: 1px solid var(--border-subtle);
}
.adb-row { display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; }
.adb-row span { color: var(--text-muted); }
.adb-row strong { color: var(--text-primary); font-weight: 700; }
.admin-dash-section-head { margin-bottom: var(--space-1); }
.admin-dash-section-head h2 {
  font-family: var(--font-display); font-size: 1.15rem;
  font-weight: 800; margin: 0 0 var(--space-1);
  color: var(--text-primary);
}
.admin-dash-charts-row {
  display: grid;
  grid-template-columns: 1fr 1.65fr;
  gap: var(--space-5);
}
.admin-dash-chart-card { display: flex; flex-direction: column; gap: var(--space-4); }
.admin-dash-chart-wrap { position: relative; height: 300px; min-height: 300px; width: 100%; }
.admin-dash-pie-wrap { height: 320px; min-height: 320px; }
@media (max-width: 1100px) {
  .admin-attention-grid { grid-template-columns: repeat(2, 1fr); }
  .admin-dash-summary-grid { grid-template-columns: repeat(2, 1fr); }
  .admin-dash-charts-row { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .admin-attention-grid { grid-template-columns: 1fr; }
  .admin-dash-summary-grid { grid-template-columns: 1fr; }
  .admin-dash-stat { font-size: 1.6rem; }
}

/* ----------------------------------------------------------
   FUNDRAISER FAQ ASSISTANT
   ---------------------------------------------------------- */
.faq-chat-widget {
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  z-index: 80;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-3);
}
.faq-chat-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  border: 0;
  border-radius: var(--radius-full);
  padding: 0.85rem 1rem;
  background: var(--brand-green);
  color: #fff;
  box-shadow: 0 18px 42px rgba(15,79,43,0.28);
  cursor: pointer;
  font-weight: 800;
}
.faq-chat-toggle span {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.18);
  font-family: var(--font-display);
}
.faq-chat-panel {
  width: min(380px, calc(100vw - 2rem));
  max-height: min(640px, calc(100vh - 7rem));
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-color);
  background: var(--surface-1);
  box-shadow: 0 24px 70px rgba(15,79,43,0.22);
}
.faq-chat-panel[hidden] { display: none; }
.faq-chat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
}
.faq-chat-head h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1rem;
}
.faq-chat-close {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-full);
  border: 1px solid var(--border-color);
  background: var(--surface-2);
  color: var(--text-primary);
  cursor: pointer;
  font-size: 1.2rem;
  line-height: 1;
}
.faq-chat-messages {
  flex: 1;
  min-height: 220px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
}
.faq-chat-message {
  max-width: 86%;
  padding: 0.78rem 0.9rem;
  border-radius: var(--radius-md);
  font-size: 0.92rem;
  line-height: 1.45;
}
.faq-chat-message.bot {
  align-self: flex-start;
  background: var(--surface-2);
  color: var(--text-primary);
}
.faq-chat-message.thinking {
  display: inline-flex;
  align-items: center;
  gap: 0.28rem;
  min-width: 58px;
}
.faq-chat-message.thinking span {
  width: 7px;
  height: 7px;
  border-radius: var(--radius-full);
  background: var(--text-muted);
  opacity: 0.45;
  animation: faq-chat-thinking 1s ease-in-out infinite;
}
.faq-chat-message.thinking span:nth-child(2) { animation-delay: 0.16s; }
.faq-chat-message.thinking span:nth-child(3) { animation-delay: 0.32s; }
.faq-chat-message.user {
  align-self: flex-end;
  background: var(--brand-green);
  color: #fff;
}
.faq-chat-prompts {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: 0 var(--space-4) var(--space-3);
}
.faq-chat-prompts button {
  border: 1px solid var(--border-color);
  border-radius: var(--radius-full);
  background: var(--surface-2);
  color: var(--text-primary);
  padding: 0.48rem 0.7rem;
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
}
.faq-chat-form {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-4);
  border-top: 1px solid var(--border-subtle);
}
.faq-chat-form input {
  flex: 1;
  min-width: 0;
}
.faq-chat-form button {
  white-space: nowrap;
}
.faq-chat-form button:disabled,
.faq-chat-form input:disabled {
  opacity: 0.65;
  cursor: wait;
}
@keyframes faq-chat-thinking {
  0%, 80%, 100% { transform: translateY(0); opacity: 0.35; }
  40% { transform: translateY(-4px); opacity: 0.9; }
}
@media (max-width: 520px) {
  .faq-chat-widget {
    right: 0.75rem;
    bottom: 0.75rem;
  }
  .faq-chat-panel {
    width: calc(100vw - 1.5rem);
    max-height: calc(100vh - 5rem);
  }
}
